OsdInterrupt.c (76f2b644fdfb79b61d612c858f9aa5e02c50215e) OsdInterrupt.c (3273b0052350a01f85ee60a6a2e31adb31d4a5a6)
1/*-
2 * Copyright (c) 2000 Michael Smith
3 * Copyright (c) 2000 BSDi
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:

--- 43 unchanged lines hidden (view full) ---

52 */
53ACPI_STATUS
54AcpiOsInstallInterruptHandler(UINT32 InterruptNumber, OSD_HANDLER ServiceRoutine, void *Context)
55{
56 struct acpi_softc *sc;
57
58 FUNCTION_TRACE(__func__);
59
1/*-
2 * Copyright (c) 2000 Michael Smith
3 * Copyright (c) 2000 BSDi
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:

--- 43 unchanged lines hidden (view full) ---

52 */
53ACPI_STATUS
54AcpiOsInstallInterruptHandler(UINT32 InterruptNumber, OSD_HANDLER ServiceRoutine, void *Context)
55{
56 struct acpi_softc *sc;
57
58 FUNCTION_TRACE(__func__);
59
60 if ((sc = devclass_get_softc(acpi_devclass, 0)) == NULL)
60 if ((sc = devclass_get_softc(devclass_find("acpi"), 0)) == NULL)
61 panic("can't find ACPI device to register interrupt");
62 if (sc->acpi_dev == NULL)
63 panic("acpi softc has invalid device");
64
65 if ((InterruptNumber < 0) || (InterruptNumber > 255))
66 return_ACPI_STATUS(AE_BAD_PARAMETER);
67 if (ServiceRoutine == NULL)
68 return_ACPI_STATUS(AE_BAD_PARAMETER);

--- 34 unchanged lines hidden (view full) ---

103
104 FUNCTION_TRACE(__func__);
105
106 if ((InterruptNumber < 0) || (InterruptNumber > 255))
107 return_ACPI_STATUS(AE_BAD_PARAMETER);
108 if (ServiceRoutine == NULL)
109 return_ACPI_STATUS(AE_BAD_PARAMETER);
110
61 panic("can't find ACPI device to register interrupt");
62 if (sc->acpi_dev == NULL)
63 panic("acpi softc has invalid device");
64
65 if ((InterruptNumber < 0) || (InterruptNumber > 255))
66 return_ACPI_STATUS(AE_BAD_PARAMETER);
67 if (ServiceRoutine == NULL)
68 return_ACPI_STATUS(AE_BAD_PARAMETER);

--- 34 unchanged lines hidden (view full) ---

103
104 FUNCTION_TRACE(__func__);
105
106 if ((InterruptNumber < 0) || (InterruptNumber > 255))
107 return_ACPI_STATUS(AE_BAD_PARAMETER);
108 if (ServiceRoutine == NULL)
109 return_ACPI_STATUS(AE_BAD_PARAMETER);
110
111 if ((sc = devclass_get_softc(acpi_devclass, 0)) == NULL)
111 if ((sc = devclass_get_softc(find_devclass("acpi"), 0)) == NULL)
112 panic("can't find ACPI device to deregister interrupt");
113
114 if (sc->acpi_irq == NULL)
115 return_ACPI_STATUS(AE_NOT_EXIST);
116
117 bus_teardown_intr(sc->acpi_dev, sc->acpi_irq, sc->acpi_irq_handle);
118 bus_release_resource(sc->acpi_dev, SYS_RES_IRQ, 0, sc->acpi_irq);
119 bus_delete_resource(sc->acpi_dev, SYS_RES_IRQ, 0);

--- 16 unchanged lines hidden ---
112 panic("can't find ACPI device to deregister interrupt");
113
114 if (sc->acpi_irq == NULL)
115 return_ACPI_STATUS(AE_NOT_EXIST);
116
117 bus_teardown_intr(sc->acpi_dev, sc->acpi_irq, sc->acpi_irq_handle);
118 bus_release_resource(sc->acpi_dev, SYS_RES_IRQ, 0, sc->acpi_irq);
119 bus_delete_resource(sc->acpi_dev, SYS_RES_IRQ, 0);

--- 16 unchanged lines hidden ---