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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ps2.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * QEMU PS/2 keyboard/mouse emulation * * Copyright (c) 2003 Fabrice Bellard * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */#include "hw.h"#include "ps2.h"#include "console.h"/* debug PC keyboard *///#define DEBUG_KBD/* debug PC keyboard : only mouse *///#define DEBUG_MOUSE/* Keyboard Commands */#define KBD_CMD_SET_LEDS	0xED	/* Set keyboard leds */#define KBD_CMD_ECHO     	0xEE#define KBD_CMD_GET_ID 	        0xF2	/* get keyboard ID */#define KBD_CMD_SET_RATE	0xF3	/* Set typematic rate */#define KBD_CMD_ENABLE		0xF4	/* Enable scanning */#define KBD_CMD_RESET_DISABLE	0xF5	/* reset and disable scanning */#define KBD_CMD_RESET_ENABLE   	0xF6    /* reset and enable 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 *//* Mouse Commands */#define AUX_SET_SCALE11		0xE6	/* Set 1:1 scaling */#define AUX_SET_SCALE21		0xE7	/* Set 2:1 scaling */#define AUX_SET_RES		0xE8	/* Set resolution */#define AUX_GET_SCALE		0xE9	/* Get scaling factor */#define AUX_SET_STREAM		0xEA	/* Set stream mode */#define AUX_POLL		0xEB	/* Poll */#define AUX_RESET_WRAP		0xEC	/* Reset wrap mode */#define AUX_SET_WRAP		0xEE	/* Set wrap mode */#define AUX_SET_REMOTE		0xF0	/* Set remote mode */#define AUX_GET_TYPE		0xF2	/* Get type */#define AUX_SET_SAMPLE		0xF3	/* Set sample rate */#define AUX_ENABLE_DEV		0xF4	/* Enable aux device */#define AUX_DISABLE_DEV		0xF5	/* Disable aux device */#define AUX_SET_DEFAULT		0xF6#define AUX_RESET		0xFF	/* Reset aux device */#define AUX_ACK			0xFA	/* Command byte ACK. */#define MOUSE_STATUS_REMOTE     0x40#define MOUSE_STATUS_ENABLED    0x20#define MOUSE_STATUS_SCALE21    0x10#define PS2_QUEUE_SIZE 256typedef struct {    uint8_t data[PS2_QUEUE_SIZE];    int rptr, wptr, count;} PS2Queue;typedef struct {    PS2Queue queue;    int32_t write_cmd;    void (*update_irq)(void *, int);    void *update_arg;} PS2State;typedef struct {    PS2State common;    int scan_enabled;    /* Qemu uses translated PC scancodes internally.  To avoid multiple       conversions we do the translation (if any) in the PS/2 emulation       not the keyboard controller.  */    int translate;} PS2KbdState;typedef struct {    PS2State common;    uint8_t mouse_status;    uint8_t mouse_resolution;    uint8_t mouse_sample_rate;    uint8_t mouse_wrap;    uint8_t mouse_type; /* 0 = PS2, 3 = IMPS/2, 4 = IMEX */    uint8_t mouse_detect_state;    int mouse_dx; /* current values, needed for 'poll' mode */    int mouse_dy;    int mouse_dz;    uint8_t mouse_buttons;} PS2MouseState;/* Table to convert from PC scancodes to raw scancodes.  */static const unsigned char ps2_raw_keycode[128] = {          0,118, 22, 30, 38, 37, 46, 54, 61, 62, 70, 69, 78, 85,102, 13,         21, 29, 36, 45, 44, 53, 60, 67, 68, 77, 84, 91, 90, 20, 28, 27,         35, 43, 52, 51, 59, 66, 75, 76, 82, 14, 18, 93, 26, 34, 33, 42,         50, 49, 58, 65, 73, 74, 89,124, 17, 41, 88,  5,  6,  4, 12,  3,         11,  2, 10,  1,  9,119,126,108,117,125,123,107,115,116,121,105,        114,122,112,113,127, 96, 97,120,  7, 15, 23, 31, 39, 47, 55, 63,         71, 79, 86, 94,  8, 16, 24, 32, 40, 48, 56, 64, 72, 80, 87,111,         19, 25, 57, 81, 83, 92, 95, 98, 99,100,101,103,104,106,109,110};void ps2_queue(void *opaque, int b){    PS2State *s = (PS2State *)opaque;    PS2Queue *q = &s->queue;    if (q->count >= PS2_QUEUE_SIZE)        return;    q->data[q->wptr] = b;    if (++q->wptr == PS2_QUEUE_SIZE)        q->wptr = 0;    q->count++;    s->update_irq(s->update_arg, 1);}static void ps2_put_keycode(void *opaque, int keycode){    PS2KbdState *s = opaque;    if (!s->translate && keycode < 0xe0)      {        if (keycode & 0x80)            ps2_queue(&s->common, 0xf0);        keycode = ps2_raw_keycode[keycode & 0x7f];      }    ps2_queue(&s->common, keycode);}uint32_t ps2_read_data(void *opaque){    PS2State *s = (PS2State *)opaque;    PS2Queue *q;    int val, index;    q = &s->queue;    if (q->count == 0) {        /* NOTE: if no data left, we return the last keyboard one           (needed for EMM386) */        /* XXX: need a timer to do things correctly */        index = q->rptr - 1;        if (index < 0)            index = PS2_QUEUE_SIZE - 1;        val = q->data[index];    } else {        val = q->data[q->rptr];        if (++q->rptr == PS2_QUEUE_SIZE)            q->rptr = 0;        q->count--;        /* reading deasserts IRQ */        s->update_irq(s->update_arg, 0);        /* reassert IRQs if data left */        s->update_irq(s->update_arg, q->count != 0);    }    return val;}static void ps2_reset_keyboard(PS2KbdState *s){    s->scan_enabled = 1;}void ps2_write_keyboard(void *opaque, int val){    PS2KbdState *s = (PS2KbdState *)opaque;    switch(s->common.write_cmd) {    default:    case -1:        switch(val) {        case 0x00:            ps2_queue(&s->common, KBD_REPLY_ACK);            break;        case 0x05:            ps2_queue(&s->common, KBD_REPLY_RESEND);            break;        case KBD_CMD_GET_ID:            ps2_queue(&s->common, KBD_REPLY_ACK);            ps2_queue(&s->common, 0xab);            ps2_queue(&s->common, 0x83);            break;        case KBD_CMD_ECHO:            ps2_queue(&s->common, KBD_CMD_ECHO);            break;        case KBD_CMD_ENABLE:            s->scan_enabled = 1;            ps2_queue(&s->common, KBD_REPLY_ACK);            break;        case KBD_CMD_SET_LEDS:        case KBD_CMD_SET_RATE:            s->common.write_cmd = val;            ps2_queue(&s->common, KBD_REPLY_ACK);            break;        case KBD_CMD_RESET_DISABLE:            ps2_reset_keyboard(s);            s->scan_enabled = 0;            ps2_queue(&s->common, KBD_REPLY_ACK);            break;        case KBD_CMD_RESET_ENABLE:            ps2_reset_keyboard(s);            s->scan_enabled = 1;            ps2_queue(&s->common, KBD_REPLY_ACK);            break;        case KBD_CMD_RESET:            ps2_reset_keyboard(s);            ps2_queue(&s->common, KBD_REPLY_ACK);            ps2_queue(&s->common, KBD_REPLY_POR);            break;        default:            ps2_queue(&s->common, KBD_REPLY_ACK);            break;        }        break;    case KBD_CMD_SET_LEDS:        ps2_queue(&s->common, KBD_REPLY_ACK);        s->common.write_cmd = -1;        break;    case KBD_CMD_SET_RATE:        ps2_queue(&s->common, KBD_REPLY_ACK);        s->common.write_cmd = -1;        break;    }}/* Set the scancode translation mode.   0 = raw scancodes.   1 = translated scancodes (used by qemu internally).  */void ps2_keyboard_set_translation(void *opaque, int mode){    PS2KbdState *s = (PS2KbdState *)opaque;    s->translate = mode;}static void ps2_mouse_send_packet(PS2MouseState *s){    unsigned int b;    int dx1, dy1, dz1;    dx1 = s->mouse_dx;    dy1 = s->mouse_dy;    dz1 = s->mouse_dz;    /* XXX: increase range to 8 bits ? */    if (dx1 > 127)        dx1 = 127;    else if (dx1 < -127)        dx1 = -127;    if (dy1 > 127)        dy1 = 127;    else if (dy1 < -127)        dy1 = -127;    b = 0x08 | ((dx1 < 0) << 4) | ((dy1 < 0) << 5) | (s->mouse_buttons & 0x07);    ps2_queue(&s->common, b);    ps2_queue(&s->common, dx1 & 0xff);    ps2_queue(&s->common, dy1 & 0xff);    /* extra byte for IMPS/2 or IMEX */    switch(s->mouse_type) {    default:        break;    case 3:        if (dz1 > 127)            dz1 = 127;        else if (dz1 < -127)                dz1 = -127;        ps2_queue(&s->common, dz1 & 0xff);        break;    case 4:        if (dz1 > 7)            dz1 = 7;        else if (dz1 < -7)            dz1 = -7;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品青草综合久久久久99| 亚洲国产精品一区二区www在线| 亚洲欧美日韩综合aⅴ视频| 天天操天天综合网| 99re亚洲国产精品| 日韩女优毛片在线| 亚洲一二三四区| 成人午夜精品一区二区三区| 日韩欧美亚洲国产另类| 一级中文字幕一区二区| a级高清视频欧美日韩| 久久久久99精品一区| 免费观看日韩av| 欧美日韩高清不卡| 一二三四社区欧美黄| 99久久综合99久久综合网站| 久久久久久电影| 国产一区二区0| 精品国产乱码久久久久久久| 日韩制服丝袜先锋影音| 欧美色图片你懂的| 一区二区三区在线视频免费| 成人美女视频在线看| 国产日韩欧美综合在线| 久久不见久久见免费视频7| 91精品国产aⅴ一区二区| 亚洲电影中文字幕在线观看| 欧美日韩三级一区| 亚洲va中文字幕| 欧美精选午夜久久久乱码6080| 一区二区三区四区视频精品免费| 99久久综合国产精品| 亚洲欧美日韩一区二区 | 激情欧美日韩一区二区| 欧美一区二区精美| 蜜臀av一级做a爰片久久| 91精品国产乱| 韩国v欧美v亚洲v日本v| 国产婷婷色一区二区三区四区| 国产精品99久久久久久有的能看| 久久色在线观看| 丰满放荡岳乱妇91ww| 一区在线中文字幕| 在线一区二区三区四区五区| 亚洲精品国产无天堂网2021| 欧美日韩一区二区在线视频| 午夜精品123| 日韩欧美激情四射| 国产传媒一区在线| 亚洲男人的天堂在线观看| 欧美亚洲国产怡红院影院| 天天操天天色综合| 欧美不卡一区二区| 懂色一区二区三区免费观看| 亚洲欧美一区二区三区极速播放 | 欧美日韩国产综合视频在线观看| 亚洲成av人综合在线观看| 欧美va亚洲va在线观看蝴蝶网| 国产一区二区伦理| 亚洲精品免费播放| 777a∨成人精品桃花网| 黑人巨大精品欧美一区| 综合在线观看色| 欧美一区二区三区系列电影| 懂色av一区二区夜夜嗨| 亚洲国产成人91porn| 久久蜜桃香蕉精品一区二区三区| 99热这里都是精品| 久久精品国内一区二区三区| 国产精品丝袜在线| 欧美日韩成人综合| 成人黄色小视频| 美女诱惑一区二区| 亚洲免费观看高清完整版在线| 在线播放日韩导航| 91视视频在线直接观看在线看网页在线看| 亚洲成人中文在线| 中文字幕av一区 二区| 91精品久久久久久久91蜜桃| 99视频一区二区三区| 狠狠久久亚洲欧美| 午夜精品影院在线观看| 国产精品第一页第二页第三页| 欧美精品久久99| 色屁屁一区二区| 高清久久久久久| 韩国精品主播一区二区在线观看| 亚洲一区在线观看网站| 中文字幕在线一区免费| 精品国产三级a在线观看| 欧美伊人久久久久久久久影院 | 日本精品视频一区二区三区| 日韩高清不卡一区二区三区| 欧美三级电影网| 亚洲欧洲无码一区二区三区| 精品午夜一区二区三区在线观看| 亚洲色图视频免费播放| 久久天堂av综合合色蜜桃网| 欧美一级精品大片| 欧美四级电影网| 欧美在线观看视频一区二区| www.亚洲精品| 大白屁股一区二区视频| 国产乱码精品一区二区三区忘忧草 | 一区二区三区国产豹纹内裤在线| 国产欧美日韩综合| 久久久久久久久伊人| 欧美一级淫片007| 欧美一级国产精品| 欧美一区二区视频在线观看2022| 欧美日韩精品电影| 欧美日韩中文另类| 欧美美女一区二区| 欧美色爱综合网| 欧美视频三区在线播放| 欧美日韩的一区二区| 欧美人xxxx| 丁香婷婷综合激情五月色| 亚洲高清在线视频| 亚洲一卡二卡三卡四卡无卡久久| 欧美日韩和欧美的一区二区| 精品视频在线看| 欧美色综合久久| 91精品国产品国语在线不卡| 欧美乱妇15p| 欧美xxxxx牲另类人与| 欧美大片国产精品| 国产欧美一区二区在线| 中文字幕巨乱亚洲| 亚洲天堂福利av| 无吗不卡中文字幕| 久久97超碰国产精品超碰| 国产一区日韩二区欧美三区| 国产aⅴ综合色| 成人中文字幕在线| 日本精品一区二区三区四区的功能| 色999日韩国产欧美一区二区| 欧美日韩一区二区三区在线看| 欧美高清视频在线高清观看mv色露露十八| 91精品婷婷国产综合久久性色| 日韩免费一区二区三区在线播放| 精品福利一区二区三区| 中文字幕中文在线不卡住| 亚洲成av人片一区二区梦乃| 午夜不卡在线视频| 国产精品一二三区| 欧美亚洲动漫另类| 国产喂奶挤奶一区二区三区| 夜色激情一区二区| 国产资源精品在线观看| 99久久久久久| 日韩免费一区二区| 亚洲精品五月天| 精品一区二区免费在线观看| aa级大片欧美| 日韩三级免费观看| 亚洲人123区| 国产在线精品免费| 欧美亚洲国产一区二区三区va| 久久久不卡影院| 亚洲mv在线观看| 99久久免费视频.com| 日韩欧美国产麻豆| 一区二区三区日韩欧美精品| 国产最新精品免费| 欧美精品色一区二区三区| 国产精品久久久久久久久晋中| 视频在线观看一区二区三区| 成人国产精品免费观看动漫| 日韩三级在线免费观看| 一区二区三区波多野结衣在线观看| 国产精品18久久久久| 欧美一区二区网站| 亚洲成a天堂v人片| 91视频在线观看免费| 国产亚洲欧美色| 国内精品免费在线观看| 欧美一区在线视频| 亚洲国产视频网站| 色域天天综合网| 国产精品福利电影一区二区三区四区| 麻豆极品一区二区三区| 欧美人成免费网站| 亚洲国产人成综合网站| 91免费版在线看| 国产精品亲子乱子伦xxxx裸| 国产精品一区二区在线观看不卡 | 国产成人一区二区精品非洲| 欧美一级爆毛片| 五月天亚洲婷婷| 制服丝袜av成人在线看| 亚洲自拍偷拍图区| 在线精品视频免费观看| 亚洲视频狠狠干| 一本色道久久综合狠狠躁的推荐| 中文字幕+乱码+中文字幕一区| 国产麻豆欧美日韩一区| 久久麻豆一区二区| 国产一区二区三区蝌蚪| 欧美精品一区二区三区在线|