diff options
| author | Srinivas Neeli <[email protected]> | 2022-07-21 07:39:09 +0000 |
|---|---|---|
| committer | Bartosz Golaszewski <[email protected]> | 2022-07-22 07:17:03 +0000 |
| commit | 32c094a09d5829ad9b02cdf667569aefa8de0ea6 (patch) | |
| tree | 63f4afcc754bfbdfaddc64231d2d678526fd0bb7 /drivers/gpio/gpio-xilinx.c | |
| parent | selftests: gpio: fix include path to kernel headers for out of tree builds (diff) | |
| download | kernel-32c094a09d5829ad9b02cdf667569aefa8de0ea6.tar.gz kernel-32c094a09d5829ad9b02cdf667569aefa8de0ea6.zip | |
gpio: gpio-xilinx: Fix integer overflow
Current implementation is not able to configure more than 32 pins
due to incorrect data type. So type casting with unsigned long
to avoid it.
Fixes: 02b3f84d9080 ("xilinx: Switch to use bitmap APIs")
Signed-off-by: Srinivas Neeli <[email protected]>
Signed-off-by: Bartosz Golaszewski <[email protected]>
Diffstat (limited to 'drivers/gpio/gpio-xilinx.c')
| -rw-r--r-- | drivers/gpio/gpio-xilinx.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/gpio/gpio-xilinx.c b/drivers/gpio/gpio-xilinx.c index b6d3a57e27ed..7f8e2fed2988 100644 --- a/drivers/gpio/gpio-xilinx.c +++ b/drivers/gpio/gpio-xilinx.c @@ -99,7 +99,7 @@ static inline void xgpio_set_value32(unsigned long *map, int bit, u32 v) const unsigned long offset = (bit % BITS_PER_LONG) & BIT(5); map[index] &= ~(0xFFFFFFFFul << offset); - map[index] |= v << offset; + map[index] |= (unsigned long)v << offset; } static inline int xgpio_regoffset(struct xgpio_instance *chip, int ch) |
