summaryrefslogtreecommitdiffstats
path: root/include/linux/virtio_caif.h
diff options
context:
space:
mode:
authorErwan Yvin <erwan.yvin@stericsson.com>2013-03-20 13:52:24 +1030
committerRusty Russell <rusty@rustcorp.com.au>2013-03-20 14:06:06 +1030
commit0d2e1a2926b1839a4b74519e660739b2566c9386 (patch)
tree29f6397b0f544c60bfdbc8d9ad0aae5337fc7532 /include/linux/virtio_caif.h
parent3beee86a4b9374e38dba36b44e81f1423a0d6b54 (diff)
downloadlinux-0d2e1a2926b1839a4b74519e660739b2566c9386.tar.gz
linux-0d2e1a2926b1839a4b74519e660739b2566c9386.tar.bz2
linux-0d2e1a2926b1839a4b74519e660739b2566c9386.zip
caif_virtio: Introduce caif over virtio
Add the CAIF Virtio shared memory driver for talking to a modem. This CAIF Link layer communicates to the modem over shared memory. It is implemented as a virtio_driver. The underlying virtio device is managed by the remoteproc framework. The Virtio queue is used for transmitting data to the modem, and the new vringh is used for receiving data. Genalloc is used for managing the shared memory used for TX data. The default dma-alloc-coherent allocator can only allocate whole pages, and this wastes too much shared memory. Flow control is implemented by stopping the TX-queues if the virtio queues go full or we run out of memory. Queued are reopened when queues are below the watermark. NAPI is used in RX path, and a dedicated tasklet is used for releasing TX buffers. Signed-off-by: Erwan Yvin <erwan.yvin@stericsson.com> Acked-by: David S. Miller <davem@davemloft.net> Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> (minor fixes)
Diffstat (limited to 'include/linux/virtio_caif.h')
-rw-r--r--include/linux/virtio_caif.h24
1 files changed, 24 insertions, 0 deletions
diff --git a/include/linux/virtio_caif.h b/include/linux/virtio_caif.h
new file mode 100644
index 000000000000..5d2d3124ca3d
--- /dev/null
+++ b/include/linux/virtio_caif.h
@@ -0,0 +1,24 @@
+/*
+ * Copyright (C) ST-Ericsson AB 2012
+ * Author: Sjur Brændeland <sjur.brandeland@stericsson.com>
+ *
+ * This header is BSD licensed so
+ * anyone can use the definitions to implement compatible remote processors
+ */
+
+#ifndef VIRTIO_CAIF_H
+#define VIRTIO_CAIF_H
+
+#include <linux/types.h>
+struct virtio_caif_transf_config {
+ u16 headroom;
+ u16 tailroom;
+ u32 mtu;
+ u8 reserved[4];
+};
+
+struct virtio_caif_config {
+ struct virtio_caif_transf_config uplink, downlink;
+ u8 reserved[8];
+};
+#endif