1 /* SPDX-License-Identifier: MIT */ 2 /* 3 * Copyright © 2023 Intel Corporation 4 */ 5 6 #ifndef _XE_GT_REGS_H_ 7 #define _XE_GT_REGS_H_ 8 9 #include "regs/xe_reg_defs.h" 10 11 /* 12 * The GSI register range [0x0 - 0x40000) is replicated at a higher offset 13 * for the media GT. xe_mmio and xe_gt_mcr functions will automatically 14 * translate offsets by MEDIA_GT_GSI_OFFSET when operating on the media GT. 15 */ 16 #define MEDIA_GT_GSI_OFFSET 0x380000 17 #define MEDIA_GT_GSI_LENGTH 0x40000 18 19 /* MTL workpoint reg to get core C state and actual freq of 3D, SAMedia */ 20 #define MTL_MIRROR_TARGET_WP1 XE_REG(0xc60) 21 #define MTL_CAGF_MASK REG_GENMASK(8, 0) 22 #define MTL_CC_MASK REG_GENMASK(12, 9) 23 #define MTL_CRST 0xf 24 25 /* RPM unit config (Gen8+) */ 26 #define RPM_CONFIG0 XE_REG(0xd00) 27 #define RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_MASK REG_GENMASK(5, 3) 28 #define RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_24_MHZ 0 29 #define RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_19_2_MHZ 1 30 #define RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_38_4_MHZ 2 31 #define RPM_CONFIG0_CRYSTAL_CLOCK_FREQ_25_MHZ 3 32 #define RPM_CONFIG0_CTC_SHIFT_PARAMETER_MASK REG_GENMASK(2, 1) 33 34 #define FORCEWAKE_ACK_MEDIA_VDBOX(n) XE_REG(0xd50 + (n) * 4) 35 #define FORCEWAKE_ACK_MEDIA_VEBOX(n) XE_REG(0xd70 + (n) * 4) 36 #define FORCEWAKE_ACK_RENDER XE_REG(0xd84) 37 38 #define GMD_ID XE_REG(0xd8c) 39 #define GMD_ID_ARCH_MASK REG_GENMASK(31, 22) 40 #define GMD_ID_RELEASE_MASK REG_GENMASK(21, 14) 41 /* 42 * Spec defines these bits as "Reserved", but then make them assume some 43 * meaning that depends on the ARCH. To avoid any confusion, call them 44 * SUBIP_FLAG_MASK. 45 */ 46 #define GMD_ID_SUBIP_FLAG_MASK REG_GENMASK(13, 6) 47 #define GMD_ID_REVID REG_GENMASK(5, 0) 48 49 #define FORCEWAKE_ACK_GSC XE_REG(0xdf8) 50 #define FORCEWAKE_ACK_GT_MTL XE_REG(0xdfc) 51 52 #define STEER_SEMAPHORE XE_REG(0xfd0) 53 #define MTL_MCR_SELECTOR XE_REG(0xfd4) 54 #define SF_MCR_SELECTOR XE_REG(0xfd8) 55 #define MCR_SELECTOR XE_REG(0xfdc) 56 #define GAM_MCR_SELECTOR XE_REG(0xfe0) 57 #define MCR_MULTICAST REG_BIT(31) 58 #define MCR_SLICE_MASK REG_GENMASK(30, 27) 59 #define MCR_SLICE(slice) REG_FIELD_PREP(MCR_SLICE_MASK, slice) 60 #define MCR_SUBSLICE_MASK REG_GENMASK(26, 24) 61 #define MCR_SUBSLICE(subslice) REG_FIELD_PREP(MCR_SUBSLICE_MASK, subslice) 62 #define MTL_MCR_GROUPID REG_GENMASK(12, 8) 63 #define MTL_MCR_INSTANCEID REG_GENMASK(3, 0) 64 65 #define PS_INVOCATION_COUNT XE_REG(0x2348) 66 67 #define XELP_GLOBAL_MOCS(i) XE_REG(0x4000 + (i) * 4) 68 #define XEHP_GLOBAL_MOCS(i) XE_REG_MCR(0x4000 + (i) * 4) 69 #define LE_SSE_MASK REG_GENMASK(18, 17) 70 #define LE_SSE(value) REG_FIELD_PREP(LE_SSE_MASK, value) 71 #define LE_COS_MASK REG_GENMASK(16, 15) 72 #define LE_SCF_MASK REG_BIT(14) 73 #define LE_SCF(value) REG_FIELD_PREP(LE_SCF_MASK, value) 74 #define LE_PFM_MASK REG_GENMASK(13, 11) 75 #define LE_PFM(value) REG_FIELD_PREP(LE_PFM_MASK, value) 76 #define LE_SCC_MASK REG_GENMASK(10, 8) 77 #define LE_SCC(value) REG_FIELD_PREP(LE_SCC_MASK, value) 78 #define LE_RSC_MASK REG_BIT(7) 79 #define LE_RSC(value) REG_FIELD_PREP(LE_RSC_MASK, value) 80 #define LE_AOM_MASK REG_BIT(6) 81 #define LE_AOM(value) REG_FIELD_PREP(LE_AOM_MASK, value) 82 #define LE_LRUM_MASK REG_GENMASK(5, 4) 83 #define LE_LRUM(value) REG_FIELD_PREP(LE_LRUM_MASK, value) 84 #define LE_TGT_CACHE_MASK REG_GENMASK(3, 2) 85 #define LE_TGT_CACHE(value) REG_FIELD_PREP(LE_TGT_CACHE_MASK, value) 86 #define LE_CACHEABILITY_MASK REG_GENMASK(1, 0) 87 #define LE_CACHEABILITY(value) REG_FIELD_PREP(LE_CACHEABILITY_MASK, value) 88 89 #define STATELESS_COMPRESSION_CTRL XE_REG_MCR(0x4148) 90 #define UNIFIED_COMPRESSION_FORMAT REG_GENMASK(3, 0) 91 92 #define XE2_GAMREQSTRM_CTRL XE_REG_MCR(0x4194) 93 #define EN_CMP_1WCOH REG_BIT(15) 94 #define CG_DIS_CNTLBUS REG_BIT(6) 95 96 #define CCS_AUX_INV XE_REG(0x4208) 97 98 #define VD0_AUX_INV XE_REG(0x4218) 99 #define VE0_AUX_INV XE_REG(0x4238) 100 101 #define VE1_AUX_INV XE_REG(0x42b8) 102 #define AUX_INV REG_BIT(0) 103 104 #define GAMSTLB_CTRL XE_REG_MCR(0x477c) 105 #define DIS_PEND_GPA_LINK REG_BIT(13) 106 107 #define GAMSTLB_CTRL2 XE_REG_MCR(0x4788) 108 #define STLB_SINGLE_BANK_MODE REG_BIT(11) 109 110 #define XE2_LMEM_CFG XE_REG(0x48b0) 111 112 #define XE2_GAMWALK_CTRL 0x47e4 113 #define XE2_GAMWALK_CTRL_MEDIA XE_REG(XE2_GAMWALK_CTRL + MEDIA_GT_GSI_OFFSET) 114 #define XE2_GAMWALK_CTRL_3D XE_REG_MCR(XE2_GAMWALK_CTRL) 115 #define EN_CMP_1WCOH_GW REG_BIT(14) 116 117 #define MMIOATSREQLIMIT_GAM_WALK_3D XE_REG_MCR(0x47f8) 118 #define DIS_ATS_WRONLY_PG REG_BIT(18) 119 120 #define XEHP_FLAT_CCS_BASE_ADDR XE_REG_MCR(0x4910) 121 #define XEHP_FLAT_CCS_PTR REG_GENMASK(31, 8) 122 123 #define WM_CHICKEN3 XE_REG_MCR(0x5588, XE_REG_OPTION_MASKED) 124 #define HIZ_PLANE_COMPRESSION_DIS REG_BIT(10) 125 126 #define CHICKEN_RASTER_1 XE_REG_MCR(0x6204, XE_REG_OPTION_MASKED) 127 #define DIS_SF_ROUND_NEAREST_EVEN REG_BIT(8) 128 #define DIS_CLIP_NEGATIVE_BOUNDING_BOX REG_BIT(6) 129 130 #define CHICKEN_RASTER_2 XE_REG_MCR(0x6208, XE_REG_OPTION_MASKED) 131 #define TBIMR_FAST_CLIP REG_BIT(5) 132 133 #define FF_MODE XE_REG_MCR(0x6210) 134 #define DIS_TE_AUTOSTRIP REG_BIT(31) 135 #define VS_HIT_MAX_VALUE_MASK REG_GENMASK(25, 20) 136 #define DIS_MESH_PARTIAL_AUTOSTRIP REG_BIT(16) 137 #define DIS_MESH_AUTOSTRIP REG_BIT(15) 138 #define DIS_TE_PATCH_CTRL REG_BIT(4) 139 140 #define VFLSKPD XE_REG_MCR(0x62a8, XE_REG_OPTION_MASKED) 141 #define DIS_PARTIAL_AUTOSTRIP REG_BIT(9) 142 #define DIS_AUTOSTRIP REG_BIT(6) 143 #define DIS_OVER_FETCH_CACHE REG_BIT(1) 144 #define DIS_MULT_MISS_RD_SQUASH REG_BIT(0) 145 146 #define FF_MODE2 XE_REG(0x6604) 147 #define XEHP_FF_MODE2 XE_REG_MCR(0x6604) 148 #define FF_MODE2_GS_TIMER_MASK REG_GENMASK(31, 24) 149 #define FF_MODE2_GS_TIMER_224 REG_FIELD_PREP(FF_MODE2_GS_TIMER_MASK, 224) 150 #define FF_MODE2_TDS_TIMER_MASK REG_GENMASK(23, 16) 151 #define FF_MODE2_TDS_TIMER_128 REG_FIELD_PREP(FF_MODE2_TDS_TIMER_MASK, 4) 152 153 #define XEHPG_INSTDONE_GEOM_SVGUNIT XE_REG_MCR(0x666c) 154 155 #define CACHE_MODE_1 XE_REG_MCR(0x7004, XE_REG_OPTION_MASKED) 156 #define MSAA_OPTIMIZATION_REDUC_DISABLE REG_BIT(11) 157 158 #define COMMON_SLICE_CHICKEN1 XE_REG(0x7010, XE_REG_OPTION_MASKED) 159 #define XEHP_COMMON_SLICE_CHICKEN1 XE_REG_MCR(0x7010, XE_REG_OPTION_MASKED) 160 #define DISABLE_BOTTOM_CLIP_RECTANGLE_TEST REG_BIT(14) 161 162 #define HIZ_CHICKEN XE_REG(0x7018, XE_REG_OPTION_MASKED) 163 #define DG1_HZ_READ_SUPPRESSION_OPTIMIZATION_DISABLE REG_BIT(14) 164 #define HZ_DEPTH_TEST_LE_GE_OPT_DISABLE REG_BIT(13) 165 166 #define XEHP_PSS_MODE2 XE_REG_MCR(0x703c, XE_REG_OPTION_MASKED) 167 #define SCOREBOARD_STALL_FLUSH_CONTROL REG_BIT(5) 168 169 #define XEHP_PSS_CHICKEN XE_REG_MCR(0x7044, XE_REG_OPTION_MASKED) 170 #define FLSH_IGNORES_PSD REG_BIT(10) 171 #define FD_END_COLLECT REG_BIT(5) 172 173 #define SC_INSTDONE XE_REG(0x7100) 174 #define SC_INSTDONE_EXTRA XE_REG(0x7104) 175 #define SC_INSTDONE_EXTRA2 XE_REG(0x7108) 176 177 #define XEHPG_SC_INSTDONE XE_REG_MCR(0x7100) 178 #define XEHPG_SC_INSTDONE_EXTRA XE_REG_MCR(0x7104) 179 #define XEHPG_SC_INSTDONE_EXTRA2 XE_REG_MCR(0x7108) 180 181 #define COMMON_SLICE_CHICKEN4 XE_REG(0x7300, XE_REG_OPTION_MASKED) 182 #define XEHP_COMMON_SLICE_CHICKEN4 XE_REG_MCR(0x7300, XE_REG_OPTION_MASKED) 183 #define SBE_PUSH_CONSTANT_BEHIND_FIX_ENABLE REG_BIT(12) 184 #define DISABLE_TDC_LOAD_BALANCING_CALC REG_BIT(6) 185 #define HW_FILTERING REG_BIT(5) 186 187 #define COMMON_SLICE_CHICKEN3 XE_REG(0x7304, XE_REG_OPTION_MASKED) 188 #define XEHP_COMMON_SLICE_CHICKEN3 XE_REG_MCR(0x7304, XE_REG_OPTION_MASKED) 189 #define DISABLE_STATE_CACHE_PERF_FIX REG_BIT(13) 190 #define DG1_FLOAT_POINT_BLEND_OPT_STRICT_MODE_EN REG_BIT(12) 191 #define XEHP_DUAL_SIMD8_SEQ_MERGE_DISABLE REG_BIT(12) 192 #define BLEND_EMB_FIX_DISABLE_IN_RCC REG_BIT(11) 193 #define DISABLE_CPS_AWARE_COLOR_PIPE REG_BIT(9) 194 195 #define XEHP_SLICE_COMMON_ECO_CHICKEN1 XE_REG_MCR(0x731c, XE_REG_OPTION_MASKED) 196 #define MSC_MSAA_REODER_BUF_BYPASS_DISABLE REG_BIT(14) 197 #define FAST_CLEAR_VALIGN_FIX REG_BIT(13) 198 199 #define XE2LPM_CCCHKNREG1 XE_REG(0x82a8) 200 201 #define VF_PREEMPTION XE_REG(0x83a4, XE_REG_OPTION_MASKED) 202 #define PREEMPTION_VERTEX_COUNT REG_GENMASK(15, 0) 203 204 #define VF_SCRATCHPAD XE_REG(0x83a8, XE_REG_OPTION_MASKED) 205 #define XE2_VFG_TED_CREDIT_INTERFACE_DISABLE REG_BIT(13) 206 207 #define VFG_PREEMPTION_CHICKEN XE_REG(0x83b4, XE_REG_OPTION_MASKED) 208 #define POLYGON_TRIFAN_LINELOOP_DISABLE REG_BIT(4) 209 210 #define SQCNT1 XE_REG_MCR(0x8718) 211 #define XELPMP_SQCNT1 XE_REG(0x8718) 212 #define SQCNT1_PMON_ENABLE REG_BIT(30) 213 #define SQCNT1_OABPC REG_BIT(29) 214 #define ENFORCE_RAR REG_BIT(23) 215 216 #define XEHP_SQCM XE_REG_MCR(0x8724) 217 #define EN_32B_ACCESS REG_BIT(30) 218 219 #define XE2_FLAT_CCS_BASE_RANGE_LOWER XE_REG_MCR(0x8800) 220 #define XE2_FLAT_CCS_ENABLE REG_BIT(0) 221 #define XE2_FLAT_CCS_BASE_LOWER_ADDR_MASK REG_GENMASK(31, 6) 222 223 #define XE2_FLAT_CCS_BASE_RANGE_UPPER XE_REG_MCR(0x8804) 224 #define XE2_FLAT_CCS_BASE_UPPER_ADDR_MASK REG_GENMASK(7, 0) 225 226 #define GSCPSMI_BASE XE_REG(0x880c) 227 228 #define CCCHKNREG1 XE_REG_MCR(0x8828) 229 #define L3CMPCTRL REG_BIT(23) 230 #define ENCOMPPERFFIX REG_BIT(18) 231 232 /* Fuse readout registers for GT */ 233 #define XEHP_FUSE4 XE_REG(0x9114) 234 #define CFEG_WMTP_DISABLE REG_BIT(20) 235 #define CCS_EN_MASK REG_GENMASK(19, 16) 236 #define GT_L3_EXC_MASK REG_GENMASK(6, 4) 237 238 #define MIRROR_FUSE3 XE_REG(0x9118) 239 #define XE2_NODE_ENABLE_MASK REG_GENMASK(31, 16) 240 #define L3BANK_PAIR_COUNT 4 241 #define XEHPC_GT_L3_MODE_MASK REG_GENMASK(7, 4) 242 #define XE2_GT_L3_MODE_MASK REG_GENMASK(7, 4) 243 #define L3BANK_MASK REG_GENMASK(3, 0) 244 #define XELP_GT_L3_MODE_MASK REG_GENMASK(7, 0) 245 /* on Xe_HP the same fuses indicates mslices instead of L3 banks */ 246 #define MAX_MSLICES 4 247 #define MEML3_EN_MASK REG_GENMASK(3, 0) 248 249 #define MIRROR_FUSE1 XE_REG(0x911c) 250 251 #define FUSE2 XE_REG(0x9120) 252 #define PRODUCTION_HW REG_BIT(2) 253 254 #define MIRROR_L3BANK_ENABLE XE_REG(0x9130) 255 #define XE3_L3BANK_ENABLE REG_GENMASK(31, 0) 256 257 #define XELP_EU_ENABLE XE_REG(0x9134) /* "_DISABLE" on Xe_LP */ 258 #define XELP_EU_MASK REG_GENMASK(7, 0) 259 #define XELP_GT_SLICE_ENABLE XE_REG(0x9138) 260 #define XELP_GT_GEOMETRY_DSS_ENABLE XE_REG(0x913c) 261 262 #define GT_VEBOX_VDBOX_DISABLE XE_REG(0x9140) 263 #define GT_VEBOX_DISABLE_MASK REG_GENMASK(19, 16) 264 #define GT_VDBOX_DISABLE_MASK REG_GENMASK(7, 0) 265 266 #define XEHP_GT_COMPUTE_DSS_ENABLE XE_REG(0x9144) 267 #define XEHPC_GT_COMPUTE_DSS_ENABLE_EXT XE_REG(0x9148) 268 #define XE2_GT_COMPUTE_DSS_2 XE_REG(0x914c) 269 #define XE2_GT_GEOMETRY_DSS_1 XE_REG(0x9150) 270 #define XE2_GT_GEOMETRY_DSS_2 XE_REG(0x9154) 271 #define XE3P_XPC_GT_GEOMETRY_DSS_3 XE_REG(0x915c) 272 #define XE3P_XPC_GT_COMPUTE_DSS_3 XE_REG(0x9160) 273 274 #define SERVICE_COPY_ENABLE XE_REG(0x9170) 275 #define FUSE_SERVICE_COPY_ENABLE_MASK REG_GENMASK(7, 0) 276 277 #define GDRST XE_REG(0x941c) 278 #define GRDOM_GUC REG_BIT(3) 279 #define GRDOM_FULL REG_BIT(0) 280 281 #define MISCCPCTL XE_REG(0x9424) 282 #define DOP_CLOCK_GATE_RENDER_ENABLE REG_BIT(1) 283 284 #define UNSLCGCTL9430 XE_REG(0x9430) 285 #define MSQDUNIT_CLKGATE_DIS REG_BIT(3) 286 287 #define UNSLICE_UNIT_LEVEL_CLKGATE XE_REG(0x9434) 288 #define VFUNIT_CLKGATE_DIS REG_BIT(20) 289 #define TSGUNIT_CLKGATE_DIS REG_BIT(17) /* XEHPSDV */ 290 #define CG3DDISCFEG_CLKGATE_DIS REG_BIT(17) /* DG2 */ 291 #define GAMEDIA_CLKGATE_DIS REG_BIT(11) 292 #define HSUNIT_CLKGATE_DIS REG_BIT(8) 293 #define VSUNIT_CLKGATE_DIS REG_BIT(3) 294 295 #define UNSLCGCTL9440 XE_REG(0x9440) 296 #define GAMTLBOACS_CLKGATE_DIS REG_BIT(28) 297 #define GAMTLBVDBOX5_CLKGATE_DIS REG_BIT(27) 298 #define GAMTLBVDBOX6_CLKGATE_DIS REG_BIT(26) 299 #define GAMTLBVDBOX3_CLKGATE_DIS REG_BIT(24) 300 #define GAMTLBVDBOX4_CLKGATE_DIS REG_BIT(23) 301 #define GAMTLBVDBOX7_CLKGATE_DIS REG_BIT(22) 302 #define GAMTLBVDBOX2_CLKGATE_DIS REG_BIT(21) 303 #define GAMTLBVDBOX0_CLKGATE_DIS REG_BIT(17) 304 #define GAMTLBKCR_CLKGATE_DIS REG_BIT(16) 305 #define GAMTLBGUC_CLKGATE_DIS REG_BIT(15) 306 #define GAMTLBBLT_CLKGATE_DIS REG_BIT(14) 307 #define GAMTLBVDBOX1_CLKGATE_DIS REG_BIT(6) 308 309 #define UNSLCGCTL9444 XE_REG(0x9444) 310 #define GAMTLBGFXA0_CLKGATE_DIS REG_BIT(30) 311 #define GAMTLBGFXA1_CLKGATE_DIS REG_BIT(29) 312 #define GAMTLBCOMPA0_CLKGATE_DIS REG_BIT(28) 313 #define GAMTLBCOMPA1_CLKGATE_DIS REG_BIT(27) 314 #define GAMTLBCOMPB0_CLKGATE_DIS REG_BIT(26) 315 #define GAMTLBCOMPB1_CLKGATE_DIS REG_BIT(25) 316 #define GAMTLBCOMPC0_CLKGATE_DIS REG_BIT(24) 317 #define GAMTLBCOMPC1_CLKGATE_DIS REG_BIT(23) 318 #define GAMTLBCOMPD0_CLKGATE_DIS REG_BIT(22) 319 #define GAMTLBCOMPD1_CLKGATE_DIS REG_BIT(21) 320 #define GAMTLBMERT_CLKGATE_DIS REG_BIT(20) 321 #define GAMTLBVEBOX3_CLKGATE_DIS REG_BIT(19) 322 #define GAMTLBVEBOX2_CLKGATE_DIS REG_BIT(18) 323 #define GAMTLBVEBOX1_CLKGATE_DIS REG_BIT(17) 324 #define GAMTLBVEBOX0_CLKGATE_DIS REG_BIT(16) 325 #define LTCDD_CLKGATE_DIS REG_BIT(10) 326 327 #define UNSLCGCTL9454 XE_REG(0x9454) 328 #define LSCFE_CLKGATE_DIS REG_BIT(4) 329 330 #define XEHP_SLICE_UNIT_LEVEL_CLKGATE XE_REG_MCR(0x94d4) 331 #define L3_CR2X_CLKGATE_DIS REG_BIT(17) 332 #define L3_CLKGATE_DIS REG_BIT(16) 333 #define NODEDSS_CLKGATE_DIS REG_BIT(12) 334 #define MSCUNIT_CLKGATE_DIS REG_BIT(10) 335 #define RCCUNIT_CLKGATE_DIS REG_BIT(7) 336 #define SARBUNIT_CLKGATE_DIS REG_BIT(5) 337 #define SBEUNIT_CLKGATE_DIS REG_BIT(4) 338 339 #define UNSLICE_UNIT_LEVEL_CLKGATE2 XE_REG(0x94e4) 340 #define VSUNIT_CLKGATE2_DIS REG_BIT(19) 341 342 #define SUBSLICE_UNIT_LEVEL_CLKGATE XE_REG_MCR(0x9524) 343 #define DSS_ROUTER_CLKGATE_DIS REG_BIT(28) 344 #define GWUNIT_CLKGATE_DIS REG_BIT(16) 345 346 #define SUBSLICE_UNIT_LEVEL_CLKGATE2 XE_REG_MCR(0x9528) 347 #define CPSSUNIT_CLKGATE_DIS REG_BIT(9) 348 349 #define SSMCGCTL9530 XE_REG_MCR(0x9530) 350 #define RTFUNIT_CLKGATE_DIS REG_BIT(18) 351 352 #define DFR_RATIO_EN_AND_CHICKEN XE_REG_MCR(0x9550) 353 #define DFR_DISABLE REG_BIT(9) 354 355 #define RPNSWREQ XE_REG(0xa008) 356 #define REQ_RATIO_MASK REG_GENMASK(31, 23) 357 358 #define RP_CONTROL XE_REG(0xa024) 359 #define RPSWCTL_MASK REG_GENMASK(10, 9) 360 #define RPSWCTL_ENABLE REG_FIELD_PREP(RPSWCTL_MASK, 2) 361 #define RPSWCTL_DISABLE REG_FIELD_PREP(RPSWCTL_MASK, 0) 362 #define RC_CONTROL XE_REG(0xa090) 363 #define RC_CTL_HW_ENABLE REG_BIT(31) 364 #define RC_CTL_TO_MODE REG_BIT(28) 365 #define RC_CTL_RC6_ENABLE REG_BIT(18) 366 #define RC_STATE XE_REG(0xa094) 367 #define RC_IDLE_HYSTERSIS XE_REG(0xa0ac) 368 #define MEDIA_POWERGATE_IDLE_HYSTERESIS XE_REG(0xa0c4) 369 #define RENDER_POWERGATE_IDLE_HYSTERESIS XE_REG(0xa0c8) 370 371 #define PMINTRMSK XE_REG(0xa168) 372 #define PMINTR_DISABLE_REDIRECT_TO_GUC REG_BIT(31) 373 #define ARAT_EXPIRED_INTRMSK REG_BIT(9) 374 375 #define FORCEWAKE_GT XE_REG(0xa188) 376 377 #define POWERGATE_ENABLE XE_REG(0xa210) 378 #define RENDER_POWERGATE_ENABLE REG_BIT(0) 379 #define MEDIA_POWERGATE_ENABLE REG_BIT(1) 380 #define MEDIA_SAMPLERS_POWERGATE_ENABLE REG_BIT(2) 381 #define VDN_HCP_POWERGATE_ENABLE(n) REG_BIT(3 + 2 * (n)) 382 #define VDN_MFXVDENC_POWERGATE_ENABLE(n) REG_BIT(4 + 2 * (n)) 383 384 #define FORCEWAKE_RENDER XE_REG(0xa278) 385 386 #define POWERGATE_DOMAIN_STATUS XE_REG(0xa2a0) 387 #define GSC_AWAKE_STATUS REG_BIT(8) 388 #define MEDIA_SLICE3_AWAKE_STATUS REG_BIT(4) 389 #define MEDIA_SLICE2_AWAKE_STATUS REG_BIT(3) 390 #define MEDIA_SLICE1_AWAKE_STATUS REG_BIT(2) 391 #define RENDER_AWAKE_STATUS REG_BIT(1) 392 #define MEDIA_SLICE0_AWAKE_STATUS REG_BIT(0) 393 394 #define MISC_STATUS_0 XE_REG(0xa500) 395 396 #define FORCEWAKE_MEDIA_VDBOX(n) XE_REG(0xa540 + (n) * 4) 397 #define FORCEWAKE_MEDIA_VEBOX(n) XE_REG(0xa560 + (n) * 4) 398 #define FORCEWAKE_GSC XE_REG(0xa618) 399 400 #define XELP_GARBCNTL XE_REG(0xb004) 401 #define XELP_BUS_HASH_CTL_BIT_EXC REG_BIT(7) 402 403 #define XEHPC_LNCFMISCCFGREG0 XE_REG_MCR(0xb01c, XE_REG_OPTION_MASKED) 404 #define XEHPC_OVRLSCCC REG_BIT(0) 405 406 #define LNCFCMOCS_REG_COUNT 32 407 #define XELP_LNCFCMOCS(i) XE_REG(0xb020 + (i) * 4) 408 #define XEHP_LNCFCMOCS(i) XE_REG_MCR(0xb020 + (i) * 4) 409 #define L3_UPPER_LKUP_MASK REG_BIT(23) 410 #define L3_UPPER_GLBGO_MASK REG_BIT(22) 411 #define L3_UPPER_IDX_CACHEABILITY_MASK REG_GENMASK(21, 20) 412 #define L3_UPPER_IDX_SCC_MASK REG_GENMASK(19, 17) 413 #define L3_UPPER_IDX_ESC_MASK REG_BIT(16) 414 #define L3_LKUP_MASK REG_BIT(7) 415 #define L3_LKUP(value) REG_FIELD_PREP(L3_LKUP_MASK, value) 416 #define L3_GLBGO_MASK REG_BIT(6) 417 #define L3_GLBGO(value) REG_FIELD_PREP(L3_GLBGO_MASK, value) 418 #define L3_CACHEABILITY_MASK REG_GENMASK(5, 4) 419 #define L3_CACHEABILITY(value) REG_FIELD_PREP(L3_CACHEABILITY_MASK, value) 420 #define L3_SCC_MASK REG_GENMASK(3, 1) 421 #define L3_SCC(value) REG_FIELD_PREP(L3_SCC_MASK, value) 422 #define L3_ESC_MASK REG_BIT(0) 423 #define L3_ESC(value) REG_FIELD_PREP(L3_ESC_MASK, value) 424 425 #define XEHP_L3NODEARBCFG XE_REG_MCR(0xb0b4) 426 #define XEHP_LNESPARE REG_BIT(19) 427 428 #define LSN_VC_REG2 XE_REG_MCR(0xb0c8) 429 #define LSN_LNI_WGT_MASK REG_GENMASK(31, 28) 430 #define LSN_LNI_WGT(value) REG_FIELD_PREP(LSN_LNI_WGT_MASK, value) 431 #define LSN_LNE_WGT_MASK REG_GENMASK(27, 24) 432 #define LSN_LNE_WGT(value) REG_FIELD_PREP(LSN_LNE_WGT_MASK, value) 433 #define LSN_DIM_X_WGT_MASK REG_GENMASK(23, 20) 434 #define LSN_DIM_X_WGT(value) REG_FIELD_PREP(LSN_DIM_X_WGT_MASK, value) 435 #define LSN_DIM_Y_WGT_MASK REG_GENMASK(19, 16) 436 #define LSN_DIM_Y_WGT(value) REG_FIELD_PREP(LSN_DIM_Y_WGT_MASK, value) 437 #define LSN_DIM_Z_WGT_MASK REG_GENMASK(15, 12) 438 #define LSN_DIM_Z_WGT(value) REG_FIELD_PREP(LSN_DIM_Z_WGT_MASK, value) 439 440 #define L3SQCREG2 XE_REG_MCR(0xb104) 441 #define L3_SQ_DISABLE_COAMA_2WAY_COH REG_BIT(30) 442 #define L3_SQ_DISABLE_COAMA REG_BIT(22) 443 #define COMPMEMRD256BOVRFETCHEN REG_BIT(20) 444 445 #define L3SQCREG3 XE_REG_MCR(0xb108) 446 #define COMPPWOVERFETCHEN REG_BIT(28) 447 448 #define SCRATCH3_LBCF XE_REG_MCR(0xb154) 449 #define RWFLUSHALLEN REG_BIT(17) 450 451 #define XEHP_L3SQCREG5 XE_REG_MCR(0xb158) 452 #define L3_PWM_TIMER_INIT_VAL_MASK REG_GENMASK(9, 0) 453 454 #define XEHP_L3SCQREG7 XE_REG_MCR(0xb188) 455 #define BLEND_FILL_CACHING_OPT_DIS REG_BIT(3) 456 457 #define XEHPC_L3CLOS_MASK(i) XE_REG_MCR(0xb194 + (i) * 8) 458 459 #define L2COMPUTESIDECTRL XE_REG_MCR(0xb1c0) 460 #define CECTRL REG_GENMASK(2, 1) 461 #define CECTRL_CENODATA_ALWAYS REG_FIELD_PREP(CECTRL, 0x0) 462 463 #define XE2_GLOBAL_INVAL XE_REG(0xb404) 464 465 #define XE2LPM_L3SQCREG2 XE_REG_MCR(0xb604) 466 467 #define XE2LPM_L3SQCREG3 XE_REG_MCR(0xb608) 468 469 #define XE2LPM_SCRATCH3_LBCF XE_REG_MCR(0xb654) 470 471 #define XE2LPM_L3SQCREG5 XE_REG_MCR(0xb658) 472 473 #define XE2_TDF_CTRL XE_REG(0xb418) 474 #define TRANSIENT_FLUSH_REQUEST REG_BIT(0) 475 476 #define XEHP_MERT_MOD_CTRL XE_REG_MCR(0xcf28) 477 #define RENDER_MOD_CTRL XE_REG_MCR(0xcf2c) 478 #define COMP_MOD_CTRL XE_REG_MCR(0xcf30) 479 #define XEHP_VDBX_MOD_CTRL XE_REG_MCR(0xcf34) 480 #define XELPMP_VDBX_MOD_CTRL XE_REG(0xcf34) 481 #define XEHP_VEBX_MOD_CTRL XE_REG_MCR(0xcf38) 482 #define XELPMP_VEBX_MOD_CTRL XE_REG(0xcf38) 483 #define FORCE_MISS_FTLB REG_BIT(3) 484 485 #define XEHP_GAMSTLB_CTRL XE_REG_MCR(0xcf4c) 486 #define BANK_HASH_MODE REG_GENMASK(27, 26) 487 #define BANK_HASH_4KB_MODE REG_FIELD_PREP(BANK_HASH_MODE, 0x3) 488 #define CONTROL_BLOCK_CLKGATE_DIS REG_BIT(12) 489 #define EGRESS_BLOCK_CLKGATE_DIS REG_BIT(11) 490 #define TAG_BLOCK_CLKGATE_DIS REG_BIT(7) 491 492 #define XEHP_GAMCNTRL_CTRL XE_REG_MCR(0xcf54) 493 #define INVALIDATION_BROADCAST_MODE_DIS REG_BIT(12) 494 #define GLOBAL_INVALIDATION_MODE REG_BIT(2) 495 496 #define LMEM_CFG XE_REG(0xcf58) 497 #define LMEM_EN REG_BIT(31) 498 #define LMTT_DIR_PTR REG_GENMASK(30, 0) /* in multiples of 64KB */ 499 500 #define HALF_SLICE_CHICKEN5 XE_REG_MCR(0xe188, XE_REG_OPTION_MASKED) 501 #define DISABLE_SAMPLE_G_PERFORMANCE REG_BIT(0) 502 503 #define SAMPLER_INSTDONE XE_REG_MCR(0xe160) 504 #define ROW_INSTDONE XE_REG_MCR(0xe164) 505 506 #define SAMPLER_MODE XE_REG_MCR(0xe18c, XE_REG_OPTION_MASKED) 507 #define ENABLE_SMALLPL REG_BIT(15) 508 #define SMP_WAIT_FETCH_MERGING_COUNTER REG_GENMASK(11, 10) 509 #define SMP_FORCE_128B_OVERFETCH REG_FIELD_PREP(SMP_WAIT_FETCH_MERGING_COUNTER, 1) 510 #define SC_DISABLE_POWER_OPTIMIZATION_EBB REG_BIT(9) 511 #define SAMPLER_ENABLE_HEADLESS_MSG REG_BIT(5) 512 #define INDIRECT_STATE_BASE_ADDR_OVERRIDE REG_BIT(0) 513 514 #define HALF_SLICE_CHICKEN7 XE_REG_MCR(0xe194, XE_REG_OPTION_MASKED) 515 #define DG2_DISABLE_ROUND_ENABLE_ALLOW_FOR_SSLA REG_BIT(15) 516 #define CLEAR_OPTIMIZATION_DISABLE REG_BIT(6) 517 518 #define CACHE_MODE_SS XE_REG_MCR(0xe420, XE_REG_OPTION_MASKED) 519 #define DISABLE_ECC REG_BIT(5) 520 #define ENABLE_PREFETCH_INTO_IC REG_BIT(3) 521 522 #define ROW_CHICKEN4 XE_REG_MCR(0xe48c, XE_REG_OPTION_MASKED) 523 #define DISABLE_GRF_CLEAR REG_BIT(13) 524 #define XEHP_DIS_BBL_SYSPIPE REG_BIT(11) 525 #define DISABLE_TDL_PUSH REG_BIT(9) 526 #define DIS_PICK_2ND_EU REG_BIT(7) 527 #define DISABLE_HDR_PAST_PAYLOAD_HOLD_FIX REG_BIT(4) 528 #define THREAD_EX_ARB_MODE REG_GENMASK(3, 2) 529 #define THREAD_EX_ARB_MODE_RR_AFTER_DEP REG_FIELD_PREP(THREAD_EX_ARB_MODE, 0x2) 530 531 #define ROW_CHICKEN3 XE_REG_MCR(0xe49c, XE_REG_OPTION_MASKED) 532 #define XE2_EUPEND_CHK_FLUSH_DIS REG_BIT(14) 533 #define DIS_FIX_EOT1_FLUSH REG_BIT(9) 534 535 #define TDL_TSL_CHICKEN XE_REG_MCR(0xe4c4, XE_REG_OPTION_MASKED) 536 #define STK_ID_RESTRICT REG_BIT(12) 537 #define SLM_WMTP_RESTORE REG_BIT(11) 538 #define RES_CHK_SPR_DIS REG_BIT(6) 539 540 #define ROW_CHICKEN XE_REG_MCR(0xe4f0, XE_REG_OPTION_MASKED) 541 #define UGM_BACKUP_MODE REG_BIT(13) 542 #define MDQ_ARBITRATION_MODE REG_BIT(12) 543 #define STALL_DOP_GATING_DISABLE REG_BIT(5) 544 #define EARLY_EOT_DIS REG_BIT(1) 545 546 #define ROW_CHICKEN2 XE_REG_MCR(0xe4f4, XE_REG_OPTION_MASKED) 547 #define DISABLE_READ_SUPPRESSION REG_BIT(15) 548 #define DISABLE_EARLY_READ REG_BIT(14) 549 #define ENABLE_LARGE_GRF_MODE REG_BIT(12) 550 #define PUSH_CONST_DEREF_HOLD_DIS REG_BIT(8) 551 #define DISABLE_TDL_SVHS_GATING REG_BIT(1) 552 #define DISABLE_DOP_GATING REG_BIT(0) 553 554 #define RT_CTRL XE_REG_MCR(0xe530) 555 #define DIS_NULL_QUERY REG_BIT(10) 556 557 #define EU_SYSTOLIC_LIC_THROTTLE_CTL_WITH_LOCK XE_REG_MCR(0xe534) 558 #define EU_SYSTOLIC_LIC_THROTTLE_CTL_LOCK_BIT REG_BIT(31) 559 560 #define XEHP_HDC_CHICKEN0 XE_REG_MCR(0xe5f0, XE_REG_OPTION_MASKED) 561 #define LSC_L1_FLUSH_CTL_3D_DATAPORT_FLUSH_EVENTS_MASK REG_GENMASK(13, 11) 562 #define DIS_ATOMIC_CHAINING_TYPED_WRITES REG_BIT(3) 563 564 #define TDL_CHICKEN XE_REG_MCR(0xe5f4, XE_REG_OPTION_MASKED) 565 #define QID_WAIT_FOR_THREAD_NOT_RUN_DISABLE REG_BIT(12) 566 #define EUSTALL_PERF_SAMPLING_DISABLE REG_BIT(5) 567 568 #define LSC_CHICKEN_BIT_0 XE_REG_MCR(0xe7c8) 569 #define DISABLE_D8_D16_COASLESCE REG_BIT(30) 570 #define WR_REQ_CHAINING_DIS REG_BIT(26) 571 #define TGM_WRITE_EOM_FORCE REG_BIT(17) 572 #define FORCE_1_SUB_MESSAGE_PER_FRAGMENT REG_BIT(15) 573 #define SEQUENTIAL_ACCESS_UPGRADE_DISABLE REG_BIT(13) 574 575 #define LSC_CHICKEN_BIT_0_UDW XE_REG_MCR(0xe7c8 + 4) 576 #define UGM_FRAGMENT_THRESHOLD_TO_3 REG_BIT(58 - 32) 577 #define DIS_CHAIN_2XSIMD8 REG_BIT(55 - 32) 578 #define XE2_ALLOC_DPA_STARVE_FIX_DIS REG_BIT(47 - 32) 579 #define SAMPLER_LD_LSC_DISABLE REG_BIT(45 - 32) 580 #define ENABLE_SMP_LD_RENDER_SURFACE_CONTROL REG_BIT(44 - 32) 581 #define FORCE_SLM_FENCE_SCOPE_TO_TILE REG_BIT(42 - 32) 582 #define FORCE_UGM_FENCE_SCOPE_TO_TILE REG_BIT(41 - 32) 583 #define L3_128B_256B_WRT_DIS REG_BIT(40 - 32) 584 #define MAXREQS_PER_BANK REG_GENMASK(39 - 32, 37 - 32) 585 #define DISABLE_128B_EVICTION_COMMAND_UDW REG_BIT(36 - 32) 586 #define LSCFE_SAME_ADDRESS_ATOMICS_COALESCING_DISABLE REG_BIT(35 - 32) 587 588 #define ROW_CHICKEN5 XE_REG_MCR(0xe7f0, XE_REG_OPTION_MASKED) 589 #define CPSS_AWARE_DIS REG_BIT(3) 590 591 #define SARB_CHICKEN1 XE_REG_MCR(0xe90c) 592 #define COMP_CKN_IN REG_GENMASK(30, 29) 593 594 #define MAIN_GAMCTRL_MODE XE_REG(0xef00) 595 #define MAIN_GAMCTRL_QUEUE_SELECT REG_BIT(0) 596 597 #define RCU_MODE XE_REG(0x14800, XE_REG_OPTION_MASKED) 598 #define RCU_MODE_FIXED_SLICE_CCS_MODE REG_BIT(1) 599 #define RCU_MODE_CCS_ENABLE REG_BIT(0) 600 601 /* 602 * Total of 4 cslices, where each cslice is in the form: 603 * [0-3] CCS ID 604 * [4-6] RSVD 605 * [7] Disabled 606 */ 607 #define CCS_MODE XE_REG(0x14804, XE_REG_OPTION_MASKED) 608 #define CCS_MODE_CSLICE_0_3_MASK REG_GENMASK(11, 0) /* 3 bits per cslice */ 609 #define CCS_MODE_CSLICE_MASK 0x7 /* CCS0-3 + rsvd */ 610 #define CCS_MODE_CSLICE_WIDTH ilog2(CCS_MODE_CSLICE_MASK + 1) 611 #define CCS_MODE_CSLICE(cslice, ccs) \ 612 ((ccs) << ((cslice) * CCS_MODE_CSLICE_WIDTH)) 613 614 #define FORCEWAKE_ACK_GT XE_REG(0x130044) 615 616 /* Applicable for all FORCEWAKE_DOMAIN and FORCEWAKE_ACK_DOMAIN regs */ 617 #define FORCEWAKE_KERNEL 0 618 #define FORCEWAKE_MT(bit) BIT(bit) 619 #define FORCEWAKE_MT_MASK(bit) BIT((bit) + 16) 620 621 #define MTL_MEDIA_PERF_LIMIT_REASONS XE_REG(0x138030) 622 #define MTL_MEDIA_MC6 XE_REG(0x138048) 623 624 #define GT_CORE_STATUS XE_REG(0x138060) 625 #define RCN_MASK REG_GENMASK(2, 0) 626 #define GT_C0 0 627 #define GT_C6 3 628 629 #define GT_GFX_RC6_LOCKED XE_REG(0x138104) 630 #define GT_GFX_RC6 XE_REG(0x138108) 631 632 #define GT0_PERF_LIMIT_REASONS XE_REG(0x1381a8) 633 /* Common performance limit reason bits - available on all platforms */ 634 #define GT0_PERF_LIMIT_REASONS_MASK 0xde3 635 #define PROCHOT_MASK REG_BIT(0) 636 #define THERMAL_LIMIT_MASK REG_BIT(1) 637 #define RATL_MASK REG_BIT(5) 638 #define VR_THERMALERT_MASK REG_BIT(6) 639 #define VR_TDC_MASK REG_BIT(7) 640 #define POWER_LIMIT_4_MASK REG_BIT(8) 641 #define POWER_LIMIT_1_MASK REG_BIT(10) 642 #define POWER_LIMIT_2_MASK REG_BIT(11) 643 /* Platform-specific performance limit reason bits - for Crescent Island */ 644 #define CRI_PERF_LIMIT_REASONS_MASK 0xfdff 645 #define SOC_THERMAL_LIMIT_MASK REG_BIT(1) 646 #define MEM_THERMAL_MASK REG_BIT(2) 647 #define VR_THERMAL_MASK REG_BIT(3) 648 #define ICCMAX_MASK REG_BIT(4) 649 #define SOC_AVG_THERMAL_MASK REG_BIT(6) 650 #define FASTVMODE_MASK REG_BIT(7) 651 #define PSYS_PL1_MASK REG_BIT(12) 652 #define PSYS_PL2_MASK REG_BIT(13) 653 #define P0_FREQ_MASK REG_BIT(14) 654 #define PSYS_CRIT_MASK REG_BIT(15) 655 656 #define GT_PERF_STATUS XE_REG(0x1381b4) 657 #define VOLTAGE_MASK REG_GENMASK(10, 0) 658 659 #define SFC_DONE(n) XE_REG(0x1cc000 + (n) * 0x1000) 660 661 #endif 662