2019-05-19 13:07:45 +01:00
# SPDX-License-Identifier: GPL-2.0-only
2013-01-16 18:53:51 -08:00
menu "Remoteproc drivers"
2011-12-14 13:01:59 +02:00
2011-10-20 16:52:46 +02:00
config REMOTEPROC
2019-08-30 08:43:12 +02:00
bool "Support for Remote Processor subsystem"
2012-09-13 20:03:58 +02:00
depends on HAS_DMA
2013-04-07 14:06:07 +03:00
select CRC32
2013-03-28 18:41:43 -07:00
select FW_LOADER
2012-09-30 10:25:34 +02:00
select VIRTIO
2018-01-05 16:04:17 -08:00
select WANT_DEV_COREDUMP
2016-12-19 10:22:50 +01:00
help
Support for remote processors (such as DSP coprocessors). These
are mainly used on embedded systems.
2011-10-20 18:53:35 +02:00
2016-10-18 10:39:08 +01:00
if REMOTEPROC
2017-08-17 09:15:26 +02:00
config IMX_REMOTEPROC
tristate "IMX6/7 remoteproc support"
2019-06-03 20:46:27 -03:00
depends on ARCH_MXC
2017-08-17 09:15:26 +02:00
help
Say y here to support iMX's remote processors (Cortex M4
on iMX7D) via the remote processor framework.
It's safe to say N here.
2011-10-20 18:53:35 +02:00
config OMAP_REMOTEPROC
tristate "OMAP remoteproc support"
2013-02-18 12:06:52 +01:00
depends on ARCH_OMAP4 || SOC_OMAP5
2012-02-28 13:04:33 +02:00
depends on OMAP_IOMMU
2013-03-12 17:55:29 -05:00
select MAILBOX
select OMAP2PLUS_MBOX
2011-10-20 18:53:35 +02:00
help
Say y here to support OMAP's remote processors (dual M3
and DSP on OMAP4) via the remote processor framework.
Currently only supported on OMAP4.
2016-12-19 10:22:50 +01:00
Usually you want to say Y here, in order to enable multimedia
2011-10-20 18:53:35 +02:00
use-cases to run on your platform (multimedia codecs are
offloaded to remote DSP processors using this framework).
2016-12-19 10:22:50 +01:00
It's safe to say N here if you're not interested in multimedia
2011-10-20 18:53:35 +02:00
offloading or just want a bare minimum kernel.
2011-12-14 13:01:59 +02:00
2015-05-22 15:45:30 -05:00
config WKUP_M3_RPROC
tristate "AMx3xx Wakeup M3 remoteproc support"
depends on SOC_AM33XX || SOC_AM43XX
help
Say y here to support Wakeup M3 remote processor on TI AM33xx
and AM43xx family of SoCs.
Required for Suspend-to-RAM on AM33xx and AM43xx SoCs. Also needed
for deep CPUIdle states on AM33xx SoCs. Allows for loading of the
firmware onto these remote processors.
If unsure say N.
2013-04-09 14:20:21 -07:00
config DA8XX_REMOTEPROC
tristate "DA8xx/OMAP-L13x remoteproc support"
depends on ARCH_DAVINCI_DA8XX
2017-05-18 17:08:59 -05:00
depends on DMA_CMA
2013-04-09 14:20:21 -07:00
help
Say y here to support DA8xx/OMAP-L13x remote processors via the
remote processor framework.
You want to say y here in order to enable AMP
use-cases to run on your platform (multimedia codecs are
offloaded to remote DSP processors using this framework).
This module controls the name of the firmware file that gets
loaded on the DSP. This file must reside in the /lib/firmware
directory. It can be specified via the module parameter
da8xx_fw_name=<filename>, and if not specified will default to
"rproc-dsp-fw".
It's safe to say n here if you're not interested in multimedia
offloading.
remoteproc/keystone: Add a remoteproc driver for Keystone 2 DSPs
The Texas Instrument's Keystone 2 family of SoCs has 1 or more
TMS320C66x DSP Core Subsystems (C66x CorePacs). Each subsystem has
a C66x Fixed/Floating-Point DSP Core, with 32KB of L1P and L1D SRAMs,
that can be configured and partitioned as either RAM and/or Cache,
and 1 MB of L2 SRAM. The CorePac also includes an Internal DMA (IDMA),
External Memory Controller (EMC), Extended Memory Controller (XMC)
with a Memory Protection and Address Extension (MPAX) unit, a Bandwidth
Management (BWM) unit, an Interrupt Controller (INTC) and a Powerdown
Controller (PDC).
A new remoteproc module is added to perform the device management of
these DSP devices. The driver expects the firmware names to be of the
form "keystone-dsp<X>-fw", where X is the corresponding DSP number, and
uses the standard remoteproc core ELF loader. The support is limited
to images only using the DSP internal memories at the moment. This
remoteproc driver is also designed to work with virtio, and uses the
IPC Generation registers for performing the virtio signalling and
getting notified of exceptions.
The driver currently supports the 66AK2H/66AK2K, 66AK2L and 66AK2E
SoCs.
Signed-off-by: Suman Anna <s-anna@ti.com>
Signed-off-by: Sam Nelson <sam.nelson@ti.com>
Signed-off-by: Andrew F. Davis <afd@ti.com>
Acked-by: Santosh Shilimkar <ssantosh@kernel.org>
Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
2017-06-13 18:45:12 -05:00
config KEYSTONE_REMOTEPROC
tristate "Keystone Remoteproc support"
depends on ARCH_KEYSTONE
help
Say Y here here to support Keystone remote processors (DSP)
via the remote processor framework.
It's safe to say N here if you're not interested in the Keystone
DSPs or just want to use a bare minimum kernel.
2018-09-24 16:45:25 -07:00
config QCOM_RPROC_COMMON
tristate
config QCOM_Q6V5_COMMON
tristate
depends on ARCH_QCOM
depends on QCOM_SMEM
2018-09-24 16:37:50 +05:30
config QCOM_Q6V5_ADSP
tristate "Qualcomm Technology Inc ADSP Peripheral Image Loader"
depends on OF && ARCH_QCOM
depends on QCOM_SMEM
depends on RPMSG_QCOM_SMD || (COMPILE_TEST && RPMSG_QCOM_SMD=n)
depends on RPMSG_QCOM_GLINK_SMEM || RPMSG_QCOM_GLINK_SMEM=n
depends on QCOM_SYSMON || QCOM_SYSMON=n
select MFD_SYSCON
select QCOM_MDT_LOADER
select QCOM_Q6V5_COMMON
select QCOM_RPROC_COMMON
help
Say y here to support the Peripheral Image Loader
for the Qualcomm Technology Inc. ADSP remote processors.
2018-09-24 16:45:26 -07:00
config QCOM_Q6V5_MSS
tristate "Qualcomm Hexagon V5 self-authenticating modem subsystem support"
2016-08-22 22:57:44 -07:00
depends on OF && ARCH_QCOM
depends on QCOM_SMEM
2017-03-27 22:26:34 -07:00
depends on RPMSG_QCOM_SMD || (COMPILE_TEST && RPMSG_QCOM_SMD=n)
2017-08-29 16:13:35 -07:00
depends on RPMSG_QCOM_GLINK_SMEM || RPMSG_QCOM_GLINK_SMEM=n
2017-08-27 21:51:38 -07:00
depends on QCOM_SYSMON || QCOM_SYSMON=n
2016-08-22 22:57:44 -07:00
select MFD_SYSCON
2019-07-04 14:46:49 +08:00
select QCOM_MDT_LOADER
2018-06-04 13:30:37 -07:00
select QCOM_Q6V5_COMMON
2017-01-27 02:28:32 -08:00
select QCOM_RPROC_COMMON
2016-12-09 12:47:02 +01:00
select QCOM_SCM
2016-08-22 22:57:44 -07:00
help
2018-09-24 16:45:26 -07:00
Say y here to support the Qualcomm self-authenticating modem
subsystem based on Hexagon V5.
2018-06-04 13:30:36 -07:00
2018-09-24 16:45:26 -07:00
config QCOM_Q6V5_PAS
tristate "Qualcomm Hexagon v5 Peripheral Authentication Service support"
2016-06-20 14:28:41 -07:00
depends on OF && ARCH_QCOM
depends on QCOM_SMEM
2017-03-27 22:26:34 -07:00
depends on RPMSG_QCOM_SMD || (COMPILE_TEST && RPMSG_QCOM_SMD=n)
2017-09-11 21:54:17 +02:00
depends on RPMSG_QCOM_GLINK_SMEM || RPMSG_QCOM_GLINK_SMEM=n
2017-08-27 21:51:38 -07:00
depends on QCOM_SYSMON || QCOM_SYSMON=n
2016-06-20 14:28:41 -07:00
select MFD_SYSCON
2018-09-24 16:45:26 -07:00
select QCOM_MDT_LOADER
2018-06-04 13:30:38 -07:00
select QCOM_Q6V5_COMMON
2017-01-27 02:28:32 -08:00
select QCOM_RPROC_COMMON
2016-12-09 12:47:02 +01:00
select QCOM_SCM
2016-06-20 14:28:41 -07:00
help
2018-09-24 16:45:25 -07:00
Say y here to support the TrustZone based Peripherial Image Loader
for the Qualcomm Hexagon v5 based remote processors. This is commonly
used to control subsystems such as ADSP, Compute and Sensor.
2016-06-20 14:28:41 -07:00
2018-06-07 22:57:11 +05:30
config QCOM_Q6V5_WCSS
tristate "Qualcomm Hexagon based WCSS Peripheral Image Loader"
depends on OF && ARCH_QCOM
depends on QCOM_SMEM
2018-07-18 13:16:26 +02:00
depends on RPMSG_QCOM_SMD || (COMPILE_TEST && RPMSG_QCOM_SMD=n)
2018-06-07 22:57:11 +05:30
depends on RPMSG_QCOM_GLINK_SMEM || RPMSG_QCOM_GLINK_SMEM=n
depends on QCOM_SYSMON || QCOM_SYSMON=n
select MFD_SYSCON
select QCOM_MDT_LOADER
select QCOM_Q6V5_COMMON
select QCOM_RPROC_COMMON
select QCOM_SCM
help
Say y here to support the Qualcomm Peripheral Image Loader for the
Hexagon V5 based WCSS remote processors.
2017-08-27 21:51:38 -07:00
config QCOM_SYSMON
tristate "Qualcomm sysmon driver"
depends on RPMSG
depends on ARCH_QCOM
2018-02-22 16:57:38 +01:00
depends on NET
2017-08-27 21:51:38 -07:00
select QCOM_QMI_HELPERS
help
The sysmon driver implements a sysmon QMI client and a handler for
the sys_mon SMD and GLINK channel, which are used for graceful
shutdown, retrieving failure information and propagating information
about other subsystems being shut down.
Say y here if your system runs firmware on any other subsystems, e.g.
modem or DSP.
2016-08-12 18:18:59 -07:00
config QCOM_WCNSS_PIL
tristate "Qualcomm WCNSS Peripheral Image Loader"
depends on OF && ARCH_QCOM
2017-03-27 22:26:34 -07:00
depends on RPMSG_QCOM_SMD || (COMPILE_TEST && RPMSG_QCOM_SMD=n)
2017-09-11 21:54:17 +02:00
depends on RPMSG_QCOM_GLINK_SMEM || RPMSG_QCOM_GLINK_SMEM=n
2016-08-12 18:18:59 -07:00
depends on QCOM_SMEM
2017-08-27 21:51:38 -07:00
depends on QCOM_SYSMON || QCOM_SYSMON=n
2016-08-12 18:18:59 -07:00
select QCOM_MDT_LOADER
2017-01-27 02:28:32 -08:00
select QCOM_RPROC_COMMON
2016-08-12 18:18:59 -07:00
select QCOM_SCM
help
Say y here to support the Peripheral Image Loader for the Qualcomm
Wireless Connectivity Subsystem.
2016-01-12 12:46:18 +00:00
config ST_REMOTEPROC
tristate "ST remoteproc support"
depends on ARCH_STI
2017-01-31 13:35:54 +01:00
select MAILBOX
select STI_MBOX
2016-01-12 12:46:18 +00:00
help
Say y here to support ST's adjunct processors via the remote
processor framework.
This can be either built-in or a loadable module.
2016-10-18 10:39:06 +01:00
config ST_SLIM_REMOTEPROC
tristate
2016-10-18 10:39:08 +01:00
2019-05-14 10:26:58 +02:00
config STM32_RPROC
tristate "STM32 remoteproc support"
depends on ARCH_STM32
depends on REMOTEPROC
select MAILBOX
help
Say y here to support STM32 MCU processors via the
remote processor framework.
You want to say y here in order to enable AMP
use-cases to run on your platform (dedicated firmware could be
offloaded to remote MCU processors using this framework).
This can be either built-in or a loadable module.
2016-10-18 10:39:08 +01:00
endif # REMOTEPROC
2016-10-18 10:39:06 +01:00
2011-12-14 13:01:59 +02:00
endmenu