blob: 158cc9e3fe733ca9a2b5e86f2ca1e1578812633d [file] [log] [blame]
Angel Pons0612b272020-04-05 15:46:56 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Subrata Banikc2fd0a22017-02-27 15:42:09 +05302
3#ifndef SOC_INTEL_COMMON_MSR_H
4#define SOC_INTEL_COMMON_MSR_H
5
6#define MSR_CORE_THREAD_COUNT 0x35
Subrata Banikc2fd0a22017-02-27 15:42:09 +05307#define MSR_PLATFORM_INFO 0xce
Elyes HAOUAS4e6b7902018-10-02 08:44:47 +02008#define MSR_PKG_CST_CONFIG_CONTROL 0xe2
9/* Set MSR_PKG_CST_CONFIG_CONTROL[3:0] for Package C-State limit */
John Su85376bf2018-11-06 10:51:43 +080010#define PKG_C_STATE_LIMIT_C2_MASK 0x2
Elyes HAOUAS4e6b7902018-10-02 08:44:47 +020011/* Set MSR_PKG_CST_CONFIG_CONTROL[7:4] for Core C-State limit*/
John Su85376bf2018-11-06 10:51:43 +080012#define CORE_C_STATE_LIMIT_C10_MASK 0x70
Elyes HAOUAS4e6b7902018-10-02 08:44:47 +020013/* Set MSR_PKG_CST_CONFIG_CONTROL[10] to IO redirect to MWAIT */
John Su85376bf2018-11-06 10:51:43 +080014#define IO_MWAIT_REDIRECT_MASK 0x400
Elyes HAOUAS4e6b7902018-10-02 08:44:47 +020015/* Set MSR_PKG_CST_CONFIG_CONTROL[15] to lock CST_CFG [0-15] bits */
John Su85376bf2018-11-06 10:51:43 +080016#define CST_CFG_LOCK_MASK 0x8000
Pratik Prajapatia04aa3d2017-06-12 23:02:36 -070017#define MSR_BIOS_UPGD_TRIG 0x7a
18#define SGX_ACTIVATE_BIT (1)
Subrata Banikc2fd0a22017-02-27 15:42:09 +053019#define MSR_PMG_IO_CAPTURE_BASE 0xe4
Elyes HAOUASf212cf32018-12-18 10:24:55 +010020#define MSR_EMULATE_PM_TIMER 0x121
John Su85376bf2018-11-06 10:51:43 +080021#define EMULATE_DELAY_OFFSET_VALUE 20
22#define EMULATE_PM_TMR_EN (1 << 16)
23#define EMULATE_DELAY_VALUE 0x13
Subrata Banikc2fd0a22017-02-27 15:42:09 +053024#define SMM_MCA_CAP_MSR 0x17d
25#define SMM_CPU_SVRSTR_BIT 57
26#define SMM_CPU_SVRSTR_MASK (1 << (SMM_CPU_SVRSTR_BIT - 32))
Barnali Sarkar19b546f2017-05-03 18:00:48 +053027#define MSR_FLEX_RATIO 0x194
28#define FLEX_RATIO_LOCK (1 << 20)
29#define FLEX_RATIO_EN (1 << 16)
Elyes HAOUAS419bfbc2018-10-01 08:47:51 +020030/* This is burst mode BIT 38 in IA32_MISC_ENABLE MSR at offset 1A0h */
Barnali Sarkar19b546f2017-05-03 18:00:48 +053031#define BURST_MODE_DISABLE (1 << 6)
Subrata Banikc2fd0a22017-02-27 15:42:09 +053032#define MSR_TEMPERATURE_TARGET 0x1a2
John Su85376bf2018-11-06 10:51:43 +080033#define TEMPERATURE_TCC_MASK 0xf
34#define TEMPERATURE_TCC_SHIFT 24
Subrata Banikc2fd0a22017-02-27 15:42:09 +053035#define MSR_PREFETCH_CTL 0x1a4
John Su85376bf2018-11-06 10:51:43 +080036#define PREFETCH_L1_DISABLE (1 << 0)
37#define PREFETCH_L2_DISABLE (1 << 2)
Subrata Banik39b76652023-04-01 16:27:55 +053038#define DISABLE_CPU_ERROR (1 << 11)
Subrata Banikc2fd0a22017-02-27 15:42:09 +053039#define MSR_MISC_PWR_MGMT 0x1aa
40#define MISC_PWR_MGMT_EIST_HW_DIS (1 << 0)
41#define MISC_PWR_MGMT_ISST_EN (1 << 6)
42#define MISC_PWR_MGMT_ISST_EN_INT (1 << 7)
43#define MISC_PWR_MGMT_ISST_EN_EPP (1 << 12)
Subrata Banik0b7388f2023-12-13 01:08:06 +053044#define MSR_DISABLE_SIGNALING_THREE_STRIKE_EVENT 0x1ab
45#define THREE_STRIKE_COUNT (1 << 0)
Subrata Banikc2fd0a22017-02-27 15:42:09 +053046#define MSR_TURBO_RATIO_LIMIT 0x1ad
Elyes HAOUASf212cf32018-12-18 10:24:55 +010047#define MSR_PRMRR_PHYS_BASE 0x1f4
48#define MSR_PRMRR_PHYS_MASK 0x1f5
Barnali Sarkar19b546f2017-05-03 18:00:48 +053049#define PRMRR_PHYS_MASK_LOCK (1 << 10)
50#define PRMRR_PHYS_MASK_VALID (1 << 11)
Michael Niewöhner7736bfc2019-10-22 23:05:06 +020051#define MSR_PRMRR_VALID_CONFIG 0x1fb
Subrata Banikc2fd0a22017-02-27 15:42:09 +053052#define MSR_POWER_CTL 0x1fc
Cole Nelson2b69b212018-06-12 09:56:24 -070053#define POWER_CTL_C1E_MASK (1 << 1)
Subrata Banik13fd3c82022-06-05 18:57:36 +053054#define MSR_PRMRR_BASE_0 0x2a0
Subrata Banikc2fd0a22017-02-27 15:42:09 +053055#define MSR_EVICT_CTL 0x2e0
Michael Niewöhner5ce66da2019-09-22 21:56:17 +020056#define MSR_LT_CONTROL 0x2e7
Michael Niewöhner90df9162020-10-13 22:58:28 +020057#define LT_CONTROL_LOCK (1 << 0)
Pratik Prajapatia04aa3d2017-06-12 23:02:36 -070058#define MSR_SGX_OWNEREPOCH0 0x300
59#define MSR_SGX_OWNEREPOCH1 0x301
Subrata Banikc2fd0a22017-02-27 15:42:09 +053060#define SMM_FEATURE_CONTROL_MSR 0x4e0
61#define SMM_CPU_SAVE_EN (1 << 1)
62#define MSR_PKG_POWER_SKU_UNIT 0x606
63#define MSR_C_STATE_LATENCY_CONTROL_0 0x60a
64#define MSR_C_STATE_LATENCY_CONTROL_1 0x60b
65#define MSR_C_STATE_LATENCY_CONTROL_2 0x60c
66#define MSR_PKG_POWER_LIMIT 0x610
67/*
68 * For Mobile, RAPL default PL1 time window value set to 28 seconds.
69 * RAPL time window calculation defined as follows:
70 * Time Window = (float)((1+X/4)*(2*^Y), X Corresponds to [23:22],
71 * Y to [21:17] in MSR 0x610. 28 sec is equal to 0x6e.
72 */
John Su85376bf2018-11-06 10:51:43 +080073#define MB_POWER_LIMIT1_TIME_DEFAULT 0x6e
Subrata Banikc2fd0a22017-02-27 15:42:09 +053074#define MSR_PKG_POWER_SKU 0x614
75#define MSR_DDR_RAPL_LIMIT 0x618
76#define MSR_C_STATE_LATENCY_CONTROL_3 0x633
77#define MSR_C_STATE_LATENCY_CONTROL_4 0x634
78#define MSR_C_STATE_LATENCY_CONTROL_5 0x635
79#define IRTL_VALID (1 << 15)
80#define IRTL_1_NS (0 << 10)
81#define IRTL_32_NS (1 << 10)
82#define IRTL_1024_NS (2 << 10)
83#define IRTL_32768_NS (3 << 10)
84#define IRTL_1048576_NS (4 << 10)
85#define IRTL_33554432_NS (5 << 10)
86#define IRTL_RESPONSE_MASK (0x3ff)
87#define MSR_COUNTER_24_MHZ 0x637
88#define MSR_CONFIG_TDP_NOMINAL 0x648
89#define MSR_CONFIG_TDP_LEVEL1 0x649
90#define MSR_CONFIG_TDP_LEVEL2 0x64a
91#define MSR_CONFIG_TDP_CONTROL 0x64b
92#define MSR_TURBO_ACTIVATION_RATIO 0x64c
93#define PKG_POWER_LIMIT_MASK (0x7fff)
94#define PKG_POWER_LIMIT_EN (1 << 15)
95#define PKG_POWER_LIMIT_CLAMP (1 << 16)
96#define PKG_POWER_LIMIT_TIME_SHIFT 17
97#define PKG_POWER_LIMIT_TIME_MASK (0x7f)
Shelley Chen50db9a22018-01-31 15:55:50 -080098#define PKG_POWER_LIMIT_DUTYCYCLE_SHIFT 24
99#define PKG_POWER_LIMIT_DUTYCYCLE_MASK (0x7f)
Subrata Banik66cd1842022-08-15 16:29:31 +0530100
101#define MSR_CORE_MKTME_ACTIVATION 0x9ff
Barnali Sarkar19b546f2017-05-03 18:00:48 +0530102/* SMM save state MSRs */
103#define SMBASE_MSR 0xc20
104#define IEDBASE_MSR 0xc22
105
Subrata Banikc2fd0a22017-02-27 15:42:09 +0530106#define MSR_L2_QOS_MASK(reg) (0xd10 + reg)
107
Barnali Sarkar19b546f2017-05-03 18:00:48 +0530108/* MTRR_CAP_MSR bits */
Tim Wawrzynczak4cba4192020-09-01 16:10:06 -0600109#define SMRR_SUPPORTED (1<<11)
110#define PRMRR_SUPPORTED (1<<12)
111#define SMRR_LOCK_SUPPORTED (1<<14)
Barnali Sarkar19b546f2017-05-03 18:00:48 +0530112
Pratikkumar Prajapati08e80672022-12-19 11:21:56 -0800113#define SGX_SUPPORTED (1<<2)
114#define TME_SUPPORTED (1<<13)
115
116#define KEYLOCKER_SUPPORTED (1<<23)
117#define KEYLOCKER_AESKL (1)
Pratik Prajapati0e5eb462017-10-11 11:48:04 -0700118
Subrata Banikc2fd0a22017-02-27 15:42:09 +0530119#endif /* SOC_INTEL_COMMON_MSR_H */