Merge commit 'd34e8f6e9d3a396c3327aa9807c83f9e1f4a7bd7' into upstream-merge
[qemu-kvm.git] / hw / etraxfs_dma.h
blob021c52ae7d7c6a70b70bb797eaf2a671b1a03ae0
1 struct dma_context_metadata {
2 /* data descriptor md */
3 uint16_t metadata;
4 };
6 struct etraxfs_dma_client
8 /* DMA controller. */
9 int channel;
10 void *ctrl;
12 /* client. */
13 struct {
14 int (*push)(void *opaque, unsigned char *buf,
15 int len, bool eop);
16 void (*pull)(void *opaque);
17 void (*metadata_push)(void *opaque,
18 const struct dma_context_metadata *md);
19 void *opaque;
20 } client;
23 void *etraxfs_dmac_init(target_phys_addr_t base, int nr_channels);
24 void etraxfs_dmac_connect(void *opaque, int channel, qemu_irq *line,
25 int input);
26 void etraxfs_dmac_connect_client(void *opaque, int c,
27 struct etraxfs_dma_client *cl);
28 int etraxfs_dmac_input(struct etraxfs_dma_client *client,
29 void *buf, int len, int eop);