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

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

?? pxa2xx.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* * Intel XScale PXA255/270 processor support. * * Copyright (c) 2006 Openedhand Ltd. * Written by Andrzej Zaborowski <balrog@zabor.org> * * This code is licenced under the GPL. */#include "hw.h"#include "pxa.h"#include "sysemu.h"#include "pc.h"#include "i2c.h"#include "qemu-timer.h"#include "qemu-char.h"static struct {    target_phys_addr_t io_base;    int irqn;} pxa255_serial[] = {    { 0x40100000, PXA2XX_PIC_FFUART },    { 0x40200000, PXA2XX_PIC_BTUART },    { 0x40700000, PXA2XX_PIC_STUART },    { 0x41600000, PXA25X_PIC_HWUART },    { 0, 0 }}, pxa270_serial[] = {    { 0x40100000, PXA2XX_PIC_FFUART },    { 0x40200000, PXA2XX_PIC_BTUART },    { 0x40700000, PXA2XX_PIC_STUART },    { 0, 0 }};typedef struct PXASSPDef {    target_phys_addr_t io_base;    int irqn;} PXASSPDef;#if 0static PXASSPDef pxa250_ssp[] = {    { 0x41000000, PXA2XX_PIC_SSP },    { 0, 0 }};#endifstatic PXASSPDef pxa255_ssp[] = {    { 0x41000000, PXA2XX_PIC_SSP },    { 0x41400000, PXA25X_PIC_NSSP },    { 0, 0 }};#if 0static PXASSPDef pxa26x_ssp[] = {    { 0x41000000, PXA2XX_PIC_SSP },    { 0x41400000, PXA25X_PIC_NSSP },    { 0x41500000, PXA26X_PIC_ASSP },    { 0, 0 }};#endifstatic PXASSPDef pxa27x_ssp[] = {    { 0x41000000, PXA2XX_PIC_SSP },    { 0x41700000, PXA27X_PIC_SSP2 },    { 0x41900000, PXA2XX_PIC_SSP3 },    { 0, 0 }};#define PMCR	0x00	/* Power Manager Control register */#define PSSR	0x04	/* Power Manager Sleep Status register */#define PSPR	0x08	/* Power Manager Scratch-Pad register */#define PWER	0x0c	/* Power Manager Wake-Up Enable register */#define PRER	0x10	/* Power Manager Rising-Edge Detect Enable register */#define PFER	0x14	/* Power Manager Falling-Edge Detect Enable register */#define PEDR	0x18	/* Power Manager Edge-Detect Status register */#define PCFR	0x1c	/* Power Manager General Configuration register */#define PGSR0	0x20	/* Power Manager GPIO Sleep-State register 0 */#define PGSR1	0x24	/* Power Manager GPIO Sleep-State register 1 */#define PGSR2	0x28	/* Power Manager GPIO Sleep-State register 2 */#define PGSR3	0x2c	/* Power Manager GPIO Sleep-State register 3 */#define RCSR	0x30	/* Reset Controller Status register */#define PSLR	0x34	/* Power Manager Sleep Configuration register */#define PTSR	0x38	/* Power Manager Standby Configuration register */#define PVCR	0x40	/* Power Manager Voltage Change Control register */#define PUCR	0x4c	/* Power Manager USIM Card Control/Status register */#define PKWR	0x50	/* Power Manager Keyboard Wake-Up Enable register */#define PKSR	0x54	/* Power Manager Keyboard Level-Detect Status */#define PCMD0	0x80	/* Power Manager I2C Command register File 0 */#define PCMD31	0xfc	/* Power Manager I2C Command register File 31 */static uint32_t pxa2xx_pm_read(void *opaque, target_phys_addr_t addr){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    addr -= s->pm_base;    switch (addr) {    case PMCR ... PCMD31:        if (addr & 3)            goto fail;        return s->pm_regs[addr >> 2];    default:    fail:        printf("%s: Bad register " REG_FMT "\n", __FUNCTION__, addr);        break;    }    return 0;}static void pxa2xx_pm_write(void *opaque, target_phys_addr_t addr,                uint32_t value){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    addr -= s->pm_base;    switch (addr) {    case PMCR:        s->pm_regs[addr >> 2] &= 0x15 & ~(value & 0x2a);        s->pm_regs[addr >> 2] |= value & 0x15;        break;    case PSSR:	/* Read-clean registers */    case RCSR:    case PKSR:        s->pm_regs[addr >> 2] &= ~value;        break;    default:	/* Read-write registers */        if (addr >= PMCR && addr <= PCMD31 && !(addr & 3)) {            s->pm_regs[addr >> 2] = value;            break;        }        printf("%s: Bad register " REG_FMT "\n", __FUNCTION__, addr);        break;    }}static CPUReadMemoryFunc *pxa2xx_pm_readfn[] = {    pxa2xx_pm_read,    pxa2xx_pm_read,    pxa2xx_pm_read,};static CPUWriteMemoryFunc *pxa2xx_pm_writefn[] = {    pxa2xx_pm_write,    pxa2xx_pm_write,    pxa2xx_pm_write,};static void pxa2xx_pm_save(QEMUFile *f, void *opaque){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    int i;    for (i = 0; i < 0x40; i ++)        qemu_put_be32s(f, &s->pm_regs[i]);}static int pxa2xx_pm_load(QEMUFile *f, void *opaque, int version_id){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    int i;    for (i = 0; i < 0x40; i ++)        qemu_get_be32s(f, &s->pm_regs[i]);    return 0;}#define CCCR	0x00	/* Core Clock Configuration register */#define CKEN	0x04	/* Clock Enable register */#define OSCC	0x08	/* Oscillator Configuration register */#define CCSR	0x0c	/* Core Clock Status register */static uint32_t pxa2xx_cm_read(void *opaque, target_phys_addr_t addr){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    addr -= s->cm_base;    switch (addr) {    case CCCR:    case CKEN:    case OSCC:        return s->cm_regs[addr >> 2];    case CCSR:        return s->cm_regs[CCCR >> 2] | (3 << 28);    default:        printf("%s: Bad register " REG_FMT "\n", __FUNCTION__, addr);        break;    }    return 0;}static void pxa2xx_cm_write(void *opaque, target_phys_addr_t addr,                uint32_t value){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    addr -= s->cm_base;    switch (addr) {    case CCCR:    case CKEN:        s->cm_regs[addr >> 2] = value;        break;    case OSCC:        s->cm_regs[addr >> 2] &= ~0x6c;        s->cm_regs[addr >> 2] |= value & 0x6e;        if ((value >> 1) & 1)			/* OON */            s->cm_regs[addr >> 2] |= 1 << 0;	/* Oscillator is now stable */        break;    default:        printf("%s: Bad register " REG_FMT "\n", __FUNCTION__, addr);        break;    }}static CPUReadMemoryFunc *pxa2xx_cm_readfn[] = {    pxa2xx_cm_read,    pxa2xx_cm_read,    pxa2xx_cm_read,};static CPUWriteMemoryFunc *pxa2xx_cm_writefn[] = {    pxa2xx_cm_write,    pxa2xx_cm_write,    pxa2xx_cm_write,};static void pxa2xx_cm_save(QEMUFile *f, void *opaque){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    int i;    for (i = 0; i < 4; i ++)        qemu_put_be32s(f, &s->cm_regs[i]);    qemu_put_be32s(f, &s->clkcfg);    qemu_put_be32s(f, &s->pmnc);}static int pxa2xx_cm_load(QEMUFile *f, void *opaque, int version_id){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    int i;    for (i = 0; i < 4; i ++)        qemu_get_be32s(f, &s->cm_regs[i]);    qemu_get_be32s(f, &s->clkcfg);    qemu_get_be32s(f, &s->pmnc);    return 0;}static uint32_t pxa2xx_clkpwr_read(void *opaque, int op2, int reg, int crm){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    switch (reg) {    case 6:	/* Clock Configuration register */        return s->clkcfg;    case 7:	/* Power Mode register */        return 0;    default:        printf("%s: Bad register 0x%x\n", __FUNCTION__, reg);        break;    }    return 0;}static void pxa2xx_clkpwr_write(void *opaque, int op2, int reg, int crm,                uint32_t value){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    static const char *pwrmode[8] = {        "Normal", "Idle", "Deep-idle", "Standby",        "Sleep", "reserved (!)", "reserved (!)", "Deep-sleep",    };    switch (reg) {    case 6:	/* Clock Configuration register */        s->clkcfg = value & 0xf;        if (value & 2)            printf("%s: CPU frequency change attempt\n", __FUNCTION__);        break;    case 7:	/* Power Mode register */        if (value & 8)            printf("%s: CPU voltage change attempt\n", __FUNCTION__);        switch (value & 7) {        case 0:            /* Do nothing */            break;        case 1:            /* Idle */            if (!(s->cm_regs[CCCR >> 2] & (1 << 31))) {	/* CPDIS */                cpu_interrupt(s->env, CPU_INTERRUPT_HALT);                break;            }            /* Fall through.  */        case 2:            /* Deep-Idle */            cpu_interrupt(s->env, CPU_INTERRUPT_HALT);            s->pm_regs[RCSR >> 2] |= 0x8;	/* Set GPR */            goto message;        case 3:            s->env->uncached_cpsr =                    ARM_CPU_MODE_SVC | CPSR_A | CPSR_F | CPSR_I;            s->env->cp15.c1_sys = 0;            s->env->cp15.c1_coproc = 0;            s->env->cp15.c2_base0 = 0;            s->env->cp15.c3 = 0;            s->pm_regs[PSSR >> 2] |= 0x8;	/* Set STS */            s->pm_regs[RCSR >> 2] |= 0x8;	/* Set GPR */            /*             * The scratch-pad register is almost universally used             * for storing the return address on suspend.  For the             * lack of a resuming bootloader, perform a jump             * directly to that address.             */            memset(s->env->regs, 0, 4 * 15);            s->env->regs[15] = s->pm_regs[PSPR >> 2];#if 0            buffer = 0xe59ff000;	/* ldr     pc, [pc, #0] */            cpu_physical_memory_write(0, &buffer, 4);            buffer = s->pm_regs[PSPR >> 2];            cpu_physical_memory_write(8, &buffer, 4);#endif            /* Suspend */            cpu_interrupt(cpu_single_env, CPU_INTERRUPT_HALT);            goto message;        default:        message:            printf("%s: machine entered %s mode\n", __FUNCTION__,                            pwrmode[value & 7]);        }        break;    default:        printf("%s: Bad register 0x%x\n", __FUNCTION__, reg);        break;    }}/* Performace Monitoring Registers */#define CPPMNC		0	/* Performance Monitor Control register */#define CPCCNT		1	/* Clock Counter register */#define CPINTEN		4	/* Interrupt Enable register */#define CPFLAG		5	/* Overflow Flag register */#define CPEVTSEL	8	/* Event Selection register */#define CPPMN0		0	/* Performance Count register 0 */#define CPPMN1		1	/* Performance Count register 1 */#define CPPMN2		2	/* Performance Count register 2 */#define CPPMN3		3	/* Performance Count register 3 */static uint32_t pxa2xx_perf_read(void *opaque, int op2, int reg, int crm){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    switch (reg) {    case CPPMNC:        return s->pmnc;    case CPCCNT:        if (s->pmnc & 1)            return qemu_get_clock(vm_clock);        else            return 0;    case CPINTEN:    case CPFLAG:    case CPEVTSEL:        return 0;    default:        printf("%s: Bad register 0x%x\n", __FUNCTION__, reg);        break;    }    return 0;}static void pxa2xx_perf_write(void *opaque, int op2, int reg, int crm,                uint32_t value){    struct pxa2xx_state_s *s = (struct pxa2xx_state_s *) opaque;    switch (reg) {    case CPPMNC:        s->pmnc = value;        break;    case CPCCNT:    case CPINTEN:    case CPFLAG:    case CPEVTSEL:        break;    default:        printf("%s: Bad register 0x%x\n", __FUNCTION__, reg);        break;    }}static uint32_t pxa2xx_cp14_read(void *opaque, int op2, int reg, int crm){    switch (crm) {    case 0:        return pxa2xx_clkpwr_read(opaque, op2, reg, crm);    case 1:        return pxa2xx_perf_read(opaque, op2, reg, crm);    case 2:        switch (reg) {        case CPPMN0:        case CPPMN1:        case CPPMN2:        case CPPMN3:            return 0;        }        /* Fall through */    default:        printf("%s: Bad register 0x%x\n", __FUNCTION__, reg);        break;    }    return 0;}static void pxa2xx_cp14_write(void *opaque, int op2, int reg, int crm,                uint32_t value){    switch (crm) {    case 0:        pxa2xx_clkpwr_write(opaque, op2, reg, crm, value);        break;    case 1:        pxa2xx_perf_write(opaque, op2, reg, crm, value);        break;    case 2:        switch (reg) {        case CPPMN0:        case CPPMN1:        case CPPMN2:

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美经典一区二区三区| 久久综合五月天婷婷伊人| 欧美日韩一区三区四区| 欧美日精品一区视频| 久久久久久久久久久久久夜| 亚洲精品一卡二卡| 激情欧美日韩一区二区| 欧美亚洲丝袜传媒另类| 国产精品视频一区二区三区不卡| 日韩中文字幕区一区有砖一区| 成人av片在线观看| 欧美精品一区二区精品网| 亚洲一区二区综合| 91丝袜高跟美女视频| 久久精品一区二区三区不卡| 日韩va亚洲va欧美va久久| 欧美亚洲禁片免费| 亚洲精品视频在线看| caoporn国产一区二区| 久久精品在线观看| 国产精品综合久久| 欧美成人免费网站| 久久精品国产99| 91.xcao| 亚洲成人午夜影院| 欧美日韩久久久| 亚洲午夜电影网| 欧美日韩国产一级片| 亚洲国产精品自拍| 欧美日韩精品一区二区三区蜜桃 | 成人动漫视频在线| 久久综合色天天久久综合图片| 天堂av在线一区| 91精品国产全国免费观看| 亚洲综合免费观看高清完整版在线| 99re视频这里只有精品| 亚洲欧美国产77777| 91免费观看在线| 亚洲一区二区在线免费看| 欧日韩精品视频| 日韩在线一二三区| 欧美一级国产精品| 国产在线观看免费一区| 国产亚洲精久久久久久| 成人18视频日本| 亚洲免费在线观看视频| 欧美三级在线播放| 日本成人在线不卡视频| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 国产精品影视网| 亚洲国产精品激情在线观看| 成人h精品动漫一区二区三区| 亚洲日韩欧美一区二区在线| 在线视频欧美精品| 免费成人av资源网| 国产午夜精品一区二区三区嫩草| 成人免费av资源| 亚洲一区二区三区中文字幕| 欧美一区二区在线免费观看| 国产成人av电影免费在线观看| 国产精品免费aⅴ片在线观看| 在线亚洲人成电影网站色www| 天天色天天操综合| 久久久精品日韩欧美| 91论坛在线播放| 美女高潮久久久| 中文字幕一区二区三区在线观看| 91福利在线免费观看| 美女视频网站久久| 国产精品区一区二区三区| 欧美日韩国产小视频| 国产剧情一区在线| 亚洲高清免费观看高清完整版在线观看| 欧美一级xxx| 91网页版在线| 国精品**一区二区三区在线蜜桃| 亚洲精品免费播放| 欧美精品一区二区在线播放| 色八戒一区二区三区| 精品一区二区三区香蕉蜜桃 | 日韩不卡免费视频| 欧美激情一区二区三区蜜桃视频| 欧美无乱码久久久免费午夜一区| 国产精品中文字幕日韩精品| 亚洲午夜视频在线| 国产精品美女一区二区在线观看| 欧美久久久久久久久久| 色婷婷久久一区二区三区麻豆| 国产一区二区精品在线观看| 亚洲电影激情视频网站| 中文字幕av不卡| 久久亚区不卡日本| 欧美人妇做爰xxxⅹ性高电影| 成a人片国产精品| 久热成人在线视频| 日韩成人精品在线| 亚洲综合色区另类av| 欧美国产日韩在线观看| 欧美tickle裸体挠脚心vk| 欧美无砖砖区免费| 91久久免费观看| 97久久超碰国产精品| 国产999精品久久| 国产一区日韩二区欧美三区| 免费在线欧美视频| 午夜视频久久久久久| 亚洲一卡二卡三卡四卡| 亚洲伦理在线精品| 国产精品国产三级国产aⅴ入口 | 国产丝袜美腿一区二区三区| 欧美一级国产精品| 91精品国产黑色紧身裤美女| 欧美日韩综合在线免费观看| 日本韩国精品一区二区在线观看| 北岛玲一区二区三区四区| 高清在线不卡av| 成人黄色软件下载| 97精品电影院| 色域天天综合网| 精品视频在线免费看| 欧美日韩美少妇| 91麻豆精品国产91久久久久久久久 | 亚洲不卡一区二区三区| 五月天视频一区| 青椒成人免费视频| 久久国产婷婷国产香蕉| 国产一区欧美二区| 成熟亚洲日本毛茸茸凸凹| 成人爱爱电影网址| 欧美亚洲日本国产| 日韩欧美国产综合| 国产午夜精品福利| 亚洲少妇30p| 日韩av电影免费观看高清完整版 | 99re成人精品视频| 欧美色图在线观看| 日韩一级片在线观看| 久久新电视剧免费观看| 自拍偷在线精品自拍偷无码专区 | 欧美一区二区视频免费观看| 日韩天堂在线观看| 国产日韩av一区| 亚洲综合无码一区二区| 日韩 欧美一区二区三区| 国产一区二区免费在线| 99re热这里只有精品免费视频| 欧美日韩国产高清一区二区三区 | 欧美韩国日本不卡| 亚洲国产综合人成综合网站| 美国一区二区三区在线播放| 国产精品一区免费视频| 91麻豆精品在线观看| 欧美一级在线免费| 日韩理论片中文av| 美女视频网站久久| 在线观看www91| 久久久三级国产网站| 亚洲精品乱码久久久久久黑人| 蜜臀精品久久久久久蜜臀| 92国产精品观看| 精品国产一区二区三区四区四| 亚洲人成在线播放网站岛国| 久久不见久久见免费视频7| 91色.com| 国产亚洲欧美色| 视频一区二区不卡| 91论坛在线播放| 亚洲国产精品传媒在线观看| 日本伊人精品一区二区三区观看方式| 成人高清在线视频| 久久久综合网站| 久久精工是国产品牌吗| 欧美日韩一区在线观看| 亚洲精品国产a久久久久久| 国产美女精品人人做人人爽| 欧美另类一区二区三区| 亚洲欧美成aⅴ人在线观看| 国产麻豆日韩欧美久久| 日韩一区二区三区电影| 亚洲国产日韩a在线播放性色| 东方aⅴ免费观看久久av| 精品盗摄一区二区三区| 婷婷久久综合九色综合绿巨人 | 亚洲制服丝袜av| 不卡一区二区在线| 久久精品一二三| 久久精品国产一区二区三区免费看| 欧美亚一区二区| 亚洲视频中文字幕| 99精品久久只有精品| 欧美国产1区2区| 国产精品1区2区| 国产欧美日韩一区二区三区在线观看 | 成人高清视频免费观看| 国产亚洲制服色| 国产成人精品免费看| 国产日韩一级二级三级| 国产精品456露脸| 国产精品久久久久久久久搜平片 | 亚洲国产综合91精品麻豆|