mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-09 07:23:14 +00:00
767d83361a
The Nokia 770 is using GPIOs from the global numberspace on the
CBUS node to pass down to the LCD controller. This regresses when we
let the OMAP GPIO driver use dynamic GPIO base.
The Nokia 770 now has dynamic allocation of IRQ numbers, so this
needs to be fixed for it to work.
As this is the only user of LCD MIPID we can easily augment the
driver to use a GPIO descriptor instead and resolve the issue.
The platform data .shutdown() callback wasn't even used in the
code, but we encode a shutdown asserting RESET in the remove()
callback for completeness sake.
The CBUS also has the ADS7846 touchscreen attached.
Populate the devices on the Nokia 770 CBUS I2C using software
nodes instead of platform data quirks. This includes the LCD
and the ADS7846 touchscreen so the conversion just brings the LCD
along with it as software nodes is an all-or-nothing design
pattern.
The ADS7846 has some limited support for using GPIO descriptors,
let's convert it over completely to using device properties and then
fix all remaining boardfile users to provide all platform data using
software nodes.
Dump the of includes and of_match_ptr() in the ADS7846 driver as part
of the job.
Since we have to move ADS7846 over to obtaining the GPIOs it is
using exclusively from descriptors, we provide descriptor tables
for the two remaining in-kernel boardfiles using ADS7846:
- PXA Spitz
- MIPS Alchemy DB1000 development board
It was too hard for me to include software node conversion of
these two remaining users at this time: the spitz is using a
hscync callback in the platform data that would require further
GPIO descriptor conversion of the Spitz, and moving the hsync
callback down into the driver: it will just become too big of
a job, but it can be done separately.
The MIPS Alchemy DB1000 is simply something I cannot test, so take
the easier approach of just providing some GPIO descriptors in
this case as I don't want the patch to grow too intrusive.
As we see that several device trees have incorrect polarity flags
and just expect to bypass the gpiolib polarity handling, fix up
all device trees too, in a separate patch.
Suggested-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Fixes: 92bf78b33b
("gpio: omap: use dynamic allocation of base")
Acked-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Reviewed-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
46 lines
1.4 KiB
C
46 lines
1.4 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/* linux/spi/ads7846.h */
|
|
|
|
struct ads7846_platform_data {
|
|
u16 model; /* 7843, 7845, 7846, 7873. */
|
|
u16 vref_delay_usecs; /* 0 for external vref; etc */
|
|
u16 vref_mv; /* external vref value, milliVolts
|
|
* ads7846: if 0, use internal vref */
|
|
bool keep_vref_on; /* set to keep vref on for differential
|
|
* measurements as well */
|
|
bool swap_xy; /* swap x and y axes */
|
|
|
|
/* Settling time of the analog signals; a function of Vcc and the
|
|
* capacitance on the X/Y drivers. If set to non-zero, two samples
|
|
* are taken with settle_delay us apart, and the second one is used.
|
|
* ~150 uSec with 0.01uF caps.
|
|
*/
|
|
u16 settle_delay_usecs;
|
|
|
|
/* If set to non-zero, after samples are taken this delay is applied
|
|
* and penirq is rechecked, to help avoid false events. This value
|
|
* is affected by the material used to build the touch layer.
|
|
*/
|
|
u16 penirq_recheck_delay_usecs;
|
|
|
|
u16 x_plate_ohms;
|
|
u16 y_plate_ohms;
|
|
|
|
u16 x_min, x_max;
|
|
u16 y_min, y_max;
|
|
u16 pressure_min, pressure_max;
|
|
|
|
u16 debounce_max; /* max number of additional readings
|
|
* per sample */
|
|
u16 debounce_tol; /* tolerance used for filtering */
|
|
u16 debounce_rep; /* additional consecutive good readings
|
|
* required after the first two */
|
|
int gpio_pendown_debounce; /* platform specific debounce time for
|
|
* the gpio_pendown */
|
|
int (*get_pendown_state)(void);
|
|
void (*wait_for_sync)(void);
|
|
bool wakeup;
|
|
unsigned long irq_flags;
|
|
};
|
|
|