xref: /aosp_15_r20/external/mesa3d/src/amd/addrlib/src/amdgpu_asic_addr.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1 /*
2 ************************************************************************************************************************
3 *
4 *  Copyright (C) 2017-2022 Advanced Micro Devices, Inc.  All rights reserved.
5 *  SPDX-License-Identifier: MIT
6 *
7 ***********************************************************************************************************************/
8 
9 #ifndef _AMDGPU_ASIC_ADDR_H
10 #define _AMDGPU_ASIC_ADDR_H
11 
12 #define ATI_VENDOR_ID         0x1002
13 #define AMD_VENDOR_ID         0x1022
14 
15 // AMDGPU_VENDOR_IS_AMD(vendorId)
16 #define AMDGPU_VENDOR_IS_AMD(v) ((v == ATI_VENDOR_ID) || (v == AMD_VENDOR_ID))
17 
18 #define FAMILY_UNKNOWN 0x00
19 #define FAMILY_TN      0x69 //# 105 / Trinity APUs
20 #define FAMILY_SI      0x6E //# 110 / Southern Islands: Tahiti, Pitcairn, CapeVerde, Oland, Hainan
21 #define FAMILY_CI      0x78 //# 120 / Sea Islands: Bonaire, Hawaii
22 #define FAMILY_KV      0x7D //# 125 / Kaveri APUs: Spectre, Spooky, Kalindi, Godavari
23 #define FAMILY_VI      0x82 //# 130 / Volcanic Islands: Iceland, Tonga, Fiji
24 #define FAMILY_CZ      0x87 //# 135 / Carrizo APUs: Carrizo, Stoney
25 #define FAMILY_AI      0x8D //# 141 / Vega: 10, 20
26 #define FAMILY_RV      0x8E //# 142 / Raven
27 #define FAMILY_NV      0x8F //# 143 / Navi: 10
28 #define FAMILY_VGH     0x90 //# 144 / Van Gogh
29 #define FAMILY_NV3     0x91 //# 145 / Navi: 3x
30 #define FAMILY_GFX1150 0x96
31 #define FAMILY_GFX1103 0x94
32 #define FAMILY_RMB     0x92 //# 146 / Rembrandt
33 #define FAMILY_RPL     0x95 //# 149 / Raphael
34 #define FAMILY_MDN     0x97 //# 151 / Mendocino
35 #define FAMILY_GFX12   0x98
36 
37 // AMDGPU_FAMILY_IS(familyId, familyName)
38 #define FAMILY_IS(f, fn)     (f == FAMILY_##fn)
39 #define FAMILY_IS_TN(f)      FAMILY_IS(f, TN)
40 #define FAMILY_IS_SI(f)      FAMILY_IS(f, SI)
41 #define FAMILY_IS_CI(f)      FAMILY_IS(f, CI)
42 #define FAMILY_IS_KV(f)      FAMILY_IS(f, KV)
43 #define FAMILY_IS_VI(f)      FAMILY_IS(f, VI)
44 #define FAMILY_IS_POLARIS(f) FAMILY_IS(f, POLARIS)
45 #define FAMILY_IS_CZ(f)      FAMILY_IS(f, CZ)
46 #define FAMILY_IS_AI(f)      FAMILY_IS(f, AI)
47 #define FAMILY_IS_RV(f)      FAMILY_IS(f, RV)
48 #define FAMILY_IS_NV(f)      FAMILY_IS(f, NV)
49 #define FAMILY_IS_RMB(f)     FAMILY_IS(f, RMB)
50 #define FAMILY_IS_NV3(f)     FAMILY_IS(f, NV3)
51 #define FAMILY_IS_GFX12(f)   FAMILY_IS(f, GFX12)
52 
53 #define AMDGPU_UNKNOWN          0xFF
54 
55 #define AMDGPU_TAHITI_RANGE     0x05, 0x14 //#  5 <= x < 20
56 #define AMDGPU_PITCAIRN_RANGE   0x15, 0x28 //# 21 <= x < 40
57 #define AMDGPU_CAPEVERDE_RANGE  0x29, 0x3C //# 41 <= x < 60
58 #define AMDGPU_OLAND_RANGE      0x3C, 0x46 //# 60 <= x < 70
59 #define AMDGPU_HAINAN_RANGE     0x46, 0xFF //# 70 <= x < max
60 
61 #define AMDGPU_BONAIRE_RANGE    0x14, 0x28 //# 20 <= x < 40
62 #define AMDGPU_HAWAII_RANGE     0x28, 0x3C //# 40 <= x < 60
63 
64 #define AMDGPU_SPECTRE_RANGE    0x01, 0x41 //#   1 <= x < 65
65 #define AMDGPU_SPOOKY_RANGE     0x41, 0x81 //#  65 <= x < 129
66 #define AMDGPU_KALINDI_RANGE    0x81, 0xA1 //# 129 <= x < 161
67 #define AMDGPU_GODAVARI_RANGE   0xA1, 0xFF //# 161 <= x < max
68 
69 #define AMDGPU_ICELAND_RANGE    0x01, 0x14 //#  1 <= x < 20
70 #define AMDGPU_TONGA_RANGE      0x14, 0x28 //# 20 <= x < 40
71 #define AMDGPU_FIJI_RANGE       0x3C, 0x50 //# 60 <= x < 80
72 
73 #define AMDGPU_POLARIS10_RANGE  0x50, 0x5A //#  80 <= x < 90
74 #define AMDGPU_POLARIS11_RANGE  0x5A, 0x64 //#  90 <= x < 100
75 #define AMDGPU_POLARIS12_RANGE  0x64, 0x6E //# 100 <= x < 110
76 #define AMDGPU_VEGAM_RANGE      0x6E, 0xFF //# 110 <= x < max
77 
78 #define AMDGPU_CARRIZO_RANGE    0x01, 0x21 //#  1 <= x < 33
79 #define AMDGPU_BRISTOL_RANGE    0x10, 0x21 //# 16 <= x < 33
80 #define AMDGPU_STONEY_RANGE     0x61, 0xFF //# 97 <= x < max
81 
82 #define AMDGPU_VEGA10_RANGE     0x01, 0x14 //#  1 <= x < 20
83 #define AMDGPU_VEGA12_RANGE     0x14, 0x28 //# 20 <= x < 40
84 #define AMDGPU_VEGA20_RANGE     0x28, 0xFF //# 40 <= x < max
85 
86 #define AMDGPU_RAVEN_RANGE      0x01, 0x81 //#   1 <= x < 129
87 #define AMDGPU_RAVEN2_RANGE     0x81, 0x90 //# 129 <= x < 144
88 #define AMDGPU_RENOIR_RANGE     0x91, 0xFF //# 145 <= x < max
89 
90 #define AMDGPU_NAVI10_RANGE     0x01, 0x0A //# 1  <= x < 10
91 #define AMDGPU_NAVI12_RANGE     0x0A, 0x14 //# 10 <= x < 20
92 #define AMDGPU_NAVI14_RANGE     0x14, 0x28 //# 20 <= x < 40
93 #define AMDGPU_NAVI21_RANGE     0x28, 0x32 //# 40  <= x < 50
94 #define AMDGPU_NAVI22_RANGE     0x32, 0x3C //# 50  <= x < 60
95 #define AMDGPU_NAVI23_RANGE     0x3C, 0x46 //# 60  <= x < 70
96 #define AMDGPU_NAVI24_RANGE     0x46, 0x50 //# 70  <= x < 80
97 
98 #define AMDGPU_VANGOGH_RANGE    0x01, 0xFF //# 1 <= x < max
99 
100 #define AMDGPU_NAVI31_RANGE     0x01, 0x10 //# 01 <= x < 16
101 #define AMDGPU_NAVI32_RANGE     0x20, 0xFF //# 32 <= x < 255
102 #define AMDGPU_NAVI33_RANGE     0x10, 0x20 //# 16 <= x < 32
103 #define AMDGPU_GFX1150_RANGE    0x01, 0x40 //# 1 <= x < 64
104 #define AMDGPU_GFX1151_RANGE    0xC0, 0xFF //# 192 <= x < 255
105 #define AMDGPU_GFX1152_RANGE    0x40, 0x50 //# 64 <= x < 80
106 
107 #define AMDGPU_GFX1103_R1_RANGE 0x01, 0x80 //# 1 <= x < 128
108 #define AMDGPU_GFX1103_R2_RANGE 0x80, 0xC0 //# 128 <= x < 192
109 #define AMDGPU_GFX1103_R1X_RANGE 0xC0, 0xF0 //# 192 <= x < 240
110 #define AMDGPU_GFX1103_R2X_RANGE 0xF0, 0xFF //# 240 <= x < 255
111 
112 #define AMDGPU_REMBRANDT_RANGE  0x01, 0xFF //# 01 <= x < 255
113 #define AMDGPU_RAPHAEL_RANGE    0x01, 0xFF //# 1 <= x < max
114 #define AMDGPU_MENDOCINO_RANGE  0x01, 0xFF //# 1 <= x < max
115 
116 #define AMDGPU_GFX1200_RANGE    0x40, 0x50
117 #define AMDGPU_GFX1201_RANGE    0x50, 0xFF
118 
119 #define AMDGPU_EXPAND_FIX(x) x
120 #define AMDGPU_RANGE_HELPER(val, min, max) ((val >= min) && (val < max))
121 #define AMDGPU_IN_RANGE(val, ...)   AMDGPU_EXPAND_FIX(AMDGPU_RANGE_HELPER(val, __VA_ARGS__))
122 
123 
124 // ASICREV_IS(eRevisionId, revisionName)
125 #define ASICREV_IS(r, rn)              AMDGPU_IN_RANGE(r, AMDGPU_##rn##_RANGE)
126 #define ASICREV_IS_TAHITI_P(r)         ASICREV_IS(r, TAHITI)
127 #define ASICREV_IS_PITCAIRN_PM(r)      ASICREV_IS(r, PITCAIRN)
128 #define ASICREV_IS_CAPEVERDE_M(r)      ASICREV_IS(r, CAPEVERDE)
129 #define ASICREV_IS_OLAND_M(r)          ASICREV_IS(r, OLAND)
130 #define ASICREV_IS_HAINAN_V(r)         ASICREV_IS(r, HAINAN)
131 
132 #define ASICREV_IS_BONAIRE_M(r)        ASICREV_IS(r, BONAIRE)
133 #define ASICREV_IS_HAWAII_P(r)         ASICREV_IS(r, HAWAII)
134 
135 #define ASICREV_IS_SPECTRE(r)          ASICREV_IS(r, SPECTRE)
136 #define ASICREV_IS_SPOOKY(r)           ASICREV_IS(r, SPOOKY)
137 #define ASICREV_IS_KALINDI(r)          ASICREV_IS(r, KALINDI)
138 #define ASICREV_IS_KALINDI_GODAVARI(r) ASICREV_IS(r, GODAVARI)
139 
140 #define ASICREV_IS_ICELAND_M(r)        ASICREV_IS(r, ICELAND)
141 #define ASICREV_IS_TONGA_P(r)          ASICREV_IS(r, TONGA)
142 #define ASICREV_IS_FIJI_P(r)           ASICREV_IS(r, FIJI)
143 
144 #define ASICREV_IS_POLARIS10_P(r)      ASICREV_IS(r, POLARIS10)
145 #define ASICREV_IS_POLARIS11_M(r)      ASICREV_IS(r, POLARIS11)
146 #define ASICREV_IS_POLARIS12_V(r)      ASICREV_IS(r, POLARIS12)
147 #define ASICREV_IS_VEGAM_P(r)          ASICREV_IS(r, VEGAM)
148 
149 #define ASICREV_IS_CARRIZO(r)          ASICREV_IS(r, CARRIZO)
150 #define ASICREV_IS_CARRIZO_BRISTOL(r)  ASICREV_IS(r, BRISTOL)
151 #define ASICREV_IS_STONEY(r)           ASICREV_IS(r, STONEY)
152 
153 #define ASICREV_IS_VEGA10_M(r)         ASICREV_IS(r, VEGA10)
154 #define ASICREV_IS_VEGA10_P(r)         ASICREV_IS(r, VEGA10)
155 #define ASICREV_IS_VEGA12_P(r)         ASICREV_IS(r, VEGA12)
156 #define ASICREV_IS_VEGA12_p(r)         ASICREV_IS(r, VEGA12)
157 #define ASICREV_IS_VEGA20_P(r)         ASICREV_IS(r, VEGA20)
158 
159 #define ASICREV_IS_RAVEN(r)            ASICREV_IS(r, RAVEN)
160 #define ASICREV_IS_RAVEN2(r)           ASICREV_IS(r, RAVEN2)
161 #define ASICREV_IS_RENOIR(r)           ASICREV_IS(r, RENOIR)
162 
163 #define ASICREV_IS_NAVI10_P(r)         ASICREV_IS(r, NAVI10)
164 
165 #define ASICREV_IS_NAVI12_P(r)         ASICREV_IS(r, NAVI12)
166 
167 #define ASICREV_IS_NAVI14_M(r)         ASICREV_IS(r, NAVI14)
168 
169 #define ASICREV_IS_NAVI21_M(r)         ASICREV_IS(r, NAVI21)
170 
171 #define ASICREV_IS_NAVI22_P(r)         ASICREV_IS(r, NAVI22)
172 
173 #define ASICREV_IS_NAVI23_P(r)         ASICREV_IS(r, NAVI23)
174 
175 #define ASICREV_IS_NAVI24_P(r)         ASICREV_IS(r, NAVI24)
176 
177 #define ASICREV_IS_VANGOGH(r)          ASICREV_IS(r, VANGOGH)
178 
179 #define ASICREV_IS_NAVI31_P(r)         ASICREV_IS(r, NAVI31)
180 #define ASICREV_IS_NAVI32_P(r)         ASICREV_IS(r, NAVI32)
181 #define ASICREV_IS_NAVI33_P(r)         ASICREV_IS(r, NAVI33)
182 #define ASICREV_IS_GFX1150(r)          ASICREV_IS(r, GFX1150)
183 #define ASICREV_IS_GFX1151(r)          ASICREV_IS(r, GFX1151)
184 #define ASICREV_IS_GFX1152(r)          ASICREV_IS(r, GFX1152)
185 
186 #define ASICREV_IS_GFX1103_R1(r)       ASICREV_IS(r, GFX1103_R1)
187 #define ASICREV_IS_GFX1103_R2(r)       ASICREV_IS(r, GFX1103_R2)
188 #define ASICREV_IS_GFX1103_R1X(r)      ASICREV_IS(r, GFX1103_R1X)
189 #define ASICREV_IS_GFX1103_R2X(r)      ASICREV_IS(r, GFX1103_R2X)
190 
191 #define ASICREV_IS_REMBRANDT(r)        ASICREV_IS(r, REMBRANDT)
192 #define ASICREV_IS_RAPHAEL(r)          ASICREV_IS(r, RAPHAEL)
193 #define ASICREV_IS_MENDOCINO(r)        ASICREV_IS(r, MENDOCINO)
194 
195 #define ASICREV_IS_GFX1200(r)          ASICREV_IS(r, GFX1200)
196 
197 #endif // _AMDGPU_ASIC_ADDR_H
198