blob: 41c9b22523e7dc251ad1fdd1061d9a66b3b52eba [file] [log] [blame]
Tom Rini6bb92fc2024-05-20 09:54:58 -06001# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/mmc/hisilicon,hi3798cv200-dw-mshc.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: Hisilicon HiSTB SoCs specific extensions to the Synopsys DWMMC controller
8
9maintainers:
10 - Yang Xiwen <forbidden405@outlook.com>
11
12properties:
13 compatible:
14 enum:
15 - hisilicon,hi3798cv200-dw-mshc
16 - hisilicon,hi3798mv200-dw-mshc
17
18 reg:
19 maxItems: 1
20
21 interrupts:
22 maxItems: 1
23
24 clocks:
25 items:
26 - description: bus interface unit clock
27 - description: card interface unit clock
28 - description: card input sample phase clock
29 - description: controller output drive phase clock
30
31 clock-names:
32 items:
33 - const: ciu
34 - const: biu
35 - const: ciu-sample
36 - const: ciu-drive
37
38 hisilicon,sap-dll-reg:
39 $ref: /schemas/types.yaml#/definitions/phandle-array
40 description: |
41 DWMMC core on Hi3798MV2x SoCs has a delay-locked-loop(DLL) attached to card data input path.
42 It is integrated into CRG core on the SoC and has to be controlled during tuning.
43 items:
44 - description: A phandle pointed to the CRG syscon node
45 - description: Sample DLL register offset in CRG address space
46
47required:
48 - compatible
49 - reg
50 - interrupts
51 - clocks
52 - clock-names
53
54allOf:
55 - $ref: synopsys-dw-mshc-common.yaml#
56
57 - if:
58 properties:
59 compatible:
60 contains:
61 const: hisilicon,hi3798mv200-dw-mshc
62 then:
63 required:
64 - hisilicon,sap-dll-reg
65 else:
66 properties:
67 hisilicon,sap-dll-reg: false
68
69unevaluatedProperties: false
70
71examples:
72 - |
73 #include <dt-bindings/clock/histb-clock.h>
74 #include <dt-bindings/interrupt-controller/arm-gic.h>
75
76 mmc@9830000 {
77 compatible = "hisilicon,hi3798cv200-dw-mshc";
78 reg = <0x9830000 0x10000>;
79 interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
80 clocks = <&crg HISTB_MMC_CIU_CLK>,
81 <&crg HISTB_MMC_BIU_CLK>,
82 <&crg HISTB_MMC_SAMPLE_CLK>,
83 <&crg HISTB_MMC_DRV_CLK>;
84 clock-names = "ciu", "biu", "ciu-sample", "ciu-drive";
85 resets = <&crg 0xa0 4>;
86 reset-names = "reset";
87 pinctrl-names = "default";
88 pinctrl-0 = <&emmc_pins_1 &emmc_pins_2
89 &emmc_pins_3 &emmc_pins_4>;
90 fifo-depth = <256>;
91 clock-frequency = <200000000>;
92 cap-mmc-highspeed;
93 mmc-ddr-1_8v;
94 mmc-hs200-1_8v;
95 non-removable;
96 bus-width = <8>;
97 };