1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-26 16:18:31 +00:00

Refine r231791. Install the resume event handler unconditionally.

This commit is contained in:
Jung-uk Kim 2012-02-16 22:28:17 +00:00
parent 443cc4d407
commit a7f8112403
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=231840

View File

@ -98,7 +98,8 @@ static void
acpi_stop_beep(void *arg)
{
timer_spkr_release();
if (acpi_resume_beep != 0)
timer_spkr_release();
}
#ifdef SMP
@ -219,7 +220,6 @@ acpi_wakeup_cpus(struct acpi_softc *sc, const cpuset_t *wakeup_cpus)
int
acpi_sleep_machdep(struct acpi_softc *sc, int state)
{
static eventhandler_tag stop_beep = NULL;
#ifdef SMP
cpuset_t wakeup_cpus;
#endif
@ -236,21 +236,8 @@ acpi_sleep_machdep(struct acpi_softc *sc, int state)
CPU_CLR(PCPU_GET(cpuid), &wakeup_cpus);
#endif
if (acpi_resume_beep == 0) {
if (stop_beep != NULL) {
EVENTHANDLER_DEREGISTER(power_resume, stop_beep);
stop_beep = NULL;
}
} else {
if (stop_beep == NULL)
stop_beep = EVENTHANDLER_REGISTER(power_resume,
acpi_stop_beep, NULL, EVENTHANDLER_PRI_LAST);
if (stop_beep == NULL)
device_printf(sc->acpi_dev,
"Failed to set up event handler\n");
else
timer_spkr_acquire();
}
if (acpi_resume_beep != 0)
timer_spkr_acquire();
AcpiSetFirmwareWakingVector(WAKECODE_PADDR(sc));
@ -267,7 +254,7 @@ acpi_sleep_machdep(struct acpi_softc *sc, int state)
}
#endif
WAKECODE_FIXUP(resume_beep, uint8_t, (stop_beep != NULL));
WAKECODE_FIXUP(resume_beep, uint8_t, (acpi_resume_beep != 0));
WAKECODE_FIXUP(reset_video, uint8_t, (acpi_reset_video != 0));
WAKECODE_FIXUP(wakeup_pcb, struct pcb *, susppcbs[0]);
@ -343,6 +330,12 @@ acpi_alloc_wakeup_handler(void)
printf("%s: can't alloc wake memory\n", __func__);
return (NULL);
}
if (EVENTHANDLER_REGISTER(power_resume, acpi_stop_beep, NULL,
EVENTHANDLER_PRI_LAST) == NULL) {
printf("%s: can't register event handler\n", __func__);
contigfree(wakeaddr, 4 * PAGE_SIZE, M_DEVBUF);
return (NULL);
}
susppcbs = malloc(mp_ncpus * sizeof(*susppcbs), M_DEVBUF, M_WAITOK);
suspfpusave = malloc(mp_ncpus * sizeof(void *), M_DEVBUF, M_WAITOK);
for (i = 0; i < mp_ncpus; i++) {