aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-omap2/vc.h
diff options
context:
space:
mode:
authorKevin Hilman <khilman@ti.com>2011-03-29 18:57:16 -0400
committerKevin Hilman <khilman@ti.com>2011-09-15 15:08:57 -0400
commit24d3194a2c9bc4d2315117915d4d22c395c07fd5 (patch)
treed7a5848a3b67f8288fc974bb0b0eab6dacb7ea97 /arch/arm/mach-omap2/vc.h
parent08d1c9a3e2dc7a285db7c689c42963d0f5271c1f (diff)
OMAP3+: VC: abstract out channel configuration
VC channel configuration is programmed based on settings coming from the PMIC configuration. Currently, the VC channel to PMIC mapping is a simple one-to-one mapping. Whenever a VC channel parameter is configured (i2c slave addres, PMIC register address, on/ret/off command), the corresponding bits are enabled in the VC channel configuration register. If necessary, the programmability of channel configuration settings could be extended to board/PMIC files, however, because this patch changes the channel configuration to be programmed based on existing values from the PMIC settings, it may not be required. Also note that starting with OMAP4, where there are more than 2 channels, one channel is identified as the "default" channel. When any of the bits in the channel config for the other channels are zero, it means to use the default channel. The OMAP4 TRM (at least through NDA version Q) is wrong in describing which is the default channel. The default channel on OMAP4 is MPU, not CORE as decribed in the TRM. Signed-off-by: Kevin Hilman <khilman@ti.com>
Diffstat (limited to 'arch/arm/mach-omap2/vc.h')
-rw-r--r--arch/arm/mach-omap2/vc.h8
1 files changed, 8 insertions, 0 deletions
diff --git a/arch/arm/mach-omap2/vc.h b/arch/arm/mach-omap2/vc.h
index 6e8806b59823..4e1913748d2a 100644
--- a/arch/arm/mach-omap2/vc.h
+++ b/arch/arm/mach-omap2/vc.h
@@ -54,8 +54,12 @@ struct omap_vc_common {
54 u8 cmd_onlp_shift; 54 u8 cmd_onlp_shift;
55 u8 cmd_ret_shift; 55 u8 cmd_ret_shift;
56 u8 cmd_off_shift; 56 u8 cmd_off_shift;
57 u8 cfg_channel_reg;
57}; 58};
58 59
60/* omap_vc_channel.flags values */
61#define OMAP_VC_CHANNEL_DEFAULT BIT(0)
62
59/** 63/**
60 * struct omap_vc_channel - VC per-instance data 64 * struct omap_vc_channel - VC per-instance data
61 * @i2c_slave_addr: I2C slave address of PMIC for this VC channel 65 * @i2c_slave_addr: I2C slave address of PMIC for this VC channel
@@ -67,6 +71,7 @@ struct omap_vc_common {
67 * @smps_volra_mask: VOLRA* bitmask in the PRM_VC_VOL_RA register 71 * @smps_volra_mask: VOLRA* bitmask in the PRM_VC_VOL_RA register
68 * @smps_cmdra_mask: CMDRA* bitmask in the PRM_VC_CMD_RA register 72 * @smps_cmdra_mask: CMDRA* bitmask in the PRM_VC_CMD_RA register
69 * @cmdval_reg: register for on/ret/off voltage level values for this channel 73 * @cmdval_reg: register for on/ret/off voltage level values for this channel
74 * @flags: VC channel-specific flags (optional)
70 */ 75 */
71struct omap_vc_channel { 76struct omap_vc_channel {
72 /* channel state */ 77 /* channel state */
@@ -74,6 +79,7 @@ struct omap_vc_channel {
74 u16 volt_reg_addr; 79 u16 volt_reg_addr;
75 u16 cmd_reg_addr; 80 u16 cmd_reg_addr;
76 u16 setup_time; 81 u16 setup_time;
82 u8 cfg_channel;
77 83
78 /* register access data */ 84 /* register access data */
79 const struct omap_vc_common *common; 85 const struct omap_vc_common *common;
@@ -81,6 +87,8 @@ struct omap_vc_channel {
81 u32 smps_volra_mask; 87 u32 smps_volra_mask;
82 u32 smps_cmdra_mask; 88 u32 smps_cmdra_mask;
83 u8 cmdval_reg; 89 u8 cmdval_reg;
90 u8 cfg_channel_sa_shift;
91 u8 flags;
84}; 92};
85 93
86extern struct omap_vc_channel omap3_vc_mpu; 94extern struct omap_vc_channel omap3_vc_mpu;