The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/contrib/device-tree/Bindings/spi/spi-controller.yaml

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 # SPDX-License-Identifier: GPL-2.0
    2 %YAML 1.2
    3 ---
    4 $id: http://devicetree.org/schemas/spi/spi-controller.yaml#
    5 $schema: http://devicetree.org/meta-schemas/core.yaml#
    6 
    7 title: SPI Controller Generic Binding
    8 
    9 maintainers:
   10   - Mark Brown <broonie@kernel.org>
   11 
   12 description: |
   13   SPI busses can be described with a node for the SPI controller device
   14   and a set of child nodes for each SPI slave on the bus. The system SPI
   15   controller may be described for use in SPI master mode or in SPI slave mode,
   16   but not for both at the same time.
   17 
   18 properties:
   19   $nodename:
   20     pattern: "^spi(@.*|-[0-9a-f])*$"
   21 
   22   "#address-cells":
   23     enum: [0, 1]
   24 
   25   "#size-cells":
   26     const: 0
   27 
   28   cs-gpios:
   29     description: |
   30       GPIOs used as chip selects.
   31       If that property is used, the number of chip selects will be
   32       increased automatically with max(cs-gpios, hardware chip selects).
   33 
   34       So if, for example, the controller has 4 CS lines, and the
   35       cs-gpios looks like this
   36         cs-gpios = <&gpio1 0 0>, <0>, <&gpio1 1 0>, <&gpio1 2 0>;
   37 
   38       Then it should be configured so that num_chipselect = 4, with
   39       the following mapping
   40         cs0 : &gpio1 0 0
   41         cs1 : native
   42         cs2 : &gpio1 1 0
   43         cs3 : &gpio1 2 0
   44 
   45       The second flag of a gpio descriptor can be GPIO_ACTIVE_HIGH (0)
   46       or GPIO_ACTIVE_LOW(1). Legacy device trees often use 0.
   47 
   48       There is a special rule set for combining the second flag of an
   49       cs-gpio with the optional spi-cs-high flag for SPI slaves.
   50 
   51       Each table entry defines how the CS pin is to be physically
   52       driven (not considering potential gpio inversions by pinmux):
   53 
   54       device node     | cs-gpio       | CS pin state active | Note
   55       ================+===============+=====================+=====
   56       spi-cs-high     | -             | H                   |
   57       -               | -             | L                   |
   58       spi-cs-high     | ACTIVE_HIGH   | H                   |
   59       -               | ACTIVE_HIGH   | L                   | 1
   60       spi-cs-high     | ACTIVE_LOW    | H                   | 2
   61       -               | ACTIVE_LOW    | L                   |
   62 
   63       Notes:
   64       1) Should print a warning about polarity inversion.
   65          Here it would be wise to avoid and define the gpio as
   66          ACTIVE_LOW.
   67       2) Should print a warning about polarity inversion
   68          because ACTIVE_LOW is overridden by spi-cs-high.
   69          Should be generally avoided and be replaced by
   70          spi-cs-high + ACTIVE_HIGH.
   71 
   72   num-cs:
   73     $ref: /schemas/types.yaml#/definitions/uint32
   74     description:
   75       Total number of chip selects.
   76 
   77   spi-slave:
   78     $ref: /schemas/types.yaml#/definitions/flag
   79     description:
   80       The SPI controller acts as a slave, instead of a master.
   81 
   82   slave:
   83     type: object
   84 
   85     properties:
   86       compatible:
   87         description:
   88           Compatible of the SPI device.
   89 
   90     required:
   91       - compatible
   92 
   93 patternProperties:
   94   "^.*@[0-9a-f]+$":
   95     type: object
   96     $ref: spi-peripheral-props.yaml
   97 
   98     properties:
   99       spi-cpha:
  100         $ref: /schemas/types.yaml#/definitions/flag
  101         description:
  102           The device requires shifted clock phase (CPHA) mode.
  103 
  104       spi-cpol:
  105         $ref: /schemas/types.yaml#/definitions/flag
  106         description:
  107           The device requires inverse clock polarity (CPOL) mode.
  108 
  109     required:
  110       - compatible
  111       - reg
  112 
  113 allOf:
  114   - if:
  115       not:
  116         required:
  117           - spi-slave
  118     then:
  119       properties:
  120         "#address-cells":
  121           const: 1
  122     else:
  123       properties:
  124         "#address-cells":
  125           const: 0
  126 
  127 additionalProperties: true
  128 
  129 examples:
  130   - |
  131     spi@80010000 {
  132         #address-cells = <1>;
  133         #size-cells = <0>;
  134         compatible = "fsl,imx28-spi";
  135         reg = <0x80010000 0x2000>;
  136         interrupts = <96>;
  137         dmas = <&dma_apbh 0>;
  138         dma-names = "rx-tx";
  139 
  140         display@0 {
  141             compatible = "lg,lg4573";
  142             spi-max-frequency = <1000000>;
  143             reg = <0>;
  144         };
  145 
  146         sensor@1 {
  147             compatible = "bosch,bme680";
  148             spi-max-frequency = <100000>;
  149             reg = <1>;
  150         };
  151 
  152         flash@2 {
  153             compatible = "jedec,spi-nor";
  154             spi-max-frequency = <50000000>;
  155             reg = <2>, <3>;
  156             stacked-memories = /bits/ 64 <0x10000000 0x10000000>;
  157         };
  158     };

Cache object: cc93e02d8ac9e02a84bf188cce274fa0


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.