On Fri, Jul 17, 2009 at 04:45:21PM +0200, Marek Vasut wrote: > From 1ea286d088993e05b5b374a08ee6f933242d3561 Mon Sep 17 00:00:00 2001 > From: Marek Vasut <marek.vasut@xxxxxxxxx> > Date: Thu, 4 Jun 2009 21:56:59 +0200 > Subject: [PATCH 2/2] Add possibility to control the GPIO_STATUS shift > > This patch allows tweaking the behaviour of GPIO_STATUS register > shift quirk that's in wm97xx-core. The problem with GPIO_STATUS > register being shifted by one doesn't appear on all hardware it > seems and causes problems with accelerated touchscreen drivers on > Palm hardware. Therefore an accelerated touchscreen driver can select > if the shift is/isn't happening on the hardware. Acked-by: Mark Brown <broonie@xxxxxxxxxxxxxxxxxxxxxxxxxxx> > > Signed-off-by: Marek Vasut <marek.vasut@xxxxxxxxx> > --- > drivers/input/touchscreen/mainstone-wm97xx.c | 3 +++ > drivers/input/touchscreen/wm97xx-core.c | 6 ++++-- > include/linux/wm97xx.h | 7 +++++++ > 3 files changed, 14 insertions(+), 2 deletions(-) > > diff --git a/drivers/input/touchscreen/mainstone-wm97xx.c b/drivers/input/touchscreen/mainstone-wm97xx.c > index de02f87..e000ab3 100644 > --- a/drivers/input/touchscreen/mainstone-wm97xx.c > +++ b/drivers/input/touchscreen/mainstone-wm97xx.c > @@ -198,6 +198,9 @@ static int wm97xx_acc_startup(struct wm97xx *wm) > if (machine_is_palmt5() || machine_is_palmtx() || machine_is_palmld()) { > pen_int = 1; > irq = 27; > + /* There is some obscure mutant of WM9712 interbred with WM9713 > + * used on Palm HW */ > + wm->variant = WM97xx_WM1613; > } else if (machine_is_mainstone() && pen_int) > irq = 4; > > diff --git a/drivers/input/touchscreen/wm97xx-core.c b/drivers/input/touchscreen/wm97xx-core.c > index 2957d48..252eb11 100644 > --- a/drivers/input/touchscreen/wm97xx-core.c > +++ b/drivers/input/touchscreen/wm97xx-core.c > @@ -204,7 +204,7 @@ void wm97xx_set_gpio(struct wm97xx *wm, u32 gpio, > else > reg &= ~gpio; > > - if (wm->id == WM9712_ID2) > + if (wm->id == WM9712_ID2 && wm->variant != WM97xx_WM1613) > wm97xx_reg_write(wm, AC97_GPIO_STATUS, reg << 1); > else > wm97xx_reg_write(wm, AC97_GPIO_STATUS, reg); > @@ -307,7 +307,7 @@ static void wm97xx_pen_irq_worker(struct work_struct *work) > WM97XX_GPIO_13); > } > > - if (wm->id == WM9712_ID2) > + if (wm->id == WM9712_ID2 && wm->variant != WM97xx_WM1613) > wm97xx_reg_write(wm, AC97_GPIO_STATUS, (status & > ~WM97XX_GPIO_13) << 1); > else > @@ -582,6 +582,8 @@ static int wm97xx_probe(struct device *dev) > > wm->id = wm97xx_reg_read(wm, AC97_VENDOR_ID2); > > + wm->variant = WM97xx_GENERIC; > + > dev_info(wm->dev, "detected a wm97%02x codec\n", wm->id & 0xff); > > switch (wm->id & 0xff) { > diff --git a/include/linux/wm97xx.h b/include/linux/wm97xx.h > index 6f69968..0c98781 100644 > --- a/include/linux/wm97xx.h > +++ b/include/linux/wm97xx.h > @@ -16,6 +16,12 @@ > #include <linux/platform_device.h> > > /* > + * WM97xx variants > + */ > +#define WM97xx_GENERIC 0x0000 > +#define WM97xx_WM1613 0x1613 > + > +/* > * WM97xx AC97 Touchscreen registers > */ > #define AC97_WM97XX_DIGITISER1 0x76 > @@ -283,6 +289,7 @@ struct wm97xx { > unsigned pen_is_down:1; /* Pen is down */ > unsigned aux_waiting:1; /* aux measurement waiting */ > unsigned pen_probably_down:1; /* used in polling mode */ > + u16 variant; /* WM97xx chip variant */ > u16 suspend_mode; /* PRP in suspend mode */ > }; > > -- > 1.6.3.3 > _______________________________________________ Alsa-devel mailing list Alsa-devel@xxxxxxxxxxxxxxxx http://mailman.alsa-project.org/mailman/listinfo/alsa-devel