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
{
    DeviceState *dev;

9
    dev = qdev_create(NULL, "xlnx.xps-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
                      int txpingpong, int rxpingpong)
{
    DeviceState *dev;

39
    qemu_check_nic_model(nd, "xlnx.xps-ethernetlite");
40

41
    dev = qdev_create(NULL, "xlnx.xps-ethernetlite");
42
    qdev_set_nic_properties(dev, nd);
43 44
    qdev_prop_set_uint32(dev, "tx-ping-pong", txpingpong);
    qdev_prop_set_uint32(dev, "rx-ping-pong", 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

static inline DeviceState *
xilinx_axiethernet_create(void *dmach,
                          NICInfo *nd, target_phys_addr_t base, qemu_irq irq,
                          int txmem, int rxmem)
{
    DeviceState *dev;
57
    qemu_check_nic_model(nd, "xlnx.axi-ethernet");
58

59
    dev = qdev_create(NULL, "xlnx.axi-ethernet");
60
    qdev_set_nic_properties(dev, nd);
61 62
    qdev_prop_set_uint32(dev, "rxmem", rxmem);
    qdev_prop_set_uint32(dev, "txmem", txmem);
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
    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;

78
    dev = qdev_create(NULL, "xlnx.axi-dma");
79 80 81 82 83
    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;
}