AGESA F15: AMD family15 AGESA code
[coreboot.git] / src / vendorcode / amd / agesa / f15 / Proc / CPU / Family / 0x10 / cpuF10WorkaroundsTable.c
1 /* $NoKeywords:$ */
2 /**
3  * @file
4  *
5  * AMD Family_10 Family Specific Workaround table
6  *
7  * @xrefitem bom "File Content Label" "Release Content"
8  * @e project:      AGESA
9  * @e sub-project:  CPU/FAMILY/0x10
10  * @e \$Revision: 57155 $   @e \$Date: 2011-07-28 02:27:47 -0600 (Thu, 28 Jul 2011) $
11  *
12  */
13 /*
14  ******************************************************************************
15  *
16  * Copyright (C) 2012 Advanced Micro Devices, Inc.
17  * All rights reserved.
18  *
19  * Redistribution and use in source and binary forms, with or without
20  * modification, are permitted provided that the following conditions are met:
21  *     * Redistributions of source code must retain the above copyright
22  *       notice, this list of conditions and the following disclaimer.
23  *     * Redistributions in binary form must reproduce the above copyright
24  *       notice, this list of conditions and the following disclaimer in the
25  *       documentation and/or other materials provided with the distribution.
26  *     * Neither the name of Advanced Micro Devices, Inc. nor the names of
27  *       its contributors may be used to endorse or promote products derived
28  *       from this software without specific prior written permission.
29  *
30  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
31  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
32  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
33  * DISCLAIMED. IN NO EVENT SHALL ADVANCED MICRO DEVICES, INC. BE LIABLE FOR ANY
34  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
35  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
36  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
37  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
38  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
39  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
40  *
41  ******************************************************************************
42  */
43
44 /*----------------------------------------------------------------------------------------
45  *                             M O D U L E S    U S E D
46  *----------------------------------------------------------------------------------------
47  */
48 #include "AGESA.h"
49 #include "amdlib.h"
50 #include "Ids.h"
51 #include "cpuRegisters.h"
52 #include "Table.h"
53 #include "cpuServices.h"
54 #include "GeneralServices.h"
55 #include "Topology.h"
56 #include "Filecode.h"
57 CODE_GROUP (G1_PEICC)
58 RDATA_GROUP (G2_PEI)
59
60 #define FILECODE PROC_CPU_FAMILY_0X10_CPUF10WORKAROUNDSTABLE_FILECODE
61
62 /*----------------------------------------------------------------------------------------
63  *                   D E F I N I T I O N S    A N D    M A C R O S
64  *----------------------------------------------------------------------------------------
65  */
66
67 /*----------------------------------------------------------------------------------------
68  *                  T Y P E D E F S     A N D     S T R U C T U R E S
69  *----------------------------------------------------------------------------------------
70  */
71
72 /*----------------------------------------------------------------------------------------
73  *           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
74  *----------------------------------------------------------------------------------------
75  */
76
77 /*---------------------------------------------------------------------------------------*/
78 /**
79  * A Family Specific Workaround method, to sync internal node 1 SbiAddr setting.
80  *
81  * @param[in] Data      The table data value (unused in this routine)
82  * @param[in] StdHeader Config handle for library and services
83  *
84  *---------------------------------------------------------------------------------------
85  **/
86 VOID
87 STATIC
88 F10RevDSyncInternalNode1SbiAddr (
89   IN       UINT32            Data,
90   IN       AMD_CONFIG_PARAMS *StdHeader
91   )
92 {
93   UINT32       Socket;
94   UINT32       Module;
95   UINT32       DataOr;
96   UINT32       DataAnd;
97   UINT32       ModuleType;
98   PCI_ADDR     PciAddress;
99   AGESA_STATUS AgesaStatus;
100   UINT32       SyncToModule;
101   AP_MAIL_INFO ApMailboxInfo;
102   UINT32       LocalPciRegister;
103
104   ApMailboxInfo.Info = 0;
105
106   GetApMailbox (&ApMailboxInfo.Info, StdHeader);
107   ASSERT (ApMailboxInfo.Fields.Socket < MAX_SOCKETS);
108   ASSERT (ApMailboxInfo.Fields.Module < MAX_DIES);
109   Socket = ApMailboxInfo.Fields.Socket;
110   Module = ApMailboxInfo.Fields.Module;
111   ModuleType = ApMailboxInfo.Fields.ModuleType;
112
113   // sync is just needed on multinode cpu
114   if (ModuleType != 0) {
115     // check if it is internal node 0 of every socket
116     if (Module == 0) {
117       if (GetPciAddress (StdHeader, Socket, Module, &PciAddress, &AgesaStatus)) {
118         PciAddress.Address.Function = FUNC_3;
119         PciAddress.Address.Register = 0x1E4;
120         // read internal node 0 F3x1E4[6:4]
121         LibAmdPciRead (AccessWidth32, PciAddress, &LocalPciRegister, StdHeader);
122         DataOr = LocalPciRegister & ((UINT32) (7 << 4));
123         DataAnd = ~(UINT32) (7 << 4);
124         for (SyncToModule = 1; SyncToModule < GetPlatformNumberOfModules (); SyncToModule++) {
125           if (GetPciAddress (StdHeader, Socket, SyncToModule, &PciAddress, &AgesaStatus)) {
126             PciAddress.Address.Function = FUNC_3;
127             PciAddress.Address.Register = 0x1E4;
128             // sync the other internal node F3x1E4[6:4]
129             LibAmdPciRead (AccessWidth32, PciAddress, &LocalPciRegister, StdHeader);
130             LocalPciRegister &= DataAnd;
131             LocalPciRegister |= DataOr;
132             LibAmdPciWrite (AccessWidth32, PciAddress, &LocalPciRegister, StdHeader);
133           }
134         }
135       }
136     }
137   }
138 }
139
140 /*----------------------------------------------------------------------------------------
141  *                          E X P O R T E D    F U N C T I O N S
142  *----------------------------------------------------------------------------------------
143  */
144
145 //  F a m i l y  S p e c i f i c  W o r k a r o u n d    T a b l e s
146 // -----------------------------------------------------------------
147
148 STATIC CONST FAM_SPECIFIC_WORKAROUND_TYPE_ENTRY_INITIALIZER ROMDATA F10Workarounds[] =
149 {
150 // F0x6C - Link Initialization Control Register
151 // Request for warm reset in AmdInitEarly
152 // [5, BiosRstDet] = 1b
153   {
154     FamSpecificWorkaround,
155     {
156       AMD_FAMILY_10,                        // CpuFamily
157       AMD_F10_ALL                           // CpuRevision
158     },
159         {AMD_PF_ALL},                             // platformFeatures
160     {{
161       SetWarmResetAtEarly,                  // function call
162       0x00000000,                           // data
163     }}
164   },
165   // Internal Node 1 SbiAddr sync for RevD
166   {
167     FamSpecificWorkaround,
168     {
169       AMD_FAMILY_10_HY,
170       AMD_F10_HY_ALL
171     },
172     {AMD_PF_ALL},
173     {{
174       F10RevDSyncInternalNode1SbiAddr,
175       0x00000000
176     }}
177   },
178 };
179
180 CONST REGISTER_TABLE ROMDATA F10WorkaroundsTable = {
181   PrimaryCores,
182   (sizeof (F10Workarounds) / sizeof (TABLE_ENTRY_FIELDS)),
183   (TABLE_ENTRY_FIELDS *)F10Workarounds,
184 };