mirror of
https://github.com/FEX-Emu/linux.git
synced 2024-12-23 01:40:30 +00:00
ARM: nomadik: convert all clocks except timer to dt
This moves all Nomadik clocks except the one used for the timer/clocksource over to the device tree. Acked-by: Mike Turquette <mturquette@linaro.org> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
This commit is contained in:
parent
c7785ea0d2
commit
6e2b07a172
@ -3,6 +3,11 @@ ST-Ericsson Nomadik Device Tree Bindings
|
|||||||
For various board the "board" node may contain specific properties
|
For various board the "board" node may contain specific properties
|
||||||
that pertain to this particular board, such as board-specific GPIOs.
|
that pertain to this particular board, such as board-specific GPIOs.
|
||||||
|
|
||||||
|
Required root node property: src
|
||||||
|
- Nomadik System and reset controller used for basic chip control, clock
|
||||||
|
and reset line control.
|
||||||
|
- compatible: must be "stericsson,nomadik,src"
|
||||||
|
|
||||||
Boards with the Nomadik SoC include:
|
Boards with the Nomadik SoC include:
|
||||||
|
|
||||||
S8815 "MiniKit" manufactured by Calao Systems:
|
S8815 "MiniKit" manufactured by Calao Systems:
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
gpio-controller;
|
gpio-controller;
|
||||||
#gpio-cells = <2>;
|
#gpio-cells = <2>;
|
||||||
gpio-bank = <0>;
|
gpio-bank = <0>;
|
||||||
|
clocks = <&pclk>;
|
||||||
};
|
};
|
||||||
|
|
||||||
gpio1: gpio@101e5000 {
|
gpio1: gpio@101e5000 {
|
||||||
@ -57,6 +58,7 @@
|
|||||||
gpio-controller;
|
gpio-controller;
|
||||||
#gpio-cells = <2>;
|
#gpio-cells = <2>;
|
||||||
gpio-bank = <1>;
|
gpio-bank = <1>;
|
||||||
|
clocks = <&pclk>;
|
||||||
};
|
};
|
||||||
|
|
||||||
gpio2: gpio@101e6000 {
|
gpio2: gpio@101e6000 {
|
||||||
@ -69,6 +71,7 @@
|
|||||||
gpio-controller;
|
gpio-controller;
|
||||||
#gpio-cells = <2>;
|
#gpio-cells = <2>;
|
||||||
gpio-bank = <2>;
|
gpio-bank = <2>;
|
||||||
|
clocks = <&pclk>;
|
||||||
};
|
};
|
||||||
|
|
||||||
gpio3: gpio@101e7000 {
|
gpio3: gpio@101e7000 {
|
||||||
@ -81,12 +84,50 @@
|
|||||||
gpio-controller;
|
gpio-controller;
|
||||||
#gpio-cells = <2>;
|
#gpio-cells = <2>;
|
||||||
gpio-bank = <3>;
|
gpio-bank = <3>;
|
||||||
|
clocks = <&pclk>;
|
||||||
};
|
};
|
||||||
|
|
||||||
pinctrl {
|
pinctrl {
|
||||||
compatible = "stericsson,nmk-pinctrl-stn8815";
|
compatible = "stericsson,nmk-pinctrl-stn8815";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
src: src@101e0000 {
|
||||||
|
compatible = "stericsson,nomadik-src";
|
||||||
|
reg = <0x101e0000 0x1000>;
|
||||||
|
clocks {
|
||||||
|
/*
|
||||||
|
* Dummy clock for primecells
|
||||||
|
*/
|
||||||
|
pclk: pclk@0 {
|
||||||
|
#clock-cells = <0>;
|
||||||
|
compatible = "fixed-clock";
|
||||||
|
clock-frequency = <2400000>;
|
||||||
|
};
|
||||||
|
/*
|
||||||
|
* The 2.4 MHz TIMCLK reference clock is active at
|
||||||
|
* boot time, this is actually the MXTALCLK @19.2 MHz
|
||||||
|
* divided by 8. This clock is used by the timers and
|
||||||
|
* watchdog. See page 105 ff.
|
||||||
|
*/
|
||||||
|
timclk: timclk@2.4M {
|
||||||
|
#clock-cells = <0>;
|
||||||
|
compatible = "fixed-clock";
|
||||||
|
clock-frequency = <2400000>;
|
||||||
|
};
|
||||||
|
/*
|
||||||
|
* At boot time, PLL2 is set to generate a set of
|
||||||
|
* fixed clocks, one of them is CLK48, the 48 MHz
|
||||||
|
* clock, routed to the UART, MMC/SD, I2C, IrDA,
|
||||||
|
* USB and SSP blocks.
|
||||||
|
*/
|
||||||
|
clk48: clk48@48M {
|
||||||
|
#clock-cells = <0>;
|
||||||
|
compatible = "fixed-clock";
|
||||||
|
clock-frequency = <48000000>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
/* A NAND flash of 128 MiB */
|
/* A NAND flash of 128 MiB */
|
||||||
fsmc: flash@40000000 {
|
fsmc: flash@40000000 {
|
||||||
compatible = "stericsson,fsmc-nand";
|
compatible = "stericsson,fsmc-nand";
|
||||||
@ -97,6 +138,7 @@
|
|||||||
<0x41000000 0x2000>, /* NAND Base ADDR */
|
<0x41000000 0x2000>, /* NAND Base ADDR */
|
||||||
<0x40800000 0x2000>; /* NAND Base CMD */
|
<0x40800000 0x2000>; /* NAND Base CMD */
|
||||||
reg-names = "fsmc_regs", "nand_data", "nand_addr", "nand_cmd";
|
reg-names = "fsmc_regs", "nand_data", "nand_addr", "nand_cmd";
|
||||||
|
clocks = <&pclk>;
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
|
||||||
partition@0 {
|
partition@0 {
|
||||||
@ -211,6 +253,8 @@
|
|||||||
reg = <0x101fd000 0x1000>;
|
reg = <0x101fd000 0x1000>;
|
||||||
interrupt-parent = <&vica>;
|
interrupt-parent = <&vica>;
|
||||||
interrupts = <12>;
|
interrupts = <12>;
|
||||||
|
clocks = <&clk48>, <&pclk>;
|
||||||
|
clock-names = "uartclk", "apb_pclk";
|
||||||
};
|
};
|
||||||
|
|
||||||
uart1: uart@101fb000 {
|
uart1: uart@101fb000 {
|
||||||
@ -218,6 +262,8 @@
|
|||||||
reg = <0x101fb000 0x1000>;
|
reg = <0x101fb000 0x1000>;
|
||||||
interrupt-parent = <&vica>;
|
interrupt-parent = <&vica>;
|
||||||
interrupts = <17>;
|
interrupts = <17>;
|
||||||
|
clocks = <&clk48>, <&pclk>;
|
||||||
|
clock-names = "uartclk", "apb_pclk";
|
||||||
};
|
};
|
||||||
|
|
||||||
uart2: uart@101f2000 {
|
uart2: uart@101f2000 {
|
||||||
@ -225,17 +271,23 @@
|
|||||||
reg = <0x101f2000 0x1000>;
|
reg = <0x101f2000 0x1000>;
|
||||||
interrupt-parent = <&vica>;
|
interrupt-parent = <&vica>;
|
||||||
interrupts = <28>;
|
interrupts = <28>;
|
||||||
|
clocks = <&clk48>, <&pclk>;
|
||||||
|
clock-names = "uartclk", "apb_pclk";
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
};
|
};
|
||||||
|
|
||||||
rng: rng@101b0000 {
|
rng: rng@101b0000 {
|
||||||
compatible = "arm,primecell";
|
compatible = "arm,primecell";
|
||||||
reg = <0x101b0000 0x1000>;
|
reg = <0x101b0000 0x1000>;
|
||||||
|
clocks = <&clk48>, <&pclk>;
|
||||||
|
clock-names = "rng", "apb_pclk";
|
||||||
};
|
};
|
||||||
|
|
||||||
rtc: rtc@101e8000 {
|
rtc: rtc@101e8000 {
|
||||||
compatible = "arm,pl031", "arm,primecell";
|
compatible = "arm,pl031", "arm,primecell";
|
||||||
reg = <0x101e8000 0x1000>;
|
reg = <0x101e8000 0x1000>;
|
||||||
|
clocks = <&pclk>;
|
||||||
|
clock-names = "apb_pclk";
|
||||||
interrupt-parent = <&vica>;
|
interrupt-parent = <&vica>;
|
||||||
interrupts = <10>;
|
interrupts = <10>;
|
||||||
};
|
};
|
||||||
@ -243,6 +295,8 @@
|
|||||||
mmcsd: sdi@101f6000 {
|
mmcsd: sdi@101f6000 {
|
||||||
compatible = "arm,pl18x", "arm,primecell";
|
compatible = "arm,pl18x", "arm,primecell";
|
||||||
reg = <0x101f6000 0x1000>;
|
reg = <0x101f6000 0x1000>;
|
||||||
|
clocks = <&clk48>, <&pclk>;
|
||||||
|
clock-names = "mclk", "apb_pclk";
|
||||||
interrupt-parent = <&vica>;
|
interrupt-parent = <&vica>;
|
||||||
interrupts = <22>;
|
interrupts = <22>;
|
||||||
max-frequency = <48000000>;
|
max-frequency = <48000000>;
|
||||||
|
@ -280,28 +280,12 @@ device_initcall(cpu8815_mmcsd_init);
|
|||||||
|
|
||||||
/* These are mostly to get the right device names for the clock lookups */
|
/* These are mostly to get the right device names for the clock lookups */
|
||||||
static struct of_dev_auxdata cpu8815_auxdata_lookup[] __initdata = {
|
static struct of_dev_auxdata cpu8815_auxdata_lookup[] __initdata = {
|
||||||
OF_DEV_AUXDATA("st,nomadik-gpio", NOMADIK_GPIO0_BASE,
|
|
||||||
"gpio.0", NULL),
|
|
||||||
OF_DEV_AUXDATA("st,nomadik-gpio", NOMADIK_GPIO1_BASE,
|
|
||||||
"gpio.1", NULL),
|
|
||||||
OF_DEV_AUXDATA("st,nomadik-gpio", NOMADIK_GPIO2_BASE,
|
|
||||||
"gpio.2", NULL),
|
|
||||||
OF_DEV_AUXDATA("st,nomadik-gpio", NOMADIK_GPIO3_BASE,
|
|
||||||
"gpio.3", NULL),
|
|
||||||
OF_DEV_AUXDATA("stericsson,nmk-pinctrl-stn8815", 0,
|
OF_DEV_AUXDATA("stericsson,nmk-pinctrl-stn8815", 0,
|
||||||
"pinctrl-stn8815", NULL),
|
"pinctrl-stn8815", NULL),
|
||||||
OF_DEV_AUXDATA("arm,primecell", NOMADIK_UART0_BASE,
|
|
||||||
"uart0", NULL),
|
|
||||||
OF_DEV_AUXDATA("arm,primecell", NOMADIK_UART1_BASE,
|
|
||||||
"uart1", NULL),
|
|
||||||
OF_DEV_AUXDATA("arm,primecell", NOMADIK_RNG_BASE,
|
|
||||||
"rng", NULL),
|
|
||||||
OF_DEV_AUXDATA("arm,primecell", NOMADIK_RTC_BASE,
|
|
||||||
"rtc-pl031", NULL),
|
|
||||||
OF_DEV_AUXDATA("stericsson,fsmc-nand", NOMADIK_FSMC_BASE,
|
OF_DEV_AUXDATA("stericsson,fsmc-nand", NOMADIK_FSMC_BASE,
|
||||||
"fsmc-nand", &cpu8815_nand_data),
|
NULL, &cpu8815_nand_data),
|
||||||
OF_DEV_AUXDATA("arm,primecell", NOMADIK_SDI_BASE,
|
OF_DEV_AUXDATA("arm,primecell", NOMADIK_SDI_BASE,
|
||||||
"mmci", &mmcsd_plat_data),
|
NULL, &mmcsd_plat_data),
|
||||||
{ /* sentinel */ },
|
{ /* sentinel */ },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -3,24 +3,24 @@
|
|||||||
#include <linux/err.h>
|
#include <linux/err.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
#include <linux/clk-provider.h>
|
#include <linux/clk-provider.h>
|
||||||
|
#include <linux/of.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The Nomadik clock tree is described in the STN8815A12 DB V4.2
|
* The Nomadik clock tree is described in the STN8815A12 DB V4.2
|
||||||
* reference manual for the chip, page 94 ff.
|
* reference manual for the chip, page 94 ff.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
static const __initconst struct of_device_id cpu8815_clk_match[] = {
|
||||||
|
{ .compatible = "fixed-clock", .data = of_fixed_clk_setup, },
|
||||||
|
{ /* sentinel */ }
|
||||||
|
};
|
||||||
|
|
||||||
void __init nomadik_clk_init(void)
|
void __init nomadik_clk_init(void)
|
||||||
{
|
{
|
||||||
struct clk *clk;
|
struct clk *clk;
|
||||||
|
|
||||||
clk = clk_register_fixed_rate(NULL, "apb_pclk", NULL, CLK_IS_ROOT, 0);
|
clk = clk_register_fixed_rate(NULL, "apb_pclk", NULL, CLK_IS_ROOT, 0);
|
||||||
clk_register_clkdev(clk, "apb_pclk", NULL);
|
clk_register_clkdev(clk, "apb_pclk", NULL);
|
||||||
clk_register_clkdev(clk, NULL, "gpio.0");
|
|
||||||
clk_register_clkdev(clk, NULL, "gpio.1");
|
|
||||||
clk_register_clkdev(clk, NULL, "gpio.2");
|
|
||||||
clk_register_clkdev(clk, NULL, "gpio.3");
|
|
||||||
clk_register_clkdev(clk, NULL, "rng");
|
|
||||||
clk_register_clkdev(clk, NULL, "fsmc-nand");
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The 2.4 MHz TIMCLK reference clock is active at boot time, this is
|
* The 2.4 MHz TIMCLK reference clock is active at boot time, this is
|
||||||
@ -32,17 +32,5 @@ void __init nomadik_clk_init(void)
|
|||||||
clk_register_clkdev(clk, NULL, "mtu0");
|
clk_register_clkdev(clk, NULL, "mtu0");
|
||||||
clk_register_clkdev(clk, NULL, "mtu1");
|
clk_register_clkdev(clk, NULL, "mtu1");
|
||||||
|
|
||||||
/*
|
of_clk_init(cpu8815_clk_match);
|
||||||
* At boot time, PLL2 is set to generate a set of fixed clocks,
|
|
||||||
* one of them is CLK48, the 48 MHz clock, routed to the UART, MMC/SD
|
|
||||||
* I2C, IrDA, USB and SSP blocks.
|
|
||||||
*/
|
|
||||||
clk = clk_register_fixed_rate(NULL, "CLK48", NULL, CLK_IS_ROOT,
|
|
||||||
48000000);
|
|
||||||
clk_register_clkdev(clk, NULL, "uart0");
|
|
||||||
clk_register_clkdev(clk, NULL, "uart1");
|
|
||||||
clk_register_clkdev(clk, NULL, "mmci");
|
|
||||||
clk_register_clkdev(clk, NULL, "ssp");
|
|
||||||
clk_register_clkdev(clk, NULL, "nmk-i2c.0");
|
|
||||||
clk_register_clkdev(clk, NULL, "nmk-i2c.1");
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user