You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
kernel_samsung_sm7125/drivers/soc/qcom/Kconfig

1106 lines
38 KiB

#
# QCOM Soc drivers
#
menu "Qualcomm SoC drivers"
config QCOM_MEM_OFFLINE
bool "Dynamic Memory Region Offline driver"
depends on MEMORY_HOTPLUG
help
Add support for DDR Self-Refresh power management through the dynamic
memory offline framework. This driver interfaces between the memory
hotplug subsystem and AOP which hot adds or removes memory blocks and
controls the start/stop of self-refresh of these DDR regions. This
helps reduce power consumption during idle mode of the system.
If unsure, say N
config OVERRIDE_MEMORY_LIMIT
bool "Override memory limit set by the kernel boot parameter"
depends on QCOM_MEM_OFFLINE
help
Override any memory limit set by the kernel boot parameter with
limit set by mem-offline dt entry so that memory offline framework
can initialize remaining memory with movable pages for memory
hot-plugging.
If unsure, say N
config QCOM_CPUSS_DUMP
bool "CPU Subsystem Dumping support"
help
Add support to dump various hardware entities such as the instruction
and data tlb's as well as the unified tlb, which are a part of the
cpu subsystem to an allocated buffer. This allows for analysis of the
the entities if corruption is suspected.
If unsure, say N
config QCOM_GLINK_SSR
tristate "Qualcomm Glink SSR driver"
depends on RPMSG
depends on QCOM_RPROC_COMMON
help
Say y here to enable GLINK SSR support. The GLINK SSR driver
implements the SSR protocol for notifying the remote processor about
neighboring subsystems going up or down.
config QCOM_RUN_QUEUE_STATS
bool "Enable collection and exporting of QTI Run Queue stats to userspace"
help
This option enables the driver to periodically collecting the statistics
of kernel run queue information and calculate the load of the system.
This information is exported to usespace via sysfs entries and userspace
algorithms uses info and decide when to turn on/off the cpu cores.
config QCOM_GSBI
tristate "QCOM General Serial Bus Interface"
depends on ARCH_QCOM
select MFD_SYSCON
help
Say y here to enable GSBI support. The GSBI provides control
functions for connecting the underlying serial UART, SPI, and I2C
devices to the output pins.
config QCOM_MDT_LOADER
tristate
select QCOM_SCM
config QCOM_LLCC
tristate "Qualcomm Technologies, Inc. LLCC driver"
depends on ARCH_QCOM
help
Qualcomm Technologies, Inc. platform specific LLCC driver for Last
Level Cache. This provides interfaces to client's that use the LLCC.
Say yes here to enable LLCC slice driver.
config QCOM_SM8150_LLCC
tristate "Qualcomm Technologies, Inc. SM8150 LLCC driver"
depends on QCOM_LLCC
help
Say yes here to enable the LLCC driver for SM8150. This is provides
data required to configure LLCC so that clients can start using the
LLCC slices.
config QCOM_SDMSHRIKE_LLCC
tristate "Qualcomm Technologies, Inc. SDMSHRIKE LLCC driver"
depends on QCOM_LLCC
help
This configuration option enables LLCC driver specific to SDMSHRIKE.
Say 'Y' here to enable the LLCC driver for SDMSHRIKE which provides
data required to configure LLCC so that clients can start using the
LLCC slices.
config QCOM_SM6150_LLCC
tristate "Qualcomm Technologies, Inc. SM6150 LLCC driver"
depends on QCOM_LLCC
help
Say yes here to enable the LLCC driver for SM6150. This is provides
data required to configure LLCC so that clients can start using the
LLCC slices.
config QCOM_SDMMAGPIE_LLCC
tristate "Qualcomm Technologies, Inc. SDMMAGPIE LLCC driver"
depends on QCOM_LLCC
help
Say yes here to enable the LLCC driver for SDMMAGPIE. This is provides
data required to configure LLCC so that clients can start using the
LLCC slices.
config QCOM_ATOLL_LLCC
tristate "Qualcomm Technologies, Inc. ATOLL LLCC driver"
depends on QCOM_LLCC
help
Say yes here to enable the LLCC driver for ATOLL. This provides
data required to configure LLCC so that clients can start using the
LLCC slices.
config QCOM_SDXPRAIRIE_LLCC
tristate "Qualcomm Technologies, Inc. SDXPRAIRIE LLCC driver"
depends on QCOM_LLCC
help
This configuration option enables LLCC driver specific to SDXPRAIRIE.
Say 'Y' here to enable the LLCC driver for SDXPRAIRIE which provides
data required to configure LLCC so that clients can start using the
LLCC slices.
config QCOM_LLCC_AMON
tristate "Qualcomm Technologies, Inc. LLCC Activity Monitor(AMON) driver"
depends on QCOM_LLCC
help
This option enables a activity monitor driver for last level cache
controller. This driver configures the activity monitor as
deadlock detector and dumps the AMON registers upon detection of
deadlock.
config QCOM_LLCC_AMON_PANIC
tristate "Panic on detecting LLCC Activity Monitor(AMON) error"
depends on QCOM_LLCC_AMON
help
This option enables panic upon detection of LLCC Activity Monitor(AMON)
errors. Say yes here to enable deadlock detection mode of AMON. In
deadlock detection mode AMON will trigger an interrupt if some LLCC request
ages out.
config QCOM_LLCC_PERFMON
tristate "Qualcomm Technologies, Inc. LLCC Perfmon driver"
depends on QCOM_LLCC
help
This option enables driver for LLCC Performance monitor block. Using
this various events in different LLCC sub block ports can be monitored.
This is used for performance and debug activity and exports SYSFS
interface. SYSFS interface used for configure and dump the LLCC
performance events.
config QCOM_PM
bool "Qualcomm Power Management"
depends on ARCH_QCOM && !ARM64
select ARM_CPU_SUSPEND
select QCOM_SCM
help
QCOM Platform specific power driver to manage cores and L2 low power
modes. It interface with various system drivers to put the cores in
low power modes.
config QCOM_QMI_HELPERS
bool "Qualcomm QMI Helpers"
depends on QRTR || QTI_QRTR
help
Helper library for handling QMI encoded messages. QMI encoded
messages are used in communication between the majority of QRTR
clients and this helpers provide the common functionality needed for
doing this from a kernel driver.
config QCOM_QMI_RMNET
bool "QTI QMI Rmnet Helpers"
depends on QCOM_QMI_HELPERS
depends on RMNET
help
Helper for handling interfaces between kernel clients and rmnet
driver. It enables the rmnet driver to create/delete DFC/WDA
clients and provides the common functionality for data flow control
and power save features.
config QCOM_QMI_DFC
bool "Enable burst mode flow control"
depends on QCOM_QMI_RMNET
help
Say y here to enable support for burst mode data flow control.
DFC client provides an interface to the modem dfc service and
does burst mode flow control. It enables the flow on receiving flow
status indication and disables flows while grant size is reached.
If unsure or not use burst mode flow control, say 'N'.
config QCOM_QMI_POWER_COLLAPSE
bool "Enable power save features"
depends on QCOM_QMI_RMNET
help
Say y here to enable support for power save features.
It provides an interface to offload uplink flow control based on
detected flow status.
If unsure or not use power save feature, say 'N'.
config QCOM_SMEM
tristate "Qualcomm Shared Memory Manager (SMEM)"
depends on ARCH_QCOM
depends on HWSPINLOCK
help
Say y here to enable support for the Qualcomm Shared Memory Manager.
The driver provides an interface to items in a heap shared among all
processors in a Qualcomm platform.
config MSM_APM
bool "Qualcomm Technologies, Inc. platform specific APM driver"
help
Platform specific driver to manage the power source of
memory arrays. Interfaces with regulator drivers to ensure
SRAM Vmin requirements are met across different performance
levels.
config QCOM_SMD_RPM
tristate "Qualcomm Resource Power Manager (RPM) over SMD"
depends on ARCH_QCOM
depends on RPMSG && OF
help
If you say yes to this option, support will be included for the
Resource Power Manager system found in the Qualcomm 8974 based
devices.
This is required to access many regulators, clocks and bus
frequencies controlled by the RPM on these devices.
Say M here if you want to include support for the Qualcomm RPM as a
module. This will build a module called "qcom-smd-rpm".
config MSM_SPM
bool "Driver support for SPM and AVS wrapper hardware"
help
Enables the support for SPM and AVS wrapper hardware on MSMs. SPM
hardware is used to manage the processor power during sleep. The
driver allows configuring SPM to allow different low power modes for
both core and L2.
config MSM_L2_SPM
bool "SPM support for L2 cache"
help
Enable SPM driver support for L2 cache. Some MSM chipsets allow
control of L2 cache low power mode with a Subsystem Power manager.
Enabling this driver allows configuring L2 SPM for low power modes
on supported chipsets.
config QCOM_SCM
bool "Secure Channel Manager (SCM) support"
default n
help
Say y here to enable Secure Channel Mananger(SCM) support for SoC.
SCM provides communication channel to communicate with secure
world(EL2 and EL3) by using smc call.
SCM driver provides the support for atomic scm calls also.
config QCOM_SCM_QCPE
bool "Para-Virtualized Secure Channel Manager (SCM) support over QCPE"
default n
help
Say y here to enable Secure Channel Mananger(SCM) support for SoC
in virtualized Linux, where SCM backend is QCPE (QCOM Protected
environment). The SCM channel will use QCOM HAB interface for
fronet-end to back-end communication.
config QCOM_MEMORY_DUMP_V2
bool "QCOM Memory Dump V2 Support"
help
This enables memory dump feature. It allows various client
subsystems to register respective dump regions. At the time
of deadlocks or cpu hangs these dump regions are captured to
give a snapshot of the system at the time of the crash.
config MSM_DEBUG_LAR_UNLOCK
bool "MSM Debug LAR Unlock Support"
depends on QCOM_MEMORY_DUMP_V2
help
This allows unlocking Core Debug lock to allow capture
of upper 32 bits of program counter at the time of
system crash. This is useful in getting correct crash
location.
config QCOM_WATCHDOG_V2
bool "Qualcomm Watchdog Support"
depends on ARCH_QCOM
help
This enables the watchdog module. It causes kernel panic if the
watchdog times out. It allows for detection of cpu hangs and
deadlocks. It does not run during the bootup process, so it will
not catch any early lockups.
config QCOM_FORCE_WDOG_BITE_ON_PANIC
bool "QCOM force watchdog bite"
depends on QCOM_WATCHDOG_V2
help
This forces a watchdog bite when the device restarts due to a
kernel panic. On certain MSM SoCs, this provides us
additional debugging information.
config QCOM_WDOG_IPI_ENABLE
bool "Qcom WDT pet optimization"
depends on QCOM_WATCHDOG_V2
default n
help
When this option is enabled, watchdog sends IPI to cores in low power
mode also. For power optimizations, by default watchdog don't ping
cores in low power mode at pettime.
To track CPUs health on LPM, or on debug builds enable it.
config QCOM_SMEM_STATE
bool
config QCOM_SMP2P
tristate "Qualcomm Shared Memory Point to Point support"
depends on MAILBOX
depends on QCOM_SMEM
select QCOM_SMEM_STATE
help
Say yes here to support the Qualcomm Shared Memory Point to Point
protocol.
config QCOM_SMSM
tristate "Qualcomm Shared Memory State Machine"
depends on QCOM_SMEM
select QCOM_SMEM_STATE
help
Say yes here to support the Qualcomm Shared Memory State Machine.
The state machine is represented by bits in shared memory.
config QCOM_WCNSS_CTRL
tristate "Qualcomm WCNSS control driver"
depends on ARCH_QCOM
depends on RPMSG
help
Client driver for the WCNSS_CTRL SMD channel, used to download nv
firmware to a newly booted WCNSS chip.
config QPNP_PBS
tristate "PBS trigger support for QPNP PMIC"
depends on SPMI
help
This driver supports configuring software PBS trigger event through PBS
RAM on Qualcomm Technologies, Inc. QPNP PMICs. This module provides
the APIs to the client drivers that wants to send the PBS trigger
event to the PBS RAM.
config MSM_SERVICE_LOCATOR
bool "Service Locator"
depends on QCOM_QMI_HELPERS
help
The Service Locator provides a library to retrieve location
information given a service identifier. Location here translates
to what process domain exports the service, and which subsystem
that process domain will execute in.
config MSM_SERVICE_NOTIFIER
bool "Service Notifier"
depends on MSM_SERVICE_LOCATOR && MSM_SUBSYSTEM_RESTART
help
The Service Notifier provides a library for a kernel client to
register for state change notifications regarding a remote service.
A remote service here refers to a process providing certain services
like audio, the identifier for which is provided by the service
locator.
config MSM_SUBSYSTEM_RESTART
bool "MSM Subsystem Restart"
help
This option enables the MSM subsystem restart framework.
The MSM subsystem restart framework provides support to boot,
shutdown, and restart subsystems with a reference counted API.
It also notifies userspace of transitions between these states via
sysfs.
config MSM_PIL
bool "Peripheral image loading"
select FW_LOADER
default n
help
Some peripherals need to be loaded into memory before they can be
brought out of reset.
Say yes to support these devices.
config MSM_SYSMON_GLINK_COMM
bool "MSM System Monitor communication support using GLINK transport"
depends on MSM_GLINK && MSM_SUBSYSTEM_RESTART
help
This option adds support for MSM System Monitor APIs using the GLINK
transport layer. The APIs provided may be used for notifying
subsystems within the SoC about other subsystems' power-up/down
state-changes.
config MSM_SYSMON_QMI_COMM
bool "MSM System Monitor communication support using QMI transport"
depends on QCOM_QMI_HELPERS && MSM_SUBSYSTEM_RESTART
help
This option adds support for MSM System Monitor APIs using the
QMI layer. The APIs provided may be used for notifying
subsystems within the SoC about other subsystems' power-up/down
state-changes.
config MSM_PIL_SSR_GENERIC
tristate "MSM Subsystem Boot Support"
depends on MSM_PIL && MSM_SUBSYSTEM_RESTART
help
Support for booting and shutting down MSM Subsystem processors.
This driver also monitors the SMSM status bits and the watchdog
interrupt for the subsystem and restarts it on a watchdog bite
or a fatal error. Subsystems include LPASS, Venus, VPU, WCNSS and
BCSS.
config MSM_PIL_MSS_QDSP6V5
tristate "MSS QDSP6v5 (Hexagon) Boot Support"
depends on MSM_PIL && MSM_SUBSYSTEM_RESTART
help
Support for booting and shutting down QDSP6v5 (Hexagon) processors
in modem subsystems. If you would like to make or receive phone
calls then say Y here.
If unsure, say N.
config SETUP_SSR_NOTIF_TIMEOUTS
bool "Set timeouts on SSR sysmon notifications and notifier callbacks"
help
Setup timers prior to initiating communication between
subsystems through sysmon, and prior to sending notifications
to drivers in the kernel that have registered callbacks with the
subsystem notifier framework for a particular subsystem. This
is a debugging feature.
config SSR_SYSMON_NOTIF_TIMEOUT
depends on SETUP_SSR_NOTIF_TIMEOUTS
int "SSR Sysmon notifications timeout in ms"
default 10000
help
The amount of time, in milliseconds, that should elapse between
the start and end of sysmon SSR notifications, before a warning
is emitted.
config SSR_SUBSYS_NOTIF_TIMEOUT
depends on SETUP_SSR_NOTIF_TIMEOUTS
int "SSR Subsystem notifier timeout in ms"
default 10000
help
The amount of time, in milliseconds, that should elapse between
the start and end of SSR notifications through the subsystem
notifier, before a warning is emitted.
config PANIC_ON_SSR_NOTIF_TIMEOUT
bool "Trigger kernel panic when notification timeout expires"
depends on SETUP_SSR_NOTIF_TIMEOUTS
help
Trigger a kernel panic when communication between subsystems
through sysmon is taking too long. Also trigger a kernel panic
if invoking the callbacks registered with a particular subsystem's
notifications by the subsystem notifier framework is taking too long.
This is a debugging feature.
config MSM_BOOT_STATS
bool "Use MSM boot stats reporting"
help
Use this to report msm boot stats such as bootloader throughput,
display init, total boot time.
This figures are reported in mpm sleep clock cycles and have a
resolution of 31 bits as 1 bit is used as an overflow check.
config MSM_BOOT_TIME_MARKER
bool "Use MSM boot time marker reporting"
depends on MSM_BOOT_STATS
help
Use this to mark msm boot kpi for measurement.
An instrumentation for boot time measurement.
To create an entry, call "place_marker" function.
At userspace, write marker name to "/sys/kernel/debug/bootkpi/kpi_values"
If unsure, say N
config MSM_CORE_HANG_DETECT
tristate "MSM Core Hang Detection Support"
help
This enables the core hang detection module. It causes SoC
reset on core hang detection and collects the core context
for hang. By using sysfs entries core hang detection can be
enabled or disabled dynamically.
config QCOM_DCC
bool "QCOM Data Capture and Compare enigne support"
help
This option enables driver for Data Capture and Compare engine. DCC
driver provides interface to configure DCC block and read back
captured data from DCC's internal SRAM.
config QCOM_DCC_V2
bool "Qualcomm Technologies Data Capture and Compare enigne support for V2"
help
This option enables driver for Data Capture and Compare engine. DCC
driver provides interface to configure DCC block and read back
captured data from DCC's internal SRAM.
config MSM_GLADIATOR_HANG_DETECT
tristate "MSM Gladiator Hang Detection Support"
help
This enables the gladiator hang detection module.
If the configured threshold is reached, it causes SoC reset on
gladiator hang detection and collects the context for the
gladiator hang.
config MSM_GLADIATOR_ERP
tristate "GLADIATOR coherency interconnect error reporting driver"
help
Support dumping debug information for the GLADIATOR
cache interconnect in the error interrupt handler.
Meant to be used for debug scenarios only.
If unsure, say N.
config SDX_EXT_IPC
tristate "QCOM external ipc driver"
help
This enables the module to help modem communicate with external
Application processor connected to Qualcomm Technologies, Inc
modem chipset. The modem and APQ can understand each other's
state by reading ipc gpios.
If unsure, say N.
config QTI_NOTIFY_SIDEBAND
tristate "QCOM sideband signalling helper"
help
This provides helper APIs and a header file through which
transport layer driver can talk to the sideband driver to
assert appropriate sideband signal.
If unsure, say N.
config PANIC_ON_GLADIATOR_ERROR
depends on MSM_GLADIATOR_ERP
bool "Panic on GLADIATOR error report"
help
Panic upon detection of an Gladiator coherency interconnect error
in order to support dumping debug information.
Meant to be used for debug scenarios only.
If unsure, say N.
config QCOM_SECURE_BUFFER
bool "Helper functions for securing buffers through TZ"
help
Say 'Y' here for targets that need to call into TZ to secure
memory buffers. This ensures that only the correct clients can
use this memory and no unauthorized access is made to the
buffer
config MSM_REMOTEQDSS
bool "Allow debug tools to enable events on other processors"
depends on QCOM_SCM && DEBUG_FS
help
Other onchip processors/execution environments may support debug
events. Provide a sysfs interface for debug tools to dynamically
enable/disable these events. Interface located in
/sys/class/remoteqdss.
config ICNSS
tristate "Platform driver for Q6 integrated connectivity"
select CNSS_UTILS
---help---
This module adds support for Q6 integrated WLAN connectivity
subsystem. This module is responsible for communicating WLAN on/off
control messages to FW over QMI channel. It is also responsible for
handling WLAN PD restart notifications.
config ICNSS_DEBUG
bool "ICNSS debug support"
depends on ICNSS
---help---
Say 'Y' here to enable ICNSS driver debug support. Debug support
primarily consists of logs consisting of information related to
hardware register access and enabling BUG_ON for certain cases to aid
the debugging.
config ICNSS_QMI
bool "ICNSS QMI support"
depends on ICNSS
---help---
Say 'Y' here to enable ICNSS QMI support. ICNSS driver will use
QMI framework to communicate with WLAN FW. It will send coldboot
handshake messages to WLAN FW, which includes hardware capabilities
and configurations. It also send WLAN on/off control message to FW
over QMI channel.
config CNSS_TIMESYNC
bool "cnss TIME SYNC support"
depends on ICNSS
---help---
Say 'Y' here to enable cnss TIME SYNC support. TIME SYNC support
primarily consists of reading the AUDIO TIMESYNC register for
deriving WLAN mac time stamp relation when FTM based clock sync is
used.
config QCOM_EUD
tristate "QTI Embedded USB Debugger (EUD)"
depends on ARCH_QCOM
select SERIAL_CORE
help
The EUD (Embedded USB Debugger) is a mini-USB hub implemented
on chip to support the USB-based debug and trace capabilities.
This module enables support for Qualcomm Technologies, Inc.
Embedded USB Debugger (EUD).
If unsure, say N.
config QCOM_MINIDUMP
bool "QCOM Minidump Support"
depends on QCOM_SMEM && QCOM_DLOAD_MODE
help
This enables minidump feature. It allows various clients to
register to dump their state at system bad state (panic/WDT,etc.,).
Minidump would dump all registered entries, only when DLOAD mode
is enabled.
config MINIDUMP_MAX_ENTRIES
int "Minidump Maximum num of entries"
default 200
depends on QCOM_MINIDUMP
help
This defines maximum number of entries to be allocated for application
subsytem in Minidump table.
config QCOM_BUS_SCALING
bool "Bus scaling driver"
help
This option enables bus scaling on MSM devices. Bus scaling
allows devices to request the clocks be set to rates sufficient
for the active devices needs without keeping the clocks at max
frequency when a slower speed is sufficient.
config QCOM_BUS_CONFIG_RPMH
bool "RPMH Bus scaling driver"
depends on QCOM_BUS_SCALING
help
This option enables bus scaling using QCOM specific hardware
accelerators. It enables the translation of bandwidth requests
from logical nodes to hardware nodes controlled by the BCM (Bus
Clock Manager)
config QCOM_COMMAND_DB
bool "Command DB"
help
Command DB queries shared memory by key string for shared system
resources
config QCOM_EARLY_RANDOM
bool "Initialize random pool very early"
help
The standard random pool may not initialize until late in the boot
process which means that any calls to get random numbers before then
may not be truly random. Select this option to make an early call
to get some random data to put in the pool. If unsure, say N.
config MSM_SPSS_UTILS
depends on MSM_PIL
bool "Secure Processor Utilities"
help
spss-utils driver selects Secure Processor firmware file name.
The firmware file name for dev, test or production is selected
based on two fuses.
Different file name is used for differnt SPSS HW versions,
because the SPSS firmware size is too small to support multiple
HW versions.
config MSM_SPCOM
depends on QCOM_GLINK
bool "Secure Processor Communication over GLINK"
help
spcom driver allows loading Secure Processor Applications and
sending messages to Secure Processor Applications.
spcom provides interface to both user space app and kernel driver.
It is using glink as the transport layer, which provides multiple
logical channels over single physical channel.
The physical layer is based on shared memory and interrupts.
spcom provides clients/server API, although currently only one client
or server is allowed per logical channel.
config MSM_TZ_SMMU
depends on ARCH_MSM8953 || ARCH_QCS405 || ARCH_QCS403 || ARCH_SDM429W
bool "Helper functions for SMMU configuration through TZ"
help
Say 'Y' here for targets that need to call into TZ to configure
SMMUs for any reason (for example, for errata workarounds or
configuration of SMMU virtualization).
If unsure, say N.
config QTI_RPMH_API
bool "QTI RPMH (h/w accelerators) Communication API"
select MAILBOX
select QTI_RPMH_MBOX
select QTI_SYSTEM_PM
help
This option enables RPMH hardware communication for making shared
resource requests on Qualcomm Technologies Inc SoCs.
config QTI_SYSTEM_PM
bool
config QSEE_IPC_IRQ
bool "QSEE interrupt manager"
help
The QSEE IPC IRQ controller manages the interrupts from the QTI
secure execution environment. This interrupt controller will use
the registers in the spcs region to mask and clear interrupts.
Clients can use this driver to avoid adding common interrupt handling
code.
config QSEE_IPC_IRQ_BRIDGE
tristate "QSEE IPC Interrupt Bridge"
select QSEE_IPC_IRQ
help
This module enables bridging an Inter-Processor Communication(IPC)
interrupt from a remote subsystem directed towards Qualcomm
Technologies, Inc. Secure Execution Environment(QSEE) to userspace.
The interrupt will be propagated through a character device that
userspace clients can poll on.
config QCOM_GLINK
tristate "GLINK Probe Helper"
depends on RPMSG_QCOM_GLINK_SMEM
help
The GLINK RPMSG Plugin is currently designed to plugin with the
remote proc framework as a subdev. This module is responsible for
creating the glink transports when remote proc is disabled.
config QCOM_GLINK_PKT
tristate "Enable device interface for GLINK packet channels"
depends on QCOM_GLINK || RPMSG_QCOM_GLINK_BGCOM
help
G-link packet driver provides the interface for the userspace
clients to communicate over G-Link via device nodes.
This enable the userspace clients to read and write to
some glink packets channel.
config MSM_JTAGV8
bool "Debug and ETM trace support across power collapse for ARMv8"
default y if CORESIGHT_SOURCE_ETM4X
help
Enables support for debugging (specifically breakpoints) and ETM
processor tracing across power collapse both for JTag and OS hosted
software running on ARMv8 target. Enabling this will ensure debug
and ETM registers are saved and restored across power collapse.
If unsure, say 'N' here to avoid potential power, performance and
memory penalty.
config QCOM_QDSS_BRIDGE
bool "Configure bridge driver for QTI/Qualcomm Technologies, Inc. MDM"
depends on MHI_BUS
help
The driver will help route diag traffic from modem side over the QDSS
sub-system to USB on APSS side. The driver acts as a bridge between the
MHI and USB interface. If unsure, say N.
config QTI_RPM_STATS_LOG
bool "Qualcomm Technologies RPM Stats Driver"
depends on QTI_RPMH_API
default n
help
This option enables a driver which reads RPM messages from a shared
memory location. These messages provide statistical information about
the low power modes that RPM enters. The drivers outputs the message
via a debugfs node.
config MSM_CDSP_LOADER
tristate "CDSP loader support"
help
Enable CDSP image loader.
The CDSP loader brings CDSP out of reset
for platforms that have compute DSP.
Say M if you want to enable this module.
config QCOM_SMCINVOKE
bool "Secure QSEE Support"
help
Enable SMCInvoke driver which supports capability based secure
communication between QTI Secure Execution Environment (QSEE)
and high level operating system. It exposes APIs for both
userspace and kernel clients.
config MSM_EVENT_TIMER
bool "Event timer"
help
This option enables a modules that manages a list of event timers
that need to be monitored by the PM. The enables the PM code to
monitor events that require the core to be awake and ready to
handle the event.
config MSM_AVTIMER
tristate "Avtimer Driver"
default n
help
This driver gets the Q6 out of power collapsed state
and exposes ioctl control to read avtimer tick.
Enables camera to use for VT call to get avtimer
timestamp.
config MSM_PM
depends on PM
select MSM_IDLE_STATS if DEBUG_FS
select CPU_IDLE_MULTIPLE_DRIVERS
bool "Qualcomm Techonolgies Inc (QTI) platform specific PM driver"
help
Platform specific power driver to manage cores and l2 low power
modes. It interface with various system driver and put the cores
into low power modes. It implements OS initiated scheme and
determines last CPU to call into PSCI for cluster Low power
modes.
config MSM_PM_LEGACY
depends on PM
select MSM_IDLE_STATS if DEBUG_FS
select CPU_IDLE_MULTIPLE_DRIVERS
bool "Qualcomm Technologies, Inc. (QTI) platform specific Legacy PM driver"
help
Platform specific legacy power driver to manage
cores and l2 low power modes. It interface with
various system driver and put the cores into
low power modes.
config MSM_NOPM
default y if !PM
bool
help
This enables bare minimum support of power management at platform level.
i.e WFI
config MSM_QBT1000
bool "QBT1000 Ultrasonic Fingerprint Sensor"
help
This driver provides services for configuring the fingerprint
sensor hardware and for communicating with the trusted app which
uses it. It enables clocks and provides commands for loading
trusted apps, unloading them and marshalling buffers to the
trusted fingerprint app.
config APSS_CORE_EA
depends on CPU_FREQ && PM_OPP
bool "Qualcomm Technology Inc specific power aware driver"
help
Platform specific power aware driver to provide power
and temperature information to the scheduler.
config QCOM_FSA4480_I2C
bool "Fairchild FSA4480 chip with I2C"
select REGMAP_I2C
depends on I2C
help
Support for the Fairchild FSA4480 IC switch chip controlled
using I2C. This driver provides common support
for accessing the device, switching between USB and Audio
modes, changing orientation.
if (MSM_PM || MSM_PM_LEGACY)
menuconfig MSM_IDLE_STATS
bool "Collect idle statistics"
help
Collect cores various low power mode idle statistics
and export them in proc/msm_pm_stats. User can read
this data and determine what low power modes and how
many times cores have entered into LPM modes.
if MSM_IDLE_STATS
config MSM_IDLE_STATS_FIRST_BUCKET
int "First bucket time"
default 62500
help
Upper time limit in nanoseconds of first bucket.
config MSM_IDLE_STATS_BUCKET_SHIFT
int "Bucket shift"
default 2
config MSM_IDLE_STATS_BUCKET_COUNT
int "Bucket count"
default 10
config MSM_SUSPEND_STATS_FIRST_BUCKET
int "First bucket time for suspend"
default 1000000000
help
Upper time limit in nanoseconds of first bucket of the
histogram. This is for collecting statistics on suspend.
endif # MSM_IDLE_STATS
endif # MSM_PM || MSM_PM_LEGACY
source "drivers/soc/qcom/memshare/Kconfig"
source "drivers/soc/qcom/hab/Kconfig"
source "drivers/soc/qcom/rmnet_ctl/Kconfig"
source "drivers/soc/qcom/hgsl/Kconfig"
config MSM_PERFORMANCE
tristate "msm performance driver to support userspace fmin/fmax request"
default n
help
This driver can restrict max freq or min freq of cpu cluster
when requested by the userspace by changing the cpufreq policy
fmin and fmax.
config MSM_DRM_NOTIFY
bool
depends on !DRM_MSM
help
This driver can register and receive notification for MSM_DRM
power event in external module. When display power state is
updated, any modules registered to the block chain will get
notified.
config MSM_DRM_TECHPACK
bool "Enable MSM DRM from techpack"
depends on DRM
depends on ARCH_QCOM || (ARM && COMPILE_TEST)
depends on OF
depends on MMU
depends on !DRM_MSM
select QCOM_MDT_LOADER if ARCH_QCOM
select REGULATOR
select DRM_KMS_HELPER
select DRM_PANEL
select SHMEM
select TMPFS
select QCOM_SCM
select SND_SOC_HDMI_CODEC if SND_SOC
select SYNC_FILE
select MSM_EXT_DISPLAY
select PM_GENERIC_DOMAINS
select V4L2_MEM2MEM_DEV
select DRM_MIPI_DSI
select MSM_DRM_NOTIFY
help
The DRM MSM TECHPACK will select modules that are required by
DRM MSM module. This option is only used when DRM MSM is loaded
from external techpack, and is mutually exclusive with builtin
DRM MSM module.
config QMP_DEBUGFS_CLIENT
bool "Debugfs Client to communicate with AOP using QMP protocol"
depends on DEBUG_FS
default n
help
This options enables a driver which allows clients to send messages
to Alway On processor using QMP transport.
config QCOM_QHEE_ENABLE_MEM_PROTECTION
bool "QHEE enable kernel memory protection"
depends on QCOM_SCM
default y
help
When this option is enabled, an SCM call will be invoked to enable
kernel memory protection in stage 2 memory mappings on kernel boot.
This is part of a security feature enabled in QHEE.
config QCOM_SMP2P_SLEEPSTATE
bool "SMP2P Sleepstate notifier"
depends on QCOM_SMP2P
help
When this option is enabled, notifications are sent to remote procs
for the power state changes on the local processor. The notifications
are sent through the smp2p framework.
config QCOM_CDSP_RM
bool "CDSP request manager"
depends on QCOM_GLINK
help
This driver serves CDSP requests for CPU L3 clock and CPU QoS thus
improving CDSP performance. Using this driver, CDSP can set appropriate
CPU L3 clock for improving IO-Coherent throughput and opt for QoS mode
to improve RPC latency.
config QCOM_CX_IPEAK
bool "Common driver to handle Cx iPeak limitation"
help
Cx ipeak HW module is used to limit the current drawn by various subsystem
blocks on Cx power rail. Each client needs to set their
bit in tcsr register if it is going to cross its own threshold. If all
clients are going to cross their thresholds then Cx ipeak hw module will raise
an interrupt to cDSP block to throttle cDSP fmax.
config QCOM_AOP_DDR_MESSAGING
bool "Send messages to AOP about the DDR frequency during reboot"
help
This driver sends messages to the AOP to adjust the DDR frequency when
the device is rebooting, to ensure that the device is powered off
cleanly.
config QCOM_AOP_DDRSS_COMMANDS
bool "Send commands to AOP to affect the behavior of the DDRSS"
help
This driver allows messages to be sent to the AOP to affect the DDRSS
behavior.
config QCOM_ADSP_MANUAL_VOTE
bool "Send commands to ADSP to unvote and vote during Suspend and resume"
help
This driver is used to manually release and acquire the ADSP vote from APPS
processor during system suspend and resume.
This driver sends message over QMI to the service which is running on
ADSP.
config MSM_BAM_DMUX
bool "BAM Data Mux Driver"
depends on SPS
help
Support Muxed Data Channels over BAM interface.
BAM has a limited number of pipes. This driver
provides a means to support more logical channels
via muxing than BAM could without muxing.
config MSM_BGCOM_INTERFACE
bool "Driver support for Blackghost Communication"
depends on MSM_BGCOM
help
Create a bg_com_dev device node for user space communication.
Single user space client can open device node for communication
from hardware. Hardware will provide access to read
registers and read/write AHB memory in the device.
config MSM_BGCOM
bool "Provide APIs to communicate with Blackghost chipset"
help
BGCOM is a thin layer above SPI. It is used whithin a SoC for
communication between G-Link/bg_com_dev and BG processor over SPI.
This handle the interrupts raised by BG and notify the G-link with
interrupt event and event data.
config MSM_BGRSB
bool "Provide support for rsb events on Blackghost chipset"
help
BGRSB communicates to BG over rpmsg driver for RSB configuration and
enable/disable on device power state change. It enables/disables
the regulator specific to RSB. Sends the side band events generated
by BG to input framework.
config MSM_BGRSB_RPMSG
bool "Provide support for Blackghost events to RSB"
depends on MSM_BGRSB
help
BGRSB-RPMSG informs BGRSB driver if GLINK channel has been
opened by remote processor. It doesn't maintain state machine
and is probed when BG opens channel and removed when the
channel is closed by remote processor.
config MSM_PIL_SSR_BG
tristate "MSM Subsystem Blackghost(BG) Support"
depends on MSM_PIL && MSM_SUBSYSTEM_RESTART
help
Support for booting and shutting down Blackghost(BG) SOC which is
an external SOC. This driver communicates with Blackghost(BG) SOC
via pair of IPC GPIOs for inward and outward signals between MSM
and Blackghost(BG) SOC.
config QCOM_SOC_INFO
bool "Chip information for QTI SoCs"
depends on SOC_BUS
default y
help
This driver provides information about the SoC and chip information such
as the chip ID and revision. Information includes decoding the chip name
based on the chip ID and querying the SoC revision. This information is
loaded by the bootloader into SMEM during the boot up process.
config QTI_CRYPTO_COMMON
tristate "Enable common crypto functionality used for FBE"
depends on BLK_INLINE_ENCRYPTION
help
Say 'Y' to enable the common crypto implementation to be used by
different storage layers such as UFS and EMMC for file based hardware
encryption. This library implements API to program and evict
keys using Trustzone or Hardware Key Manager.
config QTI_CRYPTO_TZ
tristate "Enable Trustzone to be used for FBE"
depends on QTI_CRYPTO_COMMON
help
Say 'Y' to enable routing crypto requests to Trustzone while
performing hardware based file encryption. This means keys are
programmed and managed through SCM calls to TZ where ICE driver
will configure keys.
endmenu
config QCOM_HYP_CORE_CTL
bool "CPU reservation scheme for Hypervisor"
depends on OKL4_GUEST
help
This driver reserve the specified CPUS by isolating them. The reserved
CPUs can be assigned to the other guest OS by the hypervisor.
An offline CPU is considered as a reserved CPU since this OS can't use
it.
config RENAME_BLOCK_DEVICE
bool "Rename block device node in /dev"
help
This driver is used to rename the block device node assigned by generic driver
to a name that is needed.
source "drivers/soc/qcom/wcnss/Kconfig"