Commit 6d905081 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'acpi-5.7-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm

Pull ACPI updates from Rafael Wysocki:

   - Update the ACPICA code in the kernel to the 20200214 upstream
     release including:

       * Fix to re-enable the sleep button after wakeup (Anchal
         Agarwal).

       * Fixes for mistakes in comments and typos (Bob Moore).

       * ASL-ASL+ converter updates (Erik Kaneda).

       * Type casting cleanups (Sven Barth).

   - Clean up the intialization of the EC driver and eliminate some dead
     code from it (Rafael Wysocki).

   - Clean up the quirk tables in the AC and battery drivers (Hans de
     Goede).

   - Fix the global lock handling on x86 to ignore unspecified bit
     positions in the global lock field (Jan Engelhardt).

   - Add a new "tiny" driver for ACPI button devices exposed by VMs to
     guest kernels to send signals directly to init (Josh Triplett).

   - Add a kernel parameter to disable ACPI BGRT on x86 (Alex Hung).

   - Make the ACPI PCI host bridge and fan drivers use scnprintf() to
     avoid potential buffer overflows (Takashi Iwai).

   - Clean up assorted pieces of code:

       * Reorder "asmlinkage" to make g++ happy (Alexey Dobriyan).

       * Drop unneeded variable initialization (Colin Ian King).

       * Add missing __acquires/__releases annotations (Jules Irenge).

       * Replace list_for_each_safe() with list_for_each_entry_safe()
         (chenqiwu)"

* tag 'acpi-5.7-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (31 commits)
  ACPICA: Update version to 20200214
  ACPI: PCI: Use scnprintf() for avoiding potential buffer overflow
  ACPI: fan: Use scnprintf() for avoiding potential buffer overflow
  ACPI: EC: Eliminate EC_FLAGS_QUERY_HANDSHAKE
  ACPI: EC: Do not clear boot_ec_is_ecdt in acpi_ec_add()
  ACPI: EC: Simplify acpi_ec_ecdt_start() and acpi_ec_init()
  ACPI: EC: Consolidate event handler installation code
  acpi/x86: ignore unspecified bit positions in the ACPI global lock field
  acpi/x86: add a kernel parameter to disable ACPI BGRT
  x86/acpi: make "asmlinkage" part first thing in the function definition
  ACPI: list_for_each_safe() -> list_for_each_entry_safe()
  ACPI: video: remove redundant assignments to variable result
  ACPI: OSL: Add missing __acquires/__releases annotations
  ACPI / battery: Cleanup Lenovo Ideapad Miix 320 DMI table entry
  ACPI / AC: Cleanup DMI quirk table
  ACPI: EC: Use fast path in acpi_ec_add() for DSDT boot EC
  ACPI: EC: Simplify acpi_ec_add()
  ACPI: EC: Drop AE_NOT_FOUND special case from ec_install_handlers()
  ACPI: EC: Avoid passing redundant argument to functions
  ACPI: EC: Avoid printing confusing messages in acpi_ec_setup()
  ...
