Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 44976
b: refs/heads/master
c: fb87a81
h: refs/heads/master
v: v3
  • Loading branch information
Henrique de Moraes Holschuh authored and Len Brown committed Dec 7, 2006
1 parent 0893a14 commit a356fe5
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 20 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 2df910b4c3edcce9a0c12394db6f5f4a6e69c712
refs/heads/master: fb87a811a4c232e2af8d746dc75330cbe5b0780c
50 changes: 31 additions & 19 deletions trunk/drivers/acpi/ibm_acpi.c
Original file line number Diff line number Diff line change
Expand Up @@ -397,7 +397,7 @@ struct ibm_struct {

static struct proc_dir_entry *proc_dir = NULL;

static struct backlight_device *ibm_backlight_device;
static struct backlight_device *ibm_backlight_device = NULL;

#define onoff(status,bit) ((status) & (1 << (bit)) ? "on" : "off")
#define enabled(status,bit) ((status) & (1 << (bit)) ? "enabled" : "disabled")
Expand Down Expand Up @@ -1639,6 +1639,7 @@ static int brightness_get(struct backlight_device *bd)
return -EIO;

level &= 0x7;

return level;
}

Expand Down Expand Up @@ -1713,6 +1714,33 @@ static int brightness_update_status(struct backlight_device *bd)
return brightness_set(bd->props->brightness);
}

static struct backlight_properties ibm_backlight_data = {
.owner = THIS_MODULE,
.get_brightness = brightness_get,
.update_status = brightness_update_status,
.max_brightness = 7,
};

static int brightness_init(void)
{
ibm_backlight_device = backlight_device_register("ibm", NULL,
&ibm_backlight_data);
if (IS_ERR(ibm_backlight_device)) {
printk(IBM_ERR "Could not register backlight device\n");
return PTR_ERR(ibm_backlight_device);
}

return 0;
}

static void brightness_exit(void)
{
if (ibm_backlight_device) {
backlight_device_unregister(ibm_backlight_device);
ibm_backlight_device = NULL;
}
}

static int volume_offset = 0x30;

static int volume_read(char *p)
Expand Down Expand Up @@ -2377,6 +2405,8 @@ static struct ibm_struct ibms[] = {
.name = "brightness",
.read = brightness_read,
.write = brightness_write,
.init = brightness_init,
.exit = brightness_exit,
},
{
.name = "volume",
Expand Down Expand Up @@ -2642,20 +2672,10 @@ IBM_PARAM(brightness);
IBM_PARAM(volume);
IBM_PARAM(fan);

static struct backlight_properties ibm_backlight_data = {
.owner = THIS_MODULE,
.get_brightness = brightness_get,
.update_status = brightness_update_status,
.max_brightness = 7,
};

static void acpi_ibm_exit(void)
{
int i;

if (ibm_backlight_device)
backlight_device_unregister(ibm_backlight_device);

for (i = ARRAY_SIZE(ibms) - 1; i >= 0; i--)
ibm_exit(&ibms[i]);

Expand Down Expand Up @@ -2758,14 +2778,6 @@ static int __init acpi_ibm_init(void)
}
}

ibm_backlight_device = backlight_device_register("ibm", NULL,
&ibm_backlight_data);
if (IS_ERR(ibm_backlight_device)) {
printk(IBM_ERR "Could not register ibm backlight device\n");
ibm_backlight_device = NULL;
acpi_ibm_exit();
}

return 0;
}

Expand Down

0 comments on commit a356fe5

Please sign in to comment.