watchdog: kempld: fix gcc-4.3 build
authorArnd Bergmann <arnd@arndb.de>
Wed, 1 Mar 2017 09:15:29 +0000 (10:15 +0100)
committerGuenter Roeck <linux@roeck-us.net>
Wed, 1 Mar 2017 14:15:10 +0000 (06:15 -0800)
commit3736d4eb6af37492aeded7fec0072dedd959c842
tree20d8d96e44e8af895e3dee3003db3d0ba10c1088
parent8d5755b3f77b57447ce5de253ef704ad028474d3
watchdog: kempld: fix gcc-4.3 build

gcc-4.3 can't decide whether the constant value in
kempld_prescaler[PRESCALER_21] is built-time constant or
not, and gets confused by the logic in do_div():

drivers/watchdog/kempld_wdt.o: In function `kempld_wdt_set_stage_timeout':
kempld_wdt.c:(.text.kempld_wdt_set_stage_timeout+0x130): undefined reference to `__aeabi_uldivmod'

This adds a call to ACCESS_ONCE() to force it to not consider
it to be constant, and leaves the more efficient normal case
in place for modern compilers, using an #ifdef to annotate
why we do this hack.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
drivers/watchdog/kempld_wdt.c