Documentation / devicetree / bindings / i2c / i2c-mux.yaml


Based on kernel version 6.17. Page generated on 2025-10-03 10:04 EST.

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
# SPDX-License-Identifier: GPL-2.0
%YAML 1.2
---
$id: http://devicetree.org/schemas/i2c/i2c-mux.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#

title: Common i2c bus multiplexer/switch properties.

maintainers:
  - Peter Rosin <peda@axentia.se>

description: |+
  An i2c bus multiplexer/switch will have several child busses that are numbered
  uniquely in a device dependent manner.  The nodes for an i2c bus
  multiplexer/switch will have one child node for each child bus.
 
  For i2c multiplexers/switches that have child nodes that are a mixture of both
  i2c child busses and other child nodes, the 'i2c-mux' subnode can be used for
  populating the i2c child busses.  If an 'i2c-mux' subnode is present, only
  subnodes of this will be considered as i2c child busses.

properties:
  $nodename:
    pattern: '^(i2c-?)?mux'
 
  '#address-cells':
    const: 1
 
  '#size-cells':
    const: 0

patternProperties:
  '^i2c@[0-9a-f]+$':
    $ref: /schemas/i2c/i2c-controller.yaml
    unevaluatedProperties: false

    properties:
      reg:
        description: The mux selector sub-bus number for the child I2C bus.
        maxItems: 1

additionalProperties: true

examples:
  - |
    /*
     * An NXP pca9548 8 channel I2C multiplexer at address 0x70
     * with two NXP pca8574 GPIO expanders attached, one each to
     * ports 3 and 4.
     */
    i2c {
        #address-cells = <1>;
        #size-cells = <0>;
 
        i2c-mux@70 {
            compatible = "nxp,pca9548";
            reg = <0x70>;
            #address-cells = <1>;
            #size-cells = <0>;
 
            i2c@3 {
                #address-cells = <1>;
                #size-cells = <0>;
                reg = <3>;
 
                gpio@20 {
                    compatible = "nxp,pca9555";
                    gpio-controller;
                    #gpio-cells = <2>;
                    reg = <0x20>;
                };
            };
            i2c@4 {
                #address-cells = <1>;
                #size-cells = <0>;
                reg = <4>;
 
                gpio@20 {
                    compatible = "nxp,pca9555";
                    gpio-controller;
                    #gpio-cells = <2>;
                    reg = <0x20>;
                };
            };
        };
    };
...