diff options
| author | Dmitry Torokhov <[email protected]> | 2023-08-30 16:06:38 -0700 | 
|---|---|---|
| committer | Dmitry Torokhov <[email protected]> | 2023-08-30 16:06:38 -0700 | 
| commit | 1ac731c529cd4d6adbce134754b51ff7d822b145 (patch) | |
| tree | 143ab3f35ca5f3b69f583c84e6964b17139c2ec1 /drivers/acpi/ec.c | |
| parent | 07b4c950f27bef0362dc6ad7ee713aab61d58149 (diff) | |
| parent | 54116d442e001e1b6bd482122043b1870998a1f3 (diff) | |
Merge branch 'next' into for-linus
Prepare input updates for 6.6 merge window.
Diffstat (limited to 'drivers/acpi/ec.c')
| -rw-r--r-- | drivers/acpi/ec.c | 18 | 
1 files changed, 15 insertions, 3 deletions
diff --git a/drivers/acpi/ec.c b/drivers/acpi/ec.c index 105d2e795afa..928899ab9502 100644 --- a/drivers/acpi/ec.c +++ b/drivers/acpi/ec.c @@ -1083,9 +1083,12 @@ int acpi_ec_add_query_handler(struct acpi_ec *ec, u8 query_bit,  			      acpi_handle handle, acpi_ec_query_func func,  			      void *data)  { -	struct acpi_ec_query_handler *handler = -	    kzalloc(sizeof(struct acpi_ec_query_handler), GFP_KERNEL); +	struct acpi_ec_query_handler *handler; + +	if (!handle && !func) +		return -EINVAL; +	handler = kzalloc(sizeof(*handler), GFP_KERNEL);  	if (!handler)  		return -ENOMEM; @@ -1097,6 +1100,7 @@ int acpi_ec_add_query_handler(struct acpi_ec *ec, u8 query_bit,  	kref_init(&handler->kref);  	list_add(&handler->node, &ec->list);  	mutex_unlock(&ec->mutex); +  	return 0;  }  EXPORT_SYMBOL_GPL(acpi_ec_add_query_handler); @@ -1109,9 +1113,16 @@ static void acpi_ec_remove_query_handlers(struct acpi_ec *ec,  	mutex_lock(&ec->mutex);  	list_for_each_entry_safe(handler, tmp, &ec->list, node) { -		if (remove_all || query_bit == handler->query_bit) { +		/* +		 * When remove_all is false, only remove custom query handlers +		 * which have handler->func set. This is done to preserve query +		 * handlers discovered thru ACPI, as they should continue handling +		 * EC queries. +		 */ +		if (remove_all || (handler->func && handler->query_bit == query_bit)) {  			list_del_init(&handler->node);  			list_add(&handler->node, &free_list); +  		}  	}  	mutex_unlock(&ec->mutex); @@ -1122,6 +1133,7 @@ static void acpi_ec_remove_query_handlers(struct acpi_ec *ec,  void acpi_ec_remove_query_handler(struct acpi_ec *ec, u8 query_bit)  {  	acpi_ec_remove_query_handlers(ec, false, query_bit); +	flush_workqueue(ec_query_wq);  }  EXPORT_SYMBOL_GPL(acpi_ec_remove_query_handler);  |