[PATCH 1/1] mfd: delay to mask tsc irq in max8925
Samuel Ortiz
sameo at linux.intel.com
Sun May 9 17:28:11 EDT 2010
Hi Haojian,
On Wed, Apr 28, 2010 at 08:55:53AM -0400, Haojian Zhuang wrote:
> From 07243e51659a11946a149a5f4a74322cfd840c35 Mon Sep 17 00:00:00 2001
> From: Haojian Zhuang <haojian.zhuang at marvell.com>
> Date: Tue, 27 Apr 2010 14:55:28 -0400
> Subject: [PATCH] mfd: delay to mask tsc irq in max8925
>
> There're two IRQ pins output from MAX8925. One is PMIC interrupt, the other
> is TSC interrupt. But they're sharing one irq chip.
>
> After initializing MAX8925 interrupts, unexpected TSC interrupt may occur and
> it can't be cleared if touch driver isn't loaded.
>
> Now move the operation of masking TSC interrupt behind requesting PMIC
> interrupt. If touch driver isn't loaded, this interrupt is always masked.
Patch applied to my for-next branch, thanks.
Cheers,
Samuel.
> Signed-off-by: Haojian Zhuang <haojian.zhuang at marvell.com>
> ---
> drivers/mfd/max8925-core.c | 7 +++++--
> 1 files changed, 5 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/mfd/max8925-core.c b/drivers/mfd/max8925-core.c
> index 85d63c0..f621bce 100644
> --- a/drivers/mfd/max8925-core.c
> +++ b/drivers/mfd/max8925-core.c
> @@ -508,7 +508,7 @@ static int max8925_irq_init(struct max8925_chip
> *chip, int irq,
> max8925_reg_read(chip->i2c, MAX8925_ON_OFF_IRQ2);
> max8925_reg_read(chip->rtc, MAX8925_RTC_IRQ);
> max8925_reg_read(chip->adc, MAX8925_TSC_IRQ);
> - /* mask all interrupts */
> + /* mask all interrupts except for TSC */
> max8925_reg_write(chip->rtc, MAX8925_ALARM0_CNTL, 0);
> max8925_reg_write(chip->rtc, MAX8925_ALARM1_CNTL, 0);
> max8925_reg_write(chip->i2c, MAX8925_CHG_IRQ1_MASK, 0xff);
> @@ -516,7 +516,6 @@ static int max8925_irq_init(struct max8925_chip
> *chip, int irq,
> max8925_reg_write(chip->i2c, MAX8925_ON_OFF_IRQ1_MASK, 0xff);
> max8925_reg_write(chip->i2c, MAX8925_ON_OFF_IRQ2_MASK, 0xff);
> max8925_reg_write(chip->rtc, MAX8925_RTC_IRQ_MASK, 0xff);
> - max8925_reg_write(chip->adc, MAX8925_TSC_IRQ_MASK, 0xff);
>
> mutex_init(&chip->irq_lock);
> chip->core_irq = irq;
> @@ -547,7 +546,11 @@ static int max8925_irq_init(struct max8925_chip
> *chip, int irq,
> dev_err(chip->dev, "Failed to request core IRQ: %d\n", ret);
> chip->core_irq = 0;
> }
> +
> tsc_irq:
> + /* mask TSC interrupt */
> + max8925_reg_write(chip->adc, MAX8925_TSC_IRQ_MASK, 0x0f);
> +
> if (!pdata->tsc_irq) {
> dev_warn(chip->dev, "No interrupt support on TSC IRQ\n");
> return 0;
> --
> 1.5.6.5
--
Intel Open Source Technology Centre
http://oss.intel.com/
More information about the linux-arm-kernel
mailing list