z8530.c

Go to the documentation of this file.
00001 /*
00002  * Copyright (c) 2006 Martin Decky
00003  * All rights reserved.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  *
00009  * - Redistributions of source code must retain the above copyright
00010  *   notice, this list of conditions and the following disclaimer.
00011  * - Redistributions in binary form must reproduce the above copyright
00012  *   notice, this list of conditions and the following disclaimer in the
00013  *   documentation and/or other materials provided with the distribution.
00014  * - The name of the author may not be used to endorse or promote products
00015  *   derived from this software without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
00018  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
00019  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
00020  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
00021  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
00022  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00023  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00024  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00025  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
00026  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00027  */
00028 
00037 #include <ipc/irc.h>
00038 #include <async.h>
00039 #include <sysinfo.h>
00040 #include <kbd.h>
00041 #include <kbd_port.h>
00042 #include <sun.h>
00043 #include <sys/types.h>
00044 #include <ddi.h>
00045 #include <errno.h>
00046 
00047 #define CHAN_A_STATUS  4
00048 #define CHAN_A_DATA    6
00049 
00050 #define RR0_RCA  1
00051 
00052 static irq_cmd_t z8530_cmds[] = {
00053         {
00054                 .cmd = CMD_PIO_READ_8,
00055                 .addr = (void *) 0,     /* Will be patched in run-time */
00056                 .dstarg = 1
00057         },
00058         {
00059                 .cmd = CMD_BTEST,
00060                 .value = RR0_RCA,
00061                 .srcarg = 1,
00062                 .dstarg = 3
00063         },
00064         {
00065                 .cmd = CMD_PREDICATE,
00066                 .value = 2,
00067                 .srcarg = 3
00068         },
00069         {
00070                 .cmd = CMD_PIO_READ_8,
00071                 .addr = (void *) 0,     /* Will be patched in run-time */
00072                 .dstarg = 2
00073         },
00074         {
00075                 .cmd = CMD_ACCEPT
00076         }
00077 };
00078         
00079 irq_code_t z8530_kbd = {
00080         sizeof(z8530_cmds) / sizeof(irq_cmd_t),
00081         z8530_cmds
00082 };
00083 
00084 static void z8530_irq_handler(ipc_callid_t iid, ipc_call_t *call);
00085 
00086 int z8530_port_init(void)
00087 {
00088         sysarg_t kaddr;
00089         if (sysinfo_get_value("kbd.address.kernel", &kaddr) != EOK)
00090                 return -1;
00091         
00092         sysarg_t inr;
00093         if (sysinfo_get_value("kbd.inr", &inr) != EOK)
00094                 return -1;
00095         
00096         z8530_cmds[0].addr = (void *) kaddr + CHAN_A_STATUS;
00097         z8530_cmds[3].addr = (void *) kaddr + CHAN_A_DATA;
00098         
00099         async_set_interrupt_received(z8530_irq_handler);
00100         register_irq(inr, device_assign_devno(), inr, &z8530_kbd);
00101         
00102         return 0;
00103 }
00104 
00105 static void z8530_irq_handler(ipc_callid_t iid, ipc_call_t *call)
00106 {
00107         int scan_code = IPC_GET_ARG2(*call);
00108         kbd_push_scancode(scan_code);
00109         
00110         if (irc_service)
00111                 async_msg_1(irc_phone, IRC_CLEAR_INTERRUPT,
00112                     IPC_GET_IMETHOD(*call));
00113 }
00114 

Generated on Thu Jun 2 07:45:50 2011 for HelenOS/USB by  doxygen 1.4.7