bhnd(4): fix a few bugs in pwrctl/fixed-clock device support.

- Do not panic on siba(4) detach when the bhnd(4) bus calls
   bhnd_get_pmu_info() on a PMU-less device.
 - Fix bhnd_pwrctl attach/detach on fixed-clock devices:
    - Treat bhnd_pwrctl_updateclk() as a no-op on fixed-clock devices.
    - Use bhnd_pwrctl_updateclk() to perform the appropriate clock
      transition on detach.

Sponsored by:	The FreeBSD Foundation
This commit is contained in:
Landon J. Fuller 2018-01-19 21:58:48 +00:00
parent 5ad00fa2cf
commit 1c8edc1ed8
2 changed files with 11 additions and 7 deletions

View File

@ -209,12 +209,12 @@ bhnd_pwrctl_detach(device_t dev)
if ((error = bhnd_deregister_provider(dev, BHND_SERVICE_ANY)))
return (error);
/* Update clock state */
PWRCTL_LOCK(sc);
if ((error = bhnd_pwrctl_setclk(sc, BHND_CLOCK_DYN)))
return (error);
error = bhnd_pwrctl_updateclk(sc, BHND_PWRCTL_WAR_DOWN);
PWRCTL_UNLOCK(sc);
if (error)
return (error);
STAILQ_FOREACH_SAFE(clkres, &sc->clkres_list, cr_link, crnext)
free(clkres, M_DEVBUF);
@ -344,6 +344,10 @@ bhnd_pwrctl_updateclk(struct bhnd_pwrctl_softc *sc, bhnd_pwrctl_wars wars)
PWRCTL_LOCK_ASSERT(sc, MA_OWNED);
/* Nothing to update on fixed clock devices */
if (PWRCTL_QUIRK(sc, FIXED_CLK))
return (0);
/* Default clock target */
clock = BHND_CLOCK_DYN;

View File

@ -170,9 +170,9 @@ siba_read_ivar(device_t dev, device_t child, int index, uintptr_t *result)
case SIBA_PMU_PWRCTL:
case SIBA_PMU_FIXED:
panic("bhnd_get_pmu_info() called with siba PMU state "
"%d", dinfo->pmu_state);
return (ENXIO);
*result = (uintptr_t)NULL;
SIBA_UNLOCK(sc);
return (0);
}
panic("invalid PMU state: %d", dinfo->pmu_state);