Commit 2fbc487d authored by Arnd Bergmann's avatar Arnd Bergmann Committed by Thierry Reding

pwm: meson: Handle unknown ID values

When building with -Wmaybe-uninitialized, we get a couple of harmless
warnings about three functions in this new driver that don't look
safe to the compiler:

drivers/pwm/pwm-meson.c: In function 'meson_pwm_get_state':
drivers/pwm/pwm-meson.c:355:26: error: 'mask' may be used uninitialized in this function [-Werror=maybe-uninitialized]
drivers/pwm/pwm-meson.c: In function 'meson_pwm_disable':
drivers/pwm/pwm-meson.c:263:13: error: 'enable' may be used uninitialized in this function [-Werror=maybe-uninitialized]
drivers/pwm/pwm-meson.c: In function 'meson_pwm_apply':
drivers/pwm/pwm-meson.c:231:13: error: 'clk_shift' may be used uninitialized in this function [-Werror=maybe-uninitialized]
drivers/pwm/pwm-meson.c:231:36: error: 'enable' may be used uninitialized in this function [-Werror=maybe-uninitialized]
drivers/pwm/pwm-meson.c:231:24: error: 'clk_enable' may be used uninitialized in this function [-Werror=maybe-uninitialized]

Specifically, if we have a device with an ID other than 0 or 1,
this would result in undefined behavior. This is currently not
possible, but the compiler cannot be expected to know this.

This patch adds a 'default' clause to let the compiler know
what to do instead, which shuts up the warning and makes the
code slightly more resiliant in case it gets extended to other
identifiers.
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Acked-by: default avatarNeil Armstrong <narmstrong@baylibre.com>
Signed-off-by: default avatarThierry Reding <thierry.reding@gmail.com>
parent 7d8a600c
...@@ -245,6 +245,9 @@ static void meson_pwm_enable(struct meson_pwm *meson, ...@@ -245,6 +245,9 @@ static void meson_pwm_enable(struct meson_pwm *meson,
enable = MISC_B_EN; enable = MISC_B_EN;
offset = REG_PWM_B; offset = REG_PWM_B;
break; break;
default:
return;
} }
value = readl(meson->base + REG_MISC_AB); value = readl(meson->base + REG_MISC_AB);
...@@ -273,6 +276,9 @@ static void meson_pwm_disable(struct meson_pwm *meson, unsigned int id) ...@@ -273,6 +276,9 @@ static void meson_pwm_disable(struct meson_pwm *meson, unsigned int id)
case 1: case 1:
enable = MISC_B_EN; enable = MISC_B_EN;
break; break;
default:
return;
} }
value = readl(meson->base + REG_MISC_AB); value = readl(meson->base + REG_MISC_AB);
...@@ -352,6 +358,9 @@ static void meson_pwm_get_state(struct pwm_chip *chip, struct pwm_device *pwm, ...@@ -352,6 +358,9 @@ static void meson_pwm_get_state(struct pwm_chip *chip, struct pwm_device *pwm,
case 1: case 1:
mask = MISC_B_EN; mask = MISC_B_EN;
break; break;
default:
return;
} }
value = readl(meson->base + REG_MISC_AB); value = readl(meson->base + REG_MISC_AB);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment