diff options
Diffstat (limited to 'drivers/misc/sony-laptop.c')
-rw-r--r-- | drivers/misc/sony-laptop.c | 30 |
1 files changed, 22 insertions, 8 deletions
diff --git a/drivers/misc/sony-laptop.c b/drivers/misc/sony-laptop.c index 85969c85cd89..303e48ca0e8a 100644 --- a/drivers/misc/sony-laptop.c +++ b/drivers/misc/sony-laptop.c | |||
@@ -1142,7 +1142,9 @@ static struct acpi_driver sony_nc_driver = { | |||
1142 | #define SONYPI_DEVICE_TYPE2 0x00000002 | 1142 | #define SONYPI_DEVICE_TYPE2 0x00000002 |
1143 | #define SONYPI_DEVICE_TYPE3 0x00000004 | 1143 | #define SONYPI_DEVICE_TYPE3 0x00000004 |
1144 | 1144 | ||
1145 | #define SONY_PIC_EV_MASK 0xff | 1145 | #define SONYPI_TYPE1_OFFSET 0x04 |
1146 | #define SONYPI_TYPE2_OFFSET 0x12 | ||
1147 | #define SONYPI_TYPE3_OFFSET 0x12 | ||
1146 | 1148 | ||
1147 | struct sony_pic_ioport { | 1149 | struct sony_pic_ioport { |
1148 | struct acpi_resource_io io; | 1150 | struct acpi_resource_io io; |
@@ -1156,6 +1158,7 @@ struct sony_pic_irq { | |||
1156 | 1158 | ||
1157 | struct sony_pic_dev { | 1159 | struct sony_pic_dev { |
1158 | int model; | 1160 | int model; |
1161 | u16 evport_offset; | ||
1159 | u8 camera_power; | 1162 | u8 camera_power; |
1160 | u8 bluetooth_power; | 1163 | u8 bluetooth_power; |
1161 | u8 wwan_power; | 1164 | u8 wwan_power; |
@@ -2233,20 +2236,17 @@ end: | |||
2233 | static irqreturn_t sony_pic_irq(int irq, void *dev_id) | 2236 | static irqreturn_t sony_pic_irq(int irq, void *dev_id) |
2234 | { | 2237 | { |
2235 | int i, j; | 2238 | int i, j; |
2236 | u32 port_val = 0; | ||
2237 | u8 ev = 0; | 2239 | u8 ev = 0; |
2238 | u8 data_mask = 0; | 2240 | u8 data_mask = 0; |
2239 | u8 device_event = 0; | 2241 | u8 device_event = 0; |
2240 | 2242 | ||
2241 | struct sony_pic_dev *dev = (struct sony_pic_dev *) dev_id; | 2243 | struct sony_pic_dev *dev = (struct sony_pic_dev *) dev_id; |
2242 | 2244 | ||
2243 | acpi_os_read_port(dev->cur_ioport->io.minimum, &port_val, | 2245 | ev = inb_p(dev->cur_ioport->io.minimum); |
2244 | dev->cur_ioport->io.address_length); | 2246 | data_mask = inb_p(dev->cur_ioport->io.minimum + dev->evport_offset); |
2245 | ev = port_val & SONY_PIC_EV_MASK; | ||
2246 | data_mask = 0xff & (port_val >> (dev->cur_ioport->io.address_length - 8)); | ||
2247 | 2247 | ||
2248 | dprintk("event (0x%.8x [%.2x] [%.2x]) at port 0x%.4x\n", | 2248 | dprintk("event ([%.2x] [%.2x]) at port 0x%.4x(+0x%.2x)\n", |
2249 | port_val, ev, data_mask, dev->cur_ioport->io.minimum); | 2249 | ev, data_mask, dev->cur_ioport->io.minimum, dev->evport_offset); |
2250 | 2250 | ||
2251 | if (ev == 0x00 || ev == 0xff) | 2251 | if (ev == 0x00 || ev == 0xff) |
2252 | return IRQ_HANDLED; | 2252 | return IRQ_HANDLED; |
@@ -2337,6 +2337,20 @@ static int sony_pic_add(struct acpi_device *device) | |||
2337 | spic_dev.model = sony_pic_detect_device_type(); | 2337 | spic_dev.model = sony_pic_detect_device_type(); |
2338 | mutex_init(&spic_dev.lock); | 2338 | mutex_init(&spic_dev.lock); |
2339 | 2339 | ||
2340 | /* model specific characteristics */ | ||
2341 | switch(spic_dev.model) { | ||
2342 | case SONYPI_DEVICE_TYPE1: | ||
2343 | spic_dev.evport_offset = SONYPI_TYPE1_OFFSET; | ||
2344 | break; | ||
2345 | case SONYPI_DEVICE_TYPE3: | ||
2346 | spic_dev.evport_offset = SONYPI_TYPE3_OFFSET; | ||
2347 | break; | ||
2348 | case SONYPI_DEVICE_TYPE2: | ||
2349 | default: | ||
2350 | spic_dev.evport_offset = SONYPI_TYPE2_OFFSET; | ||
2351 | break; | ||
2352 | } | ||
2353 | |||
2340 | /* read _PRS resources */ | 2354 | /* read _PRS resources */ |
2341 | result = sony_pic_possible_resources(device); | 2355 | result = sony_pic_possible_resources(device); |
2342 | if (result) { | 2356 | if (result) { |