Commit 562b42d3 authored by Andrew Duggan's avatar Andrew Duggan Committed by Dmitry Torokhov

Input: synaptics-rmi4 - add support for F30

RMI4 F30 supports input from clickpad buttons and controls LEDs located
on the touchpad PCB. This patch adds support of the clickpad buttons and
defers supporting LEDs for the future.
Signed-off-by: default avatarAndrew Duggan <aduggan@synaptics.com>
Signed-off-by: default avatarBenjamin Tissoires <benjamin.tissoires@redhat.com>
Tested-by: default avatarBenjamin Tissoires <benjamin.tissoires@redhat.com>
Tested-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Tested-by: default avatarBjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
parent b43d2c1e
...@@ -43,3 +43,12 @@ config RMI4_F12 ...@@ -43,3 +43,12 @@ config RMI4_F12
Function 12 provides 2D multifinger pointing for touchscreens and Function 12 provides 2D multifinger pointing for touchscreens and
touchpads. For sensors that support relative pointing, F12 also touchpads. For sensors that support relative pointing, F12 also
provides mouse input. provides mouse input.
config RMI4_F30
bool "RMI4 Function 30 (GPIO LED)"
depends on RMI4_CORE
help
Say Y here if you want to add support for RMI4 function 30.
Function 30 provides GPIO and LED support for RMI4 devices. This
includes support for buttons on TouchPads and ClickPads.
...@@ -6,6 +6,7 @@ rmi_core-$(CONFIG_RMI4_2D_SENSOR) += rmi_2d_sensor.o ...@@ -6,6 +6,7 @@ rmi_core-$(CONFIG_RMI4_2D_SENSOR) += rmi_2d_sensor.o
# Function drivers # Function drivers
rmi_core-$(CONFIG_RMI4_F11) += rmi_f11.o rmi_core-$(CONFIG_RMI4_F11) += rmi_f11.o
rmi_core-$(CONFIG_RMI4_F12) += rmi_f12.o rmi_core-$(CONFIG_RMI4_F12) += rmi_f12.o
rmi_core-$(CONFIG_RMI4_F30) += rmi_f30.o
# Transports # Transports
obj-$(CONFIG_RMI4_I2C) += rmi_i2c.o obj-$(CONFIG_RMI4_I2C) += rmi_i2c.o
...@@ -312,6 +312,9 @@ static struct rmi_function_handler *fn_handlers[] = { ...@@ -312,6 +312,9 @@ static struct rmi_function_handler *fn_handlers[] = {
#ifdef CONFIG_RMI4_F12 #ifdef CONFIG_RMI4_F12
&rmi_f12_handler, &rmi_f12_handler,
#endif #endif
#ifdef CONFIG_RMI4_F30
&rmi_f30_handler,
#endif
}; };
static void __rmi_unregister_function_handlers(int start_idx) static void __rmi_unregister_function_handlers(int start_idx)
......
...@@ -101,4 +101,5 @@ char *rmi_f01_get_product_ID(struct rmi_function *fn); ...@@ -101,4 +101,5 @@ char *rmi_f01_get_product_ID(struct rmi_function *fn);
extern struct rmi_function_handler rmi_f01_handler; extern struct rmi_function_handler rmi_f01_handler;
extern struct rmi_function_handler rmi_f11_handler; extern struct rmi_function_handler rmi_f11_handler;
extern struct rmi_function_handler rmi_f12_handler; extern struct rmi_function_handler rmi_f12_handler;
extern struct rmi_function_handler rmi_f30_handler;
#endif #endif
This diff is collapsed.
...@@ -101,6 +101,21 @@ struct rmi_2d_sensor_platform_data { ...@@ -101,6 +101,21 @@ struct rmi_2d_sensor_platform_data {
int dmax; int dmax;
}; };
/**
* struct rmi_f30_data - overrides defaults for a single F30 GPIOs/LED chip.
* @buttonpad - the touchpad is a buttonpad, so enable only the first actual
* button that is found.
* @trackstick_buttons - Set when the function 30 is handling the physical
* buttons of the trackstick (as a PD/2 passthrough device.
* @disable - the touchpad incorrectly reports F30 and it should be ignored.
* This is a special case which is due to misconfigured firmware.
*/
struct rmi_f30_data {
bool buttonpad;
bool trackstick_buttons;
bool disable;
};
/** /**
* struct rmi_f01_power - override default power management settings. * struct rmi_f01_power - override default power management settings.
* *
...@@ -147,6 +162,7 @@ struct rmi_device_platform_data { ...@@ -147,6 +162,7 @@ struct rmi_device_platform_data {
/* function handler pdata */ /* function handler pdata */
struct rmi_2d_sensor_platform_data *sensor_pdata; struct rmi_2d_sensor_platform_data *sensor_pdata;
struct rmi_f01_power_management power_management; struct rmi_f01_power_management power_management;
struct rmi_f30_data *f30_data;
}; };
/** /**
......
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