1 #include
2 #include
3
4 #include
5 #include
6 #include
7 #include
8 #include
9 #include
10 #include
11 #include
12 #include
13 #include
14 #include
15 #include
16
17 #include
18 #include
19 #include
20
21
22 structpin_desc{23 intirq;24 char *name;25 unsigned intpin;26 unsigned intkey_val;27 };28
29 struct pin_desc pins_desc[4] ={30 {IRQ_EINT0, "S2", S3C2410_GPF0, KEY_L},31 {IRQ_EINT2, "S3", S3C2410_GPF2, KEY_S},32 {IRQ_EINT11, "S4", S3C2410_GPG3, KEY_ENTER},33 {IRQ_EINT19, "S5", S3C2410_GPG11, KEY_LEFTSHIFT},34 };35
36 static struct input_dev *input_subsys_dev;37 static struct pin_desc *irq_pd;38 static structtimer_list buttons_timer;39
40 static irqreturn_t buttons_irq(int irq, void *dev_id)41 {42 /*[cgw]: 按键IO发生边沿中断时重新设置定时间隔43 * 用于按键消抖44 */
45 irq_pd = (struct pin_desc *)dev_id;46 buttons_timer.data = irq_pd->pin;47 mod_timer(&buttons_timer, jiffies+HZ/100);48 returnIRQ_RETVAL(IRQ_HANDLED);49 }50
51 static void buttons_timer_function(unsigned longdata)52 {53 struct pin_desc * pindesc =irq_pd;54 unsigned intpinval;55
56 if (!pindesc)57 return;58
59 /*[cgw]: 获取按键IO状态*/
60 pinval = s3c2410_gpio_getpin((unsigned int)data);61
62 /*[cgw]: 根据按键IO状态上报按键事件*/
63 if(pinval)64 {65 /*[cgw]: 上报按键弹起*/
66 input_report_key(input_subsys_dev, pindesc->key_val, 0);67 //input_sync(input_subsys_dev);
68 }69 else
70 {71 /*[cgw]: 上报按键按下*/
72 input_report_key(input_subsys_dev, pindesc->key_val, 1);73 //input_sync(input_subsys_dev);
74 }75
76 //printk("timer occur!
");
77 }78
79
80 static int led_event(struct input_dev *dev, unsigned int type, unsigned int code, intvalue)81 {82 printk("led event!");83 printk("value: 0x%x", value);84
85 /*[cgw]: 根据应用程序下发的LED控制事件86 * 亮灭LED87 */
88 //if (code == SND_BELL) {
89 if (code ==LED_MUTE) {90 if (value == 0xAA) {91 /*[cgw]: 点亮*/
92 s3c2410_gpio_setpin(S3C2410_GPF4, 0);93 } else if (value == 0xEE) {94 /*[cgw]: 熄灭*/
95 s3c2410_gpio_setpin(S3C2410_GPF4, 1);96 }97
98 return 0;99 }100
101 return -1;102 }103
104 int input_subsys_open(struct input_dev *dev)105 {106 inti, retval;107
108 /*[cgw]: 设置按键IO为中断输入*/
109 s3c2410_gpio_cfgpin(S3C2410_GPF0, S3C2410_GPF0_EINT0);110 s3c2410_gpio_cfgpin(S3C2410_GPF2, S3C2410_GPF2_EINT2);111 s3c2410_gpio_cfgpin(S3C2410_GPG3, S3C2410_GPG3_EINT11);112 s3c2410_gpio_cfgpin(S3C2410_GPG11, S3C2410_GPG11_EINT19);113
114 /*[cgw]: 设置LED IO为输出,初始为熄灭LED*/
115 s3c2410_gpio_cfgpin(S3C2410_GPF4, S3C2410_GPF4_OUTP);116 s3c2410_gpio_setpin(S3C2410_GPF4, 1);117
118 s3c2410_gpio_cfgpin(S3C2410_GPF5, S3C2410_GPF5_OUTP);119 s3c2410_gpio_setpin(S3C2410_GPF5, 1);120
121 s3c2410_gpio_cfgpin(S3C2410_GPF5, S3C2410_GPF5_OUTP);122 s3c2410_gpio_setpin(S3C2410_GPF5, 1);123
124 /*[cgw]: 为按键IO分配中断线*/
125 for (i = 0; i < 4; i++)126 {127 retval = request_irq(pins_desc[i].irq, buttons_irq, IRQT_BOTHEDGE, pins_desc[i].name, &pins_desc[i]);128 }129
130 printk("input subsys open!");131
132 return 0;133 }134
135
136
137 static int input_subsys_init(void)138 {139 /*[cgw]: 分配一个输入设备*/
140 input_subsys_dev =input_allocate_device();141 input_subsys_dev->name = "input_subsys_dev";142
143 /*[cgw]: 设置支持的事件类型*/
144 set_bit(EV_KEY, input_subsys_dev->evbit);145 //set_bit(EV_REP, input_subsys_dev->evbit);
146
147 set_bit(EV_LED, input_subsys_dev->evbit);148 //set_bit(EV_SND, input_subsys_dev->evbit);
149
150 /*[cgw]: 设置支持的事件码*/
151 set_bit(KEY_L, input_subsys_dev->keybit);152 set_bit(KEY_S, input_subsys_dev->keybit);153 set_bit(KEY_ENTER, input_subsys_dev->keybit);154 set_bit(KEY_LEFTSHIFT, input_subsys_dev->keybit);155
156 set_bit(LED_MUTE, input_subsys_dev->ledbit);157 //set_bit(SND_BELL, input_subsys_dev->sndbit);
158
159 /*[cgw]: 分配输入设备的open方法,用户操作open(/dev/xxx, ...)时调用*/
160 input_subsys_dev->open =input_subsys_open;161 /*[cgw]: 分配输入设备的event方法,用户在应用程序write()时*/
162 input_subsys_dev->event =led_event;163
164 /*[cgw]: 注册输入设备*/
165 input_register_device(input_subsys_dev);166
167 /*[cgw]: 初始化定时器,用于按键消抖*/
168 init_timer(&buttons_timer);169 buttons_timer.function =buttons_timer_function;170 add_timer(&buttons_timer);171
172 printk("input subsys init!");173
174 return 0;175 }176
177 static void input_subsys_exit(void)178 {179 inti;180
181 /*[cgw]: 释放按键IO中断*/
182 for (i = 0; i < 4; i++)183 {184 free_irq(pins_desc[i].irq, &pins_desc[i]);185 }186
187 /*[cgw]: 删除定时器*/
188 del_timer(&buttons_timer);189 /*[cgw]: 注销输入设备*/
190 input_unregister_device(input_subsys_dev);191 /*[cgw]: 释放输入设备内存空间*/
192 input_free_device(input_subsys_dev);193 }194
195 module_init(input_subsys_init);196
197 module_exit(input_subsys_exit);198
199 MODULE_LICENSE("GPL");