Commit 4d74063e authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] irqs: input drivers

Update the input and joystick drivers to the new IRQ API.
parent 2efd7260
...@@ -78,40 +78,38 @@ static void iforce_serio_write_wakeup(struct serio *serio) ...@@ -78,40 +78,38 @@ 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, struct pt_regs *regs) static irqreturn_t 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;
if (!iforce->pkt) { if (!iforce->pkt) {
if (data != 0x2b) { if (data == 0x2b)
return; iforce->pkt = 1;
} goto out;
iforce->pkt = 1;
return;
} }
if (!iforce->id) { if (!iforce->id) {
if (data > 3 && data != 0xff) { if (data > 3 && data != 0xff)
iforce->pkt = 0; iforce->pkt = 0;
return; else
} iforce->id = data;
iforce->id = data; goto out;
return;
} }
if (!iforce->len) { if (!iforce->len) {
if (data > IFORCE_MAX_LENGTH) { if (data > IFORCE_MAX_LENGTH) {
iforce->pkt = 0; iforce->pkt = 0;
iforce->id = 0; iforce->id = 0;
return; } else {
iforce->len = data;
} }
iforce->len = data; goto out;
return;
} }
if (iforce->idx < iforce->len) { if (iforce->idx < iforce->len) {
iforce->csum += iforce->data[iforce->idx++] = data; iforce->csum += iforce->data[iforce->idx++] = data;
return; goto out;
} }
if (iforce->idx == iforce->len) { if (iforce->idx == iforce->len) {
...@@ -122,6 +120,8 @@ static void iforce_serio_irq(struct serio *serio, unsigned char data, unsigned i ...@@ -122,6 +120,8 @@ static void iforce_serio_irq(struct serio *serio, unsigned char data, unsigned i
iforce->idx = 0; iforce->idx = 0;
iforce->csum = 0; iforce->csum = 0;
} }
out:
return IRQ_HANDLED;
} }
static void iforce_serio_connect(struct serio *serio, struct serio_dev *dev) static void iforce_serio_connect(struct serio *serio, struct serio_dev *dev)
......
...@@ -113,7 +113,8 @@ static void magellan_process_packet(struct magellan* magellan, struct pt_regs *r ...@@ -113,7 +113,8 @@ static void magellan_process_packet(struct magellan* magellan, struct pt_regs *r
input_sync(dev); input_sync(dev);
} }
static void magellan_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) static irqreturn_t 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;
...@@ -123,7 +124,8 @@ static void magellan_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -123,7 +124,8 @@ static void magellan_interrupt(struct serio *serio, unsigned char data, unsigned
} else { } else {
if (magellan->idx < MAGELLAN_MAX_LENGTH) if (magellan->idx < MAGELLAN_MAX_LENGTH)
magellan->data[magellan->idx++] = data; magellan->data[magellan->idx++] = data;
} }
return IRQ_HANDLED;
} }
/* /*
......
...@@ -149,7 +149,8 @@ static void spaceball_process_packet(struct spaceball* spaceball, struct pt_regs ...@@ -149,7 +149,8 @@ static void spaceball_process_packet(struct spaceball* spaceball, struct pt_regs
* 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, struct pt_regs *regs) static irqreturn_t 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;
...@@ -158,11 +159,11 @@ static void spaceball_interrupt(struct serio *serio, unsigned char data, unsigne ...@@ -158,11 +159,11 @@ static void spaceball_interrupt(struct serio *serio, unsigned char data, unsigne
spaceball_process_packet(spaceball, regs); spaceball_process_packet(spaceball, regs);
spaceball->idx = 0; spaceball->idx = 0;
spaceball->escape = 0; spaceball->escape = 0;
return; break;
case '^': case '^':
if (!spaceball->escape) { if (!spaceball->escape) {
spaceball->escape = 1; spaceball->escape = 1;
return; break;
} }
spaceball->escape = 0; spaceball->escape = 0;
case 'M': case 'M':
...@@ -177,8 +178,9 @@ static void spaceball_interrupt(struct serio *serio, unsigned char data, unsigne ...@@ -177,8 +178,9 @@ static void spaceball_interrupt(struct serio *serio, unsigned char data, unsigne
spaceball->escape = 0; spaceball->escape = 0;
if (spaceball->idx < SPACEBALL_MAX_LENGTH) if (spaceball->idx < SPACEBALL_MAX_LENGTH)
spaceball->data[spaceball->idx++] = data; spaceball->data[spaceball->idx++] = data;
return; break;
} }
return IRQ_HANDLED;
} }
/* /*
......
...@@ -130,7 +130,8 @@ static void spaceorb_process_packet(struct spaceorb *spaceorb, struct pt_regs *r ...@@ -130,7 +130,8 @@ static void spaceorb_process_packet(struct spaceorb *spaceorb, struct pt_regs *r
input_sync(dev); input_sync(dev);
} }
static void spaceorb_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) static irqreturn_t 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;
...@@ -140,6 +141,7 @@ static void spaceorb_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -140,6 +141,7 @@ static void spaceorb_interrupt(struct serio *serio, unsigned char data, unsigned
} }
if (spaceorb->idx < SPACEORB_MAX_LENGTH) if (spaceorb->idx < SPACEORB_MAX_LENGTH)
spaceorb->data[spaceorb->idx++] = data & 0x7f; spaceorb->data[spaceorb->idx++] = data & 0x7f;
return IRQ_HANDLED;
} }
/* /*
......
...@@ -98,7 +98,8 @@ static void stinger_process_packet(struct stinger *stinger, struct pt_regs *regs ...@@ -98,7 +98,8 @@ static void stinger_process_packet(struct stinger *stinger, struct pt_regs *regs
* packet processing routine. * packet processing routine.
*/ */
static void stinger_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) static irqreturn_t 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;
...@@ -112,7 +113,7 @@ static void stinger_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -112,7 +113,7 @@ static void stinger_interrupt(struct serio *serio, unsigned char data, unsigned
stinger->idx = 0; stinger->idx = 0;
} }
return; return IRQ_HANDLED;
} }
/* /*
......
...@@ -99,7 +99,8 @@ static void warrior_process_packet(struct warrior *warrior, struct pt_regs *regs ...@@ -99,7 +99,8 @@ static void warrior_process_packet(struct warrior *warrior, struct pt_regs *regs
* packet processing routine. * packet processing routine.
*/ */
static void warrior_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) static irqreturn_t 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;
...@@ -117,6 +118,7 @@ static void warrior_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -117,6 +118,7 @@ static void warrior_interrupt(struct serio *serio, unsigned char data, unsigned
warrior->idx = 0; warrior->idx = 0;
warrior->len = 0; warrior->len = 0;
} }
return IRQ_HANDLED;
} }
/* /*
......
...@@ -132,7 +132,8 @@ struct atkbd { ...@@ -132,7 +132,8 @@ struct atkbd {
* the keyboard into events. * the keyboard into events.
*/ */
static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) static irqreturn_t 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;
...@@ -145,7 +146,7 @@ static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned in ...@@ -145,7 +146,7 @@ static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned in
printk("atkbd.c: frame/parity error: %02x\n", flags); printk("atkbd.c: frame/parity error: %02x\n", flags);
serio_write(serio, ATKBD_CMD_RESEND); serio_write(serio, ATKBD_CMD_RESEND);
atkbd->resend = 1; atkbd->resend = 1;
return; goto out;
} }
if (!flags) if (!flags)
...@@ -154,34 +155,35 @@ static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned in ...@@ -154,34 +155,35 @@ static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned in
switch (code) { switch (code) {
case ATKBD_RET_ACK: case ATKBD_RET_ACK:
atkbd->ack = 1; atkbd->ack = 1;
return; goto out;
case ATKBD_RET_NAK: case ATKBD_RET_NAK:
atkbd->ack = -1; atkbd->ack = -1;
return; goto out;
} }
if (atkbd->cmdcnt) { if (atkbd->cmdcnt) {
atkbd->cmdbuf[--atkbd->cmdcnt] = code; atkbd->cmdbuf[--atkbd->cmdcnt] = code;
return; goto out;
} }
switch (atkbd->keycode[code]) { switch (atkbd->keycode[code]) {
case ATKBD_KEY_BAT: case ATKBD_KEY_BAT:
serio_rescan(atkbd->serio); serio_rescan(atkbd->serio);
return; goto out;
case ATKBD_KEY_EMUL0: case ATKBD_KEY_EMUL0:
atkbd->emul = 1; atkbd->emul = 1;
return; goto out;
case ATKBD_KEY_EMUL1: case ATKBD_KEY_EMUL1:
atkbd->emul = 2; atkbd->emul = 2;
return; goto out;
case ATKBD_KEY_RELEASE: case ATKBD_KEY_RELEASE:
atkbd->release = 1; atkbd->release = 1;
return; goto out;
} }
if (atkbd->emul) { if (atkbd->emul) {
if (--atkbd->emul) return; if (--atkbd->emul)
goto out;
code |= 0x100; code |= 0x100;
} }
...@@ -197,8 +199,10 @@ static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned in ...@@ -197,8 +199,10 @@ static void atkbd_interrupt(struct serio *serio, unsigned char data, unsigned in
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);
} }
atkbd->release = 0; atkbd->release = 0;
out:
return IRQ_HANDLED;
} }
/* /*
......
...@@ -62,7 +62,8 @@ struct nkbd { ...@@ -62,7 +62,8 @@ struct nkbd {
char phys[32]; char phys[32];
}; };
void nkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) irqreturn_t 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;
...@@ -75,6 +76,7 @@ void nkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, ...@@ -75,6 +76,7 @@ void nkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags,
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);
return IRQ_HANDLED;
} }
......
...@@ -89,18 +89,19 @@ struct sunkbd { ...@@ -89,18 +89,19 @@ struct sunkbd {
* is received. * is received.
*/ */
static void sunkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) static irqreturn_t 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;
if (sunkbd->reset <= -1) { /* If cp[i] is 0xff, sunkbd->reset will stay -1. */ if (sunkbd->reset <= -1) { /* If cp[i] is 0xff, sunkbd->reset will stay -1. */
sunkbd->reset = data; /* The keyboard sends 0xff 0xff 0xID on powerup */ sunkbd->reset = data; /* The keyboard sends 0xff 0xff 0xID on powerup */
return; goto out;
} }
if (sunkbd->layout == -1) { if (sunkbd->layout == -1) {
sunkbd->layout = data; sunkbd->layout = data;
return; goto out;
} }
switch (data) { switch (data) {
...@@ -108,14 +109,14 @@ static void sunkbd_interrupt(struct serio *serio, unsigned char data, unsigned i ...@@ -108,14 +109,14 @@ static void sunkbd_interrupt(struct serio *serio, unsigned char data, unsigned i
case SUNKBD_RET_RESET: case SUNKBD_RET_RESET:
schedule_work(&sunkbd->tq); schedule_work(&sunkbd->tq);
sunkbd->reset = -1; sunkbd->reset = -1;
return; break;
case SUNKBD_RET_LAYOUT: case SUNKBD_RET_LAYOUT:
sunkbd->layout = -1; sunkbd->layout = -1;
return; break;
case SUNKBD_RET_ALLUP: /* All keys released */ case SUNKBD_RET_ALLUP: /* All keys released */
return; break;
default: default:
if (sunkbd->keycode[data & SUNKBD_KEY]) { if (sunkbd->keycode[data & SUNKBD_KEY]) {
...@@ -127,6 +128,8 @@ static void sunkbd_interrupt(struct serio *serio, unsigned char data, unsigned i ...@@ -127,6 +128,8 @@ static void sunkbd_interrupt(struct serio *serio, unsigned char data, unsigned i
data & SUNKBD_KEY, data & SUNKBD_RELEASE ? "released" : "pressed"); data & SUNKBD_KEY, data & SUNKBD_RELEASE ? "released" : "pressed");
} }
} }
out:
return IRQ_HANDLED;
} }
/* /*
......
...@@ -63,14 +63,15 @@ struct xtkbd { ...@@ -63,14 +63,15 @@ struct xtkbd {
char phys[32]; char phys[32];
}; };
void xtkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) irqreturn_t 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;
switch (data) { switch (data) {
case XTKBD_EMUL0: case XTKBD_EMUL0:
case XTKBD_EMUL1: case XTKBD_EMUL1:
return; break;
default: default:
if (xtkbd->keycode[data & XTKBD_KEY]) { if (xtkbd->keycode[data & XTKBD_KEY]) {
...@@ -81,7 +82,8 @@ void xtkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags ...@@ -81,7 +82,8 @@ void xtkbd_interrupt(struct serio *serio, unsigned char data, unsigned int flags
printk(KERN_WARNING "xtkbd.c: Unknown key (scancode %#x) %s.\n", printk(KERN_WARNING "xtkbd.c: Unknown key (scancode %#x) %s.\n",
data & XTKBD_KEY, data & XTKBD_RELEASE ? "released" : "pressed"); data & XTKBD_KEY, data & XTKBD_RELEASE ? "released" : "pressed");
} }
} }
return IRQ_HANDLED;
} }
void xtkbd_connect(struct serio *serio, struct serio_dev *dev) void xtkbd_connect(struct serio *serio, struct serio_dev *dev)
......
...@@ -85,7 +85,7 @@ MODULE_PARM(inport_irq, "i"); ...@@ -85,7 +85,7 @@ MODULE_PARM(inport_irq, "i");
static int inport_irq = INPORT_IRQ; static int inport_irq = INPORT_IRQ;
static int inport_used = 0; static int inport_used = 0;
static void inport_interrupt(int irq, void *dev_id, struct pt_regs *regs); static irqreturn_t inport_interrupt(int irq, void *dev_id, struct pt_regs *regs);
static int inport_open(struct input_dev *dev) static int inport_open(struct input_dev *dev)
{ {
...@@ -124,7 +124,7 @@ static struct input_dev inport_dev = { ...@@ -124,7 +124,7 @@ static struct input_dev inport_dev = {
}, },
}; };
static void inport_interrupt(int irq, void *dev_id, struct pt_regs *regs) static irqreturn_t inport_interrupt(int irq, void *dev_id, struct pt_regs *regs)
{ {
unsigned char buttons; unsigned char buttons;
...@@ -150,6 +150,7 @@ static void inport_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -150,6 +150,7 @@ static void inport_interrupt(int irq, void *dev_id, struct pt_regs *regs)
outb(INPORT_MODE_IRQ | INPORT_MODE_BASE, INPORT_DATA_PORT); outb(INPORT_MODE_IRQ | INPORT_MODE_BASE, INPORT_DATA_PORT);
input_sync(&inport_dev); input_sync(&inport_dev);
return IRQ_HANDLED;
} }
#ifndef MODULE #ifndef MODULE
......
...@@ -75,7 +75,7 @@ MODULE_PARM(logibm_irq, "i"); ...@@ -75,7 +75,7 @@ MODULE_PARM(logibm_irq, "i");
static int logibm_irq = LOGIBM_IRQ; static int logibm_irq = LOGIBM_IRQ;
static int logibm_used = 0; static int logibm_used = 0;
static void logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs); static irqreturn_t logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs);
static int logibm_open(struct input_dev *dev) static int logibm_open(struct input_dev *dev)
{ {
...@@ -114,7 +114,7 @@ static struct input_dev logibm_dev = { ...@@ -114,7 +114,7 @@ static struct input_dev logibm_dev = {
}, },
}; };
static void logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs) static irqreturn_t logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs)
{ {
char dx, dy; char dx, dy;
unsigned char buttons; unsigned char buttons;
...@@ -139,6 +139,7 @@ static void logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs) ...@@ -139,6 +139,7 @@ static void logibm_interrupt(int irq, void *dev_id, struct pt_regs *regs)
input_sync(&logibm_dev); input_sync(&logibm_dev);
outb(LOGIBM_ENABLE_IRQ, LOGIBM_CONTROL_PORT); outb(LOGIBM_ENABLE_IRQ, LOGIBM_CONTROL_PORT);
return IRQ_HANDLED;
} }
#ifndef MODULE #ifndef MODULE
......
...@@ -60,7 +60,7 @@ static int pc110pad_used; ...@@ -60,7 +60,7 @@ static int pc110pad_used;
static char *pc110pad_name = "IBM PC110 TouchPad"; static char *pc110pad_name = "IBM PC110 TouchPad";
static char *pc110pad_phys = "isa15e0/input0"; static char *pc110pad_phys = "isa15e0/input0";
static void pc110pad_interrupt(int irq, void *ptr, struct pt_regs *regs) static irqreturn_t pc110pad_interrupt(int irq, void *ptr, struct pt_regs *regs)
{ {
int value = inb_p(pc110pad_io); int value = inb_p(pc110pad_io);
int handshake = inb_p(pc110pad_io + 2); int handshake = inb_p(pc110pad_io + 2);
...@@ -83,6 +83,7 @@ static void pc110pad_interrupt(int irq, void *ptr, struct pt_regs *regs) ...@@ -83,6 +83,7 @@ static void pc110pad_interrupt(int irq, void *ptr, struct pt_regs *regs)
input_sync(&pc110pad_dev); input_sync(&pc110pad_dev);
pc110pad_count = 0; pc110pad_count = 0;
return IRQ_HANDLED;
} }
static void pc110pad_close(struct input_dev *dev) static void pc110pad_close(struct input_dev *dev)
......
...@@ -167,7 +167,8 @@ static void psmouse_process_packet(struct psmouse *psmouse, struct pt_regs *regs ...@@ -167,7 +167,8 @@ static void psmouse_process_packet(struct psmouse *psmouse, struct pt_regs *regs
* 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, struct pt_regs *regs) static irqreturn_t 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;
...@@ -186,12 +187,12 @@ static void psmouse_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -186,12 +187,12 @@ static void psmouse_interrupt(struct serio *serio, unsigned char data, unsigned
break; break;
} }
psmouse->acking = 0; psmouse->acking = 0;
return; goto out;
} }
if (psmouse->cmdcnt) { if (psmouse->cmdcnt) {
psmouse->cmdbuf[--psmouse->cmdcnt] = data; psmouse->cmdbuf[--psmouse->cmdcnt] = data;
return; goto out;
} }
if (psmouse->pktcnt && time_after(jiffies, psmouse->last + HZ/2)) { if (psmouse->pktcnt && time_after(jiffies, psmouse->last + HZ/2)) {
...@@ -205,13 +206,15 @@ static void psmouse_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -205,13 +206,15 @@ static void psmouse_interrupt(struct serio *serio, unsigned char data, unsigned
if (psmouse->pktcnt == 3 + (psmouse->type >= PSMOUSE_GENPS)) { if (psmouse->pktcnt == 3 + (psmouse->type >= PSMOUSE_GENPS)) {
psmouse_process_packet(psmouse, regs); psmouse_process_packet(psmouse, regs);
psmouse->pktcnt = 0; psmouse->pktcnt = 0;
return; goto out;
} }
if (psmouse->pktcnt == 1 && psmouse->packet[0] == PSMOUSE_RET_BAT) { if (psmouse->pktcnt == 1 && psmouse->packet[0] == PSMOUSE_RET_BAT) {
serio_rescan(serio); serio_rescan(serio);
return; goto out;
} }
out:
return IRQ_HANDLED;
} }
/* /*
......
...@@ -204,7 +204,8 @@ static void sermouse_process_ms(struct sermouse *sermouse, signed char data, str ...@@ -204,7 +204,8 @@ static void sermouse_process_ms(struct sermouse *sermouse, signed char data, str
* 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, struct pt_regs *regs) static irqreturn_t 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;
...@@ -215,6 +216,7 @@ static void sermouse_interrupt(struct serio *serio, unsigned char data, unsigned ...@@ -215,6 +216,7 @@ static void sermouse_interrupt(struct serio *serio, unsigned char data, unsigned
sermouse_process_ms(sermouse, data, regs); sermouse_process_ms(sermouse, data, regs);
else else
sermouse_process_msc(sermouse, data, regs); sermouse_process_msc(sermouse, data, regs);
return IRQ_HANDLED;
} }
/* /*
......
...@@ -64,7 +64,7 @@ static char ct82c710_phys[16]; ...@@ -64,7 +64,7 @@ static char ct82c710_phys[16];
static int ct82c710_data; static int ct82c710_data;
static int ct82c710_status; static int ct82c710_status;
static void ct82c710_interrupt(int cpl, void *dev_id, struct pt_regs * regs); static irqreturn_t ct82c710_interrupt(int cpl, void *dev_id, struct pt_regs * regs);
/* /*
* Wait for device to send output char and flush any input char. * Wait for device to send output char and flush any input char.
...@@ -154,9 +154,9 @@ static struct serio ct82c710_port = ...@@ -154,9 +154,9 @@ static struct serio ct82c710_port =
* is waiting in the 82C710. * is waiting in the 82C710.
*/ */
static void ct82c710_interrupt(int cpl, void *dev_id, struct pt_regs * regs) static irqreturn_t ct82c710_interrupt(int cpl, void *dev_id, struct pt_regs * regs)
{ {
serio_interrupt(&ct82c710_port, inb(ct82c710_data), 0, regs); return serio_interrupt(&ct82c710_port, inb(ct82c710_data), 0, regs);
} }
/* /*
......
...@@ -135,13 +135,20 @@ void serio_rescan(struct serio *serio) ...@@ -135,13 +135,20 @@ 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, struct pt_regs *regs) irqreturn_t serio_interrupt(struct serio *serio,
{ unsigned char data, unsigned int flags, struct pt_regs *regs)
if (serio->dev && serio->dev->interrupt) {
serio->dev->interrupt(serio, data, flags, regs); irqreturn_t ret = IRQ_NONE;
else
if (!flags) if (serio->dev && serio->dev->interrupt) {
ret = serio->dev->interrupt(serio, data, flags, regs);
} else {
if (!flags) {
serio_rescan(serio); serio_rescan(serio);
ret = IRQ_HANDLED;
}
}
return ret;
} }
void serio_register_port(struct serio *serio) void serio_register_port(struct serio *serio)
......
...@@ -78,7 +78,8 @@ static void gunze_process_packet(struct gunze* gunze, struct pt_regs *regs) ...@@ -78,7 +78,8 @@ static void gunze_process_packet(struct gunze* gunze, struct pt_regs *regs)
input_sync(dev); input_sync(dev);
} }
static void gunze_interrupt(struct serio *serio, unsigned char data, unsigned int flags, struct pt_regs *regs) static irqreturn_t 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;
...@@ -88,7 +89,8 @@ static void gunze_interrupt(struct serio *serio, unsigned char data, unsigned in ...@@ -88,7 +89,8 @@ static void gunze_interrupt(struct serio *serio, unsigned char data, unsigned in
} else { } else {
if (gunze->idx < GUNZE_MAX_LENGTH) if (gunze->idx < GUNZE_MAX_LENGTH)
gunze->data[gunze->idx++] = data; gunze->data[gunze->idx++] = data;
} }
return IRQ_HANDLED;
} }
/* /*
......
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
*/ */
#include <linux/ioctl.h> #include <linux/ioctl.h>
#include <linux/interrupt.h>
#define SPIOCSTYPE _IOW('q', 0x01, unsigned long) #define SPIOCSTYPE _IOW('q', 0x01, unsigned long)
...@@ -50,7 +51,8 @@ struct serio_dev { ...@@ -50,7 +51,8 @@ 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, struct pt_regs *); irqreturn_t (*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 *);
...@@ -61,7 +63,7 @@ struct serio_dev { ...@@ -61,7 +63,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, struct pt_regs *regs); irqreturn_t 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);
......
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