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

📄 parallel.c.svn-base

📁 我们自己开发的一个OSEK操作系统!不知道可不可以?
💻 SVN-BASE
📖 第 1 页 / 共 2 页
字号:
    return ret;}static uint32_t parallel_ioport_read_hw(void *opaque, uint32_t addr){    ParallelState *s = opaque;    uint8_t ret = 0xff;    addr &= 7;    switch(addr) {    case PARA_REG_DATA:        qemu_chr_ioctl(s->chr, CHR_IOCTL_PP_READ_DATA, &ret);        if (s->last_read_offset != addr || s->datar != ret)            pdebug("rd%02x\n", ret);        s->datar = ret;        break;    case PARA_REG_STS:        qemu_chr_ioctl(s->chr, CHR_IOCTL_PP_READ_STATUS, &ret);        ret &= ~PARA_STS_TMOUT;        if (s->epp_timeout)            ret |= PARA_STS_TMOUT;        if (s->last_read_offset != addr || s->status != ret)            pdebug("rs%02x\n", ret);        s->status = ret;        break;    case PARA_REG_CTR:        /* s->control has some bits fixed to 1. It is zero only when           it has not been yet written to.  */        if (s->control == 0) {            qemu_chr_ioctl(s->chr, CHR_IOCTL_PP_READ_CONTROL, &ret);            if (s->last_read_offset != addr)                pdebug("rc%02x\n", ret);            s->control = ret;        }        else {            ret = s->control;            if (s->last_read_offset != addr)                pdebug("rc%02x\n", ret);        }        break;    case PARA_REG_EPP_ADDR:        if ((s->control & (PARA_CTR_DIR|PARA_CTR_SIGNAL)) != (PARA_CTR_DIR|PARA_CTR_INIT))            /* Controls not correct for EPP addr cycle, so do nothing */            pdebug("ra%02x s\n", ret);        else {            struct ParallelIOArg ioarg = { .buffer = &ret, .count = 1 };            if (qemu_chr_ioctl(s->chr, CHR_IOCTL_PP_EPP_READ_ADDR, &ioarg)) {                s->epp_timeout = 1;                pdebug("ra%02x t\n", ret);            }            else                pdebug("ra%02x\n", ret);        }        break;    case PARA_REG_EPP_DATA:        if ((s->control & (PARA_CTR_DIR|PARA_CTR_SIGNAL)) != (PARA_CTR_DIR|PARA_CTR_INIT))            /* Controls not correct for EPP data cycle, so do nothing */            pdebug("re%02x s\n", ret);        else {            struct ParallelIOArg ioarg = { .buffer = &ret, .count = 1 };            if (qemu_chr_ioctl(s->chr, CHR_IOCTL_PP_EPP_READ, &ioarg)) {                s->epp_timeout = 1;                pdebug("re%02x t\n", ret);            }            else                pdebug("re%02x\n", ret);        }        break;    }    s->last_read_offset = addr;    return ret;}static uint32_tparallel_ioport_eppdata_read_hw2(void *opaque, uint32_t addr){    ParallelState *s = opaque;    uint32_t ret;    uint16_t eppdata = ~0;    int err;    struct ParallelIOArg ioarg = {        .buffer = &eppdata, .count = sizeof(eppdata)    };    if ((s->control & (PARA_CTR_DIR|PARA_CTR_SIGNAL)) != (PARA_CTR_DIR|PARA_CTR_INIT)) {        /* Controls not correct for EPP data cycle, so do nothing */        pdebug("re%04x s\n", eppdata);        return eppdata;    }    err = qemu_chr_ioctl(s->chr, CHR_IOCTL_PP_EPP_READ, &ioarg);    ret = le16_to_cpu(eppdata);    if (err) {        s->epp_timeout = 1;        pdebug("re%04x t\n", ret);    }    else        pdebug("re%04x\n", ret);    return ret;}static uint32_tparallel_ioport_eppdata_read_hw4(void *opaque, uint32_t addr){    ParallelState *s = opaque;    uint32_t ret;    uint32_t eppdata = ~0U;    int err;    struct ParallelIOArg ioarg = {        .buffer = &eppdata, .count = sizeof(eppdata)    };    if ((s->control & (PARA_CTR_DIR|PARA_CTR_SIGNAL)) != (PARA_CTR_DIR|PARA_CTR_INIT)) {        /* Controls not correct for EPP data cycle, so do nothing */        pdebug("re%08x s\n", eppdata);        return eppdata;    }    err = qemu_chr_ioctl(s->chr, CHR_IOCTL_PP_EPP_READ, &ioarg);    ret = le32_to_cpu(eppdata);    if (err) {        s->epp_timeout = 1;        pdebug("re%08x t\n", ret);    }    else        pdebug("re%08x\n", ret);    return ret;}static void parallel_ioport_ecp_write(void *opaque, uint32_t addr, uint32_t val){    addr &= 7;    pdebug("wecp%d=%02x\n", addr, val);}static uint32_t parallel_ioport_ecp_read(void *opaque, uint32_t addr){    uint8_t ret = 0xff;    addr &= 7;    pdebug("recp%d:%02x\n", addr, ret);    return ret;}static void parallel_reset(ParallelState *s, qemu_irq irq, CharDriverState *chr){    s->datar = ~0;    s->dataw = ~0;    s->status = PARA_STS_BUSY;    s->status |= PARA_STS_ACK;    s->status |= PARA_STS_ONLINE;    s->status |= PARA_STS_ERROR;    s->control = PARA_CTR_SELECT;    s->control |= PARA_CTR_INIT;    s->irq = irq;    s->irq_pending = 0;    s->chr = chr;    s->hw_driver = 0;    s->epp_timeout = 0;    s->last_read_offset = ~0U;}/* If fd is zero, it means that the parallel device uses the console */ParallelState *parallel_init(int base, qemu_irq irq, CharDriverState *chr){    ParallelState *s;    uint8_t dummy;    s = qemu_mallocz(sizeof(ParallelState));    if (!s)        return NULL;    parallel_reset(s, irq, chr);    if (qemu_chr_ioctl(chr, CHR_IOCTL_PP_READ_STATUS, &dummy) == 0) {        s->hw_driver = 1;        s->status = dummy;    }    if (s->hw_driver) {        register_ioport_write(base, 8, 1, parallel_ioport_write_hw, s);        register_ioport_read(base, 8, 1, parallel_ioport_read_hw, s);        register_ioport_write(base+4, 1, 2, parallel_ioport_eppdata_write_hw2, s);        register_ioport_read(base+4, 1, 2, parallel_ioport_eppdata_read_hw2, s);        register_ioport_write(base+4, 1, 4, parallel_ioport_eppdata_write_hw4, s);        register_ioport_read(base+4, 1, 4, parallel_ioport_eppdata_read_hw4, s);        register_ioport_write(base+0x400, 8, 1, parallel_ioport_ecp_write, s);        register_ioport_read(base+0x400, 8, 1, parallel_ioport_ecp_read, s);    }    else {        register_ioport_write(base, 8, 1, parallel_ioport_write_sw, s);        register_ioport_read(base, 8, 1, parallel_ioport_read_sw, s);    }    return s;}/* Memory mapped interface */static uint32_t parallel_mm_readb (void *opaque, target_phys_addr_t addr){    ParallelState *s = opaque;    return parallel_ioport_read_sw(s, (addr - s->base) >> s->it_shift) & 0xFF;}static void parallel_mm_writeb (void *opaque,                                target_phys_addr_t addr, uint32_t value){    ParallelState *s = opaque;    parallel_ioport_write_sw(s, (addr - s->base) >> s->it_shift, value & 0xFF);}static uint32_t parallel_mm_readw (void *opaque, target_phys_addr_t addr){    ParallelState *s = opaque;    return parallel_ioport_read_sw(s, (addr - s->base) >> s->it_shift) & 0xFFFF;}static void parallel_mm_writew (void *opaque,                                target_phys_addr_t addr, uint32_t value){    ParallelState *s = opaque;    parallel_ioport_write_sw(s, (addr - s->base) >> s->it_shift, value & 0xFFFF);}static uint32_t parallel_mm_readl (void *opaque, target_phys_addr_t addr){    ParallelState *s = opaque;    return parallel_ioport_read_sw(s, (addr - s->base) >> s->it_shift);}static void parallel_mm_writel (void *opaque,                                target_phys_addr_t addr, uint32_t value){    ParallelState *s = opaque;    parallel_ioport_write_sw(s, (addr - s->base) >> s->it_shift, value);}static CPUReadMemoryFunc *parallel_mm_read_sw[] = {    &parallel_mm_readb,    &parallel_mm_readw,    &parallel_mm_readl,};static CPUWriteMemoryFunc *parallel_mm_write_sw[] = {    &parallel_mm_writeb,    &parallel_mm_writew,    &parallel_mm_writel,};/* If fd is zero, it means that the parallel device uses the console */ParallelState *parallel_mm_init(target_phys_addr_t base, int it_shift, qemu_irq irq, CharDriverState *chr){    ParallelState *s;    int io_sw;    s = qemu_mallocz(sizeof(ParallelState));    if (!s)        return NULL;    parallel_reset(s, irq, chr);    s->base = base;    s->it_shift = it_shift;    io_sw = cpu_register_io_memory(0, parallel_mm_read_sw, parallel_mm_write_sw, s);    cpu_register_physical_memory(base, 8 << it_shift, io_sw);    return s;}

⌨️ 快捷键说明

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