[PATCH 3/3] remoteproc: add CSRatlas7 remoteproc driver
Hillf Danton
hillf.zj at alibaba-inc.com
Tue Sep 15 01:43:12 PDT 2015
>
> In CSRaltas7, Cortex-A7 uses this proc to communicate with Cortex-M3.
> But M3 doesn't have to be a slave, it can boot indenpently or depend
> on Linux to load firmware for it.
>
> we reserve a memory for data and resource descriptors in DRAM.
>
> Signed-off-by: Wei Chen <Wei.Chen at csr.com>
> Signed-off-by: Barry Song <Baohua.Song at csr.com>
> ---
> .../bindings/remoteproc/sirf,remoteproc.txt | 33 ++
> drivers/remoteproc/Kconfig | 13 +
> drivers/remoteproc/Makefile | 1 +
> drivers/remoteproc/sirf_remoteproc.c | 467 +++++++++++++++++++++
> 4 files changed, 514 insertions(+)
> create mode 100644 Documentation/devicetree/bindings/remoteproc/sirf,remoteproc.txt
> create mode 100644 drivers/remoteproc/sirf_remoteproc.c
>
> diff --git a/Documentation/devicetree/bindings/remoteproc/sirf,remoteproc.txt
> b/Documentation/devicetree/bindings/remoteproc/sirf,remoteproc.txt
> new file mode 100644
> index 0000000..409fb40
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/remoteproc/sirf,remoteproc.txt
s/,/-/ ?
> @@ -0,0 +1,33 @@
> +SIRF Atlas7 Remote processor Device Binding
> +------------------------------------------------
> +1) Main node
> + Required properties :
> +
> + - compatible : "sirf,atlas7-rproc"
> +
> + - reg : register address of remoteproc device
> +
> + - interrupts: the irq number this rproc need to handle.
> +
> + - hwlocks: the hwlocks this rproc to used to protect data
s/to used/uses/ ?
> + between two processors.
> +
> + - memory-region: the memory region, which is used to store virtual
> + device info, fifo buffers and share memory between two processors.
> +
> + - firmware: the firmware file that will be loaded to remote processor.
> +
> +Please refer to ../reserved-memory/reserved-memory.txt for details of the
> +memory-region bindings.
> +Please refer to ../hwlock/hwlock.txt for details of the hwlock bindings.
> +
> +2) Example:
> + ns_m3_rproc at 0 {
> + compatible = "sirf,atlas7-rproc";
> + reg = <0x13240108 0x4>,
> + <0x13240208 0x4>;
> + interrupts = <0 123 0>;
> + hwlocks = <&hwlock 0>, <&hwlock 1>;
> + memory-region = <&ipc_mem0>;
> + firmware = "RTOSDemo.bin";
> + };
> diff --git a/drivers/remoteproc/Kconfig b/drivers/remoteproc/Kconfig
> index 28c711f..aeabbfa 100644
> --- a/drivers/remoteproc/Kconfig
> +++ b/drivers/remoteproc/Kconfig
> @@ -77,4 +77,17 @@ config DA8XX_REMOTEPROC
> It's safe to say n here if you're not interested in multimedia
> offloading.
>
> +config SIRF_REMOTEPROC
> + tristate "CSR atals7 remoteproc support"
> + depends on ARCH_ATLAS7
> + select REMOTEPROC
> + select RPMSG
> + default y
> + help
> + Say y or m here to support CSR Atlas7 Inter-Processors
> + Communication driver via remote processor framework.
> +
> + This can be either built-in or a loadable module.
> + If unsure say N.
> +
> endmenu
> diff --git a/drivers/remoteproc/Makefile b/drivers/remoteproc/Makefile
> index 81b04d1..8cc4790 100644
> --- a/drivers/remoteproc/Makefile
> +++ b/drivers/remoteproc/Makefile
> @@ -11,3 +11,4 @@ obj-$(CONFIG_OMAP_REMOTEPROC) += omap_remoteproc.o
> obj-$(CONFIG_STE_MODEM_RPROC) += ste_modem_rproc.o
> obj-$(CONFIG_WKUP_M3_RPROC) += wkup_m3_rproc.o
> obj-$(CONFIG_DA8XX_REMOTEPROC) += da8xx_remoteproc.o
> +obj-$(CONFIG_SIRF_REMOTEPROC) += sirf_remoteproc.o
> diff --git a/drivers/remoteproc/sirf_remoteproc.c b/drivers/remoteproc/sirf_remoteproc.c
> new file mode 100644
> index 0000000..cb7568d
> --- /dev/null
> +++ b/drivers/remoteproc/sirf_remoteproc.c
> @@ -0,0 +1,467 @@
> +/*
> + * SIRF Remote processor machine-specific module
> + *
> + * Copyright (c) 2014 Cambridge Silicon Radio Limited, a CSR plc group company.
> + *
> + * Licensed under GPLv2 or later.
> + */
> +
> +#include <linux/kernel.h>
> +#include <linux/module.h>
> +#include <linux/platform_device.h>
> +#include <linux/dma-mapping.h>
> +#include <linux/interrupt.h>
> +#include <linux/hwspinlock.h>
> +#include <linux/io.h>
> +#include <linux/of.h>
> +#include <linux/of_address.h>
> +#include <linux/of_irq.h>
> +#include <linux/of_device.h>
> +#include <linux/remoteproc.h>
> +
> +#include "remoteproc_internal.h"
> +
> +struct fifo_buffer {
> + struct hwspinlock *lock;
> + unsigned char *buffer;
> + u32 w_pos;
> + u32 r_pos;
> + u32 size;
> + u32 *count; /* pointer to shared memory */
> +};
> +
> +static int fifo_write(struct fifo_buffer *fifo,
> + const void *data, u32 len)
> +{
> + int err;
> + u32 overflow, count;
> + ulong flags;
> +
> + err = hwspin_lock_timeout_irqsave(fifo->lock, 100, &flags);
> + if (err) {
> + pr_err("%s, Get hwspinlock failed!err= %d\n",
> + __func__, err);
s/,// ?
s/!err=/! err/ ?
> + WARN_ON(err);
Given pr_err, add a comment for WARN_ON please if it
is really needed.
> + return -EBUSY;
> + }
> +
> + if (len > fifo->size) {
> + err = -EFBIG;
release fifo->lock ?
> + goto err_exit;
> + }
> +
> + count = *fifo->count;
> + overflow = len > (fifo->size - count);
> + if (overflow) {
> + /* previous data hasn't been read, FIFO busy */
> + err = -EBUSY;
ditto
> + goto err_exit;
> + }
> +
> + /* copy data to fifo buffer */
> + memcpy(fifo->buffer + fifo->w_pos, data, len);
> + /* update fifo position */
> + fifo->w_pos = (fifo->w_pos + len) % fifo->size;
> + *fifo->count = count + len;
> +
> + hwspin_unlock_irqrestore(fifo->lock, &flags);
> + err = 0;
> +
> +err_exit:
> + return err;
> +}
> +
More information about the linux-arm-kernel
mailing list