> 
> 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;
> +}
> +

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to