Commit eb5fcc31 authored by Rafael J. Wysocki's avatar Rafael J. Wysocki

Merge branches 'acpi-ec', 'acpi-button', 'acpi-sysfs', 'acpi-lpss' and 'acpi-cppc'

* acpi-ec:
  ACPI / EC: Fix regression related to triggering source of EC event handling

* acpi-button:
  ACPI / button: Delay acpi_lid_initialize_state() until first user space open

* acpi-sysfs:
  ACPI / sysfs: Make function param_set_trace_method_name() static

* acpi-lpss:
  ACPI / LPSS: Remove redundant initialization of clk

* acpi-cppc:
  ACPI / CPPC: Make CPPC ACPI driver aware of PCC subspace IDs
  mailbox: PCC: Move the MAX_PCC_SUBSPACES definition to header file
...@@ -362,7 +362,7 @@ static int register_device_clock(struct acpi_device *adev, ...@@ -362,7 +362,7 @@ static int register_device_clock(struct acpi_device *adev,
{ {
const struct lpss_device_desc *dev_desc = pdata->dev_desc; const struct lpss_device_desc *dev_desc = pdata->dev_desc;
const char *devname = dev_name(&adev->dev); const char *devname = dev_name(&adev->dev);
struct clk *clk = ERR_PTR(-ENODEV); struct clk *clk;
struct lpss_clk_data *clk_data; struct lpss_clk_data *clk_data;
const char *parent, *clk_name; const char *parent, *clk_name;
void __iomem *prv_base; void __iomem *prv_base;
......
...@@ -390,6 +390,7 @@ static void acpi_button_notify(struct acpi_device *device, u32 event) ...@@ -390,6 +390,7 @@ static void acpi_button_notify(struct acpi_device *device, u32 event)
{ {
struct acpi_button *button = acpi_driver_data(device); struct acpi_button *button = acpi_driver_data(device);
struct input_dev *input; struct input_dev *input;
int users;
switch (event) { switch (event) {
case ACPI_FIXED_HARDWARE_EVENT: case ACPI_FIXED_HARDWARE_EVENT:
...@@ -398,7 +399,11 @@ static void acpi_button_notify(struct acpi_device *device, u32 event) ...@@ -398,7 +399,11 @@ static void acpi_button_notify(struct acpi_device *device, u32 event)
case ACPI_BUTTON_NOTIFY_STATUS: case ACPI_BUTTON_NOTIFY_STATUS:
input = button->input; input = button->input;
if (button->type == ACPI_BUTTON_TYPE_LID) { if (button->type == ACPI_BUTTON_TYPE_LID) {
acpi_lid_update_state(device); mutex_lock(&button->input->mutex);
users = button->input->users;
mutex_unlock(&button->input->mutex);
if (users)
acpi_lid_update_state(device);
} else { } else {
int keycode; int keycode;
...@@ -442,12 +447,24 @@ static int acpi_button_resume(struct device *dev) ...@@ -442,12 +447,24 @@ static int acpi_button_resume(struct device *dev)
struct acpi_button *button = acpi_driver_data(device); struct acpi_button *button = acpi_driver_data(device);
button->suspended = false; button->suspended = false;
if (button->type == ACPI_BUTTON_TYPE_LID) if (button->type == ACPI_BUTTON_TYPE_LID && button->input->users)
acpi_lid_initialize_state(device); acpi_lid_initialize_state(device);
return 0; return 0;
} }
#endif #endif
static int acpi_lid_input_open(struct input_dev *input)
{
struct acpi_device *device = input_get_drvdata(input);
struct acpi_button *button = acpi_driver_data(device);
button->last_state = !!acpi_lid_evaluate_state(device);
button->last_time = ktime_get();
acpi_lid_initialize_state(device);
return 0;
}
static int acpi_button_add(struct acpi_device *device) static int acpi_button_add(struct acpi_device *device)
{ {
struct acpi_button *button; struct acpi_button *button;
...@@ -488,8 +505,7 @@ static int acpi_button_add(struct acpi_device *device) ...@@ -488,8 +505,7 @@ static int acpi_button_add(struct acpi_device *device)
strcpy(name, ACPI_BUTTON_DEVICE_NAME_LID); strcpy(name, ACPI_BUTTON_DEVICE_NAME_LID);
sprintf(class, "%s/%s", sprintf(class, "%s/%s",
ACPI_BUTTON_CLASS, ACPI_BUTTON_SUBCLASS_LID); ACPI_BUTTON_CLASS, ACPI_BUTTON_SUBCLASS_LID);
button->last_state = !!acpi_lid_evaluate_state(device); input->open = acpi_lid_input_open;
button->last_time = ktime_get();
} else { } else {
printk(KERN_ERR PREFIX "Unsupported hid [%s]\n", hid); printk(KERN_ERR PREFIX "Unsupported hid [%s]\n", hid);
error = -ENODEV; error = -ENODEV;
...@@ -522,11 +538,11 @@ static int acpi_button_add(struct acpi_device *device) ...@@ -522,11 +538,11 @@ static int acpi_button_add(struct acpi_device *device)
break; break;
} }
input_set_drvdata(input, device);
error = input_register_device(input); error = input_register_device(input);
if (error) if (error)
goto err_remove_fs; goto err_remove_fs;
if (button->type == ACPI_BUTTON_TYPE_LID) { if (button->type == ACPI_BUTTON_TYPE_LID) {
acpi_lid_initialize_state(device);
/* /*
* This assumes there's only one lid device, or if there are * This assumes there's only one lid device, or if there are
* more we only care about the last one... * more we only care about the last one...
......
This diff is collapsed.
...@@ -486,8 +486,11 @@ static inline void __acpi_ec_enable_event(struct acpi_ec *ec) ...@@ -486,8 +486,11 @@ static inline void __acpi_ec_enable_event(struct acpi_ec *ec)
{ {
if (!test_and_set_bit(EC_FLAGS_QUERY_ENABLED, &ec->flags)) if (!test_and_set_bit(EC_FLAGS_QUERY_ENABLED, &ec->flags))
ec_log_drv("event unblocked"); ec_log_drv("event unblocked");
if (!test_bit(EC_FLAGS_QUERY_PENDING, &ec->flags)) /*
advance_transaction(ec); * Unconditionally invoke this once after enabling the event
* handling mechanism to detect the pending events.
*/
advance_transaction(ec);
} }
static inline void __acpi_ec_disable_event(struct acpi_ec *ec) static inline void __acpi_ec_disable_event(struct acpi_ec *ec)
...@@ -1456,11 +1459,10 @@ static int ec_install_handlers(struct acpi_ec *ec, bool handle_events) ...@@ -1456,11 +1459,10 @@ static int ec_install_handlers(struct acpi_ec *ec, bool handle_events)
if (test_bit(EC_FLAGS_STARTED, &ec->flags) && if (test_bit(EC_FLAGS_STARTED, &ec->flags) &&
ec->reference_count >= 1) ec->reference_count >= 1)
acpi_ec_enable_gpe(ec, true); acpi_ec_enable_gpe(ec, true);
/* EC is fully operational, allow queries */
acpi_ec_enable_event(ec);
} }
} }
/* EC is fully operational, allow queries */
acpi_ec_enable_event(ec);
return 0; return 0;
} }
......
...@@ -169,7 +169,8 @@ module_param_cb(debug_level, &param_ops_debug_level, &acpi_dbg_level, 0644); ...@@ -169,7 +169,8 @@ module_param_cb(debug_level, &param_ops_debug_level, &acpi_dbg_level, 0644);
static char trace_method_name[1024]; static char trace_method_name[1024];
int param_set_trace_method_name(const char *val, const struct kernel_param *kp) static int param_set_trace_method_name(const char *val,
const struct kernel_param *kp)
{ {
u32 saved_flags = 0; u32 saved_flags = 0;
bool is_abs_path = true; bool is_abs_path = true;
......
...@@ -69,7 +69,6 @@ ...@@ -69,7 +69,6 @@
#include "mailbox.h" #include "mailbox.h"
#define MAX_PCC_SUBSPACES 256
#define MBOX_IRQ_NAME "pcc-mbox" #define MBOX_IRQ_NAME "pcc-mbox"
static struct mbox_chan *pcc_mbox_channels; static struct mbox_chan *pcc_mbox_channels;
......
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
#include <linux/mailbox_controller.h> #include <linux/mailbox_controller.h>
#include <linux/mailbox_client.h> #include <linux/mailbox_client.h>
#define MAX_PCC_SUBSPACES 256
#ifdef CONFIG_PCC #ifdef CONFIG_PCC
extern struct mbox_chan *pcc_mbox_request_channel(struct mbox_client *cl, extern struct mbox_chan *pcc_mbox_request_channel(struct mbox_client *cl,
int subspace_id); int subspace_id);
......
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