⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 m48t59.c.svn-base

📁 我们自己开发的一个OSEK操作系统!不知道可不可以?
💻 SVN-BASE
📖 第 1 页 / 共 2 页
字号:
	    set_time(NVRAM, &tm);	}        break;    case 0x1FFF:    case 0x07FF:        /* year */	tmp = fromBCD(val);	if (tmp >= 0 && tmp <= 99) {	    get_time(NVRAM, &tm);            if (NVRAM->type == 8)                tm.tm_year = fromBCD(val) + 68; // Base year is 1968            else                tm.tm_year = fromBCD(val);	    set_time(NVRAM, &tm);	}        break;    default:        /* Check lock registers state */        if (addr >= 0x20 && addr <= 0x2F && (NVRAM->lock & 1))            break;        if (addr >= 0x30 && addr <= 0x3F && (NVRAM->lock & 2))            break;    do_write:        if (addr < NVRAM->size) {            NVRAM->buffer[addr] = val & 0xFF;	}        break;    }}uint32_t m48t59_read (void *opaque, uint32_t addr){    m48t59_t *NVRAM = opaque;    struct tm tm;    uint32_t retval = 0xFF;    /* check for NVRAM access */    if ((NVRAM->type == 2 && addr < 0x078f) ||        (NVRAM->type == 8 && addr < 0x1ff8) ||        (NVRAM->type == 59 && addr < 0x1ff0))        goto do_read;    /* TOD access */    switch (addr) {    case 0x1FF0:        /* flags register */	goto do_read;    case 0x1FF1:        /* unused */	retval = 0;        break;    case 0x1FF2:        /* alarm seconds */	goto do_read;    case 0x1FF3:        /* alarm minutes */	goto do_read;    case 0x1FF4:        /* alarm hours */	goto do_read;    case 0x1FF5:        /* alarm date */	goto do_read;    case 0x1FF6:        /* interrupts */	goto do_read;    case 0x1FF7:	/* A read resets the watchdog */	set_up_watchdog(NVRAM, NVRAM->buffer[0x1FF7]);	goto do_read;    case 0x1FF8:    case 0x07F8:        /* control */	goto do_read;    case 0x1FF9:    case 0x07F9:        /* seconds (BCD) */        get_time(NVRAM, &tm);        retval = (NVRAM->buffer[addr] & 0x80) | toBCD(tm.tm_sec);        break;    case 0x1FFA:    case 0x07FA:        /* minutes (BCD) */        get_time(NVRAM, &tm);        retval = toBCD(tm.tm_min);        break;    case 0x1FFB:    case 0x07FB:        /* hours (BCD) */        get_time(NVRAM, &tm);        retval = toBCD(tm.tm_hour);        break;    case 0x1FFC:    case 0x07FC:        /* day of the week / century */        get_time(NVRAM, &tm);        retval = NVRAM->buffer[addr] | tm.tm_wday;        break;    case 0x1FFD:    case 0x07FD:        /* date */        get_time(NVRAM, &tm);        retval = toBCD(tm.tm_mday);        break;    case 0x1FFE:    case 0x07FE:        /* month */        get_time(NVRAM, &tm);        retval = toBCD(tm.tm_mon + 1);        break;    case 0x1FFF:    case 0x07FF:        /* year */        get_time(NVRAM, &tm);        if (NVRAM->type == 8)            retval = toBCD(tm.tm_year - 68); // Base year is 1968        else            retval = toBCD(tm.tm_year);        break;    default:        /* Check lock registers state */        if (addr >= 0x20 && addr <= 0x2F && (NVRAM->lock & 1))            break;        if (addr >= 0x30 && addr <= 0x3F && (NVRAM->lock & 2))            break;    do_read:        if (addr < NVRAM->size) {            retval = NVRAM->buffer[addr];	}        break;    }    if (addr > 0x1FF9 && addr < 0x2000)       NVRAM_PRINTF("%s: 0x%08x <= 0x%08x\n", __func__, addr, retval);    return retval;}void m48t59_set_addr (void *opaque, uint32_t addr){    m48t59_t *NVRAM = opaque;    NVRAM->addr = addr;}void m48t59_toggle_lock (void *opaque, int lock){    m48t59_t *NVRAM = opaque;    NVRAM->lock ^= 1 << lock;}/* IO access to NVRAM */static void NVRAM_writeb (void *opaque, uint32_t addr, uint32_t val){    m48t59_t *NVRAM = opaque;    addr -= NVRAM->io_base;    NVRAM_PRINTF("%s: 0x%08x => 0x%08x\n", __func__, addr, val);    switch (addr) {    case 0:        NVRAM->addr &= ~0x00FF;        NVRAM->addr |= val;        break;    case 1:        NVRAM->addr &= ~0xFF00;        NVRAM->addr |= val << 8;        break;    case 3:        m48t59_write(NVRAM, val, NVRAM->addr);        NVRAM->addr = 0x0000;        break;    default:        break;    }}static uint32_t NVRAM_readb (void *opaque, uint32_t addr){    m48t59_t *NVRAM = opaque;    uint32_t retval;    addr -= NVRAM->io_base;    switch (addr) {    case 3:        retval = m48t59_read(NVRAM, NVRAM->addr);        break;    default:        retval = -1;        break;    }    NVRAM_PRINTF("%s: 0x%08x <= 0x%08x\n", __func__, addr, retval);    return retval;}static void nvram_writeb (void *opaque, target_phys_addr_t addr, uint32_t value){    m48t59_t *NVRAM = opaque;    addr -= NVRAM->mem_base;    m48t59_write(NVRAM, addr, value & 0xff);}static void nvram_writew (void *opaque, target_phys_addr_t addr, uint32_t value){    m48t59_t *NVRAM = opaque;    addr -= NVRAM->mem_base;    m48t59_write(NVRAM, addr, (value >> 8) & 0xff);    m48t59_write(NVRAM, addr + 1, value & 0xff);}static void nvram_writel (void *opaque, target_phys_addr_t addr, uint32_t value){    m48t59_t *NVRAM = opaque;    addr -= NVRAM->mem_base;    m48t59_write(NVRAM, addr, (value >> 24) & 0xff);    m48t59_write(NVRAM, addr + 1, (value >> 16) & 0xff);    m48t59_write(NVRAM, addr + 2, (value >> 8) & 0xff);    m48t59_write(NVRAM, addr + 3, value & 0xff);}static uint32_t nvram_readb (void *opaque, target_phys_addr_t addr){    m48t59_t *NVRAM = opaque;    uint32_t retval;    addr -= NVRAM->mem_base;    retval = m48t59_read(NVRAM, addr);    return retval;}static uint32_t nvram_readw (void *opaque, target_phys_addr_t addr){    m48t59_t *NVRAM = opaque;    uint32_t retval;    addr -= NVRAM->mem_base;    retval = m48t59_read(NVRAM, addr) << 8;    retval |= m48t59_read(NVRAM, addr + 1);    return retval;}static uint32_t nvram_readl (void *opaque, target_phys_addr_t addr){    m48t59_t *NVRAM = opaque;    uint32_t retval;    addr -= NVRAM->mem_base;    retval = m48t59_read(NVRAM, addr) << 24;    retval |= m48t59_read(NVRAM, addr + 1) << 16;    retval |= m48t59_read(NVRAM, addr + 2) << 8;    retval |= m48t59_read(NVRAM, addr + 3);    return retval;}static CPUWriteMemoryFunc *nvram_write[] = {    &nvram_writeb,    &nvram_writew,    &nvram_writel,};static CPUReadMemoryFunc *nvram_read[] = {    &nvram_readb,    &nvram_readw,    &nvram_readl,};static void m48t59_save(QEMUFile *f, void *opaque){    m48t59_t *s = opaque;    qemu_put_8s(f, &s->lock);    qemu_put_be16s(f, &s->addr);    qemu_put_buffer(f, s->buffer, s->size);}static int m48t59_load(QEMUFile *f, void *opaque, int version_id){    m48t59_t *s = opaque;    if (version_id != 1)        return -EINVAL;    qemu_get_8s(f, &s->lock);    qemu_get_be16s(f, &s->addr);    qemu_get_buffer(f, s->buffer, s->size);    return 0;}static void m48t59_reset(void *opaque){    m48t59_t *NVRAM = opaque;    if (NVRAM->alrm_timer != NULL)        qemu_del_timer(NVRAM->alrm_timer);    if (NVRAM->wd_timer != NULL)        qemu_del_timer(NVRAM->wd_timer);}/* Initialisation routine */m48t59_t *m48t59_init (qemu_irq IRQ, target_phys_addr_t mem_base,                       uint32_t io_base, uint16_t size,                       int type){    m48t59_t *s;    target_phys_addr_t save_base;    s = qemu_mallocz(sizeof(m48t59_t));    if (!s)	return NULL;    s->buffer = qemu_mallocz(size);    if (!s->buffer) {        qemu_free(s);        return NULL;    }    s->IRQ = IRQ;    s->size = size;    s->mem_base = mem_base;    s->io_base = io_base;    s->addr = 0;    s->type = type;    if (io_base != 0) {        register_ioport_read(io_base, 0x04, 1, NVRAM_readb, s);        register_ioport_write(io_base, 0x04, 1, NVRAM_writeb, s);    }    if (mem_base != 0) {        s->mem_index = cpu_register_io_memory(0, nvram_read, nvram_write, s);        cpu_register_physical_memory(mem_base, size, s->mem_index);    }    if (type == 59) {        s->alrm_timer = qemu_new_timer(vm_clock, &alarm_cb, s);        s->wd_timer = qemu_new_timer(vm_clock, &watchdog_cb, s);    }    s->lock = 0;    qemu_register_reset(m48t59_reset, s);    save_base = mem_base ? mem_base : io_base;    register_savevm("m48t59", save_base, 1, m48t59_save, m48t59_load, s);    return s;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -