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

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

?? usb-uhci.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * USB UHCI controller emulation * * Copyright (c) 2005 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 "usb.h"#include "pci.h"#include "qemu-timer.h"//#define DEBUG//#define DEBUG_PACKET//#define DEBUG_ISOCH#define UHCI_CMD_FGR      (1 << 4)#define UHCI_CMD_EGSM     (1 << 3)#define UHCI_CMD_GRESET   (1 << 2)#define UHCI_CMD_HCRESET  (1 << 1)#define UHCI_CMD_RS       (1 << 0)#define UHCI_STS_HCHALTED (1 << 5)#define UHCI_STS_HCPERR   (1 << 4)#define UHCI_STS_HSERR    (1 << 3)#define UHCI_STS_RD       (1 << 2)#define UHCI_STS_USBERR   (1 << 1)#define UHCI_STS_USBINT   (1 << 0)#define TD_CTRL_SPD     (1 << 29)#define TD_CTRL_ERROR_SHIFT  27#define TD_CTRL_IOS     (1 << 25)#define TD_CTRL_IOC     (1 << 24)#define TD_CTRL_ACTIVE  (1 << 23)#define TD_CTRL_STALL   (1 << 22)#define TD_CTRL_BABBLE  (1 << 20)#define TD_CTRL_NAK     (1 << 19)#define TD_CTRL_TIMEOUT (1 << 18)#define UHCI_PORT_RESET (1 << 9)#define UHCI_PORT_LSDA  (1 << 8)#define UHCI_PORT_ENC   (1 << 3)#define UHCI_PORT_EN    (1 << 2)#define UHCI_PORT_CSC   (1 << 1)#define UHCI_PORT_CCS   (1 << 0)#define FRAME_TIMER_FREQ 1000#define FRAME_MAX_LOOPS  100#define NB_PORTS 2typedef struct UHCIPort {    USBPort port;    uint16_t ctrl;} UHCIPort;typedef struct UHCIState {    PCIDevice dev;    uint16_t cmd; /* cmd register */    uint16_t status;    uint16_t intr; /* interrupt enable register */    uint16_t frnum; /* frame number */    uint32_t fl_base_addr; /* frame list base address */    uint8_t sof_timing;    uint8_t status2; /* bit 0 and 1 are used to generate UHCI_STS_USBINT */    QEMUTimer *frame_timer;    UHCIPort ports[NB_PORTS];    /* Interrupts that should be raised at the end of the current frame.  */    uint32_t pending_int_mask;    /* For simplicity of implementation we only allow a single pending USB       request.  This means all usb traffic on this controller is effectively       suspended until that transfer completes.  When the transfer completes       the next transfer from that queue will be processed.  However       other queues will not be processed until the next frame.  The solution       is to allow multiple pending requests.  */    uint32_t async_qh;    uint32_t async_frame_addr;    USBPacket usb_packet;    uint8_t usb_buf[2048];} UHCIState;typedef struct UHCI_TD {    uint32_t link;    uint32_t ctrl; /* see TD_CTRL_xxx */    uint32_t token;    uint32_t buffer;} UHCI_TD;typedef struct UHCI_QH {    uint32_t link;    uint32_t el_link;} UHCI_QH;static void uhci_attach(USBPort *port1, USBDevice *dev);static void uhci_update_irq(UHCIState *s){    int level;    if (((s->status2 & 1) && (s->intr & (1 << 2))) ||        ((s->status2 & 2) && (s->intr & (1 << 3))) ||        ((s->status & UHCI_STS_USBERR) && (s->intr & (1 << 0))) ||        ((s->status & UHCI_STS_RD) && (s->intr & (1 << 1))) ||        (s->status & UHCI_STS_HSERR) ||        (s->status & UHCI_STS_HCPERR)) {        level = 1;    } else {        level = 0;    }    qemu_set_irq(s->dev.irq[3], level);}static void uhci_reset(UHCIState *s){    uint8_t *pci_conf;    int i;    UHCIPort *port;    pci_conf = s->dev.config;    pci_conf[0x6a] = 0x01; /* usb clock */    pci_conf[0x6b] = 0x00;    s->cmd = 0;    s->status = 0;    s->status2 = 0;    s->intr = 0;    s->fl_base_addr = 0;    s->sof_timing = 64;    for(i = 0; i < NB_PORTS; i++) {        port = &s->ports[i];        port->ctrl = 0x0080;        if (port->port.dev)            uhci_attach(&port->port, port->port.dev);    }}#if 0static void uhci_save(QEMUFile *f, void *opaque){    UHCIState *s = opaque;    uint8_t num_ports = NB_PORTS;    int i;    pci_device_save(&s->dev, f);    qemu_put_8s(f, &num_ports);    for (i = 0; i < num_ports; ++i)        qemu_put_be16s(f, &s->ports[i].ctrl);    qemu_put_be16s(f, &s->cmd);    qemu_put_be16s(f, &s->status);    qemu_put_be16s(f, &s->intr);    qemu_put_be16s(f, &s->frnum);    qemu_put_be32s(f, &s->fl_base_addr);    qemu_put_8s(f, &s->sof_timing);    qemu_put_8s(f, &s->status2);    qemu_put_timer(f, s->frame_timer);}static int uhci_load(QEMUFile *f, void *opaque, int version_id){    UHCIState *s = opaque;    uint8_t num_ports;    int i, ret;    if (version_id > 1)        return -EINVAL;    ret = pci_device_load(&s->dev, f);    if (ret < 0)        return ret;    qemu_get_8s(f, &num_ports);    if (num_ports != NB_PORTS)        return -EINVAL;    for (i = 0; i < num_ports; ++i)        qemu_get_be16s(f, &s->ports[i].ctrl);    qemu_get_be16s(f, &s->cmd);    qemu_get_be16s(f, &s->status);    qemu_get_be16s(f, &s->intr);    qemu_get_be16s(f, &s->frnum);    qemu_get_be32s(f, &s->fl_base_addr);    qemu_get_8s(f, &s->sof_timing);    qemu_get_8s(f, &s->status2);    qemu_get_timer(f, s->frame_timer);    return 0;}#endifstatic void uhci_ioport_writeb(void *opaque, uint32_t addr, uint32_t val){    UHCIState *s = opaque;    addr &= 0x1f;    switch(addr) {    case 0x0c:        s->sof_timing = val;        break;    }}static uint32_t uhci_ioport_readb(void *opaque, uint32_t addr){    UHCIState *s = opaque;    uint32_t val;    addr &= 0x1f;    switch(addr) {    case 0x0c:        val = s->sof_timing;        break;    default:        val = 0xff;        break;    }    return val;}static void uhci_ioport_writew(void *opaque, uint32_t addr, uint32_t val){    UHCIState *s = opaque;    addr &= 0x1f;#ifdef DEBUG    printf("uhci writew port=0x%04x val=0x%04x\n", addr, val);#endif    switch(addr) {    case 0x00:        if ((val & UHCI_CMD_RS) && !(s->cmd & UHCI_CMD_RS)) {            /* start frame processing */            qemu_mod_timer(s->frame_timer, qemu_get_clock(vm_clock));            s->status &= ~UHCI_STS_HCHALTED;        } else if (!(val & UHCI_CMD_RS)) {            s->status |= UHCI_STS_HCHALTED;        }        if (val & UHCI_CMD_GRESET) {            UHCIPort *port;            USBDevice *dev;            int i;            /* send reset on the USB bus */            for(i = 0; i < NB_PORTS; i++) {                port = &s->ports[i];                dev = port->port.dev;                if (dev) {                    usb_send_msg(dev, USB_MSG_RESET);                }            }            uhci_reset(s);            return;        }        if (val & UHCI_CMD_HCRESET) {            uhci_reset(s);            return;        }        s->cmd = val;        break;    case 0x02:        s->status &= ~val;        /* XXX: the chip spec is not coherent, so we add a hidden           register to distinguish between IOC and SPD */        if (val & UHCI_STS_USBINT)            s->status2 = 0;        uhci_update_irq(s);        break;    case 0x04:        s->intr = val;        uhci_update_irq(s);        break;    case 0x06:        if (s->status & UHCI_STS_HCHALTED)            s->frnum = val & 0x7ff;        break;    case 0x10 ... 0x1f:        {            UHCIPort *port;            USBDevice *dev;            int n;            n = (addr >> 1) & 7;            if (n >= NB_PORTS)                return;            port = &s->ports[n];            dev = port->port.dev;            if (dev) {                /* port reset */                if ( (val & UHCI_PORT_RESET) &&                     !(port->ctrl & UHCI_PORT_RESET) ) {                    usb_send_msg(dev, USB_MSG_RESET);                }            }            port->ctrl = (port->ctrl & 0x01fb) | (val & ~0x01fb);            /* some bits are reset when a '1' is written to them */            port->ctrl &= ~(val & 0x000a);        }        break;    }}static uint32_t uhci_ioport_readw(void *opaque, uint32_t addr){    UHCIState *s = opaque;    uint32_t val;    addr &= 0x1f;    switch(addr) {    case 0x00:        val = s->cmd;        break;    case 0x02:        val = s->status;        break;    case 0x04:        val = s->intr;        break;    case 0x06:        val = s->frnum;        break;    case 0x10 ... 0x1f:        {            UHCIPort *port;            int n;            n = (addr >> 1) & 7;            if (n >= NB_PORTS)                goto read_default;            port = &s->ports[n];            val = port->ctrl;        }        break;    default:    read_default:        val = 0xff7f; /* disabled port */        break;    }#ifdef DEBUG    printf("uhci readw port=0x%04x val=0x%04x\n", addr, val);#endif    return val;}static void uhci_ioport_writel(void *opaque, uint32_t addr, uint32_t val){    UHCIState *s = opaque;    addr &= 0x1f;#ifdef DEBUG    printf("uhci writel port=0x%04x val=0x%08x\n", addr, val);#endif    switch(addr) {    case 0x08:        s->fl_base_addr = val & ~0xfff;        break;    }}static uint32_t uhci_ioport_readl(void *opaque, uint32_t addr){    UHCIState *s = opaque;    uint32_t val;    addr &= 0x1f;    switch(addr) {    case 0x08:        val = s->fl_base_addr;        break;    default:        val = 0xffffffff;        break;    }    return val;}/* signal resume if controller suspended */static void uhci_resume (void *opaque){    UHCIState *s = (UHCIState *)opaque;    if (!s)        return;    if (s->cmd & UHCI_CMD_EGSM) {        s->cmd |= UHCI_CMD_FGR;        s->status |= UHCI_STS_RD;        uhci_update_irq(s);    }}static void uhci_attach(USBPort *port1, USBDevice *dev){    UHCIState *s = port1->opaque;    UHCIPort *port = &s->ports[port1->index];    if (dev) {        if (port->port.dev) {            usb_attach(port1, NULL);        }        /* set connect status */        port->ctrl |= UHCI_PORT_CCS | UHCI_PORT_CSC;        /* update speed */        if (dev->speed == USB_SPEED_LOW)            port->ctrl |= UHCI_PORT_LSDA;        else            port->ctrl &= ~UHCI_PORT_LSDA;        uhci_resume(s);        port->port.dev = dev;        /* send the attach message */        usb_send_msg(dev, USB_MSG_ATTACH);    } else {        /* set connect status */        if (port->ctrl & UHCI_PORT_CCS) {            port->ctrl &= ~UHCI_PORT_CCS;            port->ctrl |= UHCI_PORT_CSC;        }        /* disable port */        if (port->ctrl & UHCI_PORT_EN) {            port->ctrl &= ~UHCI_PORT_EN;            port->ctrl |= UHCI_PORT_ENC;        }        uhci_resume(s);        dev = port->port.dev;        if (dev) {            /* send the detach message */            usb_send_msg(dev, USB_MSG_DETACH);        }        port->port.dev = NULL;    }}static int uhci_broadcast_packet(UHCIState *s, USBPacket *p){    UHCIPort *port;    USBDevice *dev;    int i, ret;#ifdef DEBUG_PACKET    {        const char *pidstr;        switch(p->pid) {        case USB_TOKEN_SETUP: pidstr = "SETUP"; break;        case USB_TOKEN_IN: pidstr = "IN"; break;        case USB_TOKEN_OUT: pidstr = "OUT"; break;        default: pidstr = "?"; break;        }        printf("frame %d: pid=%s addr=0x%02x ep=%d len=%d\n",               s->frnum, pidstr, p->devaddr, p->devep, p->len);        if (p->pid != USB_TOKEN_IN) {            printf("     data_out=");            for(i = 0; i < p->len; i++) {                printf(" %02x", p->data[i]);            }            printf("\n");        }    }#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本韩国一区二区| 99在线精品免费| 天堂蜜桃91精品| 亚洲成人综合在线| 日韩综合小视频| 狠狠色丁香久久婷婷综| 国产精品99久久久久| 国产成都精品91一区二区三| 91在线视频免费观看| 欧美视频中文字幕| 国产婷婷色一区二区三区在线| 国产日本欧美一区二区| 亚洲精品美国一| 韩国欧美一区二区| 色综合色综合色综合| 欧美一区二区三区的| 日韩一区中文字幕| 秋霞午夜鲁丝一区二区老狼| 国产激情视频一区二区三区欧美 | 欧美一区二区三区免费| 久久久久久久久久久久电影| 亚洲伦理在线精品| 国产伦精品一区二区三区视频青涩 | 亚洲高清在线精品| 国产乱子伦一区二区三区国色天香| 不卡视频一二三| 精品国产乱码久久久久久老虎| 综合在线观看色| 国产精品99久| 日韩午夜中文字幕| 午夜激情一区二区| 色综合视频在线观看| 国产精品丝袜一区| 激情偷乱视频一区二区三区| 欧美日韩国产美| 亚洲一区成人在线| 在线亚洲免费视频| 亚洲激情自拍视频| 97精品久久久午夜一区二区三区 | 欧美一级黄色大片| 不卡大黄网站免费看| 国产香蕉久久精品综合网| 久久国产精品99久久久久久老狼| 欧美精品第1页| 免费黄网站欧美| 欧美一区二区观看视频| 久久激情五月激情| 久久久久亚洲综合| 91麻豆精品秘密| 亚洲一区二区视频在线观看| 欧洲色大大久久| 日本sm残虐另类| 中文字幕免费不卡| 色成年激情久久综合| 免费观看久久久4p| 国产精品丝袜一区| 91精品国产综合久久久久久久久久| 免费视频一区二区| 中文字幕二三区不卡| 欧美性猛交一区二区三区精品| 蜜桃视频一区二区三区| 国产精品三级在线观看| 在线不卡欧美精品一区二区三区| 奇米精品一区二区三区在线观看 | 亚洲国产一区视频| 精品久久五月天| 91国产免费看| 国产高清视频一区| 蜜桃在线一区二区三区| 亚洲精品国产无套在线观| 精品三级av在线| 欧美日韩情趣电影| 色噜噜狠狠成人中文综合| 国产精品一级二级三级| 免费人成精品欧美精品| 亚洲1区2区3区视频| 亚洲日本中文字幕区| 国产日韩高清在线| www欧美成人18+| 欧美电影免费观看高清完整版| 欧美日韩综合不卡| 欧美三级电影在线看| 99视频精品在线| 色综合久久综合网欧美综合网| 国产成人超碰人人澡人人澡| 国产一区二区调教| 国产精品18久久久久久久久 | 丝袜美腿亚洲色图| 性做久久久久久免费观看欧美| 亚洲另类在线视频| 亚洲国产欧美另类丝袜| 亚洲不卡一区二区三区| 天天色天天操综合| 久久99精品久久久久久国产越南 | 亚洲一区二区在线观看视频| 五月天网站亚洲| 国产一区二区精品久久99| 国产精品一区在线| 日本韩国精品一区二区在线观看| 91免费观看视频| 欧美成人免费网站| 中文字幕亚洲在| 天天爽夜夜爽夜夜爽精品视频 | 欧美变态tickle挠乳网站| 日本一区二区视频在线观看| 亚洲精品老司机| 老司机免费视频一区二区三区| 99久久99精品久久久久久| 欧美一区二区三区日韩| 中文字幕亚洲视频| 精品一区二区三区在线观看国产| eeuss鲁一区二区三区| 日韩一级免费一区| 亚洲国产欧美另类丝袜| 成人av先锋影音| 欧美精品一区二区三区高清aⅴ | 国产欧美日韩精品一区| 丝瓜av网站精品一区二区| 99精品视频在线免费观看| 欧美一级黄色大片| 日韩福利电影在线观看| 日本伦理一区二区| 日韩伦理av电影| 96av麻豆蜜桃一区二区| 国产精品丝袜91| 99精品欧美一区二区三区小说| 2021国产精品久久精品| 国产在线精品一区二区三区不卡 | 国产传媒日韩欧美成人| 欧美va亚洲va在线观看蝴蝶网| 丝袜诱惑制服诱惑色一区在线观看 | 一本一道综合狠狠老| 中文字幕一区二区三区视频| 成人app下载| 亚洲色图色小说| 欧美午夜宅男影院| 免费看精品久久片| 欧美国产精品专区| 日本精品一级二级| 亚洲18女电影在线观看| 国产精品久久网站| 99久久精品情趣| 日韩国产成人精品| 久久影院午夜片一区| www.日韩精品| 青青草97国产精品免费观看无弹窗版 | 欧美丰满一区二区免费视频| 免费高清视频精品| 中文av一区二区| 欧美三区在线观看| 国产一区二区在线看| 亚洲一区二区视频| 国产精品免费久久久久| 欧美日韩国产一级| 国产激情一区二区三区桃花岛亚洲| 亚洲婷婷综合色高清在线| 欧美电视剧免费全集观看| 日本福利一区二区| av在线免费不卡| 国产原创一区二区| 久久精品99国产精品| 亚洲一区视频在线| 中文字幕日韩一区| 亚洲精品一区二区三区99| 欧美丝袜丝交足nylons图片| 国产91丝袜在线播放九色| 蜜桃精品视频在线| 亚洲超碰精品一区二区| 夜夜嗨av一区二区三区四季av | 成人久久18免费网站麻豆| 精品一区二区三区久久久| 美日韩一区二区| 免费观看一级特黄欧美大片| 日韩国产高清在线| 五月婷婷综合网| 日韩精品一级中文字幕精品视频免费观看| 国产精品国产自产拍高清av| 中文字幕精品综合| 中文字幕在线不卡| 一区二区三区四区高清精品免费观看 | 一区二区成人在线观看| 亚洲精品乱码久久久久久日本蜜臀| 亚洲欧美二区三区| 午夜亚洲国产au精品一区二区| 午夜精品123| 国产一区二区三区| 97精品视频在线观看自产线路二| 91麻豆福利精品推荐| 欧美一级日韩不卡播放免费| 精品免费视频一区二区| 欧美国产一区在线| 亚洲综合丁香婷婷六月香| 日韩精品欧美精品| 国产成人av一区二区三区在线| fc2成人免费人成在线观看播放 | 秋霞成人午夜伦在线观看| 国产激情偷乱视频一区二区三区| 色婷婷国产精品综合在线观看| 欧美一区中文字幕| 亚洲黄色在线视频|