Commit 7a4d842a authored by Vojtech Pavlik's avatar Vojtech Pavlik

input: Get rid of the kbd_pt_regs variable, and instead pass the

	value all the way from an interrupt handler to keyboard.c
	that can display it.
parent bb5cc62f
...@@ -740,9 +740,6 @@ void handler_irq(int irq, struct pt_regs *regs) ...@@ -740,9 +740,6 @@ void handler_irq(int irq, struct pt_regs *regs)
irq_enter(); irq_enter();
kstat_cpu(cpu).irqs[irq]++; kstat_cpu(cpu).irqs[irq]++;
if (irq == 9)
kbd_pt_regs = regs;
/* Sliiiick... */ /* Sliiiick... */
#ifndef CONFIG_SMP #ifndef CONFIG_SMP
bp = ((irq != 0) ? bp = ((irq != 0) ?
......
...@@ -406,7 +406,6 @@ static int handle_rawcode(unsigned int keyval) ...@@ -406,7 +406,6 @@ static int handle_rawcode(unsigned int keyval)
static void a5kkbd_rx(int irq, void *dev_id, struct pt_regs *regs) static void a5kkbd_rx(int irq, void *dev_id, struct pt_regs *regs)
{ {
kbd_pt_regs = regs;
if (handle_rawcode(ioc_readb(IOC_KARTRX))) if (handle_rawcode(ioc_readb(IOC_KARTRX)))
tasklet_schedule(&keyboard_tasklet); tasklet_schedule(&keyboard_tasklet);
} }
......
...@@ -376,8 +376,6 @@ static void ec3104_keyb_interrupt(int irq, void *data, struct pt_regs *regs) ...@@ -376,8 +376,6 @@ static void ec3104_keyb_interrupt(int irq, void *data, struct pt_regs *regs)
struct e5_struct *k = &ec3104_keyb; struct e5_struct *k = &ec3104_keyb;
u8 msr, lsr; u8 msr, lsr;
kbd_pt_regs = regs;
msr = ctrl_inb(EC3104_SER4_MSR); msr = ctrl_inb(EC3104_SER4_MSR);
if ((msr & MSR_CTS) && !(k->last_msr & MSR_CTS)) { if ((msr & MSR_CTS) && !(k->last_msr & MSR_CTS)) {
......
This diff is collapsed.
...@@ -64,6 +64,8 @@ static void amijoy_interrupt(int irq, void *dummy, struct pt_regs *fp) ...@@ -64,6 +64,8 @@ static void amijoy_interrupt(int irq, void *dummy, struct pt_regs *fp)
case 1: data = ~custom.joy1dat; button = (~ciaa.pra >> 7) & 1; break; case 1: data = ~custom.joy1dat; button = (~ciaa.pra >> 7) & 1; break;
} }
input_regs(amijoy_dev + i, fp);
input_report_key(amijoy_dev + i, BTN_TRIGGER, button); input_report_key(amijoy_dev + i, BTN_TRIGGER, button);
input_report_abs(amijoy_dev + i, ABS_X, ((data >> 1) & 1) - ((data >> 9) & 1)); input_report_abs(amijoy_dev + i, ABS_X, ((data >> 1) & 1) - ((data >> 9) & 1));
......
...@@ -151,7 +151,7 @@ static int mark_core_as_ready(struct iforce *iforce, unsigned short addr) ...@@ -151,7 +151,7 @@ static int mark_core_as_ready(struct iforce *iforce, unsigned short addr)
return -1; return -1;
} }
void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data) void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data, struct pt_regs *regs)
{ {
struct input_dev *dev = &iforce->dev; struct input_dev *dev = &iforce->dev;
int i; int i;
...@@ -181,6 +181,8 @@ void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data) ...@@ -181,6 +181,8 @@ void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data)
case 0x01: /* joystick position data */ case 0x01: /* joystick position data */
case 0x03: /* wheel position data */ case 0x03: /* wheel position data */
input_regs(dev, regs);
if (HI(cmd) == 1) { if (HI(cmd) == 1) {
input_report_abs(dev, ABS_X, (__s16) (((__s16)data[1] << 8) | data[0])); input_report_abs(dev, ABS_X, (__s16) (((__s16)data[1] << 8) | data[0]));
input_report_abs(dev, ABS_Y, (__s16) (((__s16)data[3] << 8) | data[2])); input_report_abs(dev, ABS_Y, (__s16) (((__s16)data[3] << 8) | data[2]));
...@@ -219,6 +221,7 @@ void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data) ...@@ -219,6 +221,7 @@ void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data)
break; break;
case 0x02: /* status report */ case 0x02: /* status report */
input_regs(dev, regs);
input_report_key(dev, BTN_DEAD, data[0] & 0x02); input_report_key(dev, BTN_DEAD, data[0] & 0x02);
input_sync(dev); input_sync(dev);
......
...@@ -78,7 +78,7 @@ static void iforce_serio_write_wakeup(struct serio *serio) ...@@ -78,7 +78,7 @@ static void iforce_serio_write_wakeup(struct serio *serio)
iforce_serial_xmit((struct iforce *)serio->private); iforce_serial_xmit((struct iforce *)serio->private);
} }
static void iforce_serio_irq(struct serio *serio, unsigned char data, unsigned int flags) static void iforce_serio_irq(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct iforce* iforce = serio->private; struct iforce* iforce = serio->private;
...@@ -115,7 +115,7 @@ static void iforce_serio_irq(struct serio *serio, unsigned char data, unsigned i ...@@ -115,7 +115,7 @@ static void iforce_serio_irq(struct serio *serio, unsigned char data, unsigned i
} }
if (iforce->idx == iforce->len) { if (iforce->idx == iforce->len) {
iforce_process_packet(iforce, (iforce->id << 8) | iforce->idx, iforce->data); iforce_process_packet(iforce, (iforce->id << 8) | iforce->idx, iforce->data, regs);
iforce->pkt = 0; iforce->pkt = 0;
iforce->id = 0; iforce->id = 0;
iforce->len = 0; iforce->len = 0;
......
...@@ -74,7 +74,7 @@ void iforce_usb_xmit(struct iforce *iforce) ...@@ -74,7 +74,7 @@ void iforce_usb_xmit(struct iforce *iforce)
spin_unlock_irqrestore(&iforce->xmit_lock, flags); spin_unlock_irqrestore(&iforce->xmit_lock, flags);
} }
static void iforce_usb_irq(struct urb *urb) static void iforce_usb_irq(struct urb *urb, struct pt_regs *regs)
{ {
struct iforce *iforce = urb->context; struct iforce *iforce = urb->context;
int status; int status;
...@@ -96,7 +96,7 @@ static void iforce_usb_irq(struct urb *urb) ...@@ -96,7 +96,7 @@ static void iforce_usb_irq(struct urb *urb)
} }
iforce_process_packet(iforce, iforce_process_packet(iforce,
(iforce->data[0] << 8) | (urb->actual_length - 1), iforce->data + 1); (iforce->data[0] << 8) | (urb->actual_length - 1), iforce->data + 1, regs);
exit: exit:
status = usb_submit_urb (urb, GFP_ATOMIC); status = usb_submit_urb (urb, GFP_ATOMIC);
...@@ -105,7 +105,7 @@ static void iforce_usb_irq(struct urb *urb) ...@@ -105,7 +105,7 @@ static void iforce_usb_irq(struct urb *urb)
__FUNCTION__, status); __FUNCTION__, status);
} }
static void iforce_usb_out(struct urb *urb) static void iforce_usb_out(struct urb *urb, struct pt_regs *regs)
{ {
struct iforce *iforce = urb->context; struct iforce *iforce = urb->context;
...@@ -120,7 +120,7 @@ static void iforce_usb_out(struct urb *urb) ...@@ -120,7 +120,7 @@ static void iforce_usb_out(struct urb *urb)
wake_up(&iforce->wait); wake_up(&iforce->wait);
} }
static void iforce_usb_ctrl(struct urb *urb) static void iforce_usb_ctrl(struct urb *urb, struct pt_regs *regs)
{ {
struct iforce *iforce = urb->context; struct iforce *iforce = urb->context;
if (urb->status) return; if (urb->status) return;
...@@ -133,11 +133,14 @@ static int iforce_usb_probe(struct usb_interface *intf, ...@@ -133,11 +133,14 @@ static int iforce_usb_probe(struct usb_interface *intf,
const struct usb_device_id *id) const struct usb_device_id *id)
{ {
struct usb_device *dev = interface_to_usbdev(intf); struct usb_device *dev = interface_to_usbdev(intf);
struct usb_host_interface *interface;
struct usb_endpoint_descriptor *epirq, *epout; struct usb_endpoint_descriptor *epirq, *epout;
struct iforce *iforce; struct iforce *iforce;
epirq = intf->altsetting[0].endpoint + 0; interface = &intf->altsetting[intf->act_altsetting];
epout = intf->altsetting[0].endpoint + 1;
epirq = &interface->endpoint[0].desc;
epout = &interface->endpoint[1].desc;
if (!(iforce = kmalloc(sizeof(struct iforce) + 32, GFP_KERNEL))) if (!(iforce = kmalloc(sizeof(struct iforce) + 32, GFP_KERNEL)))
goto fail; goto fail;
......
...@@ -176,7 +176,7 @@ void iforce_delete_device(struct iforce *iforce); ...@@ -176,7 +176,7 @@ void iforce_delete_device(struct iforce *iforce);
/* iforce-packets.c */ /* iforce-packets.c */
int iforce_control_playback(struct iforce*, u16 id, unsigned int); int iforce_control_playback(struct iforce*, u16 id, unsigned int);
void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data); void iforce_process_packet(struct iforce *iforce, u16 cmd, unsigned char *data, struct pt_regs *regs);
int iforce_send_packet(struct iforce *iforce, u16 cmd, unsigned char* data); int iforce_send_packet(struct iforce *iforce, u16 cmd, unsigned char* data);
void iforce_dump_packet(char *msg, u16 cmd, unsigned char *data) ; void iforce_dump_packet(char *msg, u16 cmd, unsigned char *data) ;
int iforce_get_id_packet(struct iforce *iforce, char *packet); int iforce_get_id_packet(struct iforce *iforce, char *packet);
......
...@@ -81,7 +81,7 @@ static int magellan_crunch_nibbles(unsigned char *data, int count) ...@@ -81,7 +81,7 @@ static int magellan_crunch_nibbles(unsigned char *data, int count)
return 0; return 0;
} }
static void magellan_process_packet(struct magellan* magellan) static void magellan_process_packet(struct magellan* magellan, struct pt_regs *regs)
{ {
struct input_dev *dev = &magellan->dev; struct input_dev *dev = &magellan->dev;
unsigned char *data = magellan->data; unsigned char *data = magellan->data;
...@@ -89,6 +89,8 @@ static void magellan_process_packet(struct magellan* magellan) ...@@ -89,6 +89,8 @@ static void magellan_process_packet(struct magellan* magellan)
if (!magellan->idx) return; if (!magellan->idx) return;
input_regs(dev, regs);
switch (magellan->data[0]) { switch (magellan->data[0]) {
case 'd': /* Axis data */ case 'd': /* Axis data */
...@@ -111,12 +113,12 @@ static void magellan_process_packet(struct magellan* magellan) ...@@ -111,12 +113,12 @@ static void magellan_process_packet(struct magellan* magellan)
input_sync(dev); input_sync(dev);
} }
static void magellan_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void magellan_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct magellan* magellan = serio->private; struct magellan* magellan = serio->private;
if (data == '\r') { if (data == '\r') {
magellan_process_packet(magellan); magellan_process_packet(magellan, regs);
magellan->idx = 0; magellan->idx = 0;
} else { } else {
if (magellan->idx < MAGELLAN_MAX_LENGTH) if (magellan->idx < MAGELLAN_MAX_LENGTH)
......
...@@ -81,7 +81,7 @@ struct spaceball { ...@@ -81,7 +81,7 @@ struct spaceball {
* SpaceBall. * SpaceBall.
*/ */
static void spaceball_process_packet(struct spaceball* spaceball) static void spaceball_process_packet(struct spaceball* spaceball, struct pt_regs *regs)
{ {
struct input_dev *dev = &spaceball->dev; struct input_dev *dev = &spaceball->dev;
unsigned char *data = spaceball->data; unsigned char *data = spaceball->data;
...@@ -89,6 +89,8 @@ static void spaceball_process_packet(struct spaceball* spaceball) ...@@ -89,6 +89,8 @@ static void spaceball_process_packet(struct spaceball* spaceball)
if (spaceball->idx < 2) return; if (spaceball->idx < 2) return;
input_regs(dev, regs);
switch (spaceball->data[0]) { switch (spaceball->data[0]) {
case 'D': /* Ball data */ case 'D': /* Ball data */
...@@ -147,13 +149,13 @@ static void spaceball_process_packet(struct spaceball* spaceball) ...@@ -147,13 +149,13 @@ static void spaceball_process_packet(struct spaceball* spaceball)
* can occur in the axis values. * can occur in the axis values.
*/ */
static void spaceball_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void spaceball_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct spaceball *spaceball = serio->private; struct spaceball *spaceball = serio->private;
switch (data) { switch (data) {
case 0xd: case 0xd:
spaceball_process_packet(spaceball); spaceball_process_packet(spaceball, regs);
spaceball->idx = 0; spaceball->idx = 0;
spaceball->escape = 0; spaceball->escape = 0;
return; return;
......
...@@ -74,7 +74,7 @@ static unsigned char *spaceorb_errors[] = { "EEPROM storing 0 failed", "Receive ...@@ -74,7 +74,7 @@ static unsigned char *spaceorb_errors[] = { "EEPROM storing 0 failed", "Receive
* SpaceOrb. * SpaceOrb.
*/ */
static void spaceorb_process_packet(struct spaceorb *spaceorb) static void spaceorb_process_packet(struct spaceorb *spaceorb, struct pt_regs *regs)
{ {
struct input_dev *dev = &spaceorb->dev; struct input_dev *dev = &spaceorb->dev;
unsigned char *data = spaceorb->data; unsigned char *data = spaceorb->data;
...@@ -86,6 +86,8 @@ static void spaceorb_process_packet(struct spaceorb *spaceorb) ...@@ -86,6 +86,8 @@ static void spaceorb_process_packet(struct spaceorb *spaceorb)
for (i = 0; i < spaceorb->idx; i++) c ^= data[i]; for (i = 0; i < spaceorb->idx; i++) c ^= data[i];
if (c) return; if (c) return;
input_regs(dev, regs);
switch (data[0]) { switch (data[0]) {
case 'R': /* Reset packet */ case 'R': /* Reset packet */
...@@ -128,12 +130,12 @@ static void spaceorb_process_packet(struct spaceorb *spaceorb) ...@@ -128,12 +130,12 @@ static void spaceorb_process_packet(struct spaceorb *spaceorb)
input_sync(dev); input_sync(dev);
} }
static void spaceorb_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void spaceorb_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct spaceorb* spaceorb = serio->private; struct spaceorb* spaceorb = serio->private;
if (~data & 0x80) { if (~data & 0x80) {
if (spaceorb->idx) spaceorb_process_packet(spaceorb); if (spaceorb->idx) spaceorb_process_packet(spaceorb, regs);
spaceorb->idx = 0; spaceorb->idx = 0;
} }
if (spaceorb->idx < SPACEORB_MAX_LENGTH) if (spaceorb->idx < SPACEORB_MAX_LENGTH)
......
...@@ -64,13 +64,15 @@ struct stinger { ...@@ -64,13 +64,15 @@ struct stinger {
* Stinger. It updates the data accordingly. * Stinger. It updates the data accordingly.
*/ */
static void stinger_process_packet(struct stinger *stinger) static void stinger_process_packet(struct stinger *stinger, struct pt_regs *regs)
{ {
struct input_dev *dev = &stinger->dev; struct input_dev *dev = &stinger->dev;
unsigned char *data = stinger->data; unsigned char *data = stinger->data;
if (!stinger->idx) return; if (!stinger->idx) return;
input_regs(dev, regs);
input_report_key(dev, BTN_A, ((data[0] & 0x20) >> 5)); input_report_key(dev, BTN_A, ((data[0] & 0x20) >> 5));
input_report_key(dev, BTN_B, ((data[0] & 0x10) >> 4)); input_report_key(dev, BTN_B, ((data[0] & 0x10) >> 4));
input_report_key(dev, BTN_C, ((data[0] & 0x08) >> 3)); input_report_key(dev, BTN_C, ((data[0] & 0x08) >> 3));
...@@ -96,7 +98,7 @@ static void stinger_process_packet(struct stinger *stinger) ...@@ -96,7 +98,7 @@ static void stinger_process_packet(struct stinger *stinger)
* packet processing routine. * packet processing routine.
*/ */
static void stinger_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void stinger_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct stinger* stinger = serio->private; struct stinger* stinger = serio->private;
...@@ -106,7 +108,7 @@ static void stinger_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -106,7 +108,7 @@ static void stinger_interrupt(struct serio *serio, unsigned char data, unsigned
stinger->data[stinger->idx++] = data; stinger->data[stinger->idx++] = data;
if (stinger->idx == 4) { if (stinger->idx == 4) {
stinger_process_packet(stinger); stinger_process_packet(stinger, regs);
stinger->idx = 0; stinger->idx = 0;
} }
......
...@@ -101,7 +101,7 @@ struct twidjoy { ...@@ -101,7 +101,7 @@ struct twidjoy {
* Twiddler. It updates the data accordingly. * Twiddler. It updates the data accordingly.
*/ */
static void twidjoy_process_packet(struct twidjoy *twidjoy) static void twidjoy_process_packet(struct twidjoy *twidjoy, struct pt_regs *regs)
{ {
if (twidjoy->idx == TWIDJOY_MAX_LENGTH) { if (twidjoy->idx == TWIDJOY_MAX_LENGTH) {
struct input_dev *dev = &twidjoy->dev; struct input_dev *dev = &twidjoy->dev;
...@@ -111,6 +111,8 @@ static void twidjoy_process_packet(struct twidjoy *twidjoy) ...@@ -111,6 +111,8 @@ static void twidjoy_process_packet(struct twidjoy *twidjoy)
button_bits = ((data[1] & 0x7f) << 7) | (data[0] & 0x7f); button_bits = ((data[1] & 0x7f) << 7) | (data[0] & 0x7f);
input_regs(dev, regs);
for (bp = twidjoy_buttons; bp->bitmask; bp++) { for (bp = twidjoy_buttons; bp->bitmask; bp++) {
int value = (button_bits & (bp->bitmask << bp->bitshift)) >> bp->bitshift; int value = (button_bits & (bp->bitmask << bp->bitshift)) >> bp->bitshift;
int i; int i;
...@@ -140,7 +142,7 @@ static void twidjoy_process_packet(struct twidjoy *twidjoy) ...@@ -140,7 +142,7 @@ static void twidjoy_process_packet(struct twidjoy *twidjoy)
* packet processing routine. * packet processing routine.
*/ */
static void twidjoy_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void twidjoy_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struc pt_regs *regs)
{ {
struct twidjoy *twidjoy = serio->private; struct twidjoy *twidjoy = serio->private;
...@@ -157,7 +159,7 @@ static void twidjoy_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -157,7 +159,7 @@ static void twidjoy_interrupt(struct serio *serio, unsigned char data, unsigned
twidjoy->data[twidjoy->idx++] = data; twidjoy->data[twidjoy->idx++] = data;
if (twidjoy->idx == TWIDJOY_MAX_LENGTH) { if (twidjoy->idx == TWIDJOY_MAX_LENGTH) {
twidjoy_process_packet(twidjoy); twidjoy_process_packet(twidjoy, regs);
twidjoy->idx = 0; twidjoy->idx = 0;
} }
......
...@@ -63,13 +63,15 @@ struct warrior { ...@@ -63,13 +63,15 @@ struct warrior {
* Warrior. It updates the data accordingly. * Warrior. It updates the data accordingly.
*/ */
static void warrior_process_packet(struct warrior *warrior) static void warrior_process_packet(struct warrior *warrior, struct pt_regs *regs)
{ {
struct input_dev *dev = &warrior->dev; struct input_dev *dev = &warrior->dev;
unsigned char *data = warrior->data; unsigned char *data = warrior->data;
if (!warrior->idx) return; if (!warrior->idx) return;
input_regs(dev, regs);
switch ((data[0] >> 4) & 7) { switch ((data[0] >> 4) & 7) {
case 1: /* Button data */ case 1: /* Button data */
input_report_key(dev, BTN_TRIGGER, data[3] & 1); input_report_key(dev, BTN_TRIGGER, data[3] & 1);
...@@ -97,12 +99,12 @@ static void warrior_process_packet(struct warrior *warrior) ...@@ -97,12 +99,12 @@ static void warrior_process_packet(struct warrior *warrior)
* packet processing routine. * packet processing routine.
*/ */
static void warrior_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void warrior_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct warrior* warrior = serio->private; struct warrior* warrior = serio->private;
if (data & 0x80) { if (data & 0x80) {
if (warrior->idx) warrior_process_packet(warrior); if (warrior->idx) warrior_process_packet(warrior, regs);
warrior->idx = 0; warrior->idx = 0;
warrior->len = warrior_lengths[(data >> 4) & 7]; warrior->len = warrior_lengths[(data >> 4) & 7];
} }
...@@ -111,7 +113,7 @@ static void warrior_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -111,7 +113,7 @@ static void warrior_interrupt(struct serio *serio, unsigned char data, unsigned
warrior->data[warrior->idx++] = data; warrior->data[warrior->idx++] = data;
if (warrior->idx == warrior->len) { if (warrior->idx == warrior->len) {
if (warrior->idx) warrior_process_packet(warrior); if (warrior->idx) warrior_process_packet(warrior, regs);
warrior->idx = 0; warrior->idx = 0;
warrior->len = 0; warrior->len = 0;
} }
......
...@@ -87,6 +87,8 @@ static void amikbd_interrupt(int irq, void *dummy, struct pt_regs *fp) ...@@ -87,6 +87,8 @@ static void amikbd_interrupt(int irq, void *dummy, struct pt_regs *fp)
scancode = amikbd_keycode[scancode]; scancode = amikbd_keycode[scancode];
input_regs(&amikbd_dev, fp);
if (scancode == KEY_CAPSLOCK) { /* CapsLock is a toggle switch key on Amiga */ if (scancode == KEY_CAPSLOCK) { /* CapsLock is a toggle switch key on Amiga */
input_report_key(&amikbd_dev, scancode, 1); input_report_key(&amikbd_dev, scancode, 1);
input_report_key(&amikbd_dev, scancode, 0); input_report_key(&amikbd_dev, scancode, 0);
......
...@@ -132,7 +132,7 @@ struct atkbd { ...@@ -132,7 +132,7 @@ struct atkbd {
* the keyboard into events. * the keyboard into events.
*/ */
static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct atkbd *atkbd = serio->private; struct atkbd *atkbd = serio->private;
int code = data; int code = data;
...@@ -193,6 +193,7 @@ static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned in ...@@ -193,6 +193,7 @@ static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned in
atkbd->set, code, serio->phys, atkbd->release ? "released" : "pressed"); atkbd->set, code, serio->phys, atkbd->release ? "released" : "pressed");
break; break;
default: default:
input_regs(&atkbd->dev, regs);
input_report_key(&atkbd->dev, atkbd->keycode[code], !atkbd->release); input_report_key(&atkbd->dev, atkbd->keycode[code], !atkbd->release);
input_sync(&atkbd->dev); input_sync(&atkbd->dev);
} }
......
...@@ -62,18 +62,20 @@ struct nkbd { ...@@ -62,18 +62,20 @@ struct nkbd {
char phys[32]; char phys[32];
}; };
void nkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags) void nkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct nkbd *nkbd = serio->private; struct nkbd *nkbd = serio->private;
/* invalid scan codes are probably the init sequence, so we ignore them */ /* invalid scan codes are probably the init sequence, so we ignore them */
if (nkbd->keycode[data & NKBD_KEY]) if (nkbd->keycode[data & NKBD_KEY]) {
input_regs(&nkbd->dev, regs);
input_report_key(&nkbd->dev, nkbd->keycode[data & NKBD_KEY], data & NKBD_PRESS); input_report_key(&nkbd->dev, nkbd->keycode[data & NKBD_KEY], data & NKBD_PRESS);
input_sync(&nkbd->dev);
}
else if (data == 0xe7) /* end of init sequence */ else if (data == 0xe7) /* end of init sequence */
printk(KERN_INFO "input: %s on %s\n", nkbd_name, serio->phys); printk(KERN_INFO "input: %s on %s\n", nkbd_name, serio->phys);
input_sync(&nkbd->dev);
} }
void nkbd_connect(struct serio *serio, struct serio_dev *dev) void nkbd_connect(struct serio *serio, struct serio_dev *dev)
......
...@@ -89,7 +89,7 @@ struct sunkbd { ...@@ -89,7 +89,7 @@ struct sunkbd {
* is received. * is received.
*/ */
static void sunkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void sunkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct sunkbd* sunkbd = serio->private; struct sunkbd* sunkbd = serio->private;
...@@ -119,6 +119,7 @@ static void sunkbd_interrupt(struct serio *serio, unsigned char data, unsigned i ...@@ -119,6 +119,7 @@ static void sunkbd_interrupt(struct serio *serio, unsigned char data, unsigned i
default: default:
if (sunkbd->keycode[data & SUNKBD_KEY]) { if (sunkbd->keycode[data & SUNKBD_KEY]) {
input_regs(&sunkbd->dev, regs);
input_report_key(&sunkbd->dev, sunkbd->keycode[data & SUNKBD_KEY], !(data & SUNKBD_RELEASE)); input_report_key(&sunkbd->dev, sunkbd->keycode[data & SUNKBD_KEY], !(data & SUNKBD_RELEASE));
input_sync(&sunkbd->dev); input_sync(&sunkbd->dev);
} else { } else {
......
...@@ -63,7 +63,7 @@ struct xtkbd { ...@@ -63,7 +63,7 @@ struct xtkbd {
char phys[32]; char phys[32];
}; };
void xtkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags) void xtkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct xtkbd *xtkbd = serio->private; struct xtkbd *xtkbd = serio->private;
...@@ -74,6 +74,7 @@ void xtkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags ...@@ -74,6 +74,7 @@ void xtkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags
default: default:
if (xtkbd->keycode[data & XTKBD_KEY]) { if (xtkbd->keycode[data & XTKBD_KEY]) {
input_regs(&xtkbd->dev, regs);
input_report_key(&xtkbd->dev, xtkbd->keycode[data & XTKBD_KEY], !(data & XTKBD_RELEASE)); input_report_key(&xtkbd->dev, xtkbd->keycode[data & XTKBD_KEY], !(data & XTKBD_RELEASE));
input_sync(&xtkbd->dev); input_sync(&xtkbd->dev);
} else { } else {
......
...@@ -305,7 +305,7 @@ static void __init gscps2_reset(char * addr) ...@@ -305,7 +305,7 @@ static void __init gscps2_reset(char * addr)
* Receives a keyboard scancode, analyses it and sends it to the input layer. * Receives a keyboard scancode, analyses it and sends it to the input layer.
*/ */
static void gscps2_kbd_docode(void) static void gscps2_kbd_docode(struct pt_regs *regs)
{ {
int scancode = gscps2_readb_input(hpkeyb.addr); int scancode = gscps2_readb_input(hpkeyb.addr);
DPRINTK("rel=%d scancode=%d, esc=%d ", hpkeyb.released, scancode, hpkeyb.escaped); DPRINTK("rel=%d scancode=%d, esc=%d ", hpkeyb.released, scancode, hpkeyb.escaped);
...@@ -341,6 +341,7 @@ static void gscps2_kbd_docode(void) ...@@ -341,6 +341,7 @@ static void gscps2_kbd_docode(void)
default: default:
hpkeyb.scancode = scancode; hpkeyb.scancode = scancode;
DPRINTK("sent=%d, rel=%d\n",hpkeyb.scancode, hpkeyb.released); DPRINTK("sent=%d, rel=%d\n",hpkeyb.scancode, hpkeyb.released);
input_regs(regs);
input_report_key(&hpkeyb.dev, hpkeyb_keycode[hpkeyb.scancode], !hpkeyb.released); input_report_key(&hpkeyb.dev, hpkeyb_keycode[hpkeyb.scancode], !hpkeyb.released);
input_sync(&hpkeyb.dev); input_sync(&hpkeyb.dev);
if (hpkeyb.escaped) if (hpkeyb.escaped)
...@@ -359,7 +360,7 @@ static void gscps2_kbd_docode(void) ...@@ -359,7 +360,7 @@ static void gscps2_kbd_docode(void)
* correct events to the input layer. * correct events to the input layer.
*/ */
static void gscps2_mouse_docode(void) static void gscps2_mouse_docode(struct pt_regs *regs)
{ {
int xrel, yrel; int xrel, yrel;
...@@ -368,7 +369,7 @@ static void gscps2_mouse_docode(void) ...@@ -368,7 +369,7 @@ static void gscps2_mouse_docode(void)
hpmouse.nbread--; hpmouse.nbread--;
/* stolen from psmouse.c */ /* stolen from psmouse.c */
if (hpmouse.nbread && time_after(jiffies, hpmouse.last + HZ/20)) { if (hpmouse.nbread && time_after(jiffies, hpmouse.last + HZ/2)) {
printk(KERN_DEBUG "%s:%d : Lost mouse synchronization, throwing %d bytes away.\n", __FILE__, __LINE__, printk(KERN_DEBUG "%s:%d : Lost mouse synchronization, throwing %d bytes away.\n", __FILE__, __LINE__,
hpmouse.nbread); hpmouse.nbread);
hpmouse.nbread = 0; hpmouse.nbread = 0;
...@@ -387,6 +388,8 @@ static void gscps2_mouse_docode(void) ...@@ -387,6 +388,8 @@ static void gscps2_mouse_docode(void)
if ((hpmouse.bytes[PACKET_CTRL] & (MOUSE_XOVFLOW | MOUSE_YOVFLOW))) if ((hpmouse.bytes[PACKET_CTRL] & (MOUSE_XOVFLOW | MOUSE_YOVFLOW)))
DPRINTK("Mouse: position overflow\n"); DPRINTK("Mouse: position overflow\n");
input_regs(regs);
input_report_key(&hpmouse.dev, BTN_LEFT, hpmouse.bytes[PACKET_CTRL] & MOUSE_LEFTBTN); input_report_key(&hpmouse.dev, BTN_LEFT, hpmouse.bytes[PACKET_CTRL] & MOUSE_LEFTBTN);
input_report_key(&hpmouse.dev, BTN_MIDDLE, hpmouse.bytes[PACKET_CTRL] & MOUSE_MIDBTN); input_report_key(&hpmouse.dev, BTN_MIDDLE, hpmouse.bytes[PACKET_CTRL] & MOUSE_MIDBTN);
input_report_key(&hpmouse.dev, BTN_RIGHT, hpmouse.bytes[PACKET_CTRL] & MOUSE_RIGHTBTN); input_report_key(&hpmouse.dev, BTN_RIGHT, hpmouse.bytes[PACKET_CTRL] & MOUSE_RIGHTBTN);
...@@ -421,11 +424,11 @@ static void gscps2_interrupt(int irq, void *dev, struct pt_regs *reg) ...@@ -421,11 +424,11 @@ static void gscps2_interrupt(int irq, void *dev, struct pt_regs *reg)
{ {
/* process mouse actions */ /* process mouse actions */
while (gscps2_readb_status(hpmouse.addr) & GSC_STAT_RBNE) while (gscps2_readb_status(hpmouse.addr) & GSC_STAT_RBNE)
gscps2_mouse_docode(); gscps2_mouse_docode(reg);
/* process keyboard scancode */ /* process keyboard scancode */
while (gscps2_readb_status(hpkeyb.addr) & GSC_STAT_RBNE) while (gscps2_readb_status(hpkeyb.addr) & GSC_STAT_RBNE)
gscps2_kbd_docode(); gscps2_kbd_docode(reg);
} }
......
...@@ -63,6 +63,8 @@ static void amimouse_interrupt(int irq, void *dummy, struct pt_regs *fp) ...@@ -63,6 +63,8 @@ static void amimouse_interrupt(int irq, void *dummy, struct pt_regs *fp)
potgor = custom.potgor; potgor = custom.potgor;
input_regs(&amimouse_dev, fp);
input_report_rel(&amimouse_dev, REL_X, dx); input_report_rel(&amimouse_dev, REL_X, dx);
input_report_rel(&amimouse_dev, REL_Y, dy); input_report_rel(&amimouse_dev, REL_Y, dy);
......
...@@ -131,6 +131,8 @@ static void inport_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -131,6 +131,8 @@ static void inport_interrupt(int irq, void *dev_id, struct pt_regs *regs)
outb(INPORT_REG_MODE, INPORT_CONTROL_PORT); outb(INPORT_REG_MODE, INPORT_CONTROL_PORT);
outb(INPORT_MODE_HOLD | INPORT_MODE_IRQ | INPORT_MODE_BASE, INPORT_DATA_PORT); outb(INPORT_MODE_HOLD | INPORT_MODE_IRQ | INPORT_MODE_BASE, INPORT_DATA_PORT);
input_regs(&inport_dev, regs);
outb(INPORT_REG_X, INPORT_CONTROL_PORT); outb(INPORT_REG_X, INPORT_CONTROL_PORT);
input_report_rel(&inport_dev, REL_X, inb(INPORT_DATA_PORT)); input_report_rel(&inport_dev, REL_X, inb(INPORT_DATA_PORT));
......
...@@ -130,6 +130,7 @@ static void logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -130,6 +130,7 @@ static void logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs)
dy |= (buttons & 0xf) << 4; dy |= (buttons & 0xf) << 4;
buttons = ~buttons >> 5; buttons = ~buttons >> 5;
input_regs(&logibm_dev, regs);
input_report_rel(&logibm_dev, REL_X, dx); input_report_rel(&logibm_dev, REL_X, dx);
input_report_rel(&logibm_dev, REL_Y, dy); input_report_rel(&logibm_dev, REL_Y, dy);
input_report_key(&logibm_dev, BTN_RIGHT, buttons & 1); input_report_key(&logibm_dev, BTN_RIGHT, buttons & 1);
......
...@@ -73,6 +73,7 @@ static void pc110pad_interrupt(int irq, void *ptr, struct pt_regs *regs) ...@@ -73,6 +73,7 @@ static void pc110pad_interrupt(int irq, void *ptr, struct pt_regs *regs)
if (pc110pad_count < 3) return; if (pc110pad_count < 3) return;
input_regs(&pc110pad_dev, regs);
input_report_key(&pc110pad_dev, BTN_TOUCH, input_report_key(&pc110pad_dev, BTN_TOUCH,
pc110pad_data[0] & 0x01); pc110pad_data[0] & 0x01);
input_report_abs(&pc110pad_dev, ABS_X, input_report_abs(&pc110pad_dev, ABS_X,
......
...@@ -73,11 +73,13 @@ static char *psmouse_protocols[] = { "None", "PS/2", "PS2++", "PS2T++", "GenPS/2 ...@@ -73,11 +73,13 @@ static char *psmouse_protocols[] = { "None", "PS/2", "PS2++", "PS2T++", "GenPS/2
* reports relevant events to the input module. * reports relevant events to the input module.
*/ */
static void psmouse_process_packet(struct psmouse *psmouse) static void psmouse_process_packet(struct psmouse *psmouse, struct pt_regs *regs)
{ {
struct input_dev *dev = &psmouse->dev; struct input_dev *dev = &psmouse->dev;
unsigned char *packet = psmouse->packet; unsigned char *packet = psmouse->packet;
input_regs(dev, regs);
/* /*
* The PS2++ protocol is a little bit complex * The PS2++ protocol is a little bit complex
*/ */
...@@ -165,7 +167,7 @@ static void psmouse_process_packet(struct psmouse *psmouse) ...@@ -165,7 +167,7 @@ static void psmouse_process_packet(struct psmouse *psmouse)
* packets or passing them to the command routine as command output. * packets or passing them to the command routine as command output.
*/ */
static void psmouse_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void psmouse_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct psmouse *psmouse = serio->private; struct psmouse *psmouse = serio->private;
...@@ -201,7 +203,7 @@ static void psmouse_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -201,7 +203,7 @@ static void psmouse_interrupt(struct serio *serio, unsigned char data, unsigned
psmouse->packet[psmouse->pktcnt++] = data; psmouse->packet[psmouse->pktcnt++] = data;
if (psmouse->pktcnt == 3 + (psmouse->type >= PSMOUSE_GENPS)) { if (psmouse->pktcnt == 3 + (psmouse->type >= PSMOUSE_GENPS)) {
psmouse_process_packet(psmouse); psmouse_process_packet(psmouse, regs);
psmouse->pktcnt = 0; psmouse->pktcnt = 0;
return; return;
} }
......
...@@ -64,6 +64,8 @@ static void rpcmouse_irq(int irq, void *dev_id, struct pt_regs *regs) ...@@ -64,6 +64,8 @@ static void rpcmouse_irq(int irq, void *dev_id, struct pt_regs *regs)
rpcmouse_lastx = x; rpcmouse_lastx = x;
rpcmouse_lasty = y; rpcmouse_lasty = y;
input_regs(dev, regs);
input_report_rel(dev, REL_X, dx); input_report_rel(dev, REL_X, dx);
input_report_rel(dev, REL_Y, -dy); input_report_rel(dev, REL_Y, -dy);
......
...@@ -60,11 +60,13 @@ struct sermouse { ...@@ -60,11 +60,13 @@ struct sermouse {
* second, which is as good as a PS/2 or USB mouse. * second, which is as good as a PS/2 or USB mouse.
*/ */
static void sermouse_process_msc(struct sermouse *sermouse, signed char data) static void sermouse_process_msc(struct sermouse *sermouse, signed char data, struct pt_regs *regs)
{ {
struct input_dev *dev = &sermouse->dev; struct input_dev *dev = &sermouse->dev;
signed char *buf = sermouse->buf; signed char *buf = sermouse->buf;
input_regs(dev, regs);
switch (sermouse->count) { switch (sermouse->count) {
case 0: case 0:
...@@ -101,13 +103,15 @@ static void sermouse_process_msc(struct sermouse *sermouse, signed char data) ...@@ -101,13 +103,15 @@ static void sermouse_process_msc(struct sermouse *sermouse, signed char data)
* standard 3-byte packets and 1200 bps. * standard 3-byte packets and 1200 bps.
*/ */
static void sermouse_process_ms(struct sermouse *sermouse, signed char data) static void sermouse_process_ms(struct sermouse *sermouse, signed char data, struct pt_regs *regs)
{ {
struct input_dev *dev = &sermouse->dev; struct input_dev *dev = &sermouse->dev;
signed char *buf = sermouse->buf; signed char *buf = sermouse->buf;
if (data & 0x40) sermouse->count = 0; if (data & 0x40) sermouse->count = 0;
input_regs(dev, regs);
switch (sermouse->count) { switch (sermouse->count) {
case 0: case 0:
...@@ -200,7 +204,7 @@ static void sermouse_process_ms(struct sermouse *sermouse, signed char data) ...@@ -200,7 +204,7 @@ static void sermouse_process_ms(struct sermouse *sermouse, signed char data)
* packets or passing them to the command routine as command output. * packets or passing them to the command routine as command output.
*/ */
static void sermouse_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void sermouse_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct sermouse *sermouse = serio->private; struct sermouse *sermouse = serio->private;
...@@ -208,9 +212,9 @@ static void sermouse_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -208,9 +212,9 @@ static void sermouse_interrupt(struct serio *serio, unsigned char data, unsigned
sermouse->last = jiffies; sermouse->last = jiffies;
if (sermouse->type > SERIO_SUN) if (sermouse->type > SERIO_SUN)
sermouse_process_ms(sermouse, data); sermouse_process_ms(sermouse, data, regs);
else else
sermouse_process_msc(sermouse, data); sermouse_process_msc(sermouse, data, regs);
} }
/* /*
......
...@@ -23,8 +23,6 @@ ...@@ -23,8 +23,6 @@
#include <asm/irq.h> #include <asm/irq.h>
#include <asm/hardware/amba_kmi.h> #include <asm/hardware/amba_kmi.h>
extern struct pt_regs *kbd_pt_regs;
#define KMI_BASE (kmi->base) #define KMI_BASE (kmi->base)
struct amba_kmi_port { struct amba_kmi_port {
...@@ -42,10 +40,8 @@ static void amba_kmi_int(int irq, void *dev_id, struct pt_regs *regs) ...@@ -42,10 +40,8 @@ static void amba_kmi_int(int irq, void *dev_id, struct pt_regs *regs)
struct amba_kmi_port *kmi = dev_id; struct amba_kmi_port *kmi = dev_id;
unsigned int status = __raw_readb(KMIIR); unsigned int status = __raw_readb(KMIIR);
kbd_pt_regs = regs;
while (status & KMIIR_RXINTR) { while (status & KMIIR_RXINTR) {
serio_interrupt(&kmi->io, __raw_readb(KMIDATA), 0); serio_interrupt(&kmi->io, __raw_readb(KMIDATA), 0, regs);
status = __raw_readb(KMIIR); status = __raw_readb(KMIIR);
} }
} }
......
...@@ -156,7 +156,7 @@ static struct serio ct82c710_port = ...@@ -156,7 +156,7 @@ static struct serio ct82c710_port =
static void ct82c710_interrupt(int cpl, void *dev_id, struct pt_regs * regs) static void ct82c710_interrupt(int cpl, void *dev_id, struct pt_regs * regs)
{ {
serio_interrupt(&ct82c710_port, inb(ct82c710_data), 0); serio_interrupt(&ct82c710_port, inb(ct82c710_data), 0, regs);
} }
/* /*
......
...@@ -62,8 +62,6 @@ static unsigned char i8042_last_e0; ...@@ -62,8 +62,6 @@ static unsigned char i8042_last_e0;
static unsigned char i8042_mux_open; static unsigned char i8042_mux_open;
struct timer_list i8042_timer; struct timer_list i8042_timer;
extern struct pt_regs *kbd_pt_regs;
static unsigned long i8042_unxlate_seen[256 / BITS_PER_LONG]; static unsigned long i8042_unxlate_seen[256 / BITS_PER_LONG];
static unsigned char i8042_unxlate_table[128] = { static unsigned char i8042_unxlate_table[128] = {
0,118, 22, 30, 38, 37, 46, 54, 61, 62, 70, 69, 78, 85,102, 13, 0,118, 22, 30, 38, 37, 46, 54, 61, 62, 70, 69, 78, 85,102, 13,
...@@ -345,10 +343,6 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -345,10 +343,6 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
} buffer[I8042_BUFFER_SIZE]; } buffer[I8042_BUFFER_SIZE];
int i, j = 0; int i, j = 0;
#ifdef CONFIG_VT
kbd_pt_regs = regs;
#endif
spin_lock_irqsave(&i8042_lock, flags); spin_lock_irqsave(&i8042_lock, flags);
while (j < I8042_BUFFER_SIZE && while (j < I8042_BUFFER_SIZE &&
...@@ -381,7 +375,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -381,7 +375,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
dfl & SERIO_PARITY ? ", bad parity" : "", dfl & SERIO_PARITY ? ", bad parity" : "",
dfl & SERIO_TIMEOUT ? ", timeout" : ""); dfl & SERIO_TIMEOUT ? ", timeout" : "");
serio_interrupt(i8042_mux_port + ((str >> 6) & 3), data, dfl); serio_interrupt(i8042_mux_port + ((str >> 6) & 3), data, dfl, regs);
continue; continue;
} }
...@@ -391,7 +385,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -391,7 +385,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
dfl & SERIO_TIMEOUT ? ", timeout" : ""); dfl & SERIO_TIMEOUT ? ", timeout" : "");
if (i8042_aux_values.exists && (str & I8042_STR_AUXDATA)) { if (i8042_aux_values.exists && (str & I8042_STR_AUXDATA)) {
serio_interrupt(&i8042_aux_port, data, dfl); serio_interrupt(&i8042_aux_port, data, dfl, regs);
continue; continue;
} }
...@@ -399,7 +393,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -399,7 +393,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
continue; continue;
if (i8042_direct) { if (i8042_direct) {
serio_interrupt(&i8042_kbd_port, data, dfl); serio_interrupt(&i8042_kbd_port, data, dfl, regs);
continue; continue;
} }
...@@ -408,7 +402,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -408,7 +402,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
if (index == 0xaa || index == 0xb6) if (index == 0xaa || index == 0xb6)
set_bit(index, i8042_unxlate_seen); set_bit(index, i8042_unxlate_seen);
if (test_and_clear_bit(index, i8042_unxlate_seen)) { if (test_and_clear_bit(index, i8042_unxlate_seen)) {
serio_interrupt(&i8042_kbd_port, 0xf0, dfl); serio_interrupt(&i8042_kbd_port, 0xf0, dfl, regs);
data = i8042_unxlate_table[data & 0x7f]; data = i8042_unxlate_table[data & 0x7f];
} }
} else { } else {
...@@ -418,7 +412,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -418,7 +412,7 @@ static void i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
i8042_last_e0 = (data == 0xe0); i8042_last_e0 = (data == 0xe0);
serio_interrupt(&i8042_kbd_port, data, dfl); serio_interrupt(&i8042_kbd_port, data, dfl, regs);
} }
} }
......
...@@ -136,7 +136,7 @@ static void parkbd_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -136,7 +136,7 @@ static void parkbd_interrupt(int irq, void *dev_id, struct pt_regs *regs)
parkbd_buffer |= (parkbd_readlines() >> 1) << parkbd_counter++; parkbd_buffer |= (parkbd_readlines() >> 1) << parkbd_counter++;
if (parkbd_counter == parkbd_mode + 10) if (parkbd_counter == parkbd_mode + 10)
serio_interrupt(&parkbd_port, (parkbd_buffer >> (2 - parkbd_mode)) & 0xff, 0); serio_interrupt(&parkbd_port, (parkbd_buffer >> (2 - parkbd_mode)) & 0xff, 0, regs);
} }
parkbd_last = jiffies; parkbd_last = jiffies;
......
...@@ -69,8 +69,7 @@ static struct serio q40kbd_port = ...@@ -69,8 +69,7 @@ static struct serio q40kbd_port =
static void q40kbd_interrupt(int irq, void *dev_id, struct pt_regs *regs) static void q40kbd_interrupt(int irq, void *dev_id, struct pt_regs *regs)
{ {
if (Q40_IRQ_KEYB_MASK & master_inb(INTERRUPT_REG)) if (Q40_IRQ_KEYB_MASK & master_inb(INTERRUPT_REG))
if (q40kbd_port.dev) serio_interrupt(&q40kbd_port, master_inb(KEYCODE_REG), 0, regs);
q40kbd_port.dev->interrupt(&q40kbd_port, master_inb(KEYCODE_REG), 0);
master_outb(-1, KEYBOARD_UNLOCK_REG); master_outb(-1, KEYBOARD_UNLOCK_REG);
} }
......
...@@ -44,8 +44,6 @@ MODULE_AUTHOR("Vojtech Pavlik, Russell King"); ...@@ -44,8 +44,6 @@ MODULE_AUTHOR("Vojtech Pavlik, Russell King");
MODULE_DESCRIPTION("Acorn RiscPC PS/2 keyboard controller driver"); MODULE_DESCRIPTION("Acorn RiscPC PS/2 keyboard controller driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
extern struct pt_regs *kbd_pt_regs;
static int rpckbd_write(struct serio *port, unsigned char val) static int rpckbd_write(struct serio *port, unsigned char val)
{ {
while (!(iomd_readb(IOMD_KCTRL) & (1 << 7))) while (!(iomd_readb(IOMD_KCTRL) & (1 << 7)))
...@@ -60,12 +58,11 @@ static void rpckbd_rx(int irq, void *dev_id, struct pt_regs *regs) ...@@ -60,12 +58,11 @@ static void rpckbd_rx(int irq, void *dev_id, struct pt_regs *regs)
{ {
struct serio *port = dev_id; struct serio *port = dev_id;
unsigned int byte; unsigned int byte;
kbd_pt_regs = regs;
while (iomd_readb(IOMD_KCTRL) & (1 << 5)) { while (iomd_readb(IOMD_KCTRL) & (1 << 5)) {
byte = iomd_readb(IOMD_KARTRX); byte = iomd_readb(IOMD_KARTRX);
serio_interrupt(port, byte, 0); serio_interrupt(port, byte, 0, regs);
} }
} }
......
...@@ -24,8 +24,6 @@ ...@@ -24,8 +24,6 @@
#include <asm/hardware/sa1111.h> #include <asm/hardware/sa1111.h>
extern struct pt_regs *kbd_pt_regs;
struct ps2if { struct ps2if {
struct serio io; struct serio io;
struct sa1111_dev *dev; struct sa1111_dev *dev;
...@@ -47,8 +45,6 @@ static void ps2_rxint(int irq, void *dev_id, struct pt_regs *regs) ...@@ -47,8 +45,6 @@ static void ps2_rxint(int irq, void *dev_id, struct pt_regs *regs)
struct ps2if *ps2if = dev_id; struct ps2if *ps2if = dev_id;
unsigned int scancode, flag, status; unsigned int scancode, flag, status;
kbd_pt_regs = regs;
status = sa1111_readl(ps2if->base + SA1111_PS2STAT); status = sa1111_readl(ps2if->base + SA1111_PS2STAT);
while (status & PS2STAT_RXF) { while (status & PS2STAT_RXF) {
if (status & PS2STAT_STP) if (status & PS2STAT_STP)
...@@ -62,7 +58,7 @@ static void ps2_rxint(int irq, void *dev_id, struct pt_regs *regs) ...@@ -62,7 +58,7 @@ static void ps2_rxint(int irq, void *dev_id, struct pt_regs *regs)
if (hweight8(scancode) & 1) if (hweight8(scancode) & 1)
flag ^= SERIO_PARITY; flag ^= SERIO_PARITY;
serio_interrupt(&ps2if->io, scancode, flag); serio_interrupt(&ps2if->io, scancode, flag, regs);
status = sa1111_readl(ps2if->base + SA1111_PS2STAT); status = sa1111_readl(ps2if->base + SA1111_PS2STAT);
} }
......
...@@ -135,10 +135,10 @@ void serio_rescan(struct serio *serio) ...@@ -135,10 +135,10 @@ void serio_rescan(struct serio *serio)
wake_up(&serio_wait); wake_up(&serio_wait);
} }
void serio_interrupt(struct serio *serio, unsigned char data, unsigned int flags) void serio_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
if (serio->dev && serio->dev->interrupt) if (serio->dev && serio->dev->interrupt)
serio->dev->interrupt(serio, data, flags); serio->dev->interrupt(serio, data, flags, regs);
else else
if (!flags) if (!flags)
serio_rescan(serio); serio_rescan(serio);
......
...@@ -114,6 +114,9 @@ static void serport_ldisc_close(struct tty_struct *tty) ...@@ -114,6 +114,9 @@ static void serport_ldisc_close(struct tty_struct *tty)
* serport_ldisc_receive() is called by the low level tty driver when characters * serport_ldisc_receive() is called by the low level tty driver when characters
* are ready for us. We forward the characters, one by one to the 'interrupt' * are ready for us. We forward the characters, one by one to the 'interrupt'
* routine. * routine.
*
* FIXME: We should get pt_regs from the tty layer and forward them to
* serio_interrupt here.
*/ */
static void serport_ldisc_receive(struct tty_struct *tty, const unsigned char *cp, char *fp, int count) static void serport_ldisc_receive(struct tty_struct *tty, const unsigned char *cp, char *fp, int count)
...@@ -121,7 +124,7 @@ static void serport_ldisc_receive(struct tty_struct *tty, const unsigned char *c ...@@ -121,7 +124,7 @@ static void serport_ldisc_receive(struct tty_struct *tty, const unsigned char *c
struct serport *serport = (struct serport*) tty->disc_data; struct serport *serport = (struct serport*) tty->disc_data;
int i; int i;
for (i = 0; i < count; i++) for (i = 0; i < count; i++)
serio_interrupt(&serport->serio, cp[i], 0); serio_interrupt(&serport->serio, cp[i], 0, NULL);
} }
/* /*
......
...@@ -60,7 +60,7 @@ struct gunze { ...@@ -60,7 +60,7 @@ struct gunze {
char phys[32]; char phys[32];
}; };
static void gunze_process_packet(struct gunze* gunze) static void gunze_process_packet(struct gunze* gunze, struct pt_regs *regs)
{ {
struct input_dev *dev = &gunze->dev; struct input_dev *dev = &gunze->dev;
...@@ -71,18 +71,19 @@ static void gunze_process_packet(struct gunze* gunze) ...@@ -71,18 +71,19 @@ static void gunze_process_packet(struct gunze* gunze)
return; return;
} }
input_regs(dev, regs);
input_report_abs(dev, ABS_X, simple_strtoul(gunze->data + 1, NULL, 10) * 4); input_report_abs(dev, ABS_X, simple_strtoul(gunze->data + 1, NULL, 10) * 4);
input_report_abs(dev, ABS_Y, 3072 - simple_strtoul(gunze->data + 6, NULL, 10) * 3); input_report_abs(dev, ABS_Y, 3072 - simple_strtoul(gunze->data + 6, NULL, 10) * 3);
input_report_key(dev, BTN_TOUCH, gunze->data[0] == 'T'); input_report_key(dev, BTN_TOUCH, gunze->data[0] == 'T');
input_sync(dev); input_sync(dev);
} }
static void gunze_interrupt(struct serio *serio, unsigned char data, unsigned int flags) static void gunze_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs)
{ {
struct gunze* gunze = serio->private; struct gunze* gunze = serio->private;
if (data == '\r') { if (data == '\r') {
gunze_process_packet(gunze); gunze_process_packet(gunze, regs);
gunze->idx = 0; gunze->idx = 0;
} else { } else {
if (gunze->idx < GUNZE_MAX_LENGTH) if (gunze->idx < GUNZE_MAX_LENGTH)
......
...@@ -108,6 +108,7 @@ static void action_button_handler(int irq, void *dev_id, struct pt_regs *regs) ...@@ -108,6 +108,7 @@ static void action_button_handler(int irq, void *dev_id, struct pt_regs *regs)
int down = (GPLR & GPIO_BITSY_ACTION_BUTTON) ? 0 : 1; int down = (GPLR & GPIO_BITSY_ACTION_BUTTON) ? 0 : 1;
struct input_dev *dev = (struct input_dev *) dev_id; struct input_dev *dev = (struct input_dev *) dev_id;
input_regs(dev, regs);
input_report_key(dev, KEY_ENTER, down); input_report_key(dev, KEY_ENTER, down);
input_sync(dev); input_sync(dev);
} }
...@@ -121,6 +122,7 @@ static void npower_button_handler(int irq, void *dev_id, struct pt_regs *regs) ...@@ -121,6 +122,7 @@ static void npower_button_handler(int irq, void *dev_id, struct pt_regs *regs)
* This interrupt is only called when we release the key. So we have * This interrupt is only called when we release the key. So we have
* to fake a key press. * to fake a key press.
*/ */
input_regs(dev, regs);
input_report_key(dev, KEY_SUSPEND, 1); input_report_key(dev, KEY_SUSPEND, 1);
input_report_key(dev, KEY_SUSPEND, down); input_report_key(dev, KEY_SUSPEND, down);
input_sync(dev); input_sync(dev);
...@@ -183,12 +185,14 @@ static int h3600ts_pm_callback(struct pm_dev *pm_dev, pm_request_t req, ...@@ -183,12 +185,14 @@ static int h3600ts_pm_callback(struct pm_dev *pm_dev, pm_request_t req,
* packets. Some packets coming from serial are not touchscreen related. In * packets. Some packets coming from serial are not touchscreen related. In
* this case we send them off to be processed elsewhere. * this case we send them off to be processed elsewhere.
*/ */
static void h3600ts_process_packet(struct h3600_dev *ts) static void h3600ts_process_packet(struct h3600_dev *ts, struct pt_regs *regs)
{ {
struct input_dev *dev = &ts->dev; struct input_dev *dev = &ts->dev;
static int touched = 0; static int touched = 0;
int key, down = 0; int key, down = 0;
input_regs(dev, regs);
switch (ts->event) { switch (ts->event) {
/* /*
Buttons - returned as a single byte Buttons - returned as a single byte
......
...@@ -52,8 +52,6 @@ MODULE_AUTHOR("Franz Sirl <Franz.Sirl-kernel@lauterbach.com>"); ...@@ -52,8 +52,6 @@ MODULE_AUTHOR("Franz Sirl <Franz.Sirl-kernel@lauterbach.com>");
#define KEYB_LEDREG 2 /* register # for leds on ADB keyboard */ #define KEYB_LEDREG 2 /* register # for leds on ADB keyboard */
#define MOUSE_DATAREG 0 /* reg# for movement/button codes from mouse */ #define MOUSE_DATAREG 0 /* reg# for movement/button codes from mouse */
extern struct pt_regs *kbd_pt_regs;
static int adb_message_handler(struct notifier_block *, unsigned long, void *); static int adb_message_handler(struct notifier_block *, unsigned long, void *);
static struct notifier_block adbhid_adb_notifier = { static struct notifier_block adbhid_adb_notifier = {
.notifier_call = adb_message_handler, .notifier_call = adb_message_handler,
...@@ -136,14 +134,13 @@ adbhid_keyboard_input(unsigned char *data, int nb, struct pt_regs *regs, int apo ...@@ -136,14 +134,13 @@ adbhid_keyboard_input(unsigned char *data, int nb, struct pt_regs *regs, int apo
/* first check this is from register 0 */ /* first check this is from register 0 */
if (nb != 3 || (data[0] & 3) != KEYB_KEYREG) if (nb != 3 || (data[0] & 3) != KEYB_KEYREG)
return; /* ignore it */ return; /* ignore it */
kbd_pt_regs = regs; adbhid_input_keycode(id, data[1], 0, regs);
adbhid_input_keycode(id, data[1], 0);
if (!(data[2] == 0xff || (data[2] == 0x7f && data[1] == 0x7f))) if (!(data[2] == 0xff || (data[2] == 0x7f && data[1] == 0x7f)))
adbhid_input_keycode(id, data[2], 0); adbhid_input_keycode(id, data[2], 0, regs);
} }
static void static void
adbhid_input_keycode(int id, int keycode, int repeat) adbhid_input_keycode(int id, int keycode, int repeat, pt_regs *regs)
{ {
int up_flag; int up_flag;
...@@ -152,21 +149,24 @@ adbhid_input_keycode(int id, int keycode, int repeat) ...@@ -152,21 +149,24 @@ adbhid_input_keycode(int id, int keycode, int repeat)
switch (keycode) { switch (keycode) {
case 0x39: /* Generate down/up events for CapsLock everytime. */ case 0x39: /* Generate down/up events for CapsLock everytime. */
input_regs(&adbhid[id]->input, regs);
input_report_key(&adbhid[id]->input, KEY_CAPSLOCK, 1); input_report_key(&adbhid[id]->input, KEY_CAPSLOCK, 1);
input_report_key(&adbhid[id]->input, KEY_CAPSLOCK, 0); input_report_key(&adbhid[id]->input, KEY_CAPSLOCK, 0);
input_sync(&adbhid[id]->input);
return; return;
case 0x3f: /* ignore Powerbook Fn key */ case 0x3f: /* ignore Powerbook Fn key */
return; return;
} }
if (adbhid[id]->keycode[keycode]) if (adbhid[id]->keycode[keycode]) {
input_regs(&adbhid[id]->input, regs);
input_report_key(&adbhid[id]->input, input_report_key(&adbhid[id]->input,
adbhid[id]->keycode[keycode], !up_flag); adbhid[id]->keycode[keycode], !up_flag);
else input_sync(&adbhid[id]->input);
} else
printk(KERN_INFO "Unhandled ADB key (scancode %#02x) %s.\n", keycode, printk(KERN_INFO "Unhandled ADB key (scancode %#02x) %s.\n", keycode,
up_flag ? "released" : "pressed"); up_flag ? "released" : "pressed");
input_sync(&adbhid[id]->input);
} }
static void static void
...@@ -253,6 +253,8 @@ adbhid_mouse_input(unsigned char *data, int nb, struct pt_regs *regs, int autopo ...@@ -253,6 +253,8 @@ adbhid_mouse_input(unsigned char *data, int nb, struct pt_regs *regs, int autopo
break; break;
} }
input_regs(&adbhid[id]->input, regs);
input_report_key(&adbhid[id]->input, BTN_LEFT, !((data[1] >> 7) & 1)); input_report_key(&adbhid[id]->input, BTN_LEFT, !((data[1] >> 7) & 1));
input_report_key(&adbhid[id]->input, BTN_MIDDLE, !((data[2] >> 7) & 1)); input_report_key(&adbhid[id]->input, BTN_MIDDLE, !((data[2] >> 7) & 1));
...@@ -277,6 +279,8 @@ adbhid_buttons_input(unsigned char *data, int nb, struct pt_regs *regs, int auto ...@@ -277,6 +279,8 @@ adbhid_buttons_input(unsigned char *data, int nb, struct pt_regs *regs, int auto
return; return;
} }
input_regs(&adbhid[id]->input, regs);
switch (adbhid[id]->original_handler_id) { switch (adbhid[id]->original_handler_id) {
default: default:
case 0x02: /* Adjustable keyboard button device */ case 0x02: /* Adjustable keyboard button device */
......
...@@ -527,7 +527,7 @@ static void receive_kbd_ms_chars(struct uart_sunsu_port *up, struct pt_regs *reg ...@@ -527,7 +527,7 @@ static void receive_kbd_ms_chars(struct uart_sunsu_port *up, struct pt_regs *reg
} }
kbd_pt_regs = regs; kbd_pt_regs = regs;
#ifdef CONFIG_SERIO #ifdef CONFIG_SERIO
serio_interrupt(&up->serio, ch, 0); serio_interrupt(&up->serio, ch, 0, regs);
#endif #endif
} else if (up->su_type == SU_PORT_MS) { } else if (up->su_type == SU_PORT_MS) {
int ret = suncore_mouse_baud_detection(ch, is_break); int ret = suncore_mouse_baud_detection(ch, is_break);
...@@ -541,7 +541,7 @@ static void receive_kbd_ms_chars(struct uart_sunsu_port *up, struct pt_regs *reg ...@@ -541,7 +541,7 @@ static void receive_kbd_ms_chars(struct uart_sunsu_port *up, struct pt_regs *reg
case 0: case 0:
#ifdef CONFIG_SERIO #ifdef CONFIG_SERIO
serio_interrupt(&up->serio, ch, 0); serio_interrupt(&up->serio, ch, 0, regs);
#endif #endif
break; break;
}; };
......
...@@ -303,7 +303,7 @@ static void sunzilog_kbdms_receive_chars(struct uart_sunzilog_port *up, ...@@ -303,7 +303,7 @@ static void sunzilog_kbdms_receive_chars(struct uart_sunzilog_port *up,
} }
kbd_pt_regs = regs; kbd_pt_regs = regs;
#ifdef CONFIG_SERIO #ifdef CONFIG_SERIO
serio_interrupt(&up->serio, ch, 0); serio_interrupt(&up->serio, ch, 0, regs);
#endif #endif
} else if (ZS_IS_MOUSE(up)) { } else if (ZS_IS_MOUSE(up)) {
int ret = suncore_mouse_baud_detection(ch, is_break); int ret = suncore_mouse_baud_detection(ch, is_break);
...@@ -317,7 +317,7 @@ static void sunzilog_kbdms_receive_chars(struct uart_sunzilog_port *up, ...@@ -317,7 +317,7 @@ static void sunzilog_kbdms_receive_chars(struct uart_sunzilog_port *up,
case 0: case 0:
#ifdef CONFIG_SERIO #ifdef CONFIG_SERIO
serio_interrupt(&up->serio, ch, 0); serio_interrupt(&up->serio, ch, 0, regs);
#endif #endif
break; break;
}; };
......
...@@ -155,6 +155,8 @@ aiptek_irq(struct urb *urb, struct pt_regs *regs) ...@@ -155,6 +155,8 @@ aiptek_irq(struct urb *urb, struct pt_regs *regs)
dbg("received unknown report #%d", data[0]); dbg("received unknown report #%d", data[0]);
} }
input_regs(dev, regs);
proximity = data[5] & 0x01; proximity = data[5] & 0x01;
input_report_key(dev, BTN_TOOL_PEN, proximity); input_report_key(dev, BTN_TOOL_PEN, proximity);
......
...@@ -773,13 +773,13 @@ static __inline__ int search(__s32 *array, __s32 value, unsigned n) ...@@ -773,13 +773,13 @@ static __inline__ int search(__s32 *array, __s32 value, unsigned n)
return -1; return -1;
} }
static void hid_process_event(struct hid_device *hid, struct hid_field *field, struct hid_usage *usage, __s32 value) static void hid_process_event(struct hid_device *hid, struct hid_field *field, struct hid_usage *usage, __s32 value, struct pt_regs *regs)
{ {
hid_dump_input(usage, value); hid_dump_input(usage, value);
if (hid->claimed & HID_CLAIMED_INPUT) if (hid->claimed & HID_CLAIMED_INPUT)
hidinput_hid_event(hid, field, usage, value); hidinput_hid_event(hid, field, usage, value, regs);
if (hid->claimed & HID_CLAIMED_HIDDEV) if (hid->claimed & HID_CLAIMED_HIDDEV)
hiddev_hid_event(hid, field, usage, value); hiddev_hid_event(hid, field, usage, value, regs);
} }
/* /*
...@@ -788,7 +788,7 @@ static void hid_process_event(struct hid_device *hid, struct hid_field *field, s ...@@ -788,7 +788,7 @@ static void hid_process_event(struct hid_device *hid, struct hid_field *field, s
* reporting to the layer). * reporting to the layer).
*/ */
static void hid_input_field(struct hid_device *hid, struct hid_field *field, __u8 *data) static void hid_input_field(struct hid_device *hid, struct hid_field *field, __u8 *data, struct pt_regs *regs)
{ {
unsigned n; unsigned n;
unsigned count = field->report_count; unsigned count = field->report_count;
...@@ -818,25 +818,25 @@ static void hid_input_field(struct hid_device *hid, struct hid_field *field, __u ...@@ -818,25 +818,25 @@ static void hid_input_field(struct hid_device *hid, struct hid_field *field, __u
} else { } else {
if (value[n] == field->value[n]) continue; if (value[n] == field->value[n]) continue;
} }
hid_process_event(hid, field, &field->usage[n], value[n]); hid_process_event(hid, field, &field->usage[n], value[n], regs);
continue; continue;
} }
if (field->value[n] >= min && field->value[n] <= max if (field->value[n] >= min && field->value[n] <= max
&& field->usage[field->value[n] - min].hid && field->usage[field->value[n] - min].hid
&& search(value, field->value[n], count)) && search(value, field->value[n], count))
hid_process_event(hid, field, &field->usage[field->value[n] - min], 0); hid_process_event(hid, field, &field->usage[field->value[n] - min], 0, regs);
if (value[n] >= min && value[n] <= max if (value[n] >= min && value[n] <= max
&& field->usage[value[n] - min].hid && field->usage[value[n] - min].hid
&& search(field->value, value[n], count)) && search(field->value, value[n], count))
hid_process_event(hid, field, &field->usage[value[n] - min], 1); hid_process_event(hid, field, &field->usage[value[n] - min], 1, regs);
} }
memcpy(field->value, value, count * sizeof(__s32)); memcpy(field->value, value, count * sizeof(__s32));
} }
static int hid_input_report(int type, struct urb *urb) static int hid_input_report(int type, struct urb *urb, struct pt_regs *regs)
{ {
struct hid_device *hid = urb->context; struct hid_device *hid = urb->context;
struct hid_report_enum *report_enum = hid->report_enum + type; struct hid_report_enum *report_enum = hid->report_enum + type;
...@@ -886,7 +886,7 @@ static int hid_input_report(int type, struct urb *urb) ...@@ -886,7 +886,7 @@ static int hid_input_report(int type, struct urb *urb)
hiddev_report_event(hid, report); hiddev_report_event(hid, report);
for (n = 0; n < report->maxfield; n++) for (n = 0; n < report->maxfield; n++)
hid_input_field(hid, report->field[n], data); hid_input_field(hid, report->field[n], data, regs);
if (hid->claimed & HID_CLAIMED_INPUT) if (hid->claimed & HID_CLAIMED_INPUT)
hidinput_report_event(hid, report); hidinput_report_event(hid, report);
...@@ -905,7 +905,7 @@ static void hid_irq_in(struct urb *urb, struct pt_regs *regs) ...@@ -905,7 +905,7 @@ static void hid_irq_in(struct urb *urb, struct pt_regs *regs)
switch (urb->status) { switch (urb->status) {
case 0: /* success */ case 0: /* success */
hid_input_report(HID_INPUT_REPORT, urb); hid_input_report(HID_INPUT_REPORT, urb, regs);
break; break;
case -ECONNRESET: /* unlink */ case -ECONNRESET: /* unlink */
case -ENOENT: case -ENOENT:
...@@ -1130,7 +1130,7 @@ static void hid_ctrl(struct urb *urb, struct pt_regs *regs) ...@@ -1130,7 +1130,7 @@ static void hid_ctrl(struct urb *urb, struct pt_regs *regs)
spin_lock_irqsave(&hid->ctrllock, flags); spin_lock_irqsave(&hid->ctrllock, flags);
if (hid->ctrl[hid->ctrltail].dir == USB_DIR_IN) if (hid->ctrl[hid->ctrltail].dir == USB_DIR_IN)
hid_input_report(hid->ctrl[hid->ctrltail].report->type, urb); hid_input_report(hid->ctrl[hid->ctrltail].report->type, urb, regs);
hid->ctrltail = (hid->ctrltail + 1) & (HID_CONTROL_FIFO_SIZE - 1); hid->ctrltail = (hid->ctrltail + 1) & (HID_CONTROL_FIFO_SIZE - 1);
......
...@@ -380,11 +380,13 @@ static void hidinput_configure_usage(struct hid_device *device, struct hid_field ...@@ -380,11 +380,13 @@ static void hidinput_configure_usage(struct hid_device *device, struct hid_field
} }
} }
void hidinput_hid_event(struct hid_device *hid, struct hid_field *field, struct hid_usage *usage, __s32 value) void hidinput_hid_event(struct hid_device *hid, struct hid_field *field, struct hid_usage *usage, __s32 value, struct pt_regs *regs)
{ {
struct input_dev *input = &hid->input; struct input_dev *input = &hid->input;
int *quirks = &hid->quirks; int *quirks = &hid->quirks;
input_regs(input, regs);
if (usage->hat_min != usage->hat_max) { if (usage->hat_min != usage->hat_max) {
value = (value - usage->hat_min) * 8 / (usage->hat_max - usage->hat_min + 1) + 1; value = (value - usage->hat_min) * 8 / (usage->hat_max - usage->hat_min + 1) + 1;
if (value < 0 || value > 8) value = 0; if (value < 0 || value > 8) value = 0;
......
...@@ -420,13 +420,13 @@ struct hid_descriptor { ...@@ -420,13 +420,13 @@ struct hid_descriptor {
/* Applications from HID Usage Tables 4/8/99 Version 1.1 */ /* Applications from HID Usage Tables 4/8/99 Version 1.1 */
/* We ignore a few input applications that are not widely used */ /* We ignore a few input applications that are not widely used */
#define IS_INPUT_APPLICATION(a) (((a >= 0x00010000) && (a <= 0x00010008)) || ( a == 0x00010080) || ( a == 0x000c0001)) #define IS_INPUT_APPLICATION(a) (((a >= 0x00010000) && (a <= 0x00010008)) || ( a == 0x00010080) || ( a == 0x000c0001))
extern void hidinput_hid_event(struct hid_device *, struct hid_field *, struct hid_usage *, __s32); extern void hidinput_hid_event(struct hid_device *, struct hid_field *, struct hid_usage *, __s32, struct pt_regs *regs);
extern void hidinput_report_event(struct hid_device *hid, struct hid_report *report); extern void hidinput_report_event(struct hid_device *hid, struct hid_report *report);
extern int hidinput_connect(struct hid_device *); extern int hidinput_connect(struct hid_device *);
extern void hidinput_disconnect(struct hid_device *); extern void hidinput_disconnect(struct hid_device *);
#else #else
#define IS_INPUT_APPLICATION(a) (0) #define IS_INPUT_APPLICATION(a) (0)
static inline void hidinput_hid_event(struct hid_device *hid, struct hid_field *field, struct hid_usage *usage, __s32 value) { } static inline void hidinput_hid_event(struct hid_device *hid, struct hid_field *field, struct hid_usage *usage, __s32 value, struct pt_regs *regs) { }
static inline void hidinput_report_event(struct hid_device *hid, struct hid_report *report) { } static inline void hidinput_report_event(struct hid_device *hid, struct hid_report *report) { }
static inline int hidinput_connect(struct hid_device *hid) { return -ENODEV; } static inline int hidinput_connect(struct hid_device *hid) { return -ENODEV; }
static inline void hidinput_disconnect(struct hid_device *hid) { } static inline void hidinput_disconnect(struct hid_device *hid) { }
......
...@@ -180,7 +180,7 @@ static void hiddev_send_event(struct hid_device *hid, ...@@ -180,7 +180,7 @@ static void hiddev_send_event(struct hid_device *hid,
* the interrupt pipe * the interrupt pipe
*/ */
void hiddev_hid_event(struct hid_device *hid, struct hid_field *field, void hiddev_hid_event(struct hid_device *hid, struct hid_field *field,
struct hid_usage *usage, __s32 value) struct hid_usage *usage, __s32 value, struct pt_regs *regs)
{ {
unsigned type = field->report_type; unsigned type = field->report_type;
struct hiddev_usage_ref uref; struct hiddev_usage_ref uref;
......
...@@ -96,6 +96,7 @@ static void powermate_irq(struct urb *urb, struct pt_regs *regs) ...@@ -96,6 +96,7 @@ static void powermate_irq(struct urb *urb, struct pt_regs *regs)
} }
/* handle updates to device state */ /* handle updates to device state */
input_regs(&pm->input, regs);
input_report_key(&pm->input, BTN_0, pm->data[0] & 0x01); input_report_key(&pm->input, BTN_0, pm->data[0] & 0x01);
input_report_rel(&pm->input, REL_DIAL, pm->data[1]); input_report_rel(&pm->input, REL_DIAL, pm->data[1]);
input_sync(&pm->input); input_sync(&pm->input);
......
...@@ -99,6 +99,8 @@ static void usb_kbd_irq(struct urb *urb, struct pt_regs *regs) ...@@ -99,6 +99,8 @@ static void usb_kbd_irq(struct urb *urb, struct pt_regs *regs)
goto resubmit; goto resubmit;
} }
input_regs(&kbd->dev, regs);
for (i = 0; i < 8; i++) for (i = 0; i < 8; i++)
input_report_key(&kbd->dev, usb_kbd_keycode[i + 224], (kbd->new[0] >> i) & 1); input_report_key(&kbd->dev, usb_kbd_keycode[i + 224], (kbd->new[0] >> i) & 1);
......
...@@ -76,6 +76,7 @@ static void usb_mouse_irq(struct urb *urb, struct pt_regs *regs) ...@@ -76,6 +76,7 @@ static void usb_mouse_irq(struct urb *urb, struct pt_regs *regs)
goto resubmit; goto resubmit;
} }
input_regs(dev, regs);
input_report_key(dev, BTN_LEFT, data[0] & 0x01); input_report_key(dev, BTN_LEFT, data[0] & 0x01);
input_report_key(dev, BTN_RIGHT, data[0] & 0x02); input_report_key(dev, BTN_RIGHT, data[0] & 0x02);
......
...@@ -130,6 +130,8 @@ static void wacom_pl_irq(struct urb *urb, struct pt_regs *regs) ...@@ -130,6 +130,8 @@ static void wacom_pl_irq(struct urb *urb, struct pt_regs *regs)
prox = data[1] & 0x40; prox = data[1] & 0x40;
input_regs(dev, regs);
input_report_key(dev, BTN_TOOL_PEN, prox); input_report_key(dev, BTN_TOOL_PEN, prox);
if (prox) { if (prox) {
...@@ -179,6 +181,7 @@ static void wacom_penpartner_irq(struct urb *urb, struct pt_regs *regs) ...@@ -179,6 +181,7 @@ static void wacom_penpartner_irq(struct urb *urb, struct pt_regs *regs)
goto exit; goto exit;
} }
input_regs(dev, regs);
input_report_key(dev, BTN_TOOL_PEN, 1); input_report_key(dev, BTN_TOOL_PEN, 1);
input_report_abs(dev, ABS_X, data[2] << 8 | data[1]); input_report_abs(dev, ABS_X, data[2] << 8 | data[1]);
input_report_abs(dev, ABS_Y, data[4] << 8 | data[3]); input_report_abs(dev, ABS_Y, data[4] << 8 | data[3]);
...@@ -223,6 +226,8 @@ static void wacom_graphire_irq(struct urb *urb, struct pt_regs *regs) ...@@ -223,6 +226,8 @@ static void wacom_graphire_irq(struct urb *urb, struct pt_regs *regs)
x = data[2] | ((__u32)data[3] << 8); x = data[2] | ((__u32)data[3] << 8);
y = data[4] | ((__u32)data[5] << 8); y = data[4] | ((__u32)data[5] << 8);
input_regs(dev, regs);
switch ((data[1] >> 5) & 3) { switch ((data[1] >> 5) & 3) {
case 0: /* Pen */ case 0: /* Pen */
...@@ -294,6 +299,8 @@ static void wacom_intuos_irq(struct urb *urb, struct pt_regs *regs) ...@@ -294,6 +299,8 @@ static void wacom_intuos_irq(struct urb *urb, struct pt_regs *regs)
if (data[0] != 2) if (data[0] != 2)
dbg("received unknown report #%d", data[0]); dbg("received unknown report #%d", data[0]);
input_regs(dev, regs);
/* tool number */ /* tool number */
idx = data[1] & 0x01; idx = data[1] & 0x01;
......
...@@ -124,10 +124,12 @@ struct usb_xpad { ...@@ -124,10 +124,12 @@ struct usb_xpad {
* http://euc.jp/periphs/xbox-controller.ja.html * http://euc.jp/periphs/xbox-controller.ja.html
*/ */
static void xpad_process_packet(struct usb_xpad *xpad, u16 cmd, unsigned char *data) static void xpad_process_packet(struct usb_xpad *xpad, u16 cmd, unsigned char *data, struct pt_regs *regs)
{ {
struct input_dev *dev = &xpad->dev; struct input_dev *dev = &xpad->dev;
input_regs(dev, regs);
/* left stick */ /* left stick */
input_report_abs(dev, ABS_X, (__s16) (((__s16)data[13] << 8) | data[12])); input_report_abs(dev, ABS_X, (__s16) (((__s16)data[13] << 8) | data[12]));
input_report_abs(dev, ABS_Y, (__s16) (((__s16)data[15] << 8) | data[14])); input_report_abs(dev, ABS_Y, (__s16) (((__s16)data[15] << 8) | data[14]));
...@@ -183,7 +185,7 @@ static void xpad_irq_in(struct urb *urb, struct pt_regs *regs) ...@@ -183,7 +185,7 @@ static void xpad_irq_in(struct urb *urb, struct pt_regs *regs)
goto exit; goto exit;
} }
xpad_process_packet(xpad, 0, xpad->idata); xpad_process_packet(xpad, 0, xpad->idata, regs);
exit: exit:
retval = usb_submit_urb (urb, GFP_ATOMIC); retval = usb_submit_urb (urb, GFP_ATOMIC);
......
...@@ -62,8 +62,6 @@ static __inline__ int con_is_present(void) ...@@ -62,8 +62,6 @@ static __inline__ int con_is_present(void)
return serial_console ? 0 : 1; return serial_console ? 0 : 1;
} }
extern struct pt_regs *kbd_pt_regs;
/* When a context switch happens we must flush all user windows so that /* When a context switch happens we must flush all user windows so that
* the windows of the current process are flushed onto its stack. This * the windows of the current process are flushed onto its stack. This
* way the windows are all clean for the next process and the stack * way the windows are all clean for the next process and the stack
......
...@@ -131,8 +131,6 @@ static __inline__ int con_is_present(void) ...@@ -131,8 +131,6 @@ static __inline__ int con_is_present(void)
return serial_console ? 0 : 1; return serial_console ? 0 : 1;
} }
extern struct pt_regs *kbd_pt_regs;
extern void synchronize_user_stack(void); extern void synchronize_user_stack(void);
extern void __flushw_user(void); extern void __flushw_user(void);
......
...@@ -204,7 +204,7 @@ struct hiddev_usage_ref { ...@@ -204,7 +204,7 @@ struct hiddev_usage_ref {
int hiddev_connect(struct hid_device *); int hiddev_connect(struct hid_device *);
void hiddev_disconnect(struct hid_device *); void hiddev_disconnect(struct hid_device *);
void hiddev_hid_event(struct hid_device *hid, struct hid_field *field, void hiddev_hid_event(struct hid_device *hid, struct hid_field *field,
struct hid_usage *usage, __s32 value); struct hid_usage *usage, __s32 value, struct pt_regs *regs);
void hiddev_report_event(struct hid_device *hid, struct hid_report *report); void hiddev_report_event(struct hid_device *hid, struct hid_report *report);
int __init hiddev_init(void); int __init hiddev_init(void);
void __exit hiddev_exit(void); void __exit hiddev_exit(void);
...@@ -212,7 +212,7 @@ void __exit hiddev_exit(void); ...@@ -212,7 +212,7 @@ void __exit hiddev_exit(void);
static inline int hiddev_connect(struct hid_device *hid) { return -1; } static inline int hiddev_connect(struct hid_device *hid) { return -1; }
static inline void hiddev_disconnect(struct hid_device *hid) { } static inline void hiddev_disconnect(struct hid_device *hid) { }
static inline void hiddev_hid_event(struct hid_device *hid, struct hid_field *field, static inline void hiddev_hid_event(struct hid_device *hid, struct hid_field *field,
struct hid_usage *usage, __s32 value) { } struct hid_usage *usage, __s32 value, struct pt_regs *regs) { }
static inline void hiddev_report_event(struct hid_device *hid, struct hid_report *report) { } static inline void hiddev_report_event(struct hid_device *hid, struct hid_report *report) { }
static inline int hiddev_init(void) { return 0; } static inline int hiddev_init(void) { return 0; }
static inline void hiddev_exit(void) { } static inline void hiddev_exit(void) { }
......
...@@ -774,6 +774,7 @@ struct input_dev { ...@@ -774,6 +774,7 @@ struct input_dev {
struct timer_list timer; struct timer_list timer;
struct pm_dev *pm_dev; struct pm_dev *pm_dev;
struct pt_regs *regs;
int state; int state;
int sync; int sync;
...@@ -899,13 +900,15 @@ void input_unregister_minor(devfs_handle_t handle); ...@@ -899,13 +900,15 @@ void input_unregister_minor(devfs_handle_t handle);
void input_event(struct input_dev *dev, unsigned int type, unsigned int code, int value); void input_event(struct input_dev *dev, unsigned int type, unsigned int code, int value);
#define input_sync(a) input_event(a, EV_SYN, SYN_REPORT, 0)
#define input_report_key(a,b,c) input_event(a, EV_KEY, b, !!(c)) #define input_report_key(a,b,c) input_event(a, EV_KEY, b, !!(c))
#define input_report_rel(a,b,c) input_event(a, EV_REL, b, c) #define input_report_rel(a,b,c) input_event(a, EV_REL, b, c)
#define input_report_abs(a,b,c) input_event(a, EV_ABS, b, c) #define input_report_abs(a,b,c) input_event(a, EV_ABS, b, c)
#define input_report_ff(a,b,c) input_event(a, EV_FF, b, c) #define input_report_ff(a,b,c) input_event(a, EV_FF, b, c)
#define input_report_ff_status(a,b,c) input_event(a, EV_FF_STATUS, b, c) #define input_report_ff_status(a,b,c) input_event(a, EV_FF_STATUS, b, c)
#define input_regs(a,b) do { (a)->regs = (b); } while (0)
#define input_sync(a) do { input_event(a, EV_SYN, SYN_REPORT, 0); (a)->regs = NULL; } while (0)
extern struct device_class input_devclass; extern struct device_class input_devclass;
#endif #endif
......
...@@ -10,10 +10,13 @@ ...@@ -10,10 +10,13 @@
*/ */
#include <linux/ioctl.h> #include <linux/ioctl.h>
#include <linux/list.h>
#define SPIOCSTYPE _IOW('q', 0x01, unsigned long) #define SPIOCSTYPE _IOW('q', 0x01, unsigned long)
#ifdef __KERNEL__
#include <linux/list.h>
struct serio; struct serio;
struct serio { struct serio {
...@@ -47,7 +50,7 @@ struct serio_dev { ...@@ -47,7 +50,7 @@ struct serio_dev {
char *name; char *name;
void (*write_wakeup)(struct serio *); void (*write_wakeup)(struct serio *);
void (*interrupt)(struct serio *, unsigned char, unsigned int); void (*interrupt)(struct serio *, unsigned char, unsigned int, struct pt_regs *);
void (*connect)(struct serio *, struct serio_dev *dev); void (*connect)(struct serio *, struct serio_dev *dev);
void (*disconnect)(struct serio *); void (*disconnect)(struct serio *);
void (*cleanup)(struct serio *); void (*cleanup)(struct serio *);
...@@ -58,7 +61,7 @@ struct serio_dev { ...@@ -58,7 +61,7 @@ struct serio_dev {
int serio_open(struct serio *serio, struct serio_dev *dev); int serio_open(struct serio *serio, struct serio_dev *dev);
void serio_close(struct serio *serio); void serio_close(struct serio *serio);
void serio_rescan(struct serio *serio); void serio_rescan(struct serio *serio);
void serio_interrupt(struct serio *serio, unsigned char data, unsigned int flags); void serio_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs);
void serio_register_port(struct serio *serio); void serio_register_port(struct serio *serio);
void serio_unregister_port(struct serio *serio); void serio_unregister_port(struct serio *serio);
...@@ -85,6 +88,8 @@ static __inline__ void serio_cleanup(struct serio *serio) ...@@ -85,6 +88,8 @@ static __inline__ void serio_cleanup(struct serio *serio)
serio->dev->cleanup(serio); serio->dev->cleanup(serio);
} }
#endif
/* /*
* bit masks for use in "interrupt" flags (3rd argument) * bit masks for use in "interrupt" flags (3rd argument)
*/ */
......
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