Thread (12 messages) 12 messages, 3 authors, 2010-09-05

Re: [PATCH v2 4/6 RESEND] ARM: pxa27x_keypad: added wakeup event handler for keypad interrupts

From: Mark F. Brown <hidden>
Date: 2010-09-05 15:28:57
Also in: linux-arm-kernel, lkml

On Sun, Sep 5, 2010 at 6:46 AM, Eric Miao [off-list ref] wrote:
On Sun, Sep 5, 2010 at 4:02 PM, Igor Grinberg [off-list ref] wrote:
quoted
 On 09/04/10 01:28, Mark F. Brown wrote:
quoted
mach-mmp needs to clear wake event in order to clear the keypad interrupt

Signed-off-by: Mark F. Brown <redacted>
---
 arch/arm/plat-pxa/include/plat/pxa27x_keypad.h |    1 +
 drivers/input/keyboard/pxa27x_keypad.c         |   10 ++++++++++
 2 files changed, 11 insertions(+), 0 deletions(-)
diff --git a/arch/arm/plat-pxa/include/plat/pxa27x_keypad.h b/arch/arm/plat-pxa/include/plat/pxa27x_keypad.h
index 7b4eadc..73dacda 100644
--- a/arch/arm/plat-pxa/include/plat/pxa27x_keypad.h
+++ b/arch/arm/plat-pxa/include/plat/pxa27x_keypad.h
@@ -52,6 +52,7 @@ struct pxa27x_keypad_platform_data {
      /* key debounce interval */
      unsigned int    debounce_interval;
+     void            (*clear_wakeup_event)(void);
I understand, this is a bit late... but still I want to ask a question:
As I understand, the clear_wakeup_event() function is called in interrupt context,
wouldn't it be wiser to add a comment on this, so platform (current/future) code
will be aware and will make no heavy stuff in it (accidentally).
A comment will be good to have indeed, not just explaining the context
this function will be running, but also a bit about why this is introduced.

Mark,

If you come up with an updated patch, I'll help rebase my tree.
quoted
quoted
 };

 extern void pxa_set_keypad_info(struct pxa27x_keypad_platform_data *info);
diff --git a/drivers/input/keyboard/pxa27x_keypad.c b/drivers/input/keyboard/pxa27x_keypad.c
index 0610d10..b36d2be 100644
--- a/drivers/input/keyboard/pxa27x_keypad.c
+++ b/drivers/input/keyboard/pxa27x_keypad.c
@@ -330,11 +330,21 @@ static void pxa27x_keypad_scan_direct(struct pxa27x_keypad *keypad)
      keypad->direct_key_state = new_state;
 }

+static void clear_wakeup_event(struct pxa27x_keypad *keypad)
+{
+     struct pxa27x_keypad_platform_data *pdata = keypad->pdata;
+
+     if (pdata->clear_wakeup_event)
+             (pdata->clear_wakeup_event)();
+}
+
 static irqreturn_t pxa27x_keypad_irq_handler(int irq, void *dev_id)
 {
      struct pxa27x_keypad *keypad = dev_id;
      unsigned long kpc = keypad_readl(KPC);

+     clear_wakeup_event(keypad);
+
      if (kpc & KPC_DI)
              pxa27x_keypad_scan_direct(keypad);
--
Regards,
Igor.
Ok will do!

-- Mark
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help