blob: 97e9e315400d9b098476ca861918bf266784b81f [file] [log] [blame]
Thomas Abrahamcd1b00e2012-08-23 17:10:09 +00001* Samsung's SDHCI Controller device tree bindings
2
3Samsung's SDHCI controller is used as a connectivity interface with external
4MMC, SD and eMMC storage mediums. This file documents differences between the
5core mmc properties described by mmc.txt and the properties used by the
6Samsung implmentation of the SDHCI controller.
7
8Note: The mmc core bindings documentation states that if none of the core
9card-detect bindings are used, then the standard sdhci card detect mechanism
10is used. The Samsung's SDHCI controller bindings extends this as listed below.
11
12[A] The property "samsung,cd-pinmux-gpio" can be used as stated in the
13 "Optional Board Specific Properties" section below.
14
Thomas Abrahamcd1b00e2012-08-23 17:10:09 +000015Required SoC Specific Properties:
16- compatible: should be one of the following
17 - "samsung,s3c6410-sdhci": For controllers compatible with s3c6410 sdhci
18 controller.
19 - "samsung,exynos4210-sdhci": For controllers compatible with Exynos4 sdhci
20 controller.
21
22Required Board Specific Properties:
Tomasz Figab96efcc2012-11-16 15:28:17 +010023- Samsung GPIO variant (will be completely replaced by pinctrl):
24 - gpios: Should specify the gpios used for clock, command and data lines. The
25 gpio specifier format depends on the gpio controller.
26- Pinctrl variant (preferred if available):
27 - pinctrl-0: Should specify pin control groups used for this controller.
28 - pinctrl-names: Should contain only one value - "default".
Thomas Abrahamcd1b00e2012-08-23 17:10:09 +000029
30Optional Board Specific Properties:
31- samsung,cd-pinmux-gpio: Specifies the card detect line that is routed
32 through a pinmux to the card-detect pin of the card slot. This property
33 should be used only if none of the mmc core card-detect properties are
Tomasz Figab96efcc2012-11-16 15:28:17 +010034 used. Only for Samsung GPIO variant.
Thomas Abrahamcd1b00e2012-08-23 17:10:09 +000035
36Example:
37 sdhci@12530000 {
38 compatible = "samsung,exynos4210-sdhci";
39 reg = <0x12530000 0x100>;
40 interrupts = <0 75 0>;
41 bus-width = <4>;
42 cd-gpios = <&gpk2 2 2 3 3>;
Tomasz Figab96efcc2012-11-16 15:28:17 +010043
44 /* Samsung GPIO variant */
Thomas Abrahamcd1b00e2012-08-23 17:10:09 +000045 gpios = <&gpk2 0 2 0 3>, /* clock line */
46 <&gpk2 1 2 0 3>, /* command line */
47 <&gpk2 3 2 3 3>, /* data line 0 */
48 <&gpk2 4 2 3 3>, /* data line 1 */
49 <&gpk2 5 2 3 3>, /* data line 2 */
50 <&gpk2 6 2 3 3>; /* data line 3 */
Tomasz Figab96efcc2012-11-16 15:28:17 +010051
52 /* Pinctrl variant */
53 pinctrl-0 = <&sd0_clk &sd0_cmd &sd0_bus4>;
54 pinctrl-names = "default";
Thomas Abrahamcd1b00e2012-08-23 17:10:09 +000055 };
56
57 Note: This example shows both SoC specific and board specific properties
58 in a single device node. The properties can be actually be seperated
59 into SoC specific node and board specific node.