OMAP3 SRF: Generic shared resource f/w
[linux-ginger.git] / arch / arm / mach-omap2 / smartreflex.h
blob2a0e8239474e49d70c9bfaa0e3a222c5bc8eda41
1 #ifndef __ARCH_ARM_MACH_OMAP3_SMARTREFLEX_H
2 #define __ARCH_ARM_MACH_OMAP3_SMARTREFLEX_H
3 /*
4 * linux/arch/arm/mach-omap2/smartreflex.h
6 * Copyright (C) 2008 Nokia Corporation
7 * Kalle Jokiniemi
9 * Copyright (C) 2007 Texas Instruments, Inc.
10 * Lesly A M <x0080970@ti.com>
12 * This program is free software; you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License version 2 as
14 * published by the Free Software Foundation.
17 #define PHY_TO_OFF_PM_MASTER(p) (p - 0x36)
18 #define PHY_TO_OFF_PM_RECIEVER(p) (p - 0x5b)
19 #define PHY_TO_OFF_PM_INT(p) (p - 0x2e)
21 /* SMART REFLEX REG ADDRESS OFFSET */
22 #define SRCONFIG 0x00
23 #define SRSTATUS 0x04
24 #define SENVAL 0x08
25 #define SENMIN 0x0C
26 #define SENMAX 0x10
27 #define SENAVG 0x14
28 #define AVGWEIGHT 0x18
29 #define NVALUERECIPROCAL 0x1C
30 #define SENERROR 0x20
31 #define ERRCONFIG 0x24
33 /* SR Modules */
34 #define SR1 1
35 #define SR2 2
37 #define SR_FAIL 1
38 #define SR_PASS 0
40 #define SR_TRUE 1
41 #define SR_FALSE 0
43 #define GAIN_MAXLIMIT 16
44 #define R_MAXLIMIT 256
46 #define SR1_CLK_ENABLE BIT(6)
47 #define SR2_CLK_ENABLE BIT(7)
49 /* PRM_VP1_CONFIG */
50 #define PRM_VP1_CONFIG_ERROROFFSET (0x00 << 24)
51 #define PRM_VP1_CONFIG_ERRORGAIN (0x20 << 16)
53 #define PRM_VP1_CONFIG_INITVOLTAGE (0x30 << 8) /* 1.2 volt */
54 #define PRM_VP1_CONFIG_TIMEOUTEN BIT(3)
55 #define PRM_VP1_CONFIG_INITVDD BIT(2)
56 #define PRM_VP1_CONFIG_FORCEUPDATE BIT(1)
57 #define PRM_VP1_CONFIG_VPENABLE BIT(0)
59 /* PRM_VP1_VSTEPMIN */
60 #define PRM_VP1_VSTEPMIN_SMPSWAITTIMEMIN (0x01F4 << 8)
61 #define PRM_VP1_VSTEPMIN_VSTEPMIN BIT(0)
63 /* PRM_VP1_VSTEPMAX */
64 #define PRM_VP1_VSTEPMAX_SMPSWAITTIMEMAX (0x01F4 << 8)
65 #define PRM_VP1_VSTEPMAX_VSTEPMAX (0x04 << 0)
67 /* PRM_VP1_VLIMITTO */
68 #define PRM_VP1_VLIMITTO_VDDMAX (0x3C << 24)
69 #define PRM_VP1_VLIMITTO_VDDMIN (0x0 << 16)
70 #define PRM_VP1_VLIMITTO_TIMEOUT (0xFFFF << 0)
72 /* PRM_VP2_CONFIG */
73 #define PRM_VP2_CONFIG_ERROROFFSET (0x00 << 24)
74 #define PRM_VP2_CONFIG_ERRORGAIN (0x20 << 16)
76 #define PRM_VP2_CONFIG_INITVOLTAGE (0x30 << 8) /* 1.2 volt */
77 #define PRM_VP2_CONFIG_TIMEOUTEN BIT(3)
78 #define PRM_VP2_CONFIG_INITVDD BIT(2)
79 #define PRM_VP2_CONFIG_FORCEUPDATE BIT(1)
80 #define PRM_VP2_CONFIG_VPENABLE BIT(0)
82 /* PRM_VP2_VSTEPMIN */
83 #define PRM_VP2_VSTEPMIN_SMPSWAITTIMEMIN (0x01F4 << 8)
84 #define PRM_VP2_VSTEPMIN_VSTEPMIN BIT(0)
86 /* PRM_VP2_VSTEPMAX */
87 #define PRM_VP2_VSTEPMAX_SMPSWAITTIMEMAX (0x01F4 << 8)
88 #define PRM_VP2_VSTEPMAX_VSTEPMAX (0x04 << 0)
90 /* PRM_VP2_VLIMITTO */
91 #define PRM_VP2_VLIMITTO_VDDMAX (0x2C << 24)
92 #define PRM_VP2_VLIMITTO_VDDMIN (0x0 << 16)
93 #define PRM_VP2_VLIMITTO_TIMEOUT (0xFFFF << 0)
95 /* SRCONFIG */
96 #define SR1_SRCONFIG_ACCUMDATA (0x1F4 << 22)
97 #define SR2_SRCONFIG_ACCUMDATA (0x1F4 << 22)
99 #define SRCLKLENGTH_12MHZ_SYSCLK 0x3C
100 #define SRCLKLENGTH_13MHZ_SYSCLK 0x41
101 #define SRCLKLENGTH_19MHZ_SYSCLK 0x60
102 #define SRCLKLENGTH_26MHZ_SYSCLK 0x82
103 #define SRCLKLENGTH_38MHZ_SYSCLK 0xC0
105 #define SRCONFIG_SRCLKLENGTH_SHIFT 12
106 #define SRCONFIG_SENNENABLE_SHIFT 5
107 #define SRCONFIG_SENPENABLE_SHIFT 3
109 #define SRCONFIG_SRENABLE BIT(11)
110 #define SRCONFIG_SENENABLE BIT(10)
111 #define SRCONFIG_ERRGEN_EN BIT(9)
112 #define SRCONFIG_MINMAXAVG_EN BIT(8)
114 #define SRCONFIG_DELAYCTRL BIT(2)
115 #define SRCONFIG_CLKCTRL (0x00 << 0)
117 /* AVGWEIGHT */
118 #define SR1_AVGWEIGHT_SENPAVGWEIGHT (0x03 << 2)
119 #define SR1_AVGWEIGHT_SENNAVGWEIGHT (0x03 << 0)
121 #define SR2_AVGWEIGHT_SENPAVGWEIGHT BIT(2)
122 #define SR2_AVGWEIGHT_SENNAVGWEIGHT BIT(0)
124 /* NVALUERECIPROCAL */
125 #define NVALUERECIPROCAL_SENPGAIN_SHIFT 20
126 #define NVALUERECIPROCAL_SENNGAIN_SHIFT 16
127 #define NVALUERECIPROCAL_RNSENP_SHIFT 8
128 #define NVALUERECIPROCAL_RNSENN_SHIFT 0
130 /* ERRCONFIG */
131 #define SR_CLKACTIVITY_MASK (0x03 << 20)
132 #define SR_ERRWEIGHT_MASK (0x07 << 16)
133 #define SR_ERRMAXLIMIT_MASK (0xFF << 8)
134 #define SR_ERRMINLIMIT_MASK (0xFF << 0)
136 #define SR_CLKACTIVITY_IOFF_FOFF (0x00 << 20)
137 #define SR_CLKACTIVITY_IOFF_FON (0x02 << 20)
139 #define ERRCONFIG_VPBOUNDINTEN BIT(31)
140 #define ERRCONFIG_VPBOUNDINTST BIT(30)
142 #define SR1_ERRWEIGHT (0x07 << 16)
143 #define SR1_ERRMAXLIMIT (0x02 << 8)
144 #define SR1_ERRMINLIMIT (0xFA << 0)
146 #define SR2_ERRWEIGHT (0x07 << 16)
147 #define SR2_ERRMAXLIMIT (0x02 << 8)
148 #define SR2_ERRMINLIMIT (0xF9 << 0)
150 /* T2 SMART REFLEX */
151 #define R_SRI2C_SLAVE_ADDR 0x12
152 #define R_VDD1_SR_CONTROL 0x00
153 #define R_VDD2_SR_CONTROL 0x01
154 #define T2_SMPS_UPDATE_DELAY 360 /* In uSec */
156 /* Vmode control */
157 #define R_DCDC_GLOBAL_CFG PHY_TO_OFF_PM_RECIEVER(0x61)
159 #define R_VDD1_VSEL PHY_TO_OFF_PM_RECIEVER(0xb9)
160 #define R_VDD1_VMODE_CFG PHY_TO_OFF_PM_RECIEVER(0xba)
161 #define R_VDD1_VFLOOR PHY_TO_OFF_PM_RECIEVER(0xbb)
162 #define R_VDD1_VROOF PHY_TO_OFF_PM_RECIEVER(0xbc)
163 #define R_VDD1_STEP PHY_TO_OFF_PM_RECIEVER(0xbd)
165 #define R_VDD2_VSEL PHY_TO_OFF_PM_RECIEVER(0xc7)
166 #define R_VDD2_VMODE_CFG PHY_TO_OFF_PM_RECIEVER(0xc8)
167 #define R_VDD2_VFLOOR PHY_TO_OFF_PM_RECIEVER(0xc9)
168 #define R_VDD2_VROOF PHY_TO_OFF_PM_RECIEVER(0xca)
169 #define R_VDD2_STEP PHY_TO_OFF_PM_RECIEVER(0xcb)
171 /* R_DCDC_GLOBAL_CFG register, SMARTREFLEX_ENABLE values */
172 #define DCDC_GLOBAL_CFG_ENABLE_SRFLX 0x08
174 #define PRCM_MAX_SYSC_REGS 30
177 * XXX: These should be removed/moved from here once we have a working DVFS
178 * implementation in place
180 #define AT_3430 1 /*3430 ES 1.0 */
181 #define AT_3430_ES2 2 /*3430 ES 2.0 */
183 #define ID_OPP 0xE2 /*OPP*/
185 /* DEVICE ID/DPLL ID/CLOCK ID: bits 28-31 for OMAP type */
186 #define OMAP_TYPE_SHIFT 28
187 #define OMAP_TYPE_MASK 0xF
188 /* OPP ID: bits: 0-4 for OPP number */
189 #define OPP_NO_POS 0
190 #define OPP_NO_MASK 0x1F
191 /* OPP ID: bits: 5-6 for VDD */
192 #define VDD_NO_POS 5
193 #define VDD_NO_MASK 0x3
194 /* Other IDs: bits 20-27 for ID type */
195 /* These IDs have bits 25,26,27 as 1 */
196 #define OTHER_ID_TYPE_SHIFT 20
197 #define OTHER_ID_TYPE_MASK 0xFF
199 #define OTHER_ID_TYPE(X) ((X & OTHER_ID_TYPE_MASK) << OTHER_ID_TYPE_SHIFT)
200 #define ID_OPP_NO(X) ((X & OPP_NO_MASK) << OPP_NO_POS)
201 #define ID_VDD(X) ((X & VDD_NO_MASK) << VDD_NO_POS)
202 #define OMAP(X) ((X >> OMAP_TYPE_SHIFT) & OMAP_TYPE_MASK)
203 #define get_opp_no(X) ((X >> OPP_NO_POS) & OPP_NO_MASK)
204 #define get_vdd(X) ((X >> VDD_NO_POS) & VDD_NO_MASK)
206 /* VDD1 OPPs */
207 #define PRCM_VDD1_OPP1 (OMAP(AT_3430_ES2) | OTHER_ID_TYPE(ID_OPP) | \
208 ID_VDD(PRCM_VDD1) | ID_OPP_NO(0x1))
209 #define PRCM_VDD1_OPP2 (OMAP(AT_3430_ES2) | OTHER_ID_TYPE(ID_OPP) | \
210 ID_VDD(PRCM_VDD1) | ID_OPP_NO(0x2))
211 #define PRCM_VDD1_OPP3 (OMAP(AT_3430_ES2) | OTHER_ID_TYPE(ID_OPP) | \
212 ID_VDD(PRCM_VDD1) | ID_OPP_NO(0x3))
213 #define PRCM_VDD1_OPP4 (OMAP(AT_3430_ES2) | OTHER_ID_TYPE(ID_OPP) | \
214 ID_VDD(PRCM_VDD1) | ID_OPP_NO(0x4))
215 #define PRCM_VDD1_OPP5 (OMAP(AT_3430_ES2) | OTHER_ID_TYPE(ID_OPP) | \
216 ID_VDD(PRCM_VDD1) | ID_OPP_NO(0x5))
217 #define PRCM_NO_VDD1_OPPS 5
220 /* VDD2 OPPs */
221 #define PRCM_VDD2_OPP1 (OMAP(AT_3430_ES2) | OTHER_ID_TYPE(ID_OPP) | \
222 ID_VDD(PRCM_VDD2) | ID_OPP_NO(0x1))
223 #define PRCM_VDD2_OPP2 (OMAP(AT_3430_ES2) | OTHER_ID_TYPE(ID_OPP) | \
224 ID_VDD(PRCM_VDD2) | ID_OPP_NO(0x2))
225 #define PRCM_VDD2_OPP3 (OMAP(AT_3430_ES2) | OTHER_ID_TYPE(ID_OPP) | \
226 ID_VDD(PRCM_VDD2) | ID_OPP_NO(0x3))
227 #define PRCM_NO_VDD2_OPPS 3
228 /* XXX: end remove/move */
230 /* XXX: find more appropriate place for these once DVFS is in place */
231 extern u32 current_vdd1_opp;
232 extern u32 current_vdd2_opp;
234 #ifdef CONFIG_OMAP_SMARTREFLEX_TESTING
235 #define SR_TESTING_NVALUES 1
236 #else
237 #define SR_TESTING_NVALUES 0
238 #endif
241 * Smartreflex module enable/disable interface.
242 * NOTE: if smartreflex is not enabled from sysfs, these functions will not
243 * do anything.
245 #ifdef CONFIG_OMAP_SMARTREFLEX
246 void enable_smartreflex(int srid);
247 void disable_smartreflex(int srid);
248 int sr_voltagescale_vcbypass(u32 t_opp, u32 c_opp, u8 t_vsel, u8 c_vsel);
249 void sr_start_vddautocomap(int srid, u32 target_opp_no);
250 int sr_stop_vddautocomap(int srid);
251 #else
252 static inline void enable_smartreflex(int srid) {}
253 static inline void disable_smartreflex(int srid) {}
254 #endif
256 #endif