RE: [PATCH 9/9 v2] omap3: pm: introduce 3630 opps

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




> -----Original Message-----
> From: Menon, Nishanth
> Sent: Friday, November 13, 2009 11:35 AM
> To: linux-omap
> Cc: Menon, Nishanth; Cousson, Benoit; Hunter, Jon; Kevin Hilman; Chikkature
> Rajashekar, Madhusudhan; Paul Walmsley; Dasgupta, Romit; Premi, Sanjeev;
> Shilimkar, Santosh; Aguirre, Sergio; Lam, SuiLun; Gopinath, Thara; Sripathy,
> Vishwanath
> Subject: [PATCH 9/9 v2] omap3: pm: introduce 3630 opps
> 
> Introduce the OMAP3630 OPPs including the defined OPP tuples.
> 
> Further information on OMAP3630 can be found here:
> http://focus.ti.com/general/docs/wtbu/wtbuproductcontent.tsp?templateId=6123&nav
> igationId=12836&contentId=52606
> 
> OMAP36xx family introduces:
> VDD1 with 4 OPPs, of which OPP3 & 4 are available only on devices yet
> to be introduced in 36xx family. Meanwhile, VDD2 has 2 opps.
> 
> Range of OPPs supported by Devices(tentative)->
>            |<-3630-600->| (default)
>            |<-      3630-800  ->| (device: TBD)
>            |<-      3630-1000             ->| (device: TBD)
> H/w OPP-> OPP50 OPP100       OPP-Turbo   OPP1G-SB
> VDD1      OPP1  OPP2         OPP3        OPP4
> VDD2      OPP1  OPP2         OPP2        OPP2
> 
> Note:
> a) TI h/w naming for OPPs are now standardized in terms of OPP50, 100,
>    Turbo and SB. This maps as shown above to the opp IDs (s/w term).
> b) For boards which need custom VDD1/2 OPPs, the opp table can be
>    updated by the board file on a need basis after the
>    omap3_pm_init_opp_table call. The OPPs introduced here are the
>    official OPP table at this point in time.
> 
> Tested on: SDP3430, SDP3630
> 
> Cc: Benoit Cousson <b-cousson@xxxxxx>
> Cc: Jon Hunter <jon-hunter@xxxxxx>
> Cc: Kevin Hilman <khilman@xxxxxxxxxxxxxxxxxxx>
> Cc: Madhusudhan Chikkature Rajashekar <madhu.cr@xxxxxx>
> Cc: Paul Walmsley <paul@xxxxxxxxx>
> Cc: Romit Dasgupta <romit@xxxxxx>
> Cc: Sanjeev Premi <premi@xxxxxx>
> Cc: Santosh Shilimkar <santosh.shilimkar@xxxxxx>
> Cc: Sergio Alberto Aguirre Rodriguez <saaguirre@xxxxxx>
> Cc: SuiLun Lam <s-lam@xxxxxx>
> Cc: Thara Gopinath <thara@xxxxxx>
> Cc: Vishwanath Sripathy <vishwanath.bs@xxxxxx>
> 
> Signed-off-by: Nishanth Menon <nm@xxxxxx>
> ---
>  arch/arm/mach-omap2/omap3-opp.h |    9 ++++
>  arch/arm/mach-omap2/pm34xx.c    |   87
> +++++++++++++++++++++++++++++++-------
>  2 files changed, 80 insertions(+), 16 deletions(-)
> 
> diff --git a/arch/arm/mach-omap2/omap3-opp.h b/arch/arm/mach-omap2/omap3-
> opp.h
> index 7f27f44..a5880b8 100644
> --- a/arch/arm/mach-omap2/omap3-opp.h
> +++ b/arch/arm/mach-omap2/omap3-opp.h
> @@ -4,22 +4,31 @@
>  #include <plat/omap-pm.h>
> 
>  /* MPU speeds */
> +#define S1000M  1000000000
> +#define S800M   800000000
>  #define S600M   600000000
>  #define S550M   550000000
>  #define S500M   500000000
> +#define S300M   300000000
>  #define S250M   250000000
>  #define S125M   125000000
> 
>  /* DSP speeds */
> +#define S875M   875000000
> +#define S660M   660000000
> +#define S520M   520000000
>  #define S430M   430000000
>  #define S400M   400000000
>  #define S360M   360000000
> +#define S260M   260000000
>  #define S180M   180000000
>  #define S90M    90000000
> 
>  /* L3 speeds */
>  #define S83M    83000000
> +#define S100M   100000000
>  #define S166M   166000000
> +#define S200M   200000000
> 
>  extern struct omap_opp *omap3_mpu_rate_table;
>  extern struct omap_opp *omap3_dsp_rate_table;
> diff --git a/arch/arm/mach-omap2/pm34xx.c b/arch/arm/mach-omap2/pm34xx.c
> index 14131f8..86137bb 100644
> --- a/arch/arm/mach-omap2/pm34xx.c
> +++ b/arch/arm/mach-omap2/pm34xx.c
> @@ -141,6 +141,41 @@ static __initdata struct omap_opp
> omap34xx_dsp_rate_table[] = {
>  	{0, 0, 0, 0},
>  };
> 
> +static __initdata struct omap_opp omap36xx_mpu_rate_table[] = {
> +	{0, 0, 0, 0},
> +	/*OPP1 - 930mV - OPP50*/
> +	{true, S300M, VDD1_OPP1, 0x1a},
> +	/*OPP2 - 1.100V - OPP100*/
> +	{true, S600M, VDD1_OPP2, 0x28},
> +	/*OPP3 - 1.260V - OPP-Turbo*/
> +	{false, S800M, VDD1_OPP3, 0x34},
> +	/*OPP4 - 1.310V - OPP-SB*/
> +	{false, S1000M, VDD1_OPP4, 0x38},
> +	{0, 0, 0, 0},
> +};

