3  * BRIEF MODULE DESCRIPTION
 
   4  *      Qtronix 990P infrared keyboard driver.
 
   7  * Copyright 2001 MontaVista Software Inc.
 
   8  * Author: MontaVista Software, Inc.
 
   9  *              ppopov@mvista.com or source@mvista.com
 
  12  *  The bottom portion of this driver was take from 
 
  13  *  pc_keyb.c  Please see that file for copyrights.
 
  15  *  This program is free software; you can redistribute  it and/or modify it
 
  16  *  under  the terms of  the GNU General  Public License as published by the
 
  17  *  Free Software Foundation;  either version 2 of the  License, or (at your
 
  18  *  option) any later version.
 
  20  *  THIS  SOFTWARE  IS PROVIDED   ``AS  IS'' AND   ANY  EXPRESS OR IMPLIED
 
  21  *  WARRANTIES,   INCLUDING, BUT NOT  LIMITED  TO, THE IMPLIED WARRANTIES OF
 
  22  *  MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN
 
  23  *  NO  EVENT  SHALL   THE AUTHOR  BE    LIABLE FOR ANY   DIRECT, INDIRECT,
 
  24  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 
  25  *  NOT LIMITED   TO, PROCUREMENT OF  SUBSTITUTE GOODS  OR SERVICES; LOSS OF
 
  26  *  USE, DATA,  OR PROFITS; OR  BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
 
  27  *  ANY THEORY OF LIABILITY, WHETHER IN  CONTRACT, STRICT LIABILITY, OR TORT
 
  28  *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 
  29  *  THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
  31  *  You should have received a copy of the  GNU General Public License along
 
  32  *  with this program; if not, write  to the Free Software Foundation, Inc.,
 
  33  *  675 Mass Ave, Cambridge, MA 02139, USA.
 
  36 #include <linux/config.h>
 
  41  *      This driver has only been tested with the Consumer IR
 
  42  *      port of the ITE 8172 system controller.
 
  44  *      You do not need this driver if you are using the ps/2 or
 
  45  *      USB adapter that the keyboard ships with.  You only need 
 
  46  *      this driver if your board has a IR port and the keyboard
 
  47  *      data is being sent directly to the IR.  In that case,
 
  48  *      you also need some low-level IR support. See it8172_cir.c.
 
  52 #ifdef CONFIG_QTRONIX_KEYBOARD
 
  54 #include <linux/module.h>
 
  55 #include <linux/types.h>
 
  56 #include <linux/pci.h>
 
  57 #include <linux/kernel.h>
 
  59 #include <asm/it8172/it8172.h>
 
  60 #include <asm/it8172/it8172_int.h>
 
  61 #include <asm/it8172/it8172_cir.h>
 
  63 #include <linux/spinlock.h>
 
  64 #include <linux/sched.h>
 
  65 #include <linux/interrupt.h>
 
  66 #include <linux/tty.h>
 
  68 #include <linux/signal.h>
 
  69 #include <linux/init.h>
 
  70 #include <linux/kbd_ll.h>
 
  71 #include <linux/delay.h>
 
  72 #include <linux/poll.h>
 
  73 #include <linux/miscdevice.h>
 
  74 #include <linux/slab.h>
 
  75 #include <linux/kbd_kern.h>
 
  76 #include <linux/smp_lock.h>
 
  78 #include <linux/pc_keyb.h>
 
  80 #include <asm/keyboard.h>
 
  81 #include <linux/bitops.h>
 
  82 #include <asm/uaccess.h>
 
  84 #include <asm/system.h>
 
  89 #define KBD_CIR_PORT 0
 
  90 #define AUX_RECONNECT 170 /* scancode when ps2 device is plugged (back) in */
 
  92 static int data_index;
 
  94 static unsigned char kbdbytes[5];
 
  95 static unsigned char cir_data[32]; /* we only need 16 chars */
 
  97 static void kbd_int_handler(int irq, void *dev_id, struct pt_regs *regs);
 
  98 static int handle_data(unsigned char *p_data);
 
  99 static inline void handle_mouse_event(unsigned char scancode);
 
 100 static inline void handle_keyboard_event(unsigned char scancode, int down);
 
 101 static int __init psaux_init(void);
 
 103 static struct aux_queue *queue; /* Mouse data buffer. */
 
 104 static int aux_count = 0;
 
 107  * Keys accessed through the 'Fn' key
 
 108  * The Fn key does not produce a key-up sequence. So, the first
 
 109  * time the user presses it, it will be key-down event. The key
 
 110  * stays down until the user presses it again.
 
 112 #define NUM_FN_KEYS 56
 
 113 static unsigned char fn_keys[NUM_FN_KEYS] = {
 
 114         0,0,0,0,0,0,0,0,        /* 0 7   */
 
 115         8,9,10,93,0,0,0,0,      /* 8 15  */
 
 116         0,0,0,0,0,0,0,5,        /* 16 23 */
 
 117         6,7,91,0,0,0,0,0,       /* 24 31 */
 
 118         0,0,0,0,0,2,3,4,        /* 32 39 */
 
 119         92,0,0,0,0,0,0,0,       /* 40 47 */
 
 120         0,0,0,0,11,0,94,95        /* 48 55 */
 
 124 void __init init_qtronix_990P_kbd(void)
 
 128         cir = (struct cir_port *)kmalloc(sizeof(struct cir_port), GFP_KERNEL);
 
 130                 printk("Unable to initialize Qtronix keyboard\n");
 
 136          * this should be programmable, somehow by the, by the user.
 
 138         cir->port = KBD_CIR_PORT;
 
 139         cir->baud_rate = 0x1d;
 
 147         retval = request_irq(IT8172_CIR0_IRQ, kbd_int_handler, 
 
 148                         (unsigned long )(SA_INTERRUPT|SA_SHIRQ), 
 
 149                         (const char *)"Qtronix IR Keyboard", (void *)cir);
 
 152                 printk("unable to allocate cir %d irq %d\n", 
 
 153                                 cir->port, IT8172_CIR0_IRQ);
 
 155 #ifdef CONFIG_PSMOUSE
 
 160 static inline unsigned char BitReverse(unsigned short key)
 
 162         unsigned char rkey = 0;
 
 163         rkey |= (key & 0x1) << 7;
 
 164         rkey |= (key & 0x2) << 5;
 
 165         rkey |= (key & 0x4) << 3;
 
 166         rkey |= (key & 0x8) << 1;
 
 167         rkey |= (key & 0x10) >> 1;
 
 168         rkey |= (key & 0x20) >> 3;
 
 169         rkey |= (key & 0x40) >> 5;
 
 170         rkey |= (key & 0x80) >> 7;
 
 176 static inline u_int8_t UpperByte(u_int8_t data)
 
 182 static inline u_int8_t LowerByte(u_int8_t data)
 
 188 int CheckSumOk(u_int8_t byte1, u_int8_t byte2, 
 
 189                 u_int8_t byte3, u_int8_t byte4, u_int8_t byte5)
 
 193         CheckSum = (byte1 & 0x0F) + byte2 + byte3 + byte4 + byte5;
 
 194         if ( LowerByte(UpperByte(CheckSum) + LowerByte(CheckSum)) != UpperByte(byte1) )
 
 201 static void kbd_int_handler(int irq, void *dev_id, struct pt_regs *regs)
 
 203         struct cir_port *cir;
 
 205         unsigned char int_status;
 
 207         cir = (struct cir_port *)dev_id;
 
 208         int_status = get_int_status(cir);
 
 209         if (int_status & 0x4) {
 
 214         while (cir_get_rx_count(cir)) {
 
 216                 cir_data[data_index] = cir_read_data(cir);
 
 218                 if (data_index == 0) {/* expecting first byte */
 
 219                         if (cir_data[data_index] != leading1) {
 
 220                                 //printk("!leading byte %x\n", cir_data[data_index]);
 
 226                 if (data_index == 1) {
 
 227                         if ((cir_data[data_index] & 0xf) != leading2) {
 
 229                                 data_index = 0; /* start over */
 
 235                 if ( (cir_data[data_index] == 0xff)) { /* last byte */
 
 236                         //printk("data_index %d\n", data_index);
 
 239                         for (j=0; j<=data_index; j++) {
 
 240                                 printk("rx_data %d:  %x\n", j, cir_data[j]);
 
 244                         handle_data(cir_data);
 
 247                 else if (data_index>16) {
 
 250                         printk("warning: data_index %d\n", data_index);
 
 251                         for (j=0; j<=data_index; j++) {
 
 252                                 printk("rx_data %d:  %x\n", j, cir_data[j]);
 
 264 #define NUM_KBD_BYTES 5
 
 265 static int handle_data(unsigned char *p_data)
 
 267         u_int32_t bit_bucket;
 
 269         u_int32_t got_bits, next_byte;
 
 272         /* Reorganize the bit stream */
 
 274                 p_data[i] = BitReverse(~p_data[i]);
 
 277          * We've already previously checked that p_data[0]
 
 278          * is equal to leading1 and that (p_data[1] & 0xf)
 
 279          * is equal to leading2. These twelve bits are the
 
 280          * leader code.  We can now throw them away (the 12
 
 281          * bits) and continue parsing the stream.
 
 283         bit_bucket = p_data[1] << 12;
 
 288          * Process four bits at a time
 
 290         for (i=0; i<NUM_KBD_BYTES; i++) {
 
 294                 for (j=0; j<8; j++) /* 8 bits per byte */
 
 297                                 bit_bucket |= (p_data[next_byte++] << (8 - got_bits));
 
 301                         if ((bit_bucket & 0xF000) == 0x8000) { 
 
 302                                 /* Convert 1000b to 1 */
 
 303                                 kbdbytes[i] = 0x80 | (kbdbytes[i] >> 1);
 
 305                                 bit_bucket = bit_bucket << 4;
 
 307                         else if ((bit_bucket & 0xC000) == 0x8000) {
 
 308                                 /* Convert 10b to 0 */
 
 309                                 kbdbytes[i] =  kbdbytes[i] >> 1;
 
 311                                 bit_bucket = bit_bucket << 2;
 
 314                                 /* bad serial stream */
 
 318                         if (next_byte > 16) {
 
 319                                 //printk("error: too many bytes\n");
 
 326         if (!CheckSumOk(kbdbytes[0], kbdbytes[1], 
 
 327                                 kbdbytes[2], kbdbytes[3], kbdbytes[4])) {
 
 328                 //printk("checksum failed\n");
 
 332         if (kbdbytes[1] & 0x08) {
 
 333                 //printk("m: %x %x %x\n", kbdbytes[1], kbdbytes[2], kbdbytes[3]);
 
 334                 handle_mouse_event(kbdbytes[1]);
 
 335                 handle_mouse_event(kbdbytes[2]);
 
 336                 handle_mouse_event(kbdbytes[3]);
 
 339                 if (kbdbytes[2] == 0) down = 1;
 
 342                         printk("down %d\n", kbdbytes[3]);
 
 344                         printk("up %d\n", kbdbytes[3]);
 
 346                 handle_keyboard_event(kbdbytes[3], down);
 
 352 DEFINE_SPINLOCK(kbd_controller_lock);
 
 353 static unsigned char handle_kbd_event(void);
 
 356 int kbd_setkeycode(unsigned int scancode, unsigned int keycode)
 
 358         printk("kbd_setkeycode scancode %x keycode %x\n", scancode, keycode);
 
 362 int kbd_getkeycode(unsigned int scancode)
 
 368 int kbd_translate(unsigned char scancode, unsigned char *keycode,
 
 371         static int prev_scancode = 0;
 
 373         if (scancode == 0x00 || scancode == 0xff) {
 
 379         if (!prev_scancode && scancode == 160) { /* Fn key down */
 
 380                 //printk("Fn key down\n");
 
 384         else if (prev_scancode && scancode == 160) { /* Fn key up */
 
 385                 //printk("Fn key up\n");
 
 391         if (prev_scancode == 160) {
 
 392                 if (scancode <= NUM_FN_KEYS) {
 
 393                         *keycode = fn_keys[scancode];
 
 394                         //printk("fn keycode %d\n", *keycode);
 
 399         else if (scancode <= 127) {
 
 409 char kbd_unexpected_up(unsigned char keycode)
 
 411         //printk("kbd_unexpected_up\n");
 
 415 static unsigned char kbd_exists = 1;
 
 417 static inline void handle_keyboard_event(unsigned char scancode, int down)
 
 420         handle_scancode(scancode, down);
 
 421         tasklet_schedule(&keyboard_tasklet);
 
 425 void kbd_leds(unsigned char leds)
 
 430 void kbd_init_hw(void)
 
 436 static inline void handle_mouse_event(unsigned char scancode)
 
 438         if(scancode == AUX_RECONNECT){
 
 439                 queue->head = queue->tail = 0;  /* Flush input queue */
 
 440         //      __aux_write_ack(AUX_ENABLE_DEV);  /* ping the mouse :) */
 
 445                 int head = queue->head;
 
 447                 queue->buf[head] = scancode;
 
 448                 head = (head + 1) & (AUX_BUF_SIZE-1);
 
 449                 if (head != queue->tail) {
 
 451                         kill_fasync(&queue->fasync, SIGIO, POLL_IN);
 
 452                         wake_up_interruptible(&queue->proc_list);
 
 457 static unsigned char get_from_queue(void)
 
 459         unsigned char result;
 
 462         spin_lock_irqsave(&kbd_controller_lock, flags);
 
 463         result = queue->buf[queue->tail];
 
 464         queue->tail = (queue->tail + 1) & (AUX_BUF_SIZE-1);
 
 465         spin_unlock_irqrestore(&kbd_controller_lock, flags);
 
 470 static inline int queue_empty(void)
 
 472         return queue->head == queue->tail;
 
 475 static int fasync_aux(int fd, struct file *filp, int on)
 
 479         //printk("fasync_aux\n");
 
 480         retval = fasync_helper(fd, filp, on, &queue->fasync);
 
 488  * Random magic cookie for the aux device
 
 490 #define AUX_DEV ((void *)queue)
 
 492 static int release_aux(struct inode * inode, struct file * file)
 
 494         fasync_aux(-1, file, 0);
 
 499 static int open_aux(struct inode * inode, struct file * file)
 
 504         queue->head = queue->tail = 0;          /* Flush input queue */
 
 509  * Put bytes from input queue to buffer.
 
 512 static ssize_t read_aux(struct file * file, char * buffer,
 
 513                         size_t count, loff_t *ppos)
 
 515         DECLARE_WAITQUEUE(wait, current);
 
 520                 if (file->f_flags & O_NONBLOCK)
 
 522                 add_wait_queue(&queue->proc_list, &wait);
 
 524                 set_current_state(TASK_INTERRUPTIBLE);
 
 525                 if (queue_empty() && !signal_pending(current)) {
 
 529                 current->state = TASK_RUNNING;
 
 530                 remove_wait_queue(&queue->proc_list, &wait);
 
 532         while (i > 0 && !queue_empty()) {
 
 533                 c = get_from_queue();
 
 534                 put_user(c, buffer++);
 
 538                 struct inode *inode = file->f_dentry->d_inode;
 
 539                 inode->i_atime = current_fs_time(inode->i_sb);
 
 542         if (signal_pending(current))
 
 548  * Write to the aux device.
 
 551 static ssize_t write_aux(struct file * file, const char * buffer,
 
 552                          size_t count, loff_t *ppos)
 
 555          * The ITE boards this was tested on did not have the
 
 556          * transmit wires connected.
 
 561 static unsigned int aux_poll(struct file *file, poll_table * wait)
 
 563         poll_wait(file, &queue->proc_list, wait);
 
 565                 return POLLIN | POLLRDNORM;
 
 569 struct file_operations psaux_fops = {
 
 574         .release        = release_aux,
 
 575         .fasync         = fasync_aux,
 
 581 static struct miscdevice psaux_mouse = {
 
 582         PSMOUSE_MINOR, "psaux", &psaux_fops
 
 585 static int __init psaux_init(void)
 
 589         retval = misc_register(&psaux_mouse);
 
 593         queue = (struct aux_queue *) kmalloc(sizeof(*queue), GFP_KERNEL);
 
 595                 misc_deregister(&psaux_mouse);
 
 599         memset(queue, 0, sizeof(*queue));
 
 600         queue->head = queue->tail = 0;
 
 601         init_waitqueue_head(&queue->proc_list);
 
 605 module_init(init_qtronix_990P_kbd);