#include <linux/input.h>
#include <linux/delay.h>
#include <linux/interrupt.h>
-#include <linux/keyboard.h>
#include <asm/amigaints.h>
#include <asm/amigahw.h>
MODULE_DESCRIPTION("Amiga keyboard driver");
MODULE_LICENSE("GPL");
-static unsigned char amikbd_keycode[0x78] __initdata = {
+static unsigned char amikbd_keycode[0x78] = {
[0] = KEY_GRAVE,
[1] = KEY_1,
[2] = KEY_2,
scancode >>= 1;
if (scancode < 0x78) { /* scancodes < 0x78 are keys */
+
+ scancode = amikbd_keycode[scancode];
+
input_regs(amikbd_dev, fp);
- if (scancode == 98) { /* CapsLock is a toggle switch key on Amiga */
+ if (scancode == KEY_CAPSLOCK) { /* CapsLock is a toggle switch key on Amiga */
input_report_key(amikbd_dev, scancode, 1);
input_report_key(amikbd_dev, scancode, 0);
} else {
static int __init amikbd_init(void)
{
- int i, j;
+ int i;
if (!AMIGAHW_PRESENT(AMI_KEYBOARD))
return -EIO;
amikbd_dev->id.version = 0x0100;
amikbd_dev->evbit[0] = BIT(EV_KEY) | BIT(EV_REP);
+ amikbd_dev->keycode = amikbd_keycode;
+ amikbd_dev->keycodesize = sizeof(unsigned char);
+ amikbd_dev->keycodemax = ARRAY_SIZE(amikbd_keycode);
for (i = 0; i < 0x78; i++)
- set_bit(i, amikbd_dev->keybit);
-
- for (i = 0; i < MAX_NR_KEYMAPS; i++) {
- static u_short temp_map[NR_KEYS] __initdata;
- if (!key_maps[i])
- continue;
- memset(temp_map, 0, sizeof(temp_map));
- for (j = 0; j < 0x78; j++) {
- if (!amikbd_keycode[j])
- continue;
- temp_map[j] = key_maps[i][amikbd_keycode[j]];
- }
- for (j = 0; j < NR_KEYS; j++) {
- if (!temp_map[j])
- temp_map[j] = 0xf200;
- }
- memcpy(key_maps[i], temp_map, sizeof(temp_map));
- }
+ if (amikbd_keycode[i])
+ set_bit(amikbd_keycode[i], amikbd_dev->keybit);
+
ciaa.cra &= ~0x41; /* serial data in, turn off TA */
request_irq(IRQ_AMIGA_CIAA_SP, amikbd_interrupt, 0, "amikbd", amikbd_interrupt);