xilinx.h 2.7 KB
Newer Older
1 2
#include "qemu-common.h"
#include "net.h"
3 4

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

    dev = qdev_create(NULL, "xilinx,intc");
G
Gerd Hoffmann 已提交
10
    qdev_prop_set_uint32(dev, "kind-of-intr", kind_of_intr);
M
Markus Armbruster 已提交
11
    qdev_init_nofail(dev);
12 13 14 15 16 17 18
    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 *
19
xilinx_timer_create(target_phys_addr_t base, qemu_irq irq, int oto, int freq)
20 21 22
{
    DeviceState *dev;

23
    dev = qdev_create(NULL, "xlnx,xps-timer");
24
    qdev_prop_set_uint32(dev, "one-timer-only", oto);
G
Gerd Hoffmann 已提交
25
    qdev_prop_set_uint32(dev, "frequency", freq);
M
Markus Armbruster 已提交
26
    qdev_init_nofail(dev);
27 28 29 30 31 32 33
    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 已提交
34
xilinx_ethlite_create(NICInfo *nd, target_phys_addr_t base, qemu_irq irq,
35 36 37 38 39 40 41
                      int txpingpong, int rxpingpong)
{
    DeviceState *dev;

    qemu_check_nic_model(nd, "xilinx-ethlite");

    dev = qdev_create(NULL, "xilinx,ethlite");
42
    qdev_set_nic_properties(dev, nd);
G
Gerd Hoffmann 已提交
43 44
    qdev_prop_set_uint32(dev, "txpingpong", txpingpong);
    qdev_prop_set_uint32(dev, "rxpingpong", rxpingpong);
M
Markus Armbruster 已提交
45
    qdev_init_nofail(dev);
46 47 48 49
    sysbus_mmio_map(sysbus_from_qdev(dev), 0, base);
    sysbus_connect_irq(sysbus_from_qdev(dev), 0, irq);
    return dev;
}
50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83

static inline DeviceState *
xilinx_axiethernet_create(void *dmach,
                          NICInfo *nd, target_phys_addr_t base, qemu_irq irq,
                          int txmem, int rxmem)
{
    DeviceState *dev;
    qemu_check_nic_model(nd, "xilinx-axienet");

    dev = qdev_create(NULL, "xilinx,axienet");
    qdev_set_nic_properties(dev, nd);
    qdev_prop_set_uint32(dev, "c_rxmem", rxmem);
    qdev_prop_set_uint32(dev, "c_txmem", txmem);
    qdev_prop_set_ptr(dev, "dmach", dmach);
    qdev_init_nofail(dev);
    sysbus_mmio_map(sysbus_from_qdev(dev), 0, base);
    sysbus_connect_irq(sysbus_from_qdev(dev), 0, irq);

    return dev;
}

static inline DeviceState *
xilinx_axiethernetdma_create(void *dmach,
                             target_phys_addr_t base, qemu_irq irq,
                             qemu_irq irq2, int freqhz)
{
    DeviceState *dev = NULL;

    dev = qdev_create(NULL, "xilinx,axidma");
    qdev_prop_set_uint32(dev, "freqhz", freqhz);
    qdev_prop_set_ptr(dev, "dmach", dmach);
    qdev_init_nofail(dev);

    sysbus_mmio_map(sysbus_from_qdev(dev), 0, base);
84 85
    sysbus_connect_irq(sysbus_from_qdev(dev), 0, irq);
    sysbus_connect_irq(sysbus_from_qdev(dev), 1, irq2);
86 87 88

    return dev;
}