mirror of
https://github.com/torvalds/linux.git
synced 2025-01-01 15:51:46 +00:00
71f5c63c07
This patch adds support for MIPI DPHYs found in Exynos5420-compatible (5420, 5422 and 5800) and Exynos5433 SoCs. Those SoCs differs from earlier by different offset of MIPI DPHY registers in PMU controllers (Exynos 5420-compatible case) or by moving MIPI DPHY reset registers to separate system register controllers (Exynos 5433 case). In both case also additional 5th PHY (MIPI CSIS 2) has been added. Acked-by: Sylwester Nawrocki <s.nawrocki@samsung.com> Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com> Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
194 lines
6.7 KiB
Plaintext
194 lines
6.7 KiB
Plaintext
Samsung S5P/EXYNOS SoC series MIPI CSIS/DSIM DPHY
|
|
-------------------------------------------------
|
|
|
|
Required properties:
|
|
- compatible : should be one of the listed compatibles:
|
|
- "samsung,s5pv210-mipi-video-phy"
|
|
- "samsung,exynos5420-mipi-video-phy"
|
|
- "samsung,exynos5433-mipi-video-phy"
|
|
- #phy-cells : from the generic phy bindings, must be 1;
|
|
|
|
In case of s5pv210 and exynos5420 compatible PHYs:
|
|
- syscon - phandle to the PMU system controller
|
|
|
|
In case of exynos5433 compatible PHY:
|
|
- samsung,pmu-syscon - phandle to the PMU system controller
|
|
- samsung,disp-sysreg - phandle to the DISP system registers controller
|
|
- samsung,cam0-sysreg - phandle to the CAM0 system registers controller
|
|
- samsung,cam1-sysreg - phandle to the CAM1 system registers controller
|
|
|
|
For "samsung,s5pv210-mipi-video-phy" compatible PHYs the second cell in
|
|
the PHY specifier identifies the PHY and its meaning is as follows:
|
|
0 - MIPI CSIS 0,
|
|
1 - MIPI DSIM 0,
|
|
2 - MIPI CSIS 1,
|
|
3 - MIPI DSIM 1.
|
|
"samsung,exynos5420-mipi-video-phy" and "samsung,exynos5433-mipi-video-phy"
|
|
supports additional fifth PHY:
|
|
4 - MIPI CSIS 2.
|
|
|
|
Samsung EXYNOS SoC series Display Port PHY
|
|
-------------------------------------------------
|
|
|
|
Required properties:
|
|
- compatible : should be one of the following supported values:
|
|
- "samsung,exynos5250-dp-video-phy"
|
|
- "samsung,exynos5420-dp-video-phy"
|
|
- samsung,pmu-syscon: phandle for PMU system controller interface, used to
|
|
control pmu registers for power isolation.
|
|
- #phy-cells : from the generic PHY bindings, must be 0;
|
|
|
|
Samsung S5P/EXYNOS SoC series USB PHY
|
|
-------------------------------------------------
|
|
|
|
Required properties:
|
|
- compatible : should be one of the listed compatibles:
|
|
- "samsung,exynos3250-usb2-phy"
|
|
- "samsung,exynos4210-usb2-phy"
|
|
- "samsung,exynos4x12-usb2-phy"
|
|
- "samsung,exynos5250-usb2-phy"
|
|
- "samsung,s5pv210-usb2-phy"
|
|
- reg : a list of registers used by phy driver
|
|
- first and obligatory is the location of phy modules registers
|
|
- samsung,sysreg-phandle - handle to syscon used to control the system registers
|
|
- samsung,pmureg-phandle - handle to syscon used to control PMU registers
|
|
- #phy-cells : from the generic phy bindings, must be 1;
|
|
- clocks and clock-names:
|
|
- the "phy" clock is required by the phy module, used as a gate
|
|
- the "ref" clock is used to get the rate of the clock provided to the
|
|
PHY module
|
|
|
|
Optional properties:
|
|
- vbus-supply: power-supply phandle for vbus power source
|
|
|
|
The first phandle argument in the PHY specifier identifies the PHY, its
|
|
meaning is compatible dependent. For the currently supported SoCs (Exynos 4210
|
|
and Exynos 4212) it is as follows:
|
|
0 - USB device ("device"),
|
|
1 - USB host ("host"),
|
|
2 - HSIC0 ("hsic0"),
|
|
3 - HSIC1 ("hsic1"),
|
|
Exynos3250 has only USB device phy available as phy 0.
|
|
|
|
Exynos 4210 and Exynos 4212 use mode switching and require that mode switch
|
|
register is supplied.
|
|
|
|
Example:
|
|
|
|
For Exynos 4412 (compatible with Exynos 4212):
|
|
|
|
usbphy: phy@125b0000 {
|
|
compatible = "samsung,exynos4x12-usb2-phy";
|
|
reg = <0x125b0000 0x100>;
|
|
clocks = <&clock 305>, <&clock 2>;
|
|
clock-names = "phy", "ref";
|
|
status = "okay";
|
|
#phy-cells = <1>;
|
|
samsung,sysreg-phandle = <&sys_reg>;
|
|
samsung,pmureg-phandle = <&pmu_reg>;
|
|
};
|
|
|
|
Then the PHY can be used in other nodes such as:
|
|
|
|
phy-consumer@12340000 {
|
|
phys = <&usbphy 2>;
|
|
phy-names = "phy";
|
|
};
|
|
|
|
Refer to DT bindings documentation of particular PHY consumer devices for more
|
|
information about required PHYs and the way of specification.
|
|
|
|
Samsung SATA PHY Controller
|
|
---------------------------
|
|
|
|
SATA PHY nodes are defined to describe on-chip SATA Physical layer controllers.
|
|
Each SATA PHY controller should have its own node.
|
|
|
|
Required properties:
|
|
- compatible : compatible list, contains "samsung,exynos5250-sata-phy"
|
|
- reg : offset and length of the SATA PHY register set;
|
|
- #phy-cells : must be zero
|
|
- clocks : must be exactly one entry
|
|
- clock-names : must be "sata_phyctrl"
|
|
- samsung,exynos-sataphy-i2c-phandle : a phandle to the I2C device, no arguments
|
|
- samsung,syscon-phandle : a phandle to the PMU system controller, no arguments
|
|
|
|
Example:
|
|
sata_phy: sata-phy@12170000 {
|
|
compatible = "samsung,exynos5250-sata-phy";
|
|
reg = <0x12170000 0x1ff>;
|
|
clocks = <&clock 287>;
|
|
clock-names = "sata_phyctrl";
|
|
#phy-cells = <0>;
|
|
samsung,exynos-sataphy-i2c-phandle = <&sata_phy_i2c>;
|
|
samsung,syscon-phandle = <&pmu_syscon>;
|
|
};
|
|
|
|
Device-Tree bindings for sataphy i2c client driver
|
|
--------------------------------------------------
|
|
|
|
Required properties:
|
|
compatible: Should be "samsung,exynos-sataphy-i2c"
|
|
- reg: I2C address of the sataphy i2c device.
|
|
|
|
Example:
|
|
|
|
sata_phy_i2c:sata-phy@38 {
|
|
compatible = "samsung,exynos-sataphy-i2c";
|
|
reg = <0x38>;
|
|
};
|
|
|
|
Samsung Exynos5 SoC series USB DRD PHY controller
|
|
--------------------------------------------------
|
|
|
|
Required properties:
|
|
- compatible : Should be set to one of the following supported values:
|
|
- "samsung,exynos5250-usbdrd-phy" - for exynos5250 SoC,
|
|
- "samsung,exynos5420-usbdrd-phy" - for exynos5420 SoC.
|
|
- "samsung,exynos5433-usbdrd-phy" - for exynos5433 SoC.
|
|
- "samsung,exynos7-usbdrd-phy" - for exynos7 SoC.
|
|
- reg : Register offset and length of USB DRD PHY register set;
|
|
- clocks: Clock IDs array as required by the controller
|
|
- clock-names: names of clocks correseponding to IDs in the clock property;
|
|
Required clocks:
|
|
- phy: main PHY clock (same as USB DRD controller i.e. DWC3 IP clock),
|
|
used for register access.
|
|
- ref: PHY's reference clock (usually crystal clock), used for
|
|
PHY operations, associated by phy name. It is used to
|
|
determine bit values for clock settings register.
|
|
For Exynos5420 this is given as 'sclk_usbphy30' in CMU.
|
|
- optional clocks: Exynos5433 & Exynos7 SoC has now following additional
|
|
gate clocks available:
|
|
- phy_pipe: for PIPE3 phy
|
|
- phy_utmi: for UTMI+ phy
|
|
- itp: for ITP generation
|
|
- samsung,pmu-syscon: phandle for PMU system controller interface, used to
|
|
control pmu registers for power isolation.
|
|
- #phy-cells : from the generic PHY bindings, must be 1;
|
|
|
|
For "samsung,exynos5250-usbdrd-phy" and "samsung,exynos5420-usbdrd-phy"
|
|
compatible PHYs, the second cell in the PHY specifier identifies the
|
|
PHY id, which is interpreted as follows:
|
|
0 - UTMI+ type phy,
|
|
1 - PIPE3 type phy,
|
|
|
|
Example:
|
|
usbdrd_phy: usbphy@12100000 {
|
|
compatible = "samsung,exynos5250-usbdrd-phy";
|
|
reg = <0x12100000 0x100>;
|
|
clocks = <&clock 286>, <&clock 1>;
|
|
clock-names = "phy", "ref";
|
|
samsung,pmu-syscon = <&pmu_system_controller>;
|
|
#phy-cells = <1>;
|
|
};
|
|
|
|
- aliases: For SoCs like Exynos5420 having multiple USB 3.0 DRD PHY controllers,
|
|
'usbdrd_phy' nodes should have numbered alias in the aliases node,
|
|
in the form of usbdrdphyN, N = 0, 1... (depending on number of
|
|
controllers).
|
|
Example:
|
|
aliases {
|
|
usbdrdphy0 = &usb3_phy0;
|
|
usbdrdphy1 = &usb3_phy1;
|
|
};
|