pinctrl: renesas: sh7723: Optimize fixed-width reserved fields
authorGeert Uytterhoeven <geert+renesas@glider.be>
Wed, 13 Apr 2022 17:24:06 +0000 (19:24 +0200)
committerGeert Uytterhoeven <geert+renesas@glider.be>
Thu, 5 May 2022 10:02:28 +0000 (12:02 +0200)
Describe registers with fixed-width register fields and many reserved
fields using the PINMUX_CFG_REG_VAR() macro, as the latter supports a
shorthand not requiring dummy values.

This reduces kernel size by 105 bytes.

Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
Link: https://lore.kernel.org/r/5d7ef2fa02c2137d2d243fc183d18220c9aaf7b8.1649865241.git.geert+renesas@glider.be
drivers/pinctrl/renesas/pfc-sh7723.c

index 94c7acf..9534428 100644 (file)
@@ -1546,9 +1546,10 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PTD1_FN, PTD1_OUT, 0, PTD1_IN,
                PTD0_FN, PTD0_OUT, 0, PTD0_IN ))
        },
-       { PINMUX_CFG_REG("PECR", 0xa4050108, 16, 2, GROUP(
-               0, 0, 0, 0,
-               0, 0, 0, 0,
+       { PINMUX_CFG_REG_VAR("PECR", 0xa4050108, 16,
+                            GROUP(-4, 2, 2, 2, 2, 2, 2),
+                            GROUP(
+               /* RESERVED [4] */
                PTE5_FN, PTE5_OUT, 0, PTE5_IN,
                PTE4_FN, PTE4_OUT, 0, PTE4_IN,
                PTE3_FN, PTE3_OUT, 0, PTE3_IN,
@@ -1566,9 +1567,10 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PTF1_FN, PTF1_OUT, 0, PTF1_IN,
                PTF0_FN, PTF0_OUT, 0, PTF0_IN ))
        },
-       { PINMUX_CFG_REG("PGCR", 0xa405010c, 16, 2, GROUP(
-               0, 0, 0, 0,
-               0, 0, 0, 0,
+       { PINMUX_CFG_REG_VAR("PGCR", 0xa405010c, 16,
+                            GROUP(-4, 2, 2, 2, 2, 2, 2),
+                            GROUP(
+               /* RESERVED [4] */
                PTG5_FN, PTG5_OUT, 0, 0,
                PTG4_FN, PTG4_OUT, 0, 0,
                PTG3_FN, PTG3_OUT, 0, 0,
@@ -1586,11 +1588,13 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PTH1_FN, PTH1_OUT, 0, PTH1_IN,
                PTH0_FN, PTH0_OUT, 0, PTH0_IN ))
        },
-       { PINMUX_CFG_REG("PJCR", 0xa4050110, 16, 2, GROUP(
+       { PINMUX_CFG_REG_VAR("PJCR", 0xa4050110, 16,
+                            GROUP(2, -2, 2, -2, 2, 2, 2, 2),
+                            GROUP(
                PTJ7_FN, PTJ7_OUT, 0, 0,
-               0, 0, 0, 0,
+               /* RESERVED [2] */
                PTJ5_FN, PTJ5_OUT, 0, 0,
-               0, 0, 0, 0,
+               /* RESERVED [2] */
                PTJ3_FN, PTJ3_OUT, 0, PTJ3_IN,
                PTJ2_FN, PTJ2_OUT, 0, PTJ2_IN,
                PTJ1_FN, PTJ1_OUT, 0, PTJ1_IN,
@@ -1636,11 +1640,10 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PTN1_FN, PTN1_OUT, 0, PTN1_IN,
                PTN0_FN, PTN0_OUT, 0, PTN0_IN ))
        },
-       { PINMUX_CFG_REG("PQCR", 0xa405011a, 16, 2, GROUP(
-               0, 0, 0, 0,
-               0, 0, 0, 0,
-               0, 0, 0, 0,
-               0, 0, 0, 0,
+       { PINMUX_CFG_REG_VAR("PQCR", 0xa405011a, 16,
+                            GROUP(-8, 2, 2, 2, 2),
+                            GROUP(
+               /* RESERVED [8] */
                PTQ3_FN, 0, 0, PTQ3_IN,
                PTQ2_FN, 0, 0, PTQ2_IN,
                PTQ1_FN, 0, 0, PTQ1_IN,
@@ -1666,9 +1669,10 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PTS1_FN, PTS1_OUT, 0, PTS1_IN,
                PTS0_FN, PTS0_OUT, 0, PTS0_IN ))
        },
-       { PINMUX_CFG_REG("PTCR", 0xa4050140, 16, 2, GROUP(
-               0, 0, 0, 0,
-               0, 0, 0, 0,
+       { PINMUX_CFG_REG_VAR("PTCR", 0xa4050140, 16,
+                            GROUP(-4, 2, 2, 2, 2, 2, 2),
+                            GROUP(
+               /* RESERVED [4] */
                PTT5_FN, PTT5_OUT, 0, PTT5_IN,
                PTT4_FN, PTT4_OUT, 0, PTT4_IN,
                PTT3_FN, PTT3_OUT, 0, PTT3_IN,
@@ -1676,9 +1680,10 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PTT1_FN, PTT1_OUT, 0, PTT1_IN,
                PTT0_FN, PTT0_OUT, 0, PTT0_IN ))
        },
-       { PINMUX_CFG_REG("PUCR", 0xa4050142, 16, 2, GROUP(
-               0, 0, 0, 0,
-               0, 0, 0, 0,
+       { PINMUX_CFG_REG_VAR("PUCR", 0xa4050142, 16,
+                            GROUP(-4, 2, 2, 2, 2, 2, 2),
+                            GROUP(
+               /* RESERVED [4] */
                PTU5_FN, PTU5_OUT, 0, PTU5_IN,
                PTU4_FN, PTU4_OUT, 0, PTU4_IN,
                PTU3_FN, PTU3_OUT, 0, PTU3_IN,
@@ -1736,35 +1741,38 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PTZ1_FN, PTZ1_OUT, 0, PTZ1_IN,
                PTZ0_FN, PTZ0_OUT, 0, PTZ0_IN ))
        },
-       { PINMUX_CFG_REG("PSELA", 0xa405014e, 16, 2, GROUP(
+       { PINMUX_CFG_REG_VAR("PSELA", 0xa405014e, 16,
+                            GROUP(2, 2, 2, -4, 2, 2, -2),
+                            GROUP(
                PSA15_PSA14_FN1, PSA15_PSA14_FN2, 0, 0,
                PSA13_PSA12_FN1, PSA13_PSA12_FN2, 0, 0,
                PSA11_PSA10_FN1, PSA11_PSA10_FN2, 0, 0,
-               0, 0, 0, 0,
-               0, 0, 0, 0,
+               /* RESERVED [4] */
                PSA5_PSA4_FN1, PSA5_PSA4_FN2, PSA5_PSA4_FN3, 0,
                PSA3_PSA2_FN1, PSA3_PSA2_FN2, 0, 0,
-               0, 0, 0, 0 ))
+               /* RESERVED [2] */ ))
        },
-       { PINMUX_CFG_REG("PSELB", 0xa4050150, 16, 2, GROUP(
+       { PINMUX_CFG_REG_VAR("PSELB", 0xa4050150, 16,
+                            GROUP(2, 2, -2, 2, 2, 2, 2, -2),
+                            GROUP(
                PSB15_PSB14_FN1, PSB15_PSB14_FN2, 0, 0,
                PSB13_PSB12_LCDC_RGB, PSB13_PSB12_LCDC_SYS, 0, 0,
-               0, 0, 0, 0,
+               /* RESERVED [2] */
                PSB9_PSB8_FN1, PSB9_PSB8_FN2, PSB9_PSB8_FN3, 0,
                PSB7_PSB6_FN1, PSB7_PSB6_FN2, 0, 0,
                PSB5_PSB4_FN1, PSB5_PSB4_FN2, 0, 0,
                PSB3_PSB2_FN1, PSB3_PSB2_FN2, 0, 0,
-               0, 0, 0, 0 ))
+               /* RESERVED [2] */ ))
        },
-       { PINMUX_CFG_REG("PSELC", 0xa4050152, 16, 2, GROUP(
+       { PINMUX_CFG_REG_VAR("PSELC", 0xa4050152, 16,
+                            GROUP(2, 2, 2, 2, 2, -6),
+                            GROUP(
                PSC15_PSC14_FN1, PSC15_PSC14_FN2, 0, 0,
                PSC13_PSC12_FN1, PSC13_PSC12_FN2, 0, 0,
                PSC11_PSC10_FN1, PSC11_PSC10_FN2, PSC11_PSC10_FN3, 0,
                PSC9_PSC8_FN1, PSC9_PSC8_FN2, 0, 0,
                PSC7_PSC6_FN1, PSC7_PSC6_FN2, PSC7_PSC6_FN3, 0,
-               0, 0, 0, 0,
-               0, 0, 0, 0,
-               0, 0, 0, 0 ))
+               /* RESERVED [3] */ ))
        },
        { PINMUX_CFG_REG("PSELD", 0xa4050154, 16, 2, GROUP(
                PSD15_PSD14_FN1, PSD15_PSD14_FN2, 0, 0,