integratorcp.c

来自「xen虚拟机源代码安装包」· C语言 代码 · 共 548 行 · 第 1/2 页

C
548
字号
  uint32_t base;  uint32_t level;  uint32_t irq_enabled;  uint32_t fiq_enabled;  qemu_irq parent_irq;  qemu_irq parent_fiq;} icp_pic_state;static void icp_pic_update(icp_pic_state *s){    uint32_t flags;    flags = (s->level & s->irq_enabled);    qemu_set_irq(s->parent_irq, flags != 0);    flags = (s->level & s->fiq_enabled);    qemu_set_irq(s->parent_fiq, flags != 0);}static void icp_pic_set_irq(void *opaque, int irq, int level){    icp_pic_state *s = (icp_pic_state *)opaque;    if (level)        s->level |= 1 << irq;    else        s->level &= ~(1 << irq);    icp_pic_update(s);}static uint32_t icp_pic_read(void *opaque, target_phys_addr_t offset){    icp_pic_state *s = (icp_pic_state *)opaque;    offset -= s->base;    switch (offset >> 2) {    case 0: /* IRQ_STATUS */        return s->level & s->irq_enabled;    case 1: /* IRQ_RAWSTAT */        return s->level;    case 2: /* IRQ_ENABLESET */        return s->irq_enabled;    case 4: /* INT_SOFTSET */        return s->level & 1;    case 8: /* FRQ_STATUS */        return s->level & s->fiq_enabled;    case 9: /* FRQ_RAWSTAT */        return s->level;    case 10: /* FRQ_ENABLESET */        return s->fiq_enabled;    case 3: /* IRQ_ENABLECLR */    case 5: /* INT_SOFTCLR */    case 11: /* FRQ_ENABLECLR */    default:        printf ("icp_pic_read: Bad register offset 0x%x\n", (int)offset);        return 0;    }}static void icp_pic_write(void *opaque, target_phys_addr_t offset,                          uint32_t value){    icp_pic_state *s = (icp_pic_state *)opaque;    offset -= s->base;    switch (offset >> 2) {    case 2: /* IRQ_ENABLESET */        s->irq_enabled |= value;        break;    case 3: /* IRQ_ENABLECLR */        s->irq_enabled &= ~value;        break;    case 4: /* INT_SOFTSET */        if (value & 1)            icp_pic_set_irq(s, 0, 1);        break;    case 5: /* INT_SOFTCLR */        if (value & 1)            icp_pic_set_irq(s, 0, 0);        break;    case 10: /* FRQ_ENABLESET */        s->fiq_enabled |= value;        break;    case 11: /* FRQ_ENABLECLR */        s->fiq_enabled &= ~value;        break;    case 0: /* IRQ_STATUS */    case 1: /* IRQ_RAWSTAT */    case 8: /* FRQ_STATUS */    case 9: /* FRQ_RAWSTAT */    default:        printf ("icp_pic_write: Bad register offset 0x%x\n", (int)offset);        return;    }    icp_pic_update(s);}static CPUReadMemoryFunc *icp_pic_readfn[] = {   icp_pic_read,   icp_pic_read,   icp_pic_read};static CPUWriteMemoryFunc *icp_pic_writefn[] = {   icp_pic_write,   icp_pic_write,   icp_pic_write};static qemu_irq *icp_pic_init(uint32_t base,                              qemu_irq parent_irq, qemu_irq parent_fiq){    icp_pic_state *s;    int iomemtype;    qemu_irq *qi;    s = (icp_pic_state *)qemu_mallocz(sizeof(icp_pic_state));    if (!s)        return NULL;    qi = qemu_allocate_irqs(icp_pic_set_irq, s, 32);    s->base = base;    s->parent_irq = parent_irq;    s->parent_fiq = parent_fiq;    iomemtype = cpu_register_io_memory(0, icp_pic_readfn,                                       icp_pic_writefn, s);    cpu_register_physical_memory(base, 0x00800000, iomemtype);    /* ??? Save/restore.  */    return qi;}/* CP control registers.  */typedef struct {    uint32_t base;} icp_control_state;static uint32_t icp_control_read(void *opaque, target_phys_addr_t offset){    icp_control_state *s = (icp_control_state *)opaque;    offset -= s->base;    switch (offset >> 2) {    case 0: /* CP_IDFIELD */        return 0x41034003;    case 1: /* CP_FLASHPROG */        return 0;    case 2: /* CP_INTREG */        return 0;    case 3: /* CP_DECODE */        return 0x11;    default:        cpu_abort (cpu_single_env, "icp_control_read: Bad offset %x\n",                   (int)offset);        return 0;    }}static void icp_control_write(void *opaque, target_phys_addr_t offset,                          uint32_t value){    icp_control_state *s = (icp_control_state *)opaque;    offset -= s->base;    switch (offset >> 2) {    case 1: /* CP_FLASHPROG */    case 2: /* CP_INTREG */    case 3: /* CP_DECODE */        /* Nothing interesting implemented yet.  */        break;    default:        cpu_abort (cpu_single_env, "icp_control_write: Bad offset %x\n",                   (int)offset);    }}static CPUReadMemoryFunc *icp_control_readfn[] = {   icp_control_read,   icp_control_read,   icp_control_read};static CPUWriteMemoryFunc *icp_control_writefn[] = {   icp_control_write,   icp_control_write,   icp_control_write};static void icp_control_init(uint32_t base){    int iomemtype;    icp_control_state *s;    s = (icp_control_state *)qemu_mallocz(sizeof(icp_control_state));    iomemtype = cpu_register_io_memory(0, icp_control_readfn,                                       icp_control_writefn, s);    cpu_register_physical_memory(base, 0x00800000, iomemtype);    s->base = base;    /* ??? Save/restore.  */}/* Board init.  */static struct arm_boot_info integrator_binfo = {    .loader_start = 0x0,    .board_id = 0x113,};static void integratorcp_init(ram_addr_t ram_size, int vga_ram_size,                     const char *boot_device, DisplayState *ds,                     const char *kernel_filename, const char *kernel_cmdline,                     const char *initrd_filename, const char *cpu_model){    CPUState *env;    uint32_t ram_offset;    qemu_irq *pic;    qemu_irq *cpu_pic;    int sd;    if (!cpu_model)        cpu_model = "arm926";    env = cpu_init(cpu_model);    if (!env) {        fprintf(stderr, "Unable to find CPU definition\n");        exit(1);    }    ram_offset = qemu_ram_alloc(ram_size);    /* ??? On a real system the first 1Mb is mapped as SSRAM or boot flash.  */    /* ??? RAM shoud repeat to fill physical memory space.  */    /* SDRAM at address zero*/    cpu_register_physical_memory(0, ram_size, ram_offset | IO_MEM_RAM);    /* And again at address 0x80000000 */    cpu_register_physical_memory(0x80000000, ram_size, ram_offset | IO_MEM_RAM);    integratorcm_init(ram_size >> 20);    cpu_pic = arm_pic_init_cpu(env);    pic = icp_pic_init(0x14000000, cpu_pic[ARM_PIC_CPU_IRQ],                       cpu_pic[ARM_PIC_CPU_FIQ]);    icp_pic_init(0xca000000, pic[26], NULL);    icp_pit_init(0x13000000, pic, 5);    pl031_init(0x15000000, pic[8]);    pl011_init(0x16000000, pic[1], serial_hds[0], PL011_ARM);    pl011_init(0x17000000, pic[2], serial_hds[1], PL011_ARM);    icp_control_init(0xcb000000);    pl050_init(0x18000000, pic[3], 0);    pl050_init(0x19000000, pic[4], 1);    sd = drive_get_index(IF_SD, 0, 0);    if (sd == -1) {        fprintf(stderr, "qemu: missing SecureDigital card\n");        exit(1);    }    pl181_init(0x1c000000, drives_table[sd].bdrv, pic[23], pic[24]);    if (nd_table[0].vlan) {        if (nd_table[0].model == NULL            || strcmp(nd_table[0].model, "smc91c111") == 0) {            smc91c111_init(&nd_table[0], 0xc8000000, pic[27]);        } else if (strcmp(nd_table[0].model, "?") == 0) {            fprintf(stderr, "qemu: Supported NICs: smc91c111\n");            exit (1);        } else {            fprintf(stderr, "qemu: Unsupported NIC: %s\n", nd_table[0].model);            exit (1);        }    }    pl110_init(ds, 0xc0000000, pic[22], 0);    integrator_binfo.ram_size = ram_size;    integrator_binfo.kernel_filename = kernel_filename;    integrator_binfo.kernel_cmdline = kernel_cmdline;    integrator_binfo.initrd_filename = initrd_filename;    arm_load_kernel(env, &integrator_binfo);}QEMUMachine integratorcp_machine = {    "integratorcp",    "ARM Integrator/CP (ARM926EJ-S)",    integratorcp_init,    0x100000,};

⌨️ 快捷键说明

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