1e8419c24SCristian Marussi# SPDX-License-Identifier: GPL-2.0-only 2e8419c24SCristian Marussimenu "ARM System Control and Management Interface Protocol" 3e8419c24SCristian Marussi 4e8419c24SCristian Marussiconfig ARM_SCMI_PROTOCOL 5e8419c24SCristian Marussi tristate "ARM System Control and Management Interface (SCMI) Message Protocol" 6e8419c24SCristian Marussi depends on ARM || ARM64 || COMPILE_TEST 7e8419c24SCristian Marussi help 8e8419c24SCristian Marussi ARM System Control and Management Interface (SCMI) protocol is a 9e8419c24SCristian Marussi set of operating system-independent software interfaces that are 10e8419c24SCristian Marussi used in system management. SCMI is extensible and currently provides 11e8419c24SCristian Marussi interfaces for: Discovery and self-description of the interfaces 12e8419c24SCristian Marussi it supports, Power domain management which is the ability to place 13e8419c24SCristian Marussi a given device or domain into the various power-saving states that 14e8419c24SCristian Marussi it supports, Performance management which is the ability to control 15e8419c24SCristian Marussi the performance of a domain that is composed of compute engines 16e8419c24SCristian Marussi such as application processors and other accelerators, Clock 17e8419c24SCristian Marussi management which is the ability to set and inquire rates on platform 18e8419c24SCristian Marussi managed clocks and Sensor management which is the ability to read 19e8419c24SCristian Marussi sensor data, and be notified of sensor value. 20e8419c24SCristian Marussi 21e8419c24SCristian Marussi This protocol library provides interface for all the client drivers 22e8419c24SCristian Marussi making use of the features offered by the SCMI. 23e8419c24SCristian Marussi 24e8419c24SCristian Marussiif ARM_SCMI_PROTOCOL 25e8419c24SCristian Marussi 26e8419c24SCristian Marussiconfig ARM_SCMI_HAVE_TRANSPORT 27e8419c24SCristian Marussi bool 28e8419c24SCristian Marussi help 29e8419c24SCristian Marussi This declares whether at least one SCMI transport has been configured. 30e8419c24SCristian Marussi Used to trigger a build bug when trying to build SCMI without any 31e8419c24SCristian Marussi configured transport. 32e8419c24SCristian Marussi 33a7b1138bSIgor Skalkinconfig ARM_SCMI_HAVE_SHMEM 34a7b1138bSIgor Skalkin bool 35a7b1138bSIgor Skalkin help 36a7b1138bSIgor Skalkin This declares whether a shared memory based transport for SCMI is 37a7b1138bSIgor Skalkin available. 38a7b1138bSIgor Skalkin 39f301bba0SPeter Hilberconfig ARM_SCMI_HAVE_MSG 40f301bba0SPeter Hilber bool 41f301bba0SPeter Hilber help 42f301bba0SPeter Hilber This declares whether a message passing based transport for SCMI is 43f301bba0SPeter Hilber available. 44f301bba0SPeter Hilber 45e8419c24SCristian Marussiconfig ARM_SCMI_TRANSPORT_MAILBOX 46e8419c24SCristian Marussi bool "SCMI transport based on Mailbox" 47e8419c24SCristian Marussi depends on MAILBOX 48e8419c24SCristian Marussi select ARM_SCMI_HAVE_TRANSPORT 49a7b1138bSIgor Skalkin select ARM_SCMI_HAVE_SHMEM 50e8419c24SCristian Marussi default y 51e8419c24SCristian Marussi help 52e8419c24SCristian Marussi Enable mailbox based transport for SCMI. 53e8419c24SCristian Marussi 54e8419c24SCristian Marussi If you want the ARM SCMI PROTOCOL stack to include support for a 55e8419c24SCristian Marussi transport based on mailboxes, answer Y. 56e8419c24SCristian Marussi 575f90f189SEtienne Carriereconfig ARM_SCMI_TRANSPORT_OPTEE 585f90f189SEtienne Carriere bool "SCMI transport based on OP-TEE service" 595f90f189SEtienne Carriere depends on OPTEE=y || OPTEE=ARM_SCMI_PROTOCOL 605f90f189SEtienne Carriere select ARM_SCMI_HAVE_TRANSPORT 615f90f189SEtienne Carriere select ARM_SCMI_HAVE_SHMEM 625f90f189SEtienne Carriere default y 635f90f189SEtienne Carriere help 645f90f189SEtienne Carriere This enables the OP-TEE service based transport for SCMI. 655f90f189SEtienne Carriere 665f90f189SEtienne Carriere If you want the ARM SCMI PROTOCOL stack to include support for a 675f90f189SEtienne Carriere transport based on OP-TEE SCMI service, answer Y. 685f90f189SEtienne Carriere 69e8419c24SCristian Marussiconfig ARM_SCMI_TRANSPORT_SMC 70e8419c24SCristian Marussi bool "SCMI transport based on SMC" 71e8419c24SCristian Marussi depends on HAVE_ARM_SMCCC_DISCOVERY 72e8419c24SCristian Marussi select ARM_SCMI_HAVE_TRANSPORT 73a7b1138bSIgor Skalkin select ARM_SCMI_HAVE_SHMEM 74e8419c24SCristian Marussi default y 75e8419c24SCristian Marussi help 76e8419c24SCristian Marussi Enable SMC based transport for SCMI. 77e8419c24SCristian Marussi 78e8419c24SCristian Marussi If you want the ARM SCMI PROTOCOL stack to include support for a 79e8419c24SCristian Marussi transport based on SMC, answer Y. 80e8419c24SCristian Marussi 8146abe13bSIgor Skalkinconfig ARM_SCMI_TRANSPORT_VIRTIO 8246abe13bSIgor Skalkin bool "SCMI transport based on VirtIO" 83c90521a0SCristian Marussi depends on VIRTIO=y || VIRTIO=ARM_SCMI_PROTOCOL 8446abe13bSIgor Skalkin select ARM_SCMI_HAVE_TRANSPORT 8546abe13bSIgor Skalkin select ARM_SCMI_HAVE_MSG 8646abe13bSIgor Skalkin help 8746abe13bSIgor Skalkin This enables the virtio based transport for SCMI. 8846abe13bSIgor Skalkin 8946abe13bSIgor Skalkin If you want the ARM SCMI PROTOCOL stack to include support for a 9046abe13bSIgor Skalkin transport based on VirtIO, answer Y. 9146abe13bSIgor Skalkin 92*530897ecSCristian Marussiconfig ARM_SCMI_TRANSPORT_VIRTIO_VERSION1_COMPLIANCE 93*530897ecSCristian Marussi bool "SCMI VirtIO transport Version 1 compliance" 94*530897ecSCristian Marussi depends on ARM_SCMI_TRANSPORT_VIRTIO 95*530897ecSCristian Marussi default y 96*530897ecSCristian Marussi help 97*530897ecSCristian Marussi This enforces strict compliance with VirtIO Version 1 specification. 98*530897ecSCristian Marussi 99*530897ecSCristian Marussi If you want the ARM SCMI VirtIO transport layer to refuse to work 100*530897ecSCristian Marussi with Legacy VirtIO backends and instead support only VirtIO Version 1 101*530897ecSCristian Marussi devices (or above), answer Y. 102*530897ecSCristian Marussi 103*530897ecSCristian Marussi If you want instead to support also old Legacy VirtIO backends (like 104*530897ecSCristian Marussi the ones implemented by kvmtool) and let the core Kernel VirtIO layer 105*530897ecSCristian Marussi take care of the needed conversions, say N. 106*530897ecSCristian Marussi 107e8419c24SCristian Marussiendif #ARM_SCMI_PROTOCOL 108e8419c24SCristian Marussi 109e8419c24SCristian Marussiconfig ARM_SCMI_POWER_DOMAIN 110e8419c24SCristian Marussi tristate "SCMI power domain driver" 111e8419c24SCristian Marussi depends on ARM_SCMI_PROTOCOL || (COMPILE_TEST && OF) 112e8419c24SCristian Marussi default y 113e8419c24SCristian Marussi select PM_GENERIC_DOMAINS if PM 114e8419c24SCristian Marussi help 115e8419c24SCristian Marussi This enables support for the SCMI power domains which can be 116e8419c24SCristian Marussi enabled or disabled via the SCP firmware 117e8419c24SCristian Marussi 118e8419c24SCristian Marussi This driver can also be built as a module. If so, the module 119e8419c24SCristian Marussi will be called scmi_pm_domain. Note this may needed early in boot 120e8419c24SCristian Marussi before rootfs may be available. 121e8419c24SCristian Marussi 122e8419c24SCristian Marussiendmenu 123