Commit d6f66f61 authored by Simon Shields's avatar Simon Shields Committed by Dmitry Torokhov

Input: tm2-touchkey - add support for midas touchkey

The touchkey on midas boards is almost identical.
The only real difference is that it uses the same register for both
keycode and base.
Signed-off-by: default avatarSimon Shields <simon@lineageos.org>
Signed-off-by: default avatarPaweł Chmiel <pawel.mikolaj.chmiel@gmail.com>
Reviewed-by: default avatarRob Herring <robh@kernel.org>
Signed-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
parent e9eb788f
Samsung tm2-touchkey Samsung tm2-touchkey
Required properties: Required properties:
- compatible: must be "cypress,tm2-touchkey" - compatible:
* "cypress,tm2-touchkey" - for the touchkey found on the tm2 board
* "cypress,midas-touchkey" - for the touchkey found on midas boards
- reg: I2C address of the chip. - reg: I2C address of the chip.
- interrupt-parent: a phandle for the interrupt controller (see interrupt - interrupt-parent: a phandle for the interrupt controller (see interrupt
binding[0]). binding[0]).
......
...@@ -22,12 +22,12 @@ ...@@ -22,12 +22,12 @@
#include <linux/leds.h> #include <linux/leds.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_device.h>
#include <linux/pm.h> #include <linux/pm.h>
#include <linux/regulator/consumer.h> #include <linux/regulator/consumer.h>
#define TM2_TOUCHKEY_DEV_NAME "tm2-touchkey" #define TM2_TOUCHKEY_DEV_NAME "tm2-touchkey"
#define TM2_TOUCHKEY_KEYCODE_REG 0x03
#define TM2_TOUCHKEY_BASE_REG 0x00
#define TM2_TOUCHKEY_CMD_LED_ON 0x10 #define TM2_TOUCHKEY_CMD_LED_ON 0x10
#define TM2_TOUCHKEY_CMD_LED_OFF 0x20 #define TM2_TOUCHKEY_CMD_LED_OFF 0x20
#define TM2_TOUCHKEY_BIT_PRESS_EV BIT(3) #define TM2_TOUCHKEY_BIT_PRESS_EV BIT(3)
...@@ -40,12 +40,28 @@ enum { ...@@ -40,12 +40,28 @@ enum {
TM2_TOUCHKEY_KEY_BACK, TM2_TOUCHKEY_KEY_BACK,
}; };
struct touchkey_variant {
u8 keycode_reg;
u8 base_reg;
};
struct tm2_touchkey_data { struct tm2_touchkey_data {
struct i2c_client *client; struct i2c_client *client;
struct input_dev *input_dev; struct input_dev *input_dev;
struct led_classdev led_dev; struct led_classdev led_dev;
struct regulator *vdd; struct regulator *vdd;
struct regulator_bulk_data regulators[2]; struct regulator_bulk_data regulators[2];
const struct touchkey_variant *variant;
};
static const struct touchkey_variant tm2_touchkey_variant = {
.keycode_reg = 0x03,
.base_reg = 0x00,
};
static const struct touchkey_variant midas_touchkey_variant = {
.keycode_reg = 0x00,
.base_reg = 0x00,
}; };
static void tm2_touchkey_led_brightness_set(struct led_classdev *led_dev, static void tm2_touchkey_led_brightness_set(struct led_classdev *led_dev,
...@@ -66,7 +82,7 @@ static void tm2_touchkey_led_brightness_set(struct led_classdev *led_dev, ...@@ -66,7 +82,7 @@ static void tm2_touchkey_led_brightness_set(struct led_classdev *led_dev,
regulator_set_voltage(touchkey->vdd, volt, volt); regulator_set_voltage(touchkey->vdd, volt, volt);
i2c_smbus_write_byte_data(touchkey->client, i2c_smbus_write_byte_data(touchkey->client,
TM2_TOUCHKEY_BASE_REG, data); touchkey->variant->base_reg, data);
} }
static int tm2_touchkey_power_enable(struct tm2_touchkey_data *touchkey) static int tm2_touchkey_power_enable(struct tm2_touchkey_data *touchkey)
...@@ -99,7 +115,7 @@ static irqreturn_t tm2_touchkey_irq_handler(int irq, void *devid) ...@@ -99,7 +115,7 @@ static irqreturn_t tm2_touchkey_irq_handler(int irq, void *devid)
int key; int key;
data = i2c_smbus_read_byte_data(touchkey->client, data = i2c_smbus_read_byte_data(touchkey->client,
TM2_TOUCHKEY_KEYCODE_REG); touchkey->variant->keycode_reg);
if (data < 0) { if (data < 0) {
dev_err(&touchkey->client->dev, dev_err(&touchkey->client->dev,
"failed to read i2c data: %d\n", data); "failed to read i2c data: %d\n", data);
...@@ -153,6 +169,8 @@ static int tm2_touchkey_probe(struct i2c_client *client, ...@@ -153,6 +169,8 @@ static int tm2_touchkey_probe(struct i2c_client *client,
touchkey->client = client; touchkey->client = client;
i2c_set_clientdata(client, touchkey); i2c_set_clientdata(client, touchkey);
touchkey->variant = of_device_get_match_data(&client->dev);
touchkey->regulators[0].supply = "vcc"; touchkey->regulators[0].supply = "vcc";
touchkey->regulators[1].supply = "vdd"; touchkey->regulators[1].supply = "vdd";
error = devm_regulator_bulk_get(&client->dev, error = devm_regulator_bulk_get(&client->dev,
...@@ -262,7 +280,13 @@ static const struct i2c_device_id tm2_touchkey_id_table[] = { ...@@ -262,7 +280,13 @@ static const struct i2c_device_id tm2_touchkey_id_table[] = {
MODULE_DEVICE_TABLE(i2c, tm2_touchkey_id_table); MODULE_DEVICE_TABLE(i2c, tm2_touchkey_id_table);
static const struct of_device_id tm2_touchkey_of_match[] = { static const struct of_device_id tm2_touchkey_of_match[] = {
{ .compatible = "cypress,tm2-touchkey", }, {
.compatible = "cypress,tm2-touchkey",
.data = &tm2_touchkey_variant,
}, {
.compatible = "cypress,midas-touchkey",
.data = &midas_touchkey_variant,
},
{ }, { },
}; };
MODULE_DEVICE_TABLE(of, tm2_touchkey_of_match); MODULE_DEVICE_TABLE(of, tm2_touchkey_of_match);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment