linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 1/2] regulator: ltc3676: Simplify .readable_reg and .writable_reg callbacks
@ 2019-02-15 11:54 Axel Lin
  2019-02-15 11:54 ` [PATCH 2/2] regulator: ltc3676: Fix module description Axel Lin
  2019-02-15 16:20 ` [PATCH 1/2] regulator: ltc3676: Simplify .readable_reg and .writable_reg callbacks Tim Harvey
  0 siblings, 2 replies; 4+ messages in thread
From: Axel Lin @ 2019-02-15 11:54 UTC (permalink / raw)
  To: Mark Brown; +Cc: Tim Harvey, Marek Vasut, Liam Girdwood, linux-kernel, Axel Lin

Use case range for continuous range to make the code shorter.
The .readable_reg and .writable_reg implementation are exactly the same,
so use a common ltc3676_readable_writeable_reg function instead.

Signed-off-by: Axel Lin <axel.lin@ingics.com>
---
 drivers/regulator/ltc3676.c | 63 +++----------------------------------
 1 file changed, 5 insertions(+), 58 deletions(-)

diff --git a/drivers/regulator/ltc3676.c b/drivers/regulator/ltc3676.c
index 71fd0f2a4b76..549a1a243870 100644
--- a/drivers/regulator/ltc3676.c
+++ b/drivers/regulator/ltc3676.c
@@ -241,61 +241,10 @@ static struct regulator_desc ltc3676_regulators[LTC3676_NUM_REGULATORS] = {
 	LTC3676_FIXED_REG(LDO4, ldo4, LDOB, 2),
 };
 
