AGESA F15: AMD family15 AGESA code
[coreboot.git] / src / vendorcode / amd / agesa / f15 / Proc / HT / Fam10 / htNbSystemFam10.h
1 /* $NoKeywords:$ */
2 /**
3  * @file
4  *
5  * System Tuning Family 10h specific routines
6  *
7  * @xrefitem bom "File Content Label" "Release Content"
8  * @e project:      AGESA
9  * @e sub-project:  HyperTransport
10  * @e \$Revision: 44324 $   @e \$Date: 2010-12-22 02:16:51 -0700 (Wed, 22 Dec 2010) $
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 /**
46  * Set the traffic distribution register for the Links provided.
47  *
48  */
49 VOID
50 Fam10WriteTrafficDistribution (
51   IN       UINT32       Links01,
52   IN       UINT32       Links10,
53   IN       NORTHBRIDGE  *Nb
54   );
55
56 /**
57  * Write a link pair to the link pair distribution and fixups.
58  *
59  */
60 VOID
61 Fam10WriteLinkPairDistribution (
62   IN       UINT8        Node,
63   IN       UINT8        ConnectedNode,
64   IN       UINT8        Pair,
65   IN       BOOLEAN      Asymmetric,
66   IN       UINT8        MasterLink,
67   IN       UINT8        AlternateLink,
68   IN       NORTHBRIDGE  *Nb
69   );
70
71 /**
72  * Family 10h specific tunings.
73  *
74  */
75 VOID
76 Fam10BufferOptimizations (
77   IN       UINT8       Node,
78   IN       STATE_DATA  *State,
79   IN       NORTHBRIDGE *Nb
80   );
81
82 /**
83  * Family 10h Rev D specific tunings.
84  *
85  */
86 VOID
87 Fam10RevDBufferOptimizations (
88   IN       UINT8       Node,
89   IN       STATE_DATA  *State,
90   IN       NORTHBRIDGE *Nb
91   );