parents 49835c15 1da28f03
...@@ -450,6 +450,9 @@ ...@@ -450,6 +450,9 @@
bert_disable [ACPI] bert_disable [ACPI]
Disable BERT OS support on buggy BIOSes. Disable BERT OS support on buggy BIOSes.
bgrt_disable [ACPI][X86]
Disable BGRT to avoid flickering OEM logo.
bttv.card= [HW,V4L] bttv (bt848 + bt878 based grabber cards) bttv.card= [HW,V4L] bttv (bt848 + bt878 based grabber cards)
bttv.radio= Most important insmod options are available as bttv.radio= Most important insmod options are available as
kernel args too. kernel args too.
......
...@@ -45,6 +45,7 @@ EXPORT_SYMBOL(acpi_disabled); ...@@ -45,6 +45,7 @@ EXPORT_SYMBOL(acpi_disabled);
#define PREFIX "ACPI: " #define PREFIX "ACPI: "
int acpi_noirq; /* skip ACPI IRQ initialization */ int acpi_noirq; /* skip ACPI IRQ initialization */
int acpi_nobgrt; /* skip ACPI BGRT */
int acpi_pci_disabled; /* skip ACPI PCI scan and IRQ initialization */ int acpi_pci_disabled; /* skip ACPI PCI scan and IRQ initialization */
EXPORT_SYMBOL(acpi_pci_disabled); EXPORT_SYMBOL(acpi_pci_disabled);
...@@ -1619,7 +1620,7 @@ int __init acpi_boot_init(void) ...@@ -1619,7 +1620,7 @@ int __init acpi_boot_init(void)
acpi_process_madt(); acpi_process_madt();
acpi_table_parse(ACPI_SIG_HPET, acpi_parse_hpet); acpi_table_parse(ACPI_SIG_HPET, acpi_parse_hpet);
if (IS_ENABLED(CONFIG_ACPI_BGRT)) if (IS_ENABLED(CONFIG_ACPI_BGRT) && !acpi_nobgrt)
acpi_table_parse(ACPI_SIG_BGRT, acpi_parse_bgrt); acpi_table_parse(ACPI_SIG_BGRT, acpi_parse_bgrt);
if (!acpi_noirq) if (!acpi_noirq)
...@@ -1671,6 +1672,13 @@ static int __init parse_acpi(char *arg) ...@@ -1671,6 +1672,13 @@ static int __init parse_acpi(char *arg)
} }
early_param("acpi", parse_acpi); early_param("acpi", parse_acpi);
static int __init parse_acpi_bgrt(char *arg)
{
acpi_nobgrt = true;
return 0;
}
early_param("bgrt_disable", parse_acpi_bgrt);
/* FIXME: Using pci= for an ACPI parameter is a travesty. */ /* FIXME: Using pci= for an ACPI parameter is a travesty. */
static int __init parse_pci(char *arg) static int __init parse_pci(char *arg)
{ {
...@@ -1740,7 +1748,7 @@ int __acpi_acquire_global_lock(unsigned int *lock) ...@@ -1740,7 +1748,7 @@ int __acpi_acquire_global_lock(unsigned int *lock)
new = (((old & ~0x3) + 2) + ((old >> 1) & 0x1)); new = (((old & ~0x3) + 2) + ((old >> 1) & 0x1));
val = cmpxchg(lock, old, new); val = cmpxchg(lock, old, new);
} while (unlikely (val != old)); } while (unlikely (val != old));
return (new < 3) ? -1 : 0; return ((new & 0x3) < 3) ? -1 : 0;
} }
int __acpi_release_global_lock(unsigned int *lock) int __acpi_release_global_lock(unsigned int *lock)
......
...@@ -43,7 +43,7 @@ unsigned long acpi_get_wakeup_address(void) ...@@ -43,7 +43,7 @@ unsigned long acpi_get_wakeup_address(void)
* *
* Wrapper around acpi_enter_sleep_state() to be called by assmebly. * Wrapper around acpi_enter_sleep_state() to be called by assmebly.
*/ */
acpi_status asmlinkage __visible x86_acpi_enter_sleep_state(u8 state) asmlinkage acpi_status __visible x86_acpi_enter_sleep_state(u8 state)
{ {
return acpi_enter_sleep_state(state); return acpi_enter_sleep_state(state);
} }
......
...@@ -19,4 +19,4 @@ extern void do_suspend_lowlevel(void); ...@@ -19,4 +19,4 @@ extern void do_suspend_lowlevel(void);
extern int x86_acpi_suspend_lowlevel(void); extern int x86_acpi_suspend_lowlevel(void);
acpi_status asmlinkage x86_acpi_enter_sleep_state(u8 state); asmlinkage acpi_status x86_acpi_enter_sleep_state(u8 state);
...@@ -190,6 +190,30 @@ config ACPI_BUTTON ...@@ -190,6 +190,30 @@ config ACPI_BUTTON
To compile this driver as a module, choose M here: To compile this driver as a module, choose M here:
the module will be called button. the module will be called button.
config ACPI_TINY_POWER_BUTTON
tristate "Tiny Power Button Driver"
depends on !ACPI_BUTTON
help
This driver provides a tiny alternative to the ACPI Button driver.
The tiny power button driver only handles the power button. Rather
than notifying userspace via the input layer or a netlink event, this
driver directly signals the init process to shut down.
This driver is particularly suitable for cloud and VM environments,
which use a simulated power button to initiate a controlled poweroff,
but which may not want to run a separate userspace daemon to process
input events.
config ACPI_TINY_POWER_BUTTON_SIGNAL
int "Tiny Power Button Signal"
depends on ACPI_TINY_POWER_BUTTON
default 38
help
Default signal to send to init in response to the power button.
Likely values here include 38 (SIGRTMIN+4) to power off, or 2
(SIGINT) to simulate Ctrl+Alt+Del.
config ACPI_VIDEO config ACPI_VIDEO
tristate "Video" tristate "Video"
depends on X86 && BACKLIGHT_CLASS_DEVICE depends on X86 && BACKLIGHT_CLASS_DEVICE
......
...@@ -71,6 +71,7 @@ obj-$(CONFIG_ACPI_IPMI) += acpi_ipmi.o ...@@ -71,6 +71,7 @@ obj-$(CONFIG_ACPI_IPMI) += acpi_ipmi.o
obj-$(CONFIG_ACPI_AC) += ac.o obj-$(CONFIG_ACPI_AC) += ac.o
obj-$(CONFIG_ACPI_BUTTON) += button.o obj-$(CONFIG_ACPI_BUTTON) += button.o
obj-$(CONFIG_ACPI_TINY_POWER_BUTTON) += tiny-power-button.o
obj-$(CONFIG_ACPI_FAN) += fan.o obj-$(CONFIG_ACPI_FAN) += fan.o
obj-$(CONFIG_ACPI_VIDEO) += video.o obj-$(CONFIG_ACPI_VIDEO) += video.o
obj-$(CONFIG_ACPI_TAD) += acpi_tad.o obj-$(CONFIG_ACPI_TAD) += acpi_tad.o
......
...@@ -293,29 +293,30 @@ static int __init ac_do_not_check_pmic_quirk(const struct dmi_system_id *d) ...@@ -293,29 +293,30 @@ static int __init ac_do_not_check_pmic_quirk(const struct dmi_system_id *d)
return 0; return 0;
} }
/* Please keep this list alphabetically sorted */
static const struct dmi_system_id ac_dmi_table[] __initconst = { static const struct dmi_system_id ac_dmi_table[] __initconst = {
{ {
/* Thinkpad e530 */ /* ECS EF20EA, AXP288 PMIC but uses separate fuel-gauge */
.callback = thinkpad_e530_quirk, .callback = ac_do_not_check_pmic_quirk,
.matches = { .matches = {
DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"), DMI_MATCH(DMI_PRODUCT_NAME, "EF20EA"),
DMI_MATCH(DMI_PRODUCT_NAME, "32597CG"),
}, },
}, },
{ {
/* ECS EF20EA */ /* Lenovo Ideapad Miix 320, AXP288 PMIC, separate fuel-gauge */
.callback = ac_do_not_check_pmic_quirk, .callback = ac_do_not_check_pmic_quirk,
.matches = { .matches = {
DMI_MATCH(DMI_PRODUCT_NAME, "EF20EA"), DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"),
DMI_MATCH(DMI_PRODUCT_NAME, "80XF"),
DMI_MATCH(DMI_PRODUCT_VERSION, "Lenovo MIIX 320-10ICR"),
}, },
}, },
{ {
/* Lenovo Ideapad Miix 320 */ /* Lenovo Thinkpad e530, see comment in acpi_ac_notify() */
.callback = ac_do_not_check_pmic_quirk, .callback = thinkpad_e530_quirk,
.matches = { .matches = {
DMI_EXACT_MATCH(DMI_SYS_VENDOR, "LENOVO"), DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"),
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "80XF"), DMI_MATCH(DMI_PRODUCT_NAME, "32597CG"),
DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "Lenovo MIIX 320-10ICR"),
}, },
}, },
{}, {},
......
...@@ -943,7 +943,7 @@ acpi_video_init_brightness(struct acpi_video_device *device) ...@@ -943,7 +943,7 @@ acpi_video_init_brightness(struct acpi_video_device *device)
int i, max_level = 0; int i, max_level = 0;
unsigned long long level, level_old; unsigned long long level, level_old;
struct acpi_video_device_brightness *br = NULL; struct acpi_video_device_brightness *br = NULL;
int result = -EINVAL; int result;
result = acpi_video_get_levels(device->dev, &br, &max_level); result = acpi_video_get_levels(device->dev, &br, &max_level);
if (result) if (result)
......
...@@ -65,9 +65,7 @@ void cg_write_aml_comment(union acpi_parse_object *op); ...@@ -65,9 +65,7 @@ void cg_write_aml_comment(union acpi_parse_object *op);
/* /*
* cvparser * cvparser
*/ */
void void cv_init_file_tree(struct acpi_table_header *table, FILE * root_file);
cv_init_file_tree(struct acpi_table_header *table,
u8 *aml_start, u32 aml_length);
void cv_clear_op_comments(union acpi_parse_object *op); void cv_clear_op_comments(union acpi_parse_object *op);
......
...@@ -477,7 +477,7 @@ ...@@ -477,7 +477,7 @@
#define ASL_CV_PRINT_ONE_COMMENT(a,b,c,d) cv_print_one_comment_type (a,b,c,d); #define ASL_CV_PRINT_ONE_COMMENT(a,b,c,d) cv_print_one_comment_type (a,b,c,d);
#define ASL_CV_PRINT_ONE_COMMENT_LIST(a,b) cv_print_one_comment_list (a,b); #define ASL_CV_PRINT_ONE_COMMENT_LIST(a,b) cv_print_one_comment_list (a,b);
#define ASL_CV_FILE_HAS_SWITCHED(a) cv_file_has_switched(a) #define ASL_CV_FILE_HAS_SWITCHED(a) cv_file_has_switched(a)
#define ASL_CV_INIT_FILETREE(a,b,c) cv_init_file_tree(a,b,c); #define ASL_CV_INIT_FILETREE(a,b) cv_init_file_tree(a,b);
#else #else
...@@ -492,7 +492,7 @@ ...@@ -492,7 +492,7 @@
#define ASL_CV_PRINT_ONE_COMMENT(a,b,c,d) #define ASL_CV_PRINT_ONE_COMMENT(a,b,c,d)
#define ASL_CV_PRINT_ONE_COMMENT_LIST(a,b) #define ASL_CV_PRINT_ONE_COMMENT_LIST(a,b)
#define ASL_CV_FILE_HAS_SWITCHED(a) 0 #define ASL_CV_FILE_HAS_SWITCHED(a) 0
#define ASL_CV_INIT_FILETREE(a,b,c) #define ASL_CV_INIT_FILETREE(a,b)
#endif #endif
......
...@@ -130,7 +130,7 @@ static acpi_status acpi_ev_fixed_event_initialize(void) ...@@ -130,7 +130,7 @@ static acpi_status acpi_ev_fixed_event_initialize(void)
/* /*
* Initialize the structure that keeps track of fixed event handlers and * Initialize the structure that keeps track of fixed event handlers and
* enable the fixed events. * disable all of the fixed events.
*/ */
for (i = 0; i < ACPI_NUM_FIXED_EVENTS; i++) { for (i = 0; i < ACPI_NUM_FIXED_EVENTS; i++) {
acpi_gbl_fixed_event_handlers[i].handler = NULL; acpi_gbl_fixed_event_handlers[i].handler = NULL;
......
...@@ -300,6 +300,18 @@ acpi_status acpi_hw_legacy_wake(u8 sleep_state) ...@@ -300,6 +300,18 @@ acpi_status acpi_hw_legacy_wake(u8 sleep_state)
[ACPI_EVENT_POWER_BUTTON]. [ACPI_EVENT_POWER_BUTTON].
status_register_id, ACPI_CLEAR_STATUS); status_register_id, ACPI_CLEAR_STATUS);
/* Enable sleep button */
(void)
acpi_write_bit_register(acpi_gbl_fixed_event_info
[ACPI_EVENT_SLEEP_BUTTON].
enable_register_id, ACPI_ENABLE_EVENT);
(void)
acpi_write_bit_register(acpi_gbl_fixed_event_info
[ACPI_EVENT_SLEEP_BUTTON].
status_register_id, ACPI_CLEAR_STATUS);
acpi_hw_execute_sleep_method(METHOD_PATHNAME__SST, ACPI_SST_WORKING); acpi_hw_execute_sleep_method(METHOD_PATHNAME__SST, ACPI_SST_WORKING);
return_ACPI_STATUS(status); return_ACPI_STATUS(status);
} }
......
...@@ -164,7 +164,7 @@ acpi_ns_handle_to_pathname(acpi_handle target_handle, ...@@ -164,7 +164,7 @@ acpi_ns_handle_to_pathname(acpi_handle target_handle,
/* Build the path in the caller buffer */ /* Build the path in the caller buffer */
(void)acpi_ns_build_normalized_path(node, buffer->pointer, (void)acpi_ns_build_normalized_path(node, buffer->pointer,
required_size, no_trailing); (u32)required_size, no_trailing);
ACPI_DEBUG_PRINT((ACPI_DB_EXEC, "%s [%X]\n", ACPI_DEBUG_PRINT((ACPI_DB_EXEC, "%s [%X]\n",
(char *)buffer->pointer, (u32) required_size)); (char *)buffer->pointer, (u32) required_size));
...@@ -315,7 +315,7 @@ char *acpi_ns_get_normalized_pathname(struct acpi_namespace_node *node, ...@@ -315,7 +315,7 @@ char *acpi_ns_get_normalized_pathname(struct acpi_namespace_node *node,
/* Build the path in the allocated buffer */ /* Build the path in the allocated buffer */
(void)acpi_ns_build_normalized_path(node, name_buffer, size, (void)acpi_ns_build_normalized_path(node, name_buffer, (u32)size,
no_trailing); no_trailing);
ACPI_DEBUG_PRINT_RAW((ACPI_DB_NAMES, "%s: Path \"%s\"\n", ACPI_DEBUG_PRINT_RAW((ACPI_DB_NAMES, "%s: Path \"%s\"\n",
...@@ -346,7 +346,7 @@ char *acpi_ns_build_prefixed_pathname(union acpi_generic_state *prefix_scope, ...@@ -346,7 +346,7 @@ char *acpi_ns_build_prefixed_pathname(union acpi_generic_state *prefix_scope,
char *full_path = NULL; char *full_path = NULL;
char *external_path = NULL; char *external_path = NULL;
char *prefix_path = NULL; char *prefix_path = NULL;
u32 prefix_path_length = 0; acpi_size prefix_path_length = 0;
/* If there is a prefix, get the pathname to it */ /* If there is a prefix, get the pathname to it */
......
...@@ -516,7 +516,7 @@ acpi_status acpi_install_method(u8 *buffer) ...@@ -516,7 +516,7 @@ acpi_status acpi_install_method(u8 *buffer)
method_flags = *parser_state.aml++; method_flags = *parser_state.aml++;
aml_start = parser_state.aml; aml_start = parser_state.aml;
aml_length = ACPI_PTR_DIFF(parser_state.pkg_end, aml_start); aml_length = (u32)ACPI_PTR_DIFF(parser_state.pkg_end, aml_start);
/* /*
* Allocate resources up-front. We don't want to have to delete a new * Allocate resources up-front. We don't want to have to delete a new
......
...@@ -202,14 +202,14 @@ ACPI_EXPORT_SYMBOL_INIT(acpi_reallocate_root_table) ...@@ -202,14 +202,14 @@ ACPI_EXPORT_SYMBOL_INIT(acpi_reallocate_root_table)
* *
* PARAMETERS: signature - ACPI signature of needed table * PARAMETERS: signature - ACPI signature of needed table
* instance - Which instance (for SSDTs) * instance - Which instance (for SSDTs)
* out_table_header - The pointer to the table header to fill * out_table_header - The pointer to the where the table header
* is returned
* *
* RETURN: Status and pointer to mapped table header * RETURN: Status and a copy of the table header
* *
* DESCRIPTION: Finds an ACPI table header. * DESCRIPTION: Finds and returns an ACPI table header. Caller provides the
* * memory where a copy of the header is to be returned
* NOTE: Caller is responsible in unmapping the header with * (fixed length).
* acpi_os_unmap_memory
* *
******************************************************************************/ ******************************************************************************/
acpi_status acpi_status
......
...@@ -44,7 +44,7 @@ acpi_ut_get_element_length(u8 object_type, ...@@ -44,7 +44,7 @@ acpi_ut_get_element_length(u8 object_type,
* *
* NOTE: We always allocate the worst-case object descriptor because * NOTE: We always allocate the worst-case object descriptor because
* these objects are cached, and we want them to be * these objects are cached, and we want them to be
* one-size-satisifies-any-request. This in itself may not be * one-size-satisfies-any-request. This in itself may not be
* the most memory efficient, but the efficiency of the object * the most memory efficient, but the efficiency of the object
* cache should more than make up for this! * cache should more than make up for this!
* *
......
...@@ -1365,19 +1365,19 @@ static const struct dmi_system_id bat_dmi_table[] __initconst = { ...@@ -1365,19 +1365,19 @@ static const struct dmi_system_id bat_dmi_table[] __initconst = {
}, },
}, },
{ {
/* ECS EF20EA */ /* ECS EF20EA, AXP288 PMIC but uses separate fuel-gauge */
.callback = battery_do_not_check_pmic_quirk, .callback = battery_do_not_check_pmic_quirk,
.matches = { .matches = {
DMI_MATCH(DMI_PRODUCT_NAME, "EF20EA"), DMI_MATCH(DMI_PRODUCT_NAME, "EF20EA"),
}, },
}, },
{ {
/* Lenovo Ideapad Miix 320 */ /* Lenovo Ideapad Miix 320, AXP288 PMIC, separate fuel-gauge */
.callback = battery_do_not_check_pmic_quirk, .callback = battery_do_not_check_pmic_quirk,
.matches = { .matches = {
DMI_EXACT_MATCH(DMI_SYS_VENDOR, "LENOVO"), DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"),
DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "80XF"), DMI_MATCH(DMI_PRODUCT_NAME, "80XF"),
DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "Lenovo MIIX 320-10ICR"), DMI_MATCH(DMI_PRODUCT_VERSION, "Lenovo MIIX 320-10ICR"),
}, },
}, },
{}, {},
......
...@@ -30,17 +30,14 @@ ...@@ -30,17 +30,14 @@
#define ACPI_BUTTON_NOTIFY_STATUS 0x80 #define ACPI_BUTTON_NOTIFY_STATUS 0x80
#define ACPI_BUTTON_SUBCLASS_POWER "power" #define ACPI_BUTTON_SUBCLASS_POWER "power"
#define ACPI_BUTTON_HID_POWER "PNP0C0C"
#define ACPI_BUTTON_DEVICE_NAME_POWER "Power Button" #define ACPI_BUTTON_DEVICE_NAME_POWER "Power Button"
#define ACPI_BUTTON_TYPE_POWER 0x01 #define ACPI_BUTTON_TYPE_POWER 0x01
#define ACPI_BUTTON_SUBCLASS_SLEEP "sleep" #define ACPI_BUTTON_SUBCLASS_SLEEP "sleep"
#define ACPI_BUTTON_HID_SLEEP "PNP0C0E"
#define ACPI_BUTTON_DEVICE_NAME_SLEEP "Sleep Button" #define ACPI_BUTTON_DEVICE_NAME_SLEEP "Sleep Button"
#define ACPI_BUTTON_TYPE_SLEEP 0x03 #define ACPI_BUTTON_TYPE_SLEEP 0x03
#define ACPI_BUTTON_SUBCLASS_LID "lid" #define ACPI_BUTTON_SUBCLASS_LID "lid"
#define ACPI_BUTTON_HID_LID "PNP0C0D"
#define ACPI_BUTTON_DEVICE_NAME_LID "Lid Switch" #define ACPI_BUTTON_DEVICE_NAME_LID "Lid Switch"
#define ACPI_BUTTON_TYPE_LID 0x05 #define ACPI_BUTTON_TYPE_LID 0x05
......
This diff is collapsed.
...@@ -276,29 +276,29 @@ static ssize_t show_state(struct device *dev, struct device_attribute *attr, cha ...@@ -276,29 +276,29 @@ static ssize_t show_state(struct device *dev, struct device_attribute *attr, cha
int count; int count;
if (fps->control == 0xFFFFFFFF || fps->control > 100) if (fps->control == 0xFFFFFFFF || fps->control > 100)
count = snprintf(buf, PAGE_SIZE, "not-defined:"); count = scnprintf(buf, PAGE_SIZE, "not-defined:");
else else
count = snprintf(buf, PAGE_SIZE, "%lld:", fps->control); count = scnprintf(buf, PAGE_SIZE, "%lld:", fps->control);
if (fps->trip_point == 0xFFFFFFFF || fps->trip_point > 9) if (fps->trip_point == 0xFFFFFFFF || fps->trip_point > 9)
count += snprintf(&buf[count], PAGE_SIZE, "not-defined:"); count += scnprintf(&buf[count], PAGE_SIZE - count, "not-defined:");
else else
count += snprintf(&buf[count], PAGE_SIZE, "%lld:", fps->trip_point); count += scnprintf(&buf[count], PAGE_SIZE - count, "%lld:", fps->trip_point);
if (fps->speed == 0xFFFFFFFF) if (fps->speed == 0xFFFFFFFF)
count += snprintf(&buf[count], PAGE_SIZE, "not-defined:"); count += scnprintf(&buf[count], PAGE_SIZE - count, "not-defined:");
else else
count += snprintf(&buf[count], PAGE_SIZE, "%lld:", fps->speed); count += scnprintf(&buf[count], PAGE_SIZE - count, "%lld:", fps->speed);
if (fps->noise_level == 0xFFFFFFFF) if (fps->noise_level == 0xFFFFFFFF)
count += snprintf(&buf[count], PAGE_SIZE, "not-defined:"); count += scnprintf(&buf[count], PAGE_SIZE - count, "not-defined:");
else else
count += snprintf(&buf[count], PAGE_SIZE, "%lld:", fps->noise_level * 100); count += scnprintf(&buf[count], PAGE_SIZE - count, "%lld:", fps->noise_level * 100);
if (fps->power == 0xFFFFFFFF) if (fps->power == 0xFFFFFFFF)
count += snprintf(&buf[count], PAGE_SIZE, "not-defined\n"); count += scnprintf(&buf[count], PAGE_SIZE - count, "not-defined\n");
else else
count += snprintf(&buf[count], PAGE_SIZE, "%lld\n", fps->power); count += scnprintf(&buf[count], PAGE_SIZE - count, "%lld\n", fps->power);
return count; return count;
} }
......
...@@ -190,7 +190,7 @@ extern struct acpi_ec *first_ec; ...@@ -190,7 +190,7 @@ extern struct acpi_ec *first_ec;
/* External interfaces use first EC only, so remember */ /* External interfaces use first EC only, so remember */
typedef int (*acpi_ec_query_func) (void *data); typedef int (*acpi_ec_query_func) (void *data);
int acpi_ec_init(void); void acpi_ec_init(void);
void acpi_ec_ecdt_probe(void); void acpi_ec_ecdt_probe(void);
void acpi_ec_dsdt_probe(void); void acpi_ec_dsdt_probe(void);
void acpi_ec_block_transactions(void); void acpi_ec_block_transactions(void);
......
...@@ -1598,6 +1598,7 @@ void acpi_os_delete_lock(acpi_spinlock handle) ...@@ -1598,6 +1598,7 @@ void acpi_os_delete_lock(acpi_spinlock handle)
*/ */
acpi_cpu_flags acpi_os_acquire_lock(acpi_spinlock lockp) acpi_cpu_flags acpi_os_acquire_lock(acpi_spinlock lockp)
__acquires(lockp)
{ {
acpi_cpu_flags flags; acpi_cpu_flags flags;
spin_lock_irqsave(lockp, flags); spin_lock_irqsave(lockp, flags);
...@@ -1609,6 +1610,7 @@ acpi_cpu_flags acpi_os_acquire_lock(acpi_spinlock lockp) ...@@ -1609,6 +1610,7 @@ acpi_cpu_flags acpi_os_acquire_lock(acpi_spinlock lockp)
*/ */
void acpi_os_release_lock(acpi_spinlock lockp, acpi_cpu_flags flags) void acpi_os_release_lock(acpi_spinlock lockp, acpi_cpu_flags flags)
__releases(lockp)
{ {
spin_unlock_irqrestore(lockp, flags); spin_unlock_irqrestore(lockp, flags);
} }
......
...@@ -153,7 +153,7 @@ static void decode_osc_bits(struct acpi_pci_root *root, char *msg, u32 word, ...@@ -153,7 +153,7 @@ static void decode_osc_bits(struct acpi_pci_root *root, char *msg, u32 word,
buf[0] = '\0'; buf[0] = '\0';
for (i = 0, entry = table; i < size; i++, entry++) for (i = 0, entry = table; i < size; i++, entry++)
if (word & entry->bit) if (word & entry->bit)
len += snprintf(buf + len, sizeof(buf) - len, "%s%s", len += scnprintf(buf + len, sizeof(buf) - len, "%s%s",
len ? " " : "", entry->desc); len ? " " : "", entry->desc);
dev_info(&root->device->dev, "_OSC: %s [%s]\n", msg, buf); dev_info(&root->device->dev, "_OSC: %s [%s]\n", msg, buf);
......
...@@ -22,14 +22,13 @@ ACPI_MODULE_NAME("sleep") ...@@ -22,14 +22,13 @@ ACPI_MODULE_NAME("sleep")
static int static int
acpi_system_wakeup_device_seq_show(struct seq_file *seq, void *offset) acpi_system_wakeup_device_seq_show(struct seq_file *seq, void *offset)
{ {
struct list_head *node, *next; struct acpi_device *dev, *tmp;
seq_printf(seq, "Device\tS-state\t Status Sysfs node\n"); seq_printf(seq, "Device\tS-state\t Status Sysfs node\n");
mutex_lock(&acpi_device_lock); mutex_lock(&acpi_device_lock);
list_for_each_safe(node, next, &acpi_wakeup_device_list) { list_for_each_entry_safe(dev, tmp, &acpi_wakeup_device_list,
struct acpi_device *dev = wakeup_list) {
container_of(node, struct acpi_device, wakeup_list);
struct acpi_device_physical_node *entry; struct acpi_device_physical_node *entry;
if (!dev->wakeup.flags.valid) if (!dev->wakeup.flags.valid)
...@@ -96,7 +95,7 @@ acpi_system_write_wakeup_device(struct file *file, ...@@ -96,7 +95,7 @@ acpi_system_write_wakeup_device(struct file *file,
const char __user * buffer, const char __user * buffer,
size_t count, loff_t * ppos) size_t count, loff_t * ppos)
{ {
struct list_head *node, *next; struct acpi_device *dev, *tmp;
char strbuf[5]; char strbuf[5];
char str[5] = ""; char str[5] = "";
...@@ -109,9 +108,8 @@ acpi_system_write_wakeup_device(struct file *file, ...@@ -109,9 +108,8 @@ acpi_system_write_wakeup_device(struct file *file,
sscanf(strbuf, "%s", str); sscanf(strbuf, "%s", str);
mutex_lock(&acpi_device_lock); mutex_lock(&acpi_device_lock);
list_for_each_safe(node, next, &acpi_wakeup_device_list) { list_for_each_entry_safe(dev, tmp, &acpi_wakeup_device_list,
struct acpi_device *dev = wakeup_list) {
container_of(node, struct acpi_device, wakeup_list);
if (!dev->wakeup.flags.valid) if (!dev->wakeup.flags.valid)
continue; continue;
......
// SPDX-License-Identifier: GPL-2.0-or-later
#include <linux/module.h>
#include <linux/sched/signal.h>
#include <linux/acpi.h>
#include <acpi/button.h>
ACPI_MODULE_NAME("tiny-power-button");
MODULE_AUTHOR("Josh Triplett");
MODULE_DESCRIPTION("ACPI Tiny Power Button Driver");
MODULE_LICENSE("GPL");
static int power_signal __read_mostly = CONFIG_ACPI_TINY_POWER_BUTTON_SIGNAL;
module_param(power_signal, int, 0644);
MODULE_PARM_DESC(power_signal, "Power button sends this signal to init");
static const struct acpi_device_id tiny_power_button_device_ids[] = {
{ ACPI_BUTTON_HID_POWER, 0 },
{ ACPI_BUTTON_HID_POWERF, 0 },
{ "", 0 },
};
MODULE_DEVICE_TABLE(acpi, tiny_power_button_device_ids);
static int acpi_noop_add_remove(struct acpi_device *device)
{
return 0;
}
static void acpi_tiny_power_button_notify(struct acpi_device *device, u32 event)
{
kill_cad_pid(power_signal, 1);
}
static struct acpi_driver acpi_tiny_power_button_driver = {
.name = "tiny-power-button",
.class = "tiny-power-button",
.ids = tiny_power_button_device_ids,
.ops = {
.add = acpi_noop_add_remove,
.remove = acpi_noop_add_remove,
.notify = acpi_tiny_power_button_notify,
},
};
module_driver(acpi_tiny_power_button_driver,
acpi_bus_register_driver,
acpi_bus_unregister_driver);
...@@ -30,12 +30,10 @@ ACPI_MODULE_NAME("wakeup_devices") ...@@ -30,12 +30,10 @@ ACPI_MODULE_NAME("wakeup_devices")
*/ */
void acpi_enable_wakeup_devices(u8 sleep_state) void acpi_enable_wakeup_devices(u8 sleep_state)
{ {
struct list_head *node, *next; struct acpi_device *dev, *tmp;
list_for_each_safe(node, next, &acpi_wakeup_device_list) {
struct acpi_device *dev =
container_of(node, struct acpi_device, wakeup_list);
list_for_each_entry_safe(dev, tmp, &acpi_wakeup_device_list,
wakeup_list) {
if (!dev->wakeup.flags.valid if (!dev->wakeup.flags.valid
|| sleep_state > (u32) dev->wakeup.sleep_state || sleep_state > (u32) dev->wakeup.sleep_state
|| !(device_may_wakeup(&dev->dev) || !(device_may_wakeup(&dev->dev)
...@@ -57,12 +55,10 @@ void acpi_enable_wakeup_devices(u8 sleep_state) ...@@ -57,12 +55,10 @@ void acpi_enable_wakeup_devices(u8 sleep_state)
*/ */
void acpi_disable_wakeup_devices(u8 sleep_state) void acpi_disable_wakeup_devices(u8 sleep_state)
{ {
struct list_head *node, *next; struct acpi_device *dev, *tmp;
list_for_each_safe(node, next, &acpi_wakeup_device_list) {
struct acpi_device *dev =
container_of(node, struct acpi_device, wakeup_list);
list_for_each_entry_safe(dev, tmp, &acpi_wakeup_device_list,
wakeup_list) {
if (!dev->wakeup.flags.valid if (!dev->wakeup.flags.valid
|| sleep_state > (u32) dev->wakeup.sleep_state || sleep_state > (u32) dev->wakeup.sleep_state
|| !(device_may_wakeup(&dev->dev) || !(device_may_wakeup(&dev->dev)
...@@ -79,13 +75,11 @@ void acpi_disable_wakeup_devices(u8 sleep_state) ...@@ -79,13 +75,11 @@ void acpi_disable_wakeup_devices(u8 sleep_state)
int __init acpi_wakeup_device_init(void) int __init acpi_wakeup_device_init(void)
{ {
struct list_head *node, *next; struct acpi_device *dev, *tmp;
mutex_lock(&acpi_device_lock); mutex_lock(&acpi_device_lock);
list_for_each_safe(node, next, &acpi_wakeup_device_list) { list_for_each_entry_safe(dev, tmp, &acpi_wakeup_device_list,
struct acpi_device *dev = container_of(node, wakeup_list) {
struct acpi_device,
wakeup_list);
if (device_can_wakeup(&dev->dev)) { if (device_can_wakeup(&dev->dev)) {
/* Button GPEs are supposed to be always enabled. */ /* Button GPEs are supposed to be always enabled. */
acpi_enable_gpe(dev->wakeup.gpe_device, acpi_enable_gpe(dev->wakeup.gpe_device,
......
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
/* Current ACPICA subsystem version in YYYYMMDD format */ /* Current ACPICA subsystem version in YYYYMMDD format */
#define ACPI_CA_VERSION 0x20200110 #define ACPI_CA_VERSION 0x20200214
#include <acpi/acconfig.h> #include <acpi/acconfig.h>
#include <acpi/actypes.h> #include <acpi/actypes.h>
......
...@@ -862,7 +862,7 @@ enum acpi_erst_instructions { ...@@ -862,7 +862,7 @@ enum acpi_erst_instructions {
/* Command status return values */ /* Command status return values */
enum acpi_erst_command_status { enum acpi_erst_command_status {
ACPI_ERST_SUCESS = 0, ACPI_ERST_SUCCESS = 0,
ACPI_ERST_NO_SPACE = 1, ACPI_ERST_NO_SPACE = 1,
ACPI_ERST_NOT_AVAILABLE = 2, ACPI_ERST_NOT_AVAILABLE = 2,
ACPI_ERST_FAILURE = 3, ACPI_ERST_FAILURE = 3,
......
...@@ -2,6 +2,10 @@ ...@@ -2,6 +2,10 @@
#ifndef ACPI_BUTTON_H #ifndef ACPI_BUTTON_H
#define ACPI_BUTTON_H #define ACPI_BUTTON_H
#define ACPI_BUTTON_HID_POWER "PNP0C0C"
#define ACPI_BUTTON_HID_LID "PNP0C0D"
#define ACPI_BUTTON_HID_SLEEP "PNP0C0E"
#if IS_ENABLED(CONFIG_ACPI_BUTTON) #if IS_ENABLED(CONFIG_ACPI_BUTTON)
extern int acpi_lid_open(void); extern int acpi_lid_open(void);
#else #else
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment