mirror of https://gitee.com/openkylin/linux.git
Merge remote branch 'remotes/origin/voltage_split_2.6.39' into tmp-integration-2.6.39-20110310-024
Conflicts: arch/arm/mach-omap2/omap_hwmod_3xxx_data.c
This commit is contained in:
commit
a08572ae52
|
@ -59,10 +59,10 @@ endif
|
|||
# Power Management
|
||||
ifeq ($(CONFIG_PM),y)
|
||||
obj-$(CONFIG_ARCH_OMAP2) += pm24xx.o
|
||||
obj-$(CONFIG_ARCH_OMAP2) += sleep24xx.o pm_bus.o voltage.o
|
||||
obj-$(CONFIG_ARCH_OMAP3) += pm34xx.o sleep34xx.o voltage.o \
|
||||
obj-$(CONFIG_ARCH_OMAP2) += sleep24xx.o pm_bus.o
|
||||
obj-$(CONFIG_ARCH_OMAP3) += pm34xx.o sleep34xx.o \
|
||||
cpuidle34xx.o pm_bus.o
|
||||
obj-$(CONFIG_ARCH_OMAP4) += pm44xx.o voltage.o pm_bus.o
|
||||
obj-$(CONFIG_ARCH_OMAP4) += pm44xx.o pm_bus.o
|
||||
obj-$(CONFIG_PM_DEBUG) += pm-debug.o
|
||||
obj-$(CONFIG_OMAP_SMARTREFLEX) += sr_device.o smartreflex.o
|
||||
obj-$(CONFIG_OMAP_SMARTREFLEX_CLASS3) += smartreflex-class3.o
|
||||
|
@ -78,13 +78,25 @@ endif
|
|||
|
||||
# PRCM
|
||||
obj-$(CONFIG_ARCH_OMAP2) += prcm.o cm2xxx_3xxx.o prm2xxx_3xxx.o
|
||||
obj-$(CONFIG_ARCH_OMAP3) += prcm.o cm2xxx_3xxx.o prm2xxx_3xxx.o
|
||||
obj-$(CONFIG_ARCH_OMAP3) += prcm.o cm2xxx_3xxx.o prm2xxx_3xxx.o \
|
||||
vc3xxx_data.o vp3xxx_data.o
|
||||
# XXX The presence of cm2xxx_3xxx.o on the line below is temporary and
|
||||
# will be removed once the OMAP4 part of the codebase is converted to
|
||||
# use OMAP4-specific PRCM functions.
|
||||
obj-$(CONFIG_ARCH_OMAP4) += prcm.o cm2xxx_3xxx.o cminst44xx.o \
|
||||
cm44xx.o prcm_mpu44xx.o \
|
||||
prminst44xx.o
|
||||
prminst44xx.o vc44xx_data.o \
|
||||
vp44xx_data.o
|
||||
|
||||
# OMAP voltage domains
|
||||
ifeq ($(CONFIG_PM),y)
|
||||
voltagedomain-common := voltage.o
|
||||
obj-$(CONFIG_ARCH_OMAP2) += $(voltagedomain-common)
|
||||
obj-$(CONFIG_ARCH_OMAP3) += $(voltagedomain-common) \
|
||||
voltagedomains3xxx_data.o
|
||||
obj-$(CONFIG_ARCH_OMAP4) += $(voltagedomain-common) \
|
||||
voltagedomains44xx_data.o
|
||||
endif
|
||||
|
||||
# OMAP powerdomain framework
|
||||
powerdomain-common += powerdomain.o powerdomain-common.o
|
||||
|
|
|
@ -23,7 +23,6 @@
|
|||
#include <plat/i2c.h>
|
||||
#include <plat/gpio.h>
|
||||
#include <plat/mmc.h>
|
||||
#include <plat/smartreflex.h>
|
||||
#include <plat/mcbsp.h>
|
||||
#include <plat/mcspi.h>
|
||||
#include <plat/dmtimer.h>
|
||||
|
|
|
@ -21,6 +21,8 @@
|
|||
|
||||
#include <plat/omap_hwmod.h>
|
||||
|
||||
#include "voltage.h"
|
||||
|
||||
/*
|
||||
* *BIG FAT WARNING*:
|
||||
* USE the following ONLY in opp data initialization common to an SoC.
|
||||
|
@ -65,8 +67,30 @@ struct omap_opp_def {
|
|||
.u_volt = _uv, \
|
||||
}
|
||||
|
||||
/*
|
||||
* Initialization wrapper used to define SmartReflex process data
|
||||
* XXX Is this needed? Just use C99 initializers in data files?
|
||||
*/
|
||||
#define VOLT_DATA_DEFINE(_v_nom, _efuse_offs, _errminlimit, _errgain) \
|
||||
{ \
|
||||
.volt_nominal = _v_nom, \
|
||||
.sr_efuse_offs = _efuse_offs, \
|
||||
.sr_errminlimit = _errminlimit, \
|
||||
.vp_errgain = _errgain \
|
||||
}
|
||||
|
||||
/* Use this to initialize the default table */
|
||||
extern int __init omap_init_opp_table(struct omap_opp_def *opp_def,
|
||||
u32 opp_def_size);
|
||||
|
||||
|
||||
extern struct omap_volt_data omap34xx_vddmpu_volt_data[];
|
||||
extern struct omap_volt_data omap34xx_vddcore_volt_data[];
|
||||
extern struct omap_volt_data omap36xx_vddmpu_volt_data[];
|
||||
extern struct omap_volt_data omap36xx_vddcore_volt_data[];
|
||||
|
||||
extern struct omap_volt_data omap44xx_vdd_mpu_volt_data[];
|
||||
extern struct omap_volt_data omap44xx_vdd_iva_volt_data[];
|
||||
extern struct omap_volt_data omap44xx_vdd_core_volt_data[];
|
||||
|
||||
#endif /* __ARCH_ARM_MACH_OMAP2_OMAP_OPP_DATA_H */
|
||||
|
|
|
@ -18,7 +18,7 @@
|
|||
#include <linux/kernel.h>
|
||||
#include <linux/i2c/twl.h>
|
||||
|
||||
#include <plat/voltage.h>
|
||||
#include "voltage.h"
|
||||
|
||||
#include "pm.h"
|
||||
|
||||
|
|
|
@ -4,8 +4,9 @@
|
|||
* Copyright (C) 2009-2010 Texas Instruments Incorporated - http://www.ti.com/
|
||||
* Nishanth Menon
|
||||
* Kevin Hilman
|
||||
* Copyright (C) 2010 Nokia Corporation.
|
||||
* Copyright (C) 2010-2011 Nokia Corporation.
|
||||
* Eduardo Valentin
|
||||
* Paul Walmsley
|
||||
*
|
||||
* 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
|
||||
|
@ -20,8 +21,71 @@
|
|||
|
||||
#include <plat/cpu.h>
|
||||
|
||||
#include "control.h"
|
||||
#include "omap_opp_data.h"
|
||||
|
||||
/* 34xx */
|
||||
|
||||
/* VDD1 */
|
||||
|
||||
#define OMAP3430_VDD_MPU_OPP1_UV 975000
|
||||
#define OMAP3430_VDD_MPU_OPP2_UV 1075000
|
||||
#define OMAP3430_VDD_MPU_OPP3_UV 1200000
|
||||
#define OMAP3430_VDD_MPU_OPP4_UV 1270000
|
||||
#define OMAP3430_VDD_MPU_OPP5_UV 1350000
|
||||
|
||||
struct omap_volt_data omap34xx_vddmpu_volt_data[] = {
|
||||
VOLT_DATA_DEFINE(OMAP3430_VDD_MPU_OPP1_UV, OMAP343X_CONTROL_FUSE_OPP1_VDD1, 0xf4, 0x0c),
|
||||
VOLT_DATA_DEFINE(OMAP3430_VDD_MPU_OPP2_UV, OMAP343X_CONTROL_FUSE_OPP2_VDD1, 0xf4, 0x0c),
|
||||
VOLT_DATA_DEFINE(OMAP3430_VDD_MPU_OPP3_UV, OMAP343X_CONTROL_FUSE_OPP3_VDD1, 0xf9, 0x18),
|
||||
VOLT_DATA_DEFINE(OMAP3430_VDD_MPU_OPP4_UV, OMAP343X_CONTROL_FUSE_OPP4_VDD1, 0xf9, 0x18),
|
||||
VOLT_DATA_DEFINE(OMAP3430_VDD_MPU_OPP5_UV, OMAP343X_CONTROL_FUSE_OPP5_VDD1, 0xf9, 0x18),
|
||||
VOLT_DATA_DEFINE(0, 0, 0, 0),
|
||||
};
|
||||
|
||||
/* VDD2 */
|
||||
|
||||
#define OMAP3430_VDD_CORE_OPP1_UV 975000
|
||||
#define OMAP3430_VDD_CORE_OPP2_UV 1050000
|
||||
#define OMAP3430_VDD_CORE_OPP3_UV 1150000
|
||||
|
||||
struct omap_volt_data omap34xx_vddcore_volt_data[] = {
|
||||
VOLT_DATA_DEFINE(OMAP3430_VDD_CORE_OPP1_UV, OMAP343X_CONTROL_FUSE_OPP1_VDD2, 0xf4, 0x0c),
|
||||
VOLT_DATA_DEFINE(OMAP3430_VDD_CORE_OPP2_UV, OMAP343X_CONTROL_FUSE_OPP2_VDD2, 0xf4, 0x0c),
|
||||
VOLT_DATA_DEFINE(OMAP3430_VDD_CORE_OPP3_UV, OMAP343X_CONTROL_FUSE_OPP3_VDD2, 0xf9, 0x18),
|
||||
VOLT_DATA_DEFINE(0, 0, 0, 0),
|
||||
};
|
||||
|
||||
/* 36xx */
|
||||
|
||||
/* VDD1 */
|
||||
|
||||
#define OMAP3630_VDD_MPU_OPP50_UV 1012500
|
||||
#define OMAP3630_VDD_MPU_OPP100_UV 1200000
|
||||
#define OMAP3630_VDD_MPU_OPP120_UV 1325000
|
||||
#define OMAP3630_VDD_MPU_OPP1G_UV 1375000
|
||||
|
||||
struct omap_volt_data omap36xx_vddmpu_volt_data[] = {
|
||||
VOLT_DATA_DEFINE(OMAP3630_VDD_MPU_OPP50_UV, OMAP3630_CONTROL_FUSE_OPP50_VDD1, 0xf4, 0x0c),
|
||||
VOLT_DATA_DEFINE(OMAP3630_VDD_MPU_OPP100_UV, OMAP3630_CONTROL_FUSE_OPP100_VDD1, 0xf9, 0x16),
|
||||
VOLT_DATA_DEFINE(OMAP3630_VDD_MPU_OPP120_UV, OMAP3630_CONTROL_FUSE_OPP120_VDD1, 0xfa, 0x23),
|
||||
VOLT_DATA_DEFINE(OMAP3630_VDD_MPU_OPP1G_UV, OMAP3630_CONTROL_FUSE_OPP1G_VDD1, 0xfa, 0x27),
|
||||
VOLT_DATA_DEFINE(0, 0, 0, 0),
|
||||
};
|
||||
|
||||
/* VDD2 */
|
||||
|
||||
#define OMAP3630_VDD_CORE_OPP50_UV 1000000
|
||||
#define OMAP3630_VDD_CORE_OPP100_UV 1200000
|
||||
|
||||
struct omap_volt_data omap36xx_vddcore_volt_data[] = {
|
||||
VOLT_DATA_DEFINE(OMAP3630_VDD_CORE_OPP50_UV, OMAP3630_CONTROL_FUSE_OPP50_VDD2, 0xf4, 0x0c),
|
||||
VOLT_DATA_DEFINE(OMAP3630_VDD_CORE_OPP100_UV, OMAP3630_CONTROL_FUSE_OPP100_VDD2, 0xf9, 0x16),
|
||||
VOLT_DATA_DEFINE(0, 0, 0, 0),
|
||||
};
|
||||
|
||||
/* OPP data */
|
||||
|
||||
static struct omap_opp_def __initdata omap34xx_opp_def_list[] = {
|
||||
/* MPU OPP1 */
|
||||
OPP_INITIALIZER("mpu", true, 125000000, 975000),
|
||||
|
|
|
@ -5,8 +5,9 @@
|
|||
* Nishanth Menon
|
||||
* Kevin Hilman
|
||||
* Thara Gopinath
|
||||
* Copyright (C) 2010 Nokia Corporation.
|
||||
* Copyright (C) 2010-2011 Nokia Corporation.
|
||||
* Eduardo Valentin
|
||||
* Paul Walmsley
|
||||
*
|
||||
* 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
|
||||
|
@ -21,8 +22,48 @@
|
|||
|
||||
#include <plat/cpu.h>
|
||||
|
||||
#include "control.h"
|
||||
#include "omap_opp_data.h"
|
||||
|
||||
/*
|
||||
* Structures containing OMAP4430 voltage supported and various
|
||||
* voltage dependent data for each VDD.
|
||||
*/
|
||||
|
||||
#define OMAP4430_VDD_MPU_OPP50_UV 930000
|
||||
#define OMAP4430_VDD_MPU_OPP100_UV 1100000
|
||||
#define OMAP4430_VDD_MPU_OPPTURBO_UV 1260000
|
||||
#define OMAP4430_VDD_MPU_OPPNITRO_UV 1350000
|
||||
|
||||
struct omap_volt_data omap44xx_vdd_mpu_volt_data[] = {
|
||||
VOLT_DATA_DEFINE(OMAP4430_VDD_MPU_OPP50_UV, OMAP44XX_CONTROL_FUSE_MPU_OPP50, 0xf4, 0x0c),
|
||||
VOLT_DATA_DEFINE(OMAP4430_VDD_MPU_OPP100_UV, OMAP44XX_CONTROL_FUSE_MPU_OPP100, 0xf9, 0x16),
|
||||
VOLT_DATA_DEFINE(OMAP4430_VDD_MPU_OPPTURBO_UV, OMAP44XX_CONTROL_FUSE_MPU_OPPTURBO, 0xfa, 0x23),
|
||||
VOLT_DATA_DEFINE(OMAP4430_VDD_MPU_OPPNITRO_UV, OMAP44XX_CONTROL_FUSE_MPU_OPPNITRO, 0xfa, 0x27),
|
||||
VOLT_DATA_DEFINE(0, 0, 0, 0),
|
||||
};
|
||||
|
||||
#define OMAP4430_VDD_IVA_OPP50_UV 930000
|
||||
#define OMAP4430_VDD_IVA_OPP100_UV 1100000
|
||||
#define OMAP4430_VDD_IVA_OPPTURBO_UV 1260000
|
||||
|
||||
struct omap_volt_data omap44xx_vdd_iva_volt_data[] = {
|
||||
VOLT_DATA_DEFINE(OMAP4430_VDD_IVA_OPP50_UV, OMAP44XX_CONTROL_FUSE_IVA_OPP50, 0xf4, 0x0c),
|
||||
VOLT_DATA_DEFINE(OMAP4430_VDD_IVA_OPP100_UV, OMAP44XX_CONTROL_FUSE_IVA_OPP100, 0xf9, 0x16),
|
||||
VOLT_DATA_DEFINE(OMAP4430_VDD_IVA_OPPTURBO_UV, OMAP44XX_CONTROL_FUSE_IVA_OPPTURBO, 0xfa, 0x23),
|
||||
VOLT_DATA_DEFINE(0, 0, 0, 0),
|
||||
};
|
||||
|
||||
#define OMAP4430_VDD_CORE_OPP50_UV 930000
|
||||
#define OMAP4430_VDD_CORE_OPP100_UV 1100000
|
||||
|
||||
struct omap_volt_data omap44xx_vdd_core_volt_data[] = {
|
||||
VOLT_DATA_DEFINE(OMAP4430_VDD_CORE_OPP50_UV, OMAP44XX_CONTROL_FUSE_CORE_OPP50, 0xf4, 0x0c),
|
||||
VOLT_DATA_DEFINE(OMAP4430_VDD_CORE_OPP100_UV, OMAP44XX_CONTROL_FUSE_CORE_OPP100, 0xf9, 0x16),
|
||||
VOLT_DATA_DEFINE(0, 0, 0, 0),
|
||||
};
|
||||
|
||||
|
||||
static struct omap_opp_def __initdata omap44xx_opp_def_list[] = {
|
||||
/* MPU OPP1 - OPP50 */
|
||||
OPP_INITIALIZER("mpu", true, 300000000, 1100000),
|
||||
|
|
|
@ -18,8 +18,8 @@
|
|||
#include <plat/omap-pm.h>
|
||||
#include <plat/omap_device.h>
|
||||
#include <plat/common.h>
|
||||
#include <plat/voltage.h>
|
||||
|
||||
#include "voltage.h"
|
||||
#include "powerdomain.h"
|
||||
#include "clockdomain.h"
|
||||
#include "pm.h"
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
* published by the Free Software Foundation.
|
||||
*/
|
||||
|
||||
#include <plat/smartreflex.h>
|
||||
#include "smartreflex.h"
|
||||
|
||||
static int sr_class3_enable(struct voltagedomain *voltdm)
|
||||
{
|
||||
|
|
|
@ -26,9 +26,9 @@
|
|||
#include <linux/pm_runtime.h>
|
||||
|
||||
#include <plat/common.h>
|
||||
#include <plat/smartreflex.h>
|
||||
|
||||
#include "pm.h"
|
||||
#include "smartreflex.h"
|
||||
|
||||
#define SMARTREFLEX_NAME_LEN 16
|
||||
#define NVALUE_NAME_LEN 40
|
||||
|
|
|
@ -21,7 +21,8 @@
|
|||
#define __ASM_ARM_OMAP_SMARTREFLEX_H
|
||||
|
||||
#include <linux/platform_device.h>
|
||||
#include <plat/voltage.h>
|
||||
|
||||
#include "voltage.h"
|
||||
|
||||
/*
|
||||
* Different Smartreflex IPs version. The v1 is the 65nm version used in
|
|
@ -23,9 +23,9 @@
|
|||
#include <linux/io.h>
|
||||
|
||||
#include <plat/omap_device.h>
|
||||
#include <plat/smartreflex.h>
|
||||
#include <plat/voltage.h>
|
||||
|
||||
#include "smartreflex.h"
|
||||
#include "voltage.h"
|
||||
#include "control.h"
|
||||
#include "pm.h"
|
||||
|
||||
|
|
|
@ -0,0 +1,83 @@
|
|||
/*
|
||||
* OMAP3/4 Voltage Controller (VC) structure and macro definitions
|
||||
*
|
||||
* Copyright (C) 2007, 2010 Texas Instruments, Inc.
|
||||
* Rajendra Nayak <rnayak@ti.com>
|
||||
* Lesly A M <x0080970@ti.com>
|
||||
* Thara Gopinath <thara@ti.com>
|
||||
*
|
||||
* Copyright (C) 2008, 2011 Nokia Corporation
|
||||
* Kalle Jokiniemi
|
||||
* Paul Walmsley
|
||||
*
|
||||
* 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_OMAP2_VC_H
|
||||
#define __ARCH_ARM_MACH_OMAP2_VC_H
|
||||
|
||||
#include <linux/kernel.h>
|
||||
|
||||
/**
|
||||
* struct omap_vc_common_data - per-VC register/bitfield data
|
||||
* @cmd_on_mask: ON bitmask in PRM_VC_CMD_VAL* register
|
||||
* @valid: VALID bitmask in PRM_VC_BYPASS_VAL register
|
||||
* @smps_sa_reg: Offset of PRM_VC_SMPS_SA reg from PRM start
|
||||
* @smps_volra_reg: Offset of PRM_VC_SMPS_VOL_RA reg from PRM start
|
||||
* @bypass_val_reg: Offset of PRM_VC_BYPASS_VAL reg from PRM start
|
||||
* @data_shift: DATA field shift in PRM_VC_BYPASS_VAL register
|
||||
* @slaveaddr_shift: SLAVEADDR field shift in PRM_VC_BYPASS_VAL register
|
||||
* @regaddr_shift: REGADDR field shift in PRM_VC_BYPASS_VAL register
|
||||
* @cmd_on_shift: ON field shift in PRM_VC_CMD_VAL_* register
|
||||
* @cmd_onlp_shift: ONLP field shift in PRM_VC_CMD_VAL_* register
|
||||
* @cmd_ret_shift: RET field shift in PRM_VC_CMD_VAL_* register
|
||||
* @cmd_off_shift: OFF field shift in PRM_VC_CMD_VAL_* register
|
||||
*
|
||||
* XXX One of cmd_on_mask and cmd_on_shift are not needed
|
||||
* XXX VALID should probably be a shift, not a mask
|
||||
*/
|
||||
struct omap_vc_common_data {
|
||||
u32 cmd_on_mask;
|
||||
u32 valid;
|
||||
u8 smps_sa_reg;
|
||||
u8 smps_volra_reg;
|
||||
u8 bypass_val_reg;
|
||||
u8 data_shift;
|
||||
u8 slaveaddr_shift;
|
||||
u8 regaddr_shift;
|
||||
u8 cmd_on_shift;
|
||||
u8 cmd_onlp_shift;
|
||||
u8 cmd_ret_shift;
|
||||
u8 cmd_off_shift;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct omap_vc_instance_data - VC per-instance data
|
||||
* @vc_common: pointer to VC common data for this platform
|
||||
* @smps_sa_mask: SA* bitmask in the PRM_VC_SMPS_SA register
|
||||
* @smps_volra_mask: VOLRA* bitmask in the PRM_VC_VOL_RA register
|
||||
* @smps_sa_shift: SA* field shift in the PRM_VC_SMPS_SA register
|
||||
* @smps_volra_shift: VOLRA* field shift in the PRM_VC_VOL_RA register
|
||||
*
|
||||
* XXX It is not necessary to have both a *_mask and a *_shift -
|
||||
* remove one
|
||||
*/
|
||||
struct omap_vc_instance_data {
|
||||
const struct omap_vc_common_data *vc_common;
|
||||
u32 smps_sa_mask;
|
||||
u32 smps_volra_mask;
|
||||
u8 cmdval_reg;
|
||||
u8 smps_sa_shift;
|
||||
u8 smps_volra_shift;
|
||||
};
|
||||
|
||||
extern struct omap_vc_instance_data omap3_vc1_data;
|
||||
extern struct omap_vc_instance_data omap3_vc2_data;
|
||||
|
||||
extern struct omap_vc_instance_data omap4_vc_mpu_data;
|
||||
extern struct omap_vc_instance_data omap4_vc_iva_data;
|
||||
extern struct omap_vc_instance_data omap4_vc_core_data;
|
||||
|
||||
#endif
|
||||
|
|
@ -0,0 +1,63 @@
|
|||
/*
|
||||
* OMAP3 Voltage Controller (VC) data
|
||||
*
|
||||
* Copyright (C) 2007, 2010 Texas Instruments, Inc.
|
||||
* Rajendra Nayak <rnayak@ti.com>
|
||||
* Lesly A M <x0080970@ti.com>
|
||||
* Thara Gopinath <thara@ti.com>
|
||||
*
|
||||
* Copyright (C) 2008, 2011 Nokia Corporation
|
||||
* Kalle Jokiniemi
|
||||
* Paul Walmsley
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
#include <linux/io.h>
|
||||
#include <linux/err.h>
|
||||
#include <linux/init.h>
|
||||
|
||||
#include <plat/common.h>
|
||||
|
||||
#include "prm-regbits-34xx.h"
|
||||
#include "voltage.h"
|
||||
|
||||
#include "vc.h"
|
||||
|
||||
/*
|
||||
* VC data common to 34xx/36xx chips
|
||||
* XXX This stuff presumably belongs in the vc3xxx.c or vc.c file.
|
||||
*/
|
||||
static struct omap_vc_common_data omap3_vc_common = {
|
||||
.smps_sa_reg = OMAP3_PRM_VC_SMPS_SA_OFFSET,
|
||||
.smps_volra_reg = OMAP3_PRM_VC_SMPS_VOL_RA_OFFSET,
|
||||
.bypass_val_reg = OMAP3_PRM_VC_BYPASS_VAL_OFFSET,
|
||||
.data_shift = OMAP3430_DATA_SHIFT,
|
||||
.slaveaddr_shift = OMAP3430_SLAVEADDR_SHIFT,
|
||||
.regaddr_shift = OMAP3430_REGADDR_SHIFT,
|
||||
.valid = OMAP3430_VALID_MASK,
|
||||
.cmd_on_shift = OMAP3430_VC_CMD_ON_SHIFT,
|
||||
.cmd_on_mask = OMAP3430_VC_CMD_ON_MASK,
|
||||
.cmd_onlp_shift = OMAP3430_VC_CMD_ONLP_SHIFT,
|
||||
.cmd_ret_shift = OMAP3430_VC_CMD_RET_SHIFT,
|
||||
.cmd_off_shift = OMAP3430_VC_CMD_OFF_SHIFT,
|
||||
};
|
||||
|
||||
struct omap_vc_instance_data omap3_vc1_data = {
|
||||
.vc_common = &omap3_vc_common,
|
||||
.cmdval_reg = OMAP3_PRM_VC_CMD_VAL_0_OFFSET,
|
||||
.smps_sa_shift = OMAP3430_PRM_VC_SMPS_SA_SA0_SHIFT,
|
||||
.smps_sa_mask = OMAP3430_PRM_VC_SMPS_SA_SA0_MASK,
|
||||
.smps_volra_shift = OMAP3430_VOLRA0_SHIFT,
|
||||
.smps_volra_mask = OMAP3430_VOLRA0_MASK,
|
||||
};
|
||||
|
||||
struct omap_vc_instance_data omap3_vc2_data = {
|
||||
.vc_common = &omap3_vc_common,
|
||||
.cmdval_reg = OMAP3_PRM_VC_CMD_VAL_1_OFFSET,
|
||||
.smps_sa_shift = OMAP3430_PRM_VC_SMPS_SA_SA1_SHIFT,
|
||||
.smps_sa_mask = OMAP3430_PRM_VC_SMPS_SA_SA1_MASK,
|
||||
.smps_volra_shift = OMAP3430_VOLRA1_SHIFT,
|
||||
.smps_volra_mask = OMAP3430_VOLRA1_MASK,
|
||||
};
|
|
@ -0,0 +1,75 @@
|
|||
/*
|
||||
* OMAP4 Voltage Controller (VC) data
|
||||
*
|
||||
* Copyright (C) 2007, 2010 Texas Instruments, Inc.
|
||||
* Rajendra Nayak <rnayak@ti.com>
|
||||
* Lesly A M <x0080970@ti.com>
|
||||
* Thara Gopinath <thara@ti.com>
|
||||
*
|
||||
* Copyright (C) 2008, 2011 Nokia Corporation
|
||||
* Kalle Jokiniemi
|
||||
* Paul Walmsley
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
#include <linux/io.h>
|
||||
#include <linux/err.h>
|
||||
#include <linux/init.h>
|
||||
|
||||
#include <plat/common.h>
|
||||
|
||||
#include "prm44xx.h"
|
||||
#include "prm-regbits-44xx.h"
|
||||
#include "voltage.h"
|
||||
|
||||
#include "vc.h"
|
||||
|
||||
/*
|
||||
* VC data common to 44xx chips
|
||||
* XXX This stuff presumably belongs in the vc3xxx.c or vc.c file.
|
||||
*/
|
||||
static const struct omap_vc_common_data omap4_vc_common = {
|
||||
.smps_sa_reg = OMAP4_PRM_VC_SMPS_SA_OFFSET,
|
||||
.smps_volra_reg = OMAP4_PRM_VC_VAL_SMPS_RA_VOL_OFFSET,
|
||||
.bypass_val_reg = OMAP4_PRM_VC_VAL_BYPASS_OFFSET,
|
||||
.data_shift = OMAP4430_DATA_SHIFT,
|
||||
.slaveaddr_shift = OMAP4430_SLAVEADDR_SHIFT,
|
||||
.regaddr_shift = OMAP4430_REGADDR_SHIFT,
|
||||
.valid = OMAP4430_VALID_MASK,
|
||||
.cmd_on_shift = OMAP4430_ON_SHIFT,
|
||||
.cmd_on_mask = OMAP4430_ON_MASK,
|
||||
.cmd_onlp_shift = OMAP4430_ONLP_SHIFT,
|
||||
.cmd_ret_shift = OMAP4430_RET_SHIFT,
|
||||
.cmd_off_shift = OMAP4430_OFF_SHIFT,
|
||||
};
|
||||
|
||||
/* VC instance data for each controllable voltage line */
|
||||
struct omap_vc_instance_data omap4_vc_mpu_data = {
|
||||
.vc_common = &omap4_vc_common,
|
||||
.cmdval_reg = OMAP4_PRM_VC_VAL_CMD_VDD_MPU_L_OFFSET,
|
||||
.smps_sa_shift = OMAP4430_SA_VDD_MPU_L_PRM_VC_SMPS_SA_SHIFT,
|
||||
.smps_sa_mask = OMAP4430_SA_VDD_MPU_L_PRM_VC_SMPS_SA_MASK,
|
||||
.smps_volra_shift = OMAP4430_VOLRA_VDD_MPU_L_SHIFT,
|
||||
.smps_volra_mask = OMAP4430_VOLRA_VDD_MPU_L_MASK,
|
||||
};
|
||||
|
||||
struct omap_vc_instance_data omap4_vc_iva_data = {
|
||||
.vc_common = &omap4_vc_common,
|
||||
.cmdval_reg = OMAP4_PRM_VC_VAL_CMD_VDD_IVA_L_OFFSET,
|
||||
.smps_sa_shift = OMAP4430_SA_VDD_IVA_L_PRM_VC_SMPS_SA_SHIFT,
|
||||
.smps_sa_mask = OMAP4430_SA_VDD_IVA_L_PRM_VC_SMPS_SA_MASK,
|
||||
.smps_volra_shift = OMAP4430_VOLRA_VDD_IVA_L_SHIFT,
|
||||
.smps_volra_mask = OMAP4430_VOLRA_VDD_IVA_L_MASK,
|
||||
};
|
||||
|
||||
struct omap_vc_instance_data omap4_vc_core_data = {
|
||||
.vc_common = &omap4_vc_common,
|
||||
.cmdval_reg = OMAP4_PRM_VC_VAL_CMD_VDD_CORE_L_OFFSET,
|
||||
.smps_sa_shift = OMAP4430_SA_VDD_CORE_L_0_6_SHIFT,
|
||||
.smps_sa_mask = OMAP4430_SA_VDD_CORE_L_0_6_MASK,
|
||||
.smps_volra_shift = OMAP4430_VOLRA_VDD_CORE_L_SHIFT,
|
||||
.smps_volra_mask = OMAP4430_VOLRA_VDD_CORE_L_MASK,
|
||||
};
|
||||
|
File diff suppressed because it is too large
Load Diff
|
@ -16,6 +16,10 @@
|
|||
|
||||
#include <linux/err.h>
|
||||
|
||||
#include "vc.h"
|
||||
#include "vp.h"
|
||||
|
||||
/* XXX document */
|
||||
#define VOLTSCALE_VPFORCEUPDATE 1
|
||||
#define VOLTSCALE_VCBYPASS 2
|
||||
|
||||
|
@ -27,36 +31,22 @@
|
|||
#define OMAP3_VOLTOFFSET 0xff
|
||||
#define OMAP3_VOLTSETUP2 0xff
|
||||
|
||||
/* Voltage value defines */
|
||||
#define OMAP3430_VDD_MPU_OPP1_UV 975000
|
||||
#define OMAP3430_VDD_MPU_OPP2_UV 1075000
|
||||
#define OMAP3430_VDD_MPU_OPP3_UV 1200000
|
||||
#define OMAP3430_VDD_MPU_OPP4_UV 1270000
|
||||
#define OMAP3430_VDD_MPU_OPP5_UV 1350000
|
||||
|
||||
#define OMAP3430_VDD_CORE_OPP1_UV 975000
|
||||
#define OMAP3430_VDD_CORE_OPP2_UV 1050000
|
||||
#define OMAP3430_VDD_CORE_OPP3_UV 1150000
|
||||
|
||||
#define OMAP3630_VDD_MPU_OPP50_UV 1012500
|
||||
#define OMAP3630_VDD_MPU_OPP100_UV 1200000
|
||||
#define OMAP3630_VDD_MPU_OPP120_UV 1325000
|
||||
#define OMAP3630_VDD_MPU_OPP1G_UV 1375000
|
||||
|
||||
#define OMAP3630_VDD_CORE_OPP50_UV 1000000
|
||||
#define OMAP3630_VDD_CORE_OPP100_UV 1200000
|
||||
|
||||
#define OMAP4430_VDD_MPU_OPP50_UV 930000
|
||||
#define OMAP4430_VDD_MPU_OPP100_UV 1100000
|
||||
#define OMAP4430_VDD_MPU_OPPTURBO_UV 1260000
|
||||
#define OMAP4430_VDD_MPU_OPPNITRO_UV 1350000
|
||||
|
||||
#define OMAP4430_VDD_IVA_OPP50_UV 930000
|
||||
#define OMAP4430_VDD_IVA_OPP100_UV 1100000
|
||||
#define OMAP4430_VDD_IVA_OPPTURBO_UV 1260000
|
||||
|
||||
#define OMAP4430_VDD_CORE_OPP50_UV 930000
|
||||
#define OMAP4430_VDD_CORE_OPP100_UV 1100000
|
||||
/**
|
||||
* struct omap_vfsm_instance_data - per-voltage manager FSM register/bitfield
|
||||
* data
|
||||
* @voltsetup_mask: SETUP_TIME* bitmask in the PRM_VOLTSETUP* register
|
||||
* @voltsetup_reg: register offset of PRM_VOLTSETUP from PRM base
|
||||
* @voltsetup_shift: SETUP_TIME* field shift in the PRM_VOLTSETUP* register
|
||||
*
|
||||
* XXX What about VOLTOFFSET/VOLTCTRL?
|
||||
* XXX It is not necessary to have both a _mask and a _shift for the same
|
||||
* bitfield - remove one!
|
||||
*/
|
||||
struct omap_vfsm_instance_data {
|
||||
u32 voltsetup_mask;
|
||||
u8 voltsetup_reg;
|
||||
u8 voltsetup_shift;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct voltagedomain - omap voltage domain global structure.
|
||||
|
@ -113,6 +103,42 @@ struct omap_volt_pmic_info {
|
|||
u8 (*uv_to_vsel) (unsigned long uV);
|
||||
};
|
||||
|
||||
/**
|
||||
* omap_vdd_info - Per Voltage Domain info
|
||||
*
|
||||
* @volt_data : voltage table having the distinct voltages supported
|
||||
* by the domain and other associated per voltage data.
|
||||
* @pmic_info : pmic specific parameters which should be populted by
|
||||
* the pmic drivers.
|
||||
* @vp_data : the register values, shifts, masks for various
|
||||
* vp registers
|
||||
* @vp_rt_data : VP data derived at runtime, not predefined
|
||||
* @vc_data : structure containing various various vc registers,
|
||||
* shifts, masks etc.
|
||||
* @vfsm : voltage manager FSM data
|
||||
* @voltdm : pointer to the voltage domain structure
|
||||
* @debug_dir : debug directory for this voltage domain.
|
||||
* @curr_volt : current voltage for this vdd.
|
||||
* @vp_enabled : flag to keep track of whether vp is enabled or not
|
||||
* @volt_scale : API to scale the voltage of the vdd.
|
||||
*/
|
||||
struct omap_vdd_info {
|
||||
struct omap_volt_data *volt_data;
|
||||
struct omap_volt_pmic_info *pmic_info;
|
||||
struct omap_vp_instance_data *vp_data;
|
||||
struct omap_vp_runtime_data vp_rt_data;
|
||||
struct omap_vc_instance_data *vc_data;
|
||||
const struct omap_vfsm_instance_data *vfsm;
|
||||
struct voltagedomain voltdm;
|
||||
struct dentry *debug_dir;
|
||||
u32 curr_volt;
|
||||
bool vp_enabled;
|
||||
u32 (*read_reg) (u16 mod, u8 offset);
|
||||
void (*write_reg) (u32 val, u16 mod, u8 offset);
|
||||
int (*volt_scale) (struct omap_vdd_info *vdd,
|
||||
unsigned long target_volt);
|
||||
};
|
||||
|
||||
unsigned long omap_vp_get_curr_volt(struct voltagedomain *voltdm);
|
||||
void omap_vp_enable(struct voltagedomain *voltdm);
|
||||
void omap_vp_disable(struct voltagedomain *voltdm);
|
||||
|
@ -125,6 +151,9 @@ struct omap_volt_data *omap_voltage_get_voltdata(struct voltagedomain *voltdm,
|
|||
unsigned long volt);
|
||||
unsigned long omap_voltage_get_nom_volt(struct voltagedomain *voltdm);
|
||||
struct dentry *omap_voltage_get_dbgdir(struct voltagedomain *voltdm);
|
||||
int __init omap_voltage_early_init(s16 prm_mod, s16 prm_irqst_mod,
|
||||
struct omap_vdd_info *omap_vdd_array[],
|
||||
u8 omap_vdd_count);
|
||||
#ifdef CONFIG_PM
|
||||
int omap_voltage_register_pmic(struct voltagedomain *voltdm,
|
||||
struct omap_volt_pmic_info *pmic_info);
|
|
@ -0,0 +1,95 @@
|
|||
/*
|
||||
* OMAP3 voltage domain data
|
||||
*
|
||||
* Copyright (C) 2007, 2010 Texas Instruments, Inc.
|
||||
* Rajendra Nayak <rnayak@ti.com>
|
||||
* Lesly A M <x0080970@ti.com>
|
||||
* Thara Gopinath <thara@ti.com>
|
||||
*
|
||||
* Copyright (C) 2008, 2011 Nokia Corporation
|
||||
* Kalle Jokiniemi
|
||||
* Paul Walmsley
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/err.h>
|
||||
#include <linux/init.h>
|
||||
|
||||
#include <plat/common.h>
|
||||
#include <plat/cpu.h>
|
||||
|
||||
#include "prm-regbits-34xx.h"
|
||||
#include "omap_opp_data.h"
|
||||
#include "voltage.h"
|
||||
#include "vc.h"
|
||||
#include "vp.h"
|
||||
|
||||
/*
|
||||
* VDD data
|
||||
*/
|
||||
|
||||
static const struct omap_vfsm_instance_data omap3_vdd1_vfsm_data = {
|
||||
.voltsetup_reg = OMAP3_PRM_VOLTSETUP1_OFFSET,
|
||||
.voltsetup_shift = OMAP3430_SETUP_TIME1_SHIFT,
|
||||
.voltsetup_mask = OMAP3430_SETUP_TIME1_MASK,
|
||||
};
|
||||
|
||||
static struct omap_vdd_info omap3_vdd1_info = {
|
||||
.vp_data = &omap3_vp1_data,
|
||||
.vc_data = &omap3_vc1_data,
|
||||
.vfsm = &omap3_vdd1_vfsm_data,
|
||||
.voltdm = {
|
||||
.name = "mpu",
|
||||
},
|
||||
};
|
||||
|
||||
static const struct omap_vfsm_instance_data omap3_vdd2_vfsm_data = {
|
||||
.voltsetup_reg = OMAP3_PRM_VOLTSETUP1_OFFSET,
|
||||
.voltsetup_shift = OMAP3430_SETUP_TIME2_SHIFT,
|
||||
.voltsetup_mask = OMAP3430_SETUP_TIME2_MASK,
|
||||
};
|
||||
|
||||
static struct omap_vdd_info omap3_vdd2_info = {
|
||||
.vp_data = &omap3_vp2_data,
|
||||
.vc_data = &omap3_vc2_data,
|
||||
.vfsm = &omap3_vdd2_vfsm_data,
|
||||
.voltdm = {
|
||||
.name = "core",
|
||||
},
|
||||
};
|
||||
|
||||
/* OMAP3 VDD structures */
|
||||
static struct omap_vdd_info *omap3_vdd_info[] = {
|
||||
&omap3_vdd1_info,
|
||||
&omap3_vdd2_info,
|
||||
};
|
||||
|
||||
/* OMAP3 specific voltage init functions */
|
||||
static int __init omap3xxx_voltage_early_init(void)
|
||||
{
|
||||
s16 prm_mod = OMAP3430_GR_MOD;
|
||||
s16 prm_irqst_ocp_mod = OCP_MOD;
|
||||
|
||||
if (!cpu_is_omap34xx())
|
||||
return 0;
|
||||
|
||||
/*
|
||||
* XXX Will depend on the process, validation, and binning
|
||||
* for the currently-running IC
|
||||
*/
|
||||
if (cpu_is_omap3630()) {
|
||||
omap3_vdd1_info.volt_data = omap36xx_vddmpu_volt_data;
|
||||
omap3_vdd2_info.volt_data = omap36xx_vddcore_volt_data;
|
||||
} else {
|
||||
omap3_vdd1_info.volt_data = omap34xx_vddmpu_volt_data;
|
||||
omap3_vdd2_info.volt_data = omap34xx_vddcore_volt_data;
|
||||
}
|
||||
|
||||
return omap_voltage_early_init(prm_mod, prm_irqst_ocp_mod,
|
||||
omap3_vdd_info,
|
||||
ARRAY_SIZE(omap3_vdd_info));
|
||||
};
|
||||
core_initcall(omap3xxx_voltage_early_init);
|
|
@ -0,0 +1,102 @@
|
|||
/*
|
||||
* OMAP3/OMAP4 Voltage Management Routines
|
||||
*
|
||||
* Author: Thara Gopinath <thara@ti.com>
|
||||
*
|
||||
* Copyright (C) 2007 Texas Instruments, Inc.
|
||||
* Rajendra Nayak <rnayak@ti.com>
|
||||
* Lesly A M <x0080970@ti.com>
|
||||
*
|
||||
* Copyright (C) 2008 Nokia Corporation
|
||||
* Kalle Jokiniemi
|
||||
*
|
||||
* Copyright (C) 2010 Texas Instruments, Inc.
|
||||
* Thara Gopinath <thara@ti.com>
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/err.h>
|
||||
#include <linux/init.h>
|
||||
|
||||
#include <plat/common.h>
|
||||
|
||||
#include "prm-regbits-44xx.h"
|
||||
#include "prm44xx.h"
|
||||
#include "prcm44xx.h"
|
||||
#include "prminst44xx.h"
|
||||
#include "voltage.h"
|
||||
#include "omap_opp_data.h"
|
||||
#include "vc.h"
|
||||
#include "vp.h"
|
||||
|
||||
static const struct omap_vfsm_instance_data omap4_vdd_mpu_vfsm_data = {
|
||||
.voltsetup_reg = OMAP4_PRM_VOLTSETUP_MPU_RET_SLEEP_OFFSET,
|
||||
};
|
||||
|
||||
static struct omap_vdd_info omap4_vdd_mpu_info = {
|
||||
.vp_data = &omap4_vp_mpu_data,
|
||||
.vc_data = &omap4_vc_mpu_data,
|
||||
.vfsm = &omap4_vdd_mpu_vfsm_data,
|
||||
.voltdm = {
|
||||
.name = "mpu",
|
||||
},
|
||||
};
|
||||
|
||||
static const struct omap_vfsm_instance_data omap4_vdd_iva_vfsm_data = {
|
||||
.voltsetup_reg = OMAP4_PRM_VOLTSETUP_IVA_RET_SLEEP_OFFSET,
|
||||
};
|
||||
|
||||
static struct omap_vdd_info omap4_vdd_iva_info = {
|
||||
.vp_data = &omap4_vp_iva_data,
|
||||
.vc_data = &omap4_vc_iva_data,
|
||||
.vfsm = &omap4_vdd_iva_vfsm_data,
|
||||
.voltdm = {
|
||||
.name = "iva",
|
||||
},
|
||||
};
|
||||
|
||||
static const struct omap_vfsm_instance_data omap4_vdd_core_vfsm_data = {
|
||||
.voltsetup_reg = OMAP4_PRM_VOLTSETUP_CORE_RET_SLEEP_OFFSET,
|
||||
};
|
||||
|
||||
static struct omap_vdd_info omap4_vdd_core_info = {
|
||||
.vp_data = &omap4_vp_core_data,
|
||||
.vc_data = &omap4_vc_core_data,
|
||||
.vfsm = &omap4_vdd_core_vfsm_data,
|
||||
.voltdm = {
|
||||
.name = "core",
|
||||
},
|
||||
};
|
||||
|
||||
/* OMAP4 VDD structures */
|
||||
static struct omap_vdd_info *omap4_vdd_info[] = {
|
||||
&omap4_vdd_mpu_info,
|
||||
&omap4_vdd_iva_info,
|
||||
&omap4_vdd_core_info,
|
||||
};
|
||||
|
||||
/* OMAP4 specific voltage init functions */
|
||||
static int __init omap44xx_voltage_early_init(void)
|
||||
{
|
||||
s16 prm_mod = OMAP4430_PRM_DEVICE_INST;
|
||||
s16 prm_irqst_ocp_mod = OMAP4430_PRM_OCP_SOCKET_INST;
|
||||
|
||||
if (!cpu_is_omap44xx())
|
||||
return 0;
|
||||
|
||||
/*
|
||||
* XXX Will depend on the process, validation, and binning
|
||||
* for the currently-running IC
|
||||
*/
|
||||
omap4_vdd_mpu_info.volt_data = omap44xx_vdd_mpu_volt_data;
|
||||
omap4_vdd_iva_info.volt_data = omap44xx_vdd_iva_volt_data;
|
||||
omap4_vdd_core_info.volt_data = omap44xx_vdd_core_volt_data;
|
||||
|
||||
return omap_voltage_early_init(prm_mod, prm_irqst_ocp_mod,
|
||||
omap4_vdd_info,
|
||||
ARRAY_SIZE(omap4_vdd_info));
|
||||
};
|
||||
core_initcall(omap44xx_voltage_early_init);
|
|
@ -0,0 +1,143 @@
|
|||
/*
|
||||
* OMAP3/4 Voltage Processor (VP) structure and macro definitions
|
||||
*
|
||||
* Copyright (C) 2007, 2010 Texas Instruments, Inc.
|
||||
* Rajendra Nayak <rnayak@ti.com>
|
||||
* Lesly A M <x0080970@ti.com>
|
||||
* Thara Gopinath <thara@ti.com>
|
||||
*
|
||||
* Copyright (C) 2008, 2011 Nokia Corporation
|
||||
* Kalle Jokiniemi
|
||||
* Paul Walmsley
|
||||
*
|
||||
* 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_OMAP2_VP_H
|
||||
#define __ARCH_ARM_MACH_OMAP2_VP_H
|
||||
|
||||
#include <linux/kernel.h>
|
||||
|
||||
/* XXX document */
|
||||
#define VP_IDLE_TIMEOUT 200
|
||||
#define VP_TRANXDONE_TIMEOUT 300
|
||||
|
||||
|
||||
/**
|
||||
* struct omap_vp_common_data - register data common to all VDDs
|
||||
* @vpconfig_errorgain_mask: ERRORGAIN bitmask in the PRM_VP*_CONFIG reg
|
||||
* @vpconfig_initvoltage_mask: INITVOLTAGE bitmask in the PRM_VP*_CONFIG reg
|
||||
* @vpconfig_timeouten_mask: TIMEOUT bitmask in the PRM_VP*_CONFIG reg
|
||||
* @vpconfig_initvdd: INITVDD bitmask in the PRM_VP*_CONFIG reg
|
||||
* @vpconfig_forceupdate: FORCEUPDATE bitmask in the PRM_VP*_CONFIG reg
|
||||
* @vpconfig_vpenable: VPENABLE bitmask in the PRM_VP*_CONFIG reg
|
||||
* @vpconfig_erroroffset_shift: ERROROFFSET field shift in PRM_VP*_CONFIG reg
|
||||
* @vpconfig_errorgain_shift: ERRORGAIN field shift in PRM_VP*_CONFIG reg
|
||||
* @vpconfig_initvoltage_shift: INITVOLTAGE field shift in PRM_VP*_CONFIG reg
|
||||
* @vpconfig_stepmin_shift: VSTEPMIN field shift in the PRM_VP*_VSTEPMIN reg
|
||||
* @vpconfig_smpswaittimemin_shift: SMPSWAITTIMEMIN field shift in PRM_VP*_VSTEPMIN reg
|
||||
* @vpconfig_stepmax_shift: VSTEPMAX field shift in the PRM_VP*_VSTEPMAX reg
|
||||
* @vpconfig_smpswaittimemax_shift: SMPSWAITTIMEMAX field shift in PRM_VP*_VSTEPMAX reg
|
||||
* @vpconfig_vlimitto_vddmin_shift: VDDMIN field shift in PRM_VP*_VLIMITTO reg
|
||||
* @vpconfig_vlimitto_vddmax_shift: VDDMAX field shift in PRM_VP*_VLIMITTO reg
|
||||
* @vpconfig_vlimitto_timeout_shift: TIMEOUT field shift in PRM_VP*_VLIMITTO reg
|
||||
*
|
||||
* XXX It it not necessary to have both a mask and a shift for the same
|
||||
* bitfield - remove one
|
||||
* XXX Many of these fields are wrongly named -- e.g., vpconfig_smps* -- fix!
|
||||
*/
|
||||
struct omap_vp_common_data {
|
||||
u32 vpconfig_errorgain_mask;
|
||||
u32 vpconfig_initvoltage_mask;
|
||||
u32 vpconfig_timeouten;
|
||||
u32 vpconfig_initvdd;
|
||||
u32 vpconfig_forceupdate;
|
||||
u32 vpconfig_vpenable;
|
||||
u8 vpconfig_erroroffset_shift;
|
||||
u8 vpconfig_errorgain_shift;
|
||||
u8 vpconfig_initvoltage_shift;
|
||||
u8 vstepmin_stepmin_shift;
|
||||
u8 vstepmin_smpswaittimemin_shift;
|
||||
u8 vstepmax_stepmax_shift;
|
||||
u8 vstepmax_smpswaittimemax_shift;
|
||||
u8 vlimitto_vddmin_shift;
|
||||
u8 vlimitto_vddmax_shift;
|
||||
u8 vlimitto_timeout_shift;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct omap_vp_prm_irqst_data - PRM_IRQSTATUS_MPU.VP_TRANXDONE_ST data
|
||||
* @prm_irqst_reg: reg offset for PRM_IRQSTATUS_MPU from top of PRM
|
||||
* @tranxdone_status: VP_TRANXDONE_ST bitmask in PRM_IRQSTATUS_MPU reg
|
||||
*
|
||||
* XXX prm_irqst_reg does not belong here
|
||||
* XXX Note that on OMAP3, VP_TRANXDONE interrupt may not work due to a
|
||||
* hardware bug
|
||||
* XXX This structure is probably not needed
|
||||
*/
|
||||
struct omap_vp_prm_irqst_data {
|
||||
u8 prm_irqst_reg;
|
||||
u32 tranxdone_status;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct omap_vp_instance_data - VP register offsets (per-VDD)
|
||||
* @vp_common: pointer to struct omap_vp_common_data * for this SoC
|
||||
* @prm_irqst_data: pointer to struct omap_vp_prm_irqst_data for this VDD
|
||||
* @vpconfig: PRM_VP*_CONFIG reg offset from PRM start
|
||||
* @vstepmin: PRM_VP*_VSTEPMIN reg offset from PRM start
|
||||
* @vlimitto: PRM_VP*_VLIMITTO reg offset from PRM start
|
||||
* @vstatus: PRM_VP*_VSTATUS reg offset from PRM start
|
||||
* @voltage: PRM_VP*_VOLTAGE reg offset from PRM start
|
||||
*
|
||||
* XXX vp_common is probably not needed since it is per-SoC
|
||||
*/
|
||||
struct omap_vp_instance_data {
|
||||
const struct omap_vp_common_data *vp_common;
|
||||
const struct omap_vp_prm_irqst_data *prm_irqst_data;
|
||||
u8 vpconfig;
|
||||
u8 vstepmin;
|
||||
u8 vstepmax;
|
||||
u8 vlimitto;
|
||||
u8 vstatus;
|
||||
u8 voltage;
|
||||
};
|
||||
|
||||
/**
|
||||
* struct omap_vp_runtime_data - VP data populated at runtime by code
|
||||
* @vpconfig_erroroffset: value of ERROROFFSET bitfield in PRM_VP*_CONFIG
|
||||
* @vpconfig_errorgain: value of ERRORGAIN bitfield in PRM_VP*_CONFIG
|
||||
* @vstepmin_smpswaittimemin: value of SMPSWAITTIMEMIN bitfield in PRM_VP*_VSTEPMIN
|
||||
* @vstepmax_smpswaittimemax: value of SMPSWAITTIMEMAX bitfield in PRM_VP*_VSTEPMAX
|
||||
* @vlimitto_timeout: value of TIMEOUT bitfield in PRM_VP*_VLIMITTO
|
||||
* @vstepmin_stepmin: value of VSTEPMIN bitfield in PRM_VP*_VSTEPMIN
|
||||
* @vstepmax_stepmax: value of VSTEPMAX bitfield in PRM_VP*_VSTEPMAX
|
||||
* @vlimitto_vddmin: value of VDDMIN bitfield in PRM_VP*_VLIMITTO
|
||||
* @vlimitto_vddmax: value of VDDMAX bitfield in PRM_VP*_VLIMITTO
|
||||
*
|
||||
* XXX Is this structure really needed? Why not just program the
|
||||
* device directly? They are in PRM space, therefore in the WKUP
|
||||
* powerdomain, so register contents should not be lost in off-mode.
|
||||
* XXX Some of these fields are incorrectly named, e.g., vstep*
|
||||
*/
|
||||
struct omap_vp_runtime_data {
|
||||
u32 vpconfig_erroroffset;
|
||||
u16 vpconfig_errorgain;
|
||||
u16 vstepmin_smpswaittimemin;
|
||||
u16 vstepmax_smpswaittimemax;
|
||||
u16 vlimitto_timeout;
|
||||
u8 vstepmin_stepmin;
|
||||
u8 vstepmax_stepmax;
|
||||
u8 vlimitto_vddmin;
|
||||
u8 vlimitto_vddmax;
|
||||
};
|
||||
|
||||
extern struct omap_vp_instance_data omap3_vp1_data;
|
||||
extern struct omap_vp_instance_data omap3_vp2_data;
|
||||
|
||||
extern struct omap_vp_instance_data omap4_vp_mpu_data;
|
||||
extern struct omap_vp_instance_data omap4_vp_iva_data;
|
||||
extern struct omap_vp_instance_data omap4_vp_core_data;
|
||||
|
||||
#endif
|
|
@ -0,0 +1,82 @@
|
|||
/*
|
||||
* OMAP3 Voltage Processor (VP) data
|
||||
*
|
||||
* Copyright (C) 2007, 2010 Texas Instruments, Inc.
|
||||
* Rajendra Nayak <rnayak@ti.com>
|
||||
* Lesly A M <x0080970@ti.com>
|
||||
* Thara Gopinath <thara@ti.com>
|
||||
*
|
||||
* Copyright (C) 2008, 2011 Nokia Corporation
|
||||
* Kalle Jokiniemi
|
||||
* Paul Walmsley
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include <linux/io.h>
|
||||
#include <linux/err.h>
|
||||
#include <linux/init.h>
|
||||
|
||||
#include <plat/common.h>
|
||||
|
||||
#include "prm-regbits-34xx.h"
|
||||
#include "voltage.h"
|
||||
|
||||
#include "vp.h"
|
||||
|
||||
/*
|
||||
* VP data common to 34xx/36xx chips
|
||||
* XXX This stuff presumably belongs in the vp3xxx.c or vp.c file.
|
||||
*/
|
||||
static const struct omap_vp_common_data omap3_vp_common = {
|
||||
.vpconfig_erroroffset_shift = OMAP3430_ERROROFFSET_SHIFT,
|
||||
.vpconfig_errorgain_mask = OMAP3430_ERRORGAIN_MASK,
|
||||
.vpconfig_errorgain_shift = OMAP3430_ERRORGAIN_SHIFT,
|
||||
.vpconfig_initvoltage_shift = OMAP3430_INITVOLTAGE_SHIFT,
|
||||
.vpconfig_initvoltage_mask = OMAP3430_INITVOLTAGE_MASK,
|
||||
.vpconfig_timeouten = OMAP3430_TIMEOUTEN_MASK,
|
||||
.vpconfig_initvdd = OMAP3430_INITVDD_MASK,
|
||||
.vpconfig_forceupdate = OMAP3430_FORCEUPDATE_MASK,
|
||||
.vpconfig_vpenable = OMAP3430_VPENABLE_MASK,
|
||||
.vstepmin_smpswaittimemin_shift = OMAP3430_SMPSWAITTIMEMIN_SHIFT,
|
||||
.vstepmax_smpswaittimemax_shift = OMAP3430_SMPSWAITTIMEMAX_SHIFT,
|
||||
.vstepmin_stepmin_shift = OMAP3430_VSTEPMIN_SHIFT,
|
||||
.vstepmax_stepmax_shift = OMAP3430_VSTEPMAX_SHIFT,
|
||||
.vlimitto_vddmin_shift = OMAP3430_VDDMIN_SHIFT,
|
||||
.vlimitto_vddmax_shift = OMAP3430_VDDMAX_SHIFT,
|
||||
.vlimitto_timeout_shift = OMAP3430_TIMEOUT_SHIFT,
|
||||
};
|
||||
|
||||
static const struct omap_vp_prm_irqst_data omap3_vp1_prm_irqst_data = {
|
||||
.prm_irqst_reg = OMAP3_PRM_IRQSTATUS_MPU_OFFSET,
|
||||
.tranxdone_status = OMAP3430_VP1_TRANXDONE_ST_MASK,
|
||||
};
|
||||
|
||||
struct omap_vp_instance_data omap3_vp1_data = {
|
||||
.vp_common = &omap3_vp_common,
|
||||
.vpconfig = OMAP3_PRM_VP1_CONFIG_OFFSET,
|
||||
.vstepmin = OMAP3_PRM_VP1_VSTEPMIN_OFFSET,
|
||||
.vstepmax = OMAP3_PRM_VP1_VSTEPMAX_OFFSET,
|
||||
.vlimitto = OMAP3_PRM_VP1_VLIMITTO_OFFSET,
|
||||
.vstatus = OMAP3_PRM_VP1_STATUS_OFFSET,
|
||||
.voltage = OMAP3_PRM_VP1_VOLTAGE_OFFSET,
|
||||
.prm_irqst_data = &omap3_vp1_prm_irqst_data,
|
||||
};
|
||||
|
||||
static const struct omap_vp_prm_irqst_data omap3_vp2_prm_irqst_data = {
|
||||
.prm_irqst_reg = OMAP3_PRM_IRQSTATUS_MPU_OFFSET,
|
||||
.tranxdone_status = OMAP3430_VP2_TRANXDONE_ST_MASK,
|
||||
};
|
||||
|
||||
struct omap_vp_instance_data omap3_vp2_data = {
|
||||
.vp_common = &omap3_vp_common,
|
||||
.vpconfig = OMAP3_PRM_VP2_CONFIG_OFFSET,
|
||||
.vstepmin = OMAP3_PRM_VP2_VSTEPMIN_OFFSET,
|
||||
.vstepmax = OMAP3_PRM_VP2_VSTEPMAX_OFFSET,
|
||||
.vlimitto = OMAP3_PRM_VP2_VLIMITTO_OFFSET,
|
||||
.vstatus = OMAP3_PRM_VP2_STATUS_OFFSET,
|
||||
.voltage = OMAP3_PRM_VP2_VOLTAGE_OFFSET,
|
||||
.prm_irqst_data = &omap3_vp2_prm_irqst_data,
|
||||
};
|
|
@ -0,0 +1,100 @@
|
|||
/*
|
||||
* OMAP3 Voltage Processor (VP) data
|
||||
*
|
||||
* Copyright (C) 2007, 2010 Texas Instruments, Inc.
|
||||
* Rajendra Nayak <rnayak@ti.com>
|
||||
* Lesly A M <x0080970@ti.com>
|
||||
* Thara Gopinath <thara@ti.com>
|
||||
*
|
||||
* Copyright (C) 2008, 2011 Nokia Corporation
|
||||
* Kalle Jokiniemi
|
||||
* Paul Walmsley
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include <linux/io.h>
|
||||
#include <linux/err.h>
|
||||
#include <linux/init.h>
|
||||
|
||||
#include <plat/common.h>
|
||||
|
||||
#include "prm44xx.h"
|
||||
#include "prm-regbits-44xx.h"
|
||||
#include "voltage.h"
|
||||
|
||||
#include "vp.h"
|
||||
|
||||
/*
|
||||
* VP data common to 44xx chips
|
||||
* XXX This stuff presumably belongs in the vp44xx.c or vp.c file.
|
||||
*/
|
||||
static const struct omap_vp_common_data omap4_vp_common = {
|
||||
.vpconfig_erroroffset_shift = OMAP4430_ERROROFFSET_SHIFT,
|
||||
.vpconfig_errorgain_mask = OMAP4430_ERRORGAIN_MASK,
|
||||
.vpconfig_errorgain_shift = OMAP4430_ERRORGAIN_SHIFT,
|
||||
.vpconfig_initvoltage_shift = OMAP4430_INITVOLTAGE_SHIFT,
|
||||
.vpconfig_initvoltage_mask = OMAP4430_INITVOLTAGE_MASK,
|
||||
.vpconfig_timeouten = OMAP4430_TIMEOUTEN_MASK,
|
||||
.vpconfig_initvdd = OMAP4430_INITVDD_MASK,
|
||||
.vpconfig_forceupdate = OMAP4430_FORCEUPDATE_MASK,
|
||||
.vpconfig_vpenable = OMAP4430_VPENABLE_MASK,
|
||||
.vstepmin_smpswaittimemin_shift = OMAP4430_SMPSWAITTIMEMIN_SHIFT,
|
||||
.vstepmax_smpswaittimemax_shift = OMAP4430_SMPSWAITTIMEMAX_SHIFT,
|
||||
.vstepmin_stepmin_shift = OMAP4430_VSTEPMIN_SHIFT,
|
||||
.vstepmax_stepmax_shift = OMAP4430_VSTEPMAX_SHIFT,
|
||||
.vlimitto_vddmin_shift = OMAP4430_VDDMIN_SHIFT,
|
||||
.vlimitto_vddmax_shift = OMAP4430_VDDMAX_SHIFT,
|
||||
.vlimitto_timeout_shift = OMAP4430_TIMEOUT_SHIFT,
|
||||
};
|
||||
|
||||
static const struct omap_vp_prm_irqst_data omap4_vp_mpu_prm_irqst_data = {
|
||||
.prm_irqst_reg = OMAP4_PRM_IRQSTATUS_MPU_2_OFFSET,
|
||||
.tranxdone_status = OMAP4430_VP_MPU_TRANXDONE_ST_MASK,
|
||||
};
|
||||
|
||||
struct omap_vp_instance_data omap4_vp_mpu_data = {
|
||||
.vp_common = &omap4_vp_common,
|
||||
.vpconfig = OMAP4_PRM_VP_MPU_CONFIG_OFFSET,
|
||||
.vstepmin = OMAP4_PRM_VP_MPU_VSTEPMIN_OFFSET,
|
||||
.vstepmax = OMAP4_PRM_VP_MPU_VSTEPMAX_OFFSET,
|
||||
.vlimitto = OMAP4_PRM_VP_MPU_VLIMITTO_OFFSET,
|
||||
.vstatus = OMAP4_PRM_VP_MPU_STATUS_OFFSET,
|
||||
.voltage = OMAP4_PRM_VP_MPU_VOLTAGE_OFFSET,
|
||||
.prm_irqst_data = &omap4_vp_mpu_prm_irqst_data,
|
||||
};
|
||||
|
||||
static const struct omap_vp_prm_irqst_data omap4_vp_iva_prm_irqst_data = {
|
||||
.prm_irqst_reg = OMAP4_PRM_IRQSTATUS_MPU_OFFSET,
|
||||
.tranxdone_status = OMAP4430_VP_IVA_TRANXDONE_ST_MASK,
|
||||
};
|
||||
|
||||
struct omap_vp_instance_data omap4_vp_iva_data = {
|
||||
.vp_common = &omap4_vp_common,
|
||||
.vpconfig = OMAP4_PRM_VP_IVA_CONFIG_OFFSET,
|
||||
.vstepmin = OMAP4_PRM_VP_IVA_VSTEPMIN_OFFSET,
|
||||
.vstepmax = OMAP4_PRM_VP_IVA_VSTEPMAX_OFFSET,
|
||||
.vlimitto = OMAP4_PRM_VP_IVA_VLIMITTO_OFFSET,
|
||||
.vstatus = OMAP4_PRM_VP_IVA_STATUS_OFFSET,
|
||||
.voltage = OMAP4_PRM_VP_IVA_VOLTAGE_OFFSET,
|
||||
.prm_irqst_data = &omap4_vp_iva_prm_irqst_data,
|
||||
};
|
||||
|
||||
static const struct omap_vp_prm_irqst_data omap4_vp_core_prm_irqst_data = {
|
||||
.prm_irqst_reg = OMAP4_PRM_IRQSTATUS_MPU_OFFSET,
|
||||
.tranxdone_status = OMAP4430_VP_CORE_TRANXDONE_ST_MASK,
|
||||
};
|
||||
|
||||
struct omap_vp_instance_data omap4_vp_core_data = {
|
||||
.vp_common = &omap4_vp_common,
|
||||
.vpconfig = OMAP4_PRM_VP_CORE_CONFIG_OFFSET,
|
||||
.vstepmin = OMAP4_PRM_VP_CORE_VSTEPMIN_OFFSET,
|
||||
.vstepmax = OMAP4_PRM_VP_CORE_VSTEPMAX_OFFSET,
|
||||
.vlimitto = OMAP4_PRM_VP_CORE_VLIMITTO_OFFSET,
|
||||
.vstatus = OMAP4_PRM_VP_CORE_STATUS_OFFSET,
|
||||
.voltage = OMAP4_PRM_VP_CORE_VOLTAGE_OFFSET,
|
||||
.prm_irqst_data = &omap4_vp_core_prm_irqst_data,
|
||||
};
|
||||
|
|
@ -35,7 +35,6 @@
|
|||
#include <linux/ioport.h>
|
||||
#include <linux/spinlock.h>
|
||||
#include <plat/cpu.h>
|
||||
#include <plat/voltage.h>
|
||||
|
||||
struct omap_device;
|
||||
|
||||
|
|
Loading…
Reference in New Issue