diff options
author | John Crispin <blogic@openwrt.org> | 2012-04-17 09:53:19 -0400 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2012-05-21 09:31:51 -0400 |
commit | 287e3f3f4e68ca881e3faa413e7aa114fee609d3 (patch) | |
tree | f33d5e8b76c50306eee6540570b39d5bcd92210f /arch/mips/include/asm/mach-lantiq | |
parent | bd51db7f3bf2ba23ff55f6d5fdcec04c74df13e4 (diff) |
MIPS: lantiq: implement support for clkdev api
This patch unifies all clock generation and gating code into one file.
All drivers will now be able to request their clocks via their device.
This patch also adds support for the clockout feature, which allows
clock generation on external pins.
Support for COMMON_CLK will be provided in the next series.
Signed-off-by: John Crispin <blogic@openwrt.org>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/3804/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips/include/asm/mach-lantiq')
-rw-r--r-- | arch/mips/include/asm/mach-lantiq/lantiq.h | 27 | ||||
-rw-r--r-- | arch/mips/include/asm/mach-lantiq/xway/lantiq_soc.h | 5 |
2 files changed, 17 insertions, 15 deletions
diff --git a/arch/mips/include/asm/mach-lantiq/lantiq.h b/arch/mips/include/asm/mach-lantiq/lantiq.h index 7a90190bc387..6775d2402cd0 100644 --- a/arch/mips/include/asm/mach-lantiq/lantiq.h +++ b/arch/mips/include/asm/mach-lantiq/lantiq.h | |||
@@ -9,6 +9,8 @@ | |||
9 | #define _LANTIQ_H__ | 9 | #define _LANTIQ_H__ |
10 | 10 | ||
11 | #include <linux/irq.h> | 11 | #include <linux/irq.h> |
12 | #include <linux/device.h> | ||
13 | #include <linux/clk.h> | ||
12 | 14 | ||
13 | /* generic reg access functions */ | 15 | /* generic reg access functions */ |
14 | #define ltq_r32(reg) __raw_readl(reg) | 16 | #define ltq_r32(reg) __raw_readl(reg) |
@@ -21,26 +23,13 @@ | |||
21 | /* register access macros for EBU and CGU */ | 23 | /* register access macros for EBU and CGU */ |
22 | #define ltq_ebu_w32(x, y) ltq_w32((x), ltq_ebu_membase + (y)) | 24 | #define ltq_ebu_w32(x, y) ltq_w32((x), ltq_ebu_membase + (y)) |
23 | #define ltq_ebu_r32(x) ltq_r32(ltq_ebu_membase + (x)) | 25 | #define ltq_ebu_r32(x) ltq_r32(ltq_ebu_membase + (x)) |
24 | #define ltq_cgu_w32(x, y) ltq_w32((x), ltq_cgu_membase + (y)) | 26 | #define ltq_ebu_w32_mask(x, y, z) \ |
25 | #define ltq_cgu_r32(x) ltq_r32(ltq_cgu_membase + (x)) | 27 | ltq_w32_mask(x, y, ltq_ebu_membase + (z)) |
26 | |||
27 | extern __iomem void *ltq_ebu_membase; | 28 | extern __iomem void *ltq_ebu_membase; |
28 | extern __iomem void *ltq_cgu_membase; | ||
29 | 29 | ||
30 | extern unsigned int ltq_get_cpu_ver(void); | 30 | extern unsigned int ltq_get_cpu_ver(void); |
31 | extern unsigned int ltq_get_soc_type(void); | 31 | extern unsigned int ltq_get_soc_type(void); |
32 | 32 | ||
33 | /* clock speeds */ | ||
34 | #define CLOCK_60M 60000000 | ||
35 | #define CLOCK_83M 83333333 | ||
36 | #define CLOCK_111M 111111111 | ||
37 | #define CLOCK_133M 133333333 | ||
38 | #define CLOCK_167M 166666667 | ||
39 | #define CLOCK_200M 200000000 | ||
40 | #define CLOCK_266M 266666666 | ||
41 | #define CLOCK_333M 333333333 | ||
42 | #define CLOCK_400M 400000000 | ||
43 | |||
44 | /* spinlock all ebu i/o */ | 33 | /* spinlock all ebu i/o */ |
45 | extern spinlock_t ebu_lock; | 34 | extern spinlock_t ebu_lock; |
46 | 35 | ||
@@ -48,6 +37,14 @@ extern spinlock_t ebu_lock; | |||
48 | extern void ltq_disable_irq(struct irq_data *data); | 37 | extern void ltq_disable_irq(struct irq_data *data); |
49 | extern void ltq_mask_and_ack_irq(struct irq_data *data); | 38 | extern void ltq_mask_and_ack_irq(struct irq_data *data); |
50 | extern void ltq_enable_irq(struct irq_data *data); | 39 | extern void ltq_enable_irq(struct irq_data *data); |
40 | |||
41 | /* clock handling */ | ||
42 | extern int clk_activate(struct clk *clk); | ||
43 | extern void clk_deactivate(struct clk *clk); | ||
44 | extern struct clk *clk_get_cpu(void); | ||
45 | extern struct clk *clk_get_fpi(void); | ||
46 | extern struct clk *clk_get_io(void); | ||
47 | |||
51 | /* find out what bootsource we have */ | 48 | /* find out what bootsource we have */ |
52 | extern unsigned char ltq_boot_select(void); | 49 | extern unsigned char ltq_boot_select(void); |
53 | /* find out what caused the last cpu reset */ | 50 | /* find out what caused the last cpu reset */ |
diff --git a/arch/mips/include/asm/mach-lantiq/xway/lantiq_soc.h b/arch/mips/include/asm/mach-lantiq/xway/lantiq_soc.h index 150c7bef5a14..b5a2acf9156f 100644 --- a/arch/mips/include/asm/mach-lantiq/xway/lantiq_soc.h +++ b/arch/mips/include/asm/mach-lantiq/xway/lantiq_soc.h | |||
@@ -59,6 +59,11 @@ | |||
59 | #define BS_NAND 0x6 | 59 | #define BS_NAND 0x6 |
60 | #define BS_RMII0 0x7 | 60 | #define BS_RMII0 0x7 |
61 | 61 | ||
62 | /* helpers used to access the cgu */ | ||
63 | #define ltq_cgu_w32(x, y) ltq_w32((x), ltq_cgu_membase + (y)) | ||
64 | #define ltq_cgu_r32(x) ltq_r32(ltq_cgu_membase + (x)) | ||
65 | extern __iomem void *ltq_cgu_membase; | ||
66 | |||
62 | /* | 67 | /* |
63 | * during early_printk no ioremap is possible | 68 | * during early_printk no ioremap is possible |
64 | * lets use KSEG1 instead | 69 | * lets use KSEG1 instead |