OPP Table vsel values seem to be wrong. Eg: for OPP1 to get 930mV, vsel should be 0x1b. vsel=Ceiling((930-600)/12.5)

> +
> +static __initdata struct omap_opp omap36xx_l3_rate_table[] = {
> +	{0, 0, 0, 0},
> +	/*OPP1 - 930mV - OPP50 */
> +	{true, S100M, VDD2_OPP1, 0x1a},
> +	/*OPP2 - 1.375V - OPP100, OPP-Turbo, OPP-SB*/
> +	{true, S200M, VDD2_OPP2, 0x2b},
> +	{0, 0, 0, 0},
> +};
> +


Same case

> +static __initdata struct omap_opp omap36xx_dsp_rate_table[] = {
> +	{0, 0, 0, 0},
> +	/*OPP1 - OPP50*/
> +	{true, S260M, VDD1_OPP1, 0x1a},
> +	/*OPP2 - OPP100*/
> +	{true, S520M, VDD1_OPP2, 0x28},
> +	/*OPP3 - OPP-Turbo*/
> +	{false, S660M, VDD1_OPP3, 0x34},
> +	/*OPP4 - OPP-SB*/
> +	{false, S875M, VDD1_OPP4, 0x38},
> +	{0, 0, 0, 0},
> +};
> +

Same case

>  struct omap_opp *omap3_mpu_rate_table;
>  struct omap_opp *omap3_dsp_rate_table;
>  struct omap_opp *omap3_l3_rate_table;
> @@ -1287,22 +1322,42 @@ static void __init configure_vc(void)
>  void __init omap3_pm_init_opp_table(void)
>  {
>  	/* Populate the base CPU rate tables here */
> -	omap3_mpu_rate_table = kmalloc(sizeof(omap34xx_mpu_rate_table),
> -			GFP_KERNEL);
> -	omap3_dsp_rate_table = kmalloc(sizeof(omap34xx_dsp_rate_table),
> -			GFP_KERNEL);
> -	omap3_l3_rate_table = kmalloc(sizeof(omap34xx_l3_rate_table),
> -			GFP_KERNEL);
> -
> -	BUG_ON(!omap3_mpu_rate_table || !omap3_dsp_rate_table ||
> -		!omap3_l3_rate_table);
> -
> -	memcpy(omap3_mpu_rate_table, omap34xx_mpu_rate_table,
> -			sizeof(omap34xx_mpu_rate_table));
> -	memcpy(omap3_dsp_rate_table, omap34xx_dsp_rate_table,
> -			sizeof(omap34xx_dsp_rate_table));
> -	memcpy(omap3_l3_rate_table, omap34xx_l3_rate_table,
> -			sizeof(omap34xx_l3_rate_table));
> +	if (cpu_is_omap3630()) {
> +		omap3_mpu_rate_table = kmalloc(sizeof(omap36xx_mpu_rate_table),
> +				GFP_KERNEL);
> +		omap3_dsp_rate_table = kmalloc(sizeof(omap36xx_dsp_rate_table),
> +				GFP_KERNEL);
> +		omap3_l3_rate_table = kmalloc(sizeof(omap36xx_l3_rate_table),
> +				GFP_KERNEL);
> +
> +		BUG_ON(!omap3_mpu_rate_table || !omap3_dsp_rate_table ||
> +			!omap3_l3_rate_table);
> +
> +		memcpy(omap3_mpu_rate_table, omap36xx_mpu_rate_table,
> +				sizeof(omap36xx_mpu_rate_table));
> +		memcpy(omap3_dsp_rate_table, omap36xx_dsp_rate_table,
> +				sizeof(omap36xx_dsp_rate_table));
> +		memcpy(omap3_l3_rate_table, omap36xx_l3_rate_table,
> +				sizeof(omap36xx_l3_rate_table));
> +	} else {
> +		/* Default to 34xx devices */
> +		omap3_mpu_rate_table = kmalloc(sizeof(omap34xx_mpu_rate_table),
> +				GFP_KERNEL);
> +		omap3_dsp_rate_table = kmalloc(sizeof(omap34xx_dsp_rate_table),
> +				GFP_KERNEL);
> +		omap3_l3_rate_table = kmalloc(sizeof(omap34xx_l3_rate_table),
> +				GFP_KERNEL);
> +
> +		BUG_ON(!omap3_mpu_rate_table || !omap3_dsp_rate_table ||
> +			!omap3_l3_rate_table);
> +
> +		memcpy(omap3_mpu_rate_table, omap34xx_mpu_rate_table,
> +				sizeof(omap34xx_mpu_rate_table));
> +		memcpy(omap3_dsp_rate_table, omap34xx_dsp_rate_table,
> +				sizeof(omap34xx_dsp_rate_table));
> +		memcpy(omap3_l3_rate_table, omap34xx_l3_rate_table,
> +				sizeof(omap34xx_l3_rate_table));
> +	}
>  }
> 
>  static int __init omap3_pm_early_init(void)
> --
> 1.6.3.3

--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Arm (vger)]     [ARM Kernel]     [ARM MSM]     [Linux Tegra]     [Linux WPAN Networking]     [Linux Wireless Networking]     [Maemo Users]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux