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

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

?? atkbd.c

?? QQ2440板子
?? C
?? 第 1 頁 / 共 2 頁
字號:
 * For known special keyboards we can go ahead and set the correct set. * We check for NCD PS/2 Sun, NorthGate OmniKey 101 and * IBM RapidAccess / IBM EzButton / Chicony KBP-8993 keyboards. */	if (atkbd->translated)		return 2;	if (atkbd->id == 0xaca1) {		param[0] = 3;		ps2_command(ps2dev, param, ATKBD_CMD_SSCANSET);		return 3;	}	if (allow_extra) {		param[0] = 0x71;		if (!ps2_command(ps2dev, param, ATKBD_CMD_EX_ENABLE)) {			atkbd->extra = 1;			return 2;		}	}	if (target_set != 3)		return 2;	if (!ps2_command(ps2dev, param, ATKBD_CMD_OK_GETID)) {		atkbd->id = param[0] << 8 | param[1];		return 2;	}	param[0] = 3;	if (ps2_command(ps2dev, param, ATKBD_CMD_SSCANSET))		return 2;	param[0] = 0;	if (ps2_command(ps2dev, param, ATKBD_CMD_GSCANSET))		return 2;	if (param[0] != 3) {		param[0] = 2;		if (ps2_command(ps2dev, param, ATKBD_CMD_SSCANSET))		return 2;	}	ps2_command(ps2dev, param, ATKBD_CMD_SETALL_MBR);	return 3;}static int atkbd_activate(struct atkbd *atkbd){	struct ps2dev *ps2dev = &atkbd->ps2dev;	unsigned char param[1];/* * Set the LEDs to a defined state. */	param[0] = 0;	if (ps2_command(ps2dev, param, ATKBD_CMD_SETLEDS))		return -1;/* * Set autorepeat to fastest possible. */	param[0] = 0;	if (ps2_command(ps2dev, param, ATKBD_CMD_SETREP))		return -1;/* * Enable the keyboard to receive keystrokes. */	if (ps2_command(ps2dev, NULL, ATKBD_CMD_ENABLE)) {		printk(KERN_ERR "atkbd.c: Failed to enable keyboard on %s\n",			ps2dev->serio->phys);		return -1;	}	return 0;}/* * atkbd_cleanup() restores the keyboard state so that BIOS is happy after a * reboot. */static void atkbd_cleanup(struct serio *serio){	struct atkbd *atkbd = serio_get_drvdata(serio);	ps2_command(&atkbd->ps2dev, NULL, ATKBD_CMD_RESET_BAT);}/* * atkbd_disconnect() closes and frees. */static void atkbd_disconnect(struct serio *serio){	struct atkbd *atkbd = serio_get_drvdata(serio);	atkbd_disable(atkbd);	/* make sure we don't have a command in flight */	synchronize_sched();  /* Allow atkbd_interrupt()s to complete. */	flush_scheduled_work();	device_remove_file(&serio->dev, &atkbd_attr_extra);	device_remove_file(&serio->dev, &atkbd_attr_scroll);	device_remove_file(&serio->dev, &atkbd_attr_set);	device_remove_file(&serio->dev, &atkbd_attr_softrepeat);	device_remove_file(&serio->dev, &atkbd_attr_softraw);	input_unregister_device(&atkbd->dev);	serio_close(serio);	serio_set_drvdata(serio, NULL);	kfree(atkbd);}/* * atkbd_set_device_attrs() initializes keyboard's keycode table * according to the selected scancode set */static void atkbd_set_keycode_table(struct atkbd *atkbd){	int i, j;	memset(atkbd->keycode, 0, sizeof(atkbd->keycode));	if (atkbd->translated) {		for (i = 0; i < 128; i++) {			atkbd->keycode[i] = atkbd_set2_keycode[atkbd_unxlate_table[i]];			atkbd->keycode[i | 0x80] = atkbd_set2_keycode[atkbd_unxlate_table[i] | 0x80];			if (atkbd->scroll)				for (j = 0; j < ARRAY_SIZE(atkbd_scroll_keys); j++)					if ((atkbd_unxlate_table[i] | 0x80) == atkbd_scroll_keys[j].set2)						atkbd->keycode[i | 0x80] = atkbd_scroll_keys[j].keycode;		}	} else if (atkbd->set == 3) {		memcpy(atkbd->keycode, atkbd_set3_keycode, sizeof(atkbd->keycode));	} else {		memcpy(atkbd->keycode, atkbd_set2_keycode, sizeof(atkbd->keycode));		if (atkbd->scroll)			for (i = 0; i < ARRAY_SIZE(atkbd_scroll_keys); i++)				atkbd->keycode[atkbd_scroll_keys[i].set2] = atkbd_scroll_keys[i].keycode;	}}/* * atkbd_set_device_attrs() sets up keyboard's input device structure */static void atkbd_set_device_attrs(struct atkbd *atkbd){	int i;	memset(&atkbd->dev, 0, sizeof(struct input_dev));	init_input_dev(&atkbd->dev);	atkbd->dev.name = atkbd->name;	atkbd->dev.phys = atkbd->phys;	atkbd->dev.id.bustype = BUS_I8042;	atkbd->dev.id.vendor = 0x0001;	atkbd->dev.id.product = atkbd->translated ? 1 : atkbd->set;	atkbd->dev.id.version = atkbd->id;	atkbd->dev.event = atkbd_event;	atkbd->dev.private = atkbd;	atkbd->dev.dev = &atkbd->ps2dev.serio->dev;	atkbd->dev.evbit[0] = BIT(EV_KEY) | BIT(EV_REP) | BIT(EV_MSC);	if (atkbd->write) {		atkbd->dev.evbit[0] |= BIT(EV_LED);		atkbd->dev.ledbit[0] = BIT(LED_NUML) | BIT(LED_CAPSL) | BIT(LED_SCROLLL);	}	if (atkbd->extra)		atkbd->dev.ledbit[0] |= BIT(LED_COMPOSE) | BIT(LED_SUSPEND) |					BIT(LED_SLEEP) | BIT(LED_MUTE) | BIT(LED_MISC);	if (!atkbd->softrepeat) {		atkbd->dev.rep[REP_DELAY] = 250;		atkbd->dev.rep[REP_PERIOD] = 33;	}	atkbd->dev.mscbit[0] = atkbd->softraw ? BIT(MSC_SCAN) : BIT(MSC_RAW) | BIT(MSC_SCAN);	if (atkbd->scroll) {		atkbd->dev.evbit[0] |= BIT(EV_REL);		atkbd->dev.relbit[0] = BIT(REL_WHEEL) | BIT(REL_HWHEEL);		set_bit(BTN_MIDDLE, atkbd->dev.keybit);	}	atkbd->dev.keycode = atkbd->keycode;	atkbd->dev.keycodesize = sizeof(unsigned char);	atkbd->dev.keycodemax = ARRAY_SIZE(atkbd_set2_keycode);	for (i = 0; i < 512; i++)		if (atkbd->keycode[i] && atkbd->keycode[i] < ATKBD_SPECIAL)			set_bit(atkbd->keycode[i], atkbd->dev.keybit);}/* * atkbd_connect() is called when the serio module finds an interface * that isn't handled yet by an appropriate device driver. We check if * there is an AT keyboard out there and if yes, we register ourselves * to the input module. */static int atkbd_connect(struct serio *serio, struct serio_driver *drv){	struct atkbd *atkbd;	int err;	if (!(atkbd = kmalloc(sizeof(struct atkbd), GFP_KERNEL)))		return - ENOMEM;	memset(atkbd, 0, sizeof(struct atkbd));	ps2_init(&atkbd->ps2dev, serio);	switch (serio->id.type) {		case SERIO_8042_XL:			atkbd->translated = 1;		case SERIO_8042:			if (serio->write)				atkbd->write = 1;			break;	}	atkbd->softraw = atkbd_softraw;	atkbd->softrepeat = atkbd_softrepeat;	atkbd->scroll = atkbd_scroll;	if (!atkbd->write)		atkbd->softrepeat = 1;	if (atkbd->softrepeat)		atkbd->softraw = 1;	serio_set_drvdata(serio, atkbd);	err = serio_open(serio, drv);	if (err) {		serio_set_drvdata(serio, NULL);		kfree(atkbd);		return err;	}	if (atkbd->write) {		if (atkbd_probe(atkbd)) {			serio_close(serio);			serio_set_drvdata(serio, NULL);			kfree(atkbd);			return -ENODEV;		}		atkbd->set = atkbd_select_set(atkbd, atkbd_set, atkbd_extra);		atkbd_activate(atkbd);	} else {		atkbd->set = 2;		atkbd->id = 0xab00;	}	if (atkbd->extra)		sprintf(atkbd->name, "AT Set 2 Extra keyboard");	else		sprintf(atkbd->name, "AT %s Set %d keyboard",			atkbd->translated ? "Translated" : "Raw", atkbd->set);	sprintf(atkbd->phys, "%s/input0", serio->phys);	atkbd_set_keycode_table(atkbd);	atkbd_set_device_attrs(atkbd);	input_register_device(&atkbd->dev);	device_create_file(&serio->dev, &atkbd_attr_extra);	device_create_file(&serio->dev, &atkbd_attr_scroll);	device_create_file(&serio->dev, &atkbd_attr_set);	device_create_file(&serio->dev, &atkbd_attr_softrepeat);	device_create_file(&serio->dev, &atkbd_attr_softraw);	atkbd_enable(atkbd);	printk(KERN_INFO "input: %s on %s\n", atkbd->name, serio->phys);	return 0;}/* * atkbd_reconnect() tries to restore keyboard into a sane state and is * most likely called on resume. */static int atkbd_reconnect(struct serio *serio){	struct atkbd *atkbd = serio_get_drvdata(serio);	struct serio_driver *drv = serio->drv;	unsigned char param[1];	if (!atkbd || !drv) {		printk(KERN_DEBUG "atkbd: reconnect request, but serio is disconnected, ignoring...\n");		return -1;	}	atkbd_disable(atkbd);	if (atkbd->write) {		param[0] = (test_bit(LED_SCROLLL, atkbd->dev.led) ? 1 : 0)		         | (test_bit(LED_NUML,    atkbd->dev.led) ? 2 : 0)		         | (test_bit(LED_CAPSL,   atkbd->dev.led) ? 4 : 0);		if (atkbd_probe(atkbd))			return -1;		if (atkbd->set != atkbd_select_set(atkbd, atkbd->set, atkbd->extra))			return -1;		atkbd_activate(atkbd);		if (ps2_command(&atkbd->ps2dev, param, ATKBD_CMD_SETLEDS))			return -1;	}	atkbd_enable(atkbd);	return 0;}static struct serio_device_id atkbd_serio_ids[] = {	{		.type	= SERIO_8042,		.proto	= SERIO_ANY,		.id	= SERIO_ANY,		.extra	= SERIO_ANY,	},	{		.type	= SERIO_8042_XL,		.proto	= SERIO_ANY,		.id	= SERIO_ANY,		.extra	= SERIO_ANY,	},	{		.type	= SERIO_RS232,		.proto	= SERIO_PS2SER,		.id	= SERIO_ANY,		.extra	= SERIO_ANY,	},	{ 0 }};MODULE_DEVICE_TABLE(serio, atkbd_serio_ids);static struct serio_driver atkbd_drv = {	.driver		= {		.name	= "atkbd",	},	.description	= DRIVER_DESC,	.id_table	= atkbd_serio_ids,	.interrupt	= atkbd_interrupt,	.connect	= atkbd_connect,	.reconnect	= atkbd_reconnect,	.disconnect	= atkbd_disconnect,	.cleanup	= atkbd_cleanup,};static ssize_t atkbd_attr_show_helper(struct device *dev, char *buf,				ssize_t (*handler)(struct atkbd *, char *)){	struct serio *serio = to_serio_port(dev);	int retval;	retval = serio_pin_driver(serio);	if (retval)		return retval;	if (serio->drv != &atkbd_drv) {		retval = -ENODEV;		goto out;	}	retval = handler((struct atkbd *)serio_get_drvdata(serio), buf);out:	serio_unpin_driver(serio);	return retval;}static ssize_t atkbd_attr_set_helper(struct device *dev, const char *buf, size_t count,				ssize_t (*handler)(struct atkbd *, const char *, size_t)){	struct serio *serio = to_serio_port(dev);	struct atkbd *atkbd;	int retval;	retval = serio_pin_driver(serio);	if (retval)		return retval;	if (serio->drv != &atkbd_drv) {		retval = -ENODEV;		goto out;	}	atkbd = serio_get_drvdata(serio);	atkbd_disable(atkbd);	retval = handler(atkbd, buf, count);	atkbd_enable(atkbd);out:	serio_unpin_driver(serio);	return retval;}static ssize_t atkbd_show_extra(struct atkbd *atkbd, char *buf){	return sprintf(buf, "%d\n", atkbd->extra ? 1 : 0);}static ssize_t atkbd_set_extra(struct atkbd *atkbd, const char *buf, size_t count){	unsigned long value;	char *rest;	if (!atkbd->write)		return -EIO;	value = simple_strtoul(buf, &rest, 10);	if (*rest || value > 1)		return -EINVAL;	if (atkbd->extra != value) {		/* unregister device as it's properties will change */		input_unregister_device(&atkbd->dev);		atkbd->set = atkbd_select_set(atkbd, atkbd->set, value);		atkbd_activate(atkbd);		atkbd_set_device_attrs(atkbd);		input_register_device(&atkbd->dev);	}	return count;}static ssize_t atkbd_show_scroll(struct atkbd *atkbd, char *buf){	return sprintf(buf, "%d\n", atkbd->scroll ? 1 : 0);}static ssize_t atkbd_set_scroll(struct atkbd *atkbd, const char *buf, size_t count){	unsigned long value;	char *rest;	value = simple_strtoul(buf, &rest, 10);	if (*rest || value > 1)		return -EINVAL;	if (atkbd->scroll != value) {		/* unregister device as it's properties will change */		input_unregister_device(&atkbd->dev);		atkbd->scroll = value;		atkbd_set_keycode_table(atkbd);		atkbd_set_device_attrs(atkbd);		input_register_device(&atkbd->dev);	}	return count;}static ssize_t atkbd_show_set(struct atkbd *atkbd, char *buf){	return sprintf(buf, "%d\n", atkbd->set);}static ssize_t atkbd_set_set(struct atkbd *atkbd, const char *buf, size_t count){	unsigned long value;	char *rest;	if (!atkbd->write)		return -EIO;	value = simple_strtoul(buf, &rest, 10);	if (*rest || (value != 2 && value != 3))		return -EINVAL;	if (atkbd->set != value) {		/* unregister device as it's properties will change */		input_unregister_device(&atkbd->dev);		atkbd->set = atkbd_select_set(atkbd, value, atkbd->extra);		atkbd_activate(atkbd);		atkbd_set_keycode_table(atkbd);		atkbd_set_device_attrs(atkbd);		input_register_device(&atkbd->dev);	}	return count;}static ssize_t atkbd_show_softrepeat(struct atkbd *atkbd, char *buf){	return sprintf(buf, "%d\n", atkbd->softrepeat ? 1 : 0);}static ssize_t atkbd_set_softrepeat(struct atkbd *atkbd, const char *buf, size_t count){	unsigned long value;	char *rest;	if (!atkbd->write)		return -EIO;	value = simple_strtoul(buf, &rest, 10);	if (*rest || value > 1)		return -EINVAL;	if (atkbd->softrepeat != value) {		/* unregister device as it's properties will change */		input_unregister_device(&atkbd->dev);		atkbd->softrepeat = value;		if (atkbd->softrepeat)			atkbd->softraw = 1;		atkbd_set_device_attrs(atkbd);		input_register_device(&atkbd->dev);	}	return count;}static ssize_t atkbd_show_softraw(struct atkbd *atkbd, char *buf){	return sprintf(buf, "%d\n", atkbd->softraw ? 1 : 0);}static ssize_t atkbd_set_softraw(struct atkbd *atkbd, const char *buf, size_t count){	unsigned long value;	char *rest;	value = simple_strtoul(buf, &rest, 10);	if (*rest || value > 1)		return -EINVAL;	if (atkbd->softraw != value) {		/* unregister device as it's properties will change */		input_unregister_device(&atkbd->dev);		atkbd->softraw = value;		atkbd_set_device_attrs(atkbd);		input_register_device(&atkbd->dev);	}	return count;}static int __init atkbd_init(void){	serio_register_driver(&atkbd_drv);	return 0;}static void __exit atkbd_exit(void){	serio_unregister_driver(&atkbd_drv);}module_init(atkbd_init);module_exit(atkbd_exit);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区四区蜜桃| 久久成人综合网| 日韩欧美激情四射| 91亚洲大成网污www| 国产一区二区三区在线观看精品| 亚洲色图制服丝袜| 精品久久久久一区| 欧美日韩精品高清| 色素色在线综合| 国产成人自拍高清视频在线免费播放 | 国产电影一区在线| 日韩极品在线观看| 国产精品高潮呻吟久久| 日韩精品一区二区三区在线观看 | 日韩欧美一区在线观看| 色综合久久综合网| 成人教育av在线| 韩国中文字幕2020精品| 五月天亚洲精品| 亚洲一区av在线| 亚洲美女屁股眼交3| 国产精品久久久久久妇女6080| 日韩精品一区二区三区四区视频 | 欧美国产一区在线| 欧美哺乳videos| 欧美一级国产精品| 91精品综合久久久久久| 欧美性大战久久久久久久蜜臀| av电影一区二区| 成人精品gif动图一区| 国产凹凸在线观看一区二区| 国产在线一区观看| 精品亚洲国产成人av制服丝袜| 麻豆一区二区99久久久久| 日韩av一区二区在线影视| 午夜久久久影院| 午夜精品福利一区二区蜜股av| 亚洲午夜免费电影| 亚洲成人动漫在线免费观看| 一区二区三区国产精品| 亚洲综合清纯丝袜自拍| 亚洲观看高清完整版在线观看| 亚洲一区二区三区视频在线播放| 有码一区二区三区| 夜夜嗨av一区二区三区网页 | kk眼镜猥琐国模调教系列一区二区 | 日韩欧美精品三级| 久久综合色天天久久综合图片| 久久亚区不卡日本| 国产农村妇女精品| 国产精品电影院| 亚洲国产精品影院| 日产国产欧美视频一区精品| 久久国产欧美日韩精品| 国产精品88888| www.av亚洲| 久久婷婷综合激情| 国产日韩欧美一区二区三区乱码| 国产精品久久久一区麻豆最新章节| 国产精品高潮呻吟| 图片区小说区区亚洲影院| 美女看a上一区| 国产成人午夜精品5599| 99re热这里只有精品免费视频| 粉嫩aⅴ一区二区三区四区| 99精品国产视频| 欧美日韩性生活| 亚洲精品一区二区三区在线观看| 国产亚洲一区二区三区| 一区二区三区国产| 精品一区二区综合| 91在线观看美女| 91麻豆精品国产91久久久久久久久| 久久久久国产一区二区三区四区| 樱桃国产成人精品视频| 日本欧美在线看| 成人18精品视频| 欧美蜜桃一区二区三区| 久久精品综合网| 亚洲一级二级在线| 国产精品456| 欧美三级电影网站| 国产三级久久久| 亚洲成人高清在线| 不卡电影免费在线播放一区| 欧美色综合影院| 国产偷国产偷亚洲高清人白洁| 亚洲欧洲精品天堂一级 | 91婷婷韩国欧美一区二区| 制服.丝袜.亚洲.中文.综合| 国产精品蜜臀在线观看| 亚洲成人你懂的| 成人国产精品视频| 精品久久免费看| 亚洲午夜久久久久中文字幕久| 高清久久久久久| 欧美一区二区在线播放| 亚洲欧洲综合另类| 国产99久久久精品| 91精选在线观看| 亚洲一区二区三区四区中文字幕| 粉嫩av一区二区三区在线播放| 日韩午夜三级在线| 亚洲国产毛片aaaaa无费看| 成人激情校园春色| 久久久美女艺术照精彩视频福利播放| 亚洲国产成人va在线观看天堂| k8久久久一区二区三区 | 亚洲精品v日韩精品| 国产一区91精品张津瑜| 国产精品你懂的在线欣赏| 蜜臀av一区二区在线观看| 在线观看一区二区视频| 综合分类小说区另类春色亚洲小说欧美 | 日韩欧美久久久| 亚洲午夜电影在线观看| 成人aa视频在线观看| 国产婷婷色一区二区三区四区| 日本aⅴ精品一区二区三区 | 成人一区二区三区视频在线观看| 91精品国产一区二区三区香蕉| 亚洲综合色噜噜狠狠| 色综合久久久网| 亚洲精品日产精品乱码不卡| 成人av电影免费观看| 国产欧美精品一区二区三区四区 | 成人18视频在线播放| 久久久国产精品午夜一区ai换脸| 日本va欧美va瓶| 日韩欧美一区二区视频| 蜜桃在线一区二区三区| 91精品欧美福利在线观看| 天天综合色天天综合| 91精品国产乱码久久蜜臀| 日韩国产成人精品| 91精品国产综合久久婷婷香蕉| 秋霞午夜鲁丝一区二区老狼| 欧美一区二区福利视频| 免费一级片91| 久久久亚洲高清| 丁香六月久久综合狠狠色| 国产精品污污网站在线观看| 成人午夜在线视频| 亚洲视频你懂的| 欧美日韩在线观看一区二区| 丝袜脚交一区二区| 精品国一区二区三区| 国产a精品视频| 国产精品白丝在线| 欧美性xxxxx极品少妇| 三级精品在线观看| 久久久久久久久久久99999| 丁香亚洲综合激情啪啪综合| 亚洲少妇30p| 91麻豆精品国产自产在线观看一区| 久久99国产精品免费网站| 日本一区二区视频在线观看| 99久久精品国产观看| 亚洲成年人网站在线观看| 日韩欧美电影一区| 成人小视频免费在线观看| 亚洲综合色视频| 欧美成人在线直播| 日韩欧美在线一区二区三区| 极品少妇一区二区| 中文字幕中文乱码欧美一区二区| 色又黄又爽网站www久久| 日本vs亚洲vs韩国一区三区二区| 久久嫩草精品久久久精品一| 91亚洲精品久久久蜜桃| 日韩成人午夜电影| 国产精品久久久爽爽爽麻豆色哟哟| 欧美午夜免费电影| 国产一区欧美二区| 一片黄亚洲嫩模| 国产午夜精品理论片a级大结局| 97久久超碰国产精品电影| 日韩av电影一区| 国产精品不卡一区| 欧美xingq一区二区| 91网站最新地址| 美国十次综合导航| 亚洲欧美偷拍卡通变态| 精品国产91乱码一区二区三区| 91小视频在线免费看| 国内精品视频一区二区三区八戒| 亚洲精品视频在线观看网站| 精品福利一区二区三区 | 久久久久久久av麻豆果冻| 在线亚洲精品福利网址导航| 国产一区二区三区久久久| 亚洲一区在线观看免费| 欧美国产丝袜视频| 91精品国产丝袜白色高跟鞋| 99精品视频在线观看| 国内成人免费视频| 日本人妖一区二区| 亚洲影院理伦片| 亚洲欧美日韩国产综合在线 | 精品国产青草久久久久福利|