radv,aco: disable opts if VK_PIPELINE_CREATE_DISABLE_OPTIMIZATION_BIT
[mesa.git] / src / amd / addrlib / src / amdgpu_asic_addr.h
1 /*
2 * Copyright © 2017-2019 Advanced Micro Devices, Inc.
3 * All Rights Reserved.
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining
6 * a copy of this software and associated documentation files (the
7 * "Software"), to deal in the Software without restriction, including
8 * without limitation the rights to use, copy, modify, merge, publish,
9 * distribute, sub license, and/or sell copies of the Software, and to
10 * permit persons to whom the Software is furnished to do so, subject to
11 * the following conditions:
12 *
13 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
14 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
15 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
16 * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS
17 * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
20 * USE OR OTHER DEALINGS IN THE SOFTWARE.
21 *
22 * The above copyright notice and this permission notice (including the
23 * next paragraph) shall be included in all copies or substantial portions
24 * of the Software.
25 */
26
27 #ifndef _AMDGPU_ASIC_ADDR_H
28 #define _AMDGPU_ASIC_ADDR_H
29
30 #define ATI_VENDOR_ID 0x1002
31 #define AMD_VENDOR_ID 0x1022
32
33 // AMDGPU_VENDOR_IS_AMD(vendorId)
34 #define AMDGPU_VENDOR_IS_AMD(v) ((v == ATI_VENDOR_ID) || (v == AMD_VENDOR_ID))
35
36 #define FAMILY_UNKNOWN 0x00
37 #define FAMILY_TN 0x69
38 #define FAMILY_SI 0x6E
39 #define FAMILY_CI 0x78
40 #define FAMILY_KV 0x7D
41 #define FAMILY_VI 0x82
42 #define FAMILY_POLARIS 0x82
43 #define FAMILY_CZ 0x87
44 #define FAMILY_AI 0x8D
45 #define FAMILY_RV 0x8E
46 #define FAMILY_NV 0x8F
47
48 // AMDGPU_FAMILY_IS(familyId, familyName)
49 #define FAMILY_IS(f, fn) (f == FAMILY_##fn)
50 #define FAMILY_IS_TN(f) FAMILY_IS(f, TN)
51 #define FAMILY_IS_SI(f) FAMILY_IS(f, SI)
52 #define FAMILY_IS_CI(f) FAMILY_IS(f, CI)
53 #define FAMILY_IS_KV(f) FAMILY_IS(f, KV)
54 #define FAMILY_IS_VI(f) FAMILY_IS(f, VI)
55 #define FAMILY_IS_POLARIS(f) FAMILY_IS(f, POLARIS)
56 #define FAMILY_IS_CZ(f) FAMILY_IS(f, CZ)
57 #define FAMILY_IS_AI(f) FAMILY_IS(f, AI)
58 #define FAMILY_IS_RV(f) FAMILY_IS(f, RV)
59 #define FAMILY_IS_NV(f) FAMILY_IS(f, NV)
60
61 #define AMDGPU_UNKNOWN 0xFF
62
63 #define AMDGPU_TAHITI_RANGE 0x05, 0x14
64 #define AMDGPU_PITCAIRN_RANGE 0x15, 0x28
65 #define AMDGPU_CAPEVERDE_RANGE 0x29, 0x3C
66 #define AMDGPU_OLAND_RANGE 0x3C, 0x46
67 #define AMDGPU_HAINAN_RANGE 0x46, 0xFF
68
69 #define AMDGPU_BONAIRE_RANGE 0x14, 0x28
70 #define AMDGPU_HAWAII_RANGE 0x28, 0x3C
71
72 #define AMDGPU_SPECTRE_RANGE 0x01, 0x41
73 #define AMDGPU_SPOOKY_RANGE 0x41, 0x81
74 #define AMDGPU_KALINDI_RANGE 0x81, 0xA1
75 #define AMDGPU_GODAVARI_RANGE 0xA1, 0xFF
76
77 #define AMDGPU_ICELAND_RANGE 0x01, 0x14
78 #define AMDGPU_TONGA_RANGE 0x14, 0x28
79 #define AMDGPU_FIJI_RANGE 0x3C, 0x50
80 #define AMDGPU_POLARIS10_RANGE 0x50, 0x5A
81 #define AMDGPU_POLARIS11_RANGE 0x5A, 0x64
82 #define AMDGPU_POLARIS12_RANGE 0x64, 0x6E
83 #define AMDGPU_VEGAM_RANGE 0x6E, 0xFF
84
85 #define AMDGPU_CARRIZO_RANGE 0x01, 0x21
86 #define AMDGPU_STONEY_RANGE 0x61, 0xFF
87
88 #define AMDGPU_VEGA10_RANGE 0x01, 0x14
89 #define AMDGPU_VEGA12_RANGE 0x14, 0x28
90 #define AMDGPU_VEGA20_RANGE 0x28, 0x32
91 #define AMDGPU_ARCTURUS_RANGE 0x32, 0xFF
92
93 #define AMDGPU_RAVEN_RANGE 0x01, 0x81
94 #define AMDGPU_RAVEN2_RANGE 0x81, 0x91
95 #define AMDGPU_RENOIR_RANGE 0x91, 0xFF
96
97 #define AMDGPU_NAVI10_RANGE 0x01, 0x0A
98 #define AMDGPU_NAVI12_RANGE 0x0A, 0x14
99 #define AMDGPU_NAVI14_RANGE 0x14, 0x28
100 #define AMDGPU_SIENNA_CICHLID_RANGE 0x28, 0x32
101 #define AMDGPU_NAVY_FLOUNDER_RANGE 0x32, 0x3C
102
103 #define AMDGPU_EXPAND_FIX(x) x
104 #define AMDGPU_RANGE_HELPER(val, min, max) ((val >= min) && (val < max))
105 #define AMDGPU_IN_RANGE(val, ...) AMDGPU_EXPAND_FIX(AMDGPU_RANGE_HELPER(val, __VA_ARGS__))
106
107 // ASICREV_IS(eRevisionId, revisionName)
108 #define ASICREV_IS(r, rn) AMDGPU_IN_RANGE(r, AMDGPU_##rn##_RANGE)
109 #define ASICREV_IS_TAHITI_P(r) ASICREV_IS(r, TAHITI)
110 #define ASICREV_IS_PITCAIRN_PM(r) ASICREV_IS(r, PITCAIRN)
111 #define ASICREV_IS_CAPEVERDE_M(r) ASICREV_IS(r, CAPEVERDE)
112 #define ASICREV_IS_OLAND_M(r) ASICREV_IS(r, OLAND)
113 #define ASICREV_IS_HAINAN_V(r) ASICREV_IS(r, HAINAN)
114
115 #define ASICREV_IS_BONAIRE_M(r) ASICREV_IS(r, BONAIRE)
116 #define ASICREV_IS_HAWAII_P(r) ASICREV_IS(r, HAWAII)
117
118 #define ASICREV_IS_SPECTRE(r) ASICREV_IS(r, SPECTRE)
119 #define ASICREV_IS_SPOOKY(r) ASICREV_IS(r, SPOOKY)
120 #define ASICREV_IS_KALINDI(r) ASICREV_IS(r, KALINDI)
121 #define ASICREV_IS_KALINDI_GODAVARI(r) ASICREV_IS(r, GODAVARI)
122
123 #define ASICREV_IS_ICELAND_M(r) ASICREV_IS(r, ICELAND)
124 #define ASICREV_IS_TONGA_P(r) ASICREV_IS(r, TONGA)
125 #define ASICREV_IS_FIJI_P(r) ASICREV_IS(r, FIJI)
126
127 #define ASICREV_IS_POLARIS10_P(r) ASICREV_IS(r, POLARIS10)
128 #define ASICREV_IS_POLARIS11_M(r) ASICREV_IS(r, POLARIS11)
129 #define ASICREV_IS_POLARIS12_V(r) ASICREV_IS(r, POLARIS12)
130 #define ASICREV_IS_VEGAM_P(r) ASICREV_IS(r, VEGAM)
131
132 #define ASICREV_IS_CARRIZO(r) ASICREV_IS(r, CARRIZO)
133 #define ASICREV_IS_STONEY(r) ASICREV_IS(r, STONEY)
134
135 #define ASICREV_IS_VEGA10_M(r) ASICREV_IS(r, VEGA10)
136 #define ASICREV_IS_VEGA10_P(r) ASICREV_IS(r, VEGA10)
137 #define ASICREV_IS_VEGA12_P(r) ASICREV_IS(r, VEGA12)
138 #define ASICREV_IS_VEGA12_p(r) ASICREV_IS(r, VEGA12)
139 #define ASICREV_IS_VEGA20_P(r) ASICREV_IS(r, VEGA20)
140 #define ASICREV_IS_ARCTURUS(r) ASICREV_IS(r, ARCTURUS)
141
142 #define ASICREV_IS_RAVEN(r) ASICREV_IS(r, RAVEN)
143 #define ASICREV_IS_RAVEN2(r) ASICREV_IS(r, RAVEN2)
144 #define ASICREV_IS_RENOIR(r) ASICREV_IS(r, RENOIR)
145
146 #define ASICREV_IS_NAVI10_P(r) ASICREV_IS(r, NAVI10)
147 #define ASICREV_IS_NAVI12(r) ASICREV_IS(r, NAVI12)
148 #define ASICREV_IS_NAVI14(r) ASICREV_IS(r, NAVI14)
149 #define ASICREV_IS_SIENNA_CICHLID(r) ASICREV_IS(r, SIENNA_CICHLID)
150 #define ASICREV_IS_NAVY_FLOUNDER(r) ASICREV_IS(r, NAVY_FLOUNDER)
151
152 #endif // _AMDGPU_ASIC_ADDR_H