-static bool ltc3676_writeable_reg(struct device *dev, unsigned int reg)
+static bool ltc3676_readable_writeable_reg(struct device *dev, unsigned int reg)
 {
 	switch (reg) {
-	case LTC3676_IRQSTAT:
-	case LTC3676_BUCK1:
-	case LTC3676_BUCK2:
-	case LTC3676_BUCK3:
-	case LTC3676_BUCK4:
-	case LTC3676_LDOA:
-	case LTC3676_LDOB:
-	case LTC3676_SQD1:
-	case LTC3676_SQD2:
-	case LTC3676_CNTRL:
-	case LTC3676_DVB1A:
-	case LTC3676_DVB1B:
-	case LTC3676_DVB2A:
-	case LTC3676_DVB2B:
-	case LTC3676_DVB3A:
-	case LTC3676_DVB3B:
-	case LTC3676_DVB4A:
-	case LTC3676_DVB4B:
-	case LTC3676_MSKIRQ:
-	case LTC3676_MSKPG:
-	case LTC3676_USER:
-	case LTC3676_HRST:
-	case LTC3676_CLIRQ:
-		return true;
-	}
-	return false;
-}
-
-static bool ltc3676_readable_reg(struct device *dev, unsigned int reg)
-{
-	switch (reg) {
-	case LTC3676_IRQSTAT:
-	case LTC3676_BUCK1:
-	case LTC3676_BUCK2:
-	case LTC3676_BUCK3:
-	case LTC3676_BUCK4:
-	case LTC3676_LDOA:
-	case LTC3676_LDOB:
-	case LTC3676_SQD1:
-	case LTC3676_SQD2:
-	case LTC3676_CNTRL:
-	case LTC3676_DVB1A:
-	case LTC3676_DVB1B:
-	case LTC3676_DVB2A:
-	case LTC3676_DVB2B:
-	case LTC3676_DVB3A:
-	case LTC3676_DVB3B:
-	case LTC3676_DVB4A:
-	case LTC3676_DVB4B:
-	case LTC3676_MSKIRQ:
-	case LTC3676_MSKPG:
-	case LTC3676_USER:
+	case LTC3676_BUCK1 ... LTC3676_IRQSTAT:
 	case LTC3676_HRST:
 	case LTC3676_CLIRQ:
 		return true;
@@ -306,9 +255,7 @@ static bool ltc3676_readable_reg(struct device *dev, unsigned int reg)
 static bool ltc3676_volatile_reg(struct device *dev, unsigned int reg)
 {
 	switch (reg) {
-	case LTC3676_IRQSTAT:
-	case LTC3676_PGSTATL:
-	case LTC3676_PGSTATRT:
+	case LTC3676_IRQSTAT ... LTC3676_PGSTATRT:
 		return true;
 	}
 	return false;
@@ -317,8 +264,8 @@ static bool ltc3676_volatile_reg(struct device *dev, unsigned int reg)
 static const struct regmap_config ltc3676_regmap_config = {
 	.reg_bits = 8,
 	.val_bits = 8,
-	.writeable_reg = ltc3676_writeable_reg,
-	.readable_reg = ltc3676_readable_reg,
+	.writeable_reg = ltc3676_readable_writeable_reg,
+	.readable_reg = ltc3676_readable_writeable_reg,
 	.volatile_reg = ltc3676_volatile_reg,
 	.max_register = LTC3676_CLIRQ,
 	.use_single_read = true,
-- 
2.17.1


^ permalink raw reply related	[flat|nested] 4+ messages in thread

* [PATCH 2/2] regulator: ltc3676: Fix module description
  2019-02-15 11:54 [PATCH 1/2] regulator: ltc3676: Simplify .readable_reg and .writable_reg callbacks Axel Lin
@ 2019-02-15 11:54 ` Axel Lin
  2019-02-15 16:11   ` Tim Harvey
  2019-02-15 16:20 ` [PATCH 1/2] regulator: ltc3676: Simplify .readable_reg and .writable_reg callbacks Tim Harvey
  1 sibling, 1 reply; 4+ messages in thread
From: Axel Lin @ 2019-02-15 11:54 UTC (permalink / raw)
  To: Mark Brown; +Cc: Tim Harvey, Marek Vasut, Liam Girdwood, linux-kernel, Axel Lin

This driver is for LTC3676 rather than LTC1376.

Signed-off-by: Axel Lin <axel.lin@ingics.com>
---
 drivers/regulator/ltc3676.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/regulator/ltc3676.c b/drivers/regulator/ltc3676.c
index 549a1a243870..e6d66e492b85 100644
--- a/drivers/regulator/ltc3676.c
+++ b/drivers/regulator/ltc3676.c
@@ -389,5 +389,5 @@ static struct i2c_driver ltc3676_driver = {
 module_i2c_driver(ltc3676_driver);
 
 MODULE_AUTHOR("Tim Harvey <tharvey@gateworks.com>");
-MODULE_DESCRIPTION("Regulator driver for Linear Technology LTC1376");
+MODULE_DESCRIPTION("Regulator driver for Linear Technology LTC3676");
 MODULE_LICENSE("GPL v2");
-- 
2.17.1


^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH 2/2] regulator: ltc3676: Fix module description
  2019-02-15 11:54 ` [PATCH 2/2] regulator: ltc3676: Fix module description Axel Lin
@ 2019-02-15 16:11   ` Tim Harvey
  0 siblings, 0 replies; 4+ messages in thread
From: Tim Harvey @ 2019-02-15 16:11 UTC (permalink / raw)
  To: Axel Lin; +Cc: Mark Brown, Marek Vasut, Liam Girdwood, open list

On Fri, Feb 15, 2019 at 3:54 AM Axel Lin <axel.lin@ingics.com> wrote:
>
> This driver is for LTC3676 rather than LTC1376.
>
> Signed-off-by: Axel Lin <axel.lin@ingics.com>
> ---
>  drivers/regulator/ltc3676.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/regulator/ltc3676.c b/drivers/regulator/ltc3676.c
> index 549a1a243870..e6d66e492b85 100644
> --- a/drivers/regulator/ltc3676.c
> +++ b/drivers/regulator/ltc3676.c
> @@ -389,5 +389,5 @@ static struct i2c_driver ltc3676_driver = {
>  module_i2c_driver(ltc3676_driver);
>
>  MODULE_AUTHOR("Tim Harvey <tharvey@gateworks.com>");
> -MODULE_DESCRIPTION("Regulator driver for Linear Technology LTC1376");
> +MODULE_DESCRIPTION("Regulator driver for Linear Technology LTC3676");
>  MODULE_LICENSE("GPL v2");
> --

Acked-by: Tim Harvey <tharvey@gateworks.com>

Tim

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH 1/2] regulator: ltc3676: Simplify .readable_reg and .writable_reg callbacks
  2019-02-15 11:54 [PATCH 1/2] regulator: ltc3676: Simplify .readable_reg and .writable_reg callbacks Axel Lin
  2019-02-15 11:54 ` [PATCH 2/2] regulator: ltc3676: Fix module description Axel Lin
@ 2019-02-15 16:20 ` Tim Harvey
  1 sibling, 0 replies; 4+ messages in thread
From: Tim Harvey @ 2019-02-15 16:20 UTC (permalink / raw)
  To: Axel Lin; +Cc: Mark Brown, Marek Vasut, Liam Girdwood, open list

On Fri, Feb 15, 2019 at 3:54 AM Axel Lin <axel.lin@ingics.com> wrote:
>
> Use case range for continuous range to make the code shorter.
> The .readable_reg and .writable_reg implementation are exactly the same,
> so use a common ltc3676_readable_writeable_reg function instead.
>
> Signed-off-by: Axel Lin <axel.lin@ingics.com>
> ---
>  drivers/regulator/ltc3676.c | 63 +++----------------------------------
>  1 file changed, 5 insertions(+), 58 deletions(-)
>
> diff --git a/drivers/regulator/ltc3676.c b/drivers/regulator/ltc3676.c
> index 71fd0f2a4b76..549a1a243870 100644
> --- a/drivers/regulator/ltc3676.c
> +++ b/drivers/regulator/ltc3676.c
> @@ -241,61 +241,10 @@ static struct regulator_desc ltc3676_regulators[LTC3676_NUM_REGULATORS] = {
>         LTC3676_FIXED_REG(LDO4, ldo4, LDOB, 2),
>  };
>
> -static bool ltc3676_writeable_reg(struct device *dev, unsigned int reg)
> +static bool ltc3676_readable_writeable_reg(struct device *dev, unsigned int reg)
>  {
>         switch (reg) {
> -       case LTC3676_IRQSTAT:
> -       case LTC3676_BUCK1:
> -       case LTC3676_BUCK2:
> -       case LTC3676_BUCK3:
> -       case LTC3676_BUCK4:
> -       case LTC3676_LDOA:
> -       case LTC3676_LDOB:
> -       case LTC3676_SQD1:
> -       case LTC3676_SQD2:
> -       case LTC3676_CNTRL:
> -       case LTC3676_DVB1A:
> -       case LTC3676_DVB1B:
> -       case LTC3676_DVB2A:
> -       case LTC3676_DVB2B:
> -       case LTC3676_DVB3A:
> -       case LTC3676_DVB3B:
> -       case LTC3676_DVB4A:
> -       case LTC3676_DVB4B:
> -       case LTC3676_MSKIRQ:
> -       case LTC3676_MSKPG:
> -       case LTC3676_USER:
> -       case LTC3676_HRST:
> -       case LTC3676_CLIRQ:
> -               return true;
> -       }
> -       return false;
> -}
> -
> -static bool ltc3676_readable_reg(struct device *dev, unsigned int reg)
> -{
> -       switch (reg) {
> -       case LTC3676_IRQSTAT:
> -       case LTC3676_BUCK1:
> -       case LTC3676_BUCK2:
> -       case LTC3676_BUCK3:
> -       case LTC3676_BUCK4:
> -       case LTC3676_LDOA:
> -       case LTC3676_LDOB:
> -       case LTC3676_SQD1:
> -       case LTC3676_SQD2:
> -       case LTC3676_CNTRL:
> -       case LTC3676_DVB1A:
> -       case LTC3676_DVB1B:
> -       case LTC3676_DVB2A:
> -       case LTC3676_DVB2B:
> -       case LTC3676_DVB3A:
> -       case LTC3676_DVB3B:
> -       case LTC3676_DVB4A:
> -       case LTC3676_DVB4B:
> -       case LTC3676_MSKIRQ:
> -       case LTC3676_MSKPG:
> -       case LTC3676_USER:
> +       case LTC3676_BUCK1 ... LTC3676_IRQSTAT:
>         case LTC3676_HRST:
>         case LTC3676_CLIRQ:
>                 return true;
> @@ -306,9 +255,7 @@ static bool ltc3676_readable_reg(struct device *dev, unsigned int reg)
>  static bool ltc3676_volatile_reg(struct device *dev, unsigned int reg)
>  {
>         switch (reg) {
> -       case LTC3676_IRQSTAT:
> -       case LTC3676_PGSTATL:
> -       case LTC3676_PGSTATRT:
> +       case LTC3676_IRQSTAT ... LTC3676_PGSTATRT:
>                 return true;
>         }
>         return false;
> @@ -317,8 +264,8 @@ static bool ltc3676_volatile_reg(struct device *dev, unsigned int reg)
>  static const struct regmap_config ltc3676_regmap_config = {
>         .reg_bits = 8,
>         .val_bits = 8,
> -       .writeable_reg = ltc3676_writeable_reg,
> -       .readable_reg = ltc3676_readable_reg,
> +       .writeable_reg = ltc3676_readable_writeable_reg,
> +       .readable_reg = ltc3676_readable_writeable_reg,
>         .volatile_reg = ltc3676_volatile_reg,
>         .max_register = LTC3676_CLIRQ,
>         .use_single_read = true,
> --
> 2.17.1
>

Acked-by: Tim Harvey <tharvey@gateworks.com>

Tim

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2019-02-15 16:21 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-02-15 11:54 [PATCH 1/2] regulator: ltc3676: Simplify .readable_reg and .writable_reg callbacks Axel Lin
2019-02-15 11:54 ` [PATCH 2/2] regulator: ltc3676: Fix module description Axel Lin
2019-02-15 16:11   ` Tim Harvey
2019-02-15 16:20 ` [PATCH 1/2] regulator: ltc3676: Simplify .readable_reg and .writable_reg callbacks Tim Harvey

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).