mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-27 14:43:58 +08:00
825f4e0271
A quite large set of SoC updates this cycle. In no particular order: - Multi-cluster power management for Samsung Exynos, adding support for big.LITTLE CPU switching on EXYNOS5 - SMP support for Marvell Armada 375 and 38x - SMP rework on Allwinner A31 - Xilinx Zynq support for SOC_BUS, big endian - Marvell orion5x platform cleanup, modernizing the implementation and moving to DT. - _Finally_ moving Samsung Exynos over to support MULTIPLATFORM, so that their platform can be enabled in the same kernel binary as most of the other v7 platforms in the tree. \o/ The work isn't quite complete, there's some driver fixes still needed, but the basics now work. New SoC support added: - Freescale i.MX6SX - LSI Axxia AXM55xx SoCs - Samsung EXYNOS 3250, 5260, 5410, 5420 and 5800 - STi STIH407 Plus a large set of various smaller updates for different platforms. I'm probably missing some important one here. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.14 (GNU/Linux) iQIcBAABAgAGBQJTjOKWAAoJEIwa5zzehBx36aEP/2vTD7x9FC59FACNHJ8iO7aw 0ebTgBBjI1Np6X18O+M7URbxV5TaBgwpUm/NDN86p03MpQ2eOXr8r47qVxe/HhZs AdlTvzgE6QwxcVL/HeCKKUEN3BPH74+TZgFl9I5aSzNjpR39xETeK1aWP/ZiAl/q /lGRZAQ59+c7Ung00Hg0g2YDxH9WFpK50Nj90ROnyjKSFkhIYngXYVpZB3maOypq Pgib/U8IraKZ52oGJw3yinSoORr7FdcUdAGWGTz/lQdNL/jYDfQ6GkRW2oblWXdt 3Xvj9UW6NmkbMICucMvFuuW1nXAgutZuTp9w7mBxsiUlYepxPv/DXM6yiI1WGlEb BeVOmOreNeN2nT6avv/uUhk3Osq63Jn9x8cz5y+7/lgWQwllh3/c+G01RotvgJEQ vpQq5ps9fMxIAMaNP6N/YqMJI1IOrBj0iXxaZEDw3VYM/k4lSvtb3VXP9c/rqApu U4i6hpSIGzrraU4NrjndYPndcLeNOVZbByETQKosZXuCo6G1sb7FstNSkzI9vSo8 O/pujIVUfYyBW82GzZGDw+aa7DWA29FPeUQ3p+sj5MSCg051xXT8h6QwqMo2K/zY 5ATs/qo6w7zH/Ou9rtHTRynCIb0GQJThDSlWtuXFedUF9quEltS+TDz/2o+dWtGJ yBFGKDRuBB20D36w9xqg =6LYI -----END PGP SIGNATURE----- Merge tag 'soc-for-3.16' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc into next Pull part one of ARM SoC updates from Olof Johansson: "A quite large set of SoC updates this cycle. In no particular order: - Multi-cluster power management for Samsung Exynos, adding support for big.LITTLE CPU switching on EXYNOS5 - SMP support for Marvell Armada 375 and 38x - SMP rework on Allwinner A31 - Xilinx Zynq support for SOC_BUS, big endian - Marvell orion5x platform cleanup, modernizing the implementation and moving to DT. - _Finally_ moving Samsung Exynos over to support MULTIPLATFORM, so that their platform can be enabled in the same kernel binary as most of the other v7 platforms in the tree. \o/ The work isn't quite complete, there's some driver fixes still needed, but the basics now work. New SoC support added: - Freescale i.MX6SX - LSI Axxia AXM55xx SoCs - Samsung EXYNOS 3250, 5260, 5410, 5420 and 5800 - STi STIH407 plus a large set of various smaller updates for different platforms. I'm probably missing some important one here" * tag 'soc-for-3.16' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: (281 commits) ARM: exynos: don't run exynos4 l2x0 setup on other platforms ARM: exynos: Fix "allmodconfig" build errors in mcpm and hotplug ARM: EXYNOS: mcpm rename the power_down_finish ARM: EXYNOS: Enable mcpm for dual-cluster exynos5800 SoC ARM: EXYNOS: Enable multi-platform build support ARM: EXYNOS: Consolidate Kconfig entries ARM: EXYNOS: Add support for EXYNOS5410 SoC ARM: EXYNOS: Support secondary CPU boot of Exynos3250 ARM: EXYNOS: Add Exynos3250 SoC ID ARM: EXYNOS: Add 5800 SoC support ARM: EXYNOS: initial board support for exynos5260 SoC clk: exynos5410: register clocks using common clock framework ARM: debug: qcom: add UART addresses to Kconfig help for APQ8084 ARM: sunxi: allow building without reset controller Documentation: devicetree: arm: sort enable-method entries ARM: rockchip: convert smp bringup to CPU_METHOD_OF_DECLARE clk: exynos5250: Add missing sysmmu clocks for DISP and ISP blocks ARM: dts: axxia: Add reset controller power: reset: Add Axxia system reset driver ARM: axxia: Adding defconfig for AXM55xx ...
450 lines
13 KiB
Plaintext
450 lines
13 KiB
Plaintext
Device Tree Clock bindings for arch-at91
|
|
|
|
This binding uses the common clock binding[1].
|
|
|
|
[1] Documentation/devicetree/bindings/clock/clock-bindings.txt
|
|
|
|
Required properties:
|
|
- compatible : shall be one of the following:
|
|
"atmel,at91sam9x5-sckc":
|
|
at91 SCKC (Slow Clock Controller)
|
|
This node contains the slow clock definitions.
|
|
|
|
"atmel,at91sam9x5-clk-slow-osc":
|
|
at91 slow oscillator
|
|
|
|
"atmel,at91sam9x5-clk-slow-rc-osc":
|
|
at91 internal slow RC oscillator
|
|
|
|
"atmel,at91rm9200-pmc" or
|
|
"atmel,at91sam9g45-pmc" or
|
|
"atmel,at91sam9n12-pmc" or
|
|
"atmel,at91sam9x5-pmc" or
|
|
"atmel,sama5d3-pmc":
|
|
at91 PMC (Power Management Controller)
|
|
All at91 specific clocks (clocks defined below) must be child
|
|
node of the PMC node.
|
|
|
|
"atmel,at91sam9x5-clk-slow" (under sckc node)
|
|
or
|
|
"atmel,at91sam9260-clk-slow" (under pmc node):
|
|
at91 slow clk
|
|
|
|
"atmel,at91rm9200-clk-main-osc"
|
|
"atmel,at91sam9x5-clk-main-rc-osc"
|
|
at91 main clk sources
|
|
|
|
"atmel,at91sam9x5-clk-main"
|
|
"atmel,at91rm9200-clk-main":
|
|
at91 main clock
|
|
|
|
"atmel,at91rm9200-clk-master" or
|
|
"atmel,at91sam9x5-clk-master":
|
|
at91 master clock
|
|
|
|
"atmel,at91sam9x5-clk-peripheral" or
|
|
"atmel,at91rm9200-clk-peripheral":
|
|
at91 peripheral clocks
|
|
|
|
"atmel,at91rm9200-clk-pll" or
|
|
"atmel,at91sam9g45-clk-pll" or
|
|
"atmel,at91sam9g20-clk-pllb" or
|
|
"atmel,sama5d3-clk-pll":
|
|
at91 pll clocks
|
|
|
|
"atmel,at91sam9x5-clk-plldiv":
|
|
at91 plla divisor
|
|
|
|
"atmel,at91rm9200-clk-programmable" or
|
|
"atmel,at91sam9g45-clk-programmable" or
|
|
"atmel,at91sam9x5-clk-programmable":
|
|
at91 programmable clocks
|
|
|
|
"atmel,at91sam9x5-clk-smd":
|
|
at91 SMD (Soft Modem) clock
|
|
|
|
"atmel,at91rm9200-clk-system":
|
|
at91 system clocks
|
|
|
|
"atmel,at91rm9200-clk-usb" or
|
|
"atmel,at91sam9x5-clk-usb" or
|
|
"atmel,at91sam9n12-clk-usb":
|
|
at91 usb clock
|
|
|
|
"atmel,at91sam9x5-clk-utmi":
|
|
at91 utmi clock
|
|
|
|
Required properties for SCKC node:
|
|
- reg : defines the IO memory reserved for the SCKC.
|
|
- #size-cells : shall be 0 (reg is used to encode clk id).
|
|
- #address-cells : shall be 1 (reg is used to encode clk id).
|
|
|
|
|
|
For example:
|
|
sckc: sckc@fffffe50 {
|
|
compatible = "atmel,sama5d3-pmc";
|
|
reg = <0xfffffe50 0x4>
|
|
#size-cells = <0>;
|
|
#address-cells = <1>;
|
|
|
|
/* put at91 slow clocks here */
|
|
};
|
|
|
|
|
|
Required properties for internal slow RC oscillator:
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clock-frequency : define the internal RC oscillator frequency.
|
|
|
|
Optional properties:
|
|
- clock-accuracy : define the internal RC oscillator accuracy.
|
|
|
|
For example:
|
|
slow_rc_osc: slow_rc_osc {
|
|
compatible = "atmel,at91sam9x5-clk-slow-rc-osc";
|
|
clock-frequency = <32768>;
|
|
clock-accuracy = <50000000>;
|
|
};
|
|
|
|
Required properties for slow oscillator:
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall encode the main osc source clk sources (see atmel datasheet).
|
|
|
|
Optional properties:
|
|
- atmel,osc-bypass : boolean property. Set this when a clock signal is directly
|
|
provided on XIN.
|
|
|
|
For example:
|
|
slow_osc: slow_osc {
|
|
compatible = "atmel,at91rm9200-clk-slow-osc";
|
|
#clock-cells = <0>;
|
|
clocks = <&slow_xtal>;
|
|
};
|
|
|
|
Required properties for slow clock:
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall encode the slow clk sources (see atmel datasheet).
|
|
|
|
For example:
|
|
clk32k: slck {
|
|
compatible = "atmel,at91sam9x5-clk-slow";
|
|
#clock-cells = <0>;
|
|
clocks = <&slow_rc_osc &slow_osc>;
|
|
};
|
|
|
|
Required properties for PMC node:
|
|
- reg : defines the IO memory reserved for the PMC.
|
|
- #size-cells : shall be 0 (reg is used to encode clk id).
|
|
- #address-cells : shall be 1 (reg is used to encode clk id).
|
|
- interrupts : shall be set to PMC interrupt line.
|
|
- interrupt-controller : tell that the PMC is an interrupt controller.
|
|
- #interrupt-cells : must be set to 1. The first cell encodes the interrupt id,
|
|
and reflect the bit position in the PMC_ER/DR/SR registers.
|
|
You can use the dt macros defined in dt-bindings/clock/at91.h.
|
|
0 (AT91_PMC_MOSCS) -> main oscillator ready
|
|
1 (AT91_PMC_LOCKA) -> PLL A ready
|
|
2 (AT91_PMC_LOCKB) -> PLL B ready
|
|
3 (AT91_PMC_MCKRDY) -> master clock ready
|
|
6 (AT91_PMC_LOCKU) -> UTMI PLL clock ready
|
|
8 .. 15 (AT91_PMC_PCKRDY(id)) -> programmable clock ready
|
|
16 (AT91_PMC_MOSCSELS) -> main oscillator selected
|
|
17 (AT91_PMC_MOSCRCS) -> RC main oscillator stabilized
|
|
18 (AT91_PMC_CFDEV) -> clock failure detected
|
|
|
|
For example:
|
|
pmc: pmc@fffffc00 {
|
|
compatible = "atmel,sama5d3-pmc";
|
|
interrupts = <1 4 7>;
|
|
interrupt-controller;
|
|
#interrupt-cells = <2>;
|
|
#size-cells = <0>;
|
|
#address-cells = <1>;
|
|
|
|
/* put at91 clocks here */
|
|
};
|
|
|
|
Required properties for main clock internal RC oscillator:
|
|
- interrupt-parent : must reference the PMC node.
|
|
- interrupts : shall be set to "<0>".
|
|
- clock-frequency : define the internal RC oscillator frequency.
|
|
|
|
Optional properties:
|
|
- clock-accuracy : define the internal RC oscillator accuracy.
|
|
|
|
For example:
|
|
main_rc_osc: main_rc_osc {
|
|
compatible = "atmel,at91sam9x5-clk-main-rc-osc";
|
|
interrupt-parent = <&pmc>;
|
|
interrupts = <0>;
|
|
clock-frequency = <12000000>;
|
|
clock-accuracy = <50000000>;
|
|
};
|
|
|
|
Required properties for main clock oscillator:
|
|
- interrupt-parent : must reference the PMC node.
|
|
- interrupts : shall be set to "<0>".
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall encode the main osc source clk sources (see atmel datasheet).
|
|
|
|
Optional properties:
|
|
- atmel,osc-bypass : boolean property. Specified if a clock signal is provided
|
|
on XIN.
|
|
|
|
clock signal is directly provided on XIN pin.
|
|
|
|
For example:
|
|
main_osc: main_osc {
|
|
compatible = "atmel,at91rm9200-clk-main-osc";
|
|
interrupt-parent = <&pmc>;
|
|
interrupts = <0>;
|
|
#clock-cells = <0>;
|
|
clocks = <&main_xtal>;
|
|
};
|
|
|
|
Required properties for main clock:
|
|
- interrupt-parent : must reference the PMC node.
|
|
- interrupts : shall be set to "<0>".
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall encode the main clk sources (see atmel datasheet).
|
|
|
|
For example:
|
|
main: mainck {
|
|
compatible = "atmel,at91sam9x5-clk-main";
|
|
interrupt-parent = <&pmc>;
|
|
interrupts = <0>;
|
|
#clock-cells = <0>;
|
|
clocks = <&main_rc_osc &main_osc>;
|
|
};
|
|
|
|
Required properties for master clock:
|
|
- interrupt-parent : must reference the PMC node.
|
|
- interrupts : shall be set to "<3>".
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall be the master clock sources (see atmel datasheet) phandles.
|
|
e.g. "<&ck32k>, <&main>, <&plla>, <&pllb>".
|
|
- atmel,clk-output-range : minimum and maximum clock frequency (two u32
|
|
fields).
|
|
e.g. output = <0 133000000>; <=> 0 to 133MHz.
|
|
- atmel,clk-divisors : master clock divisors table (four u32 fields).
|
|
0 <=> reserved value.
|
|
e.g. divisors = <1 2 4 6>;
|
|
- atmel,master-clk-have-div3-pres : some SoC use the reserved value 7 in the
|
|
PRES field as CLOCK_DIV3 (e.g sam9x5).
|
|
|
|
For example:
|
|
mck: mck {
|
|
compatible = "atmel,at91rm9200-clk-master";
|
|
interrupt-parent = <&pmc>;
|
|
interrupts = <3>;
|
|
#clock-cells = <0>;
|
|
atmel,clk-output-range = <0 133000000>;
|
|
atmel,clk-divisors = <1 2 4 0>;
|
|
};
|
|
|
|
Required properties for peripheral clocks:
|
|
- #size-cells : shall be 0 (reg is used to encode clk id).
|
|
- #address-cells : shall be 1 (reg is used to encode clk id).
|
|
- clocks : shall be the master clock phandle.
|
|
e.g. clocks = <&mck>;
|
|
- name: device tree node describing a specific system clock.
|
|
* #clock-cells : from common clock binding; shall be set to 0.
|
|
* reg: peripheral id. See Atmel's datasheets to get a full
|
|
list of peripheral ids.
|
|
* atmel,clk-output-range : minimum and maximum clock frequency
|
|
(two u32 fields). Only valid on at91sam9x5-clk-peripheral
|
|
compatible IPs.
|
|
|
|
For example:
|
|
periph: periphck {
|
|
compatible = "atmel,at91sam9x5-clk-peripheral";
|
|
#size-cells = <0>;
|
|
#address-cells = <1>;
|
|
clocks = <&mck>;
|
|
|
|
ssc0_clk {
|
|
#clock-cells = <0>;
|
|
reg = <2>;
|
|
atmel,clk-output-range = <0 133000000>;
|
|
};
|
|
|
|
usart0_clk {
|
|
#clock-cells = <0>;
|
|
reg = <3>;
|
|
atmel,clk-output-range = <0 66000000>;
|
|
};
|
|
};
|
|
|
|
|
|
Required properties for pll clocks:
|
|
- interrupt-parent : must reference the PMC node.
|
|
- interrupts : shall be set to "<1>".
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall be the main clock phandle.
|
|
- reg : pll id.
|
|
0 -> PLL A
|
|
1 -> PLL B
|
|
- atmel,clk-input-range : minimum and maximum source clock frequency (two u32
|
|
fields).
|
|
e.g. input = <1 32000000>; <=> 1 to 32MHz.
|
|
- #atmel,pll-clk-output-range-cells : number of cells reserved for pll output
|
|
range description. Sould be set to 2, 3
|
|
or 4.
|
|
* 1st and 2nd cells represent the frequency range (min-max).
|
|
* 3rd cell is optional and represents the OUT field value for the given
|
|
range.
|
|
* 4th cell is optional and represents the ICPLL field (PLLICPR
|
|
register)
|
|
- atmel,pll-clk-output-ranges : pll output frequency ranges + optional parameter
|
|
depending on #atmel,pll-output-range-cells
|
|
property value.
|
|
|
|
For example:
|
|
plla: pllack {
|
|
compatible = "atmel,at91sam9g45-clk-pll";
|
|
interrupt-parent = <&pmc>;
|
|
interrupts = <1>;
|
|
#clock-cells = <0>;
|
|
clocks = <&main>;
|
|
reg = <0>;
|
|
atmel,clk-input-range = <2000000 32000000>;
|
|
#atmel,pll-clk-output-range-cells = <4>;
|
|
atmel,pll-clk-output-ranges = <74500000 800000000 0 0
|
|
69500000 750000000 1 0
|
|
64500000 700000000 2 0
|
|
59500000 650000000 3 0
|
|
54500000 600000000 0 1
|
|
49500000 550000000 1 1
|
|
44500000 500000000 2 1
|
|
40000000 450000000 3 1>;
|
|
};
|
|
|
|
Required properties for plldiv clocks (plldiv = pll / 2):
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall be the plla clock phandle.
|
|
|
|
The pll divisor is equal to 2 and cannot be changed.
|
|
|
|
For example:
|
|
plladiv: plladivck {
|
|
compatible = "atmel,at91sam9x5-clk-plldiv";
|
|
#clock-cells = <0>;
|
|
clocks = <&plla>;
|
|
};
|
|
|
|
Required properties for programmable clocks:
|
|
- interrupt-parent : must reference the PMC node.
|
|
- #size-cells : shall be 0 (reg is used to encode clk id).
|
|
- #address-cells : shall be 1 (reg is used to encode clk id).
|
|
- clocks : shall be the programmable clock source phandles.
|
|
e.g. clocks = <&clk32k>, <&main>, <&plla>, <&pllb>;
|
|
- name: device tree node describing a specific prog clock.
|
|
* #clock-cells : from common clock binding; shall be set to 0.
|
|
* reg : programmable clock id (register offset from PCKx
|
|
register).
|
|
* interrupts : shall be set to "<(8 + id)>".
|
|
|
|
For example:
|
|
prog: progck {
|
|
compatible = "atmel,at91sam9g45-clk-programmable";
|
|
#size-cells = <0>;
|
|
#address-cells = <1>;
|
|
interrupt-parent = <&pmc>;
|
|
clocks = <&clk32k>, <&main>, <&plladiv>, <&utmi>, <&mck>;
|
|
|
|
prog0 {
|
|
#clock-cells = <0>;
|
|
reg = <0>;
|
|
interrupts = <8>;
|
|
};
|
|
|
|
prog1 {
|
|
#clock-cells = <0>;
|
|
reg = <1>;
|
|
interrupts = <9>;
|
|
};
|
|
};
|
|
|
|
|
|
Required properties for smd clock:
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall be the smd clock source phandles.
|
|
e.g. clocks = <&plladiv>, <&utmi>;
|
|
|
|
For example:
|
|
smd: smdck {
|
|
compatible = "atmel,at91sam9x5-clk-smd";
|
|
#clock-cells = <0>;
|
|
clocks = <&plladiv>, <&utmi>;
|
|
};
|
|
|
|
Required properties for system clocks:
|
|
- #size-cells : shall be 0 (reg is used to encode clk id).
|
|
- #address-cells : shall be 1 (reg is used to encode clk id).
|
|
- name: device tree node describing a specific system clock.
|
|
* #clock-cells : from common clock binding; shall be set to 0.
|
|
* reg: system clock id (bit position in SCER/SCDR/SCSR registers).
|
|
See Atmel's datasheet to get a full list of system clock ids.
|
|
|
|
For example:
|
|
system: systemck {
|
|
compatible = "atmel,at91rm9200-clk-system";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
ddrck {
|
|
#clock-cells = <0>;
|
|
reg = <2>;
|
|
clocks = <&mck>;
|
|
};
|
|
|
|
uhpck {
|
|
#clock-cells = <0>;
|
|
reg = <6>;
|
|
clocks = <&usb>;
|
|
};
|
|
|
|
udpck {
|
|
#clock-cells = <0>;
|
|
reg = <7>;
|
|
clocks = <&usb>;
|
|
};
|
|
};
|
|
|
|
|
|
Required properties for usb clock:
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall be the smd clock source phandles.
|
|
e.g. clocks = <&pllb>;
|
|
- atmel,clk-divisors (only available for "atmel,at91rm9200-clk-usb"):
|
|
usb clock divisor table.
|
|
e.g. divisors = <1 2 4 0>;
|
|
|
|
For example:
|
|
usb: usbck {
|
|
compatible = "atmel,at91sam9x5-clk-usb";
|
|
#clock-cells = <0>;
|
|
clocks = <&plladiv>, <&utmi>;
|
|
};
|
|
|
|
usb: usbck {
|
|
compatible = "atmel,at91rm9200-clk-usb";
|
|
#clock-cells = <0>;
|
|
clocks = <&pllb>;
|
|
atmel,clk-divisors = <1 2 4 0>;
|
|
};
|
|
|
|
|
|
Required properties for utmi clock:
|
|
- interrupt-parent : must reference the PMC node.
|
|
- interrupts : shall be set to "<AT91_PMC_LOCKU IRQ_TYPE_LEVEL_HIGH>".
|
|
- #clock-cells : from common clock binding; shall be set to 0.
|
|
- clocks : shall be the main clock source phandle.
|
|
|
|
For example:
|
|
utmi: utmick {
|
|
compatible = "atmel,at91sam9x5-clk-utmi";
|
|
interrupt-parent = <&pmc>;
|
|
interrupts = <AT91_PMC_LOCKU IRQ_TYPE_LEVEL_HIGH>;
|
|
#clock-cells = <0>;
|
|
clocks = <&main>;
|
|
};
|