2019-05-19 13:07:45 +01:00
# SPDX-License-Identifier: GPL-2.0-only
2005-04-16 15:20:36 -07:00
#
2006-08-13 23:39:11 +02:00
# I2C subsystem configuration
2005-04-16 15:20:36 -07:00
#
2014-05-20 20:59:24 +08:00
menu "I2C support"
config I2C
2005-04-16 15:20:36 -07:00
tristate "I2C support"
2009-12-06 17:06:22 +01:00
select RT_MUTEXES
2016-10-13 14:10:40 +02:00
select IRQ_DOMAIN
2020-06-14 01:50:22 +09:00
help
2011-07-08 22:33:24 +00:00
I2C (pronounce: I-squared-C) is a slow serial bus protocol used in
2005-04-16 15:20:36 -07:00
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.
2014-08-15 13:38:59 +08:00
config ACPI_I2C_OPREGION
bool "ACPI I2C Operation region support"
depends on I2C=y && ACPI
2014-05-20 20:59:24 +08:00
default y
help
2014-08-15 13:38:59 +08:00
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.
2014-05-20 20:59:24 +08:00
2007-05-01 23:26:34 +02:00
if I2C
i2c: Add i2c_board_info and i2c_new_device()
This provides partial support for new-style I2C driver binding. It builds
on "struct i2c_board_info" declarations that identify I2C devices on a given
board. This is needed on systems with I2C devices that can't be fully probed
and/or autoconfigured, such as many embedded Linux configurations where the
way a given I2C device is wired may affect how it must be used.
There are two models for declaring such devices:
* LATE -- using a public function i2c_new_device(). This lets modules
declare I2C devices found *AFTER* a given I2C adapter becomes available.
For example, a PCI card could create adapters giving access to utility
chips on that card, and this would be used to associate those chips with
those adapters.
* EARLY -- from arch_initcall() level code, using a non-exported function
i2c_register_board_info(). This copies the declarations *BEFORE* such
an i2c_adapter becomes available, arranging that i2c_new_device() will
be called later when i2c-core registers the relevant i2c_adapter.
For example, arch/.../.../board-*.c files would declare the I2C devices
along with their platform data, and I2C devices would behave much like
PNPACPI devices. (That is, both enumerate from board-specific tables.)
To match the exported i2c_new_device(), the previously-private function
i2c_unregister_device() is now exported.
Pending later patches using these new APIs, this is effectively a NOP.
Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: Jean Delvare <khali@linux-fr.org>
2007-05-01 23:26:31 +02:00
config I2C_BOARDINFO
2014-12-20 15:41:11 -05:00
bool
i2c: Add i2c_board_info and i2c_new_device()
This provides partial support for new-style I2C driver binding. It builds
on "struct i2c_board_info" declarations that identify I2C devices on a given
board. This is needed on systems with I2C devices that can't be fully probed
and/or autoconfigured, such as many embedded Linux configurations where the
way a given I2C device is wired may affect how it must be used.
There are two models for declaring such devices:
* LATE -- using a public function i2c_new_device(). This lets modules
declare I2C devices found *AFTER* a given I2C adapter becomes available.
For example, a PCI card could create adapters giving access to utility
chips on that card, and this would be used to associate those chips with
those adapters.
* EARLY -- from arch_initcall() level code, using a non-exported function
i2c_register_board_info(). This copies the declarations *BEFORE* such
an i2c_adapter becomes available, arranging that i2c_new_device() will
be called later when i2c-core registers the relevant i2c_adapter.
For example, arch/.../.../board-*.c files would declare the I2C devices
along with their platform data, and I2C devices would behave much like
PNPACPI devices. (That is, both enumerate from board-specific tables.)
To match the exported i2c_new_device(), the previously-private function
i2c_unregister_device() is now exported.
Pending later patches using these new APIs, this is effectively a NOP.
Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: Jean Delvare <khali@linux-fr.org>
2007-05-01 23:26:31 +02:00
default y
2009-09-18 22:45:46 +02:00
config I2C_COMPAT
2014-12-20 15:41:11 -05:00
bool "Enable compatibility bits for old user-space"
2009-09-18 22:45:46 +02:00
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.
2005-04-16 15:20:36 -07:00
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
2019-07-26 09:51:16 -03:00
contained in the file <file:Documentation/i2c/dev-interface.rst>.
2005-04-16 15:20:36 -07:00
This support is also available as a module. If so, the module
will be called i2c-dev.
2010-08-11 18:21:02 +02:00
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.
2018-12-11 20:01:04 +09:00
source "drivers/i2c/muxes/Kconfig"
2010-08-11 18:21:03 +02:00
2008-08-10 22:56:15 +02:00
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.
2010-03-02 12:23:43 +01:00
config I2C_SMBUS
2010-11-06 18:30:25 -03:00
tristate "SMBus-specific protocols" if !I2C_HELPER_AUTO
2010-03-02 12:23:43 +01:00
help
Say Y here if you want support for SMBus extensions to the I2C
2016-07-18 12:39:43 +02:00
specification. At the moment, two extensions are supported:
the SMBus Alert protocol and the SMBus Host Notify protocol.
2010-03-02 12:23:43 +01:00
This support is also available as a module. If so, the module
will be called i2c-smbus.
2018-12-11 20:01:04 +09:00
source "drivers/i2c/algos/Kconfig"
source "drivers/i2c/busses/Kconfig"
2005-04-16 15:20:36 -07:00
2012-10-05 22:23:52 +02:00
config I2C_STUB
tristate "I2C/SMBus Test Stub"
2013-01-16 18:53:37 -08:00
depends on m
2012-10-05 22:23:52 +02:00
default 'n'
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
2019-07-26 09:51:16 -03:00
in <file:Documentation/i2c/i2c-stub.rst>.
2012-10-05 22:23:52 +02:00
If you don't know what to do here, definitely say N.
2014-11-18 17:04:54 +01:00
config I2C_SLAVE
bool "I2C slave support"
2020-06-28 20:55:22 +02:00
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.
2014-11-18 17:04:54 +01:00
if I2C_SLAVE
config I2C_SLAVE_EEPROM
tristate "I2C eeprom slave driver"
2020-06-28 20:54:26 +02:00
help
This backend makes Linux behave like an I2C EEPROM. Please read
Documentation/i2c/slave-eeprom-backend.rst for further details.
2014-11-18 17:04:54 +01:00
endif
2005-04-16 15:20:36 -07:00
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"
2012-10-05 22:23:52 +02:00
depends on HAS_IOMEM
2005-04-16 15:20:36 -07:00
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.
2007-05-01 23:26:34 +02:00
endif # I2C
2014-05-20 20:59:24 +08:00
endmenu