Thread (18 messages) 18 messages, 2 authors, 2015-08-25

[PATCH-v6 5/6] mfd: 88pm800: Set default interrupt clear method

From: Lee Jones <hidden>
Date: 2015-08-25 09:30:53
Also in: lkml

On Tue, 25 Aug 2015, Vaibhav Hiremath wrote:
On Tuesday 25 August 2015 02:00 PM, Lee Jones wrote:
quoted
On Mon, 24 Aug 2015, Vaibhav Hiremath wrote:
quoted
On Monday 24 August 2015 09:21 PM, Lee Jones wrote:
quoted
On Mon, 24 Aug 2015, Vaibhav Hiremath wrote:
quoted
On Monday 24 August 2015 07:24 PM, Lee Jones wrote:
quoted
On Wed, 08 Jul 2015, Vaibhav Hiremath wrote:
quoted
As per the spec, bit 1 (INT_CLEAR_MODE) of reg addr 0xe
(page 0) controls the method of clearing interrupt
status of 88pm800 family of devices;

  0: clear on read
  1: clear on write

If pdata is not coming from board file, then set the
default irq clear method to "irq clear on write"

Also, as suggested by "Lee Jones" renaming variable field
to appropriate name and removed unnecessary field
pm80x_chip.irq_mode, using platform_data.irq_clr_method.

Signed-off-by: Zhao Ye <redacted>
Signed-off-by: Vaibhav Hiremath <redacted>
Reviewed-by: Krzysztof Kozlowski <redacted>
---
 drivers/mfd/88pm800.c       | 15 ++++++++++-----
 include/linux/mfd/88pm80x.h |  9 +++++++--
 2 files changed, 17 insertions(+), 7 deletions(-)
[...]
quoted
quoted
If you are OK with it, I will spin another version and submit it.
If you can't use the value directly, which if you want to pull the
value from DT you can't, then either use the method above, or
something like this might be better:

int clear_on_write = 0;

if (pdata->clear_irq_on_write)
   clear_on_write = PM800_WAKEUP2_INT_WRITE_CLEAR;

.. this way you only need to add one new define and you can drop
PM800_WAKEUP2_INT_READ_CLEAR altogether.  This is better, because it
will aid you to move to the BIT() macro easier (there is no BIT()
value for shifting 0's).
Just to clarify, I will adopt this implementation.
Sounds good.  Although, I would suggest just using 'val' as the local
variable.  It makes it more clear that PM800_WAKEUP2_INT_WRITE_CLEAR
is a bit value.

-- 
Lee Jones
Linaro STMicroelectronics Landing Team Lead
Linaro.org ? Open source software for ARM SoCs
Follow Linaro: Facebook | Twitter | Blog
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help