160 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			160 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| # SPDX-License-Identifier: GPL-2.0
 | |
| %YAML 1.2
 | |
| ---
 | |
| $id: http://devicetree.org/schemas/spi/spi-pl022.yaml#
 | |
| $schema: http://devicetree.org/meta-schemas/core.yaml#
 | |
| 
 | |
| title: ARM PL022 SPI controller
 | |
| 
 | |
| maintainers:
 | |
|   - Linus Walleij <linus.walleij@linaro.org>
 | |
| 
 | |
| allOf:
 | |
|   - $ref: "spi-controller.yaml#"
 | |
| 
 | |
| # We need a select here so we don't match all nodes with 'arm,primecell'
 | |
| select:
 | |
|   properties:
 | |
|     compatible:
 | |
|       contains:
 | |
|         const: arm,pl022
 | |
|   required:
 | |
|     - compatible
 | |
| 
 | |
| properties:
 | |
|   compatible:
 | |
|     items:
 | |
|       - const: arm,pl022
 | |
|       - const: arm,primecell
 | |
| 
 | |
|   reg:
 | |
|     maxItems: 1
 | |
| 
 | |
|   interrupts:
 | |
|     maxItems: 1
 | |
| 
 | |
|   clocks:
 | |
|     maxItems: 2
 | |
| 
 | |
|   clock-names:
 | |
|     items:
 | |
|       - enum:
 | |
|           - SSPCLK
 | |
|           - sspclk
 | |
|       - const: apb_pclk
 | |
| 
 | |
|   pl022,autosuspend-delay:
 | |
|     description: delay in ms following transfer completion before the
 | |
|       runtime power management system suspends the device. A setting of 0
 | |
|       indicates no delay and the device will be suspended immediately.
 | |
|     $ref: "/schemas/types.yaml#/definitions/uint32"
 | |
| 
 | |
|   pl022,rt:
 | |
|     description: indicates the controller should run the message pump with realtime
 | |
|       priority to minimise the transfer latency on the bus (boolean)
 | |
|     type: boolean
 | |
| 
 | |
|   dmas:
 | |
|     description:
 | |
|       Two or more DMA channel specifiers following the convention outlined
 | |
|       in bindings/dma/dma.txt
 | |
|     minItems: 2
 | |
|     maxItems: 32
 | |
| 
 | |
|   dma-names:
 | |
|     description:
 | |
|       There must be at least one channel named "tx" for transmit and named "rx"
 | |
|       for receive.
 | |
|     minItems: 2
 | |
|     maxItems: 32
 | |
|     additionalItems: true
 | |
|     items:
 | |
|       - const: rx
 | |
|       - const: tx
 | |
| 
 | |
| patternProperties:
 | |
|   "^[a-zA-Z][a-zA-Z0-9,+\\-._]{0,63}@[0-9a-f]+$":
 | |
|     type: object
 | |
|     # SPI slave nodes must be children of the SPI master node and can
 | |
|     # contain the following properties.
 | |
|     properties:
 | |
|       pl022,interface:
 | |
|         description: SPI interface type
 | |
|         $ref: "/schemas/types.yaml#/definitions/uint32"
 | |
|         enum:
 | |
|           - 0      # SPI
 | |
|           - 1      # Texas Instruments Synchronous Serial Frame Format
 | |
|           - 2      # Microwire (Half Duplex)
 | |
| 
 | |
|       pl022,com-mode:
 | |
|         description: Specifies the transfer mode
 | |
|         $ref: "/schemas/types.yaml#/definitions/uint32"
 | |
|         enum:
 | |
|           - 0      # interrupt mode
 | |
|           - 1      # polling mode
 | |
|           - 2      # DMA mode
 | |
|         default: 1
 | |
| 
 | |
|       pl022,rx-level-trig:
 | |
|         description: Rx FIFO watermark level
 | |
|         $ref: "/schemas/types.yaml#/definitions/uint32"
 | |
|         minimum: 0
 | |
|         maximum: 4
 | |
| 
 | |
|       pl022,tx-level-trig:
 | |
|         description: Tx FIFO watermark level
 | |
|         $ref: "/schemas/types.yaml#/definitions/uint32"
 | |
|         minimum: 0
 | |
|         maximum: 4
 | |
| 
 | |
|       pl022,ctrl-len:
 | |
|         description: Microwire interface - Control length
 | |
|         $ref: "/schemas/types.yaml#/definitions/uint32"
 | |
|         minimum: 0x03
 | |
|         maximum: 0x1f
 | |
| 
 | |
|       pl022,wait-state:
 | |
|         description: Microwire interface - Wait state
 | |
|         $ref: "/schemas/types.yaml#/definitions/uint32"
 | |
|         enum: [0, 1]
 | |
| 
 | |
|       pl022,duplex:
 | |
|         description: Microwire interface - Full/Half duplex
 | |
|         $ref: "/schemas/types.yaml#/definitions/uint32"
 | |
|         enum: [0, 1]
 | |
| 
 | |
| required:
 | |
|   - compatible
 | |
|   - reg
 | |
|   - interrupts
 | |
| 
 | |
| unevaluatedProperties: false
 | |
| 
 | |
| examples:
 | |
|   - |
 | |
|     spi@e0100000 {
 | |
|       compatible = "arm,pl022", "arm,primecell";
 | |
|       reg = <0xe0100000 0x1000>;
 | |
|       #address-cells = <1>;
 | |
|       #size-cells = <0>;
 | |
|       interrupts = <0 31 0x4>;
 | |
|       dmas = <&dma_controller 23 1>,
 | |
|         <&dma_controller 24 0>;
 | |
|       dma-names = "rx", "tx";
 | |
| 
 | |
|       m25p80@1 {
 | |
|         compatible = "st,m25p80";
 | |
|         reg = <1>;
 | |
|         spi-max-frequency = <12000000>;
 | |
|         spi-cpol;
 | |
|         spi-cpha;
 | |
|         pl022,interface = <0>;
 | |
|         pl022,com-mode = <0x2>;
 | |
|         pl022,rx-level-trig = <0>;
 | |
|         pl022,tx-level-trig = <0>;
 | |
|         pl022,ctrl-len = <0x11>;
 | |
|         pl022,wait-state = <0>;
 | |
|         pl022,duplex = <0>;
 | |
|       };
 | |
|     };
 | |
| ...
 |