Commit 57ede701 authored by Mattia Dongili's avatar Mattia Dongili Committed by Len Brown

sony_acpi: Allow multiple sony_acpi_values for the same .name

The acpi handles are kept _only_ if both the requested .acpiget and .acpiset
are available in the DSDT.
Currently only the SCDP/CDPW dualism is known.
Signed-off-by: default avatarMattia Dongili <malattia@linux.it>
Signed-off-by: default avatarLen Brown <len.brown@intel.com>
parent 4465857d
...@@ -68,7 +68,7 @@ static struct backlight_properties sony_backlight_properties = { ...@@ -68,7 +68,7 @@ static struct backlight_properties sony_backlight_properties = {
static struct sony_acpi_value { static struct sony_acpi_value {
char *name; /* name of the entry */ char *name; /* name of the entry */
struct proc_dir_entry *proc; /* /proc entry */ struct proc_dir_entry *proc; /* /proc entry */
char *acpiget;/* name of the ACPI get function */ char *acpiget;/* name of the ACPI get function */
char *acpiset;/* name of the ACPI get function */ char *acpiset;/* name of the ACPI get function */
int min; /* minimum allowed value or -1 */ int min; /* minimum allowed value or -1 */
...@@ -78,6 +78,7 @@ static struct sony_acpi_value { ...@@ -78,6 +78,7 @@ static struct sony_acpi_value {
int debug; /* active only in debug mode ? */ int debug; /* active only in debug mode ? */
} sony_acpi_values[] = { } sony_acpi_values[] = {
{ {
/* for backward compatibility only */
.name = "brightness", .name = "brightness",
.acpiget = "GBRT", .acpiget = "GBRT",
.acpiset = "SBRT", .acpiset = "SBRT",
...@@ -106,6 +107,14 @@ static struct sony_acpi_value { ...@@ -106,6 +107,14 @@ static struct sony_acpi_value {
.max = 1, .max = 1,
.debug = 0, .debug = 0,
}, },
{
.name = "cdpower",
.acpiget = "GCDP",
.acpiset = "CDPW",
.min = 0,
.max = 1,
.debug = 0,
},
{ {
.name = "audiopower", .name = "audiopower",
.acpiget = "GAZP", .acpiget = "GAZP",
...@@ -356,27 +365,24 @@ static int sony_acpi_add(struct acpi_device *device) ...@@ -356,27 +365,24 @@ static int sony_acpi_add(struct acpi_device *device)
if (!debug && item->debug) if (!debug && item->debug)
continue; continue;
if (item->acpiget && if (item->acpiget) {
ACPI_SUCCESS(acpi_get_handle(sony_acpi_handle, if (ACPI_FAILURE(acpi_get_handle(sony_acpi_handle,
item->acpiget, &handle))) item->acpiget, &handle)))
proc_file_mode = S_IRUSR; continue;
else
printk(LOG_PFX "unable to get ACPI handle for %s (get)\n",
item->name);
if (item->acpiset &&
ACPI_SUCCESS(acpi_get_handle(sony_acpi_handle,
item->acpiset, &handle)))
proc_file_mode |= S_IWUSR;
else
printk(LOG_PFX "unable to get ACPI handle for %s (set)\n",
item->name);
if (proc_file_mode == 0) proc_file_mode |= S_IRUSR;
continue; }
if (item->acpiset) {
if (ACPI_FAILURE(acpi_get_handle(sony_acpi_handle,
item->acpiset, &handle)))
continue;
proc_file_mode |= S_IWUSR;
}
item->proc = create_proc_entry(item->name, proc_file_mode, item->proc = create_proc_entry(item->name, proc_file_mode,
acpi_device_dir(device)); acpi_device_dir(device));
if (!item->proc) { if (!item->proc) {
printk(LOG_PFX "unable to create proc entry\n"); printk(LOG_PFX "unable to create proc entry\n");
result = -EIO; result = -EIO;
......
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