Lines Matching +full:rx +full:- +full:dma +full:- +full:channel
2 # SPDX-License-Identifier: Apache-2.0
5 GD32 DMA controller with FIFO
7 channel: Select channel for data transmitting
9 slot: Select peripheral to connect DMA
11 config: A 32bit mask specifying the DMA channel configuration
12 - bit 6-7: Direction (see dma.h)
13 - 0x0: MEMORY to MEMORY
14 - 0x1: MEMORY to PERIPH
15 - 0x2: PERIPH to MEMORY
16 - 0x3: reserved for PERIPH to PERIPH
18 - bit 9: Peripheral address increase
19 - 0x0: no address increment between transfers
20 - 0x1: increment address between transfers
22 - bit 10: Memory address increase
23 - 0x0: no address increase between transfers
24 - 0x1: increase address between transfers
26 - bit 11-12: Peripheral data width
27 - 0x0: 8 bits
28 - 0x1: 16 bits
29 - 0x2: 32 bits
30 - 0x3: reserved
32 - bit 13-14: Memory data width
33 - 0x0: 8 bits
34 - 0x1: 16 bits
35 - 0x2: 32 bits
36 - 0x3: reserved
38 - bit 15: Peripheral Increment Offset Size
39 - 0x0: offset size is linked to the peripheral bus width
40 - 0x1: offset size is fixed to 4 (32-bit alignment)
42 - bit 16-17: Priority
43 - 0x0: low
44 - 0x1: medium
45 - 0x2: high
46 - 0x3: very high
48 fifo-threshold: A 32bit bitfield value specifying FIFO threshold
49 - bit 0-1: Depth of DMA's FIFO used by burst-transfer.
50 - 0x0: 1 word
51 - 0x1: 2 word
52 - 0x2: 3 word
53 - 0x3: 4 word
60 pinctrl-0 = <&spi0_default>;
61 pinctrl-names = "default";
62 cs-gpios = <&gpioa 4 GPIO_ACTIVE_LOW>;
65 dma-names = "rx", "tx";
69 Each is named "rx" and "tx".
70 The first cell assigns channel 0 to receive and channel 5 to transmit.
72 What the slot number '3' means depends on the DMA controller and channel.
76 Set the priority for the transmitting channel as HIGH, LOW(the default) for receive channel.
77 The fifo-threshold cell that places the fourth is configuring FIFO threshold.
78 The behavior of burst transfer determines by data-width in the config cell,
79 burst-length in the dma_config struct, and fifo-threshold.
80 A single burst transfer transfers [(4 * fifo-threshold)] bytes using with DMA's FIFO.
81 Where (data-width * burst-length) must be multiple numbers of burst transfer size.
82 For example, In the case of data-width is 'byte' and burst-length is 8.
83 If the fifo-threshold is a 2-word case, it runs one burst transfer to transfer 8 bytes.
84 Or the fifo-threshold is a 4-word case, runs two times burst transfer to transferring 8 bytes each
87 compatible: "gd,gd32-dma-v1"
89 include: ["reset-device.yaml", "gd,gd32-dma-base.yaml"]
92 "#dma-cells":
95 dma-cells:
96 - channel
97 - slot
98 - config
99 - fifo-threshold