bcma: fix watchdog on some ARM chipsets
These chipsets don't need changing clock mode. Signed-off-by: Rafał Miłecki <zajec5@gmail.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
cfbed87b30
commit
68fcd24503
1 changed files with 7 additions and 3 deletions
|
@ -178,7 +178,6 @@ void bcma_core_chipcommon_init(struct bcma_drv_cc *cc)
|
||||||
u32 bcma_chipco_watchdog_timer_set(struct bcma_drv_cc *cc, u32 ticks)
|
u32 bcma_chipco_watchdog_timer_set(struct bcma_drv_cc *cc, u32 ticks)
|
||||||
{
|
{
|
||||||
u32 maxt;
|
u32 maxt;
|
||||||
enum bcma_clkmode clkmode;
|
|
||||||
|
|
||||||
maxt = bcma_chipco_watchdog_get_max_timer(cc);
|
maxt = bcma_chipco_watchdog_get_max_timer(cc);
|
||||||
if (cc->capabilities & BCMA_CC_CAP_PMU) {
|
if (cc->capabilities & BCMA_CC_CAP_PMU) {
|
||||||
|
@ -188,8 +187,13 @@ u32 bcma_chipco_watchdog_timer_set(struct bcma_drv_cc *cc, u32 ticks)
|
||||||
ticks = maxt;
|
ticks = maxt;
|
||||||
bcma_cc_write32(cc, BCMA_CC_PMU_WATCHDOG, ticks);
|
bcma_cc_write32(cc, BCMA_CC_PMU_WATCHDOG, ticks);
|
||||||
} else {
|
} else {
|
||||||
clkmode = ticks ? BCMA_CLKMODE_FAST : BCMA_CLKMODE_DYNAMIC;
|
struct bcma_bus *bus = cc->core->bus;
|
||||||
bcma_core_set_clockmode(cc->core, clkmode);
|
|
||||||
|
if (bus->chipinfo.id != BCMA_CHIP_ID_BCM4707 &&
|
||||||
|
bus->chipinfo.id != BCMA_CHIP_ID_BCM53018)
|
||||||
|
bcma_core_set_clockmode(cc->core,
|
||||||
|
ticks ? BCMA_CLKMODE_FAST : BCMA_CLKMODE_DYNAMIC);
|
||||||
|
|
||||||
if (ticks > maxt)
|
if (ticks > maxt)
|
||||||
ticks = maxt;
|
ticks = maxt;
|
||||||
/* instant NMI */
|
/* instant NMI */
|
||||||
|
|
Loading…
Add table
Reference in a new issue