aboutsummaryrefslogtreecommitdiff
path: root/src/vendorcode/amd/agesa/f16kb/Proc/GNB/Modules/GnbInitKB/GfxTablesKB.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/vendorcode/amd/agesa/f16kb/Proc/GNB/Modules/GnbInitKB/GfxTablesKB.c')
-rw-r--r--src/vendorcode/amd/agesa/f16kb/Proc/GNB/Modules/GnbInitKB/GfxTablesKB.c479
1 files changed, 479 insertions, 0 deletions
diff --git a/src/vendorcode/amd/agesa/f16kb/Proc/GNB/Modules/GnbInitKB/GfxTablesKB.c b/src/vendorcode/amd/agesa/f16kb/Proc/GNB/Modules/GnbInitKB/GfxTablesKB.c
new file mode 100644
index 0000000000..99e7f933a9
--- /dev/null
+++ b/src/vendorcode/amd/agesa/f16kb/Proc/GNB/Modules/GnbInitKB/GfxTablesKB.c
@@ -0,0 +1,479 @@
+/* $NoKeywords:$ */
+/**
+ * @file
+ *
+ * GFx tables
+ *
+ *
+ *
+ * @xrefitem bom "File Content Label" "Release Content"
+ * @e project: AGESA
+ * @e sub-project: GNB
+ * @e \$Revision: 87698 $ @e \$Date: 2013-02-07 12:40:51 -0600 (Thu, 07 Feb 2013) $
+ *
+ */
+/*
+*****************************************************************************
+*
+ * Copyright (c) 2008 - 2013, Advanced Micro Devices, Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of Advanced Micro Devices, Inc. nor the names of
+ * its contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL ADVANCED MICRO DEVICES, INC. BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+* ***************************************************************************
+*
+*/
+/*----------------------------------------------------------------------------------------
+ * M O D U L E S U S E D
+ *----------------------------------------------------------------------------------------
+ */
+#include "AGESA.h"
+#include "Gnb.h"
+#include "GnbPcie.h"
+#include "GnbCommonLib.h"
+#include "GnbTable.h"
+#include "GnbRegistersKB.h"
+#include "cpuFamilyTranslation.h"
+
+/*----------------------------------------------------------------------------------------
+ * D E F I N I T I O N S A N D M A C R O S
+ *----------------------------------------------------------------------------------------
+ */
+
+
+/*----------------------------------------------------------------------------------------
+ * T Y P E D E F S A N D S T R U C T U R E S
+ *----------------------------------------------------------------------------------------
+ */
+
+
+/*----------------------------------------------------------------------------------------
+ * P R O T O T Y P E S O F L O C A L F U N C T I O N S
+ *----------------------------------------------------------------------------------------
+ */
+
+
+/*----------------------------------------------------------------------------------------
+ * T A B L E S
+ *----------------------------------------------------------------------------------------
+ */
+
+GNB_TABLE ROMDATA GfxGmcFeature1DisableKB [] = {
+ //2.1 Disable clock-gating
+ GNB_ENTRY_WR (0x12, 0x20C0, 0x00000C80),
+ GNB_ENTRY_WR (0x12, 0x2478, 0x00000400),
+ GNB_ENTRY_WR (0x12, 0x20B8, 0x00000400),
+ GNB_ENTRY_WR (0x12, 0x20BC, 0x00000400),
+ GNB_ENTRY_WR (0x12, 0x2648, 0x00000400),
+ GNB_ENTRY_WR (0x12, 0x264C, 0x00000400),
+ GNB_ENTRY_WR (0x12, 0x2650, 0x00000400),
+ GNB_ENTRY_WR (0x12, 0x15C0, 0x00000400),
+ GNB_ENTRY_TERMINATE
+};
+
+GNB_TABLE ROMDATA GfxGmcInitTableKB [] = {
+ GNB_ENTRY_RMW (D18F5x178_TYPE, D18F5x178_ADDRESS, D18F5x178_SwGfxDis_MASK, 0 << D18F5x178_SwGfxDis_OFFSET),
+ //2.2 System memory address translation
+ GNB_ENTRY_COPY (0x12, 0x2814, 0, 32, D18F2x40_dct0_TYPE, D18F2x40_dct0_ADDRESS, 0, 32),
+ GNB_ENTRY_COPY (0x12, 0x281C, 0, 32, D18F2x44_dct0_TYPE, D18F2x44_dct0_ADDRESS, 0, 32),
+ GNB_ENTRY_COPY (0x12, 0x2824, 0, 32, D18F2x48_dct0_TYPE, D18F2x48_dct0_ADDRESS, 0, 32),
+ GNB_ENTRY_COPY (0x12, 0x282C, 0, 32, D18F2x4C_dct0_TYPE, D18F2x4C_dct0_ADDRESS, 0, 32),
+ GNB_ENTRY_COPY (0x12, 0x2834, 0, 32, D18F2x60_dct0_TYPE, D18F2x60_dct0_ADDRESS, 0, 32),
+ GNB_ENTRY_COPY (0x12, 0x283C, 0, 32, D18F2x64_dct0_TYPE, D18F2x64_dct0_ADDRESS, 0, 32),
+ // MC_FUS_DRAM0_BANK_ADDR_MAPPING
+ GNB_ENTRY_COPY (0x12, 0x2844, 0, 8, D18F2x80_dct0_TYPE, D18F2x80_dct0_ADDRESS, 0, 8),
+ GNB_ENTRY_COPY (0x12, 0x2844, 8, 1, D18F2x94_dct0_TYPE, D18F2x94_dct0_ADDRESS, 22, 1),
+ GNB_ENTRY_COPY (0x12, 0x2844, 9, 1, D18F2xA8_dct0_TYPE, D18F2xA8_dct0_ADDRESS, 20, 1),
+ // MC_FUS_DRAM0_CTL_BASE
+ GNB_ENTRY_COPY (0x12, 0x284C, 0, 3, D18F1x200_TYPE, D18F1x200_ADDRESS, 4, 3),
+ GNB_ENTRY_COPY (0x12, 0x284C, 3, 4, D18F1x204_TYPE, D18F1x204_ADDRESS, 0, 4),
+ GNB_ENTRY_COPY (0x12, 0x284C, 7, 21, D18F1x200_TYPE, D18F1x200_ADDRESS, 11, 21),
+ GNB_ENTRY_COPY (0x12, 0x284C, 28, 1, D18F1x200_TYPE, D18F1x200_ADDRESS, 3, 1),
+ GNB_ENTRY_COPY (0x12, 0x284C, 29, 1, D18F1x200_TYPE, D18F1x200_ADDRESS, 0, 1),
+ // MC_FUS_DRAM0_CTL_LIMIT
+ GNB_ENTRY_COPY (0x12, 0x2854, 0, 21, D18F1x204_TYPE, D18F1x204_ADDRESS, 11, 21),
+ GNB_ENTRY_COPY (0x12, 0x2854, 21, 1, D18F1xF0_TYPE, D18F1xF0_ADDRESS, 1, 1),
+ // MC_FUS_DRAM_MODE
+ GNB_ENTRY_COPY (0x12, 0x2864, 3, 1, D18F2x78_dct0_TYPE, D18F2x78_dct0_ADDRESS, 8, 1),
+ GNB_ENTRY_COPY (0x12, 0x2864, 4, 9, D18F1xF0_TYPE, D18F1xF0_ADDRESS, 7, 9),
+ GNB_ENTRY_COPY (0x12, 0x2864, 0, 2, D18F2x110_TYPE, D18F2x110_ADDRESS, 6, 2),
+ GNB_ENTRY_COPY (0x12, 0x2864, 2, 1, D18F2x114_TYPE, D18F2x114_ADDRESS, 9, 1),
+ // MC_FUS_DRAM_CTL_HIGH_01
+ GNB_ENTRY_COPY (0x12, 0x285C, 0, 12, D18F1x240_TYPE, D18F1x240_ADDRESS, 11, 12),
+
+ // 2.4 Sequencer model programming
+ GNB_ENTRY_WR (0x12, 0x276C, 0x000003ff),
+
+ //---------------------------------------------------------------------------
+ // 2.5 Power gating init
+ // Initializing PGFSMs
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x3538, 0x200010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x3538, 0x300010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x210000),
+ GNB_ENTRY_WR (0x12, 0x3538, 0xa00010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x21003),
+ GNB_ENTRY_WR (0x12, 0x3538, 0xb00010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x2b00),
+ GNB_ENTRY_WR (0x12, 0x3538, 0xc00010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x3538, 0xd00010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x420000),
+ GNB_ENTRY_WR (0x12, 0x3538, 0x100010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x120202),
+ GNB_ENTRY_WR (0x12, 0x3538, 0x500010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x3e3e36),
+ GNB_ENTRY_WR (0x12, 0x3538, 0x600010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x373f3e),
+ GNB_ENTRY_WR (0x12, 0x3538, 0x700010ff),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x0),
+ GNB_ENTRY_WR (0x12, 0x353C, 0x3e1332),
+ GNB_ENTRY_WR (0x12, 0x3538, 0xe00010ff),
+//---------------------------------------------------------------------------
+// Initializing register engine
+// opcode=1, body_cnt=0, mask=0xf, const=0xf: MC_CONFIG (0x800) MC_CONFIG (0x800)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x0),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x10000800),
+ GNB_ENTRY_WR (0x12, 0x3504, 0xf),
+ GNB_ENTRY_WR (0x12, 0x3504, 0xf),
+// opcode=1, body_cnt=0, mask=0x3f, const=0x3f: MC_CONFIG_MCD (0x828) MC_CONFIG_MCD (0x828)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x4),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x10000828),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x3f),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x3f),
+// opcode=1, body_cnt=0, mask=0xffff, const=0xffff: VM_INVALIDATE_REQUEST (0x51e) VM_INVALIDATE_REQUEST (0x51e)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x8),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x1000051e),
+ GNB_ENTRY_WR (0x12, 0x3504, 0xffff),
+ GNB_ENTRY_WR (0x12, 0x3504, 0xffff),
+// opcode=0, body_cnt=2: VM_L2_CNTL (0x500) VM_L2_CNTL3 (0x502)
+ GNB_ENTRY_WR (0x12, 0x3500, 0xc),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x20500),
+// opcode=0, body_cnt=4: VM_CONTEXT0_CNTL (0x504) VM_SECURE_FAULT_CNTL (0x508)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x10),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x40504),
+// opcode=0, body_cnt=9: VM_CONTEXT0_CNTL2 (0x50c) VM_CONTEXT15_PAGE_TABLE_BASE_ADDR (0x515)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x16),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x9050c),
+// opcode=0, body_cnt=9: VM_PRT_APERTURE0_LOW_ADDR (0x52c) VM_CONTEXTS_DISABLE (0x535)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x21),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x9052c),
+// opcode=0, body_cnt=1: VM_CONTEXT0_PROTECTION_FAULT_DEFAULT_ADDR (0x546) VM_CONTEXT1_PROTECTION_FAULT_DEFAULT_ADDR (0x547)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x2c),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x10546),
+// opcode=0, body_cnt=10: VM_FAULT_CLIENT_ID (0x54e) VM_CONTEXT1_PAGE_TABLE_START_ADDR (0x558)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x2f),
+ GNB_ENTRY_WR (0x12, 0x3504, 0xa054e),
+// opcode=0, body_cnt=1: VM_CONTEXT0_PAGE_TABLE_END_ADDR (0x55f) VM_CONTEXT1_PAGE_TABLE_END_ADDR (0x560)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x3b),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x1055f),
+// opcode=0, body_cnt=1: VM_DEBUG (0x56f) VM_L2_CG (0x570)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x3e),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x1056f),
+// opcode=0, body_cnt=1: VM_L2_BANK_SELECT_MASKA (0x572) VM_L2_BANK_SELECT_MASKB (0x573)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x41),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x10572),
+// opcode=0, body_cnt=2: VM_L2_CONTEXT1_IDENTITY_APERTURE_LOW_ADDR (0x575) VM_L2_CONTEXT_IDENTITY_PHYSICAL_OFFSET (0x577)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x44),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x20575),
+// opcode=0, body_cnt=53: MC_CITF_PERFCOUNTER_LO (0x7a0) ATC_PERFCOUNTER_RSLT_CNTL (0x7d5)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x48),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x3507a0),
+// opcode=0, body_cnt=0: MC_ARB_PERF_MON_CNTL0_ECC (0x7db) MC_ARB_PERF_MON_CNTL0_ECC (0x7db)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x7f),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x7db),
+// opcode=0, body_cnt=26: MC_SHARED_CHMAP (0x801) MC_VM_STEERING (0x81b)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x81),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x1a0801),
+// opcode=0, body_cnt=2: MC_CG_CONFIG_MCD (0x829) MC_SHARED_BLACKOUT_CNTL (0x82b)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x9d),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x20829),
+// opcode=0, body_cnt=4: MC_HUB_MISC_POWER (0x82d) MC_HUB_MISC_DBG (0x831)
+ GNB_ENTRY_WR (0x12, 0x3500, 0xa1),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x4082d),
+// opcode=0, body_cnt=4: MC_HUB_MISC_OVERRIDE (0x833) MC_HUB_WDP_BP (0x837)
+ GNB_ENTRY_WR (0x12, 0x3500, 0xa7),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x40833),
+// opcode=0, body_cnt=11: MC_HUB_RDREQ_CNTL (0x83b) MC_HUB_SHARED_DAGB_DLY (0x846)
+ GNB_ENTRY_WR (0x12, 0x3500, 0xad),
+ GNB_ENTRY_WR (0x12, 0x3504, 0xb083b),
+// opcode=0, body_cnt=1: MC_HUB_RDREQ_DMIF_LIMIT (0x848) MC_HUB_RDREQ_ACPG_LIMIT (0x849)
+ GNB_ENTRY_WR (0x12, 0x3500, 0xba),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x10848),
+// opcode=0, body_cnt=63: MC_HUB_WDP_SH2 (0x84d) MC_HUB_WDP_SAM (0x88c)
+ GNB_ENTRY_WR (0x12, 0x3500, 0xbd),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x3f084d),
+// opcode=0, body_cnt=0: MC_VM_MB_L1_TLB0_DEBUG (0x891) MC_VM_MB_L1_TLB0_DEBUG (0x891)
+ GNB_ENTRY_WR (0x12, 0x3500, 0xfe),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x891),
+// opcode=0, body_cnt=0: MC_VM_MB_L1_TLB2_DEBUG (0x893) MC_VM_MB_L1_TLB2_DEBUG (0x893)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x100),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x893),
+// opcode=0, body_cnt=0: MC_VM_MB_L2ARBITER_L2_CREDITS (0x8a1) MC_VM_MB_L2ARBITER_L2_CREDITS (0x8a1)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x102),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x8a1),
+// opcode=0, body_cnt=0: MC_VM_MB_L1_TLB3_DEBUG (0x8a5) MC_VM_MB_L1_TLB3_DEBUG (0x8a5)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x104),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x8a5),
+// opcode=0, body_cnt=51: MC_XPB_RTR_SRC_APRTR0 (0x8cd) MC_XPB_UNC_THRESH_SID (0x900)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x106),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x3308cd),
+// opcode=0, body_cnt=1: MC_XPB_WCB_CFG (0x902) MC_XPB_P2P_BAR_CFG (0x903)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x13b),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x10902),
+// opcode=0, body_cnt=19: MC_XPB_P2P_BAR_SETUP (0x90c) MC_XPB_INTF_CFG (0x91f)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x13e),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x13090c),
+// opcode=0, body_cnt=0: MC_XPB_SUB_CTRL (0x922) MC_XPB_SUB_CTRL (0x922)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x153),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x922),
+// opcode=0, body_cnt=0: MC_XPB_PERF_KNOBS (0x924) MC_XPB_PERF_KNOBS (0x924)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x155),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x924),
+// opcode=0, body_cnt=20: MC_XPB_STICKY_W1C (0x926) MC_XPB_CLG_CFG36 (0x93a)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x157),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x140926),
+// opcode=2, body_cnt=0: MC_RPB_CID_QUEUE_EX (0x95a)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x16d),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x2000095a),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x1),
+// opcode=3, body_cnt=31: MC_RPB_CID_QUEUE_EX_DATA (0x95b)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x16f),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x301f095b),
+// opcode=0, body_cnt=12: MC_RPB_CONF (0x94d) MC_RPB_PERF_COUNTER_STATUS (0x959)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x190),
+ GNB_ENTRY_WR (0x12, 0x3504, 0xc094d),
+// opcode=0, body_cnt=16: MC_CITF_XTRA_ENABLE (0x96d) MC_CITF_INT_CREDITS_WR (0x97d)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x19e),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x10096d),
+// opcode=0, body_cnt=12: MC_CITF_WTM_RD_CNTL (0x97f) MC_WR_GRP_LCL (0x98b)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x1b0),
+ GNB_ENTRY_WR (0x12, 0x3504, 0xc097f),
+// opcode=0, body_cnt=0: MC_CITF_PERF_MON_CNTL2 (0x98e) MC_CITF_PERF_MON_CNTL2 (0x98e)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x1be),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x98e),
+// opcode=0, body_cnt=2: MC_CITF_MISC_RD_CG (0x992) MC_CITF_MISC_VM_CG (0x994)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x1c0),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x20992),
+// opcode=0, body_cnt=2: MC_VM_MD_L1_TLB0_DEBUG (0x998) MC_VM_MD_L1_TLB2_DEBUG (0x99a)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x1c4),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x20998),
+// opcode=0, body_cnt=0: MC_VM_MD_L2ARBITER_L2_CREDITS (0x9a4) MC_VM_MD_L2ARBITER_L2_CREDITS (0x9a4)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x1c8),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x9a4),
+// opcode=0, body_cnt=0: MC_VM_MD_L1_TLB3_DEBUG (0x9a7) MC_VM_MD_L1_TLB3_DEBUG (0x9a7)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x1ca),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x9a7),
+// opcode=0, body_cnt=6: MC_ARB_AGE_CNTL (0x9bf) MC_ARB_GECC2_DEBUG2 (0x9c5)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x1cc),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x609bf),
+// opcode=0, body_cnt=45: MC_ARB_GECC2 (0x9c9) MC_ARB_MAX_LAT_CID (0x9f6)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x1d4),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x2d09c9),
+// opcode=0, body_cnt=3: MC_ARB_SSM (0x9f9) MC_ARB_DRAM_TIMING_1 (0x9fc)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x203),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x309f9),
+// opcode=0, body_cnt=0: MC_ARB_DRAM_TIMING2_1 (0x9ff) MC_ARB_DRAM_TIMING2_1 (0x9ff)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x208),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x9ff),
+// opcode=0, body_cnt=2: MC_ARB_BURST_TIME (0xa02) MC_ARB_SCRAMBLE_KEY1 (0xa04)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x20a),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x20a02),
+// opcode=0, body_cnt=6: MC_FUS_DRAM0_CTL_BASE (0xa13) MC_FUS_DRAM_MODE (0xa19)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x20e),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x60a13),
+// opcode=0, body_cnt=3: MC_FUS_ARB_GARLIC_ISOC_PRI (0xa1f) MC_FUS_ARB_GARLIC_WR_PRI2 (0xa22)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x216),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x30a1f),
+// opcode=1, body_cnt=0, mask=0x3f, const=0x0: ATC_ATS_FAULT_CNTL (0xccd) ATC_ATS_FAULT_CNTL (0xccd)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x21b),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x10000ccd),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x3f),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x0),
+// opcode=0, body_cnt=7: ATC_VM_APERTURE0_LOW_ADDR (0xcc0) ATC_VM_APERTURE1_CNTL2 (0xcc7)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x21f),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x70cc0),
+// opcode=0, body_cnt=2: ATC_ATS_CNTL (0xcc9) ATC_ATS_FAULT_DEBUG (0xccb)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x228),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x20cc9),
+// opcode=0, body_cnt=1: ATC_ATS_DEFAULT_PAGE_LOW (0xcd0) ATC_ATS_DEFAULT_PAGE_CNTL (0xcd1)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x22c),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x10cd0),
+// opcode=0, body_cnt=4: ATC_MISC_CG (0xcd4) ATC_L2_DEBUG2 (0xcd8)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x22f),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x40cd4),
+// opcode=0, body_cnt=5: ATC_L1_CNTL (0xcdc) ATC_L1WR_STATUS (0xce1)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x235),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x50cdc),
+// opcode=0, body_cnt=16: ATC_VMID_PASID_MAPPING_UPDATE_STATUS (0xce6) ATC_VMID15_PASID_MAPPING (0xcf6)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x23c),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x100ce6),
+// opcode=0, body_cnt=0: ATC_ATS_FAULT_CNTL (0xccd) ATC_ATS_FAULT_CNTL (0xccd)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x24e),
+ GNB_ENTRY_WR (0x12, 0x3504, 0xccd),
+// opcode=0, body_cnt=23: MC_ARB_HARSH_EN_RD (0xdc0) MC_ARB_HARSH_CTL_WR (0xdd7)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x250),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x170dc0),
+// opcode=0, body_cnt=0: MC_CONFIG (0x800) MC_CONFIG (0x800)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x269),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x800),
+// opcode=0, body_cnt=0: MC_CONFIG_MCD (0x828) MC_CONFIG_MCD (0x828)
+ GNB_ENTRY_WR (0x12, 0x3500, 0x26b),
+ GNB_ENTRY_WR (0x12, 0x3504, 0x828),
+//---------------------------------------------------------------------------
+// Setting up end pointers
+ GNB_ENTRY_RMW (0x12, 0x3508, 0xfffff000, 0x9b26c000),
+//---------------------------------------------------------------------------
+// Enabling light sleep
+ GNB_ENTRY_RMW (0x12, 0x3544, 0x6000000, 0x2000000),
+
+ // 2.7 Performance tuning
+ GNB_ENTRY_WR (0x12, 0x27D0, 0x10724847),
+ GNB_ENTRY_WR (0x12, 0x27C0, 0x00C32008),
+ GNB_ENTRY_WR (0x12, 0x27C4, 0x00C32006),
+ GNB_ENTRY_WR (0x12, 0x277C, 0x00000007),
+ GNB_ENTRY_WR (0x12, 0x218C, 0x000021b1),
+ GNB_ENTRY_WR (0x12, 0x201C, 0x47773337),
+ GNB_ENTRY_WR (0x12, 0x2020, 0x73773337),
+ GNB_ENTRY_WR (0x12, 0x2018, 0x66334303),
+ GNB_ENTRY_WR (0x12, 0x2014, 0x66300333),
+ GNB_ENTRY_WR (0x12, 0x2794, 0xfcfcfdfc),
+ GNB_ENTRY_WR (0x12, 0x2798, 0xfcfcfdfc),
+ GNB_ENTRY_WR (0x12, 0x27A4, 0x00ffffff),
+ GNB_ENTRY_WR (0x12, 0x27A8, 0x00ffffff),
+ GNB_ENTRY_WR (0x12, 0x278C, 0x00000008),
+ GNB_ENTRY_WR (0x12, 0x2790, 0x00000008),
+ GNB_ENTRY_WR (0x12, 0x2628, 0x55111000),
+ GNB_ENTRY_WR (0x12, 0x25E0, 0x00000025),
+ GNB_ENTRY_WR (0x12, 0x262C, 0x10555111),
+ GNB_ENTRY_WR (0x12, 0x25E4, 0x00000025),
+ GNB_ENTRY_WR (0x12, 0x25C8, 0x0080685F),
+ GNB_ENTRY_WR (0x12, 0x25CC, 0x0000807F),
+ GNB_ENTRY_WR (0x12, 0x2144, 0x50A1421D),
+ GNB_ENTRY_WR (0x12, 0x20EC, 0x0000001C),
+ GNB_ENTRY_WR (0x12, 0x2184, 0x0000A1F1),
+ GNB_ENTRY_WR (0x12, 0x21E0, 0x0000A1F1),
+ GNB_ENTRY_WR (0x12, 0x217C, 0x0000A1F1),
+ GNB_ENTRY_WR (0x12, 0x21C0, 0x0000A1F1),
+ GNB_ENTRY_WR (0x12, 0x2214, 0x000021B1),
+ GNB_ENTRY_WR (0x12, 0x2220, 0x000021B1),
+ GNB_ENTRY_WR (0x12, 0x3758, 0x00000800),
+ GNB_ENTRY_WR (0x12, 0x375C, 0x00000800),
+ GNB_ENTRY_WR (0x12, 0x3700, 0xD1000000),
+ GNB_ENTRY_WR (0x12, 0x3704, 0xD0000000),
+ GNB_ENTRY_WR (0x12, 0x3748, 0x0000007F),
+ GNB_ENTRY_WR (0x12, 0x3750, 0x18201015),
+ GNB_ENTRY_WR (0x12, 0x3754, 0x18201015),
+ GNB_ENTRY_WR (0x12, 0x253C, 0x000000B4),
+ GNB_ENTRY_WR (0x12, 0x2550, 0x000000A3),
+ GNB_ENTRY_WR (0x12, 0x2558, 0x00002077),
+ GNB_ENTRY_WR (0x12, 0x2558, 0x000020B7),
+ GNB_ENTRY_WR (0x12, 0x2558, 0x00002A3D),
+
+ GNB_ENTRY_WR (0x12, 0x287C, 0x0c000911),
+
+ //2.9 Display latency
+ GNB_ENTRY_WR (0x12, 0x2114, 0x00000015),
+
+ GNB_ENTRY_WR (0x12, 0x2880, 0xFCFE8000),
+
+ //2.12 Remove blackout
+ GNB_ENTRY_WR (0x12, 0x20AC, 0x00000000),
+
+ // VCE Optimization
+ GNB_ENTRY_RMW (0x12, 0x2108, 0xff00, (1 << 8)),
+ GNB_ENTRY_WR (0x12, 0x21fc, 0xA1F1),
+ GNB_ENTRY_WR (0x12, 0x2198, 0xA1F1),
+
+ // STCTRL_IGNORE_PROTECTION_FAULT
+ GNB_ENTRY_RMW (0x12, 0x350C, 0x01000000, (1 << 24)),
+
+ GNB_ENTRY_RMW (0x12, 0x5490, 0x2 | 0x1, (1 << 0) | (1 << 1)),
+
+ GNB_ENTRY_TERMINATE
+};
+
+GNB_TABLE ROMDATA GfxGmcFeature1EnableKB [] = {
+ GNB_ENTRY_WR (0x12, 0x20C0, 0x000c0c80),
+ GNB_ENTRY_WR (0x12, 0x2478, 0x000c0400),
+ GNB_ENTRY_WR (0x12, 0x20B8, 0x000c0400),
+ GNB_ENTRY_WR (0x12, 0x20BC, 0x000c0400),
+ GNB_ENTRY_WR (0x12, 0x2648, 0x00080400),
+ GNB_ENTRY_WR (0x12, 0x264C, 0x000c0400),
+ GNB_ENTRY_WR (0x12, 0x2650, 0x000c0400),
+ GNB_ENTRY_WR (0x12, 0x15C0, 0x000c0400),
+ GNB_ENTRY_TERMINATE
+};
+
+GNB_TABLE ROMDATA GfxEnvInitTableKB [] = {
+ GNB_ENTRY_TERMINATE
+};