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

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

?? pxa2xx.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 5 頁
字號:
{    struct pxa2xx_i2c_s *s = (struct pxa2xx_i2c_s *) opaque;    addr -= s->base;    switch (addr) {    case ICR:        return s->control;    case ISR:        return s->status | (i2c_bus_busy(s->bus) << 2);    case ISAR:        return s->slave.address;    case IDBR:        return s->data;    case IBMR:        if (s->status & (1 << 2))            s->ibmr ^= 3;	/* Fake SCL and SDA pin changes */        else            s->ibmr = 0;        return s->ibmr;    default:        printf("%s: Bad register " REG_FMT "\n", __FUNCTION__, addr);        break;    }    return 0;}static void pxa2xx_i2c_write(void *opaque, target_phys_addr_t addr,                uint32_t value){    struct pxa2xx_i2c_s *s = (struct pxa2xx_i2c_s *) opaque;    int ack;    addr -= s->base;    switch (addr) {    case ICR:        s->control = value & 0xfff7;        if ((value & (1 << 3)) && (value & (1 << 6))) {	/* TB and IUE */            /* TODO: slave mode */            if (value & (1 << 0)) {			/* START condition */                if (s->data & 1)                    s->status |= 1 << 0;		/* set RWM */                else                    s->status &= ~(1 << 0);		/* clear RWM */                ack = !i2c_start_transfer(s->bus, s->data >> 1, s->data & 1);            } else {                if (s->status & (1 << 0)) {		/* RWM */                    s->data = i2c_recv(s->bus);                    if (value & (1 << 2))		/* ACKNAK */                        i2c_nack(s->bus);                    ack = 1;                } else                    ack = !i2c_send(s->bus, s->data);            }            if (value & (1 << 1))			/* STOP condition */                i2c_end_transfer(s->bus);            if (ack) {                if (value & (1 << 0))			/* START condition */                    s->status |= 1 << 6;		/* set ITE */                else                    if (s->status & (1 << 0))		/* RWM */                        s->status |= 1 << 7;		/* set IRF */                    else                        s->status |= 1 << 6;		/* set ITE */                s->status &= ~(1 << 1);			/* clear ACKNAK */            } else {                s->status |= 1 << 6;			/* set ITE */                s->status |= 1 << 10;			/* set BED */                s->status |= 1 << 1;			/* set ACKNAK */            }        }        if (!(value & (1 << 3)) && (value & (1 << 6)))	/* !TB and IUE */            if (value & (1 << 4))			/* MA */                i2c_end_transfer(s->bus);        pxa2xx_i2c_update(s);        break;    case ISR:        s->status &= ~(value & 0x07f0);        pxa2xx_i2c_update(s);        break;    case ISAR:        i2c_set_slave_address(&s->slave, value & 0x7f);        break;    case IDBR:        s->data = value & 0xff;        break;    default:        printf("%s: Bad register " REG_FMT "\n", __FUNCTION__, addr);    }}static CPUReadMemoryFunc *pxa2xx_i2c_readfn[] = {    pxa2xx_i2c_read,    pxa2xx_i2c_read,    pxa2xx_i2c_read,};static CPUWriteMemoryFunc *pxa2xx_i2c_writefn[] = {    pxa2xx_i2c_write,    pxa2xx_i2c_write,    pxa2xx_i2c_write,};static void pxa2xx_i2c_save(QEMUFile *f, void *opaque){    struct pxa2xx_i2c_s *s = (struct pxa2xx_i2c_s *) opaque;    qemu_put_be16s(f, &s->control);    qemu_put_be16s(f, &s->status);    qemu_put_8s(f, &s->ibmr);    qemu_put_8s(f, &s->data);    i2c_bus_save(f, s->bus);    i2c_slave_save(f, &s->slave);}static int pxa2xx_i2c_load(QEMUFile *f, void *opaque, int version_id){    struct pxa2xx_i2c_s *s = (struct pxa2xx_i2c_s *) opaque;    qemu_get_be16s(f, &s->control);    qemu_get_be16s(f, &s->status);    qemu_get_8s(f, &s->ibmr);    qemu_get_8s(f, &s->data);    i2c_bus_load(f, s->bus);    i2c_slave_load(f, &s->slave);    return 0;}struct pxa2xx_i2c_s *pxa2xx_i2c_init(target_phys_addr_t base,                qemu_irq irq, uint32_t page_size){    int iomemtype;    struct pxa2xx_i2c_s *s = (struct pxa2xx_i2c_s *)            i2c_slave_init(i2c_init_bus(), 0, sizeof(struct pxa2xx_i2c_s));    s->base = base;    s->irq = irq;    s->slave.event = pxa2xx_i2c_event;    s->slave.recv = pxa2xx_i2c_rx;    s->slave.send = pxa2xx_i2c_tx;    s->bus = i2c_init_bus();    iomemtype = cpu_register_io_memory(0, pxa2xx_i2c_readfn,                    pxa2xx_i2c_writefn, s);    cpu_register_physical_memory(s->base & ~page_size, page_size, iomemtype);    register_savevm("pxa2xx_i2c", base, 0,                    pxa2xx_i2c_save, pxa2xx_i2c_load, s);    return s;}i2c_bus *pxa2xx_i2c_bus(struct pxa2xx_i2c_s *s){    return s->bus;}/* PXA Inter-IC Sound Controller */static void pxa2xx_i2s_reset(struct pxa2xx_i2s_s *i2s){    i2s->rx_len = 0;    i2s->tx_len = 0;    i2s->fifo_len = 0;    i2s->clk = 0x1a;    i2s->control[0] = 0x00;    i2s->control[1] = 0x00;    i2s->status = 0x00;    i2s->mask = 0x00;}#define SACR_TFTH(val)	((val >> 8) & 0xf)#define SACR_RFTH(val)	((val >> 12) & 0xf)#define SACR_DREC(val)	(val & (1 << 3))#define SACR_DPRL(val)	(val & (1 << 4))static inline void pxa2xx_i2s_update(struct pxa2xx_i2s_s *i2s){    int rfs, tfs;    rfs = SACR_RFTH(i2s->control[0]) < i2s->rx_len &&            !SACR_DREC(i2s->control[1]);    tfs = (i2s->tx_len || i2s->fifo_len < SACR_TFTH(i2s->control[0])) &&            i2s->enable && !SACR_DPRL(i2s->control[1]);    pxa2xx_dma_request(i2s->dma, PXA2XX_RX_RQ_I2S, rfs);    pxa2xx_dma_request(i2s->dma, PXA2XX_TX_RQ_I2S, tfs);    i2s->status &= 0xe0;    if (i2s->fifo_len < 16 || !i2s->enable)        i2s->status |= 1 << 0;			/* TNF */    if (i2s->rx_len)        i2s->status |= 1 << 1;			/* RNE */    if (i2s->enable)        i2s->status |= 1 << 2;			/* BSY */    if (tfs)        i2s->status |= 1 << 3;			/* TFS */    if (rfs)        i2s->status |= 1 << 4;			/* RFS */    if (!(i2s->tx_len && i2s->enable))        i2s->status |= i2s->fifo_len << 8;	/* TFL */    i2s->status |= MAX(i2s->rx_len, 0xf) << 12;	/* RFL */    qemu_set_irq(i2s->irq, i2s->status & i2s->mask);}#define SACR0	0x00	/* Serial Audio Global Control register */#define SACR1	0x04	/* Serial Audio I2S/MSB-Justified Control register */#define SASR0	0x0c	/* Serial Audio Interface and FIFO Status register */#define SAIMR	0x14	/* Serial Audio Interrupt Mask register */#define SAICR	0x18	/* Serial Audio Interrupt Clear register */#define SADIV	0x60	/* Serial Audio Clock Divider register */#define SADR	0x80	/* Serial Audio Data register */static uint32_t pxa2xx_i2s_read(void *opaque, target_phys_addr_t addr){    struct pxa2xx_i2s_s *s = (struct pxa2xx_i2s_s *) opaque;    addr -= s->base;    switch (addr) {    case SACR0:        return s->control[0];    case SACR1:        return s->control[1];    case SASR0:        return s->status;    case SAIMR:        return s->mask;    case SAICR:        return 0;    case SADIV:        return s->clk;    case SADR:        if (s->rx_len > 0) {            s->rx_len --;            pxa2xx_i2s_update(s);            return s->codec_in(s->opaque);        }        return 0;    default:        printf("%s: Bad register " REG_FMT "\n", __FUNCTION__, addr);        break;    }    return 0;}static void pxa2xx_i2s_write(void *opaque, target_phys_addr_t addr,                uint32_t value){    struct pxa2xx_i2s_s *s = (struct pxa2xx_i2s_s *) opaque;    uint32_t *sample;    addr -= s->base;    switch (addr) {    case SACR0:        if (value & (1 << 3))				/* RST */            pxa2xx_i2s_reset(s);        s->control[0] = value & 0xff3d;        if (!s->enable && (value & 1) && s->tx_len) {	/* ENB */            for (sample = s->fifo; s->fifo_len > 0; s->fifo_len --, sample ++)                s->codec_out(s->opaque, *sample);            s->status &= ~(1 << 7);			/* I2SOFF */        }        if (value & (1 << 4))				/* EFWR */            printf("%s: Attempt to use special function\n", __FUNCTION__);        s->enable = ((value ^ 4) & 5) == 5;		/* ENB && !RST*/        pxa2xx_i2s_update(s);        break;    case SACR1:        s->control[1] = value & 0x0039;        if (value & (1 << 5))				/* ENLBF */            printf("%s: Attempt to use loopback function\n", __FUNCTION__);        if (value & (1 << 4))				/* DPRL */            s->fifo_len = 0;        pxa2xx_i2s_update(s);        break;    case SAIMR:        s->mask = value & 0x0078;        pxa2xx_i2s_update(s);        break;    case SAICR:        s->status &= ~(value & (3 << 5));        pxa2xx_i2s_update(s);        break;    case SADIV:        s->clk = value & 0x007f;        break;    case SADR:        if (s->tx_len && s->enable) {            s->tx_len --;            pxa2xx_i2s_update(s);            s->codec_out(s->opaque, value);        } else if (s->fifo_len < 16) {            s->fifo[s->fifo_len ++] = value;            pxa2xx_i2s_update(s);        }        break;    default:        printf("%s: Bad register " REG_FMT "\n", __FUNCTION__, addr);    }}static CPUReadMemoryFunc *pxa2xx_i2s_readfn[] = {    pxa2xx_i2s_read,    pxa2xx_i2s_read,    pxa2xx_i2s_read,};static CPUWriteMemoryFunc *pxa2xx_i2s_writefn[] = {    pxa2xx_i2s_write,    pxa2xx_i2s_write,    pxa2xx_i2s_write,};static void pxa2xx_i2s_save(QEMUFile *f, void *opaque){    struct pxa2xx_i2s_s *s = (struct pxa2xx_i2s_s *) opaque;    qemu_put_be32s(f, &s->control[0]);    qemu_put_be32s(f, &s->control[1]);    qemu_put_be32s(f, &s->status);    qemu_put_be32s(f, &s->mask);    qemu_put_be32s(f, &s->clk);    qemu_put_be32(f, s->enable);    qemu_put_be32(f, s->rx_len);    qemu_put_be32(f, s->tx_len);    qemu_put_be32(f, s->fifo_len);}static int pxa2xx_i2s_load(QEMUFile *f, void *opaque, int version_id){    struct pxa2xx_i2s_s *s = (struct pxa2xx_i2s_s *) opaque;    qemu_get_be32s(f, &s->control[0]);    qemu_get_be32s(f, &s->control[1]);    qemu_get_be32s(f, &s->status);    qemu_get_be32s(f, &s->mask);    qemu_get_be32s(f, &s->clk);    s->enable = qemu_get_be32(f);    s->rx_len = qemu_get_be32(f);    s->tx_len = qemu_get_be32(f);    s->fifo_len = qemu_get_be32(f);    return 0;}static void pxa2xx_i2s_data_req(void *opaque, int tx, int rx){    struct pxa2xx_i2s_s *s = (struct pxa2xx_i2s_s *) opaque;    uint32_t *sample;    /* Signal FIFO errors */    if (s->enable && s->tx_len)        s->status |= 1 << 5;		/* TUR */    if (s->enable && s->rx_len)        s->status |= 1 << 6;		/* ROR */    /* Should be tx - MIN(tx, s->fifo_len) but we don't really need to     * handle the cases where it makes a difference.  */    s->tx_len = tx - s->fifo_len;    s->rx_len = rx;    /* Note that is s->codec_out wasn't set, we wouldn't get called.  */    if (s->enable)        for (sample = s->fifo; s->fifo_len; s->fifo_len --, sample ++)            s->codec_out(s->opaque, *sample);    pxa2xx_i2s_update(s);}static struct pxa2xx_i2s_s *pxa2xx_i2s_init(target_phys_addr_t base,                qemu_irq irq, struct pxa2xx_dma_state_s *dma){    int iomemtype;    struct pxa2xx_i2s_s *s = (struct pxa2xx_i2s_s *)            qemu_mallocz(sizeof(struct pxa2xx_i2s_s));    s->base = base;    s->irq = irq;    s->dma = dma;    s->data_req = pxa2xx_i2s_data_req;    pxa2xx_i2s_reset(s);    iomemtype = cpu_register_io_memory(0, pxa2xx_i2s_readfn,                    pxa2xx_i2s_writefn, s);    cpu_register_physical_memory(s->base & 0xfff00000, 0x100000, iomemtype);    register_savevm("pxa2xx_i2s", base, 0,                    pxa2xx_i2s_save, pxa2xx_i2s_load, s);    return s;}/* PXA Fast Infra-red Communications Port */struct pxa2xx_fir_s {    target_phys_addr_t base;    qemu_irq irq;    struct pxa2xx_dma_state_s *dma;    int enable;    CharDriverState *chr;    uint8_t control[3];    uint8_t status[2];    int rx_len;    int rx_start;    uint8_t rx_fifo[64];};static void pxa2xx_fir_reset(struct pxa2xx_fir_s *s){    s->control[0] = 0x00;    s->control[1] = 0x00;    s->control[2] = 0x00;    s->status[0] = 0x00;    s->status[1] = 0x00;    s->enable = 0;}static inline void pxa2xx_fir_update(struct pxa2xx_fir_s *s){    static const int tresh[4] = { 8, 16, 32, 0 };    int intr = 0;    if ((s->control[0] & (1 << 4)) &&			/* RXE */                    s->rx_len >= tresh[s->control[2] & 3])	/* TRIG */        s->status[0] |= 1 << 4;				/* RFS */    else        s->status[0] &= ~(1 << 4);			/* RFS */    if (s->control[0] & (1 << 3))			/* TXE */        s->status[0] |= 1 << 3;				/* TFS */    else        s->status[0] &= ~(1 << 3);			/* TFS */    if (s->rx_len)        s->status[1] |= 1 << 2;				/* RNE */    else        s->status[1] &= ~(1 << 2);			/* RNE */    if (s->control[0] & (1 << 4))			/* RXE */        s->status[1] |= 1 << 0;				/* RSY */    else        s->status[1] &= ~(1 << 0);			/* RSY */    intr |= (s->control[0] & (1 << 5)) &&		/* RIE */            (s->status[0] & (1 << 4));			/* RFS */    intr |= (s->control[0] & (1 << 6)) &&		/* TIE */            (s->status[0] & (1 << 3));			/* TFS */    intr |= (s->control[2] & (1 << 4)) &&		/* TRAIL */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
最新不卡av在线| 一二三四社区欧美黄| 色婷婷国产精品| 免费高清成人在线| 亚洲欧洲一区二区在线播放| 欧美电影在哪看比较好| 成人福利电影精品一区二区在线观看 | 亚洲国产一区二区三区青草影视 | 久久久久久久国产精品影院| 91欧美一区二区| 国内精品伊人久久久久影院对白| 亚洲一区二区视频| 中文字幕一区二| 久久新电视剧免费观看| 91麻豆精品国产| 色婷婷国产精品| 99国产精品99久久久久久| 欧美日韩国产不卡| 99re热视频这里只精品| 久久99国产乱子伦精品免费| 性感美女久久精品| 亚洲美女在线国产| 国产精品美女久久久久av爽李琼| 日韩美女主播在线视频一区二区三区| 欧美在线三级电影| 91美女片黄在线观看91美女| 成人黄色av网站在线| 国产精品亚洲人在线观看| 精品亚洲国内自在自线福利| 人禽交欧美网站| 男人操女人的视频在线观看欧美| 一区二区三区在线免费播放| 综合久久综合久久| 亚洲三级免费观看| 亚洲乱码日产精品bd| 亚洲手机成人高清视频| 亚洲品质自拍视频网站| 亚洲柠檬福利资源导航| 5月丁香婷婷综合| 日本亚洲天堂网| 一级中文字幕一区二区| 久久综合色婷婷| 精品国产91乱码一区二区三区 | 亚洲二区视频在线| 一区二区三区在线不卡| 一二三区精品福利视频| 亚洲一区在线视频| 天天综合网天天综合色| 日韩av电影天堂| 美女一区二区三区| 国产一区在线精品| 国产成人午夜片在线观看高清观看| 激情久久久久久久久久久久久久久久| 久久精品国内一区二区三区| 国产一区91精品张津瑜| 成人免费毛片a| 在线日韩一区二区| 91精品国产入口| 亚洲精品一区二区精华| 国产喷白浆一区二区三区| 国产精品热久久久久夜色精品三区 | 久久久精品国产免费观看同学| 久久嫩草精品久久久久| 国产精品女上位| 亚洲一区成人在线| 男女性色大片免费观看一区二区| 国产一区二区剧情av在线| 粉嫩一区二区三区在线看 | 日韩免费高清av| 日本一区二区三区在线不卡| 成人免费视频视频在线观看免费 | 久久色在线视频| 国产精品美女久久久久久| 亚洲一区影音先锋| 久久99精品视频| 94-欧美-setu| 日韩欧美成人午夜| 18欧美亚洲精品| 日本女优在线视频一区二区| 国产乱码精品一品二品| 欧美中文字幕久久| www国产亚洲精品久久麻豆| 一区二区三区在线观看视频 | 在线一区二区三区四区五区| 日韩一级成人av| 中文字幕制服丝袜成人av | 亚洲麻豆国产自偷在线| 天天影视色香欲综合网老头| 国产精品99久| 色成人在线视频| 日韩欧美一二三| 国产寡妇亲子伦一区二区| 欧美国产一区在线| 亚洲成人综合视频| 国产成人午夜精品5599| 欧美美女网站色| 中文字幕在线一区免费| 久久99精品网久久| 欧美日韩一区二区在线观看视频| 中国av一区二区三区| 久久精品免费观看| 欧美视频在线不卡| 中文字幕一区二区三区四区不卡| 美女视频黄 久久| 欧美性三三影院| 国产精品乱码一区二区三区软件 | 天堂久久一区二区三区| 成人国产视频在线观看| 亚洲精品一区二区三区影院 | 亚洲一二三四久久| 成人app下载| 国产调教视频一区| 日本不卡视频在线观看| 欧美在线观看18| 亚洲欧洲色图综合| 成人小视频在线| 久久久噜噜噜久噜久久综合| 日本欧美加勒比视频| 欧美日韩三级视频| 亚洲最大成人网4388xx| 99精品国产视频| 中文字幕一区二区5566日韩| 国产不卡视频一区| 日本一区二区三区四区| 国产精品911| 国产欧美日韩在线观看| 国产真实精品久久二三区| 日韩欧美高清一区| 久久成人av少妇免费| 日韩你懂的电影在线观看| 麻豆免费看一区二区三区| 日韩一区二区三区免费看 | 久久久亚洲欧洲日产国码αv| 日日夜夜精品视频天天综合网| 欧美日韩免费视频| 日韩制服丝袜av| 欧美一区二区在线不卡| 日韩二区三区在线观看| 4438x亚洲最大成人网| 香蕉久久夜色精品国产使用方法| 欧美色综合久久| 亚洲成人第一页| 91精品国产91久久综合桃花| 青青草97国产精品免费观看无弹窗版| 欧美一区二区三区在线电影| 久久精品国产一区二区三区免费看| 欧美一区二区大片| 久久99国产精品成人| 国产视频一区二区在线| 成人午夜免费视频| 自拍偷拍国产精品| 欧美日韩一区国产| 久久99久久久欧美国产| 国产欧美日韩在线看| 色伊人久久综合中文字幕| 午夜视频久久久久久| 日韩你懂的在线播放| 成人激情免费网站| 亚洲自拍欧美精品| 日韩片之四级片| 成人美女在线视频| 国产成人综合亚洲网站| 国产精品99精品久久免费| 国产精品一区二区三区乱码| 国产精品免费丝袜| 色菇凉天天综合网| 麻豆成人91精品二区三区| 久草热8精品视频在线观看| 久久色视频免费观看| 91香蕉视频mp4| 日韩精品一区第一页| 久久九九99视频| 在线精品视频免费观看| 秋霞国产午夜精品免费视频| 中文乱码免费一区二区| 欧美三电影在线| 国产精品一级在线| 一区二区三区蜜桃网| 日韩免费视频一区二区| av激情综合网| 秋霞影院一区二区| 自拍偷拍亚洲激情| 精品福利一区二区三区 | 成人黄色片在线观看| 亚洲高清视频中文字幕| 久久久久久免费毛片精品| 在线亚洲精品福利网址导航| 黑人巨大精品欧美一区| 亚洲色图都市小说| 欧美电视剧在线看免费| 99re66热这里只有精品3直播 | a级精品国产片在线观看| 亚洲成av人**亚洲成av**| 国产人妖乱国产精品人妖| 精品视频色一区| 99精品视频中文字幕| 国内精品嫩模私拍在线| 水野朝阳av一区二区三区| 国产精品对白交换视频| wwwwxxxxx欧美|