From: lee.jones@linaro.org (Lee Jones)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH-V5 3/4] mfd: 88pm800: Set default interrupt clear method
Date: Tue, 7 Jul 2015 08:29:58 +0100 [thread overview]
Message-ID: <20150707072958.GN3182@x1> (raw)
In-Reply-To: <1435591877-18214-4-git-send-email-vaibhav.hiremath@linaro.org>
On Mon, 29 Jun 2015, Vaibhav Hiremath wrote:
> 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.
>
> Signed-off-by: Zhao Ye <zhaoy@marvell.com>
> Signed-off-by: Vaibhav Hiremath <vaibhav.hiremath@linaro.org>
> ---
> drivers/mfd/88pm800.c | 15 ++++++++++-----
> include/linux/mfd/88pm80x.h | 10 ++++++++--
> 2 files changed, 18 insertions(+), 7 deletions(-)
>
> diff --git a/drivers/mfd/88pm800.c b/drivers/mfd/88pm800.c
> index d495737..66347be 100644
> --- a/drivers/mfd/88pm800.c
> +++ b/drivers/mfd/88pm800.c
> @@ -374,7 +374,7 @@ static int device_irq_init_800(struct pm80x_chip *chip)
> {
> struct regmap *map = chip->regmap;
> unsigned long flags = IRQF_ONESHOT;
> - int data, mask, ret = -EINVAL;
> + int irq_clr_mode, mask, ret = -EINVAL;
>
> if (!map || !chip->irq) {
> dev_err(chip->dev, "incorrect parameters\n");
> @@ -382,15 +382,16 @@ static int device_irq_init_800(struct pm80x_chip *chip)
> }
>
> /*
> - * irq_mode defines the way of clearing interrupt. it's read-clear by
> - * default.
> + * irq_clr_on_wr defines the way of clearing interrupt by
> + * read/write(0/1). It's read-clear by default.
> */
> mask =
> PM800_WAKEUP2_INV_INT | PM800_WAKEUP2_INT_CLEAR |
> PM800_WAKEUP2_INT_MASK;
>
> - data = PM800_WAKEUP2_INT_CLEAR;
> - ret = regmap_update_bits(map, PM800_WAKEUP2, mask, data);
> + irq_clr_mode = chip->irq_clr_method == PM800_IRQ_CLR_ON_WRITE ?
> + PM800_WAKEUP2_INT_WRITE_CLEAR : PM800_WAKEUP2_INT_READ_CLEAR;
> + ret = regmap_update_bits(map, PM800_WAKEUP2, mask, irq_clr_mode);
What's stopping you just passing PM800_WAKEUP2_INT_WRITE_CLEAR or
PM800_WAKEUP2_INT_READ_CLEAR from pdata? Then you can use the value
directly without all of this faffing about.
regmap_update_bits(map, PM800_WAKEUP2, mask, pdata->irq_clr_mode);
> if (ret < 0)
> goto out;
> @@ -512,6 +513,7 @@ static int device_800_init(struct pm80x_chip *chip,
> }
>
> chip->regmap_irq_chip = &pm800_irq_chip;
> + chip->irq_clr_method = pdata->irq_clr_method;
>
> ret = device_irq_init_800(chip);
> if (ret < 0) {
> @@ -564,6 +566,9 @@ static int pm800_probe(struct i2c_client *client,
> pdata = devm_kzalloc(&client->dev, sizeof(*pdata), GFP_KERNEL);
> if (!pdata)
> return -ENOMEM;
> +
> + /* by default, set irq clear method on write */
> + pdata->irq_clr_method = PM800_IRQ_CLR_ON_WRITE;
> }
>
> ret = pm80x_init(client);
> diff --git a/include/linux/mfd/88pm80x.h b/include/linux/mfd/88pm80x.h
> index 8fcad63..648e01a 100644
> --- a/include/linux/mfd/88pm80x.h
> +++ b/include/linux/mfd/88pm80x.h
> @@ -77,6 +77,8 @@ enum {
> #define PM800_WAKEUP2 (0x0E)
> #define PM800_WAKEUP2_INV_INT BIT(0)
> #define PM800_WAKEUP2_INT_CLEAR BIT(1)
> +#define PM800_WAKEUP2_INT_READ_CLEAR (0 << 1)
> +#define PM800_WAKEUP2_INT_WRITE_CLEAR (1 << 1)
> #define PM800_WAKEUP2_INT_MASK BIT(2)
>
> #define PM800_POWER_UP_LOG (0x10)
> @@ -300,7 +302,11 @@ struct pm80x_chip {
> struct regmap_irq_chip_data *irq_data;
> int type;
> int irq;
> - int irq_mode;
> +
> +#define PM800_IRQ_CLR_ON_READ 0
> +#define PM800_IRQ_CLR_ON_WRITE 1
Defines in the middle of structs makes for ugly code.
> + bool irq_clr_method; /* '1': Clear on write, '0': Clear on read */
> unsigned long wu_flag;
> spinlock_t lock;
> };
> @@ -315,7 +321,7 @@ struct pm80x_platform_data {
> */
> struct regulator_init_data *regulators[PM800_ID_RG_MAX];
> unsigned int num_regulators;
> - int irq_mode; /* Clear interrupt by read/write(0/1) */
> + bool irq_clr_method; /* Clear interrupt by read/write(0/1) */
> int batt_det; /* enable/disable */
> int (*plat_config)(struct pm80x_chip *chip,
> struct pm80x_platform_data *pdata);
--
Lee Jones
Linaro STMicroelectronics Landing Team Lead
Linaro.org ? Open source software for ARM SoCs
Follow Linaro: Facebook | Twitter | Blog
WARNING: multiple messages have this Message-ID (diff)
From: Lee Jones <lee.jones@linaro.org>
To: Vaibhav Hiremath <vaibhav.hiremath@linaro.org>
Cc: linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org,
robh+dt@kernel.org, sameo@linux.intel.com,
linux-kernel@vger.kernel.org, yizhang@marvell.com,
Zhao Ye <zhaoy@marvell.com>
Subject: Re: [PATCH-V5 3/4] mfd: 88pm800: Set default interrupt clear method
Date: Tue, 7 Jul 2015 08:29:58 +0100 [thread overview]
Message-ID: <20150707072958.GN3182@x1> (raw)
In-Reply-To: <1435591877-18214-4-git-send-email-vaibhav.hiremath@linaro.org>
On Mon, 29 Jun 2015, Vaibhav Hiremath wrote:
> 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.
>
> Signed-off-by: Zhao Ye <zhaoy@marvell.com>
> Signed-off-by: Vaibhav Hiremath <vaibhav.hiremath@linaro.org>
> ---
> drivers/mfd/88pm800.c | 15 ++++++++++-----
> include/linux/mfd/88pm80x.h | 10 ++++++++--
> 2 files changed, 18 insertions(+), 7 deletions(-)
>
> diff --git a/drivers/mfd/88pm800.c b/drivers/mfd/88pm800.c
> index d495737..66347be 100644
> --- a/drivers/mfd/88pm800.c
> +++ b/drivers/mfd/88pm800.c
> @@ -374,7 +374,7 @@ static int device_irq_init_800(struct pm80x_chip *chip)
> {
> struct regmap *map = chip->regmap;
> unsigned long flags = IRQF_ONESHOT;
> - int data, mask, ret = -EINVAL;
> + int irq_clr_mode, mask, ret = -EINVAL;
>
> if (!map || !chip->irq) {
> dev_err(chip->dev, "incorrect parameters\n");
> @@ -382,15 +382,16 @@ static int device_irq_init_800(struct pm80x_chip *chip)
> }
>
> /*
> - * irq_mode defines the way of clearing interrupt. it's read-clear by
> - * default.
> + * irq_clr_on_wr defines the way of clearing interrupt by
> + * read/write(0/1). It's read-clear by default.
> */
> mask =
> PM800_WAKEUP2_INV_INT | PM800_WAKEUP2_INT_CLEAR |
> PM800_WAKEUP2_INT_MASK;
>
> - data = PM800_WAKEUP2_INT_CLEAR;
> - ret = regmap_update_bits(map, PM800_WAKEUP2, mask, data);
> + irq_clr_mode = chip->irq_clr_method == PM800_IRQ_CLR_ON_WRITE ?
> + PM800_WAKEUP2_INT_WRITE_CLEAR : PM800_WAKEUP2_INT_READ_CLEAR;
> + ret = regmap_update_bits(map, PM800_WAKEUP2, mask, irq_clr_mode);
What's stopping you just passing PM800_WAKEUP2_INT_WRITE_CLEAR or
PM800_WAKEUP2_INT_READ_CLEAR from pdata? Then you can use the value
directly without all of this faffing about.
regmap_update_bits(map, PM800_WAKEUP2, mask, pdata->irq_clr_mode);
> if (ret < 0)
> goto out;
> @@ -512,6 +513,7 @@ static int device_800_init(struct pm80x_chip *chip,
> }
>
> chip->regmap_irq_chip = &pm800_irq_chip;
> + chip->irq_clr_method = pdata->irq_clr_method;
>
> ret = device_irq_init_800(chip);
> if (ret < 0) {
> @@ -564,6 +566,9 @@ static int pm800_probe(struct i2c_client *client,
> pdata = devm_kzalloc(&client->dev, sizeof(*pdata), GFP_KERNEL);
> if (!pdata)
> return -ENOMEM;
> +
> + /* by default, set irq clear method on write */
> + pdata->irq_clr_method = PM800_IRQ_CLR_ON_WRITE;
> }
>
> ret = pm80x_init(client);
> diff --git a/include/linux/mfd/88pm80x.h b/include/linux/mfd/88pm80x.h
> index 8fcad63..648e01a 100644
> --- a/include/linux/mfd/88pm80x.h
> +++ b/include/linux/mfd/88pm80x.h
> @@ -77,6 +77,8 @@ enum {
> #define PM800_WAKEUP2 (0x0E)
> #define PM800_WAKEUP2_INV_INT BIT(0)
> #define PM800_WAKEUP2_INT_CLEAR BIT(1)
> +#define PM800_WAKEUP2_INT_READ_CLEAR (0 << 1)
> +#define PM800_WAKEUP2_INT_WRITE_CLEAR (1 << 1)
> #define PM800_WAKEUP2_INT_MASK BIT(2)
>
> #define PM800_POWER_UP_LOG (0x10)
> @@ -300,7 +302,11 @@ struct pm80x_chip {
> struct regmap_irq_chip_data *irq_data;
> int type;
> int irq;
> - int irq_mode;
> +
> +#define PM800_IRQ_CLR_ON_READ 0
> +#define PM800_IRQ_CLR_ON_WRITE 1
Defines in the middle of structs makes for ugly code.
> + bool irq_clr_method; /* '1': Clear on write, '0': Clear on read */
> unsigned long wu_flag;
> spinlock_t lock;
> };
> @@ -315,7 +321,7 @@ struct pm80x_platform_data {
> */
> struct regulator_init_data *regulators[PM800_ID_RG_MAX];
> unsigned int num_regulators;
> - int irq_mode; /* Clear interrupt by read/write(0/1) */
> + bool irq_clr_method; /* Clear interrupt by read/write(0/1) */
> int batt_det; /* enable/disable */
> int (*plat_config)(struct pm80x_chip *chip,
> struct pm80x_platform_data *pdata);
--
Lee Jones
Linaro STMicroelectronics Landing Team Lead
Linaro.org │ Open source software for ARM SoCs
Follow Linaro: Facebook | Twitter | Blog
next prev parent reply other threads:[~2015-07-07 7:29 UTC|newest]
Thread overview: 82+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-06-29 15:31 [PATCH-V5 0/4] mfd: 88pm800: Add Device tree support Vaibhav Hiremath
2015-06-29 15:31 ` Vaibhav Hiremath
2015-06-29 15:31 ` [PATCH-V5 1/4] mfd: 88pm800: Add device " Vaibhav Hiremath
2015-06-29 15:31 ` Vaibhav Hiremath
2015-06-29 15:31 ` Vaibhav Hiremath
2015-06-30 0:32 ` Krzysztof Kozlowski
2015-06-30 0:32 ` Krzysztof Kozlowski
2015-06-30 0:32 ` Krzysztof Kozlowski
2015-07-07 7:30 ` Lee Jones
2015-07-07 7:30 ` Lee Jones
2015-06-29 15:31 ` [PATCH-V5 2/4] mfd: 88pm800: Remove unnecessary protection around pdata Vaibhav Hiremath
2015-06-29 15:31 ` Vaibhav Hiremath
2015-06-29 15:31 ` Vaibhav Hiremath
2015-06-30 0:34 ` Krzysztof Kozlowski
2015-06-30 0:34 ` Krzysztof Kozlowski
2015-06-30 0:34 ` Krzysztof Kozlowski
2015-07-07 7:30 ` Lee Jones
2015-07-07 7:30 ` Lee Jones
2015-07-07 7:30 ` Lee Jones
2015-06-29 15:31 ` [PATCH-V5 3/4] mfd: 88pm800: Set default interrupt clear method Vaibhav Hiremath
2015-06-29 15:31 ` Vaibhav Hiremath
2015-06-29 15:31 ` Vaibhav Hiremath
2015-06-30 0:29 ` Krzysztof Kozlowski
2015-06-30 0:29 ` Krzysztof Kozlowski
2015-06-30 0:29 ` Krzysztof Kozlowski
2015-07-07 7:29 ` Lee Jones [this message]
2015-07-07 7:29 ` Lee Jones
2015-07-07 9:53 ` Vaibhav Hiremath
2015-07-07 9:53 ` Vaibhav Hiremath
2015-07-07 9:53 ` Vaibhav Hiremath
2015-07-07 10:40 ` Lee Jones
2015-07-07 10:40 ` Lee Jones
2015-07-07 10:40 ` Lee Jones
2015-07-07 10:51 ` Vaibhav Hiremath
2015-07-07 10:51 ` Vaibhav Hiremath
2015-07-07 10:51 ` Vaibhav Hiremath
2015-07-07 11:12 ` Lee Jones
2015-07-07 11:12 ` Lee Jones
2015-07-07 11:12 ` Lee Jones
2015-07-07 11:18 ` Vaibhav Hiremath
2015-07-07 11:18 ` Vaibhav Hiremath
2015-07-07 11:25 ` Vaibhav Hiremath
2015-07-07 11:25 ` Vaibhav Hiremath
2015-07-07 11:25 ` Vaibhav Hiremath
2015-07-07 12:54 ` Lee Jones
2015-07-07 12:54 ` Lee Jones
2015-07-07 12:54 ` Lee Jones
2015-07-07 14:47 ` Vaibhav Hiremath
2015-07-07 14:47 ` Vaibhav Hiremath
2015-07-07 14:57 ` Lee Jones
2015-07-07 14:57 ` Lee Jones
2015-07-08 12:22 ` Vaibhav Hiremath
2015-07-08 12:22 ` Vaibhav Hiremath
2015-06-29 15:31 ` [PATCH-V5 4/4] mfd: devicetree: bindings: Add new 88pm800 mfd binding Vaibhav Hiremath
2015-06-29 15:31 ` Vaibhav Hiremath
2015-06-29 15:31 ` Vaibhav Hiremath
2015-06-30 0:30 ` Krzysztof Kozłowski
2015-06-30 0:30 ` Krzysztof Kozłowski
2015-06-30 0:30 ` Krzysztof Kozłowski
2015-07-01 7:43 ` Lee Jones
2015-07-01 7:43 ` Lee Jones
2015-07-01 8:00 ` Krzysztof Kozłowski
2015-07-01 8:00 ` Krzysztof Kozłowski
2015-06-30 0:31 ` Krzysztof Kozlowski
2015-06-30 0:31 ` Krzysztof Kozlowski
2015-06-30 0:31 ` Krzysztof Kozlowski
2015-06-30 5:40 ` Vaibhav Hiremath
2015-06-30 5:40 ` Vaibhav Hiremath
2015-06-30 5:40 ` Vaibhav Hiremath
2015-07-01 16:10 ` Rob Herring
2015-07-01 16:10 ` Rob Herring
2015-07-01 16:21 ` Vaibhav Hiremath
2015-07-01 16:21 ` Vaibhav Hiremath
2015-07-01 17:17 ` Rob Herring
2015-07-01 17:17 ` Rob Herring
2015-07-01 17:17 ` Rob Herring
2015-07-01 17:24 ` Vaibhav Hiremath
2015-07-01 17:24 ` Vaibhav Hiremath
2015-07-01 17:24 ` Vaibhav Hiremath
2015-07-07 7:31 ` Lee Jones
2015-07-07 7:31 ` Lee Jones
2015-07-07 7:31 ` Lee Jones
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20150707072958.GN3182@x1 \
--to=lee.jones@linaro.org \
--cc=linux-arm-kernel@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.