treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / drivers / bus / Kconfig
blob50200d1c06ea624d342341593144f89ad5d8a795
1 # SPDX-License-Identifier: GPL-2.0
3 # Bus Devices
6 menu "Bus devices"
8 config ARM_CCI
9         bool
11 config ARM_CCI400_COMMON
12         bool
13         select ARM_CCI
15 config ARM_CCI400_PORT_CTRL
16         bool
17         depends on ARM && OF && CPU_V7
18         select ARM_CCI400_COMMON
19         help
20           Low level power management driver for CCI400 cache coherent
21           interconnect for ARM platforms.
23 config BRCMSTB_GISB_ARB
24         bool "Broadcom STB GISB bus arbiter"
25         depends on ARM || ARM64 || MIPS
26         default ARCH_BRCMSTB || BMIPS_GENERIC
27         help
28           Driver for the Broadcom Set Top Box System-on-a-chip internal bus
29           arbiter. This driver provides timeout and target abort error handling
30           and internal bus master decoding.
32 config MOXTET
33         tristate "CZ.NIC Turris Mox module configuration bus"
34         depends on SPI_MASTER && OF
35         help
36           Say yes here to add support for the module configuration bus found
37           on CZ.NIC's Turris Mox. This is needed for the ability to discover
38           the order in which the modules are connected and to get/set some of
39           their settings. For example the GPIOs on Mox SFP module are
40           configured through this bus.
42 config HISILICON_LPC
43         bool "Support for ISA I/O space on HiSilicon Hip06/7"
44         depends on (ARM64 && ARCH_HISI) || (COMPILE_TEST && !ALPHA && !HEXAGON && !PARISC && !C6X)
45         depends on HAS_IOMEM
46         select INDIRECT_PIO if ARM64
47         help
48           Driver to enable I/O access to devices attached to the Low Pin
49           Count bus on the HiSilicon Hip06/7 SoC.
51 config IMX_WEIM
52         bool "Freescale EIM DRIVER"
53         depends on ARCH_MXC
54         help
55           Driver for i.MX WEIM controller.
56           The WEIM(Wireless External Interface Module) works like a bus.
57           You can attach many different devices on it, such as NOR, onenand.
59 config MIPS_CDMM
60         bool "MIPS Common Device Memory Map (CDMM) Driver"
61         depends on CPU_MIPSR2
62         help
63           Driver needed for the MIPS Common Device Memory Map bus in MIPS
64           cores. This bus is for per-CPU tightly coupled devices such as the
65           Fast Debug Channel (FDC).
67           For this to work, either your bootloader needs to enable the CDMM
68           region at an unused physical address on the boot CPU, or else your
69           platform code needs to implement mips_cdmm_phys_base() (see
70           asm/cdmm.h).
72 config MVEBU_MBUS
73         bool
74         depends on PLAT_ORION
75         help
76           Driver needed for the MBus configuration on Marvell EBU SoCs
77           (Kirkwood, Dove, Orion5x, MV78XX0 and Armada 370/XP).
79 config OMAP_INTERCONNECT
80         tristate "OMAP INTERCONNECT DRIVER"
81         depends on ARCH_OMAP2PLUS
83         help
84           Driver to enable OMAP interconnect error handling driver.
86 config OMAP_OCP2SCP
87         tristate "OMAP OCP2SCP DRIVER"
88         depends on ARCH_OMAP2PLUS
89         help
90           Driver to enable ocp2scp module which transforms ocp interface
91           protocol to scp protocol. In OMAP4, USB PHY is connected via
92           OCP2SCP and in OMAP5, both USB PHY and SATA PHY is connected via
93           OCP2SCP.
95 config QCOM_EBI2
96         bool "Qualcomm External Bus Interface 2 (EBI2)"
97         depends on HAS_IOMEM
98         depends on ARCH_QCOM || COMPILE_TEST
99         default ARCH_QCOM
100         help
101           Say y here to enable support for the Qualcomm External Bus
102           Interface 2, which can be used to connect things like NAND Flash,
103           SRAM, ethernet adapters, FPGAs and LCD displays.
105 config SIMPLE_PM_BUS
106         tristate "Simple Power-Managed Bus Driver"
107         depends on OF && PM
108         help
109           Driver for transparent busses that don't need a real driver, but
110           where the bus controller is part of a PM domain, or under the control
111           of a functional clock, and thus relies on runtime PM for managing
112           this PM domain and/or clock.
113           An example of such a bus controller is the Renesas Bus State
114           Controller (BSC, sometimes called "LBSC within Bus Bridge", or
115           "External Bus Interface") as found on several Renesas ARM SoCs.
117 config SUN50I_DE2_BUS
118         bool "Allwinner A64 DE2 Bus Driver"
119           default ARM64
120           depends on ARCH_SUNXI
121           select SUNXI_SRAM
122           help
123           Say y here to enable support for Allwinner A64 DE2 bus driver. It's
124           mostly transparent, but a SRAM region needs to be claimed in the SRAM
125           controller to make the all blocks in the DE2 part accessible.
127 config SUNXI_RSB
128         tristate "Allwinner sunXi Reduced Serial Bus Driver"
129           default MACH_SUN8I || MACH_SUN9I || ARM64
130           depends on ARCH_SUNXI
131           select REGMAP
132           help
133           Say y here to enable support for Allwinner's Reduced Serial Bus
134           (RSB) support. This controller is responsible for communicating
135           with various RSB based devices, such as AXP223, AXP8XX PMICs,
136           and AC100/AC200 ICs.
138 config TEGRA_ACONNECT
139         tristate "Tegra ACONNECT Bus Driver"
140         depends on ARCH_TEGRA_210_SOC
141         depends on OF && PM
142         select PM_CLK
143         help
144           Driver for the Tegra ACONNECT bus which is used to interface with
145           the devices inside the Audio Processing Engine (APE) for Tegra210.
147 config TEGRA_GMI
148         tristate "Tegra Generic Memory Interface bus driver"
149         depends on ARCH_TEGRA
150         help
151           Driver for the Tegra Generic Memory Interface bus which can be used
152           to attach devices such as NOR, UART, FPGA and more.
154 config  TI_PWMSS
155         bool
156         default y if (ARCH_OMAP2PLUS) && (PWM_TIECAP || PWM_TIEHRPWM || TI_EQEP)
157         help
158           PWM Subsystem driver support for AM33xx SOC.
160           PWM submodules require PWM config space access from submodule
161           drivers and require common parent driver support.
163 config TI_SYSC
164         bool "TI sysc interconnect target module driver"
165         depends on ARCH_OMAP2PLUS
166         help
167           Generic driver for Texas Instruments interconnect target module
168           found on many TI SoCs.
170 config TS_NBUS
171         tristate "Technologic Systems NBUS Driver"
172         depends on SOC_IMX28
173         depends on OF_GPIO && PWM
174         help
175           Driver for the Technologic Systems NBUS which is used to interface
176           with the peripherals in the FPGA of the TS-4600 SoM.
178 config UNIPHIER_SYSTEM_BUS
179         tristate "UniPhier System Bus driver"
180         depends on ARCH_UNIPHIER && OF
181         default y
182         help
183           Support for UniPhier System Bus, a simple external bus.  This is
184           needed to use on-board devices connected to UniPhier SoCs.
186 config VEXPRESS_CONFIG
187         bool "Versatile Express configuration bus"
188         default y if ARCH_VEXPRESS
189         depends on ARM || ARM64
190         depends on OF
191         select REGMAP
192         help
193           Platform configuration infrastructure for the ARM Ltd.
194           Versatile Express.
196 config DA8XX_MSTPRI
197         bool "TI da8xx master peripheral priority driver"
198         depends on ARCH_DAVINCI_DA8XX
199         help
200           Driver for Texas Instruments da8xx master peripheral priority
201           configuration. Allows to adjust the priorities of all master
202           peripherals.
204 source "drivers/bus/fsl-mc/Kconfig"
206 endmenu