2 * This file is part of the coreboot project.
4 * Copyright 2015 Google Inc.
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; version 2 of the License.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
17 #include <device/pci_ids.h>
18 #include <device/pci_ops.h>
20 #include <soc/ramstage.h>
21 #include <soc/vr_config.h>
22 #include <console/console.h>
23 #include <intelblocks/cpulib.h>
25 /* Default values for domain configuration. PSI3 and PSI4 are disabled. */
26 static const struct vr_config default_configs
[NUM_VR_DOMAINS
] = {
28 .vr_config_enable
= 1,
29 .psi1threshold
= VR_CFG_AMP(20),
30 .psi2threshold
= VR_CFG_AMP(4),
31 .psi3threshold
= VR_CFG_AMP(1),
36 .icc_max
= VR_CFG_AMP(7),
37 .voltage_limit
= 1520,
40 .vr_config_enable
= 1,
41 .psi1threshold
= VR_CFG_AMP(20),
42 .psi2threshold
= VR_CFG_AMP(5),
43 .psi3threshold
= VR_CFG_AMP(1),
48 .icc_max
= VR_CFG_AMP(34),
49 .voltage_limit
= 1520,
52 .vr_config_enable
= 1,
53 .psi1threshold
= VR_CFG_AMP(20),
54 .psi2threshold
= VR_CFG_AMP(5),
55 .psi3threshold
= VR_CFG_AMP(1),
60 .icc_max
= VR_CFG_AMP(35),
61 .voltage_limit
= 1520,
64 .vr_config_enable
= 1,
65 .psi1threshold
= VR_CFG_AMP(20),
66 .psi2threshold
= VR_CFG_AMP(5),
67 .psi3threshold
= VR_CFG_AMP(1),
72 .icc_max
= VR_CFG_AMP(35),
73 .voltage_limit
= 1520,
77 static uint16_t get_sku_icc_max(int domain
)
79 const uint16_t tdp
= cpu_get_power_max();
81 static uint16_t mch_id
= 0, igd_id
= 0;
83 struct device
*dev
= pcidev_path_on_root(SA_DEVFN_ROOT
);
84 mch_id
= dev
? pci_read_config16(dev
, PCI_DEVICE_ID
) : 0xffff;
87 struct device
*dev
= pcidev_path_on_root(SA_DEVFN_IGD
);
88 igd_id
= dev
? pci_read_config16(dev
, PCI_DEVICE_ID
) : 0xffff;
92 * Iccmax table from Doc #559100 Section 7.2 DC Specifications, the
93 * Iccmax is the same among KBL-Y but KBL-U/R.
94 * Addendum for AML-Y #594883, IccMax for IA core is 28A.
95 * KBL-S #335195, KBL-H #335190, SKL-S #332687, SKL-H #332986,
98 * Platform Segment SA IA GT (GT/GTx)
99 * ---------------------------------------------------------------------
100 * KBL/SKL-S (95W) quad 11.1 100 45
101 * SKL-S (80W) quad 11.1 82 45
102 * KBL/SKL-S (65W) quad 11.1 79 45
103 * SKL-S (45W) quad 11.1 70 0
104 * KBL/SKL-S (35W) quad 11.1 66 35
105 * SKL-S (25W) quad 11.1 55 35
107 * KBL/SKL-S (54W) dual 11.1 58 48
108 * KBL/SKL-S (51W) dual 11.1 45 48
109 * KBL/SKL-S (35W) dual 11.1 40 48
111 * SKL-H + OPC (65W) GT4 quad 8 74 105/24
112 * SKL-H + OPC (45W) GT4 quad 8 74 94/20
113 * SKL-H + OPC (35W) GT4 quad 8 66 94/20
115 * SKL-H (35W) GT2 dual 11.1 60 55
117 * KBL/SKL-H (45W) GT2 quad 11.1 68 55
118 * KBL-H (18W) GT2 quad 6.6 60 55
120 * SKL-U + OPC (28W) GT3 dual 5.1 32 57/19
121 * SKL-U + OPC (15W) GT3 dual 5.1 29 57/19
122 * SKL-U (15W) GT2 dual 4.5 29 31
124 * KBL-U/R + OPC (28W) GT3 dual 5.1 32 57/19
125 * KBL-U/R + OPC (15W) GT3 dual 5.1 32 57/19
127 * KBL-U/R (15W) GT2 quad 6 64 31
128 * KBL-U/R (15W) GT1/2 dual 4.5 32 31
129 * KBL-U/R (15W) GT2 quad 4.5 29 31
131 * SKL/KBL-Y (6W) 4.1 24 24
132 * SKL/KBL-Y (4.5W) 4.1 24 24
136 case PCI_DEVICE_ID_INTEL_SKL_ID_S_2
: /* fallthrough */
137 case PCI_DEVICE_ID_INTEL_KBL_ID_S
: {
138 uint16_t icc_max
[NUM_VR_DOMAINS
] = VR_CFG_ALL_DOMAINS_ICC(11.1, 40, 48, 48);
140 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(58);
142 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(45);
144 return icc_max
[domain
];
146 case PCI_DEVICE_ID_INTEL_SKL_ID_S_4
: /* fallthrough */
147 case PCI_DEVICE_ID_INTEL_KBL_ID_DT_2
: /* fallthrough */
148 case PCI_DEVICE_ID_INTEL_KBL_ID_DT
: {
149 uint16_t icc_max
[NUM_VR_DOMAINS
] = VR_CFG_ALL_DOMAINS_ICC(11.1, 55, 45, 45);
151 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(100);
153 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(82);
155 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(79);
156 else if (tdp
>= 45) {
157 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(70);
158 icc_max
[VR_GT_SLICED
] = 0;
159 icc_max
[VR_GT_UNSLICED
] = 0;
160 } else if (tdp
>= 25) {
162 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(66);
164 icc_max
[VR_GT_SLICED
] = VR_CFG_AMP(35);
165 icc_max
[VR_GT_UNSLICED
] = VR_CFG_AMP(35);
168 return icc_max
[domain
];
170 case PCI_DEVICE_ID_INTEL_SKL_ID_H_4
: {
171 uint16_t icc_max
[NUM_VR_DOMAINS
] = VR_CFG_ALL_DOMAINS_ICC(11.1, 60, 94, 20);
173 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(74);
175 icc_max
[VR_GT_SLICED
] = VR_CFG_AMP(105);
176 icc_max
[VR_GT_UNSLICED
] = VR_CFG_AMP(24);
179 return icc_max
[domain
];
181 case PCI_DEVICE_ID_INTEL_SKL_ID_H_2
: /* fallthrough */
182 case PCI_DEVICE_ID_INTEL_SKL_ID_H_EM
: /* fallthrough */
183 case PCI_DEVICE_ID_INTEL_KBL_ID_H
: {
184 uint16_t icc_max
[NUM_VR_DOMAINS
] = VR_CFG_ALL_DOMAINS_ICC(6.6, 60, 55, 55);
187 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(68);
189 icc_max
[VR_SYSTEM_AGENT
] = VR_CFG_AMP(11.1);
192 return icc_max
[domain
];
194 case PCI_DEVICE_ID_INTEL_SKL_ID_U
: {
195 uint16_t icc_max
[NUM_VR_DOMAINS
] = VR_CFG_ALL_DOMAINS_ICC(5.1, 29, 57, 19);
197 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(32);
198 else if (igd_id
!= PCI_DEVICE_ID_INTEL_SKL_GT3E_SULTM_1
) {
199 const uint16_t icc_max_gt2
[NUM_VR_DOMAINS
] =
200 VR_CFG_ALL_DOMAINS_ICC(4.5, 29, 31, 31);
202 return icc_max_gt2
[domain
];
204 return icc_max
[domain
];
206 case PCI_DEVICE_ID_INTEL_KBL_U_R
: {
207 const uint16_t icc_max
[NUM_VR_DOMAINS
] =
208 VR_CFG_ALL_DOMAINS_ICC(6, 64, 31, 31);
209 return icc_max
[domain
];
211 case PCI_DEVICE_ID_INTEL_SKL_ID_Y
: /* fallthrough */
212 case PCI_DEVICE_ID_INTEL_KBL_ID_Y
: {
213 uint16_t icc_max
[NUM_VR_DOMAINS
] = VR_CFG_ALL_DOMAINS_ICC(4.1, 24, 24, 24);
215 if (igd_id
== PCI_DEVICE_ID_INTEL_AML_GT2_ULX
)
216 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(28);
218 return icc_max
[domain
];
220 case PCI_DEVICE_ID_INTEL_KBL_ID_U
: {
221 uint16_t icc_max
[NUM_VR_DOMAINS
] = VR_CFG_ALL_DOMAINS_ICC(4.5, 32, 31, 31);
223 if ((igd_id
== PCI_DEVICE_ID_INTEL_KBL_GT3E_SULTM_1
) ||
224 (igd_id
== PCI_DEVICE_ID_INTEL_KBL_GT3E_SULTM_2
))
225 icc_max
[VR_IA_CORE
] = VR_CFG_AMP(29);
227 return icc_max
[domain
];
230 printk(BIOS_ERR
, "ERROR: Unknown MCH (%u) in VR-config\n", mch_id
);
235 static uint16_t get_sku_ac_dc_loadline(const int domain
)
237 static uint16_t mch_id
= 0, igd_id
= 0;
239 struct device
*dev
= pcidev_path_on_root(SA_DEVFN_ROOT
);
240 mch_id
= dev
? pci_read_config16(dev
, PCI_DEVICE_ID
) : 0xffff;
243 struct device
*dev
= pcidev_path_on_root(SA_DEVFN_IGD
);
244 igd_id
= dev
? pci_read_config16(dev
, PCI_DEVICE_ID
) : 0xffff;
248 case PCI_DEVICE_ID_INTEL_SKL_ID_S_2
: /* fallthrough */
249 case PCI_DEVICE_ID_INTEL_SKL_ID_S_4
: /* fallthrough */
250 case PCI_DEVICE_ID_INTEL_KBL_ID_S
: /* fallthrough */
251 case PCI_DEVICE_ID_INTEL_KBL_ID_DT
: /* fallthrough */
252 case PCI_DEVICE_ID_INTEL_KBL_ID_DT_2
: {
253 /* SA Loadline is not specified */
254 const uint16_t loadline
[NUM_VR_DOMAINS
] =
255 VR_CFG_ALL_DOMAINS_LOADLINE(0, 2.1, 3.1, 3.1);
256 return loadline
[domain
];
258 case PCI_DEVICE_ID_INTEL_SKL_ID_H_2
: /* fallthrough */
259 case PCI_DEVICE_ID_INTEL_SKL_ID_H_EM
: /* fallthrough */
260 case PCI_DEVICE_ID_INTEL_SKL_ID_H_4
: /* fallthrough */
261 case PCI_DEVICE_ID_INTEL_KBL_ID_H
: {
262 const uint16_t loadline
[NUM_VR_DOMAINS
] =
263 VR_CFG_ALL_DOMAINS_LOADLINE(10, 1.8, 2.65, 2.65);
265 if (igd_id
== PCI_DEVICE_ID_INTEL_SKL_GT4_SHALM
) {
266 const uint16_t loadline_gt4
[NUM_VR_DOMAINS
] =
267 VR_CFG_ALL_DOMAINS_LOADLINE(6, 1.6, 1.4, 6);
268 return loadline_gt4
[domain
];
271 return loadline
[domain
];
273 case PCI_DEVICE_ID_INTEL_SKL_ID_Y
: /* fallthrough */
274 case PCI_DEVICE_ID_INTEL_KBL_ID_Y
: {
275 uint16_t loadline
[NUM_VR_DOMAINS
] =
276 VR_CFG_ALL_DOMAINS_LOADLINE(18, 5.9, 5.7, 5.7);
278 if (igd_id
== PCI_DEVICE_ID_INTEL_AML_GT2_ULX
)
279 loadline
[VR_IA_CORE
] = VR_CFG_MOHMS(4);
281 return loadline
[domain
];
283 case PCI_DEVICE_ID_INTEL_SKL_ID_U
: /* fallthrough */
284 case PCI_DEVICE_ID_INTEL_KBL_U_R
: /* fallthrough */
285 case PCI_DEVICE_ID_INTEL_KBL_ID_U
: {
286 uint16_t loadline
[NUM_VR_DOMAINS
] =
287 VR_CFG_ALL_DOMAINS_LOADLINE(10.3, 2.4, 3.1, 3.1);
289 if ((igd_id
== PCI_DEVICE_ID_INTEL_SKL_GT3E_SULTM_1
) ||
290 (igd_id
== PCI_DEVICE_ID_INTEL_SKL_GT3E_SULTM_2
) ||
291 (igd_id
== PCI_DEVICE_ID_INTEL_KBL_GT3E_SULTM_1
) ||
292 (igd_id
== PCI_DEVICE_ID_INTEL_KBL_GT3E_SULTM_2
)) {
293 loadline
[VR_GT_UNSLICED
] = VR_CFG_MOHMS(2);
294 loadline
[VR_GT_SLICED
] = VR_CFG_MOHMS(6);
297 return loadline
[domain
];
300 printk(BIOS_ERR
, "ERROR: Unknown MCH (%u) in VR-config\n", mch_id
);
305 void fill_vr_domain_config(void *params
,
306 int domain
, const struct vr_config
*chip_cfg
)
308 FSP_SIL_UPD
*vr_params
= (FSP_SIL_UPD
*)params
;
309 const struct vr_config
*cfg
;
311 if (domain
< 0 || domain
>= NUM_VR_DOMAINS
)
314 /* Use device tree override if requested. */
315 if (chip_cfg
->vr_config_enable
)
318 cfg
= &default_configs
[domain
];
320 vr_params
->VrConfigEnable
[domain
] = cfg
->vr_config_enable
;
321 vr_params
->Psi1Threshold
[domain
] = cfg
->psi1threshold
;
322 vr_params
->Psi2Threshold
[domain
] = cfg
->psi2threshold
;
323 vr_params
->Psi3Threshold
[domain
] = cfg
->psi3threshold
;
324 vr_params
->Psi3Enable
[domain
] = cfg
->psi3enable
;
325 vr_params
->Psi4Enable
[domain
] = cfg
->psi4enable
;
326 vr_params
->ImonSlope
[domain
] = cfg
->imon_slope
;
327 vr_params
->ImonOffset
[domain
] = cfg
->imon_offset
;
328 /* If board provided non-zero value, use it. */
330 vr_params
->IccMax
[domain
] = cfg
->icc_max
;
332 vr_params
->IccMax
[domain
] = get_sku_icc_max(domain
);
333 vr_params
->VrVoltageLimit
[domain
] = cfg
->voltage_limit
;
335 if (cfg
->ac_loadline
)
336 vr_params
->AcLoadline
[domain
] = cfg
->ac_loadline
;
338 vr_params
->AcLoadline
[domain
] = get_sku_ac_dc_loadline(domain
);
339 if (cfg
->dc_loadline
)
340 vr_params
->DcLoadline
[domain
] = cfg
->dc_loadline
;
342 vr_params
->DcLoadline
[domain
] = get_sku_ac_dc_loadline(domain
);