内核驱动 i2c-mux-gpio¶
作者: Peter Korsgaard <peter.korsgaard@barco.com>
描述¶
i2c-mux-gpio 是一个 i2c 多路复用器驱动程序,它提供从主 I2C 总线访问 I2C 总线段的能力,并通过 GPIO 引脚控制硬件 MUX。
例如:
---------- ---------- Bus segment 1 - - - - -
| | SCL/SDA | |-------------- | |
| |------------| |
| | | | Bus segment 2 | |
| Linux | GPIO 1..N | MUX |--------------- Devices
| |------------| | | |
| | | | Bus segment M
| | | |---------------| |
---------- ---------- - - - - -
主 I2C 总线的 SCL/SDA 根据 GPIO 引脚 1..N 的设置多路复用到总线段 1..M。
用法¶
i2c-mux-gpio 使用平台总线,因此您需要提供一个 struct platform_device,其 platform_data 指向一个 struct i2c_mux_gpio_platform_data,其中包含主总线的 I2C 适配器号、要创建的总线段数以及用于控制它的 GPIO 引脚。 有关详细信息,请参阅 include/linux/platform_data/i2c-mux-gpio.h。
例如,对于一个通过 3 个 GPIO 引脚控制的提供 4 个总线段的 MUX,可以这样:
#include <linux/platform_data/i2c-mux-gpio.h>
#include <linux/platform_device.h>
static const unsigned myboard_gpiomux_gpios[] = {
AT91_PIN_PC26, AT91_PIN_PC25, AT91_PIN_PC24
};
static const unsigned myboard_gpiomux_values[] = {
0, 1, 2, 3
};
static struct i2c_mux_gpio_platform_data myboard_i2cmux_data = {
.parent = 1,
.base_nr = 2, /* optional */
.values = myboard_gpiomux_values,
.n_values = ARRAY_SIZE(myboard_gpiomux_values),
.gpios = myboard_gpiomux_gpios,
.n_gpios = ARRAY_SIZE(myboard_gpiomux_gpios),
.idle = 4, /* optional */
};
static struct platform_device myboard_i2cmux = {
.name = "i2c-mux-gpio",
.id = 0,
.dev = {
.platform_data = &myboard_i2cmux_data,
},
};
如果您在注册时不知道绝对 GPIO 引脚号,您可以改为提供芯片名称 (.chip_name) 和相对 GPIO 引脚号,i2c-mux-gpio 驱动程序将为您完成这项工作,包括在 GPIO 芯片不可立即使用时进行延迟探测。
设备注册¶
注册 i2c-mux-gpio 设备时,您应该将它使用的任何 GPIO 引脚号作为设备 ID 传递。 这保证了每个实例都有不同的 ID。
或者,如果您不需要稳定的设备名称,您可以简单地将 PLATFORM_DEVID_AUTO 作为设备 ID 传递,平台核心将为您的设备分配一个动态 ID。 如果您在注册时不知道绝对 GPIO 引脚号,这甚至是唯一的选择。