📄 clock.h
字号:
/* * linux/arch/arm/mach-omap1/clock.h * * Copyright (C) 2004 - 2005 Nokia corporation * Written by Tuukka Tikkanen <tuukka.tikkanen@elektrobit.com> * Based on clocks.h by Tony Lindgren, Gordon McNutt and RidgeRun, Inc * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */#ifndef __ARCH_ARM_MACH_OMAP1_CLOCK_H#define __ARCH_ARM_MACH_OMAP1_CLOCK_Hstatic int omap1_clk_enable_generic(struct clk * clk);static void omap1_clk_disable_generic(struct clk * clk);static void omap1_ckctl_recalc(struct clk * clk);static void omap1_watchdog_recalc(struct clk * clk);static void omap1_ckctl_recalc_dsp_domain(struct clk * clk);static int omap1_clk_enable_dsp_domain(struct clk * clk);static int omap1_clk_set_rate_dsp_domain(struct clk * clk, unsigned long rate);static void omap1_clk_disable_dsp_domain(struct clk * clk);static int omap1_set_uart_rate(struct clk * clk, unsigned long rate);static void omap1_uart_recalc(struct clk * clk);static int omap1_clk_enable_uart_functional(struct clk * clk);static void omap1_clk_disable_uart_functional(struct clk * clk);static int omap1_set_ext_clk_rate(struct clk * clk, unsigned long rate);static long omap1_round_ext_clk_rate(struct clk * clk, unsigned long rate);static void omap1_init_ext_clk(struct clk * clk);static int omap1_select_table_rate(struct clk * clk, unsigned long rate);static long omap1_round_to_table_rate(struct clk * clk, unsigned long rate);static int omap1_clk_enable(struct clk *clk);static void omap1_clk_disable(struct clk *clk);struct mpu_rate { unsigned long rate; unsigned long xtal; unsigned long pll_rate; __u16 ckctl_val; __u16 dpllctl_val;};struct uart_clk { struct clk clk; unsigned long sysc_addr;};/* Provide a method for preventing idling some ARM IDLECT clocks */struct arm_idlect1_clk { struct clk clk; unsigned long no_idle_count; __u8 idlect_shift;};/* ARM_CKCTL bit shifts */#define CKCTL_PERDIV_OFFSET 0#define CKCTL_LCDDIV_OFFSET 2#define CKCTL_ARMDIV_OFFSET 4#define CKCTL_DSPDIV_OFFSET 6#define CKCTL_TCDIV_OFFSET 8#define CKCTL_DSPMMUDIV_OFFSET 10/*#define ARM_TIMXO 12*/#define EN_DSPCK 13/*#define ARM_INTHCK_SEL 14*/ /* Divide-by-2 for mpu inth_ck *//* DSP_CKCTL bit shifts */#define CKCTL_DSPPERDIV_OFFSET 0/* ARM_IDLECT2 bit shifts */#define EN_WDTCK 0#define EN_XORPCK 1#define EN_PERCK 2#define EN_LCDCK 3#define EN_LBCK 4 /* Not on 1610/1710 *//*#define EN_HSABCK 5*/#define EN_APICK 6#define EN_TIMCK 7#define DMACK_REQ 8#define EN_GPIOCK 9 /* Not on 1610/1710 *//*#define EN_LBFREECK 10*/#define EN_CKOUT_ARM 11/* ARM_IDLECT3 bit shifts */#define EN_OCPI_CK 0#define EN_TC1_CK 2#define EN_TC2_CK 4/* DSP_IDLECT2 bit shifts (0,1,2 are same as for ARM_IDLECT2) */#define EN_DSPTIMCK 5/* Various register defines for clock controls scattered around OMAP chip */#define USB_MCLK_EN_BIT 4 /* In ULPD_CLKC_CTRL */#define USB_HOST_HHC_UHOST_EN 9 /* In MOD_CONF_CTRL_0 */#define SWD_ULPD_PLL_CLK_REQ 1 /* In SWD_CLK_DIV_CTRL_SEL */#define COM_ULPD_PLL_CLK_REQ 1 /* In COM_CLK_DIV_CTRL_SEL */#define SWD_CLK_DIV_CTRL_SEL 0xfffe0874#define COM_CLK_DIV_CTRL_SEL 0xfffe0878#define SOFT_REQ_REG 0xfffe0834#define SOFT_REQ_REG2 0xfffe0880/*------------------------------------------------------------------------- * Omap1 MPU rate table *-------------------------------------------------------------------------*/static struct mpu_rate rate_table[] = { /* MPU MHz, xtal MHz, dpll1 MHz, CKCTL, DPLL_CTL * NOTE: Comment order here is different from bits in CKCTL value: * armdiv, dspdiv, dspmmu, tcdiv, perdiv, lcddiv */#if defined(CONFIG_OMAP_ARM_216MHZ) { 216000000, 12000000, 216000000, 0x050d, 0x2910 }, /* 1/1/2/2/2/8 */#endif#if defined(CONFIG_OMAP_ARM_195MHZ) { 195000000, 13000000, 195000000, 0x050e, 0x2790 }, /* 1/1/2/2/4/8 */#endif#if defined(CONFIG_OMAP_ARM_192MHZ) { 192000000, 19200000, 192000000, 0x050f, 0x2510 }, /* 1/1/2/2/8/8 */ { 192000000, 12000000, 192000000, 0x050f, 0x2810 }, /* 1/1/2/2/8/8 */ { 96000000, 12000000, 192000000, 0x055f, 0x2810 }, /* 2/2/2/2/8/8 */ { 48000000, 12000000, 192000000, 0x0baf, 0x2810 }, /* 4/4/4/8/8/8 */ { 24000000, 12000000, 192000000, 0x0fff, 0x2810 }, /* 8/8/8/8/8/8 */#endif#if defined(CONFIG_OMAP_ARM_182MHZ) { 182000000, 13000000, 182000000, 0x050e, 0x2710 }, /* 1/1/2/2/4/8 */#endif#if defined(CONFIG_OMAP_ARM_168MHZ) { 168000000, 12000000, 168000000, 0x010f, 0x2710 }, /* 1/1/1/2/8/8 */#endif#if defined(CONFIG_OMAP_ARM_150MHZ) { 150000000, 12000000, 150000000, 0x010a, 0x2cb0 }, /* 1/1/1/2/4/4 */#endif#if defined(CONFIG_OMAP_ARM_120MHZ) { 120000000, 12000000, 120000000, 0x010a, 0x2510 }, /* 1/1/1/2/4/4 */#endif#if defined(CONFIG_OMAP_ARM_96MHZ) { 96000000, 12000000, 96000000, 0x0005, 0x2410 }, /* 1/1/1/1/2/2 */#endif#if defined(CONFIG_OMAP_ARM_60MHZ) { 60000000, 12000000, 60000000, 0x0005, 0x2290 }, /* 1/1/1/1/2/2 */#endif#if defined(CONFIG_OMAP_ARM_30MHZ) { 30000000, 12000000, 60000000, 0x0555, 0x2290 }, /* 2/2/2/2/2/2 */#endif { 0, 0, 0, 0, 0 },};/*------------------------------------------------------------------------- * Omap1 clocks *-------------------------------------------------------------------------*/static struct clk ck_ref = { .name = "ck_ref", .rate = 12000000, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | ALWAYS_ENABLED, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic,};static struct clk ck_dpll1 = { .name = "ck_dpll1", .parent = &ck_ref, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | RATE_PROPAGATES | ALWAYS_ENABLED, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic,};static struct arm_idlect1_clk ck_dpll1out = { .clk = { .name = "ck_dpll1out", .parent = &ck_dpll1, .flags = CLOCK_IN_OMAP16XX | CLOCK_IDLE_CONTROL, .enable_reg = (void __iomem *)ARM_IDLECT2, .enable_bit = EN_CKOUT_ARM, .recalc = &followparent_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic, }, .idlect_shift = 12,};static struct clk arm_ck = { .name = "arm_ck", .parent = &ck_dpll1, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | RATE_CKCTL | RATE_PROPAGATES | ALWAYS_ENABLED, .rate_offset = CKCTL_ARMDIV_OFFSET, .recalc = &omap1_ckctl_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic,};static struct arm_idlect1_clk armper_ck = { .clk = { .name = "armper_ck", .parent = &ck_dpll1, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | RATE_CKCTL | CLOCK_IDLE_CONTROL, .enable_reg = (void __iomem *)ARM_IDLECT2, .enable_bit = EN_PERCK, .rate_offset = CKCTL_PERDIV_OFFSET, .recalc = &omap1_ckctl_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic, }, .idlect_shift = 2,};static struct clk arm_gpio_ck = { .name = "arm_gpio_ck", .parent = &ck_dpll1, .flags = CLOCK_IN_OMAP1510, .enable_reg = (void __iomem *)ARM_IDLECT2, .enable_bit = EN_GPIOCK, .recalc = &followparent_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic,};static struct arm_idlect1_clk armxor_ck = { .clk = { .name = "armxor_ck", .parent = &ck_ref, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | CLOCK_IDLE_CONTROL, .enable_reg = (void __iomem *)ARM_IDLECT2, .enable_bit = EN_XORPCK, .recalc = &followparent_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic, }, .idlect_shift = 1,};static struct arm_idlect1_clk armtim_ck = { .clk = { .name = "armtim_ck", .parent = &ck_ref, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | CLOCK_IDLE_CONTROL, .enable_reg = (void __iomem *)ARM_IDLECT2, .enable_bit = EN_TIMCK, .recalc = &followparent_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic, }, .idlect_shift = 9,};static struct arm_idlect1_clk armwdt_ck = { .clk = { .name = "armwdt_ck", .parent = &ck_ref, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | CLOCK_IDLE_CONTROL, .enable_reg = (void __iomem *)ARM_IDLECT2, .enable_bit = EN_WDTCK, .recalc = &omap1_watchdog_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic, }, .idlect_shift = 0,};static struct clk arminth_ck16xx = { .name = "arminth_ck", .parent = &arm_ck, .flags = CLOCK_IN_OMAP16XX | ALWAYS_ENABLED, .recalc = &followparent_recalc, /* Note: On 16xx the frequency can be divided by 2 by programming * ARM_CKCTL:ARM_INTHCK_SEL(14) to 1 * * 1510 version is in TC clocks. */ .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic,};static struct clk dsp_ck = { .name = "dsp_ck", .parent = &ck_dpll1, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | RATE_CKCTL, .enable_reg = (void __iomem *)ARM_CKCTL, .enable_bit = EN_DSPCK, .rate_offset = CKCTL_DSPDIV_OFFSET, .recalc = &omap1_ckctl_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic,};static struct clk dspmmu_ck = { .name = "dspmmu_ck", .parent = &ck_dpll1, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | RATE_CKCTL | ALWAYS_ENABLED, .rate_offset = CKCTL_DSPMMUDIV_OFFSET, .recalc = &omap1_ckctl_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic,};static struct clk dspper_ck = { .name = "dspper_ck", .parent = &ck_dpll1, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | RATE_CKCTL | VIRTUAL_IO_ADDRESS, .enable_reg = (void __iomem *)DSP_IDLECT2, .enable_bit = EN_PERCK, .rate_offset = CKCTL_PERDIV_OFFSET, .recalc = &omap1_ckctl_recalc_dsp_domain, .set_rate = &omap1_clk_set_rate_dsp_domain, .enable = &omap1_clk_enable_dsp_domain, .disable = &omap1_clk_disable_dsp_domain,};static struct clk dspxor_ck = { .name = "dspxor_ck", .parent = &ck_ref, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | VIRTUAL_IO_ADDRESS, .enable_reg = (void __iomem *)DSP_IDLECT2, .enable_bit = EN_XORPCK, .recalc = &followparent_recalc, .enable = &omap1_clk_enable_dsp_domain, .disable = &omap1_clk_disable_dsp_domain,};static struct clk dsptim_ck = { .name = "dsptim_ck", .parent = &ck_ref, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | VIRTUAL_IO_ADDRESS, .enable_reg = (void __iomem *)DSP_IDLECT2, .enable_bit = EN_DSPTIMCK, .recalc = &followparent_recalc, .enable = &omap1_clk_enable_dsp_domain, .disable = &omap1_clk_disable_dsp_domain,};/* Tie ARM_IDLECT1:IDLIF_ARM to this logical clock structure */static struct arm_idlect1_clk tc_ck = { .clk = { .name = "tc_ck", .parent = &ck_dpll1, .flags = CLOCK_IN_OMAP1510 | CLOCK_IN_OMAP16XX | CLOCK_IN_OMAP730 | RATE_CKCTL | RATE_PROPAGATES | ALWAYS_ENABLED | CLOCK_IDLE_CONTROL, .rate_offset = CKCTL_TCDIV_OFFSET, .recalc = &omap1_ckctl_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic, }, .idlect_shift = 6,};static struct clk arminth_ck1510 = { .name = "arminth_ck", .parent = &tc_ck.clk, .flags = CLOCK_IN_OMAP1510 | ALWAYS_ENABLED, .recalc = &followparent_recalc, /* Note: On 1510 the frequency follows TC_CK * * 16xx version is in MPU clocks. */ .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic,};static struct clk tipb_ck = { /* No-idle controlled by "tc_ck" */ .name = "tibp_ck", .parent = &tc_ck.clk, .flags = CLOCK_IN_OMAP1510 | ALWAYS_ENABLED, .recalc = &followparent_recalc, .enable = &omap1_clk_enable_generic, .disable = &omap1_clk_disable_generic,};static struct clk l3_ocpi_ck = { /* No-idle controlled by "tc_ck" */ .name = "l3_ocpi_ck", .parent = &tc_ck.clk, .flags = CLOCK_IN_OMAP16XX,
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -