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