Changeset View
Changeset View
Standalone View
Standalone View
sys/dev/acpica/acpi.c
Context not available. | |||||
/* Holds the description of the acpi0 device. */ | /* Holds the description of the acpi0 device. */ | ||||
static char acpi_desc[ACPI_OEM_ID_SIZE + ACPI_OEM_TABLE_ID_SIZE + 2]; | static char acpi_desc[ACPI_OEM_ID_SIZE + ACPI_OEM_TABLE_ID_SIZE + 2]; | ||||
SYSCTL_NODE(_debug, OID_AUTO, acpi, CTLFLAG_RD, NULL, "ACPI debugging"); | SYSCTL_NODE(_debug, OID_AUTO, acpi, CTLFLAG_RD | CTLFLAG_MPSAFE, NULL, | ||||
"ACPI debugging"); | |||||
static char acpi_ca_version[12]; | static char acpi_ca_version[12]; | ||||
SYSCTL_STRING(_debug_acpi, OID_AUTO, acpi_ca_version, CTLFLAG_RD, | SYSCTL_STRING(_debug_acpi, OID_AUTO, acpi_ca_version, CTLFLAG_RD, | ||||
acpi_ca_version, 0, "Version of Intel ACPI-CA"); | acpi_ca_version, 0, "Version of Intel ACPI-CA"); | ||||
Context not available. | |||||
static int acpi_debug_objects; | static int acpi_debug_objects; | ||||
TUNABLE_INT("debug.acpi.enable_debug_objects", &acpi_debug_objects); | TUNABLE_INT("debug.acpi.enable_debug_objects", &acpi_debug_objects); | ||||
SYSCTL_PROC(_debug_acpi, OID_AUTO, enable_debug_objects, | SYSCTL_PROC(_debug_acpi, OID_AUTO, enable_debug_objects, | ||||
CTLFLAG_RW | CTLTYPE_INT, NULL, 0, acpi_debug_objects_sysctl, "I", | CTLFLAG_RW | CTLTYPE_INT | CTLFLAG_NEEDGIANT, NULL, 0, | ||||
acpi_debug_objects_sysctl, "I", | |||||
"Enable Debug objects"); | "Enable Debug objects"); | ||||
/* Allow the interpreter to ignore common mistakes in BIOS. */ | /* Allow the interpreter to ignore common mistakes in BIOS. */ | ||||
Context not available. | |||||
*/ | */ | ||||
sysctl_ctx_init(&sc->acpi_sysctl_ctx); | sysctl_ctx_init(&sc->acpi_sysctl_ctx); | ||||
sc->acpi_sysctl_tree = SYSCTL_ADD_NODE(&sc->acpi_sysctl_ctx, | sc->acpi_sysctl_tree = SYSCTL_ADD_NODE(&sc->acpi_sysctl_ctx, | ||||
SYSCTL_STATIC_CHILDREN(_hw), OID_AUTO, | SYSCTL_STATIC_CHILDREN(_hw), OID_AUTO, device_get_name(dev), | ||||
device_get_name(dev), CTLFLAG_RD, 0, ""); | CTLFLAG_RD | CTLFLAG_MPSAFE, 0, ""); | ||||
SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | ||||
OID_AUTO, "supported_sleep_state", CTLTYPE_STRING | CTLFLAG_RD, | OID_AUTO, "supported_sleep_state", | ||||
CTLTYPE_STRING | CTLFLAG_RD | CTLFLAG_NEEDGIANT, | |||||
0, 0, acpi_supported_sleep_state_sysctl, "A", | 0, 0, acpi_supported_sleep_state_sysctl, "A", | ||||
"List supported ACPI sleep states."); | "List supported ACPI sleep states."); | ||||
SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | ||||
OID_AUTO, "power_button_state", CTLTYPE_STRING | CTLFLAG_RW, | OID_AUTO, "power_button_state", | ||||
CTLTYPE_STRING | CTLFLAG_RW | CTLFLAG_NEEDGIANT, | |||||
&sc->acpi_power_button_sx, 0, acpi_sleep_state_sysctl, "A", | &sc->acpi_power_button_sx, 0, acpi_sleep_state_sysctl, "A", | ||||
"Power button ACPI sleep state."); | "Power button ACPI sleep state."); | ||||
SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | ||||
OID_AUTO, "sleep_button_state", CTLTYPE_STRING | CTLFLAG_RW, | OID_AUTO, "sleep_button_state", | ||||
CTLTYPE_STRING | CTLFLAG_RW | CTLFLAG_NEEDGIANT, | |||||
&sc->acpi_sleep_button_sx, 0, acpi_sleep_state_sysctl, "A", | &sc->acpi_sleep_button_sx, 0, acpi_sleep_state_sysctl, "A", | ||||
"Sleep button ACPI sleep state."); | "Sleep button ACPI sleep state."); | ||||
SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | ||||
OID_AUTO, "lid_switch_state", CTLTYPE_STRING | CTLFLAG_RW, | OID_AUTO, "lid_switch_state", | ||||
CTLTYPE_STRING | CTLFLAG_RW | CTLFLAG_NEEDGIANT, | |||||
&sc->acpi_lid_switch_sx, 0, acpi_sleep_state_sysctl, "A", | &sc->acpi_lid_switch_sx, 0, acpi_sleep_state_sysctl, "A", | ||||
"Lid ACPI sleep state. Set to S3 if you want to suspend your laptop when close the Lid."); | "Lid ACPI sleep state. Set to S3 if you want to suspend your laptop when close the Lid."); | ||||
SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | ||||
OID_AUTO, "standby_state", CTLTYPE_STRING | CTLFLAG_RW, | OID_AUTO, "standby_state", | ||||
CTLTYPE_STRING | CTLFLAG_RW | CTLFLAG_NEEDGIANT, | |||||
&sc->acpi_standby_sx, 0, acpi_sleep_state_sysctl, "A", ""); | &sc->acpi_standby_sx, 0, acpi_sleep_state_sysctl, "A", ""); | ||||
SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | SYSCTL_ADD_PROC(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | ||||
OID_AUTO, "suspend_state", CTLTYPE_STRING | CTLFLAG_RW, | OID_AUTO, "suspend_state", | ||||
CTLTYPE_STRING | CTLFLAG_RW | CTLFLAG_NEEDGIANT, | |||||
&sc->acpi_suspend_sx, 0, acpi_sleep_state_sysctl, "A", ""); | &sc->acpi_suspend_sx, 0, acpi_sleep_state_sysctl, "A", ""); | ||||
SYSCTL_ADD_INT(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | SYSCTL_ADD_INT(&sc->acpi_sysctl_ctx, SYSCTL_CHILDREN(sc->acpi_sysctl_tree), | ||||
OID_AUTO, "sleep_delay", CTLFLAG_RW, &sc->acpi_sleep_delay, 0, | OID_AUTO, "sleep_delay", CTLFLAG_RW, &sc->acpi_sleep_delay, 0, | ||||
Context not available. | |||||
if (ACPI_SUCCESS(status)) { | if (ACPI_SUCCESS(status)) { | ||||
SYSCTL_ADD_PROC(device_get_sysctl_ctx(child), | SYSCTL_ADD_PROC(device_get_sysctl_ctx(child), | ||||
SYSCTL_CHILDREN(device_get_sysctl_tree(child)), OID_AUTO, | SYSCTL_CHILDREN(device_get_sysctl_tree(child)), OID_AUTO, | ||||
"wake", CTLTYPE_INT | CTLFLAG_RW, child, 0, | "wake", CTLTYPE_INT | CTLFLAG_RW | CTLFLAG_NEEDGIANT, child, 0, | ||||
acpi_wake_set_sysctl, "I", "Device set to wake the system"); | acpi_wake_set_sysctl, "I", "Device set to wake the system"); | ||||
} | } | ||||
} | } | ||||
Context not available. | |||||
return (error); | return (error); | ||||
} | } | ||||
SYSCTL_PROC(_debug_acpi, OID_AUTO, layer, CTLFLAG_RW | CTLTYPE_STRING, | SYSCTL_PROC(_debug_acpi, OID_AUTO, layer, | ||||
"debug.acpi.layer", 0, acpi_debug_sysctl, "A", ""); | CTLFLAG_RW | CTLTYPE_STRING | CTLFLAG_NEEDGIANT, "debug.acpi.layer", 0, | ||||
SYSCTL_PROC(_debug_acpi, OID_AUTO, level, CTLFLAG_RW | CTLTYPE_STRING, | acpi_debug_sysctl, "A", | ||||
"debug.acpi.level", 0, acpi_debug_sysctl, "A", ""); | ""); | ||||
SYSCTL_PROC(_debug_acpi, OID_AUTO, level, | |||||
CTLFLAG_RW | CTLTYPE_STRING | CTLFLAG_NEEDGIANT, "debug.acpi.level", 0, | |||||
acpi_debug_sysctl, "A", | |||||
""); | |||||
#endif /* ACPI_DEBUG */ | #endif /* ACPI_DEBUG */ | ||||
static int | static int | ||||
Context not available. |