2024-06-15 21:02:09 +02:00
|
|
|
# SPDX-License-Identifier: GPL-2.0-only
|
|
|
|
menu "Remoteproc drivers"
|
|
|
|
|
|
|
|
config REMOTEPROC
|
|
|
|
bool "Support for Remote Processor subsystem"
|
|
|
|
depends on HAS_DMA
|
|
|
|
select CRC32
|
|
|
|
select FW_LOADER
|
|
|
|
select VIRTIO
|
|
|
|
select WANT_DEV_COREDUMP
|
|
|
|
help
|
|
|
|
Support for remote processors (such as DSP coprocessors). These
|
|
|
|
are mainly used on embedded systems.
|
|
|
|
|
|
|
|
if REMOTEPROC
|
|
|
|
|
|
|
|
config REMOTEPROC_CDEV
|
|
|
|
bool "Remoteproc character device interface"
|
|
|
|
help
|
|
|
|
Say y here to have a character device interface for the remoteproc
|
|
|
|
framework. Userspace can boot/shutdown remote processors through
|
|
|
|
this interface.
|
|
|
|
|
|
|
|
It's safe to say N if you don't want to use this interface.
|
|
|
|
|
|
|
|
config IMX_REMOTEPROC
|
|
|
|
tristate "IMX6/7 remoteproc support"
|
|
|
|
depends on ARCH_MXC
|
|
|
|
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.
|
|
|
|
|
|
|
|
config INGENIC_VPU_RPROC
|
|
|
|
tristate "Ingenic JZ47xx VPU remoteproc support"
|
|
|
|
depends on MIPS || COMPILE_TEST
|
|
|
|
help
|
|
|
|
Say y or m here to support the VPU in the JZ47xx SoCs from Ingenic.
|
|
|
|
|
|
|
|
This can be either built-in or a loadable module.
|
|
|
|
If unsure say N.
|
|
|
|
|
|
|
|
config MTK_SCP
|
|
|
|
tristate "Mediatek SCP support"
|
|
|
|
depends on ARCH_MEDIATEK || COMPILE_TEST
|
|
|
|
select RPMSG_MTK_SCP
|
|
|
|
help
|
|
|
|
Say y here to support Mediatek's System Companion Processor (SCP) via
|
|
|
|
the remote processor framework.
|
|
|
|
|
|
|
|
It's safe to say N here.
|
|
|
|
|
|
|
|
config OMAP_REMOTEPROC
|
|
|
|
tristate "OMAP remoteproc support"
|
|
|
|
depends on ARCH_OMAP4 || SOC_OMAP5 || SOC_DRA7XX
|
|
|
|
depends on OMAP_IOMMU
|
|
|
|
select MAILBOX
|
|
|
|
select OMAP2PLUS_MBOX
|
|
|
|
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.
|
|
|
|
|
|
|
|
Usually you want to say Y here, in order to enable multimedia
|
|
|
|
use-cases to run on your platform (multimedia codecs are
|
|
|
|
offloaded to remote DSP processors using this framework).
|
|
|
|
|
|
|
|
It's safe to say N here if you're not interested in multimedia
|
|
|
|
offloading or just want a bare minimum kernel.
|
|
|
|
|
|
|
|
config OMAP_REMOTEPROC_WATCHDOG
|
|
|
|
bool "OMAP remoteproc watchdog timer"
|
|
|
|
depends on OMAP_REMOTEPROC
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
Say Y here to enable watchdog timer for remote processors.
|
|
|
|
|
|
|
|
This option controls the watchdog functionality for the remote
|
|
|
|
processors in OMAP. Dedicated OMAP DMTimers are used by the remote
|
|
|
|
processors and triggers the timer interrupt upon a watchdog
|
|
|
|
detection.
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
config DA8XX_REMOTEPROC
|
|
|
|
tristate "DA8xx/OMAP-L13x remoteproc support"
|
|
|
|
depends on ARCH_DAVINCI_DA8XX
|
|
|
|
depends on DMA_CMA
|
|
|
|
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.
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
config QCOM_PIL_INFO
|
|
|
|
tristate
|
|
|
|
|
|
|
|
config QCOM_RPROC_COMMON
|
|
|
|
tristate
|
|
|
|
|
|
|
|
config QCOM_Q6V5_COMMON
|
|
|
|
tristate
|
|
|
|
depends on ARCH_QCOM
|
|
|
|
depends on QCOM_SMEM
|
|
|
|
|
|
|
|
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_PIL_INFO
|
|
|
|
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.
|
|
|
|
|
|
|
|
config QCOM_Q6V5_MSS
|
|
|
|
tristate "Qualcomm Hexagon V5 self-authenticating modem subsystem support"
|
|
|
|
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_PIL_INFO
|
|
|
|
select QCOM_Q6V5_COMMON
|
|
|
|
select QCOM_RPROC_COMMON
|
|
|
|
select QCOM_SCM
|
|
|
|
help
|
|
|
|
Say y here to support the Qualcomm self-authenticating modem
|
|
|
|
subsystem based on Hexagon V5.
|
|
|
|
|
|
|
|
config QCOM_Q6V5_PAS
|
|
|
|
tristate "Qualcomm Hexagon v5 Peripheral Authentication Service support"
|
|
|
|
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_PIL_INFO
|
|
|
|
select QCOM_MDT_LOADER
|
|
|
|
select QCOM_Q6V5_COMMON
|
|
|
|
select QCOM_RPROC_COMMON
|
|
|
|
select QCOM_SCM
|
|
|
|
help
|
|
|
|
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.
|
|
|
|
|
|
|
|
config QCOM_Q6V5_WCSS
|
|
|
|
tristate "Qualcomm Hexagon based WCSS 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_PIL_INFO
|
|
|
|
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.
|
|
|
|
|
|
|
|
config QCOM_SYSMON
|
|
|
|
tristate "Qualcomm sysmon driver"
|
|
|
|
depends on RPMSG
|
|
|
|
depends on ARCH_QCOM
|
|
|
|
depends on NET
|
|
|
|
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.
|
|
|
|
|
|
|
|
config QCOM_WCNSS_PIL
|
|
|
|
tristate "Qualcomm WCNSS Peripheral Image Loader"
|
|
|
|
depends on OF && ARCH_QCOM
|
|
|
|
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_SMEM
|
|
|
|
depends on QCOM_SYSMON || QCOM_SYSMON=n
|
|
|
|
select QCOM_MDT_LOADER
|
|
|
|
select QCOM_PIL_INFO
|
|
|
|
select QCOM_RPROC_COMMON
|
|
|
|
select QCOM_SCM
|
|
|
|
help
|
|
|
|
Say y here to support the Peripheral Image Loader for the Qualcomm
|
|
|
|
Wireless Connectivity Subsystem.
|
|
|
|
|
|
|
|
config ST_REMOTEPROC
|
|
|
|
tristate "ST remoteproc support"
|
|
|
|
depends on ARCH_STI
|
|
|
|
select MAILBOX
|
|
|
|
select STI_MBOX
|
|
|
|
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.
|
|
|
|
|
|
|
|
config ST_SLIM_REMOTEPROC
|
|
|
|
tristate
|
|
|
|
|
|
|
|
config STM32_RPROC
|
|
|
|
tristate "STM32 remoteproc support"
|
remoteproc: stm32: use correct format strings on 64-bit
[ Upstream commit 03bd158e1535e68bcd2b1e095b0ebcad7c84bd20 ]
With CONFIG_ARCH_STM32 making it into arch/arm64, a couple of format
strings no longer work, since they rely on size_t being compatible
with %x, or they print an 'int' using %z:
drivers/remoteproc/stm32_rproc.c: In function 'stm32_rproc_mem_alloc':
drivers/remoteproc/stm32_rproc.c:122:22: error: format '%x' expects argument of type 'unsigned int', but argument 5 has type 'size_t' {aka 'long unsigned int'} [-Werror=format=]
drivers/remoteproc/stm32_rproc.c:122:40: note: format string is defined here
122 | dev_dbg(dev, "map memory: %pa+%x\n", &mem->dma, mem->len);
| ~^
| |
| unsigned int
| %lx
drivers/remoteproc/stm32_rproc.c:125:30: error: format '%x' expects argument of type 'unsigned int', but argument 4 has type 'size_t' {aka 'long unsigned int'} [-Werror=format=]
drivers/remoteproc/stm32_rproc.c:125:65: note: format string is defined here
125 | dev_err(dev, "Unable to map memory region: %pa+%x\n",
| ~^
| |
| unsigned int
| %lx
drivers/remoteproc/stm32_rproc.c: In function 'stm32_rproc_get_loaded_rsc_table':
drivers/remoteproc/stm32_rproc.c:646:30: error: format '%zx' expects argument of type 'size_t', but argument 4 has type 'int' [-Werror=format=]
drivers/remoteproc/stm32_rproc.c:646:66: note: format string is defined here
646 | dev_err(dev, "Unable to map memory region: %pa+%zx\n",
| ~~^
| |
| long unsigned int
| %x
Fix up all three instances to work across architectures, and enable
compile testing for this driver to ensure it builds everywhere.
Reviewed-by: Arnaud Pouliquen <arnaud.pouliquen@foss.st.com>
Acked-by: Randy Dunlap <rdunlap@infradead.org>
Tested-by: Randy Dunlap <rdunlap@infradead.org>
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Stable-dep-of: 32381bbccba4 ("remoteproc: stm32: Fix incorrect type in assignment for va")
Signed-off-by: Sasha Levin <sashal@kernel.org>
2023-06-09 12:45:42 +02:00
|
|
|
depends on ARCH_STM32 || COMPILE_TEST
|
2024-06-15 21:02:09 +02:00
|
|
|
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.
|
|
|
|
|
|
|
|
config TI_K3_DSP_REMOTEPROC
|
|
|
|
tristate "TI K3 DSP remoteproc support"
|
|
|
|
depends on ARCH_K3
|
|
|
|
select MAILBOX
|
|
|
|
select OMAP2PLUS_MBOX
|
|
|
|
help
|
|
|
|
Say m here to support TI's C66x and C71x DSP remote processor
|
|
|
|
subsystems on various TI K3 family of SoCs through the remote
|
|
|
|
processor framework.
|
|
|
|
|
|
|
|
It's safe to say N here if you're not interested in utilizing
|
|
|
|
the DSP slave processors.
|
|
|
|
|
|
|
|
config TI_K3_R5_REMOTEPROC
|
|
|
|
tristate "TI K3 R5 remoteproc support"
|
|
|
|
depends on ARCH_K3
|
|
|
|
select MAILBOX
|
|
|
|
select OMAP2PLUS_MBOX
|
|
|
|
help
|
|
|
|
Say m here to support TI's R5F remote processor subsystems
|
|
|
|
on various TI K3 family of SoCs through the remote processor
|
|
|
|
framework.
|
|
|
|
|
|
|
|
It's safe to say N here if you're not interested in utilizing
|
|
|
|
a slave processor.
|
|
|
|
|
|
|
|
endif # REMOTEPROC
|
|
|
|
|
|
|
|
endmenu
|