summary refs log tree commit diff stats
path: root/include/hw/cris/etraxfs_dma.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/hw/cris/etraxfs_dma.h')
-rw-r--r--include/hw/cris/etraxfs_dma.h34
1 files changed, 34 insertions, 0 deletions
diff --git a/include/hw/cris/etraxfs_dma.h b/include/hw/cris/etraxfs_dma.h
new file mode 100644
index 0000000000..38104a67b5
--- /dev/null
+++ b/include/hw/cris/etraxfs_dma.h
@@ -0,0 +1,34 @@
+#ifndef HW_ETRAXFS_DMA_H
+#define HW_ETRAXFS_DMA_H 1
+
+struct dma_context_metadata {
+	/* data descriptor md */
+	uint16_t metadata;
+};
+
+struct etraxfs_dma_client
+{
+	/* DMA controller. */
+	int channel;
+	void *ctrl;
+
+	/* client.  */
+	struct {
+		int (*push)(void *opaque, unsigned char *buf,
+		            int len, bool eop);
+		void (*pull)(void *opaque);
+		void (*metadata_push)(void *opaque,
+		                      const struct dma_context_metadata *md);
+		void *opaque;
+	} client;
+};
+
+void *etraxfs_dmac_init(hwaddr base, int nr_channels);
+void etraxfs_dmac_connect(void *opaque, int channel, qemu_irq *line,
+			  int input);
+void etraxfs_dmac_connect_client(void *opaque, int c, 
+				 struct etraxfs_dma_client *cl);
+int etraxfs_dmac_input(struct etraxfs_dma_client *client, 
+		       void *buf, int len, int eop);
+
+#endif