mirror of https://gitee.com/openkylin/linux.git
108 lines
3.1 KiB
Plaintext
108 lines
3.1 KiB
Plaintext
NVIDIA Tegra124 and Tegra132 Clock And Reset Controller
|
|
|
|
This binding uses the common clock binding:
|
|
Documentation/devicetree/bindings/clock/clock-bindings.txt
|
|
|
|
The CAR (Clock And Reset) Controller on Tegra is the HW module responsible
|
|
for muxing and gating Tegra's clocks, and setting their rates.
|
|
|
|
Required properties :
|
|
- compatible : Should be "nvidia,tegra124-car" or "nvidia,tegra132-car"
|
|
- reg : Should contain CAR registers location and length
|
|
- clocks : Should contain phandle and clock specifiers for two clocks:
|
|
the 32 KHz "32k_in", and the board-specific oscillator "osc".
|
|
- #clock-cells : Should be 1.
|
|
In clock consumers, this cell represents the clock ID exposed by the
|
|
CAR. The assignments may be found in the header files
|
|
<dt-bindings/clock/tegra124-car-common.h> (which covers IDs common
|
|
to Tegra124 and Tegra132) and <dt-bindings/clock/tegra124-car.h>
|
|
(for Tegra124-specific clocks).
|
|
- #reset-cells : Should be 1.
|
|
In clock consumers, this cell represents the bit number in the CAR's
|
|
array of CLK_RST_CONTROLLER_RST_DEVICES_* registers.
|
|
- nvidia,external-memory-controller : phandle of the EMC driver.
|
|
|
|
The node should contain a "emc-timings" subnode for each supported RAM type (see
|
|
field RAM_CODE in register PMC_STRAPPING_OPT_A).
|
|
|
|
Required properties for "emc-timings" nodes :
|
|
- nvidia,ram-code : Should contain the value of RAM_CODE this timing set
|
|
is used for.
|
|
|
|
Each "emc-timings" node should contain a "timing" subnode for every supported
|
|
EMC clock rate.
|
|
|
|
Required properties for "timing" nodes :
|
|
- clock-frequency : Should contain the memory clock rate to which this timing
|
|
relates.
|
|
- nvidia,parent-clock-frequency : Should contain the rate at which the current
|
|
parent of the EMC clock should be running at this timing.
|
|
- clocks : Must contain an entry for each entry in clock-names.
|
|
See ../clocks/clock-bindings.txt for details.
|
|
- clock-names : Must include the following entries:
|
|
- emc-parent : the clock that should be the parent of the EMC clock at this
|
|
timing.
|
|
|
|
Example SoC include file:
|
|
|
|
/ {
|
|
tegra_car: clock@60006000 {
|
|
compatible = "nvidia,tegra124-car";
|
|
reg = <0x60006000 0x1000>;
|
|
#clock-cells = <1>;
|
|
#reset-cells = <1>;
|
|
nvidia,external-memory-controller = <&emc>;
|
|
};
|
|
|
|
usb@c5004000 {
|
|
clocks = <&tegra_car TEGRA124_CLK_USB2>;
|
|
};
|
|
};
|
|
|
|
Example board file:
|
|
|
|
/ {
|
|
clocks {
|
|
compatible = "simple-bus";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
osc: clock@0 {
|
|
compatible = "fixed-clock";
|
|
reg = <0>;
|
|
#clock-cells = <0>;
|
|
clock-frequency = <112400000>;
|
|
};
|
|
|
|
clk_32k: clock@1 {
|
|
compatible = "fixed-clock";
|
|
reg = <1>;
|
|
#clock-cells = <0>;
|
|
clock-frequency = <32768>;
|
|
};
|
|
};
|
|
|
|
&tegra_car {
|
|
clocks = <&clk_32k> <&osc>;
|
|
};
|
|
|
|
clock@60006000 {
|
|
emc-timings-3 {
|
|
nvidia,ram-code = <3>;
|
|
|
|
timing-12750000 {
|
|
clock-frequency = <12750000>;
|
|
nvidia,parent-clock-frequency = <408000000>;
|
|
clocks = <&tegra_car TEGRA124_CLK_PLL_P>;
|
|
clock-names = "emc-parent";
|
|
};
|
|
timing-20400000 {
|
|
clock-frequency = <20400000>;
|
|
nvidia,parent-clock-frequency = <408000000>;
|
|
clocks = <&tegra_car TEGRA124_CLK_PLL_P>;
|
|
clock-names = "emc-parent";
|
|
};
|
|
};
|
|
};
|
|
};
|