提交 2cefdb1f 编写于 作者: N Nick Dyer 提交者: Dmitry Torokhov

Input: atmel_mxt_ts - remove unnecessary platform data

It is not necessary to download these values to the maXTouch chip on every
probe, since they are stored in NVRAM. It makes life difficult when tuning
the device to keep them in sync with the config array/file, and requires a
new kernel build for minor tweaks.

These parameters only represent a tiny subset of the available
configuration options, tracking all of these options in platform data would
be a endless task. In addition, different versions of maXTouch chips may
have these values in different places or may not even have them at all.

Having these values also makes life more complex for device tree and other
platforms where having to define a static configuration isn't helpful.
Signed-off-by: NNick Dyer <nick.dyer@itdev.co.uk>
Acked-by: NBenson Leung <bleung@chromium.org>
Acked-by: NYufeng Shen <miletus@chromium.org>
Signed-off-by: NDmitry Torokhov <dmitry.torokhov@gmail.com>
上级 7cdcb8d1
...@@ -239,13 +239,8 @@ static void __init goni_radio_init(void) ...@@ -239,13 +239,8 @@ static void __init goni_radio_init(void)
/* TSP */ /* TSP */
static struct mxt_platform_data qt602240_platform_data = { static struct mxt_platform_data qt602240_platform_data = {
.x_line = 17,
.y_line = 11,
.x_size = 800, .x_size = 800,
.y_size = 480, .y_size = 480,
.blen = 0x21,
.threshold = 0x28,
.voltage = 2800000, /* 2.8V */
.orient = MXT_DIAGONAL, .orient = MXT_DIAGONAL,
.irqflags = IRQF_TRIGGER_FALLING, .irqflags = IRQF_TRIGGER_FALLING,
}; };
......
...@@ -685,54 +685,6 @@ static int mxt_make_highchg(struct mxt_data *data) ...@@ -685,54 +685,6 @@ static int mxt_make_highchg(struct mxt_data *data)
return 0; return 0;
} }
static void mxt_handle_pdata(struct mxt_data *data)
{
const struct mxt_platform_data *pdata = data->pdata;
u8 voltage;
/* Set touchscreen lines */
mxt_write_object(data, MXT_TOUCH_MULTI_T9, MXT_TOUCH_XSIZE,
pdata->x_line);
mxt_write_object(data, MXT_TOUCH_MULTI_T9, MXT_TOUCH_YSIZE,
pdata->y_line);
/* Set touchscreen orient */
mxt_write_object(data, MXT_TOUCH_MULTI_T9, MXT_TOUCH_ORIENT,
pdata->orient);
/* Set touchscreen burst length */
mxt_write_object(data, MXT_TOUCH_MULTI_T9,
MXT_TOUCH_BLEN, pdata->blen);
/* Set touchscreen threshold */
mxt_write_object(data, MXT_TOUCH_MULTI_T9,
MXT_TOUCH_TCHTHR, pdata->threshold);
/* Set touchscreen resolution */
mxt_write_object(data, MXT_TOUCH_MULTI_T9,
MXT_TOUCH_XRANGE_LSB, (pdata->x_size - 1) & 0xff);
mxt_write_object(data, MXT_TOUCH_MULTI_T9,
MXT_TOUCH_XRANGE_MSB, (pdata->x_size - 1) >> 8);
mxt_write_object(data, MXT_TOUCH_MULTI_T9,
MXT_TOUCH_YRANGE_LSB, (pdata->y_size - 1) & 0xff);
mxt_write_object(data, MXT_TOUCH_MULTI_T9,
MXT_TOUCH_YRANGE_MSB, (pdata->y_size - 1) >> 8);
/* Set touchscreen voltage */
if (pdata->voltage) {
if (pdata->voltage < MXT_VOLTAGE_DEFAULT) {
voltage = (MXT_VOLTAGE_DEFAULT - pdata->voltage) /
MXT_VOLTAGE_STEP;
voltage = 0xff - voltage + 1;
} else
voltage = (pdata->voltage - MXT_VOLTAGE_DEFAULT) /
MXT_VOLTAGE_STEP;
mxt_write_object(data, MXT_SPT_CTECONFIG_T28,
MXT_CTE_VOLTAGE, voltage);
}
}
static int mxt_get_info(struct mxt_data *data) static int mxt_get_info(struct mxt_data *data)
{ {
struct i2c_client *client = data->client; struct i2c_client *client = data->client;
...@@ -840,8 +792,6 @@ static int mxt_initialize(struct mxt_data *data) ...@@ -840,8 +792,6 @@ static int mxt_initialize(struct mxt_data *data)
if (error) if (error)
goto err_free_object_table; goto err_free_object_table;
mxt_handle_pdata(data);
/* Backup to memory */ /* Backup to memory */
mxt_write_object(data, MXT_GEN_COMMAND_T6, mxt_write_object(data, MXT_GEN_COMMAND_T6,
MXT_COMMAND_BACKUPNV, MXT_COMMAND_BACKUPNV,
......
...@@ -85,13 +85,8 @@ static struct i2c_board_info tsl2563_als_device = { ...@@ -85,13 +85,8 @@ static struct i2c_board_info tsl2563_als_device = {
}; };
static struct mxt_platform_data atmel_224s_tp_platform_data = { static struct mxt_platform_data atmel_224s_tp_platform_data = {
.x_line = 18,
.y_line = 12,
.x_size = 102*20, .x_size = 102*20,
.y_size = 68*20, .y_size = 68*20,
.blen = 0x80, /* Gain setting is in upper 4 bits */
.threshold = 0x32,
.voltage = 0, /* 3.3V */
.orient = MXT_VERTICAL_FLIP, .orient = MXT_VERTICAL_FLIP,
.irqflags = IRQF_TRIGGER_FALLING, .irqflags = IRQF_TRIGGER_FALLING,
.is_tp = true, .is_tp = true,
...@@ -110,13 +105,8 @@ static struct i2c_board_info atmel_224s_tp_device = { ...@@ -110,13 +105,8 @@ static struct i2c_board_info atmel_224s_tp_device = {
}; };
static struct mxt_platform_data atmel_1664s_platform_data = { static struct mxt_platform_data atmel_1664s_platform_data = {
.x_line = 32,
.y_line = 50,
.x_size = 1700, .x_size = 1700,
.y_size = 2560, .y_size = 2560,
.blen = 0x89, /* Gain setting is in upper 4 bits */
.threshold = 0x28,
.voltage = 0, /* 3.3V */
.orient = MXT_ROTATED_90_COUNTER, .orient = MXT_ROTATED_90_COUNTER,
.irqflags = IRQF_TRIGGER_FALLING, .irqflags = IRQF_TRIGGER_FALLING,
.is_tp = false, .is_tp = false,
......
...@@ -33,14 +33,10 @@ struct mxt_platform_data { ...@@ -33,14 +33,10 @@ struct mxt_platform_data {
const u8 *config; const u8 *config;
size_t config_length; size_t config_length;
unsigned int x_line;
unsigned int y_line;
unsigned int x_size; unsigned int x_size;
unsigned int y_size; unsigned int y_size;
unsigned int blen;
unsigned int threshold;
unsigned int voltage;
unsigned char orient; unsigned char orient;
unsigned long irqflags; unsigned long irqflags;
bool is_tp; bool is_tp;
const unsigned int key_map[MXT_NUM_GPIO]; const unsigned int key_map[MXT_NUM_GPIO];
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册