blob: 73f5cc124a3606a5cb73406e207d8a27fd4c339e [file] [log] [blame]
GuanXuetao425ad522011-01-15 18:28:19 +08001/*
2 * Code specific to PKUnity SoC and UniCore ISA
3 *
4 * Maintained by GUAN Xue-tao <gxt@mprc.pku.edu.cn>
5 * Copyright (C) 2001-2011 Guan Xuetao
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10 */
11#ifndef _I8042_UNICORE32_H
12#define _I8042_UNICORE32_H
13
14#include <mach/hardware.h>
15
16/*
17 * Names.
18 */
19#define I8042_KBD_PHYS_DESC "isa0060/serio0"
20#define I8042_AUX_PHYS_DESC "isa0060/serio1"
21#define I8042_MUX_PHYS_DESC "isa0060/serio%d"
22
23/*
24 * IRQs.
25 */
26#define I8042_KBD_IRQ IRQ_PS2_KBD
27#define I8042_AUX_IRQ IRQ_PS2_AUX
28
29/*
30 * Register numbers.
31 */
GuanXuetaoe5abf782011-02-26 21:21:18 +080032#define I8042_COMMAND_REG PS2_COMMAND
33#define I8042_STATUS_REG PS2_STATUS
34#define I8042_DATA_REG PS2_DATA
GuanXuetao3838b822011-02-18 18:38:33 +080035
GuanXuetaoe5abf782011-02-26 21:21:18 +080036#define I8042_REGION_START (resource_size_t)(PS2_DATA)
GuanXuetao3838b822011-02-18 18:38:33 +080037#define I8042_REGION_SIZE (resource_size_t)(16)
GuanXuetao425ad522011-01-15 18:28:19 +080038
39static inline int i8042_read_data(void)
40{
GuanXuetao3838b822011-02-18 18:38:33 +080041 return readb(I8042_DATA_REG);
GuanXuetao425ad522011-01-15 18:28:19 +080042}
43
44static inline int i8042_read_status(void)
45{
GuanXuetao3838b822011-02-18 18:38:33 +080046 return readb(I8042_STATUS_REG);
GuanXuetao425ad522011-01-15 18:28:19 +080047}
48
49static inline void i8042_write_data(int val)
50{
GuanXuetao3838b822011-02-18 18:38:33 +080051 writeb(val, I8042_DATA_REG);
GuanXuetao425ad522011-01-15 18:28:19 +080052}
53
54static inline void i8042_write_command(int val)
55{
GuanXuetao3838b822011-02-18 18:38:33 +080056 writeb(val, I8042_COMMAND_REG);
GuanXuetao425ad522011-01-15 18:28:19 +080057}
58
59static inline int i8042_platform_init(void)
60{
GuanXuetao45173662011-02-25 17:58:00 +080061 if (!request_mem_region(I8042_REGION_START, I8042_REGION_SIZE, "i8042"))
GuanXuetao425ad522011-01-15 18:28:19 +080062 return -EBUSY;
63
64 i8042_reset = 1;
65 return 0;
66}
67
68static inline void i8042_platform_exit(void)
69{
GuanXuetao45173662011-02-25 17:58:00 +080070 release_mem_region(I8042_REGION_START, I8042_REGION_SIZE);
GuanXuetao425ad522011-01-15 18:28:19 +080071}
72
73#endif /* _I8042_UNICORE32_H */