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