Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

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