2  *  i8042 keyboard and mouse controller driver for Linux
 
   4  *  Copyright (c) 1999-2004 Vojtech Pavlik
 
   8  * This program is free software; you can redistribute it and/or modify it
 
   9  * under the terms of the GNU General Public License version 2 as published by
 
  10  * the Free Software Foundation.
 
  13 #include <linux/delay.h>
 
  14 #include <linux/module.h>
 
  15 #include <linux/moduleparam.h>
 
  16 #include <linux/interrupt.h>
 
  17 #include <linux/ioport.h>
 
  18 #include <linux/config.h>
 
  19 #include <linux/init.h>
 
  20 #include <linux/serio.h>
 
  21 #include <linux/err.h>
 
  22 #include <linux/rcupdate.h>
 
  23 #include <linux/platform_device.h>
 
  27 MODULE_AUTHOR("Vojtech Pavlik <vojtech@suse.cz>");
 
  28 MODULE_DESCRIPTION("i8042 keyboard and mouse controller driver");
 
  29 MODULE_LICENSE("GPL");
 
  31 static unsigned int i8042_nokbd;
 
  32 module_param_named(nokbd, i8042_nokbd, bool, 0);
 
  33 MODULE_PARM_DESC(nokbd, "Do not probe or use KBD port.");
 
  35 static unsigned int i8042_noaux;
 
  36 module_param_named(noaux, i8042_noaux, bool, 0);
 
  37 MODULE_PARM_DESC(noaux, "Do not probe or use AUX (mouse) port.");
 
  39 static unsigned int i8042_nomux;
 
  40 module_param_named(nomux, i8042_nomux, bool, 0);
 
  41 MODULE_PARM_DESC(nomux, "Do not check whether an active multiplexing conrtoller is present.");
 
  43 static unsigned int i8042_unlock;
 
  44 module_param_named(unlock, i8042_unlock, bool, 0);
 
  45 MODULE_PARM_DESC(unlock, "Ignore keyboard lock.");
 
  47 static unsigned int i8042_reset;
 
  48 module_param_named(reset, i8042_reset, bool, 0);
 
  49 MODULE_PARM_DESC(reset, "Reset controller during init and cleanup.");
 
  51 static unsigned int i8042_direct;
 
  52 module_param_named(direct, i8042_direct, bool, 0);
 
  53 MODULE_PARM_DESC(direct, "Put keyboard port into non-translated mode.");
 
  55 static unsigned int i8042_dumbkbd;
 
  56 module_param_named(dumbkbd, i8042_dumbkbd, bool, 0);
 
  57 MODULE_PARM_DESC(dumbkbd, "Pretend that controller can only read data from keyboard");
 
  59 static unsigned int i8042_noloop;
 
  60 module_param_named(noloop, i8042_noloop, bool, 0);
 
  61 MODULE_PARM_DESC(noloop, "Disable the AUX Loopback command while probing for the AUX port");
 
  63 static unsigned int i8042_blink_frequency = 500;
 
  64 module_param_named(panicblink, i8042_blink_frequency, uint, 0600);
 
  65 MODULE_PARM_DESC(panicblink, "Frequency with which keyboard LEDs should blink when kernel panics");
 
  68 static int i8042_nopnp;
 
  69 module_param_named(nopnp, i8042_nopnp, bool, 0);
 
  70 MODULE_PARM_DESC(nopnp, "Do not use PNP to detect controller settings");
 
  75 static int i8042_debug;
 
  76 module_param_named(debug, i8042_debug, bool, 0600);
 
  77 MODULE_PARM_DESC(debug, "Turn i8042 debugging mode on and off");
 
  80 __obsolete_setup("i8042_noaux");
 
  81 __obsolete_setup("i8042_nomux");
 
  82 __obsolete_setup("i8042_unlock");
 
  83 __obsolete_setup("i8042_reset");
 
  84 __obsolete_setup("i8042_direct");
 
  85 __obsolete_setup("i8042_dumbkbd");
 
  89 static DEFINE_SPINLOCK(i8042_lock);
 
  94         unsigned char disable;
 
 101 #define I8042_KBD_PORT_NO       0
 
 102 #define I8042_AUX_PORT_NO       1
 
 103 #define I8042_MUX_PORT_NO       2
 
 104 #define I8042_NUM_PORTS         (I8042_NUM_MUX_PORTS + 2)
 
 105 static struct i8042_port i8042_ports[I8042_NUM_PORTS] = {
 
 107                 .disable        = I8042_CTR_KBDDIS,
 
 108                 .irqen          = I8042_CTR_KBDINT,
 
 113                 .disable        = I8042_CTR_AUXDIS,
 
 114                 .irqen          = I8042_CTR_AUXINT,
 
 120 static unsigned char i8042_initial_ctr;
 
 121 static unsigned char i8042_ctr;
 
 122 static unsigned char i8042_mux_open;
 
 123 static unsigned char i8042_mux_present;
 
 124 static struct timer_list i8042_timer;
 
 125 static struct platform_device *i8042_platform_device;
 
 129  * Shared IRQ's require a device pointer, but this driver doesn't support
 
 132 #define i8042_request_irq_cookie (&i8042_timer)
 
 134 static irqreturn_t i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs);
 
 137  * The i8042_wait_read() and i8042_wait_write functions wait for the i8042 to
 
 138  * be ready for reading values from it / writing values to it.
 
 139  * Called always with i8042_lock held.
 
 142 static int i8042_wait_read(void)
 
 145         while ((~i8042_read_status() & I8042_STR_OBF) && (i < I8042_CTL_TIMEOUT)) {
 
 149         return -(i == I8042_CTL_TIMEOUT);
 
 152 static int i8042_wait_write(void)
 
 155         while ((i8042_read_status() & I8042_STR_IBF) && (i < I8042_CTL_TIMEOUT)) {
 
 159         return -(i == I8042_CTL_TIMEOUT);
 
 163  * i8042_flush() flushes all data that may be in the keyboard and mouse buffers
 
 164  * of the i8042 down the toilet.
 
 167 static int i8042_flush(void)
 
 170         unsigned char data, str;
 
 173         spin_lock_irqsave(&i8042_lock, flags);
 
 175         while (((str = i8042_read_status()) & I8042_STR_OBF) && (i < I8042_BUFFER_SIZE)) {
 
 177                 data = i8042_read_data();
 
 179                 dbg("%02x <- i8042 (flush, %s)", data,
 
 180                         str & I8042_STR_AUXDATA ? "aux" : "kbd");
 
 183         spin_unlock_irqrestore(&i8042_lock, flags);
 
 189  * i8042_command() executes a command on the i8042. It also sends the input
 
 190  * parameter(s) of the commands to it, and receives the output value(s). The
 
 191  * parameters are to be stored in the param array, and the output is placed
 
 192  * into the same array. The number of the parameters and output values is
 
 193  * encoded in bits 8-11 of the command number.
 
 196 static int i8042_command(unsigned char *param, int command)
 
 199         int i, retval, auxerr = 0;
 
 201         if (i8042_noloop && command == I8042_CMD_AUX_LOOP)
 
 204         spin_lock_irqsave(&i8042_lock, flags);
 
 206         if ((retval = i8042_wait_write()))
 
 209         dbg("%02x -> i8042 (command)", command & 0xff);
 
 210         i8042_write_command(command & 0xff);
 
 212         for (i = 0; i < ((command >> 12) & 0xf); i++) {
 
 213                 if ((retval = i8042_wait_write()))
 
 215                 dbg("%02x -> i8042 (parameter)", param[i]);
 
 216                 i8042_write_data(param[i]);
 
 219         for (i = 0; i < ((command >> 8) & 0xf); i++) {
 
 220                 if ((retval = i8042_wait_read()))
 
 223                 if (command == I8042_CMD_AUX_LOOP &&
 
 224                     !(i8042_read_status() & I8042_STR_AUXDATA)) {
 
 225                         retval = auxerr = -1;
 
 229                 param[i] = i8042_read_data();
 
 230                 dbg("%02x <- i8042 (return)", param[i]);
 
 234                 dbg("     -- i8042 (%s)", auxerr ? "auxerr" : "timeout");
 
 237         spin_unlock_irqrestore(&i8042_lock, flags);
 
 242  * i8042_kbd_write() sends a byte out through the keyboard interface.
 
 245 static int i8042_kbd_write(struct serio *port, unsigned char c)
 
 250         spin_lock_irqsave(&i8042_lock, flags);
 
 252         if(!(retval = i8042_wait_write())) {
 
 253                 dbg("%02x -> i8042 (kbd-data)", c);
 
 257         spin_unlock_irqrestore(&i8042_lock, flags);
 
 263  * i8042_aux_write() sends a byte out through the aux interface.
 
 266 static int i8042_aux_write(struct serio *serio, unsigned char c)
 
 268         struct i8042_port *port = serio->port_data;
 
 276                 retval = i8042_command(&c, I8042_CMD_AUX_SEND);
 
 278                 retval = i8042_command(&c, I8042_CMD_MUX_SEND + port->mux);
 
 281  * Make sure the interrupt happens and the character is received even
 
 282  * in the case the IRQ isn't wired, so that we can receive further
 
 286         i8042_interrupt(0, NULL, NULL);
 
 291  * i8042_activate_port() enables port on a chip.
 
 294 static int i8042_activate_port(struct i8042_port *port)
 
 302          * Enable port again here because it is disabled if we are
 
 303          * resuming (normally it is enabled already).
 
 305         i8042_ctr &= ~port->disable;
 
 307         i8042_ctr |= port->irqen;
 
 309         if (i8042_command(&i8042_ctr, I8042_CMD_CTL_WCTR)) {
 
 310                 i8042_ctr &= ~port->irqen;
 
 319  * i8042_open() is called when a port is open by the higher layer.
 
 320  * It allocates the interrupt and calls i8042_enable_port.
 
 323 static int i8042_open(struct serio *serio)
 
 325         struct i8042_port *port = serio->port_data;
 
 328                 if (i8042_mux_open++)
 
 331         if (request_irq(port->irq, i8042_interrupt,
 
 332                         SA_SHIRQ, "i8042", i8042_request_irq_cookie)) {
 
 333                 printk(KERN_ERR "i8042.c: Can't get irq %d for %s, unregistering the port.\n", port->irq, port->name);
 
 337         if (i8042_activate_port(port)) {
 
 338                 printk(KERN_ERR "i8042.c: Can't activate %s, unregistering the port\n", port->name);
 
 342         i8042_interrupt(0, NULL, NULL);
 
 347         free_irq(port->irq, i8042_request_irq_cookie);
 
 350         serio_unregister_port_delayed(serio);
 
 356  * i8042_close() frees the interrupt, so that it can possibly be used
 
 357  * by another driver. We never know - if the user doesn't have a mouse,
 
 358  * the BIOS could have used the AUX interrupt for PCI.
 
 361 static void i8042_close(struct serio *serio)
 
 363         struct i8042_port *port = serio->port_data;
 
 366                 if (--i8042_mux_open)
 
 369         i8042_ctr &= ~port->irqen;
 
 371         if (i8042_command(&i8042_ctr, I8042_CMD_CTL_WCTR)) {
 
 372                 printk(KERN_WARNING "i8042.c: Can't write CTR while closing %s.\n", port->name);
 
 374  * We still want to continue and free IRQ so if more data keeps coming in
 
 375  * kernel will just ignore the irq.
 
 379         free_irq(port->irq, i8042_request_irq_cookie);
 
 385  * i8042_start() is called by serio core when port is about to finish
 
 386  * registering. It will mark port as existing so i8042_interrupt can
 
 387  * start sending data through it.
 
 389 static int i8042_start(struct serio *serio)
 
 391         struct i8042_port *port = serio->port_data;
 
 399  * i8042_stop() marks serio port as non-existing so i8042_interrupt
 
 400  * will not try to send data to the port that is about to go away.
 
 401  * The function is called by serio core as part of unregister procedure.
 
 403 static void i8042_stop(struct serio *serio)
 
 405         struct i8042_port *port = serio->port_data;
 
 413  * i8042_interrupt() is the most important function in this driver -
 
 414  * it handles the interrupts from the i8042, and sends incoming bytes
 
 415  * to the upper layers.
 
 418 static irqreturn_t i8042_interrupt(int irq, void *dev_id, struct pt_regs *regs)
 
 420         struct i8042_port *port;
 
 422         unsigned char str, data;
 
 424         unsigned int port_no;
 
 427         mod_timer(&i8042_timer, jiffies + I8042_POLL_PERIOD);
 
 429         spin_lock_irqsave(&i8042_lock, flags);
 
 430         str = i8042_read_status();
 
 431         if (unlikely(~str & I8042_STR_OBF)) {
 
 432                 spin_unlock_irqrestore(&i8042_lock, flags);
 
 433                 if (irq) dbg("Interrupt %d, without any data", irq);
 
 437         data = i8042_read_data();
 
 438         spin_unlock_irqrestore(&i8042_lock, flags);
 
 440         if (i8042_mux_present && (str & I8042_STR_AUXDATA)) {
 
 441                 static unsigned long last_transmit;
 
 442                 static unsigned char last_str;
 
 445                 if (str & I8042_STR_MUXERR) {
 
 446                         dbg("MUX error, status is %02x, data is %02x", str, data);
 
 450  * When MUXERR condition is signalled the data register can only contain
 
 451  * 0xfd, 0xfe or 0xff if implementation follows the spec. Unfortunately
 
 452  * it is not always the case. Some KBC just get confused which port the
 
 453  * data came from and signal error leaving the data intact. They _do not_
 
 454  * revert to legacy mode (actually I've never seen KBC reverting to legacy
 
 455  * mode yet, when we see one we'll add proper handling).
 
 456  * Anyway, we will assume that the data came from the same serio last byte
 
 457  * was transmitted (if transmission happened not too long ago).
 
 459                                         if (time_before(jiffies, last_transmit + HZ/10)) {
 
 463                                         /* fall through - report timeout */
 
 465                                 case 0xfe: dfl = SERIO_TIMEOUT; data = 0xfe; break;
 
 466                                 case 0xff: dfl = SERIO_PARITY;  data = 0xfe; break;
 
 470                 port_no = I8042_MUX_PORT_NO + ((str >> 6) & 3);
 
 472                 last_transmit = jiffies;
 
 475                 dfl = ((str & I8042_STR_PARITY) ? SERIO_PARITY : 0) |
 
 476                       ((str & I8042_STR_TIMEOUT) ? SERIO_TIMEOUT : 0);
 
 478                 port_no = (str & I8042_STR_AUXDATA) ?
 
 479                                 I8042_AUX_PORT_NO : I8042_KBD_PORT_NO;
 
 482         port = &i8042_ports[port_no];
 
 484         dbg("%02x <- i8042 (interrupt, %s, %d%s%s)",
 
 485             data, port->name, irq,
 
 486             dfl & SERIO_PARITY ? ", bad parity" : "",
 
 487             dfl & SERIO_TIMEOUT ? ", timeout" : "");
 
 489         if (likely(port->exists))
 
 490                 serio_interrupt(port->serio, data, dfl, regs);
 
 494         return IRQ_RETVAL(ret);
 
 498  * i8042_set_mux_mode checks whether the controller has an active
 
 499  * multiplexor and puts the chip into Multiplexed (1) or Legacy (0) mode.
 
 502 static int i8042_set_mux_mode(unsigned int mode, unsigned char *mux_version)
 
 507  * Get rid of bytes in the queue.
 
 513  * Internal loopback test - send three bytes, they should come back from the
 
 514  * mouse interface, the last should be version. Note that we negate mouseport
 
 515  * command responses for the i8042_check_aux() routine.
 
 519         if (i8042_command(¶m, I8042_CMD_AUX_LOOP) || param != 0xf0)
 
 521         param = mode ? 0x56 : 0xf6;
 
 522         if (i8042_command(¶m, I8042_CMD_AUX_LOOP) || param != (mode ? 0x56 : 0xf6))
 
 524         param = mode ? 0xa4 : 0xa5;
 
 525         if (i8042_command(¶m, I8042_CMD_AUX_LOOP) || param == (mode ? 0xa4 : 0xa5))
 
 529                 *mux_version = param;
 
 536  * i8042_enable_mux_ports enables 4 individual AUX ports after
 
 537  * the controller has been switched into Multiplexed mode
 
 540 static int i8042_enable_mux_ports(void)
 
 545  * Disable all muxed ports by disabling AUX.
 
 548         i8042_ctr |= I8042_CTR_AUXDIS;
 
 549         i8042_ctr &= ~I8042_CTR_AUXINT;
 
 551         if (i8042_command(&i8042_ctr, I8042_CMD_CTL_WCTR)) {
 
 552                 printk(KERN_ERR "i8042.c: Failed to disable AUX port, can't use MUX.\n");
 
 557  * Enable all muxed ports.
 
 560         for (i = 0; i < I8042_NUM_MUX_PORTS; i++) {
 
 561                 i8042_command(¶m, I8042_CMD_MUX_PFX + i);
 
 562                 i8042_command(¶m, I8042_CMD_AUX_ENABLE);
 
 570  * i8042_check_mux() checks whether the controller supports the PS/2 Active
 
 571  * Multiplexing specification by Synaptics, Phoenix, Insyde and
 
 575 static int __init i8042_check_mux(void)
 
 577         unsigned char mux_version;
 
 579         if (i8042_set_mux_mode(1, &mux_version))
 
 582         /* Workaround for interference with USB Legacy emulation */
 
 583         /* that causes a v10.12 MUX to be found. */
 
 584         if (mux_version == 0xAC)
 
 587         printk(KERN_INFO "i8042.c: Detected active multiplexing controller, rev %d.%d.\n",
 
 588                 (mux_version >> 4) & 0xf, mux_version & 0xf);
 
 590         if (i8042_enable_mux_ports())
 
 593         i8042_mux_present = 1;
 
 599  * i8042_check_aux() applies as much paranoia as it can at detecting
 
 600  * the presence of an AUX interface.
 
 603 static int __init i8042_check_aux(void)
 
 606         static int i8042_check_aux_cookie;
 
 609  * Check if AUX irq is available. If it isn't, then there is no point
 
 610  * in trying to detect AUX presence.
 
 613         if (request_irq(i8042_ports[I8042_AUX_PORT_NO].irq, i8042_interrupt,
 
 614                         SA_SHIRQ, "i8042", &i8042_check_aux_cookie))
 
 616         free_irq(i8042_ports[I8042_AUX_PORT_NO].irq, &i8042_check_aux_cookie);
 
 619  * Get rid of bytes in the queue.
 
 625  * Internal loopback test - filters out AT-type i8042's. Unfortunately
 
 626  * SiS screwed up and their 5597 doesn't support the LOOP command even
 
 627  * though it has an AUX port.
 
 631         if (i8042_command(¶m, I8042_CMD_AUX_LOOP) || param != 0x5a) {
 
 634  * External connection test - filters out AT-soldered PS/2 i8042's
 
 635  * 0x00 - no error, 0x01-0x03 - clock/data stuck, 0xff - general error
 
 636  * 0xfa - no error on some notebooks which ignore the spec
 
 637  * Because it's common for chipsets to return error on perfectly functioning
 
 638  * AUX ports, we test for this only when the LOOP command failed.
 
 641                 if (i8042_command(¶m, I8042_CMD_AUX_TEST)
 
 642                         || (param && param != 0xfa && param != 0xff))
 
 647  * Bit assignment test - filters out PS/2 i8042's in AT mode
 
 650         if (i8042_command(¶m, I8042_CMD_AUX_DISABLE))
 
 652         if (i8042_command(¶m, I8042_CMD_CTL_RCTR) || (~param & I8042_CTR_AUXDIS)) {
 
 653                 printk(KERN_WARNING "Failed to disable AUX port, but continuing anyway... Is this a SiS?\n");
 
 654                 printk(KERN_WARNING "If AUX port is really absent please use the 'i8042.noaux' option.\n");
 
 657         if (i8042_command(¶m, I8042_CMD_AUX_ENABLE))
 
 659         if (i8042_command(¶m, I8042_CMD_CTL_RCTR) || (param & I8042_CTR_AUXDIS))
 
 663  * Disable the interface.
 
 666         i8042_ctr |= I8042_CTR_AUXDIS;
 
 667         i8042_ctr &= ~I8042_CTR_AUXINT;
 
 669         if (i8042_command(&i8042_ctr, I8042_CMD_CTL_WCTR))
 
 677  * i8042_port_register() marks the device as existing,
 
 678  * registers it, and reports to the user.
 
 681 static int __init i8042_port_register(struct i8042_port *port)
 
 683         i8042_ctr &= ~port->disable;
 
 685         if (i8042_command(&i8042_ctr, I8042_CMD_CTL_WCTR)) {
 
 686                 printk(KERN_WARNING "i8042.c: Can't write CTR while registering.\n");
 
 689                 i8042_ctr |= port->disable;
 
 693         printk(KERN_INFO "serio: i8042 %s port at %#lx,%#lx irq %d\n",
 
 695                (unsigned long) I8042_DATA_REG,
 
 696                (unsigned long) I8042_COMMAND_REG,
 
 699         serio_register_port(port->serio);
 
 705 static void i8042_timer_func(unsigned long data)
 
 707         i8042_interrupt(0, NULL, NULL);
 
 710 static int i8042_ctl_test(void)
 
 717         if (i8042_command(¶m, I8042_CMD_CTL_TEST)) {
 
 718                 printk(KERN_ERR "i8042.c: i8042 controller self test timeout.\n");
 
 722         if (param != I8042_RET_CTL_TEST) {
 
 723                 printk(KERN_ERR "i8042.c: i8042 controller selftest failed. (%#x != %#x)\n",
 
 724                          param, I8042_RET_CTL_TEST);
 
 732  * i8042_controller init initializes the i8042 controller, and,
 
 733  * most importantly, sets it into non-xlated mode if that's
 
 737 static int i8042_controller_init(void)
 
 742  * Test the i8042. We need to know if it thinks it's working correctly
 
 743  * before doing anything else.
 
 746         if (i8042_flush() == I8042_BUFFER_SIZE) {
 
 747                 printk(KERN_ERR "i8042.c: No controller found.\n");
 
 751         if (i8042_ctl_test())
 
 755  * Save the CTR for restoral on unload / reboot.
 
 758         if (i8042_command(&i8042_ctr, I8042_CMD_CTL_RCTR)) {
 
 759                 printk(KERN_ERR "i8042.c: Can't read CTR while initializing i8042.\n");
 
 763         i8042_initial_ctr = i8042_ctr;
 
 766  * Disable the keyboard interface and interrupt.
 
 769         i8042_ctr |= I8042_CTR_KBDDIS;
 
 770         i8042_ctr &= ~I8042_CTR_KBDINT;
 
 776         spin_lock_irqsave(&i8042_lock, flags);
 
 777         if (~i8042_read_status() & I8042_STR_KEYLOCK) {
 
 779                         i8042_ctr |= I8042_CTR_IGNKEYLOCK;
 
 781                         printk(KERN_WARNING "i8042.c: Warning: Keylock active.\n");
 
 783         spin_unlock_irqrestore(&i8042_lock, flags);
 
 786  * If the chip is configured into nontranslated mode by the BIOS, don't
 
 787  * bother enabling translating and be happy.
 
 790         if (~i8042_ctr & I8042_CTR_XLATE)
 
 794  * Set nontranslated mode for the kbd interface if requested by an option.
 
 795  * After this the kbd interface becomes a simple serial in/out, like the aux
 
 796  * interface is. We don't do this by default, since it can confuse notebook
 
 801                 i8042_ctr &= ~I8042_CTR_XLATE;
 
 807         if (i8042_command(&i8042_ctr, I8042_CMD_CTL_WCTR)) {
 
 808                 printk(KERN_ERR "i8042.c: Can't write CTR while initializing i8042.\n");
 
 817  * Reset the controller.
 
 819 static void i8042_controller_reset(void)
 
 822  * Reset the controller if requested.
 
 828  * Disable MUX mode if present.
 
 831         if (i8042_mux_present)
 
 832                 i8042_set_mux_mode(0, NULL);
 
 835  * Restore the original control register setting.
 
 838         i8042_ctr = i8042_initial_ctr;
 
 840         if (i8042_command(&i8042_ctr, I8042_CMD_CTL_WCTR))
 
 841                 printk(KERN_WARNING "i8042.c: Can't restore CTR.\n");
 
 846  * Here we try to reset everything back to a state in which the BIOS will be
 
 847  * able to talk to the hardware when rebooting.
 
 850 static void i8042_controller_cleanup(void)
 
 857  * Reset anything that is connected to the ports.
 
 860         for (i = 0; i < I8042_NUM_PORTS; i++)
 
 861                 if (i8042_ports[i].exists)
 
 862                         serio_cleanup(i8042_ports[i].serio);
 
 864         i8042_controller_reset();
 
 869  * i8042_panic_blink() will flash the keyboard LEDs and is called when
 
 870  * kernel panics. Flashing LEDs is useful for users running X who may
 
 871  * not see the console and will help distingushing panics from "real"
 
 874  * Note that DELAY has a limit of 10ms so we will not get stuck here
 
 875  * waiting for KBC to free up even if KBD interrupt is off
 
 878 #define DELAY do { mdelay(1); if (++delay > 10) return delay; } while(0)
 
 880 static long i8042_panic_blink(long count)
 
 883         static long last_blink;
 
 887          * We expect frequency to be about 1/2s. KDB uses about 1s.
 
 888          * Make sure they are different.
 
 890         if (!i8042_blink_frequency)
 
 892         if (count - last_blink < i8042_blink_frequency)
 
 896         while (i8042_read_status() & I8042_STR_IBF)
 
 898         i8042_write_data(0xed); /* set leds */
 
 900         while (i8042_read_status() & I8042_STR_IBF)
 
 903         i8042_write_data(led);
 
 912  * Here we try to restore the original BIOS settings
 
 915 static int i8042_suspend(struct platform_device *dev, pm_message_t state)
 
 917         del_timer_sync(&i8042_timer);
 
 918         i8042_controller_reset();
 
 925  * Here we try to reset everything back to a state in which suspended
 
 928 static int i8042_resume(struct platform_device *dev)
 
 932         if (i8042_ctl_test())
 
 935         if (i8042_command(&i8042_ctr, I8042_CMD_CTL_WCTR)) {
 
 936                 printk(KERN_ERR "i8042: Can't write CTR\n");
 
 940         if (i8042_mux_present)
 
 941                 if (i8042_set_mux_mode(1, NULL) || i8042_enable_mux_ports())
 
 942                         printk(KERN_WARNING "i8042: failed to resume active multiplexor, mouse won't work.\n");
 
 945  * Activate all ports.
 
 948         for (i = 0; i < I8042_NUM_PORTS; i++)
 
 949                 i8042_activate_port(&i8042_ports[i]);
 
 952  * Restart timer (for polling "stuck" data)
 
 954         mod_timer(&i8042_timer, jiffies + I8042_POLL_PERIOD);
 
 956         panic_blink = i8042_panic_blink;
 
 963  * We need to reset the 8042 back to original mode on system shutdown,
 
 964  * because otherwise BIOSes will be confused.
 
 967 static void i8042_shutdown(struct platform_device *dev)
 
 969         i8042_controller_cleanup();
 
 972 static struct platform_driver i8042_driver = {
 
 973         .suspend        = i8042_suspend,
 
 974         .resume         = i8042_resume,
 
 975         .shutdown       = i8042_shutdown,
 
 981 static int __init i8042_create_kbd_port(void)
 
 984         struct i8042_port *port = &i8042_ports[I8042_KBD_PORT_NO];
 
 986         serio = kzalloc(sizeof(struct serio), GFP_KERNEL);
 
 990         serio->id.type          = i8042_direct ? SERIO_8042 : SERIO_8042_XL;
 
 991         serio->write            = i8042_dumbkbd ? NULL : i8042_kbd_write;
 
 992         serio->open             = i8042_open;
 
 993         serio->close            = i8042_close;
 
 994         serio->start            = i8042_start;
 
 995         serio->stop             = i8042_stop;
 
 996         serio->port_data        = port;
 
 997         serio->dev.parent       = &i8042_platform_device->dev;
 
 998         strlcpy(serio->name, "i8042 Kbd Port", sizeof(serio->name));
 
 999         strlcpy(serio->phys, I8042_KBD_PHYS_DESC, sizeof(serio->phys));
 
1001         port->serio = serio;
 
1003         return i8042_port_register(port);
 
1006 static int __init i8042_create_aux_port(void)
 
1008         struct serio *serio;
 
1009         struct i8042_port *port = &i8042_ports[I8042_AUX_PORT_NO];
 
1011         serio = kzalloc(sizeof(struct serio), GFP_KERNEL);
 
1015         serio->id.type          = SERIO_8042;
 
1016         serio->write            = i8042_aux_write;
 
1017         serio->open             = i8042_open;
 
1018         serio->close            = i8042_close;
 
1019         serio->start            = i8042_start;
 
1020         serio->stop             = i8042_stop;
 
1021         serio->port_data        = port;
 
1022         serio->dev.parent       = &i8042_platform_device->dev;
 
1023         strlcpy(serio->name, "i8042 Aux Port", sizeof(serio->name));
 
1024         strlcpy(serio->phys, I8042_AUX_PHYS_DESC, sizeof(serio->phys));
 
1026         port->serio = serio;
 
1028         return i8042_port_register(port);
 
1031 static int __init i8042_create_mux_port(int index)
 
1033         struct serio *serio;
 
1034         struct i8042_port *port = &i8042_ports[I8042_MUX_PORT_NO + index];
 
1036         serio = kzalloc(sizeof(struct serio), GFP_KERNEL);
 
1040         serio->id.type          = SERIO_8042;
 
1041         serio->write            = i8042_aux_write;
 
1042         serio->open             = i8042_open;
 
1043         serio->close            = i8042_close;
 
1044         serio->start            = i8042_start;
 
1045         serio->stop             = i8042_stop;
 
1046         serio->port_data        = port;
 
1047         serio->dev.parent       = &i8042_platform_device->dev;
 
1048         snprintf(serio->name, sizeof(serio->name), "i8042 Aux-%d Port", index);
 
1049         snprintf(serio->phys, sizeof(serio->phys), I8042_MUX_PHYS_DESC, index + 1);
 
1051         *port = i8042_ports[I8042_AUX_PORT_NO];
 
1053         snprintf(port->name, sizeof(port->name), "AUX%d", index);
 
1055         port->serio = serio;
 
1057         return i8042_port_register(port);
 
1060 static int __init i8042_init(void)
 
1062         int i, have_ports = 0;
 
1067         init_timer(&i8042_timer);
 
1068         i8042_timer.function = i8042_timer_func;
 
1070         err = i8042_platform_init();
 
1074         i8042_ports[I8042_AUX_PORT_NO].irq = I8042_AUX_IRQ;
 
1075         i8042_ports[I8042_KBD_PORT_NO].irq = I8042_KBD_IRQ;
 
1077         if (i8042_controller_init()) {
 
1079                 goto err_platform_exit;
 
1082         err = platform_driver_register(&i8042_driver);
 
1084                 goto err_controller_cleanup;
 
1086         i8042_platform_device = platform_device_register_simple("i8042", -1, NULL, 0);
 
1087         if (IS_ERR(i8042_platform_device)) {
 
1088                 err = PTR_ERR(i8042_platform_device);
 
1089                 goto err_unregister_driver;
 
1092         if (!i8042_noaux && !i8042_check_aux()) {
 
1093                 if (!i8042_nomux && !i8042_check_mux()) {
 
1094                         for (i = 0; i < I8042_NUM_MUX_PORTS; i++) {
 
1095                                 err = i8042_create_mux_port(i);
 
1097                                         goto err_unregister_ports;
 
1100                         err = i8042_create_aux_port();
 
1102                                 goto err_unregister_ports;
 
1108                 err = i8042_create_kbd_port();
 
1110                         goto err_unregister_ports;
 
1116                 goto err_unregister_device;
 
1119         mod_timer(&i8042_timer, jiffies + I8042_POLL_PERIOD);
 
1123  err_unregister_ports:
 
1124         for (i = 0; i < I8042_NUM_PORTS; i++)
 
1125                 if (i8042_ports[i].serio)
 
1126                         serio_unregister_port(i8042_ports[i].serio);
 
1127  err_unregister_device:
 
1128         platform_device_unregister(i8042_platform_device);
 
1129  err_unregister_driver:
 
1130         platform_driver_unregister(&i8042_driver);
 
1131  err_controller_cleanup:
 
1132         i8042_controller_cleanup();
 
1134         i8042_platform_exit();
 
1139 static void __exit i8042_exit(void)
 
1143         i8042_controller_cleanup();
 
1145         for (i = 0; i < I8042_NUM_PORTS; i++)
 
1146                 if (i8042_ports[i].exists)
 
1147                         serio_unregister_port(i8042_ports[i].serio);
 
1149         del_timer_sync(&i8042_timer);
 
1151         platform_device_unregister(i8042_platform_device);
 
1152         platform_driver_unregister(&i8042_driver);
 
1154         i8042_platform_exit();
 
1159 module_init(i8042_init);
 
1160 module_exit(i8042_exit);