⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ps2kbd.c

📁 U-BOOT,著名的Bootloader程序
💻 C
📖 第 1 页 / 共 2 页
字号:
/* * (C) Copyright 2002 * John W. Linville, linville@tuxdriver.com * * Modified from code for support of MIP405 and PIP405 boards.  Previous * copyright follows. * * (C) Copyright 2001 * Denis Peter, MPL AG Switzerland, d.peter@mpl.ch * * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * * * Source partly derived from: * linux/drivers/char/pc_keyb.c * * */#include <common.h>#include <asm/processor.h>#include <devices.h>#include "ps2kbd.h"unsigned char kbd_read_status(void);unsigned char kbd_read_input(void);void kbd_send_data(unsigned char data);void i8259_mask_irq(unsigned int irq);void i8259_unmask_irq(unsigned int irq);/* used only by send_data - set by keyboard_interrupt */#undef KBG_DEBUG#ifdef KBG_DEBUG#define	PRINTF(fmt,args...)	printf (fmt ,##args)#else#define PRINTF(fmt,args...)#endif#define KBD_STAT_KOBF		0x01#define KBD_STAT_IBF		0x02#define KBD_STAT_SYS		0x04#define KBD_STAT_CD		0x08#define KBD_STAT_LOCK		0x10#define KBD_STAT_MOBF		0x20#define KBD_STAT_TI_OUT	0x40#define KBD_STAT_PARERR	0x80#define KBD_INIT_TIMEOUT 2000		/* Timeout in ms for initializing the keyboard */#define KBC_TIMEOUT 250			/* Timeout in ms for sending to keyboard controller */#define KBD_TIMEOUT 2000		/* Timeout in ms for keyboard command acknowledge *//* *	Keyboard Controller Commands */#define KBD_CCMD_READ_MODE	0x20	/* Read mode bits */#define KBD_CCMD_WRITE_MODE	0x60	/* Write mode bits */#define KBD_CCMD_GET_VERSION	0xA1	/* Get controller version */#define KBD_CCMD_MOUSE_DISABLE	0xA7	/* Disable mouse interface */#define KBD_CCMD_MOUSE_ENABLE	0xA8	/* Enable mouse interface */#define KBD_CCMD_TEST_MOUSE	0xA9	/* Mouse interface test */#define KBD_CCMD_SELF_TEST	0xAA	/* Controller self test */#define KBD_CCMD_KBD_TEST	0xAB	/* Keyboard interface test */#define KBD_CCMD_KBD_DISABLE	0xAD	/* Keyboard interface disable */#define KBD_CCMD_KBD_ENABLE	0xAE	/* Keyboard interface enable */#define KBD_CCMD_WRITE_AUX_OBUF	0xD3    /* Write to output buffer as if					   initiated by the auxiliary device */#define KBD_CCMD_WRITE_MOUSE	0xD4	/* Write the following byte to the mouse *//* *	Keyboard Commands */#define KBD_CMD_SET_LEDS	0xED	/* Set keyboard leds */#define KBD_CMD_SET_RATE	0xF3	/* Set typematic rate */#define KBD_CMD_ENABLE		0xF4	/* Enable scanning */#define KBD_CMD_DISABLE		0xF5	/* Disable scanning */#define KBD_CMD_RESET		0xFF	/* Reset *//* *	Keyboard Replies */#define KBD_REPLY_POR		0xAA	/* Power on reset */#define KBD_REPLY_ACK		0xFA	/* Command ACK */#define KBD_REPLY_RESEND	0xFE	/* Command NACK, send the cmd again *//* *	Status Register Bits */#define KBD_STAT_OBF		0x01	/* Keyboard output buffer full */#define KBD_STAT_IBF		0x02	/* Keyboard input buffer full */#define KBD_STAT_SELFTEST	0x04	/* Self test successful */#define KBD_STAT_CMD		0x08	/* Last write was a command write (0=data) */#define KBD_STAT_UNLOCKED	0x10	/* Zero if keyboard locked */#define KBD_STAT_MOUSE_OBF	0x20	/* Mouse output buffer full */#define KBD_STAT_GTO		0x40	/* General receive/xmit timeout */#define KBD_STAT_PERR		0x80	/* Parity error */#define AUX_STAT_OBF (KBD_STAT_OBF | KBD_STAT_MOUSE_OBF)/* *	Controller Mode Register Bits */#define KBD_MODE_KBD_INT	0x01	/* Keyboard data generate IRQ1 */#define KBD_MODE_MOUSE_INT	0x02	/* Mouse data generate IRQ12 */#define KBD_MODE_SYS		0x04	/* The system flag (?) */#define KBD_MODE_NO_KEYLOCK	0x08	/* The keylock doesn't affect the keyboard if set */#define KBD_MODE_DISABLE_KBD	0x10	/* Disable keyboard interface */#define KBD_MODE_DISABLE_MOUSE	0x20	/* Disable mouse interface */#define KBD_MODE_KCC		0x40	/* Scan code conversion to PC format */#define KBD_MODE_RFU		0x80#define KDB_DATA_PORT		0x60#define KDB_COMMAND_PORT	0x64#define	LED_SCR			0x01	/* scroll lock led */#define	LED_CAP			0x04	/* caps lock led */#define	LED_NUM			0x02	/* num lock led */#define	KBD_BUFFER_LEN		0x20	/* size of the keyboardbuffer */static volatile char kbd_buffer[KBD_BUFFER_LEN];static volatile int in_pointer = 0;static volatile int out_pointer = 0;static unsigned char num_lock = 0;static unsigned char caps_lock = 0;static unsigned char scroll_lock = 0;static unsigned char shift = 0;static unsigned char ctrl = 0;static unsigned char alt = 0;static unsigned char e0 = 0;static unsigned char leds = 0;#define DEVNAME "ps2kbd"/* Simple translation table for the keys */static unsigned char kbd_plain_xlate[] = {	0xff,0x1b, '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '=','\b','\t',	/* 0x00 - 0x0f */	 'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', '[', ']','\r',0xff, 'a', 's',	/* 0x10 - 0x1f */	 'd', 'f', 'g', 'h', 'j', 'k', 'l', ';','\'', '`',0xff,'\\', 'z', 'x', 'c', 'v',	/* 0x20 - 0x2f */	 'b', 'n', 'm', ',', '.', '/',0xff,0xff,0xff, ' ',0xff,0xff,0xff,0xff,0xff,0xff,	/* 0x30 - 0x3f */	0xff,0xff,0xff,0xff,0xff,0xff,0xff, '7', '8', '9', '-', '4', '5', '6', '+', '1',	/* 0x40 - 0x4f */	 '2', '3', '0', '.',0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,  /* 0x50 - 0x5F */	'\r',0xff,0xff	};static unsigned char kbd_shift_xlate[] = {	0xff,0x1b, '!', '@', '#', '$', '%', '^', '&', '*', '(', ')', '_', '+','\b','\t',	/* 0x00 - 0x0f */	 'Q', 'W', 'E', 'R', 'T', 'Y', 'U', 'I', 'O', 'P', '{', '}','\r',0xff, 'A', 'S',	/* 0x10 - 0x1f */	 'D', 'F', 'G', 'H', 'J', 'K', 'L', ':', '"', '~',0xff, '|', 'Z', 'X', 'C', 'V',	/* 0x20 - 0x2f */	 'B', 'N', 'M', '<', '>', '?',0xff,0xff,0xff, ' ',0xff,0xff,0xff,0xff,0xff,0xff,	/* 0x30 - 0x3f */	0xff,0xff,0xff,0xff,0xff,0xff,0xff, '7', '8', '9', '-', '4', '5', '6', '+', '1',	/* 0x40 - 0x4f */	 '2', '3', '0', '.',0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,  /* 0x50 - 0x5F */	'\r',0xff,0xff	};static unsigned char kbd_ctrl_xlate[] = {	0xff,0x1b, '1',0x00, '3', '4', '5',0x1E, '7', '8', '9', '0',0x1F, '=','\b','\t',	/* 0x00 - 0x0f */	0x11,0x17,0x05,0x12,0x14,0x18,0x15,0x09,0x0f,0x10,0x1b,0x1d,'\n',0xff,0x01,0x13,	/* 0x10 - 0x1f */	0x04,0x06,0x08,0x09,0x0a,0x0b,0x0c, ';','\'', '~',0x00,0x1c,0x1a,0x18,0x03,0x16,	/* 0x20 - 0x2f */	0x02,0x0e,0x0d, '<', '>', '?',0xff,0xff,0xff,0x00,0xff,0xff,0xff,0xff,0xff,0xff,	/* 0x30 - 0x3f */	0xff,0xff,0xff,0xff,0xff,0xff,0xff, '7', '8', '9', '-', '4', '5', '6', '+', '1',	/* 0x40 - 0x4f */	 '2', '3', '0', '.',0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,  /* 0x50 - 0x5F */	'\r',0xff,0xff	};/****************************************************************** * Init ******************************************************************/int isa_kbd_init (void){	char *result;	result = kbd_initialize ();	if (result != NULL) {		result = kbd_initialize ();	}	if (result == NULL) {		printf ("AT Keyboard initialized\n");		irq_install_handler (KBD_INTERRUPT,				     (interrupt_handler_t *) kbd_interrupt,				     NULL);		return (1);	} else {		printf ("%s\n", result);		return (-1);	}}#ifdef CFG_CONSOLE_OVERWRITE_ROUTINEextern int overwrite_console (void);#elseint overwrite_console (void){	return (0);}#endifint drv_isa_kbd_init (void){	int error;	device_t kbddev ;	char *stdinname  = getenv ("stdin");	if(isa_kbd_init() == -1)		return -1;	memset (&kbddev, 0, sizeof(kbddev));	strcpy(kbddev.name, DEVNAME);	kbddev.flags =  DEV_FLAGS_INPUT | DEV_FLAGS_SYSTEM;	kbddev.putc = NULL ;	kbddev.puts = NULL ;	kbddev.getc = kbd_getc ;	kbddev.tstc = kbd_testc ;	error = device_register (&kbddev);	if(error==0) {		/* check if this is the standard input device */		if(strcmp(stdinname,DEVNAME)==0) {			/* reassign the console */			if(overwrite_console()) {				return 1;			}			error=console_assign(stdin,DEVNAME);			if(error==0)				return 1;			else				return error;		}		return 1;	}	return error;}/****************************************************************** * Queue handling ******************************************************************//* puts character in the queue and sets up the in and out pointer */void kbd_put_queue(char data){	if((in_pointer+1)==KBD_BUFFER_LEN) {		if(out_pointer==0) {			return; /* buffer full */		} else{			in_pointer=0;		}	} else {		if((in_pointer+1)==out_pointer)			return; /* buffer full */		in_pointer++;	}	kbd_buffer[in_pointer]=data;	return;}/* test if a character is in the queue */int kbd_testc(void){	if(in_pointer==out_pointer)		return(0); /* no data */	else		return(1);}/* gets the character from the queue */int kbd_getc(void){	char c;	while(in_pointer==out_pointer);	if((out_pointer+1)==KBD_BUFFER_LEN)		out_pointer=0;	else		out_pointer++;	c=kbd_buffer[out_pointer];	return (int)c;}/* set LEDs */void kbd_set_leds(void){	if(caps_lock==0)		leds&=~LED_CAP; /* switch caps_lock off */	else		leds|=LED_CAP; /* switch on LED */	if(num_lock==0)		leds&=~LED_NUM; /* switch LED off */	else		leds|=LED_NUM;  /* switch on LED */	if(scroll_lock==0)		leds&=~LED_SCR; /* switch LED off */	else		leds|=LED_SCR; /* switch on LED */	kbd_send_data(KBD_CMD_SET_LEDS);	kbd_send_data(leds);}void handle_keyboard_event (unsigned char scancode){	unsigned char keycode;	/*  Convert scancode to keycode */	PRINTF ("scancode %x\n", scancode);	if (scancode == 0xe0) {		e0 = 1;		/* special charakters */		return;	}	if (e0 == 1) {		e0 = 0;		/* delete flag */		if (!(((scancode & 0x7F) == 0x38) ||	/* the right ctrl key */		      ((scancode & 0x7F) == 0x1D) ||	/* the right alt key */		      ((scancode & 0x7F) == 0x35) ||	/* the right '/' key */		      ((scancode & 0x7F) == 0x1C) ||	/* the right enter key */		      ((scancode) == 0x48) ||	/* arrow up */		      ((scancode) == 0x50) ||	/* arrow down */		      ((scancode) == 0x4b) ||	/* arrow left */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -