2009-12-08 16:21:29 -07:00
/*
2010-01-08 15:23:15 -07:00
* opp2430_data . c - old - style " OPP " table for OMAP2430
2009-12-08 16:21:29 -07:00
*
* Copyright ( C ) 2005 - 2009 Texas Instruments , Inc .
* Copyright ( C ) 2004 - 2009 Nokia Corporation
*
* Richard Woodruff < r - woodruff2 @ ti . com >
*
* The OMAP2 processor can be run at several discrete ' PRCM configurations ' .
* These configurations are characterized by voltage and speed for clocks .
* The device is only validated for certain combinations . One way to express
2010-01-08 15:23:15 -07:00
* these combinations is via the ' ratios ' which the clocks operate with
2009-12-08 16:21:29 -07:00
* respect to each other . These ratio sets are for a given voltage / DPLL
2010-01-08 15:23:15 -07:00
* setting . All configurations can be described by a DPLL setting and a ratio .
2009-12-08 16:21:29 -07:00
*
* 2430 differs from 2420 in that there are no more phase synchronizers used .
* They both have a slightly different clock domain setup . 2420 ( iva1 , dsp ) vs
* 2430 ( iva2 .1 , NOdsp , mdm )
*
* XXX Missing voltage data .
2010-01-08 15:23:15 -07:00
* XXX Missing 19.2 MHz sys_clk rate sets .
2009-12-08 16:21:29 -07:00
*
* THe format described in this file is deprecated . Once a reasonable
* OPP API exists , the data in this file should be converted to use it .
*
* This is technically part of the OMAP2xxx clock code .
*/
2012-08-31 10:59:07 -07:00
# include <linux/kernel.h>
2012-02-24 10:34:35 -08:00
2009-12-08 16:21:29 -07:00
# include "opp2xxx.h"
# include "sdrc.h"
# include "clock.h"
2010-01-08 15:23:15 -07:00
/*
* Key dividers which make up a PRCM set . Ratios for a PRCM are mandated .
2009-12-08 16:21:29 -07:00
* xtal_speed , dpll_speed , mpu_speed , CM_CLKSEL_MPU ,
* CM_CLKSEL_DSP , CM_CLKSEL_GFX , CM_CLKSEL1_CORE , CM_CLKSEL1_PLL ,
* CM_CLKSEL2_PLL , CM_CLKSEL_MDM
*
2010-01-08 15:23:15 -07:00
* Filling in table based on 2430 - SDPs variants available . There are
* quite a few more rate combinations which could be defined .
2009-12-08 16:21:29 -07:00
*
2010-01-08 15:23:15 -07:00
* When multiple values are defined the start up will try and choose
* the fastest one . If a ' fast ' value is defined , then automatically ,
* the / 2 one should be included as it can be used . Generally having
* more than one fast set does not make sense , as static timings need
* to be changed to change the set . The exception is the bypass
* setting which is available for low power bypass .
2009-12-08 16:21:29 -07:00
*
* Note : This table needs to be sorted , fastest to slowest .
2010-01-08 15:23:15 -07:00
*/
2009-12-08 16:21:29 -07:00
const struct prcm_config omap2430_rate_table [ ] = {
/* PRCM #4 - ratio2 (ES2.1) - FAST */
{ S13M , S798M , S399M , R2_CM_CLKSEL_MPU_VAL , /* 399MHz ARM */
R2_CM_CLKSEL_DSP_VAL , R2_CM_CLKSEL_GFX_VAL ,
R2_CM_CLKSEL1_CORE_VAL , M4_CM_CLKSEL1_PLL_13_VAL ,
MX_CLKSEL2_PLL_2x_VAL , R2_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_133MHz ,
RATE_IN_243X } ,
/* PRCM #2 - ratio1 (ES2) - FAST */
{ S13M , S658M , S329M , R1_CM_CLKSEL_MPU_VAL , /* 330MHz ARM */
R1_CM_CLKSEL_DSP_VAL , R1_CM_CLKSEL_GFX_VAL ,
R1_CM_CLKSEL1_CORE_VAL , M2_CM_CLKSEL1_PLL_13_VAL ,
MX_CLKSEL2_PLL_2x_VAL , R1_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_165MHz ,
RATE_IN_243X } ,
/* PRCM #5a - ratio1 - FAST */
{ S13M , S532M , S266M , R1_CM_CLKSEL_MPU_VAL , /* 266MHz ARM */
R1_CM_CLKSEL_DSP_VAL , R1_CM_CLKSEL_GFX_VAL ,
R1_CM_CLKSEL1_CORE_VAL , M5A_CM_CLKSEL1_PLL_13_VAL ,
MX_CLKSEL2_PLL_2x_VAL , R1_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_133MHz ,
RATE_IN_243X } ,
/* PRCM #5b - ratio1 - FAST */
{ S13M , S400M , S200M , R1_CM_CLKSEL_MPU_VAL , /* 200MHz ARM */
R1_CM_CLKSEL_DSP_VAL , R1_CM_CLKSEL_GFX_VAL ,
R1_CM_CLKSEL1_CORE_VAL , M5B_CM_CLKSEL1_PLL_13_VAL ,
MX_CLKSEL2_PLL_2x_VAL , R1_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_100MHz ,
RATE_IN_243X } ,
/* PRCM #4 - ratio1 (ES2.1) - SLOW */
{ S13M , S399M , S199M , R2_CM_CLKSEL_MPU_VAL , /* 200MHz ARM */
R2_CM_CLKSEL_DSP_VAL , R2_CM_CLKSEL_GFX_VAL ,
R2_CM_CLKSEL1_CORE_VAL , M4_CM_CLKSEL1_PLL_13_VAL ,
MX_CLKSEL2_PLL_1x_VAL , R2_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_133MHz ,
RATE_IN_243X } ,
/* PRCM #2 - ratio1 (ES2) - SLOW */
{ S13M , S329M , S164M , R1_CM_CLKSEL_MPU_VAL , /* 165MHz ARM */
R1_CM_CLKSEL_DSP_VAL , R1_CM_CLKSEL_GFX_VAL ,
R1_CM_CLKSEL1_CORE_VAL , M2_CM_CLKSEL1_PLL_13_VAL ,
MX_CLKSEL2_PLL_1x_VAL , R1_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_165MHz ,
RATE_IN_243X } ,
/* PRCM #5a - ratio1 - SLOW */
{ S13M , S266M , S133M , R1_CM_CLKSEL_MPU_VAL , /* 133MHz ARM */
R1_CM_CLKSEL_DSP_VAL , R1_CM_CLKSEL_GFX_VAL ,
R1_CM_CLKSEL1_CORE_VAL , M5A_CM_CLKSEL1_PLL_13_VAL ,
MX_CLKSEL2_PLL_1x_VAL , R1_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_133MHz ,
RATE_IN_243X } ,
/* PRCM #5b - ratio1 - SLOW*/
{ S13M , S200M , S100M , R1_CM_CLKSEL_MPU_VAL , /* 100MHz ARM */
R1_CM_CLKSEL_DSP_VAL , R1_CM_CLKSEL_GFX_VAL ,
R1_CM_CLKSEL1_CORE_VAL , M5B_CM_CLKSEL1_PLL_13_VAL ,
MX_CLKSEL2_PLL_1x_VAL , R1_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_100MHz ,
RATE_IN_243X } ,
/* PRCM-boot/bypass */
{ S13M , S13M , S13M , RB_CM_CLKSEL_MPU_VAL , /* 13Mhz */
RB_CM_CLKSEL_DSP_VAL , RB_CM_CLKSEL_GFX_VAL ,
RB_CM_CLKSEL1_CORE_VAL , MB_CM_CLKSEL1_PLL_13_VAL ,
MX_CLKSEL2_PLL_2x_VAL , RB_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_BYPASS ,
RATE_IN_243X } ,
/* PRCM-boot/bypass */
{ S12M , S12M , S12M , RB_CM_CLKSEL_MPU_VAL , /* 12Mhz */
RB_CM_CLKSEL_DSP_VAL , RB_CM_CLKSEL_GFX_VAL ,
RB_CM_CLKSEL1_CORE_VAL , MB_CM_CLKSEL1_PLL_12_VAL ,
MX_CLKSEL2_PLL_2x_VAL , RB_CM_CLKSEL_MDM_VAL ,
SDRC_RFR_CTRL_BYPASS ,
RATE_IN_243X } ,
{ 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 } ,
} ;