1# SPDX-License-Identifier: GPL-2.0-only 2# 3# I2C subsystem configuration 4# 5 6menu "I2C support" 7 8config I2C 9 tristate "I2C support" 10 select RT_MUTEXES 11 select IRQ_DOMAIN 12 help 13 I2C (pronounce: I-squared-C) is a slow serial bus protocol used in 14 many micro controller applications and developed by Philips. SMBus, 15 or System Management Bus is a subset of the I2C protocol. More 16 information is contained in the directory <file:Documentation/i2c/>, 17 especially in the file called "summary" there. 18 19 Both I2C and SMBus are supported here. You will need this for 20 hardware sensors support, and also for Video For Linux support. 21 22 If you want I2C support, you should say Y here and also to the 23 specific driver for your bus adapter(s) below. 24 25 This I2C support can also be built as a module. If so, the module 26 will be called i2c-core. 27 28config ACPI_I2C_OPREGION 29 bool "ACPI I2C Operation region support" 30 depends on I2C=y && ACPI 31 default y 32 help 33 Say Y here if you want to enable ACPI I2C operation region support. 34 Operation Regions allow firmware (BIOS) code to access I2C slave devices, 35 such as smart batteries through an I2C host controller driver. 36 37if I2C 38 39config I2C_BOARDINFO 40 bool 41 default y 42 43config I2C_COMPAT 44 bool "Enable compatibility bits for old user-space" 45 default y 46 help 47 Say Y here if you intend to run lm-sensors 3.1.1 or older, or any 48 other user-space package which expects i2c adapters to be class 49 devices. If you don't know, say Y. 50 51config I2C_CHARDEV 52 tristate "I2C device interface" 53 help 54 Say Y here to use i2c-* device files, usually found in the /dev 55 directory on your system. They make it possible to have user-space 56 programs use the I2C bus. Information on how to do this is 57 contained in the file <file:Documentation/i2c/dev-interface.rst>. 58 59 This support is also available as a module. If so, the module 60 will be called i2c-dev. 61 62config I2C_MUX 63 tristate "I2C bus multiplexing support" 64 help 65 Say Y here if you want the I2C core to support the ability to 66 handle multiplexed I2C bus topologies, by presenting each 67 multiplexed segment as a I2C adapter. 68 69 This support is also available as a module. If so, the module 70 will be called i2c-mux. 71 72source "drivers/i2c/muxes/Kconfig" 73 74config I2C_ATR 75 tristate "I2C Address Translator (ATR) support" if COMPILE_TEST 76 help 77 Enable support for I2C Address Translator (ATR) chips. 78 79 An ATR allows accessing multiple I2C busses from a single 80 physical bus via address translation instead of bus selection as 81 i2c-muxes do. 82 83config I2C_HELPER_AUTO 84 bool "Autoselect pertinent helper modules" 85 default y 86 help 87 Some I2C bus drivers require so-called "I2C algorithm" modules 88 to work. These are basically software-only abstractions of generic 89 I2C interfaces. This option will autoselect them so that you don't 90 have to care. 91 92 Unselect this only if you need to enable additional helper 93 modules, for example for use with external I2C bus drivers. 94 95 In doubt, say Y. 96 97config I2C_SMBUS 98 tristate "SMBus-specific protocols" if !I2C_HELPER_AUTO 99 help 100 Say Y here if you want support for SMBus extensions to the I2C 101 specification. At the moment, two extensions are supported: 102 the SMBus Alert protocol and the SMBus Host Notify protocol. 103 104 This support is also available as a module. If so, the module 105 will be called i2c-smbus. 106 107source "drivers/i2c/algos/Kconfig" 108source "drivers/i2c/busses/Kconfig" 109 110config I2C_STUB 111 tristate "I2C/SMBus Test Stub" 112 depends on m 113 help 114 This module may be useful to developers of SMBus client drivers, 115 especially for certain kinds of sensor chips. 116 117 If you do build this module, be sure to read the notes and warnings 118 in <file:Documentation/i2c/i2c-stub.rst>. 119 120 If you don't know what to do here, definitely say N. 121 122config I2C_SLAVE 123 bool "I2C slave support" 124 help 125 This enables Linux to act as an I2C slave device. Note that your I2C 126 bus master driver also needs to support this functionality. Please 127 read Documentation/i2c/slave-interface.rst for further details. 128 129if I2C_SLAVE 130 131config I2C_SLAVE_EEPROM 132 tristate "I2C eeprom slave driver" 133 help 134 This backend makes Linux behave like an I2C EEPROM. Please read 135 Documentation/i2c/slave-eeprom-backend.rst for further details. 136 137config I2C_SLAVE_TESTUNIT 138 tristate "I2C eeprom testunit driver" 139 help 140 This backend can be used to trigger test cases for I2C bus masters 141 which require a remote device with certain capabilities, e.g. 142 multi-master, SMBus Host Notify, etc. Please read 143 Documentation/i2c/slave-testunit-backend.rst for further details. 144 145endif 146 147config I2C_DEBUG_CORE 148 bool "I2C Core debugging messages" 149 help 150 Say Y here if you want the I2C core to produce a bunch of debug 151 messages to the system log. Select this if you are having a 152 problem with I2C support and want to see more of what is going on. 153 154config I2C_DEBUG_ALGO 155 bool "I2C Algorithm debugging messages" 156 help 157 Say Y here if you want the I2C algorithm drivers to produce a bunch 158 of debug messages to the system log. Select this if you are having 159 a problem with I2C support and want to see more of what is going 160 on. 161 162config I2C_DEBUG_BUS 163 bool "I2C Bus debugging messages" 164 depends on HAS_IOMEM 165 help 166 Say Y here if you want the I2C bus drivers to produce a bunch of 167 debug messages to the system log. Select this if you are having 168 a problem with I2C support and want to see more of what is going 169 on. 170 171endif # I2C 172 173endmenu 174