/linux/Documentation/ABI/testing/ |
H A D | sysfs-bus-i3c | 1 What: /sys/bus/i3c/devices/i3c-<bus-id> 3 Contact: linux-i3c@vger.kernel.org 5 An I3C bus. This directory will contain one sub-directory per 6 I3C device present on the bus. 8 What: /sys/bus/i3c/devices/i3c-<bus-id>/current_master 10 Contact: linux-i3c@vger.kernel.org 17 What: /sys/bus/i3c/devices/i3c-<bus-id>/mode 19 Contact: linux-i3c@vger.kernel.org 21 I3C bus mode. Can be "pure", "mixed-fast" or "mixed-slow". See 22 the I3C specification for a detailed description of what each [all …]
|
/linux/drivers/i3c/master/ |
H A D | renesas-i3c.c | 3 * Renesas I3C Controller driver 16 #include <linux/i3c/master.h> 318 static int renesas_i3c_get_free_pos(struct renesas_i3c *i3c) in renesas_i3c_get_free_pos() argument 320 if (!(i3c->free_pos & GENMASK(i3c->maxdevs - 1, 0))) in renesas_i3c_get_free_pos() 323 return ffs(i3c->free_pos) - 1; in renesas_i3c_get_free_pos() 326 static int renesas_i3c_get_addr_pos(struct renesas_i3c *i3c, u8 addr) in renesas_i3c_get_addr_pos() argument 330 for (pos = 0; pos < i3c->maxdevs; pos++) { in renesas_i3c_get_addr_pos() 331 if (addr == i3c->addrs[pos]) in renesas_i3c_get_addr_pos() 338 static struct renesas_i3c_xfer *renesas_i3c_alloc_xfer(struct renesas_i3c *i3c, in renesas_i3c_alloc_xfer() argument 354 static void renesas_i3c_start_xfer_locked(struct renesas_i3c *i3c) in renesas_i3c_start_xfer_locked() argument [all …]
|
H A D | Kconfig | 3 tristate "Cadence I3C master driver" 7 Enable this driver if you want to support Cadence I3C master block. 10 tristate "Synospsys DesignWare I3C master driver" 15 Support for Synopsys DesignWare MIPI I3C Controller. 21 will be called dw-i3c-master. 24 tristate "ASPEED AST2600 I3C master driver" 29 Support for ASPEED AST2600 I3C Controller. 31 This hardware is an instance of the DW I3C controller; this 35 will be called ast2600-i3c-master. 38 tristate "Silvaco I3C Dual-Role Master driver" [all …]
|
H A D | Makefile | 2 obj-$(CONFIG_CDNS_I3C_MASTER) += i3c-master-cdns.o 3 obj-$(CONFIG_DW_I3C_MASTER) += dw-i3c-master.o 4 obj-$(CONFIG_AST2600_I3C_MASTER) += ast2600-i3c-master.o 5 obj-$(CONFIG_SVC_I3C_MASTER) += svc-i3c-master.o 6 obj-$(CONFIG_MIPI_I3C_HCI) += mipi-i3c-hci/ 7 obj-$(CONFIG_RENESAS_I3C) += renesas-i3c.o
|
/linux/include/linux/i3c/ |
H A D | master.h | 15 #include <linux/i3c/ccc.h> 16 #include <linux/i3c/device.h> 39 * struct i3c_i2c_dev_desc - Common part of the I3C/I2C device descriptor 40 * @node: node element used to insert the slot into the I2C or I3C device 42 * @master: I3C master that instantiated this device. Will be used to do 43 * I2C/I3C transfers 47 * This structure is describing common I3C/I2C dev information. 65 * @lvr: LVR (Legacy Virtual Register) needed by the I3C core to know about 69 * Each I2C device connected on the I3C bus should have one. 82 * @lvr: LVR (Legacy Virtual Register) needed by the I3C core to know about [all …]
|
H A D | device.h | 19 * enum i3c_error_code - I3C error codes 21 * @I3C_ERROR_UNKNOWN: unknown error, usually means the error is not I3C 27 * These are the standard error codes as defined by the I3C specification. 54 * struct i3c_priv_xfer - I3C SDR private transfer 61 * @err: I3C error code 75 * enum i3c_dcr - I3C DCR values 76 * @I3C_DCR_GENERIC_DEVICE: generic I3C device 100 * struct i3c_device_info - I3C device information 114 * These are all basic information that should be advertised by an I3C device. 117 * For each I3C slave attached to a master with [all …]
|
H A D | ccc.h | 12 #include <linux/i3c/device.h> 14 /* I3C CCC (Common Command Codes) related definitions */ 88 * The IBI length is only valid if the I3C slave is IBI capable 97 * struct i3c_ccc_dev_desc - I3C/I2C device descriptor used for DEFSLVS 99 * @dyn_addr: dynamic address assigned to the I3C slave or 0 if the entry is 102 * @lvr: LVR value (not applicable to entries describing I3C devices) 108 * descriptors (one entry per I3C/I2C dev controlled by the master). 154 * Information passed to the ENTTM CCC to instruct an I3C device to enter a 164 * @addr: dynamic address to assign to an I3C device 167 * dynamic address of an I3C device. [all …]
|
/linux/Documentation/devicetree/bindings/i3c/ |
H A D | i3c.yaml | 4 $id: http://devicetree.org/schemas/i3c/i3c.yaml# 7 title: I3C bus 14 I3C busses can be described with a node for the primary I3C controller device 15 and a set of child nodes for each I2C or I3C slave on the bus. Each of them 20 pattern: "^i3c@[0-9a-f]+$" 27 All I3C devices are supposed to support DAA (Dynamic Address Assignment), 28 and are thus discoverable. So, by default, I3C devices do not have to be 32 I3C devices. 34 Another use case for describing an I3C device in the device tree is when 35 this I3C device has a static I2C address and we want to assign it a [all …]
|
H A D | mipi-i3c-hci.yaml | 4 $id: http://devicetree.org/schemas/i3c/mipi-i3c-hci.yaml# 7 title: MIPI I3C HCI 13 - $ref: /schemas/i3c/i3c.yaml# 16 MIPI I3C Host Controller Interface 18 The MIPI I3C HCI (Host Controller Interface) specification defines 19 a common software driver interface to support compliant MIPI I3C 27 https://www.mipi.org/specifications/i3c-hci 31 const: mipi-i3c-hci 46 i3c@a0000000 { 47 compatible = "mipi-i3c-hci";
|
H A D | aspeed,ast2600-i3c.yaml | 4 $id: http://devicetree.org/schemas/i3c/aspeed,ast2600-i3c.yaml# 7 title: ASPEED AST2600 i3c controller 13 - $ref: i3c.yaml# 17 const: aspeed,ast2600-i3c 41 - description: phandle to i3c global register syscon node 42 - description: index of this i3c controller in the global register set 44 A (phandle, controller index) reference to the i3c global register set 60 i3c@2000 { 61 compatible = "aspeed,ast2600-i3c";
|
H A D | snps,dw-i3c-master.yaml | 4 $id: http://devicetree.org/schemas/i3c/snps,dw-i3c-master.yaml# 7 title: Synopsys DesignWare I3C master block 13 - $ref: i3c.yaml# 17 const: snps,dw-i3c-master-1.00a 50 i3c@2000 { 51 compatible = "snps,dw-i3c-master-1.00a";
|
H A D | renesas,i3c.yaml | 4 $id: http://devicetree.org/schemas/i3c/renesas,i3c.yaml# 7 title: Renesas RZ/G3S and RZ/G3E I3C Bus Interface 17 - renesas,r9a08g045-i3c # RZ/G3S 18 - renesas,r9a09g047-i3c # RZ/G3E 104 - $ref: i3c.yaml# 110 const: renesas,r9a08g045-i3c 126 const: renesas,r9a09g047-i3c 145 i3c@1005b000 { 146 compatible = "renesas,r9a08g045-i3c";
|
/linux/arch/arm64/boot/dts/axiado/ |
H A D | ax3000.dtsi | 232 /* I3C Controller 0 - 16 */ 233 i3c0: i3c@80500400 { 234 compatible = "axiado,ax3000-i3c", "cdns,i3c-master"; 241 i3c-scl-hz = <400000>; 247 i3c1: i3c@80500800 { 248 compatible = "axiado,ax3000-i3c", "cdns,i3c-master"; 255 i3c-scl-hz = <400000>; 261 i3c2: i3c@80580400 { 262 compatible = "axiado,ax3000-i3c", "cdns,i3c-master"; 269 i3c-scl-hz = <400000>; [all …]
|
/linux/drivers/i3c/ |
H A D | Kconfig | 3 menuconfig I3C config 4 tristate "I3C support" 7 I3C is a serial protocol standardized by the MIPI alliance. 13 The I3C protocol also standardizes the slave device types and is 16 If you want I3C support, you should say Y here and also to the 19 This I3C support can also be built as a module. If so, the module 20 will be called i3c. 22 if I3C 23 source "drivers/i3c/master/Kconfig" 24 endif # I3C
|
H A D | master.c | 30 * @bus: I3C bus to take the lock on 41 * logic to rely on I3C device information that could be changed behind their 52 * @bus: I3C bus to release the lock on 65 * @bus: I3C bus to take the lock on 69 * maintenance operations). Basically all communications with I3C devices are 71 * state or I3C dynamic address). 74 * In other words, transfer requests passed to the I3C master can be submitted 75 * in parallel and I3C master drivers have to use their own locking to make 86 * @bus: I3C bus to release the lock on 250 struct i3c_device *i3c = dev_to_i3cdev(dev); in modalias_show() local [all …]
|
H A D | Makefile | 2 i3c-y := device.o master.o 3 obj-$(CONFIG_I3C) += i3c.o
|
/linux/drivers/net/mctp/ |
H A D | mctp-i3c.c | 4 * "DSP0233 Management Component Transport Protocol (MCTP) I3C Transport 13 #include <linux/i3c/device.h> 14 #include <linux/i3c/master.h> 73 struct i3c_device *i3c; member 82 /* I3C dynamic address */ 128 /* Make sure netif_rx() is read in the same order as i3c. */ in mctp_i3c_read() 130 rc = i3c_device_do_priv_xfers(mi->i3c, &xfer, 1); in mctp_i3c_read() 135 /* Bad i3c bus driver */ in mctp_i3c_read() 179 static void mctp_i3c_ibi_handler(struct i3c_device *i3c, in mctp_i3c_ibi_handler() argument 182 struct mctp_i3c_device *mi = i3cdev_get_drvdata(i3c); in mctp_i3c_ibi_handler() [all …]
|
/linux/drivers/base/regmap/ |
H A D | regmap-i3c.c | 5 #include <linux/i3c/device.h> 6 #include <linux/i3c/master.h> 12 struct i3c_device *i3c = dev_to_i3cdev(dev); in regmap_i3c_write() local 21 return i3c_device_do_priv_xfers(i3c, xfers, 1); in regmap_i3c_write() 29 struct i3c_device *i3c = dev_to_i3cdev(dev); in regmap_i3c_read() local 40 return i3c_device_do_priv_xfers(i3c, xfers, 2); in regmap_i3c_read() 48 struct regmap *__devm_regmap_init_i3c(struct i3c_device *i3c, in __devm_regmap_init_i3c() argument 53 return __devm_regmap_init(&i3c->dev, ®map_i3c, &i3c->dev, config, in __devm_regmap_init_i3c() 59 MODULE_DESCRIPTION("regmap I3C Module");
|
/linux/drivers/iio/imu/st_lsm6dsx/ |
H A D | Kconfig | 5 depends on (I2C || SPI || I3C) 54 tristate "ST_LSM6DSx driver for STM 6-axis IMU MEMS sensors I3C Interface" 55 depends on I3C && IIO_ST_LSM6DSX 56 default I3C && IIO_ST_LSM6DSX
|
H A D | st_lsm6dsx_i3c.c | 11 #include <linux/i3c/device.h> 22 MODULE_DEVICE_TABLE(i3c, st_lsm6dsx_i3c_ids); 37 dev_err(dev, "Failed to register i3c regmap %ld\n", PTR_ERR(regmap)); in st_lsm6dsx_i3c_probe() 55 MODULE_DESCRIPTION("STMicroelectronics st_lsm6dsx i3c driver");
|
/linux/drivers/i3c/master/mipi-i3c-hci/ |
H A D | xfer_mode_rate.h | 9 * This applies starting from I3C HCI v2.0. 22 #define XFERMODE_IDX_I3C_SDR 0x00 /* I3C SDR Mode */ 23 #define XFERMODE_IDX_I3C_HDR_DDR 0x01 /* I3C HDR-DDR Mode */ 24 #define XFERMODE_IDX_I3C_HDR_T 0x02 /* I3C HDR-Ternary Mode */ 25 #define XFERMODE_IDX_I3C_HDR_BT 0x03 /* I3C HDR-BT Mode */
|
H A D | Makefile | 3 obj-$(CONFIG_MIPI_I3C_HCI) += mipi-i3c-hci.o 4 mipi-i3c-hci-y := core.o ext_caps.o pio.o dma.o \ 8 obj-$(CONFIG_MIPI_I3C_HCI_PCI) += mipi-i3c-hci-pci.o
|
H A D | cmd_v2.c | 7 * I3C HCI v2.0 Command Descriptor Handling 9 * Note: The I3C HCI v2.0 spec is still in flux. The code here will change. 13 #include <linux/i3c/master.h> 70 if (bus->scl_rate.i3c >= 12000000) in get_i3c_rate_idx() 72 if (bus->scl_rate.i3c > 8000000) in get_i3c_rate_idx() 74 if (bus->scl_rate.i3c > 6000000) in get_i3c_rate_idx() 76 if (bus->scl_rate.i3c > 4000000) in get_i3c_rate_idx() 78 if (bus->scl_rate.i3c > 2000000) in get_i3c_rate_idx()
|
/linux/Documentation/driver-api/i3c/ |
H A D | device-driver-api.rst | 4 I3C device driver API 7 .. kernel-doc:: include/linux/i3c/device.h 9 .. kernel-doc:: drivers/i3c/device.c
|
H A D | master-driver-api.rst | 4 I3C master controller driver API 7 .. kernel-doc:: drivers/i3c/master.c 9 .. kernel-doc:: include/linux/i3c/master.h
|