haswell: Add ACPI support for Controllable TDP

Add ACPI Methods to enable and disable power limiting with PL1.
This can be used in ACPI Thermal Zone or in EC ACPI _QXX events.

This commit adds new unused methods and is fully tested with the
subsequent commit that makes use of these methods.

Change-Id: I9d8d23bfe9cf7c756ff8ab0412e5a010826b12db
Signed-off-by: Duncan Laurie <dlaurie@chromium.org>
Reviewed-on: https://gerrit.chromium.org/gerrit/60546
Reviewed-on: http://review.coreboot.org/4334
Reviewed-by: Alexandru Gagniuc <mr.nuke.me@gmail.com>
Tested-by: build bot (Jenkins)
This commit is contained in:
Duncan Laurie 2013-06-28 16:01:53 -07:00 committed by Alexandru Gagniuc
parent c70353f1eb
commit b17117904d
1 changed files with 99 additions and 17 deletions

View File

@ -106,35 +106,45 @@ Device (MCHC)
Name (CTCN, 0) /* CTDP Nominal Select */ Name (CTCN, 0) /* CTDP Nominal Select */
Name (CTCD, 1) /* CTDP Down Select */ Name (CTCD, 1) /* CTDP Down Select */
Name (CTCU, 2) /* CTDP Up Select */ Name (CTCU, 2) /* CTDP Up Select */
Name (SPL1, 0) /* Saved PL1 value */
OperationRegion (MCHB, SystemMemory, DEFAULT_MCHBAR, 0x8000) OperationRegion (MCHB, SystemMemory, Add(DEFAULT_MCHBAR,0x5000), 0x1000)
Field (MCHB, DWordAcc, Lock, Preserve) Field (MCHB, DWordAcc, Lock, Preserve)
{ {
Offset (0x5930), Offset (0x930), /* PACKAGE_POWER_SKU */
CTDN, 15, /* CTDP Nominal PL1 */ CTDN, 15, /* CTDP Nominal PL1 */
Offset (0x59a0), Offset (0x938), /* PACKAGE_POWER_SKU_UNIT */
PUNI, 4, /* Power Units */
, 4,
EUNI, 5, /* Energy Units */
, 3,
TUNI, 4, /* Time Units */
Offset (0x958), /* PLATFORM_INFO */
, 40,
LFM_, 8, /* Maximum Efficiency Ratio (LFM) */
Offset (0x9a0), /* TURBO_POWER_LIMIT1 */
PL1V, 15, /* Power Limit 1 Value */ PL1V, 15, /* Power Limit 1 Value */
PL1E, 1, /* Power Limit 1 Enable */ PL1E, 1, /* Power Limit 1 Enable */
PL1C, 1, /* Power Limit 1 Clamp */ PL1C, 1, /* Power Limit 1 Clamp */
PL1T, 7, /* Power Limit 1 Time */ PL1T, 7, /* Power Limit 1 Time */
Offset (0x59a4), Offset (0x9a4), /* TURBO_POWER_LIMIT2 */
PL2V, 15, /* Power Limit 2 Value */ PL2V, 15, /* Power Limit 2 Value */
PL2E, 1, /* Power Limit 2 Enable */ PL2E, 1, /* Power Limit 2 Enable */
PL2C, 1, /* Power Limit 2 Clamp */ PL2C, 1, /* Power Limit 2 Clamp */
PL2T, 7, /* Power Limit 2 Time */ PL2T, 7, /* Power Limit 2 Time */
Offset (0x5f3c), Offset (0xf3c), /* CONFIG_TDP_NOMINAL */
TARN, 8, /* CTDP Nominal Turbo Activation Ratio */ TARN, 8, /* CTDP Nominal Turbo Activation Ratio */
Offset (0x5f40), Offset (0xf40), /* CONFIG_TDP_LEVEL1 */
CTDD, 15, /* CTDP Down PL1 */ CTDD, 15, /* CTDP Down PL1 */
, 1, , 1,
TARD, 8, /* CTDP Down Turbo Activation Ratio */ TARD, 8, /* CTDP Down Turbo Activation Ratio */
Offset (0x5f48), Offset (0xf48), /* MSR_CONFIG_TDP_LEVEL2 */
CTDU, 15, /* CTDP Up PL1 */ CTDU, 15, /* CTDP Up PL1 */
, 1, , 1,
TARU, 8, /* CTDP Up Turbo Activation Ratio */ TARU, 8, /* CTDP Up Turbo Activation Ratio */
Offset (0x5f50), Offset (0xf50), /* CONFIG_TDP_CONTROL */
CTCS, 2, /* CTDP Select */ CTCS, 2, /* CTDP Select */
Offset (0x5f54), Offset (0xf54), /* TURBO_ACTIVATION_RATIO */
TARS, 8, /* Turbo Activation Ratio Select */ TARS, 8, /* Turbo Activation Ratio Select */
} }
@ -166,7 +176,19 @@ Device (MCHC)
Return (0) Return (0)
} }
/* Set TDP Down */ /* Calculate PL2 based on chip type */
Method (CPL2, 1, NotSerialized)
{
If (\ISLP ()) {
/* Haswell ULT PL2 = 25W */
Return (Multiply (25, 8))
} Else {
/* Haswell Mobile PL2 = 1.25 * PL1 */
Return (Divide (Multiply (Arg0, 125), 100))
}
}
/* Set Config TDP Down */
Method (STND, 0, Serialized) Method (STND, 0, Serialized)
{ {
If (Acquire (CTCM, 100)) { If (Acquire (CTCM, 100)) {
@ -189,8 +211,8 @@ Device (MCHC)
Store (PSSS (TARD), PPCM) Store (PSSS (TARD), PPCM)
PPCN () PPCN ()
/* Set PL2 to 1.25 * PL1 */ /* Set PL2 */
Divide (Multiply (CTDD, 125), 100, Local0, PL2V) Store (CPL2 (CTDD), PL2V)
/* Set PL1 */ /* Set PL1 */
Store (CTDD, PL1V) Store (CTDD, PL1V)
@ -202,7 +224,7 @@ Device (MCHC)
Return (1) Return (1)
} }
/* Set TDP Nominal from Down */ /* Set Config TDP Nominal from Down */
Method (STDN, 0, Serialized) Method (STDN, 0, Serialized)
{ {
If (Acquire (CTCM, 100)) { If (Acquire (CTCM, 100)) {
@ -218,8 +240,8 @@ Device (MCHC)
/* Set PL1 */ /* Set PL1 */
Store (CTDN, PL1V) Store (CTDN, PL1V)
/* Set PL2 to 1.25 * PL1 */ /* Set PL2 */
Divide (Multiply (CTDN, 125), 100, Local0, PL2V) Store (CPL2 (CTDN), PL2V)
/* Set PPC limit and notify OS */ /* Set PPC limit and notify OS */
Store (PSSS (TARN), PPCM) Store (PSSS (TARN), PPCM)
@ -237,6 +259,66 @@ Device (MCHC)
Release (CTCM) Release (CTCM)
Return (1) Return (1)
} }
/* Calculate PL1 value based on requested TDP */
Method (TDPP, 1, NotSerialized)
{
Return (Multiply (ShiftLeft (Subtract (PUNI, 1), 2), Arg0))
}
/* Enable Controllable TDP to limit PL1 to requested value */
Method (CTLE, 1, Serialized)
{
If (Acquire (CTCM, 100)) {
Return (0)
}
Store ("Enable PL1 Limit", Debug)
/* Set _PPC to LFM */
Store (PSSS (LFM_), Local0)
Add (Local0, 1, PPCM)
\PPCN ()
/* Set TAR to LFM-1 */
Subtract (LFM_, 1, TARS)
/* Set PL1 to desired value */
Store (PL1V, SPL1)
Store (TDPP (Arg0), PL1V)
/* Set PL1 CLAMP bit */
Store (One, PL1C)
Release (CTCM)
Return (1)
}
/* Disable Controllable TDP */
Method (CTLD, 0, Serialized)
{
If (Acquire (CTCM, 100)) {
Return (0)
}
Store ("Disable PL1 Limit", Debug)
/* Clear PL1 CLAMP bit */
Store (Zero, PL1C)
/* Set PL1 to normal value */
Store (SPL1, PL1V)
/* Set TAR to 0 */
Store (Zero, TARS)
/* Set _PPC to 0 */
Store (Zero, PPCM)
\PPCN ()
Release (CTCM)
Return (1)
}
} }
// Current Resource Settings // Current Resource Settings