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

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

?? pl031.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
字號(hào):
/* * ARM AMBA PrimeCell PL031 RTC * * Copyright (c) 2007 CodeSourcery * * This file is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. * */#include "hw.h"#include "primecell.h"#include "qemu-timer.h"#include "sysemu.h"//#define DEBUG_PL031#ifdef DEBUG_PL031#define DPRINTF(fmt, args...) \do { printf("pl031: " fmt , ##args); } while (0)#else#define DPRINTF(fmt, args...) do {} while(0)#endif#define RTC_DR      0x00    /* Data read register */#define RTC_MR      0x04    /* Match register */#define RTC_LR      0x08    /* Data load register */#define RTC_CR      0x0c    /* Control register */#define RTC_IMSC    0x10    /* Interrupt mask and set register */#define RTC_RIS     0x14    /* Raw interrupt status register */#define RTC_MIS     0x18    /* Masked interrupt status register */#define RTC_ICR     0x1c    /* Interrupt clear register */typedef struct {    QEMUTimer *timer;    qemu_irq irq;    uint32_t base;    uint64_t start_time;    uint32_t tick_offset;    uint32_t mr;    uint32_t lr;    uint32_t cr;    uint32_t im;    uint32_t is;} pl031_state;static const unsigned char pl031_id[] = {    0x31, 0x10, 0x14, 0x00,         /* Device ID        */    0x0d, 0xf0, 0x05, 0xb1          /* Cell ID      */};static void pl031_update(pl031_state *s){    qemu_set_irq(s->irq, s->is & s->im);}static void pl031_interrupt(void * opaque){    pl031_state *s = (pl031_state *)opaque;    s->im = 1;    DPRINTF("Alarm raised\n");    pl031_update(s);}static uint32_t pl031_get_count(pl031_state *s){    /* This assumes qemu_get_clock returns the time since the machine was       created.  */    return s->tick_offset + qemu_get_clock(vm_clock) / ticks_per_sec;}static void pl031_set_alarm(pl031_state *s){    int64_t now;    uint32_t ticks;    now = qemu_get_clock(vm_clock);    ticks = s->tick_offset + now / ticks_per_sec;    /* The timer wraps around.  This subtraction also wraps in the same way,       and gives correct results when alarm < now_ticks.  */    ticks = s->mr - ticks;    DPRINTF("Alarm set in %ud ticks\n", ticks);    if (ticks == 0) {        qemu_del_timer(s->timer);        pl031_interrupt(s);    } else {        qemu_mod_timer(s->timer, now + (int64_t)ticks * ticks_per_sec);    }}static uint32_t pl031_read(void *opaque, target_phys_addr_t offset){    pl031_state *s = (pl031_state *)opaque;    offset -= s->base;    if (offset >= 0xfe0  &&  offset < 0x1000)        return pl031_id[(offset - 0xfe0) >> 2];    switch (offset) {    case RTC_DR:        return pl031_get_count(s);    case RTC_MR:        return s->mr;    case RTC_IMSC:        return s->im;    case RTC_RIS:        return s->is;    case RTC_LR:        return s->lr;    case RTC_CR:        /* RTC is permanently enabled.  */        return 1;    case RTC_MIS:        return s->is & s->im;    case RTC_ICR:        fprintf(stderr, "qemu: pl031_read: Unexpected offset 0x%x\n",                (int)offset);        break;    default:        cpu_abort(cpu_single_env, "pl031_read: Bad offset 0x%x\n",                  (int)offset);        break;    }    return 0;}static void pl031_write(void * opaque, target_phys_addr_t offset,                        uint32_t value){    pl031_state *s = (pl031_state *)opaque;    offset -= s->base;    switch (offset) {    case RTC_LR:        s->tick_offset += value - pl031_get_count(s);        pl031_set_alarm(s);        break;    case RTC_MR:        s->mr = value;        pl031_set_alarm(s);        break;    case RTC_IMSC:        s->im = value & 1;        DPRINTF("Interrupt mask %d\n", s->im);        pl031_update(s);        break;    case RTC_ICR:        /* The PL031 documentation (DDI0224B) states that the interupt is           cleared when bit 0 of the written value is set.  However the           arm926e documentation (DDI0287B) states that the interrupt is           cleared when any value is written.  */        DPRINTF("Interrupt cleared");        s->is = 0;        pl031_update(s);        break;    case RTC_CR:        /* Written value is ignored.  */        break;    case RTC_DR:    case RTC_MIS:    case RTC_RIS:        fprintf(stderr, "qemu: pl031_write: Unexpected offset 0x%x\n",                (int)offset);        break;    default:        cpu_abort(cpu_single_env, "pl031_write: Bad offset 0x%x\n",                  (int)offset);        break;    }}static CPUWriteMemoryFunc * pl031_writefn[] = {    pl031_write,    pl031_write,    pl031_write};static CPUReadMemoryFunc * pl031_readfn[] = {    pl031_read,    pl031_read,    pl031_read};void pl031_init(uint32_t base, qemu_irq irq){    int iomemtype;    pl031_state *s;    time_t ti;    struct tm *tm;    s = qemu_mallocz(sizeof(pl031_state));    if (!s)        cpu_abort(cpu_single_env, "pl031_init: Out of memory\n");    iomemtype = cpu_register_io_memory(0, pl031_readfn, pl031_writefn, s);    if (iomemtype == -1)        cpu_abort(cpu_single_env, "pl031_init: Can't register I/O memory\n");    cpu_register_physical_memory(base, 0x00001000, iomemtype);    s->base = base;    s->irq  = irq;    /* ??? We assume vm_clock is zero at this point.  */    time(&ti);    if (rtc_utc)        tm = gmtime(&ti);    else        tm = localtime(&ti);    s->tick_offset = mktime(tm);    s->timer = qemu_new_timer(vm_clock, pl031_interrupt, s);}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩不卡一区二区| 日本一区中文字幕| 欧美一级电影网站| 成人91在线观看| 久久激情五月婷婷| 亚洲天堂网中文字| 精品乱人伦小说| 在线日韩一区二区| 国产馆精品极品| 免费观看在线综合色| 一区二区三区中文免费| 久久久蜜臀国产一区二区| 欧美日韩一二三区| 成人av电影免费观看| 精品在线播放免费| 视频一区在线播放| 亚洲久草在线视频| 国产精品色一区二区三区| 日韩欧美资源站| 欧美写真视频网站| 91麻豆高清视频| 成人午夜激情在线| 久久91精品国产91久久小草| 视频精品一区二区| 亚洲国产精品久久久久秋霞影院| 亚洲欧洲精品成人久久奇米网| 久久你懂得1024| 日韩精品一区国产麻豆| 4438x亚洲最大成人网| 欧美日韩一区三区四区| 波多野结衣欧美| 国产成人精品午夜视频免费| 黑人精品欧美一区二区蜜桃 | 视频一区二区三区中文字幕| 亚洲美女一区二区三区| 亚洲色图第一区| 国产精品久久久久久久午夜片| 久久精品一级爱片| 久久综合九色综合97婷婷| 日韩午夜精品视频| 欧美一区二区在线不卡| 欧美日韩一区二区三区高清| 日本韩国欧美一区二区三区| 色综合天天综合网天天狠天天| 99久久久久免费精品国产| 成人国产精品免费网站| 91亚洲精华国产精华精华液| av一区二区不卡| 一本色道综合亚洲| 欧美影院一区二区| 欧美美女网站色| 91精品国产91热久久久做人人| 制服丝袜激情欧洲亚洲| 日韩一级免费观看| 久久先锋影音av鲁色资源网| 久久久久久一二三区| 欧美激情综合五月色丁香 | 亚洲欧美日韩国产另类专区| 亚洲精选视频免费看| 一区二区欧美视频| 午夜免费久久看| 久久黄色级2电影| 国产成人精品aa毛片| www.在线成人| 欧美日韩第一区日日骚| 日韩一级免费观看| 国产欧美日韩亚州综合| 亚洲乱码国产乱码精品精小说| 亚洲成人黄色小说| 国产原创一区二区三区| 成人深夜在线观看| 在线观看免费视频综合| 日韩免费高清电影| 国产精品免费久久| 香蕉成人伊视频在线观看| 精品一区二区三区免费| 99免费精品在线| 欧美精品在线观看一区二区| 久久精品视频免费| 一卡二卡三卡日韩欧美| 久久99精品国产麻豆不卡| 91在线国内视频| 欧美肥胖老妇做爰| 国产日韩精品一区二区三区在线| 一区二区三区四区av| 久久se精品一区二区| 色屁屁一区二区| 2024国产精品| 亚洲一区二区成人在线观看| 国产一区二区三区在线观看精品 | 国产一区二区精品在线观看| 91传媒视频在线播放| 日韩精品一区二区三区视频在线观看| 国产精品―色哟哟| 久久国产精品色婷婷| 在线观看视频一区| 国产亚洲污的网站| 五月婷婷激情综合网| 成人高清免费观看| 亚洲精品在线观看视频| 一区二区三区四区在线免费观看 | 日韩中文字幕亚洲一区二区va在线| 激情小说欧美图片| 欧美浪妇xxxx高跟鞋交| 国产精品人人做人人爽人人添| 丝袜美腿亚洲一区| 色网站国产精品| 国产精品午夜春色av| 精品一区二区久久| 欧美剧情片在线观看| 亚洲三级在线免费| 成人综合婷婷国产精品久久| 欧美一区二区三区在线观看视频| 亚洲图片欧美激情| 白白色 亚洲乱淫| 久久精品亚洲精品国产欧美| 人禽交欧美网站| 欧美羞羞免费网站| 亚洲免费资源在线播放| 成人福利视频网站| 久久精品一区二区三区不卡| 久久99热狠狠色一区二区| 欧美精品国产精品| 石原莉奈一区二区三区在线观看| 欧洲另类一二三四区| 中文字幕亚洲精品在线观看| 国产伦精品一区二区三区免费| 日韩精品一区二区三区视频| 蜜臀99久久精品久久久久久软件| 欧美色精品天天在线观看视频| 亚洲色图欧洲色图| 色先锋久久av资源部| 亚洲人午夜精品天堂一二香蕉| 丰满白嫩尤物一区二区| 欧美国产在线观看| 夫妻av一区二区| 最新日韩av在线| 91丨九色丨黑人外教| 最新不卡av在线| 91麻豆福利精品推荐| 亚洲精品成人在线| 日本电影欧美片| 亚洲国产色一区| 欧美肥妇bbw| 久久se精品一区二区| 久久久久久久精| 成人黄动漫网站免费app| 国产精品理伦片| 色哟哟欧美精品| 亚洲大尺度视频在线观看| 精品视频1区2区3区| 视频一区视频二区中文字幕| 日韩色在线观看| 国产乱人伦偷精品视频不卡| 国产蜜臀av在线一区二区三区| 成人国产精品免费观看视频| 亚洲黄色性网站| 欧美一区二区三区免费观看视频| 免费不卡在线视频| 精品久久久久久综合日本欧美| 国产原创一区二区三区| 国产精品国产三级国产三级人妇| 色综合久久中文字幕| 亚洲电影视频在线| 日韩欧美国产高清| 成人性生交大片免费看在线播放 | 国产日产欧美一区| www.日韩在线| 香蕉成人伊视频在线观看| 欧美成人a在线| 成人av免费在线观看| 亚洲成人在线观看视频| 精品少妇一区二区三区免费观看| 成人少妇影院yyyy| 亚洲一区二区三区视频在线播放| 日韩欧美资源站| 色综合激情久久| 久久精品国产精品青草| 国产精品全国免费观看高清| 欧美日韩情趣电影| 国产成人一区在线| 首页国产欧美久久| 国产免费观看久久| 在线播放视频一区| 成人aaaa免费全部观看| 人人精品人人爱| 亚洲美女屁股眼交| www国产成人免费观看视频 深夜成人网| 色欧美片视频在线观看在线视频| 蜜桃一区二区三区在线观看| 中文字幕免费观看一区| 欧美日本国产视频| 91小视频在线免费看| 精品无人区卡一卡二卡三乱码免费卡| 中文字幕制服丝袜一区二区三区| 欧美一区二区二区| 91免费版在线| 国产精品一区2区| 男女激情视频一区| 亚洲午夜激情av|