亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? keyboard.c

?? <Linux1.0核心游記>電子書+書后源碼+Linux1.0源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * linux/kernel/chr_drv/keyboard.c * * Keyboard driver for Linux v0.99 using Latin-1. * * Written for linux by Johan Myreen as a translation from * the assembly version by Linus (with diacriticals added) * * Some additional features added by Christoph Niemann (ChN), March 1993 * Loadable keymaps by Risto Kankkunen, May 1993 * Diacriticals redone & other small changes, aeb@cwi.nl, June 1993 */#define KEYBOARD_IRQ 1#include <linux/sched.h>#include <linux/tty.h>#include <linux/mm.h>#include <linux/ptrace.h>#include <linux/interrupt.h>#include <linux/config.h>#include <linux/signal.h>#include <linux/string.h>#include <asm/bitops.h>#include "kbd_kern.h"#include "diacr.h"#define SIZE(x) (sizeof(x)/sizeof((x)[0]))#define KBD_REPORT_ERR#define KBD_REPORT_UNKN#ifndef KBD_DEFMODE#define KBD_DEFMODE ((1 << VC_REPEAT) | (1 << VC_META))#endif#ifndef KBD_DEFLEDS/* * Some laptops take the 789uiojklm,. keys as number pad when NumLock * is on. This seems a good reason to start with NumLock off. */#define KBD_DEFLEDS 0#endif#ifndef KBD_DEFLOCK#define KBD_DEFLOCK 0#endif/* * The default IO slowdown is doing 'inb()'s from 0x61, which should be * safe. But as that is the keyboard controller chip address, we do our * slowdowns here by doing short jumps: the keyboard controller should * be able to keep up */#define REALLY_SLOW_IO#define SLOW_IO_BY_JUMPING#include <asm/io.h>#include <asm/system.h>extern void do_keyboard_interrupt(void);extern void ctrl_alt_del(void);extern void change_console(unsigned int new_console);extern void scrollback(int);extern void scrollfront(int);#define fake_keyboard_interrupt() \__asm__ __volatile__("int $0x21")unsigned char kbd_read_mask = 0x01;	/* modified by psaux.c *//* * global state includes the following, and various static variables * in this module: prev_scancode, shift_state, diacr, npadch, *   dead_key_next, last_console *//* shift state counters.. */static unsigned char k_down[NR_SHIFT] = {0, };/* keyboard key bitmap */static unsigned long key_down[8] = { 0, };static int want_console = -1;static int last_console = 0;		/* last used VC */static int dead_key_next = 0;static int shift_state = 0;static int npadch = -1;		        /* -1 or number assembled on pad */static unsigned char diacr = 0;static char rep = 0;			/* flag telling character repeat */struct kbd_struct kbd_table[NR_CONSOLES];static struct kbd_struct * kbd = kbd_table;static struct tty_struct * tty = NULL;/* used only by send_data - set by keyboard_interrupt */static volatile unsigned char acknowledge = 0;static volatile unsigned char resend = 0;typedef void (*k_hand)(unsigned char value, char up_flag);typedef void (k_handfn)(unsigned char value, char up_flag);static k_handfn        do_self, do_fn, do_spec, do_pad, do_dead, do_cons, do_cur, do_shift,	do_meta, do_ascii, do_lock, do_lowercase;static k_hand key_handler[] = {	do_self, do_fn, do_spec, do_pad, do_dead, do_cons, do_cur, do_shift,	do_meta, do_ascii, do_lock, do_lowercase};/* maximum values each key_handler can handle */const int max_vals[] = {	255, NR_FUNC - 1, 14, 17, 4, 255, 3, NR_SHIFT,	255, 9, 3, 255};const int NR_TYPES = SIZE(max_vals);static void put_queue(int);static unsigned char handle_diacr(unsigned char);/* pt_regs - set by keyboard_interrupt(), used by show_ptregs() */static struct pt_regs * pt_regs;static int got_break = 0;static inline void kb_wait(void){	int i;	for (i=0; i<0x10000; i++)		if ((inb_p(0x64) & 0x02) == 0)			break;}static inline void send_cmd(unsigned char c){	kb_wait();	outb(c,0x64);}/* * Translation of escaped scancodes to keysyms. * This should be user-settable. */#define E0_BASE 96#define E0_KPENTER (E0_BASE+0)#define E0_RCTRL   (E0_BASE+1)#define E0_KPSLASH (E0_BASE+2)#define E0_PRSCR   (E0_BASE+3)#define E0_RALT    (E0_BASE+4)#define E0_BREAK   (E0_BASE+5)  /* (control-pause) */#define E0_HOME    (E0_BASE+6)#define E0_UP      (E0_BASE+7)#define E0_PGUP    (E0_BASE+8)#define E0_LEFT    (E0_BASE+9)#define E0_RIGHT   (E0_BASE+10)#define E0_END     (E0_BASE+11)#define E0_DOWN    (E0_BASE+12)#define E0_PGDN    (E0_BASE+13)#define E0_INS     (E0_BASE+14)#define E0_DEL     (E0_BASE+15)/* BTC */#define E0_MACRO   (E0_BASE+16)/* LK450 */#define E0_F13     (E0_BASE+17)#define E0_F14     (E0_BASE+18)#define E0_HELP    (E0_BASE+19)#define E0_DO      (E0_BASE+20)#define E0_F17     (E0_BASE+21)#define E0_KPMINPLUS (E0_BASE+22)#define E1_PAUSE   (E0_BASE+23)static unsigned char e0_keys[128] = {  0, 0, 0, 0, 0, 0, 0, 0,			      /* 0x00-0x07 */  0, 0, 0, 0, 0, 0, 0, 0,			      /* 0x08-0x0f */  0, 0, 0, 0, 0, 0, 0, 0,			      /* 0x10-0x17 */  0, 0, 0, 0, E0_KPENTER, E0_RCTRL, 0, 0,	      /* 0x18-0x1f */  0, 0, 0, 0, 0, 0, 0, 0,			      /* 0x20-0x27 */  0, 0, 0, 0, 0, 0, 0, 0,			      /* 0x28-0x2f */  0, 0, 0, 0, 0, E0_KPSLASH, 0, E0_PRSCR,	      /* 0x30-0x37 */  E0_RALT, 0, 0, 0, 0, E0_F13, E0_F14, E0_HELP,	      /* 0x38-0x3f */  E0_DO, E0_F17, 0, 0, 0, 0, E0_BREAK, E0_HOME,	      /* 0x40-0x47 */  E0_UP, E0_PGUP, 0, E0_LEFT, 0, E0_RIGHT, E0_KPMINPLUS, E0_END,/* 0x48-0x4f */  E0_DOWN, E0_PGDN, E0_INS, E0_DEL, 0, 0, 0, 0,	      /* 0x50-0x57 */  0, 0, 0, 0, 0, 0, 0, 0,			      /* 0x58-0x5f */  0, 0, 0, 0, 0, 0, 0, 0,			      /* 0x60-0x67 */  0, 0, 0, 0, 0, 0, 0, E0_MACRO,		      /* 0x68-0x6f */  0, 0, 0, 0, 0, 0, 0, 0,			      /* 0x70-0x77 */  0, 0, 0, 0, 0, 0, 0, 0			      /* 0x78-0x7f */};static void keyboard_interrupt(int int_pt_regs){	unsigned char scancode;	static unsigned int prev_scancode = 0;   /* remember E0, E1 */	char up_flag;		                 /* 0 or 0200 */	char raw_mode;	pt_regs = (struct pt_regs *) int_pt_regs;	send_cmd(0xAD);		/* disable keyboard */	kb_wait();	if ((inb_p(0x64) & kbd_read_mask) != 0x01)		goto end_kbd_intr;	scancode = inb(0x60);	mark_bh(KEYBOARD_BH);	if (scancode == 0xfa) {		acknowledge = 1;		goto end_kbd_intr;	} else if (scancode == 0xfe) {		resend = 1;		goto end_kbd_intr;	} else if (scancode == 0) {#ifdef KBD_REPORT_ERR	        printk("keyboard buffer overflow\n");#endif		goto end_kbd_intr;	} else if (scancode == 0xff) {#ifdef KBD_REPORT_ERR	        printk("keyboard error\n");#endif	        prev_scancode = 0;	        goto end_kbd_intr;	}	tty = TTY_TABLE(0); 	kbd = kbd_table + fg_console;	if ((raw_mode = vc_kbd_mode(kbd,VC_RAW))) { 		put_queue(scancode);		/* we do not return yet, because we want to maintain		   the key_down array, so that we have the correct		   values when finishing RAW mode or when changing VT's */ 	}	if (scancode == 0xe0 || scancode == 0xe1) {		prev_scancode = scancode;		goto end_kbd_intr; 	} 	/*	 *  Convert scancode to keysym, using prev_scancode. 	 */	up_flag = (scancode & 0200); 	scancode &= 0x7f;  	if (prev_scancode) {	  /*	   * usually it will be 0xe0, but a Pause key generates	   * e1 1d 45 e1 9d c5 when pressed, and nothing when released	   */	  if (prev_scancode != 0xe0) {	      if (prev_scancode == 0xe1 && scancode == 0x1d) {		  prev_scancode = 0x100;		  goto end_kbd_intr;	      } else if (prev_scancode == 0x100 && scancode == 0x45) {		  scancode = E1_PAUSE;		  prev_scancode = 0;	      } else {		  printk("keyboard: unknown e1 escape sequence\n");		  prev_scancode = 0;		  goto end_kbd_intr;	      }	  } else {	      prev_scancode = 0;	      /*	       *  The keyboard maintains its own internal caps lock and	       *  num lock statuses. In caps lock mode E0 AA precedes make	       *  code and E0 2A follows break code. In num lock mode,	       *  E0 2A precedes make code and E0 AA follows break code.	       *  We do our own book-keeping, so we will just ignore these.	       */	      /*	       *  For my keyboard there is no caps lock mode, but there are	       *  both Shift-L and Shift-R modes. The former mode generates	       *  E0 2A / E0 AA pairs, the latter E0 B6 / E0 36 pairs.	       *  So, we should also ignore the latter. - aeb@cwi.nl	       */	      if (scancode == 0x2a || scancode == 0x36)		goto end_kbd_intr;	      if (e0_keys[scancode])		scancode = e0_keys[scancode];	      else if (!raw_mode) {#ifdef KBD_REPORT_UNKN		  printk("keyboard: unknown scancode e0 %02x\n", scancode);#endif		  goto end_kbd_intr;	      }	  }	} else if (scancode >= E0_BASE && !raw_mode) {#ifdef KBD_REPORT_UNKN	  printk("keyboard: scancode (%02x) not in range 00 - %2x\n",		 scancode, E0_BASE - 1);#endif	  goto end_kbd_intr; 	}  	/*	 * At this point the variable `scancode' contains the keysym.	 * We keep track of the up/down status of the key, and	 * return the keysym if in MEDIUMRAW mode.	 * (Note: earlier kernels had a bug and did not pass the up/down	 * bit to applications.)	 */	if (up_flag) { 		clear_bit(scancode, key_down);		rep = 0;	} else 		rep = set_bit(scancode, key_down);  	if (raw_mode)	        goto end_kbd_intr; 	if (vc_kbd_mode(kbd, VC_MEDIUMRAW)) { 		put_queue(scancode + up_flag);		goto end_kbd_intr; 	}   	/*	 * Small change in philosophy: earlier we defined repetition by	 *	 rep = scancode == prev_keysym;	 *	 prev_keysym = scancode;	 * but now by the fact that the depressed key was down already.	 * Does this ever make a difference?	 */	/* 	 *  Repeat a key only if the input buffers are empty or the 	 *  characters get echoed locally. This makes key repeat usable 	 *  with slow applications and under heavy loads.	 */	if (!rep || 	    (vc_kbd_mode(kbd,VC_REPEAT) && tty &&	     (L_ECHO(tty) || (EMPTY(&tty->secondary) && EMPTY(&tty->read_q)))))	{		u_short key_code;		u_char type;		/* the XOR below used to be an OR */		int shift_final = shift_state ^ kbd->lockstate;		key_code = key_map[shift_final][scancode];		type = KTYP(key_code);		if (type == KT_LETTER) {		    type = KT_LATIN;		    if (vc_kbd_led(kbd,VC_CAPSLOCK))			key_code = key_map[shift_final ^ (1<<KG_SHIFT)][scancode];		}		(*key_handler[type])(key_code & 0xff, up_flag);	}end_kbd_intr:	send_cmd(0xAE);         /* enable keyboard */}static void put_queue(int ch){	struct tty_queue *qp;	wake_up(&keypress_wait);	if (!tty)		return;	qp = &tty->read_q;	if (LEFT(qp)) {		qp->buf[qp->head] = ch;		INC(qp->head);	}}static void puts_queue(char *cp){	struct tty_queue *qp;	char ch;	/* why interruptible here, plain wake_up above? */	wake_up_interruptible(&keypress_wait);	if (!tty)		return;	qp = &tty->read_q;	while ((ch = *(cp++)) != 0) {		if (LEFT(qp)) {			qp->buf[qp->head] = ch;			INC(qp->head);		}	}}static void applkey(int key, char mode){	static char buf[] = { 0x1b, 'O', 0x00, 0x00 };	buf[1] = (mode ? 'O' : '[');	buf[2] = key;	puts_queue(buf);}static void enter(void){	put_queue(13);	if (vc_kbd_mode(kbd,VC_CRLF))		put_queue(10);}static void caps_toggle(void){	if (rep)		return;	chg_vc_kbd_led(kbd,VC_CAPSLOCK);}static void caps_on(void){	if (rep)		return;	set_vc_kbd_led(kbd,VC_CAPSLOCK);}static void show_ptregs(void){	if (!pt_regs)		return;	printk("\n");	printk("EIP: %04x:%08lx",0xffff & pt_regs->cs,pt_regs->eip);	if (pt_regs->cs & 3)		printk(" ESP: %04x:%08lx",0xffff & pt_regs->ss,pt_regs->esp);	printk(" EFLAGS: %08lx\n",pt_regs->eflags);	printk("EAX: %08lx EBX: %08lx ECX: %08lx EDX: %08lx\n",		pt_regs->orig_eax,pt_regs->ebx,pt_regs->ecx,pt_regs->edx);	printk("ESI: %08lx EDI: %08lx EBP: %08lx",		pt_regs->esi, pt_regs->edi, pt_regs->ebp);	printk(" DS: %04x ES: %04x FS: %04x GS: %04x\n",		0xffff & pt_regs->ds,0xffff & pt_regs->es,		0xffff & pt_regs->fs,0xffff & pt_regs->gs);}static void hold(void){	if (rep || !tty)		return;	/*	 * Note: SCROLLOCK wil be set (cleared) by stop_tty (start_tty);	 * these routines are also activated by ^S/^Q.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧洲日本在线| 一区二区三区自拍| 一区二区三区四区视频精品免费| 日韩中文字幕一区二区三区| 成人精品国产福利| 精品毛片乱码1区2区3区| 亚洲一区视频在线观看视频| 国产一区二区精品在线观看| 欧美日韩一区二区三区视频| 中文字幕成人在线观看| 日韩精品高清不卡| 色综合久久综合| 欧美高清一级片在线观看| 蜜芽一区二区三区| 欧美区一区二区三区| 国产精品久久久久久一区二区三区| 免费观看一级特黄欧美大片| 欧美色图12p| 一区二区三区高清| 色综合久久六月婷婷中文字幕| 久久久久一区二区三区四区| 久久精品免费观看| 日韩精品一区二区三区四区视频| 亚洲国产美国国产综合一区二区| 99视频精品在线| 欧美国产1区2区| 国产激情精品久久久第一区二区 | 全国精品久久少妇| 欧美无乱码久久久免费午夜一区| 亚洲四区在线观看| 不卡电影免费在线播放一区| 日本一区二区视频在线| 国产激情一区二区三区| 久久精品在线观看| 国产+成+人+亚洲欧洲自线| 日本一区免费视频| 国产成人超碰人人澡人人澡| 国产婷婷色一区二区三区四区 | 免费在线看成人av| 91麻豆精品国产91久久久使用方法 | 在线成人小视频| 亚洲成av人综合在线观看| 欧美情侣在线播放| 日本美女一区二区三区| 日韩一区二区免费在线观看| 亚洲国产成人av| 欧美一区二区三区不卡| 精品一区在线看| 国产精品欧美久久久久无广告 | 2020日本不卡一区二区视频| 激情综合五月婷婷| 国产精品欧美久久久久一区二区| 91在线视频免费观看| 亚洲国产精品久久艾草纯爱| 欧美一区二区女人| 国产成人小视频| 亚洲精品国产成人久久av盗摄 | 国产精品久久久久一区二区三区| 色诱亚洲精品久久久久久| 日韩精品视频网| 久久久久高清精品| 色综合久久天天| 美女视频黄免费的久久| 国产喂奶挤奶一区二区三区| 色呦呦国产精品| 日韩一区精品视频| 亚洲欧洲色图综合| 欧美一区二区网站| 97se亚洲国产综合自在线不卡 | 欧美午夜精品理论片a级按摩| 日韩av不卡一区二区| 国产偷v国产偷v亚洲高清| 色一情一乱一乱一91av| 毛片基地黄久久久久久天堂| 国产精品福利在线播放| 欧美一区日韩一区| 99久久综合狠狠综合久久| 蜜臀av性久久久久蜜臀av麻豆| 亚洲欧洲av在线| 日韩精品一区二区三区四区视频 | 在线不卡一区二区| 国产91精品在线观看| 午夜精品福利一区二区三区av | 精品1区2区在线观看| 91国偷自产一区二区三区观看 | 中文字幕一区视频| 精品国产一二三区| 欧美亚洲一区三区| 99精品视频在线观看| 国产呦萝稀缺另类资源| 亚洲国产精品麻豆| 国产精品丝袜久久久久久app| 欧美大片在线观看| 欧美日韩国产综合久久| 91色在线porny| 成人免费毛片嘿嘿连载视频| 久久超碰97人人做人人爱| 午夜影院在线观看欧美| 亚洲精品欧美专区| 国产精品久99| 中文字幕一区二区日韩精品绯色| 欧美精品一区二区三区蜜臀| 51精品视频一区二区三区| 欧美图区在线视频| 成人爽a毛片一区二区免费| 国产一区二区三区在线观看精品 | 午夜精品福利一区二区蜜股av| 中文字幕在线播放不卡一区| 国产婷婷一区二区| 久久婷婷国产综合精品青草| 欧美成人精品高清在线播放| 欧美日韩国产不卡| 欧美色手机在线观看| 欧美日韩一区二区三区在线看| 欧洲生活片亚洲生活在线观看| 在线观看亚洲成人| 欧美性色欧美a在线播放| 在线观看免费一区| 欧美浪妇xxxx高跟鞋交| 在线综合视频播放| 欧美一区二区三区婷婷月色| 欧美一区二区播放| 精品乱人伦小说| 国产偷国产偷亚洲高清人白洁| 中文字幕乱码久久午夜不卡 | 91女神在线视频| 色av成人天堂桃色av| 欧美午夜宅男影院| 日韩视频一区二区在线观看| 亚洲精品一区二区三区99| 久久久亚洲午夜电影| 国产精品系列在线| 亚洲综合激情另类小说区| 日韩av在线播放中文字幕| 激情深爱一区二区| 粉嫩aⅴ一区二区三区四区| 91亚洲精华国产精华精华液| 欧美天天综合网| 日韩无一区二区| 欧美激情一区在线| 日韩美女视频一区二区| 亚洲成av人片www| 国产精品自产自拍| 91在线观看地址| 日韩欧美www| 中文字幕不卡一区| 五月天激情综合| 国产mv日韩mv欧美| 欧美日韩精品免费| 国产人成一区二区三区影院| 亚洲精品国产a| 国产综合色视频| 欧美主播一区二区三区| 2020国产精品自拍| 亚洲国产成人av好男人在线观看| 国产一区视频在线看| 在线观看免费视频综合| 精品国一区二区三区| 亚洲永久精品大片| 国产精品一区二区x88av| 欧美日韩视频第一区| 中文字幕不卡三区| 强制捆绑调教一区二区| 99国产欧美久久久精品| www国产成人免费观看视频 深夜成人网| 国产精品久久久久久久久免费樱桃 | 色88888久久久久久影院按摩| 日韩午夜在线影院| 亚洲丝袜自拍清纯另类| 国产综合久久久久久鬼色| 欧美丝袜丝nylons| 最新国产の精品合集bt伙计| 另类调教123区| 欧美揉bbbbb揉bbbbb| 国产精品久久久久久户外露出 | 9i在线看片成人免费| 精品久久免费看| 日韩专区欧美专区| 欧洲国产伦久久久久久久| 中文字幕不卡一区| 国产剧情一区二区三区| 91精品国产欧美一区二区18| 亚洲一二三专区| 99国产精品视频免费观看| 国产网站一区二区三区| 精品在线免费观看| 欧美一区二区人人喊爽| 亚洲成人福利片| 欧美中文字幕亚洲一区二区va在线 | 91在线porny国产在线看| 国产视频一区不卡| 国产一区视频导航| 欧美tickling网站挠脚心| 午夜欧美视频在线观看| 欧美午夜精品久久久久久孕妇| 亚洲欧美综合另类在线卡通| 成人国产在线观看| 国产人伦精品一区二区| 国产91在线|亚洲| 国产日本一区二区|