diff options
author | Robert Nagy <robert@cvs.openbsd.org> | 2008-10-01 19:13:58 +0000 |
---|---|---|
committer | Robert Nagy <robert@cvs.openbsd.org> | 2008-10-01 19:13:58 +0000 |
commit | 3fa02cfe9bdc284bf1fb6b30d994a5d4ff35bfe9 (patch) | |
tree | cec48c7b835db18a83e1c5736b441e6197b96314 | |
parent | a7514fd7c95c679cf59a49547851275f73160bbb (diff) |
The display cycle key generates two ACPI events, so catch both
from jsign@
Change the camel capitalized key defines to full capitals,
and add some keys found on the eeepc 1000H
ok marco@
-rw-r--r-- | sys/dev/acpi/acpiasus.c | 74 |
1 files changed, 46 insertions, 28 deletions
diff --git a/sys/dev/acpi/acpiasus.c b/sys/dev/acpi/acpiasus.c index 3745f4b8cc1..9ec6069a4cf 100644 --- a/sys/dev/acpi/acpiasus.c +++ b/sys/dev/acpi/acpiasus.c @@ -1,4 +1,4 @@ -/* $OpenBSD: acpiasus.c,v 1.6 2008/06/14 17:17:33 jsing Exp $ */ +/* $OpenBSD: acpiasus.c,v 1.7 2008/10/01 19:13:57 robert Exp $ */ /* $NetBSD: asus_acpi.c,v 1.2.2.2 2008/04/03 12:42:37 mjf Exp $ */ /* * Copyright (c) 2007, 2008 Jared D. McNeill <jmcneill@invisible.ca> @@ -59,18 +59,24 @@ struct acpiasus_softc { void *sc_powerhook; }; -#define ASUS_NOTIFY_WirelessSwitchOn 0x10 -#define ASUS_NOTIFY_WirelessSwitchOff 0x11 -#define ASUS_NOTIFY_BrightnessLow 0x20 -#define ASUS_NOTIFY_BrightnessHigh 0x2f -#define ASUS_NOTIFY_DisplayCycle 0x30 -#define ASUS_NOTIFY_TaskSwitch 0x12 -#define ASUS_NOTIFY_VolumeMute 0x13 -#define ASUS_NOTIFY_VolumeDown 0x14 -#define ASUS_NOTIFY_VolumeUp 0x15 - -#define ASUS_NOTIFY_PowerConnect 0x50 -#define ASUS_NOTIFY_PowerDisconnect 0x51 +#define ASUS_NOTIFY_WIRELESSON 0x10 +#define ASUS_NOTIFY_WIRELESSOFF 0x11 +#define ASUS_NOTIFY_TASKSWITCH 0x12 +#define ASUS_NOTIFY_VOLUMEMUTE 0x13 +#define ASUS_NOTIFY_VOLUMEDOWN 0x14 +#define ASUS_NOTIFY_VOLUMEUP 0x15 +#define ASUS_NOTIFY_LCDSWITCHOFF0 0x16 +#define ASUS_NOTIFY_LCDSWITCHOFF1 0x1a +#define ASUS_NOTIFY_LCDCHANGERES 0x1b +#define ASUS_NOTIFY_USERDEF0 0x1c +#define ASUS_NOTIFY_USERDEF1 0x1d +#define ASUS_NOTIFY_BRIGHTNESSLOW 0x20 +#define ASUS_NOTIFY_BRIGHTNESSHIGH 0x2f +#define ASUS_NOTIFY_DISPLAYCYCLEDOWN 0x30 +#define ASUS_NOTIFY_DISPLAYCYCLEUP 0x32 + +#define ASUS_NOTIFY_POWERCONNECT 0x50 +#define ASUS_NOTIFY_POWERDISCONNECT 0x51 #define ASUS_SDSP_LCD 0x01 #define ASUS_SDSP_CRT 0x02 @@ -152,9 +158,9 @@ acpiasus_notify(struct aml_node *node, int notify, void *arg) { struct acpiasus_softc *sc = arg; - if (notify >= ASUS_NOTIFY_BrightnessLow && - notify <= ASUS_NOTIFY_BrightnessHigh) { -#if ACPIASUS_DEBUG + if (notify >= ASUS_NOTIFY_BRIGHTNESSLOW && + notify <= ASUS_NOTIFY_BRIGHTNESSHIGH) { +#ifdef ACPIASUS_DEBUG printf("%s: brightness %d percent\n", DEVNAME(sc), (notify & 0xf) * 100 / 0xf); #endif @@ -162,34 +168,46 @@ acpiasus_notify(struct aml_node *node, int notify, void *arg) } switch (notify) { - case ASUS_NOTIFY_WirelessSwitchOn: /* Handled by AML. */ - case ASUS_NOTIFY_WirelessSwitchOff: /* Handled by AML. */ + case ASUS_NOTIFY_WIRELESSON: /* Handled by AML. */ + case ASUS_NOTIFY_WIRELESSOFF: /* Handled by AML. */ break; - case ASUS_NOTIFY_TaskSwitch: + case ASUS_NOTIFY_TASKSWITCH: break; - case ASUS_NOTIFY_DisplayCycle: + case ASUS_NOTIFY_DISPLAYCYCLEDOWN: + case ASUS_NOTIFY_DISPLAYCYCLEUP: break; #if NAUDIO > 0 && NWSKBD > 0 - case ASUS_NOTIFY_VolumeMute: + case ASUS_NOTIFY_VOLUMEMUTE: workq_add_task(NULL, 0, (workq_fn)wskbd_set_mixervolume, (void *)(long)0, NULL); break; - case ASUS_NOTIFY_VolumeDown: + case ASUS_NOTIFY_VOLUMEDOWN: workq_add_task(NULL, 0, (workq_fn)wskbd_set_mixervolume, (void *)(long)-1, NULL); break; - case ASUS_NOTIFY_VolumeUp: + case ASUS_NOTIFY_VOLUMEUP: workq_add_task(NULL, 0, (workq_fn)wskbd_set_mixervolume, (void *)(long)1, NULL); break; #else - case ASUS_NOTIFY_VolumeMute: - case ASUS_NOTIFY_VolumeDown: - case ASUS_NOTIFY_VolumeUp: + case ASUS_NOTIFY_VOLUMEMUTE: + case ASUS_NOTIFY_VOLUMEDOWN: + case ASUS_NOTIFY_VOLUMEUP: break; #endif - case ASUS_NOTIFY_PowerConnect: - case ASUS_NOTIFY_PowerDisconnect: + case ASUS_NOTIFY_POWERCONNECT: + case ASUS_NOTIFY_POWERDISCONNECT: + break; + + case ASUS_NOTIFY_LCDSWITCHOFF0: + case ASUS_NOTIFY_LCDSWITCHOFF1: + break; + + case ASUS_NOTIFY_LCDCHANGERES: + break; + + case ASUS_NOTIFY_USERDEF0: + case ASUS_NOTIFY_USERDEF1: break; default: |