6
#include "xf86_OSproc.h"
9
#include <sys/socket.h>
15
#define ACPI_SOCKET "/var/run/acpid.socket"
16
#define ACPI_EVENTS "/proc/acpi/event"
18
#define ACPI_VIDEO_NOTIFY_SWITCH 0x80
19
#define ACPI_VIDEO_NOTIFY_PROBE 0x81
20
#define ACPI_VIDEO_NOTIFY_CYCLE 0x82
21
#define ACPI_VIDEO_NOTIFY_NEXT_OUTPUT 0x83
22
#define ACPI_VIDEO_NOTIFY_PREV_OUTPUT 0x84
24
#define ACPI_VIDEO_NOTIFY_CYCLE_BRIGHTNESS 0x82
25
#define ACPI_VIDEO_NOTIFY_INC_BRIGHTNESS 0x83
26
#define ACPI_VIDEO_NOTIFY_DEC_BRIGHTNESS 0x84
27
#define ACPI_VIDEO_NOTIFY_ZERO_BRIGHTNESS 0x85
28
#define ACPI_VIDEO_NOTIFY_DISPLAY_OFF 0x86
30
#define ACPI_VIDEO_HEAD_INVALID (~0u - 1)
31
#define ACPI_VIDEO_HEAD_END (~0u)
33
static void lnxCloseACPI(void);
34
static pointer ACPIihPtr = NULL;
35
PMClose lnxACPIOpen(void);
37
#define LINE_LENGTH 80
40
lnxACPIGetEventFromOs(int fd, pmEvent *events, int num)
45
memset(ev, 0, LINE_LENGTH);
47
n = read( fd, ev, LINE_LENGTH );
49
/* Check that we have a video event */
50
if (strstr(ev, "video") == ev) {
54
char *data = NULL; /* doesn't appear to be used in the kernel */
55
unsigned long int notify_l, data_l;
57
video = strtok(ev, "video");
59
GFX = strtok(NULL, " ");
61
ErrorF("GFX: %s\n",GFX);
64
notify = strtok(NULL, " ");
65
notify_l = strtoul(notify, NULL, 16);
67
ErrorF("notify: 0x%lx\n",notify_l);
70
data = strtok(NULL, " ");
71
data_l = strtoul(data, NULL, 16);
73
ErrorF("data: 0x%lx\n",data_l);
76
/* We currently don't differentiate between any event */
78
case ACPI_VIDEO_NOTIFY_SWITCH:
80
case ACPI_VIDEO_NOTIFY_PROBE:
82
case ACPI_VIDEO_NOTIFY_CYCLE:
84
case ACPI_VIDEO_NOTIFY_NEXT_OUTPUT:
86
case ACPI_VIDEO_NOTIFY_PREV_OUTPUT:
92
/* Deal with all ACPI events as a capability change */
93
events[0] = XF86_APM_CAPABILITY_CHANGED;
102
lnxACPIConfirmEventToOs(int fd, pmEvent event)
104
/* No ability to send back to the kernel in ACPI */
115
struct sockaddr_un addr;
119
ErrorF("ACPI: OSPMOpen called\n");
121
if (ACPIihPtr || !xf86Info.pmFlag)
125
ErrorF("ACPI: Opening device\n");
127
if ((fd = socket(AF_UNIX, SOCK_STREAM, 0)) > -1) {
128
memset(&addr, 0, sizeof(addr));
129
addr.sun_family = AF_UNIX;
130
strcpy(addr.sun_path, ACPI_SOCKET);
131
if ((r = connect(fd, (struct sockaddr*)&addr, sizeof(addr))) == -1) {
138
/* acpid's socket isn't available, so try going direct */
140
if ((fd = open(ACPI_EVENTS, O_RDONLY)) < 0) {
141
xf86MsgVerb(X_WARNING,3,"Open ACPI failed (%s) (%s)\n", ACPI_EVENTS,
147
xf86PMGetEventFromOs = lnxACPIGetEventFromOs;
148
xf86PMConfirmEventToOs = lnxACPIConfirmEventToOs;
149
ACPIihPtr = xf86AddInputHandler(fd,xf86HandlePMEvents,NULL);
150
xf86MsgVerb(X_INFO,3,"Open ACPI successful (%s)\n", (r != -1) ? ACPI_SOCKET : ACPI_EVENTS);
161
ErrorF("ACPI: Closing device\n");
164
fd = xf86RemoveInputHandler(ACPIihPtr);