xilinx.h 1.5 KB
Newer Older
1 2 3 4 5

/* OPB Interrupt Controller.  */
qemu_irq *microblaze_pic_init_cpu(CPUState *env);

static inline DeviceState *
A
Anthony Liguori 已提交
6
xilinx_intc_create(target_phys_addr_t base, qemu_irq irq, int kind_of_intr)
7 8 9 10
{
    DeviceState *dev;

    dev = qdev_create(NULL, "xilinx,intc");
G
Gerd Hoffmann 已提交
11
    qdev_prop_set_uint32(dev, "kind-of-intr", kind_of_intr);
M
Markus Armbruster 已提交
12
    qdev_init_nofail(dev);
13 14 15 16 17 18 19
    sysbus_mmio_map(sysbus_from_qdev(dev), 0, base);
    sysbus_connect_irq(sysbus_from_qdev(dev), 0, irq);
    return dev;
}

/* OPB Timer/Counter.  */
static inline DeviceState *
A
Anthony Liguori 已提交
20
xilinx_timer_create(target_phys_addr_t base, qemu_irq irq, int nr, int freq)
21 22 23 24
{
    DeviceState *dev;

    dev = qdev_create(NULL, "xilinx,timer");
G
Gerd Hoffmann 已提交
25 26
    qdev_prop_set_uint32(dev, "nr-timers", nr);
    qdev_prop_set_uint32(dev, "frequency", freq);
M
Markus Armbruster 已提交
27
    qdev_init_nofail(dev);
28 29 30 31 32 33 34
    sysbus_mmio_map(sysbus_from_qdev(dev), 0, base);
    sysbus_connect_irq(sysbus_from_qdev(dev), 0, irq);
    return dev;
}

/* XPS Ethernet Lite MAC.  */
static inline DeviceState *
A
Anthony Liguori 已提交
35
xilinx_ethlite_create(NICInfo *nd, target_phys_addr_t base, qemu_irq irq,
36 37 38 39 40 41 42
                      int txpingpong, int rxpingpong)
{
    DeviceState *dev;

    qemu_check_nic_model(nd, "xilinx-ethlite");

    dev = qdev_create(NULL, "xilinx,ethlite");
43
    qdev_set_nic_properties(dev, nd);
G
Gerd Hoffmann 已提交
44 45
    qdev_prop_set_uint32(dev, "txpingpong", txpingpong);
    qdev_prop_set_uint32(dev, "rxpingpong", rxpingpong);
M
Markus Armbruster 已提交
46
    qdev_init_nofail(dev);
47 48 49 50
    sysbus_mmio_map(sysbus_from_qdev(dev), 0, base);
    sysbus_connect_irq(sysbus_from_qdev(dev), 0, irq);
    return dev;
}