1 | /*␊ |
2 | * ATI Graphics Card Enabler, part of the Chameleon Boot Loader Project␊ |
3 | *␊ |
4 | * Copyright 2010 by Islam M. Ahmed Zaid. All rights reserved.␊ |
5 | *␊ |
6 | */␊ |
7 | ␊ |
8 | #include "boot.h"␊ |
9 | #include "bootstruct.h"␊ |
10 | #include "pci.h"␊ |
11 | #include "platform.h"␊ |
12 | #include "device_inject.h"␊ |
13 | #include "ati_reg.h"␊ |
14 | ␊ |
15 | #define OFFSET_TO_GET_ATOMBIOS_STRINGS_START 0x6e␊ |
16 | ␊ |
17 | #define Reg32(reg)␉␉␉␉(*(volatile uint32_t *)(card->mmio + reg))␊ |
18 | #define RegRead32(reg)␉␉␉(Reg32(reg))␊ |
19 | #define RegWrite32(reg, value)␉(Reg32(reg) = value)␊ |
20 | ␊ |
21 | static const char *chip_family_name[] = {␊ |
22 | ␉"UNKNOW",␊ |
23 | ␉"R420",␊ |
24 | ␉"RV410",␊ |
25 | ␉"RV515",␊ |
26 | ␉"R520",␊ |
27 | ␉"RV530",␊ |
28 | ␉"RV560",␊ |
29 | ␉"RV570",␊ |
30 | ␉"R580",␊ |
31 | ␉/* IGP */␊ |
32 | ␉"RS600",␊ |
33 | ␉"RS690",␊ |
34 | ␉"RS740",␊ |
35 | ␉"RS780",␊ |
36 | ␉"RS880",␊ |
37 | ␉/* R600 */␊ |
38 | ␉"R600",␊ |
39 | ␉"RV610",␊ |
40 | ␉"RV620",␊ |
41 | ␉"RV630",␊ |
42 | ␉"RV635",␊ |
43 | ␉"RV670",␊ |
44 | ␉/* R700 */␊ |
45 | ␉"RV710",␊ |
46 | ␉"RV730",␊ |
47 | ␉"RV740",␊ |
48 | ␉"RV772",␊ |
49 | ␉"RV770",␊ |
50 | ␉"RV790",␊ |
51 | ␉/* Evergreen */␊ |
52 | ␉"Cedar",␊ |
53 | ␉"Cypress",␊ |
54 | ␉"Hemlock",␊ |
55 | ␉"Juniper",␊ |
56 | ␉"Redwood",␊ |
57 | ␉"Broadway",␊ |
58 | //␉"Madison",␊ |
59 | //␉"Park",␊ |
60 | ␉/* Northern Islands */␊ |
61 | //␉"Antilles",␊ |
62 | ␉"Barts",␊ |
63 | ␉"Caicos",␊ |
64 | ␉"Cayman",␊ |
65 | ␉"Turks",␊ |
66 | ␉/* Southern Islands */␊ |
67 | ␉"Tahiti",␊ |
68 | ␉"Pitcairn",␊ |
69 | //␉"CapeVerde",␊ |
70 | //␉"Thames",␊ |
71 | //␉"Lombok",␊ |
72 | //␉"NewZealand",␊ |
73 | ␉""␊ |
74 | };␊ |
75 | ␊ |
76 | static card_config_t card_configs[] = {␊ |
77 | ␉{NULL,␉␉0},␊ |
78 | /* OLDController */␊ |
79 | ␉{"Wormy",␉2},␊ |
80 | ␉{"Alopias",␉2},␊ |
81 | ␉{"Caretta",␉1},␊ |
82 | ␉{"Kakapo",␉3},␊ |
83 | ␉{"Kipunji",␉4},␊ |
84 | ␉{"Peregrine",␉2},␊ |
85 | ␉{"Raven",␉3},␊ |
86 | ␉{"Sphyrna",␉1},␊ |
87 | /* AMD2400Controller */␊ |
88 | ␉{"Iago",␉2},␊ |
89 | /* AMD2600Controller */␊ |
90 | ␉{"Hypoprion",␉2},␊ |
91 | ␉{"Lamna",␉2},␊ |
92 | /* AMD3800Controller */␊ |
93 | ␉{"Megalodon",␉3},␊ |
94 | ␉{"Triakis",␉2},␊ |
95 | /* AMD4600Controller */␊ |
96 | ␉{"Flicker",␉3},␊ |
97 | ␉{"Gliff",␉3},␊ |
98 | ␉{"Shrike",␉3},␊ |
99 | /* AMD4800Controller */␊ |
100 | ␉{"Cardinal",␉2},␊ |
101 | ␉{"Motmot",␉2},␊ |
102 | ␉{"Quail",␉3},␊ |
103 | /* AMD5000Controller */␊ |
104 | ␉{"Douc",␉2},␊ |
105 | ␉{"Langur",␉3},␊ |
106 | ␉{"Uakari",␉4},␊ |
107 | ␉{"Zonalis",␉6},␊ |
108 | ␉{"Alouatta",␉4},␊ |
109 | ␉{"Hoolock",␉3},␊ |
110 | ␉{"Vervet",␉4},␊ |
111 | ␉{"Baboon",␉3},␊ |
112 | ␉{"Eulemur",␉3},␊ |
113 | ␉{"Galago",␉2},␊ |
114 | ␉{"Colobus",␉2},␊ |
115 | ␉{"Mangabey",␉2},␊ |
116 | ␉{"Nomascus",␉4},␊ |
117 | ␉{"Orangutan",␉2},␊ |
118 | /* AMD6000Controller */␊ |
119 | ␉{"Pithecia",␉3},␊ |
120 | ␉{"Bulrushes",␉6},␊ |
121 | ␉{"Cattail",␉4},␊ |
122 | ␉{"Hydrilla",␉5},␊ |
123 | ␉{"Duckweed",␉4},␊ |
124 | ␉{"Fanwort",␉4},␊ |
125 | ␉{"Elodea",␉5},␊ |
126 | ␉{"Kudzu",␉2},␊ |
127 | ␉{"Gibba",␉5},␊ |
128 | ␉{"Lotus",␉3},␊ |
129 | ␉{"Ipomoea",␉3},␊ |
130 | ␉{"Muskgrass",␉4},␊ |
131 | ␉{"Juncus",␉4},␊ |
132 | ␉{"Osmunda", 4},␊ |
133 | ␉{"Pondweed", 3},␊ |
134 | ␉{"Spikerush", 4},␊ |
135 | ␉{"Typha", 5},␊ |
136 | /* AMD7000Controller */␊ |
137 | ␉{"Aji", 4},␊ |
138 | ␉{"Buri", 4},␊ |
139 | ␉{"Chutoro", 5},␊ |
140 | ␉{"Dashimaki", 4},␊ |
141 | ␉{"Ebi", 5},␊ |
142 | ␉{"Gari", 5},␊ |
143 | ␉{"Futomaki", 4},␊ |
144 | ␉{"Hamachi", 4},␊ |
145 | ␉{"OPM", 6},␊ |
146 | ␉{"Ikura", 6},␊ |
147 | ␉{"IkuraS", 1}␊ |
148 | };␊ |
149 | ␊ |
150 | static radeon_card_info_t radeon_cards[] = {␊ |
151 | ␉␊ |
152 | ␉// Earlier cards are not supported␊ |
153 | ␉//␊ |
154 | ␉// Layout is device_id, subsys_id (subsystem id plus vendor id), chip_family_name, display name, frame buffer␊ |
155 | ␉// Cards are grouped by device id and vendor id then sorted by subsystem id to make it easier to add new cards␊ |
156 | ␉// ␊ |
157 | ␊ |
158 | ␉{ 0x9400,␉0x01611043, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 XT", kNull␉␉},␊ |
159 | ␉{ 0x9400,␉0x021E1043, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 XT", kNull␉␉},␊ |
160 | ␉{ 0x9400,␉0x25521002, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 XT", kNull␉␉},␊ |
161 | ␉{ 0x9400,␉0x30001002, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 PRO", kNull␉␉},␊ |
162 | ␉{ 0x9400,␉0x31421002, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 XT", kNull␉␉},␊ |
163 | ␊ |
164 | ␉{ 0x9440,␉0x05021002, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870", kMotmot␉␉},␊ |
165 | ␉{ 0x9440,␉0x0851174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870", kMotmot␉␉},␊ |
166 | ␉{ 0x9440,␉0x114A174B, CHIP_FAMILY_RV770,␉␉"Sapphire Radeon HD4870 Vapor-X", kCardinal␉},␊ |
167 | ␉{ 0x9440,␉0x24401682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870", kMotmot␉␉},␊ |
168 | ␉{ 0x9440,␉0x24411682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870", kMotmot␉␉},␊ |
169 | ␉{ 0x9440,␉0x24441682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870", kMotmot␉␉},␊ |
170 | ␉{ 0x9440,␉0x24451682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870", kMotmot␉␉},␊ |
171 | ␊ |
172 | ␉{ 0x9441,␉0x02601043, CHIP_FAMILY_RV770,␉␉"ASUS EAH4870x2", kMotmot␉␉},␊ |
173 | ␉{ 0x9441,␉0x02841043, CHIP_FAMILY_RV770,␉␉"ASUS EAH4870x2", kMotmot␉␉},␊ |
174 | ␉{ 0x9441,␉0x24401682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870 X2", kMotmot␉␉},␊ |
175 | ␉{ 0x9441,␉0x25421002, CHIP_FAMILY_RV770,␉␉"PowerColor HD 4870 X2", kMotmot␉␉},␊ |
176 | ␊ |
177 | ␉{ 0x9442,␉0x05021002, CHIP_FAMILY_RV770,␉␉"MSI R4850-T2D512", kMotmot␉␉},␊ |
178 | ␉{ 0x9442,␉0x080110B0, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
179 | ␉{ 0x9442,␉0x24701682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
180 | ␉{ 0x9442,␉0x24711682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
181 | ␉{ 0x9442,␉0xE104174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
182 | ␉{ 0x9442,␉0xE810174B, CHIP_FAMILY_RV770,␉␉"Sapphire HD 4850", kMotmot␉␉},␊ |
183 | ␊ |
184 | ␉{ 0x944A,␉0x02A21028, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
185 | ␉{ 0x944A,␉0x30001043, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
186 | ␉{ 0x944A,␉0x30001458, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
187 | ␉{ 0x944A,␉0x30001462, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
188 | ␉{ 0x944A,␉0x30001545, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
189 | ␉{ 0x944A,␉0x30001682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
190 | ␉{ 0x944A,␉0x3000174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
191 | ␉{ 0x944A,␉0x30001787, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
192 | ␉{ 0x944A,␉0x300017AF, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850", kMotmot␉␉},␊ |
193 | ␊ |
194 | ␉{ 0x944C,␉0x05021002, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4830", kMotmot␉␉},␊ |
195 | ␉{ 0x944C,␉0x20031787, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4830", kMotmot␉␉},␊ |
196 | ␉{ 0x944C,␉0x24801682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4830", kMotmot␉␉},␊ |
197 | ␉{ 0x944C,␉0x24811682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4830", kMotmot␉␉},␊ |
198 | ␊ |
199 | ␉{ 0x944E,␉0x30001787, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4730", kMotmot␉␉},␊ |
200 | ␉{ 0x944E,␉0x30101787, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4810", kMotmot␉␉},␊ |
201 | ␉{ 0x944E,␉0x31001787, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4820", kMotmot␉␉},␊ |
202 | ␉{ 0x944E,␉0x3260174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4810", kMotmot␉␉},␊ |
203 | ␉{ 0x944E,␉0x3261174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4810", kMotmot␉␉},␊ |
204 | ␊ |
205 | ␉{ 0x9460,␉0x27021682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4890", kMotmot␉␉},␊ |
206 | ␉{ 0x9460,␉0xE115174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4890", kMotmot␉␉},␊ |
207 | ␉{ 0x9460,␉0xE118174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4890", kMotmot␉␉},␊ |
208 | ␊ |
209 | ␉{ 0x9480,␉0x01211025, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650M", kGliff␉␉},␊ |
210 | ␉{ 0x9480,␉0x03111025, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 5165M", kNull␉␉},␊ |
211 | ␉{ 0x9480,␉0x03121025, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 5165M", kNull␉␉},␊ |
212 | ␉{ 0x9480,␉0x031C1025, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 5165M", kNull␉␉},␊ |
213 | ␉{ 0x9480,␉0x031D1025, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 5165M", kNull␉␉},␊ |
214 | ␉{ 0x9480,␉0x036C1025, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 5165M", kNull␉␉},␊ |
215 | ␉{ 0x9480,␉0x036D1025, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 5165M", kNull␉␉},␊ |
216 | ␉{ 0x9480,␉0x3628103C, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650M", kGliff␉␉},␊ |
217 | ␉{ 0x9480,␉0x9035104D, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650M", kGliff␉␉},␊ |
218 | ␉{ 0x9480,␉0xFD001179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650M", kNull␉␉},␊ |
219 | ␉{ 0x9480,␉0xFDD01179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650M", kNull␉␉},␊ |
220 | ␉{ 0x9480,␉0xFD121179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650M", kNull␉␉},␊ |
221 | ␉{ 0x9480,␉0xFD501179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650M", kNull␉␉},␊ |
222 | ␉{ 0x9480,␉0xFF001179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600M", kNull␉␉},␊ |
223 | ␉{ 0x9480,␉0xFF151179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600M", kNull␉␉},␊ |
224 | ␉{ 0x9480,␉0xFF221179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600M", kNull␉␉},␊ |
225 | ␉{ 0x9480,␉0xFF501179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600M", kNull␉␉},␊ |
226 | ␉{ 0x9480,␉0xFF801179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600M", kNull␉␉},␊ |
227 | ␉{ 0x9480,␉0xFF821179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 5165M", kNull␉␉},␊ |
228 | ␉{ 0x9480,␉0xFFA01179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600M", kNull␉␉},␊ |
229 | ␉{ 0x9480,␉0xFFA21179, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 5165M", kNull␉␉},␊ |
230 | ␊ |
231 | ␉{ 0x9490,␉0x20031787, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4670", kFlicker␉},␊ |
232 | ␉{ 0x9490,␉0x25421028, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4670", kFlicker␉},␊ |
233 | ␉{ 0x9490,␉0x30501787, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4710", kNull␉␉},␊ |
234 | ␉{ 0x9490,␉0x300017AF, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4710", kNull␉␉},␊ |
235 | ␉{ 0x9490,␉0x4710174B, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4710", kNull␉␉},␊ |
236 | ␊ |
237 | ␉{ 0x9498,␉0x10001043, CHIP_FAMILY_RV730,␉␉"ASUS EAHG4670", kNull␉␉},␊ |
238 | ␉{ 0x9498,␉0x20091787, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650", kNull␉␉},␊ |
239 | ␉{ 0x9498,␉0x21CF1458, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600", kNull␉␉},␊ |
240 | ␉{ 0x9498,␉0x24511682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650", kNull␉␉},␊ |
241 | ␉{ 0x9498,␉0x24521682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650", kNull␉␉},␊ |
242 | ␉{ 0x9498,␉0x24541682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650", kNull␉␉},␊ |
243 | ␉{ 0x9498,␉0x29331682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4670", kNull␉␉},␊ |
244 | ␉{ 0x9498,␉0x29341682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4670", kNull␉␉},␊ |
245 | ␉{ 0x9498,␉0x30501787, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4700", kNull␉␉},␊ |
246 | ␉{ 0x9498,␉0x31001787, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4720", kNull␉␉},␊ |
247 | ␊ |
248 | ␉{ 0x94B3,␉0x0D001002, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770", kFlicker␉},␊ |
249 | ␉{ 0x94B3,␉0x1170174B, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770", kFlicker␉},␊ |
250 | ␉{ 0x94B3,␉0x29001682, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770", kFlicker␉},␊ |
251 | ␊ |
252 | ␉{ 0x94C1,␉0x0D021002, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT", kNull␉␉},␊ |
253 | ␉{ 0x94C1,␉0x10021002, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Pro", kNull␉␉},␊ |
254 | ␉{ 0x94C1,␉0x0D021028, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT", kNull␉␉},␊ |
255 | ␉{ 0x94C1,␉0x21741458, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT", kNull␉␉},␊ |
256 | ␉{ 0x94C1,␉0x10331462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT", kNull␉␉},␊ |
257 | ␉{ 0x94C1,␉0x10401462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT", kNull␉␉},␊ |
258 | ␉{ 0x94C1,␉0x11101462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT", kNull␉␉},␊ |
259 | ␊ |
260 | ␉{ 0x94C3,␉0x03421002, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
261 | ␉{ 0x94C3,␉0x01011A93, CHIP_FAMILY_RV610,␉␉"Qimonda Radeon HD 2400 PRO",␉␉␉kNull␉␉},␊ |
262 | ␉{ 0x94C3,␉0x03021028, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
263 | ␉{ 0x94C3,␉0x03421002, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
264 | ␉{ 0x94C3,␉0x04021028, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
265 | ␉{ 0x94C3,␉0x10321462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
266 | ␉{ 0x94C3,␉0x10411462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400", kNull␉␉},␊ |
267 | ␉{ 0x94C3,␉0x11041462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400", kNull␉␉},␊ |
268 | ␉{ 0x94C3,␉0x11051462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400", kNull␉␉},␊ |
269 | ␉{ 0x94C3,␉0x203817AF, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400", kNull␉␉},␊ |
270 | ␉{ 0x94C3,␉0x216A1458, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
271 | ␉{ 0x94C3,␉0x21721458, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
272 | ␉{ 0x94C3,␉0x2247148C, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 LE", kNull␉␉},␊ |
273 | ␉{ 0x94C3,␉0x22471787, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 LE", kNull␉␉},␊ |
274 | ␉{ 0x94C3,␉0x30001025, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350", kNull␉␉},␊ |
275 | ␉{ 0x94C3,␉0x30001458, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 3410", kNull␉␉},␊ |
276 | ␉{ 0x94C3,␉0x30001462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 3410", kNull␉␉},␊ |
277 | ␉{ 0x94C3,␉0x3000148C, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350", kNull␉␉},␊ |
278 | ␉{ 0x94C3,␉0x30001642, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 3410", kNull␉␉},␊ |
279 | ␉{ 0x94C3,␉0x3000174B, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350", kNull␉␉},␊ |
280 | ␉{ 0x94C3,␉0x30001787, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350", kNull␉␉},␊ |
281 | ␉{ 0x94C3,␉0x37161642, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
282 | ␉{ 0x94C3,␉0x94C31002, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
283 | ␉{ 0x94C3,␉0xE370174B, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
284 | ␉{ 0x94C3,␉0xE400174B, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO", kNull␉␉},␊ |
285 | ␊ |
286 | ␉{ 0x9501,␉0x25421002, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3870", kNull␉␉},␊ |
287 | ␉{ 0x9501,␉0x30001002, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3690", kNull␉␉},␊ |
288 | ␉{ 0x9501,␉0x3000174B, CHIP_FAMILY_RV670,␉␉"Sapphire Radeon HD 3690", kNull␉␉},␊ |
289 | ␉{ 0x9501,␉0x30001787, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3690", kNull␉␉},␊ |
290 | ␉{ 0x9501,␉0x4750174B, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750", kNull␉␉},␊ |
291 | ␊ |
292 | ␉{ 0x9505,␉0x024A1043, CHIP_FAMILY_RV670,␉␉"ASUS MA 3850", kNull␉␉},␊ |
293 | ␉{ 0x9505,␉0x25421002, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3850", kNull␉␉},␊ |
294 | ␉{ 0x9505,␉0x30001002, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3690", kNull␉␉},␊ |
295 | ␉{ 0x9505,␉0x3000148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3850", kNull␉␉},␊ |
296 | ␉{ 0x9505,␉0x3000174B, CHIP_FAMILY_RV670,␉␉"Sapphire Radeon HD 3690", kNull␉␉},␊ |
297 | ␉{ 0x9505,␉0x30001787, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3690", kNull␉␉},␊ |
298 | ␉{ 0x9505,␉0x30011043, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4730", kNull␉␉},␊ |
299 | ␉{ 0x9505,␉0x3001148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4730", kNull␉␉},␊ |
300 | ␉{ 0x9505,␉0x3001174B, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750", kNull␉␉},␊ |
301 | ␉{ 0x9505,␉0x3002148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4730", kNull␉␉},␊ |
302 | ␉{ 0x9505,␉0x3003148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750", kNull␉␉},␊ |
303 | ␉{ 0x9505,␉0x3004148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750", kNull␉␉},␊ |
304 | ␉{ 0x9505,␉0x3010174B, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750", kNull␉␉},␊ |
305 | ␉{ 0x9505,␉0x301017AF, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750", kNull␉␉},␊ |
306 | ␉{ 0x9505,␉0x4730174B, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4730", kNull␉␉},␊ |
307 | ␉{ 0x9505,␉0xE630174B, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3800 Series", kNull␉␉},␊ |
308 | ␊ |
309 | ␉{ 0x9540,␉0x30501787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4590", kNull␉␉},␊ |
310 | ␉{ 0x9540,␉0x4590174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4590", kNull␉␉},␊ |
311 | ␊ |
312 | ␉{ 0x954F,␉0x16131462, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4550", kNull␉␉},␊ |
313 | ␉{ 0x954F,␉0x20081787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4350", kNull␉␉},␊ |
314 | ␉{ 0x954F,␉0x29201682, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4550", kNull␉␉},␊ |
315 | ␉{ 0x954F,␉0x29211682, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4550", kNull␉␉},␊ |
316 | ␉{ 0x954F,␉0x3000174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4520", kNull␉␉},␊ |
317 | ␉{ 0x954F,␉0x301017AF, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4450", kNull␉␉},␊ |
318 | ␉{ 0x954F,␉0x30501787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4450", kNull␉␉},␊ |
319 | ␉{ 0x954F,␉0x30901682, CHIP_FAMILY_RV710,␉␉"XFX Radeon HD 4570", kNull␉␉},␊ |
320 | ␉{ 0x954F,␉0x31001787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4520", kNull␉␉},␊ |
321 | ␉{ 0x954F,␉0x4450174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4450", kNull␉␉},␊ |
322 | ␉{ 0x954F,␉0x4570174B, CHIP_FAMILY_RV710,␉␉"Sapphire Radeon HD 4570", kNull␉␉},␊ |
323 | ␉{ 0x954F,␉0x66661043, CHIP_FAMILY_RV710,␉␉"ASUS EAH4550", kNull␉␉},␊ |
324 | ␉{ 0x954F,␉0xE990174B, CHIP_FAMILY_RV710,␉␉"Sapphire Radeon HD 4350", kNull␉␉},␊ |
325 | ␊ |
326 | ␉{ 0x9552,␉0x04341028, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4330", kShrike␉␉},␊ |
327 | ␉{ 0x9552,␉0x21AC1458, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500", kNull␉␉},␊ |
328 | ␉{ 0x9552,␉0x21ED1458, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500", kNull␉␉},␊ |
329 | ␉{ 0x9552,␉0x308B103C, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4330", kShrike␉␉},␊ |
330 | ␉{ 0x9552,␉0x3000148C, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500", kNull␉␉},␊ |
331 | ␉{ 0x9552,␉0x3000174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500", kNull␉␉},␊ |
332 | ␉{ 0x9552,␉0x30001787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500", kNull␉␉},␊ |
333 | ␉{ 0x9552,␉0x300017AF, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500", kNull␉␉},␊ |
334 | ␉{ 0x9552,␉0x44721545, CHIP_FAMILY_RV710,␉␉"VisionTek Radeon 4350", kNull␉␉},␊ |
335 | ␊ |
336 | ␉{ 0x9553,␉0x18751043, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4570",␉␉␉kShrike␉␉},␊ |
337 | ␉{ 0x9553,␉0x1B321043, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4570",␉␉␉kShrike␉␉},␊ |
338 | ␉{ 0x9553,␉0x3092174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500 Series",␉␉kNull␉␉},␊ |
339 | ␉{ 0x9553,␉0x39291642, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4570",␉␉␉kNull␉␉},␊ |
340 | ␉{ 0x9553,␉0xFD001179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 5145",␉␉␉kNull␉␉},␊ |
341 | ␉{ 0x9553,␉0xFD121179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 5145",␉␉␉kNull␉␉},␊ |
342 | ␉{ 0x9553,␉0xFD501179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 5145",␉␉␉kNull␉␉},␊ |
343 | ␉{ 0x9553,␉0xFD921179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 5145",␉␉␉kNull␉␉},␊ |
344 | ␉{ 0x9553,␉0xFDD01179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 5145",␉␉␉kNull␉␉},␊ |
345 | ␉{ 0x9553,␉0xFF001179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500",␉␉␉kNull␉␉},␊ |
346 | ␉{ 0x9553,␉0xFF151179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500",␉␉␉kNull␉␉},␊ |
347 | ␉{ 0x9553,␉0xFF161179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 5145",␉␉␉kNull␉␉},␊ |
348 | ␉{ 0x9553,␉0xFF221179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500",␉␉␉kNull␉␉},␊ |
349 | ␉{ 0x9553,␉0xFF401179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500",␉␉␉kNull␉␉},␊ |
350 | ␉{ 0x9553,␉0xFF501179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500",␉␉␉kNull␉␉},␊ |
351 | ␉{ 0x9553,␉0xFF801179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500",␉␉␉kNull␉␉},␊ |
352 | ␉{ 0x9553,␉0xFF821179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 5145",␉␉␉kNull␉␉},␊ |
353 | ␉{ 0x9553,␉0xFFA01179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 5145",␉␉␉kNull␉␉},␊ |
354 | ␉{ 0x9553,␉0xFFA21179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500",␉␉␉kNull␉␉},␊ |
355 | ␉{ 0x9553,␉0xFFC01179, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500",␉␉␉kNull␉␉},␊ |
356 | ␊ |
357 | ␉{ 0x9555,␉0x29241682, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4550", kNull␉␉},␊ |
358 | ␉{ 0x9555,␉0x24651682, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD4300/HD4500", kNull␉␉}, ␊ |
359 | ␉{ 0x9555,␉0x3711174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD4300/HD4500", kNull␉␉},␊ |
360 | ␊ |
361 | ␉{ 0x9581,␉0x011F1025, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600", kNull␉␉},␊ |
362 | ␉{ 0x9581,␉0x0562107B, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600", kNull␉␉},␊ |
363 | ␉{ 0x9581,␉0x15621043, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600", kNull␉␉},␊ |
364 | ␉{ 0x9581,␉0x3000148C, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600", kNull␉␉},␊ |
365 | ␉{ 0x9581,␉0x30C5103C, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600", kNull␉␉},␊ |
366 | ␉{ 0x9581,␉0x3C2D17AA, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600", kNull␉␉},␊ |
367 | ␉{ 0x9581,␉0x63F61462, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600", kNull␉␉},␊ |
368 | ␉{ 0x9581,␉0x95811002, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600", kNull␉␉},␊ |
369 | ␉{ 0x9581,␉0xFF001179, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600", kNull␉␉},␊ |
370 | ␉{ 0x9581,␉0xFF011179, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600", kNull␉␉},␊ |
371 | ␊ |
372 | ␉{ 0x9583,␉0x0083106B, CHIP_FAMILY_RV630,␉␉"ATI Mobility Radeon HD 2600 XT",␉␉kNull␉␉},␊ |
373 | ␉{ 0x9583,␉0x11071734, CHIP_FAMILY_RV630,␉␉"ATI Mobility Radeon HD 2600 XT",␉␉kNull␉␉},␊ |
374 | ␉{ 0x9583,␉0x3000148C, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600", kNull␉␉},␊ |
375 | ␉{ 0x9583,␉0x30D4103C, CHIP_FAMILY_RV630,␉␉"ATI Mobility Radeon HD 2600 XT",␉␉kNull␉␉},␊ |
376 | ␊ |
377 | ␉{ 0x9588,␉0x01021A93, CHIP_FAMILY_RV630,␉␉"Qimonda Radeon HD 2600 XT",␉␉␉kNull␉␉},␊ |
378 | ␊ |
379 | ␉{ 0x9589,␉0x01001A93, CHIP_FAMILY_RV630,␉␉"Qimonda Radeon HD 2600 PRO",␉␉␉kNull␉␉},␊ |
380 | ␉{ 0x9589,␉0x0E41174B, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600", kNull␉␉},␊ |
381 | ␉{ 0x9589,␉0x30001462, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3610", kNull␉␉},␊ |
382 | ␉{ 0x9589,␉0x30001642, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3610", kNull␉␉},␊ |
383 | ␉{ 0x9589,␉0x30001787, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600", kNull␉␉},␊ |
384 | ␊ |
385 | ␉{ 0x9591,␉0x15453992, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3600", kNull␉␉},␊ |
386 | ␉{ 0x9591,␉0x2303148C, CHIP_FAMILY_RV635,␉␉"VisionTek Radeon HD 2600/3600 Series", kNull␉␉},␊ |
387 | ␊ |
388 | ␉{ 0x9598,␉0xB3831002, CHIP_FAMILY_RV635,␉␉"ATI All-in-Wonder HD", kNull␉␉},␊ |
389 | ␉{ 0x9598,␉0x30001043, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3730", kNull␉␉},␊ |
390 | ␉{ 0x9598,␉0x3000148C, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3730", kNull␉␉},␊ |
391 | ␉{ 0x9598,␉0x30001545, CHIP_FAMILY_RV635,␉␉"VisionTek Radeon HD 2600 XT",␉␉␉kNull␉␉},␊ |
392 | ␉{ 0x9598,␉0x3000174B, CHIP_FAMILY_RV635,␉␉"Sapphire Radeon HD 3730", kNull␉␉},␊ |
393 | ␉{ 0x9598,␉0x30011043, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4570", kNull␉␉},␊ |
394 | ␉{ 0x9598,␉0x3001148C, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4580", kNull␉␉},␊ |
395 | ␉{ 0x9598,␉0x3031148C, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4570", kNull␉␉},␊ |
396 | ␉{ 0x9598,␉0x30011545, CHIP_FAMILY_RV635,␉␉"VisionTek Radeon HD 2600 Pro",␉␉␉kNull␉␉},␊ |
397 | ␉{ 0x9598,␉0x3001174B, CHIP_FAMILY_RV635,␉␉"Sapphire Radeon HD 3750", kNull␉␉},␊ |
398 | ␉{ 0x9598,␉0x300117AF, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3750", kNull␉␉},␊ |
399 | ␉{ 0x9598,␉0x301017AF, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4570", kNull␉␉},␊ |
400 | ␉{ 0x9598,␉0x301117AF, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4580", kNull␉␉},␊ |
401 | ␉{ 0x9598,␉0x30501787, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4610", kNull␉␉},␊ |
402 | ␉{ 0x9598,␉0x4570174B, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4570", kNull␉␉},␊ |
403 | ␉{ 0x9598,␉0x4580174B, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4580", kNull␉␉},␊ |
404 | ␉{ 0x9598,␉0x4610174B, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4610", kNull␉␉},␊ |
405 | ␊ |
406 | ␉{ 0x95C0,␉0x3000148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3550", kNull␉␉},␊ |
407 | ␉{ 0x95C0,␉0x3000174B, CHIP_FAMILY_RV620,␉␉"Sapphire Radeon HD 3550", kNull␉␉},␊ |
408 | ␉{ 0x95C0,␉0x3002174B, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3570", kNull␉␉},␊ |
409 | ␉{ 0x95C0,␉0x3020174B, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250", kNull␉␉},␊ |
410 | ␉{ 0x95C0,␉0xE3901745, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3550", kNull␉␉},␊ |
411 | ␊ |
412 | ␉{ 0x95C5,␉0x01041A93, CHIP_FAMILY_RV620,␉␉"Qimonda Radeon HD 3450", kNull␉␉},␊ |
413 | ␉{ 0x95C5,␉0x01051A93, CHIP_FAMILY_RV620,␉␉"Qimonda Radeon HD 3450", kNull␉␉},␊ |
414 | ␉{ 0x95C5,␉0x3000148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3450", kNull␉␉},␊ |
415 | ␉{ 0x95C5,␉0x3001148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3550", kNull␉␉},␊ |
416 | ␉{ 0x95C5,␉0x3002148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4230", kNull␉␉},␊ |
417 | ␉{ 0x95C5,␉0x3003148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250", kNull␉␉},␊ |
418 | ␉{ 0x95C5,␉0x3010174B, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250", kNull␉␉},␊ |
419 | ␉{ 0x95C5,␉0x301017AF, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4230", kNull␉␉},␊ |
420 | ␉{ 0x95C5,␉0x3032148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250", kNull␉␉},␊ |
421 | ␉{ 0x95C5,␉0x3033148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4230", kNull␉␉},␊ |
422 | ␉{ 0x95C5,␉0x30501787, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250", kNull␉␉},␊ |
423 | ␉{ 0x95C5,␉0x4250174B, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250", kNull␉␉},␊ |
424 | ␊ |
425 | ␉/* Evergreen */␊ |
426 | ␉{ 0x6898,␉0x00D0106B, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870", kLangur␉␉},␊ |
427 | ␉{ 0x6898,␉0x032E1043, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870", kUakari␉␉},␊ |
428 | ␉{ 0x6898,␉0x038C1043, CHIP_FAMILY_CYPRESS,␉"ASUS 5870 Eyefinity 6", kNull␉␉},␊ |
429 | ␉{ 0x6898,␉0x0B001002, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870", kZonalis␉},␊ |
430 | ␉{ 0x6898,␉0x21E51458, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870", kUakari␉␉},␊ |
431 | ␉{ 0x6898,␉0x29611682, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870", kUakari␉␉},␊ |
432 | ␉{ 0x6898,␉0xE140174B, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870", kUakari␉␉},␊ |
433 | ␊ |
434 | ␉{ 0x6899,␉0x200A1787, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5850", kUakari␉␉},␊ |
435 | ␉{ 0x6899,␉0x21E41458, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5850", kUakari␉␉},␊ |
436 | ␉{ 0x6899,␉0x22901787, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5850", kUakari␉␉},␊ |
437 | ␉{ 0x6899,␉0xE140174B, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5850", kUakari␉␉},␊ |
438 | ␉{ 0x6899,␉0xE174174B, CHIP_FAMILY_CYPRESS,␉"ATI Sapphire Radeon HD 5850", kUakari␉␉},␊ |
439 | ␊ |
440 | ␉{ 0x689C,␉0x034A1043, CHIP_FAMILY_HEMLOCK,␉"ATI Radeon HD 5970", kUakari␉␉},␊ |
441 | ␉{ 0x689C,␉0x03521043, CHIP_FAMILY_HEMLOCK,␉"ASUS ARES", kUakari␉␉},␊ |
442 | ␉{ 0x689C,␉0x039E1043, CHIP_FAMILY_HEMLOCK,␉"ASUS EAH5870", kUakari␉␉},␊ |
443 | ␉{ 0x689C,␉0x25421002, CHIP_FAMILY_HEMLOCK,␉"ATI Radeon HD 5970", kUakari␉␉},␊ |
444 | ␉{ 0x689C,␉0x30201682, CHIP_FAMILY_HEMLOCK,␉"ATI Radeon HD 5970", kUakari␉␉},␊ |
445 | ␊ |
446 | ␉{ 0x68A0,␉0x03081025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5830",␉␉␉kNomascus␉},␊ |
447 | ␉{ 0x68A0,␉0x030A1025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5830",␉␉␉kNomascus␉},␊ |
448 | ␉{ 0x68A0,␉0x043A1028, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5870",␉␉␉kNomascus␉},␊ |
449 | ␊ |
450 | ␉{ 0x68A1,␉0x03081025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
451 | ␉{ 0x68A1,␉0x030A1025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
452 | ␉{ 0x68A1,␉0x03671025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
453 | ␉{ 0x68A1,␉0x03681025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
454 | ␉{ 0x68A1,␉0x038B1025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
455 | ␉{ 0x68A1,␉0x038C1025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
456 | ␉{ 0x68A1,␉0x042E1025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
457 | ␉{ 0x68A1,␉0x042F1025, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
458 | ␉{ 0x68A1,␉0x144D103C, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNomascus␉},␊ |
459 | ␉{ 0x68A1,␉0x1522103C, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kHoolock␉},␊ |
460 | ␉{ 0x68A1,␉0x22411462, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
461 | ␉{ 0x68A1,␉0x39961462, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNull␉},␊ |
462 | ␊ |
463 | ␉{ 0x68A8,␉0x04421025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
464 | ␉{ 0x68A8,␉0x04511025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
465 | ␉{ 0x68A8,␉0x048F1028, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6870M", kNull␉␉},␊ |
466 | ␉{ 0x68A8,␉0x04901028, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6870M", kNull␉␉},␊ |
467 | ␉{ 0x68A8,␉0x04B91028, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6870M", kNull␉␉},␊ |
468 | ␉{ 0x68A8,␉0x04BA1028, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6870M", kNull␉␉},␊ |
469 | ␉{ 0x68A8,␉0x050A1025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
470 | ␉{ 0x68A8,␉0x050B1025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
471 | ␉{ 0x68A8,␉0x050C1025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
472 | ␉{ 0x68A8,␉0x050E1025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
473 | ␉{ 0x68A8,␉0x050F1025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
474 | ␉{ 0x68A8,␉0x05131025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
475 | ␉{ 0x68A8,␉0x05141025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
476 | ␉{ 0x68A8,␉0x05151025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
477 | ␉{ 0x68A8,␉0x05161025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
478 | ␉{ 0x68A8,␉0x05251025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
479 | ␉{ 0x68A8,␉0x05261025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
480 | ␉{ 0x68A8,␉0x056D1025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
481 | ␉{ 0x68A8,␉0x159B103C, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
482 | ␉{ 0x68A8,␉0xC0AD144D, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M", kUakari␉␉},␊ |
483 | ␊ |
484 | ␉{ 0x68B8,␉0x00CF106B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kHoolock␉},␊ |
485 | ␉{ 0x68B8,␉0x0044144D, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6770", kVervet␉␉},␊ |
486 | ␉{ 0x68B8,␉0x1482174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
487 | ␉{ 0x68B8,␉0x200A1787, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
488 | ␉{ 0x68B8,␉0x200B1787, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
489 | ␉{ 0x68B8,␉0x21D71458, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
490 | ␉{ 0x68B8,␉0x21F61458, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
491 | ␉{ 0x68B8,␉0x22881787, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
492 | ␉{ 0x68B8,␉0x25431002, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
493 | ␉{ 0x68B8,␉0x25431458, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
494 | ␉{ 0x68B8,␉0x29901682, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
495 | ␉{ 0x68B8,␉0x29911682, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
496 | ␉{ 0x68B8,␉0x30001002, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6700", kVervet␉␉},␊ |
497 | ␉{ 0x68B8,␉0x6880103C, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
498 | ␉{ 0x68B8,␉0x6881103C, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6770", kVervet␉␉},␊ |
499 | ␉{ 0x68B8,␉0xE144174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kHoolock␉},␊ |
500 | ␉{ 0x68B8,␉0xE147174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
501 | ␉{ 0x68B8,␉0xE160174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770", kVervet␉␉},␊ |
502 | ␉{ 0x68B8,␉0xEA60174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6770", kVervet␉␉},␊ |
503 | ␊ |
504 | ␉{ 0x68BA,␉0x03FE1043, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
505 | ␉{ 0x68BA,␉0x1482174B, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
506 | ␉{ 0x68BA,␉0x174B1482, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
507 | ␉{ 0x68BA,␉0x200A1787, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
508 | ␉{ 0x68BA,␉0x21421462, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
509 | ␉{ 0x68BA,␉0x25431458, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
510 | ␉{ 0x68BA,␉0x31501682, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
511 | ␉{ 0x68BA,␉0x31521682, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
512 | ␉{ 0x68BA,␉0x31531682, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
513 | ␉{ 0x68BA,␉0xE144174B, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770", kVervet␉␉},␊ |
514 | ␊ |
515 | ␉{ 0x68BE,␉0x200A1787, CHIP_FAMILY_JUNIPER,␉"HIS ATI 5750", kVervet␉␉},␊ |
516 | ␉{ 0x68BE,␉0x22881787, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5750", kVervet␉␉},␊ |
517 | ␉{ 0x68BE,␉0x3000148C, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6750", kNull␉␉},␊ |
518 | ␉{ 0x68BE,␉0x3000174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6750", kNull␉␉},␊ |
519 | ␉{ 0x68BE,␉0x300017AF, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6750", kNull␉␉},␊ |
520 | ␉{ 0x68BE,␉0x39821642, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6750", kNull␉␉},␊ |
521 | ␊ |
522 | ␉{ 0x68BF,␉0x220E1458, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6750", kVervet␉␉},␊ |
523 | ␉{ 0x68BF,␉0x3000148C, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6750", kVervet␉␉},␊ |
524 | ␉{ 0x68BF,␉0x31401682, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6750", kVervet␉␉},␊ |
525 | ␉{ 0x68BF,␉0x6750174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6750", kVervet␉␉},␊ |
526 | ␊ |
527 | ␉{ 0x68C0,␉0x1594103C, CHIP_FAMILY_REDWOOD,␉"AMD Radeon HD 6570M", kNull␉␉},␊ |
528 | ␉{ 0x68C0,␉0x392717AA, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5730",␉␉␉kNull␉␉},␊ |
529 | ␉{ 0x68C0,␉0x395217AA, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5730",␉␉␉kNull␉␉},␊ |
530 | ␉{ 0x68C0,␉0x84721043, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5000",␉␉␉kNull␉␉},␊ |
531 | ␊ |
532 | ␉{ 0x68C1,␉0x02051025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
533 | ␉{ 0x68C1,␉0x02961025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
534 | ␉{ 0x68C1,␉0x030A1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
535 | ␉{ 0x68C1,␉0x033D1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
536 | ␉{ 0x68C1,␉0x033E1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kNull␉␉},␊ |
537 | ␉{ 0x68C1,␉0x03471025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
538 | ␉{ 0x68C1,␉0x03561025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
539 | ␉{ 0x68C1,␉0x03581025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
540 | ␉{ 0x68C1,␉0x035A1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
541 | ␉{ 0x68C1,␉0x035C1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
542 | ␉{ 0x68C1,␉0x03641025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
543 | ␉{ 0x68C1,␉0x036D1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kNull␉␉},␊ |
544 | ␉{ 0x68C1,␉0x03791025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
545 | ␉{ 0x68C1,␉0x037E1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
546 | ␉{ 0x68C1,␉0x03821025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉},␊ |
547 | ␉{ 0x68C1,␉0x04121025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kNull␉␉},␊ |
548 | ␉{ 0x68C1,␉0x042E1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kNull␉␉},␊ |
549 | ␉{ 0x68C1,␉0x042F1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kNull␉␉},␊ |
550 | ␉{ 0x68C1,␉0x9071104D, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kEulemur␉},␊ |
551 | ␉{ 0x68C1,␉0x1449103C, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kEulemur␉},␊ |
552 | ␉{ 0x68C1,␉0xFD001179, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kEulemur␉},␊ |
553 | ␉{ 0x68C1,␉0xFD121179, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kEulemur␉},␊ |
554 | ␉{ 0x68C1,␉0xFD501179, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kEulemur␉},␊ |
555 | ␉{ 0x68C1,␉0xFDD01179, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kEulemur␉},␊ |
556 | ␊ |
557 | ␉{ 0x68C8,␉0x2306103C, CHIP_FAMILY_REDWOOD,␉"ATI FirePro V4800 (FireGL)",␉␉␉kNull␉␉},␊ |
558 | ␉{ 0x68C8,␉0x240A1002, CHIP_FAMILY_REDWOOD,␉"ATI FirePro V4800 (FireGL)",␉␉␉kNull␉␉},␊ |
559 | ␉{ 0x68C8,␉0x240A1028, CHIP_FAMILY_REDWOOD,␉"ATI FirePro V4800 (FireGL)",␉␉␉kNull␉␉},␊ |
560 | ␊ |
561 | ␉{ 0x68D8,␉0x03561043, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670", kBaboon␉␉},␊ |
562 | ␉{ 0x68D8,␉0x03C01043, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670", kNull␉␉},␊ |
563 | ␉{ 0x68D8,␉0x20091787, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670", kNull␉␉},␊ |
564 | ␉{ 0x68D8,␉0x21D91458, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670", kBaboon␉␉},␊ |
565 | ␉{ 0x68D8,␉0x21F41458, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670", kNull␉␉},␊ |
566 | ␉{ 0x68D8,␉0x22051462, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5690", kNull␉␉},␊ |
567 | ␉{ 0x68D8,␉0x22941787, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5690", kNull␉␉},␊ |
568 | ␉{ 0x68D8,␉0x30001787, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5730", kNull␉␉},␊ |
569 | ␉{ 0x68D8,␉0x301017AF, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5730", kNull␉␉},␊ |
570 | ␉{ 0x68D8,␉0x301117AF, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5690", kNull␉␉},␊ |
571 | ␉{ 0x68D8,␉0x30601682, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5690", kNull␉␉},␊ |
572 | ␉{ 0x68D8,␉0x30651682, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5690", kNull␉␉},␊ |
573 | ␉{ 0x68D8,␉0x56701545, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5690", kNull␉␉},␊ |
574 | ␉{ 0x68D8,␉0x5690174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5690", kNull␉␉},␊ |
575 | ␉{ 0x68D8,␉0x5730174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5730", kNull␉␉},␊ |
576 | ␉{ 0x68D8,␉0x68E01028, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670", kBaboon␉␉},␊ |
577 | ␉{ 0x68D8,␉0xE151174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670", kEulemur␉},␊ |
578 | ␉{ 0x68D8,␉0xE155174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670", kNull␉␉},␊ |
579 | ␉{ 0x68D8,␉0xE166174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670", kUakari␉␉},␊ |
580 | ␊ |
581 | ␉{ 0x68D9,␉0x03CE1043, CHIP_FAMILY_REDWOOD,␉"ASUS EAH5550 series", kNull␉␉},␊ |
582 | ␉{ 0x68D9,␉0x22401462, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5570", kNull␉␉},␊ |
583 | ␉{ 0x68D9,␉0x3000148C, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 6510", kNull␉␉},␊ |
584 | ␉{ 0x68D9,␉0x3000174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 6510", kNull␉␉},␊ |
585 | ␉{ 0x68D9,␉0x301017AF, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5630", kNull␉␉},␊ |
586 | ␉{ 0x68D9,␉0x39691642, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5570", kNull␉␉},␊ |
587 | ␊ |
588 | ␉{ 0x68DA,␉0x3000148C, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 6390", kNull␉␉},␊ |
589 | ␉{ 0x68DA,␉0x3000174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 6390", kNull␉␉},␊ |
590 | ␉{ 0x68DA,␉0x30001787, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5630", kNull␉␉},␊ |
591 | ␉{ 0x68DA,␉0x300017AF, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 6390", kNull␉␉},␊ |
592 | ␉{ 0x68DA,␉0x301017AF, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5630", kNull␉␉},␊ |
593 | ␉{ 0x68DA,␉0x5630174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5630", kNull␉␉},␊ |
594 | ␊ |
595 | ␉{ 0x68E0,␉0x02931025, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
596 | ␉{ 0x68E0,␉0x03581025, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
597 | ␉{ 0x68E0,␉0x03591025, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
598 | ␉{ 0x68E0,␉0x035C1025, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
599 | ␉{ 0x68E0,␉0x035D1025, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
600 | ␉{ 0x68E0,␉0x036D1025, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kLangur },␊ |
601 | ␉{ 0x68E0,␉0x04471028, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
602 | ␉{ 0x68E0,␉0x04561028, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
603 | ␉{ 0x68E0,␉0x04831025, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
604 | ␉{ 0x68E0,␉0x1433103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
605 | ␉{ 0x68E0,␉0x1441103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
606 | ␉{ 0x68E0,␉0x144A103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
607 | ␉{ 0x68E0,␉0x1BF21043, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kNull },␊ |
608 | ␉{ 0x68E0,␉0x848F1043, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kNull },␊ |
609 | ␉{ 0x68E0,␉0xFD001179, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
610 | ␉{ 0x68E0,␉0xFD121179, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
611 | ␉{ 0x68E0,␉0xFD501179, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
612 | ␉{ 0x68E0,␉0xFD921179, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
613 | ␉{ 0x68E0,␉0xFDD01179, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
614 | ␊ |
615 | ␉{ 0x68E1,␉0x04661028, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
616 | ␉{ 0x68E1,␉0x10021B61, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450M", kEulemur␉},␊ |
617 | ␉{ 0x68E1,␉0x10501462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
618 | ␉{ 0x68E1,␉0x1426103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
619 | ␉{ 0x68E1,␉0x142A103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 545vM", kEulemur␉},␊ |
620 | ␉{ 0x68E1,␉0x14E110CF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5400M", kEulemur␉},␊ |
621 | ␉{ 0x68E1,␉0x21D81458, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
622 | ␉{ 0x68E1,␉0x21E21458, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
623 | ␉{ 0x68E1,␉0x21F11458, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
624 | ␉{ 0x68E1,␉0x22021458, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
625 | ␉{ 0x68E1,␉0x23421462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
626 | ␉{ 0x68E1,␉0x23431462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
627 | ␉{ 0x68E1,␉0x25481458, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5400M Series", kEulemur␉},␊ |
628 | ␉{ 0x68E1,␉0x254A1458, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5000M Series", kEulemur␉},␊ |
629 | ␉{ 0x68E1,␉0x30001043, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
630 | ␉{ 0x68E1,␉0x3000148C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
631 | ␉{ 0x68E1,␉0x30001682, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
632 | ␉{ 0x68E1,␉0x3000174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉}, ␊ |
633 | ␉{ 0x68E1,␉0x30001787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉}, // 5430M ???␊ |
634 | ␉{ 0x68E1,␉0x300017AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
635 | ␉{ 0x68E1,␉0x3001148C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
636 | ␉{ 0x68E1,␉0x301417AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kEulemur␉},␊ |
637 | ␉{ 0x68E1,␉0x3002148C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
638 | ␉{ 0x68E1,␉0x3003148C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450M", kEulemur␉},␊ |
639 | ␉{ 0x68E1,␉0x54501545, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
640 | ␉{ 0x68E1,␉0x5470174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M", kEulemur␉},␊ |
641 | ␉{ 0x68E1,␉0x60001092, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
642 | ␉{ 0x68E1,␉0x60001682, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
643 | ␉{ 0x68E1,␉0x6000174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
644 | ␉{ 0x68E1,␉0x6230174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kEulemur␉},␊ |
645 | ␉{ 0x68E1,␉0x6350174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kEulemur␉},␊ |
646 | ␉{ 0x68E1,␉0xFDD01179, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M", kEulemur␉},␊ |
647 | ␊ |
648 | ␉{ 0x68E4,␉0x04821025, CHIP_FAMILY_CEDAR,␉␉"AMD Radeon HD 6370M", kNull␉␉},␊ |
649 | ␉{ 0x68E4,␉0x1426103C, CHIP_FAMILY_CEDAR,␉␉"AMD Radeon HD 6370M", kNull␉␉},␊ |
650 | ␉{ 0x68E4,␉0x1C921043, CHIP_FAMILY_CEDAR,␉␉"AMD Radeon HD 6370M", kNull␉␉},␊ |
651 | ␉{ 0x68E4,␉0x397917AA, CHIP_FAMILY_CEDAR,␉␉"AMD Radeon HD 6370M", kNull␉␉},␊ |
652 | ␉{ 0x68E4,␉0x397F17AA, CHIP_FAMILY_CEDAR,␉␉"AMD Radeon HD 7370M", kNull␉␉},␊ |
653 | ␉{ 0x68E4,␉0x84A01043, CHIP_FAMILY_CEDAR,␉␉"AMD Radeon HD 6370M", kNull␉␉},␊ |
654 | ␊ |
655 | ␉{ 0x68F9,␉0x00011019, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
656 | ␉{ 0x68F9,␉0x00021019, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
657 | ␉{ 0x68F9,␉0x00191019, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
658 | ␉{ 0x68F9,␉0x010E1002, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
659 | ␉{ 0x68F9,␉0x010E1028, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
660 | ␉{ 0x68F9,␉0x03741043, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
661 | ␉{ 0x68F9,␉0x03CA1043, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
662 | ␉{ 0x68F9,␉0x05181025, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
663 | ␉{ 0x68F9,␉0x05191025, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
664 | ␉{ 0x68F9,␉0x174B3000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6230", kNull␉␉},␊ |
665 | ␉{ 0x68F9,␉0x174B6250, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6250", kNull␉␉},␊ |
666 | ␉{ 0x68F9,␉0x174B6290, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6290", kNull␉␉},␊ |
667 | ␉{ 0x68F9,␉0x174BE164, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
668 | ␉{ 0x68F9,␉0x20091787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
669 | ␉{ 0x68F9,␉0x21261028, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
670 | ␉{ 0x68F9,␉0x2126103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
671 | ␉{ 0x68F9,␉0x21301462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
672 | ␉{ 0x68F9,␉0x21311462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
673 | ␉{ 0x68F9,␉0x21331462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kEulemur␉},␊ |
674 | ␉{ 0x68F9,␉0x21801462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
675 | ␉{ 0x68F9,␉0x21811462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
676 | ␉{ 0x68F9,␉0x21821462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
677 | ␉{ 0x68F9,␉0x21831462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
678 | ␉{ 0x68F9,␉0x22911787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
679 | ␉{ 0x68F9,␉0x22301462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
680 | ␉{ 0x68F9,␉0x22311462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
681 | ␉{ 0x68F9,␉0x23401462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
682 | ␉{ 0x68F9,␉0x24951462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
683 | ␉{ 0x68F9,␉0x2AAC103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
684 | ␉{ 0x68F9,␉0x2AEC103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
685 | ␉{ 0x68F9,␉0x30001787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470", kNull␉␉},␊ |
686 | ␉{ 0x68F9,␉0x300017AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6250", kNull␉␉},␊ |
687 | ␉{ 0x68F9,␉0x3001148C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6250", kNull␉␉},␊ |
688 | ␉{ 0x68F9,␉0x30011787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5530", kNull␉␉},␊ |
689 | ␉{ 0x68F9,␉0x3002148C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6290", kNull␉␉},␊ |
690 | ␉{ 0x68F9,␉0x30021787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5490", kNull␉␉},␊ |
691 | ␉{ 0x68F9,␉0x300217AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6290", kNull␉␉},␊ |
692 | ␉{ 0x68F9,␉0x3003148C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6230", kNull␉␉},␊ |
693 | ␉{ 0x68F9,␉0x301117AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470", kNull␉␉},␊ |
694 | ␉{ 0x68F9,␉0x301217AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5490", kNull␉␉},␊ |
695 | ␉{ 0x68F9,␉0x301317AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470", kNull␉␉},␊ |
696 | ␉{ 0x68F9,␉0x301417AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
697 | ␉{ 0x68F9,␉0x30321682, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450",␉␉␉kEulemur␉},␊ |
698 | ␉{ 0x68F9,␉0x303A1682, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450",␉␉␉kEulemur␉},␊ |
699 | ␉{ 0x68F9,␉0x3580103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
700 | ␉{ 0x68F9,␉0x360217AA, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
701 | ␉{ 0x68F9,␉0x360317AA, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
702 | ␉{ 0x68F9,␉0x360F17AA, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
703 | ␉{ 0x68F9,␉0x361917AA, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
704 | ␉{ 0x68F9,␉0x39831642, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
705 | ␉{ 0x68F9,␉0x39841642, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
706 | ␉{ 0x68F9,␉0x39871642, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
707 | ␉{ 0x68F9,␉0x3987174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
708 | ␉{ 0x68F9,␉0x39971462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
709 | ␉{ 0x68F9,␉0x3A051642, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kNull␉␉},␊ |
710 | ␉{ 0x68F9,␉0x3B311642, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350A", kNull␉␉},␊ |
711 | ␉{ 0x68F9,␉0x5470174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470", kNull␉␉},␊ |
712 | ␉{ 0x68F9,␉0x5490174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5490", kNull␉␉},␊ |
713 | ␉{ 0x68F9,␉0x5530174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5530", kNull␉␉},␊ |
714 | ␉{ 0x68F9,␉0x6230174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6230", kNull␉␉},␊ |
715 | ␉{ 0x68F9,␉0x6350174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6350", kNull␉␉},␊ |
716 | ␉{ 0x68F9,␉0x7350148C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 7350", kNull␉␉},␊ |
717 | ␉{ 0x68F9,␉0xE127174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
718 | ␉{ 0x68F9,␉0xE145174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
719 | ␉{ 0x68F9,␉0xE153174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
720 | ␉{ 0x68F9,␉0xE164174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450", kEulemur␉},␊ |
721 | ␊ |
722 | ␉/* Northen Islands */␊ |
723 | ␉{ 0x6718,␉0x0B001002, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970", kGibba␉␉},␊ |
724 | ␉{ 0x6718,␉0x20101458, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970", kGibba␉␉},␊ |
725 | ␉{ 0x6718,␉0x22001458, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970", kGibba␉␉},␊ |
726 | ␉{ 0x6718,␉0x23061787, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970", kGibba␉␉},␊ |
727 | ␉{ 0x6718,␉0x23701462, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970", kGibba␉␉},␊ |
728 | ␉{ 0x6718,␉0x31301682, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970", kGibba␉␉},␊ |
729 | ␉{ 0x6718,␉0x67181002, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970", kGibba␉␉},␊ |
730 | ␉{ 0x6718,␉0xE182174B, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970", kGibba␉␉},␊ |
731 | ␉{ 0x6718,␉0xE203174B, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970", kGibba␉␉},␊ |
732 | ␊ |
733 | ␉{ 0x6719,␉0x03BE1043, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
734 | ␉{ 0x6719,␉0x03D41043, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
735 | ␉{ 0x6719,␉0x0B001002, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
736 | ␉{ 0x6719,␉0x186B174B, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
737 | ␉{ 0x6719,␉0x20101787, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
738 | ␉{ 0x6719,␉0x21FD1458, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
739 | ␉{ 0x6719,␉0x23071787, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
740 | ␉{ 0x6719,␉0x24611462, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
741 | ␉{ 0x6719,␉0x31211682, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
742 | ␉{ 0x6719,␉0x31221682, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
743 | ␉{ 0x6719,␉0xE189174B, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950", kGibba␉␉},␊ |
744 | ␊ |
745 | //␉{ 0x671D,␉0x0B2A1002, CHIP_FAMILY_ANTILLES,␉"AMD Radeon HD 6990", kNull␉␉},␊ |
746 | //␉{ 0x671D,␉0x1B2A1002, CHIP_FAMILY_ANTILLES,␉"AMD Radeon HD 6990", kNull␉␉},␊ |
747 | //␉{ 0x671D,␉0x31601682, CHIP_FAMILY_ANTILLES,␉"AMD Radeon HD 6990", kNull␉␉},␊ |
748 | ␊ |
749 | ␉{ 0x6720,␉0x048F1028, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M", kElodea␉␉},␊ |
750 | ␉{ 0x6720,␉0x04901028, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M", kElodea␉␉},␊ |
751 | ␉{ 0x6720,␉0x04A41028, CHIP_FAMILY_BARTS,␉␉"AMD FirePro M8900M", kElodea␉␉},␊ |
752 | ␉{ 0x6720,␉0x04B91028, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M", kElodea␉␉},␊ |
753 | ␉{ 0x6720,␉0x04BA1028, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M", kElodea␉␉},␊ |
754 | ␉{ 0x6720,␉0x51021558, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M", kElodea␉␉},␊ |
755 | ␉{ 0x6720,␉0x51041558, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6990M", kElodea␉␉},␊ |
756 | ␉{ 0x6720,␉0x71001558, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M", kElodea␉␉},␊ |
757 | ␉{ 0x6720,␉0x72001558, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M", kElodea␉␉},␊ |
758 | ␉{ 0x6720,␉0x72011558, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6990M", kElodea␉␉},␊ |
759 | ␉{ 0x6720,␉0xC0AD144D, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M", kElodea␉␉},␊ |
760 | ␊ |
761 | ␉{ 0x6738,␉0x00D01002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
762 | ␉{ 0x6738,␉0x03AE1043, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
763 | ␉{ 0x6738,␉0x03C61043, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
764 | ␉{ 0x6738,␉0x174B174B, CHIP_FAMILY_BARTS,␉␉"Sapphire Radeon HD6870", kBulrushes␉}, // ?? kDuckweed ??␊ |
765 | ␉{ 0x6738,␉0x20101787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
766 | ␉{ 0x6738,␉0x21FA1002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
767 | ␉{ 0x6738,␉0x21FA1458, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
768 | ␉{ 0x6738,␉0x23051787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
769 | ␉{ 0x6738,␉0x25101462, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
770 | ␉{ 0x6738,␉0x31031682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
771 | ␉{ 0x6738,␉0x31041682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
772 | ␉{ 0x6738,␉0x31071682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
773 | ␉{ 0x6738,␉0x31081682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉}, // ?? kJuncus ??␊ |
774 | ␉{ 0x6738,␉0x67381002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
775 | ␉{ 0x6738,␉0xE178174B, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870", kDuckweed␉},␊ |
776 | ␊ |
777 | ␉{ 0x6739,␉0x03B41043, CHIP_FAMILY_BARTS,␉␉"ASUS EAH6850 DirectCU", kDuckweed␉},␊ |
778 | ␉{ 0x6739,␉0x174B174B, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
779 | ␉{ 0x6739,␉0x200F1787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
780 | ␉{ 0x6739,␉0x21F81458, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kBulrushes␉},␊ |
781 | ␉{ 0x6739,␉0x23041787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
782 | ␉{ 0x6739,␉0x24001462, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
783 | ␉{ 0x6739,␉0x24411462, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
784 | ␉{ 0x6739,␉0x25201462, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
785 | ␉{ 0x6739,␉0x30001787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
786 | ␉{ 0x6739,␉0x31101682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
787 | ␉{ 0x6739,␉0x31131682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
788 | ␉{ 0x6739,␉0x31141682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
789 | ␉{ 0x6739,␉0x31161682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
790 | ␉{ 0x6739,␉0x31171682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
791 | ␉{ 0x6739,␉0x67391002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
792 | ␉{ 0x6739,␉0xAA881002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
793 | ␉{ 0x6739,␉0xE174174B, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
794 | ␉{ 0x6739,␉0xE177174B, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
795 | ␉{ 0x6739,␉0xE183174B, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850", kDuckweed␉},␊ |
796 | ␊ |
797 | ␉{ 0x673E,␉0x174B174B, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790", kNull␉␉},␊ |
798 | ␉{ 0x673E,␉0x23101787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790", kNull␉␉},␊ |
799 | ␉{ 0x673E,␉0x31701682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790", kNull␉␉},␊ |
800 | ␉{ 0x673E,␉0x31721682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790", kNull␉␉},␊ |
801 | ␊ |
802 | ␉{ 0x6740,␉0x04A31028, CHIP_FAMILY_TURKS,␉␉"Dell HD 6770M", kNull␉␉}, // ??␊ |
803 | ␉{ 0x6740,␉0x1D121043, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6730M", kNull␉␉},␊ |
804 | ␉{ 0x6740,␉0x1631103C, CHIP_FAMILY_TURKS,␉␉"AMD FirePro M5950", kNull␉␉},␊ |
805 | ␉{ 0x6740,␉0x1657103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6770M", kNull␉␉},␊ |
806 | ␉{ 0x6740,␉0x165A103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6770M", kNull␉␉},␊ |
807 | ␉{ 0x6740,␉0x3388103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6770M", kNull␉␉},␊ |
808 | ␉{ 0x6740,␉0x3389103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6770M", kNull␉␉}, // ?? kHydrilla ??␊ |
809 | ␉{ 0x6740,␉0x6740106B, CHIP_FAMILY_TURKS,␉␉"Apple HD 6770M", kNull␉␉}, // ??␊ |
810 | ␊ |
811 | ␉{ 0x6741,␉0x050E1025, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6650M", kNull␉␉},␊ |
812 | ␉{ 0x6741,␉0x050F1025, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6650M", kNull␉␉},␊ |
813 | ␉{ 0x6741,␉0x05131025, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6650M", kNull␉␉},␊ |
814 | ␉{ 0x6741,␉0x1646103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6750M", kNull␉␉},␊ |
815 | ␉{ 0x6741,␉0x1688103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 7690M", kNull␉␉},␊ |
816 | ␉{ 0x6741,␉0x358D103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6630M/6650M/6750M", kNull␉␉},␊ |
817 | ␉{ 0x6741,␉0x9080104D, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6630M", kNull␉␉},␊ |
818 | ␊ |
819 | ␉{ 0x6758,␉0x00121028, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
820 | ␉{ 0x6758,␉0x0B0E1002, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kPithecia␉},␊ |
821 | ␉{ 0x6758,␉0x0B0E1028, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
822 | ␉{ 0x6758,␉0x20121787, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kPithecia␉},␊ |
823 | ␉{ 0x6758,␉0x20141787, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
824 | ␉{ 0x6758,␉0x22051458, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
825 | ␉{ 0x6758,␉0x31811682, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
826 | ␉{ 0x6758,␉0x31831682, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
827 | ␉{ 0x6758,␉0x67581002, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
828 | ␉{ 0x6758,␉0x6882103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
829 | ␉{ 0x6758,␉0xE181174B, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
830 | ␉{ 0x6758,␉0xE1941746, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kBulrushes␉},␊ |
831 | ␉{ 0x6758,␉0xE194174B, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670", kMangabey␉}, ␊ |
832 | ␊ |
833 | ␉{ 0x6759,␉0x20121787, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6570", kPithecia␉},␊ |
834 | ␉{ 0x6759,␉0xE193174B, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6570", kPithecia␉},␊ |
835 | ␊ |
836 | ␉{ 0x675F,␉0x23141787, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 5570", kNull␉␉},␊ |
837 | ␉{ 0x675F,␉0x254B1458, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 5570", kNull␉␉},␊ |
838 | ␉{ 0x675F,␉0x6510148C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 5570", kNull␉␉},␊ |
839 | ␉{ 0x675F,␉0x6510174B, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 5570", kNull␉␉},␊ |
840 | ␊ |
841 | ␉{ 0x6760,␉0x00031179, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M", kIpomoea␉},␊ |
842 | ␉{ 0x6760,␉0x04C11028, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M", kIpomoea␉},␊ |
843 | ␉{ 0x6760,␉0x04CA1028, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M", kIpomoea␉},␊ |
844 | ␉{ 0x6760,␉0x04CC1028, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M", kIpomoea␉},␊ |
845 | ␉{ 0x6760,␉0x101C1043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M", kIpomoea␉},␊ |
846 | ␉{ 0x6760,␉0x165A103C, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6470M", kIpomoea␉},␊ |
847 | ␉{ 0x6760,␉0x167D103C, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6470M", kIpomoea␉},␊ |
848 | ␉{ 0x6760,␉0x1CB21043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6470M", kIpomoea␉},␊ |
849 | ␉{ 0x6760,␉0x20011043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6470M", kIpomoea␉},␊ |
850 | ␉{ 0x6760,␉0x85171043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 7470M", kNull␉␉},␊ |
851 | ␊ |
852 | ␉{ 0x6779,␉0x00001002, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
853 | ␉{ 0x6779,␉0x03DA1043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
854 | ␉{ 0x6779,␉0x03DC1043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
855 | ␉{ 0x6779,␉0x20121787, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
856 | ␉{ 0x6779,␉0x21201028, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
857 | ␉{ 0x6779,␉0x21251462, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
858 | ␉{ 0x6779,␉0x22031458, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
859 | ␉{ 0x6779,␉0x22041458, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
860 | ␉{ 0x6779,␉0x23111787, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
861 | ␉{ 0x6779,␉0x32001682, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
862 | ␉{ 0x6779,␉0x64501092, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
863 | ␉{ 0x6779,␉0x909D1B0A, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
864 | ␉{ 0x6779,␉0xE164174B, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kIpomoea␉},␊ |
865 | ␉{ 0x6779,␉0xE180174B, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kPithecia␉},␊ |
866 | ␉{ 0x6779,␉0xE190174B, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
867 | ␉{ 0x6779,␉0xE199174B, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉},␊ |
868 | ␊ |
869 | ␉/* Southen Islands */␊ |
870 | ␊ |
871 | ␉{ 0x6798,␉0x04181043, CHIP_FAMILY_TAHITI,␉␉"Asus HD7970 7970", kAji },␊ |
872 | ␉{ 0x6798,␉0x04201043, CHIP_FAMILY_TAHITI,␉␉"Asus HD7970 7970", kAji␉},␊ |
873 | ␉{ 0x6798,␉0x044A1043, CHIP_FAMILY_TAHITI,␉␉"Asus HD7970 7970", kAji␉},␊ |
874 | ␉{ 0x6798,␉0x044C1043, CHIP_FAMILY_TAHITI,␉␉"Asus HD7970 7970", kAji␉},␊ |
875 | ␉{ 0x6798,␉0x044E1043, CHIP_FAMILY_TAHITI,␉␉"Asus HD7970 7970", kAji␉},␊ |
876 | ␉{ 0x6798,␉0x0B001002, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
877 | ␉{ 0x6798,␉0x201C1787, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
878 | ␉{ 0x6798,␉0x23171787, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
879 | ␉{ 0x6798,␉0x254D1458, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
880 | ␉{ 0x6798,␉0x27701462, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
881 | ␉{ 0x6798,␉0x30001002, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
882 | ␉{ 0x6798,␉0x32101682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
883 | ␉{ 0x6798,␉0x32111682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
884 | ␉{ 0x6798,␉0x32121682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji },␊ |
885 | ␉{ 0x6798,␉0x32131682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
886 | ␉{ 0x6798,␉0xE208174B, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kAji␉},␊ |
887 | ␊ |
888 | ␉{ 0x679A,␉0x0B001002, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kAji␉},␊ |
889 | ␉{ 0x679A,␉0x0B011002, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 8900", kAji␉},␊ |
890 | ␉{ 0x679A,␉0x23161787, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kAji␉},␊ |
891 | ␉{ 0x679A,␉0x254C1458, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kAji␉},␊ |
892 | ␉{ 0x679A,␉0x27601462, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kAji␉},␊ |
893 | ␉{ 0x679A,␉0x32211682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kAji␉},␊ |
894 | ␉{ 0x679A,␉0x6616103C, CHIP_FAMILY_TAHITI,␉␉"HP Radeon HD 7950", kAji␉},␊ |
895 | ␉{ 0x679A,␉0xE207174B, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kAji␉},␊ |
896 | ␊ |
897 | ␉{ 0x6818,␉0x042F1043, CHIP_FAMILY_TAHITI,␉␉"Asus HD 7870", kAji␉␉},␊ |
898 | ␉{ 0x6818,␉0x04311043, CHIP_FAMILY_TAHITI,␉␉"Asus HD 7870", kAji␉␉},␊ |
899 | ␉{ 0x6818,␉0x0B041002, CHIP_FAMILY_TAHITI,␉␉"ATI Radeon HD 7870", kAji␉␉},␊ |
900 | ␉{ 0x6818,␉0x0B051002, CHIP_FAMILY_TAHITI,␉␉"ATI Radeon HD 8800", kAji␉␉},␊ |
901 | ␉{ 0x6818,␉0x201C1787, CHIP_FAMILY_TAHITI,␉␉"ATI Radeon HD 7870", kAji␉␉},␊ |
902 | ␉{ 0x6818,␉0x23211787, CHIP_FAMILY_TAHITI,␉␉"ATI Radeon HD 7870", kAji␉␉},␊ |
903 | ␉{ 0x6818,␉0x25541458, CHIP_FAMILY_TAHITI,␉␉"Gigabyte HD 7870", kAji␉␉},␊ |
904 | ␉{ 0x6818,␉0x27401462, CHIP_FAMILY_TAHITI,␉␉"ATI Radeon HD 7870", kAji␉␉},␊ |
905 | ␉{ 0x6818,␉0x32501682, CHIP_FAMILY_TAHITI,␉␉"ATI Radeon HD 7870", kAji␉␉},␊ |
906 | ␉{ 0x6818,␉0xE217174B, CHIP_FAMILY_TAHITI,␉␉"ATI Radeon HD 7870", kAji␉␉},␊ |
907 | ␊ |
908 | ␉{ 0x6819,␉0x04311043, CHIP_FAMILY_TAHITI,␉␉"Asus HD 7850", kAji␉␉}, // Asus␊ |
909 | ␉{ 0x6819,␉0x04331043, CHIP_FAMILY_TAHITI,␉␉"Asus HD 7850", kAji␉␉}, // Asus␊ |
910 | ␉{ 0x6819,␉0x0B041002, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7850", kAji␉␉}, // ATI␊ |
911 | ␉{ 0x6819,␉0x201C1787, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7850", kAji␉␉}, // HIS␊ |
912 | ␉{ 0x6819,␉0x23201787, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7850", kAji␉␉}, // HIS␊ |
913 | ␉{ 0x6819,␉0x25531458, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7850", kAji␉␉}, // Gigabyte␊ |
914 | ␉{ 0x6819,␉0x32601682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7850", kAji␉␉}, // XFX␊ |
915 | ␉{ 0x6819,␉0xE218174B, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7850", kAji␉␉}, // Sapphire␊ |
916 | ␊ |
917 | ␉{ 0x682F,␉0x15271043, CHIP_FAMILY_TAHITI,␉␉"Asus Radeon HD 7700M", kAji␉␉},␊ |
918 | ␉{ 0x682F,␉0x1831103C, CHIP_FAMILY_TAHITI,␉␉"HP Radeon HD 7730M", kAji␉␉},␊ |
919 | ␉{ 0x682F,␉0x1832103C, CHIP_FAMILY_TAHITI,␉␉"HP Radeon HD 7730M", kAji␉␉},␊ |
920 | ␉{ 0x682F,␉0x1834103C, CHIP_FAMILY_TAHITI,␉␉"HP Radeon HD 7730M", kAji␉␉},␊ |
921 | ␉{ 0x682F,␉0x18A7103C, CHIP_FAMILY_TAHITI,␉␉"HP Radeon HD 7730M", kAji␉␉},␊ |
922 | ␉{ 0x682F,␉0xC0DA144D, CHIP_FAMILY_TAHITI,␉␉"Samsung Radeon HD 7730M", kAji␉␉},␊ |
923 | ␊ |
924 | ␉{ 0x683D,␉0x04211043, CHIP_FAMILY_TAHITI,␉␉"Asus Radeon HD 7770", kAji␉␉},␊ |
925 | ␉{ 0x683D,␉0x23041002, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7700", kAji␉␉},␊ |
926 | ␉{ 0x683D,␉0x25561458, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7770", kAji␉␉},␊ |
927 | ␉{ 0x683D,␉0x27101462, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7770", kAji␉␉},␊ |
928 | ␉{ 0x683D,␉0x2B301002, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7770", kAji␉␉},␊ |
929 | ␉{ 0x683D,␉0x32331682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7770", kAji␉␉},␊ |
930 | ␉{ 0x683D,␉0x6886103C, CHIP_FAMILY_TAHITI,␉␉"HP Radeon HD 7700", kAji␉␉},␊ |
931 | ␉{ 0x683D,␉0xE214174B, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7770", kAji␉␉},␊ |
932 | ␊ |
933 | ␉{ 0x683F,␉0x04231043, CHIP_FAMILY_TAHITI,␉␉"Asus HD 7750", kChutoro␉␉},␊ |
934 | ␉{ 0x683F,␉0x04271043, CHIP_FAMILY_TAHITI,␉␉"Asus HD 7750", kChutoro␉␉},␊ |
935 | ␉{ 0x683F,␉0x04591043, CHIP_FAMILY_TAHITI,␉␉"Asus HD 7750", kChutoro␉␉},␊ |
936 | ␉{ 0x683F,␉0x200B1787, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7750", kChutoro␉␉},␊ |
937 | ␉{ 0x683F,␉0x23181787, CHIP_FAMILY_TAHITI,␉␉"Vertex3D HD 7750", kChutoro␉␉},␊ |
938 | ␉{ 0x683F,␉0x25511458, CHIP_FAMILY_TAHITI,␉␉"Gigabyte HD 7750", kChutoro␉␉},␊ |
939 | ␉{ 0x683F,␉0x27921462, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7750", kChutoro␉␉},␊ |
940 | ␉{ 0x683F,␉0x2B301002, CHIP_FAMILY_TAHITI,␉␉"Ati HD 7750", kChutoro␉␉},␊ |
941 | ␉{ 0x683F,␉0x32411682, CHIP_FAMILY_TAHITI,␉␉"XFX HD 7750", kChutoro␉␉},␊ |
942 | ␉{ 0x683F,␉0x32421682, CHIP_FAMILY_TAHITI,␉␉"XFX HD 7750", kChutoro␉␉},␊ |
943 | ␉{ 0x683F,␉0x32451682, CHIP_FAMILY_TAHITI,␉␉"XFX HD 7750", kChutoro␉␉},␊ |
944 | ␉{ 0x683F,␉0xE2131019, CHIP_FAMILY_TAHITI,␉␉"Diamond HD 7750", kChutoro␉␉},␊ |
945 | ␉{ 0x683F,␉0xE213174B, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7750", kChutoro␉␉},␊ |
946 | ␉{ 0x683F,␉0xE215174B, CHIP_FAMILY_TAHITI,␉␉"Sapphire HD 7750", kChutoro␉␉},␊ |
947 | ␊ |
948 | ␉{ 0x6840,␉0x01241002, CHIP_FAMILY_LOMBOK,␉␉"AMD Radeon HD 7600M Series", kPondweed },␊ |
949 | ␉{ 0x6840,␉0x01341002, CHIP_FAMILY_LOMBOK,␉␉"AMD Radeon HD 7600M Series", kPondweed },␊ |
950 | ␉{ 0x6840,␉0x050E1025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
951 | ␉{ 0x6840,␉0x050F1025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
952 | ␉{ 0x6840,␉0x05131025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
953 | ␉{ 0x6840,␉0x05141025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
954 | ␉{ 0x6840,␉0x056D1025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
955 | ␉{ 0x6840,␉0x059A1025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
956 | ␉{ 0x6840,␉0x059B1025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
957 | ␉{ 0x6840,␉0x059E1025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
958 | ␉{ 0x6840,␉0x06001025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
959 | ␉{ 0x6840,␉0x06061025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
960 | ␉{ 0x6840,␉0x06961025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
961 | ␉{ 0x6840,␉0x06971025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
962 | ␉{ 0x6840,␉0x06981025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
963 | ␉{ 0x6840,␉0x06991025, CHIP_FAMILY_LOMBOK,␉␉"Acer HD 7670M", kPondweed },␊ |
964 | ␉{ 0x6840,␉0x100A1043, CHIP_FAMILY_LOMBOK,␉␉"Asus HD 7670M", kPondweed },␊ |
965 | ␉{ 0x6840,␉0x104B1043, CHIP_FAMILY_LOMBOK,␉␉"Asus HD 7670M", kPondweed },␊ |
966 | ␉{ 0x6840,␉0x10DC1043, CHIP_FAMILY_LOMBOK,␉␉"Asus HD 7670M", kPondweed },␊ |
967 | ␉{ 0x6840,␉0x1813103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7590M", kPondweed },␊ |
968 | ␉{ 0x6840,␉0x182F103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
969 | ␉{ 0x6840,␉0x1830103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
970 | ␉{ 0x6840,␉0x1835103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
971 | ␉{ 0x6840,␉0x183A103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
972 | ␉{ 0x6840,␉0x183C103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
973 | ␉{ 0x6840,␉0x183E103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
974 | ␉{ 0x6840,␉0x1840103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
975 | ␉{ 0x6840,␉0x1842103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
976 | ␉{ 0x6840,␉0x1844103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
977 | ␉{ 0x6840,␉0x1848103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
978 | ␉{ 0x6840,␉0x184A103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
979 | ␉{ 0x6840,␉0x184C103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
980 | ␉{ 0x6840,␉0x1895103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
981 | ␉{ 0x6840,␉0x1897103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
982 | ␉{ 0x6840,␉0x18A5103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
983 | ␉{ 0x6840,␉0x18A7103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
984 | ␉{ 0x6840,␉0x18F4103C, CHIP_FAMILY_LOMBOK,␉␉"HP HD 7670M", kPondweed },␊ |
985 | ␉{ 0x6840,␉0x21211043, CHIP_FAMILY_LOMBOK,␉␉"Asus HD 7670M", kPondweed },␊ |
986 | ␉{ 0x6840,␉0x21221043, CHIP_FAMILY_LOMBOK,␉␉"Asus HD 7670M", kPondweed },␊ |
987 | ␉{ 0x6840,␉0x21231043, CHIP_FAMILY_LOMBOK,␉␉"Asus HD 7670M", kPondweed },␊ |
988 | ␉{ 0x6840,␉0x21251043, CHIP_FAMILY_LOMBOK,␉␉"Asus HD 7670M", kPondweed },␊ |
989 | ␉{ 0x6840,␉0x21271043, CHIP_FAMILY_LOMBOK,␉␉"Asus HD 7670M", kPondweed },␊ |
990 | ␉{ 0x6840,␉0x397017AA, CHIP_FAMILY_LOMBOK,␉␉"Lenovo HD 7670M", kPondweed },␊ |
991 | ␉{ 0x6840,␉0x397B17AA, CHIP_FAMILY_LOMBOK,␉␉"Lenovo HD 7670M", kPondweed },␊ |
992 | ␉{ 0x6840,␉0xC0C5144D, CHIP_FAMILY_LOMBOK,␉␉"Samsung HD 6000M series", kPondweed },␊ |
993 | ␉{ 0x6840,␉0xC0CE144D, CHIP_FAMILY_LOMBOK,␉␉"Samsung HD 7670M", kPondweed },␊ |
994 | ␉{ 0x6840,␉0xC0DA144D, CHIP_FAMILY_LOMBOK,␉␉"Samsung HD 7670M", kPondweed },␊ |
995 | ␉{ 0x6840,␉0xFB111179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
996 | ␉{ 0x6840,␉0xFB221179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
997 | ␉{ 0x6840,␉0xFB231179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
998 | ␉{ 0x6840,␉0xFB2C1179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
999 | ␉{ 0x6840,␉0xFB311179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1000 | ␉{ 0x6840,␉0xFB321179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1001 | ␉{ 0x6840,␉0xFB381179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1002 | ␉{ 0x6840,␉0xFB391179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1003 | ␉{ 0x6840,␉0xFB3A1179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1004 | ␉{ 0x6840,␉0xFB401179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1005 | ␉{ 0x6840,␉0xFB411179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1006 | ␉{ 0x6840,␉0xFB471179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1007 | ␉{ 0x6840,␉0xFB481179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1008 | ␉{ 0x6840,␉0xFB511179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1009 | ␉{ 0x6840,␉0xFB521179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1010 | ␉{ 0x6840,␉0xFB531179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1011 | ␉{ 0x6840,␉0xFB811179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1012 | ␉{ 0x6840,␉0xFB821179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1013 | ␉{ 0x6840,␉0xFB831179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1014 | ␉{ 0x6840,␉0xFC561179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1015 | ␉{ 0x6840,␉0xFCD41179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1016 | ␉{ 0x6840,␉0xFCEE1179, CHIP_FAMILY_LOMBOK,␉␉"Toshiba HD 7670M", kPondweed },␊ |
1017 | ␊ |
1018 | ␉/*old series*/␊ |
1019 | ␊ |
1020 | ␉{ 0x5D48,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Mobile ", kNull␉␉ },␊ |
1021 | ␉{ 0x5D49,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Mobile ", kNull␉␉ },␊ |
1022 | ␉{ 0x5D4A,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Mobile ", kNull␉␉ },␊ |
1023 | ␊ |
1024 | ␉{ 0x5D4C,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1025 | ␉{ 0x5D4D,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1026 | ␉{ 0x5D4E,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1027 | ␉{ 0x5D4F,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1028 | ␉{ 0x5D50,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1029 | ␊ |
1030 | ␉{ 0x5D52,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1031 | ␊ |
1032 | ␉{ 0x5D57,␉0x00000000, CHIP_FAMILY_R420,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1033 | ␊ |
1034 | ␉{ 0x5E48,␉0x00000000, CHIP_FAMILY_RV410,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1035 | ␊ |
1036 | ␉{ 0x5E4A,␉0x00000000, CHIP_FAMILY_RV410,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1037 | ␉{ 0x5E4B,␉0x00000000, CHIP_FAMILY_RV410,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1038 | ␉{ 0x5E4C,␉0x00000000, CHIP_FAMILY_RV410,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1039 | ␉{ 0x5E4D,␉0x00000000, CHIP_FAMILY_RV410,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1040 | ␊ |
1041 | ␉{ 0x5E4F,␉0x00000000, CHIP_FAMILY_RV410,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1042 | ␊ |
1043 | ␉{ 0x7100,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1044 | ␉{ 0x7101,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Mobile ", kNull␉␉ },␊ |
1045 | ␉{ 0x7102,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Mobile ", kNull␉␉ },␊ |
1046 | ␉{ 0x7103,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Mobile ", kNull␉␉ },␊ |
1047 | ␉{ 0x7104,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1048 | ␉{ 0x7105,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1049 | ␉{ 0x7106,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Mobile ", kNull␉␉ },␊ |
1050 | ␉{ 0x7108,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1051 | ␉{ 0x7109,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1052 | ␉{ 0x710A,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1053 | ␉{ 0x710B,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1054 | ␉{ 0x710C,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1055 | ␊ |
1056 | ␉{ 0x710E,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1057 | ␉{ 0x710F,␉0x00000000, CHIP_FAMILY_R520,␉␉"ATI Radeon HD Desktop ", kNull␉␉ },␊ |
1058 | ␊ |
1059 | ␉{ 0x7140,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1060 | ␉{ 0x7141,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1061 | ␉{ 0x7142,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1062 | ␉{ 0x7143,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1063 | ␉{ 0x7144,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1064 | ␉{ 0x7145,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1065 | ␉{ 0x7146,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1066 | ␉{ 0x7147,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1067 | ␊ |
1068 | ␉{ 0x7149,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1069 | ␉{ 0x714A,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1070 | ␉{ 0x714B,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1071 | ␉{ 0x714C,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1072 | ␉{ 0x714D,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1073 | ␉{ 0x714E,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1074 | ␉{ 0x714F,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1075 | ␊ |
1076 | ␉{ 0x7151,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1077 | ␉{ 0x7152,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1078 | ␉{ 0x7153,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1079 | ␊ |
1080 | ␉{ 0x715E,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1081 | ␉{ 0x715F,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1082 | ␊ |
1083 | ␉{ 0x7180,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1084 | ␉{ 0x7181,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1085 | ␉{ 0x7183,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1086 | ␊ |
1087 | ␉{ 0x7186,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1088 | ␉{ 0x7187,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1089 | ␉{ 0x7188,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1090 | ␊ |
1091 | ␉{ 0x718A,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1092 | ␉{ 0x718B,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1093 | ␉{ 0x718C,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1094 | ␉{ 0x718D,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1095 | ␊ |
1096 | ␉{ 0x718F,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1097 | ␊ |
1098 | ␉{ 0x7193,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1099 | ␊ |
1100 | ␉{ 0x7196,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Mobile ", kCaretta␉␉ },␊ |
1101 | ␊ |
1102 | ␉{ 0x719B,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1103 | ␊ |
1104 | ␉{ 0x719F,␉0x00000000, CHIP_FAMILY_RV515,␉␉"ATI Radeon HD Desktop ", kCaretta␉␉ },␊ |
1105 | ␊ |
1106 | ␉{ 0x71C0,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1107 | ␉{ 0x71C1,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1108 | ␉{ 0x71C2,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1109 | ␉{ 0x71C3,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1110 | ␉{ 0x71C4,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Mobile ", kWormy␉␉ },␊ |
1111 | ␊ |
1112 | ␉{ 0x71C5,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Mobile ", kWormy␉␉ },␊ |
1113 | ␉{ 0x71C6,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1114 | ␉{ 0x71C7,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1115 | ␊ |
1116 | ␉{ 0x71CD,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1117 | ␉{ 0x71CE,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1118 | ␊ |
1119 | ␉{ 0x71D2,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1120 | ␊ |
1121 | ␉{ 0x71D4,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Mobile ", kWormy␉␉ },␊ |
1122 | ␉{ 0x71D5,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Mobile ", kWormy␉␉ },␊ |
1123 | ␉{ 0x71D6,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Mobile ", kWormy␉␉ },␊ |
1124 | ␊ |
1125 | ␉{ 0x71DA,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1126 | ␊ |
1127 | ␉{ 0x71DE,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ASUS M66 ATI Radeon Mobile ", kWormy␉␉ },␊ |
1128 | ␊ |
1129 | ␉{ 0x7200,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Desktop ", kWormy␉␉ },␊ |
1130 | ␊ |
1131 | ␉{ 0x7210,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Mobile ", kWormy␉␉ },␊ |
1132 | ␉{ 0x7211,␉0x00000000, CHIP_FAMILY_RV530,␉␉"ATI Radeon HD Mobile ", kWormy␉␉ },␊ |
1133 | ␊ |
1134 | ␉{ 0x7240,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1135 | ␊ |
1136 | ␉{ 0x7243,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1137 | ␉{ 0x7244,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1138 | ␉{ 0x7245,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1139 | ␉{ 0x7246,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1140 | ␉{ 0x7247,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1141 | ␉{ 0x7248,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1142 | ␉{ 0x7249,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1143 | ␉{ 0x724A,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1144 | ␉{ 0x724B,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1145 | ␉{ 0x724C,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1146 | ␉{ 0x724D,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1147 | ␉{ 0x724E,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1148 | ␉{ 0x724F,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1149 | ␊ |
1150 | ␉{ 0x7280,␉0x00000000, CHIP_FAMILY_RV570,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1151 | ␉{ 0x7281,␉0x00000000, CHIP_FAMILY_RV560,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1152 | ␉{ 0x7283,␉0x00000000, CHIP_FAMILY_RV560,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1153 | ␉{ 0x7284,␉0x00000000, CHIP_FAMILY_R580,␉␉"ATI Radeon HD Mobile ", kAlopias␉␉ },␊ |
1154 | ␊ |
1155 | ␉{ 0x7287,␉0x00000000, CHIP_FAMILY_RV560,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1156 | ␉{ 0x7288,␉0x00000000, CHIP_FAMILY_RV570,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1157 | ␉{ 0x7289,␉0x00000000, CHIP_FAMILY_RV570,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1158 | ␊ |
1159 | ␉{ 0x728B,␉0x00000000, CHIP_FAMILY_RV570,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1160 | ␉{ 0x728C,␉0x00000000, CHIP_FAMILY_RV570,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1161 | ␊ |
1162 | ␉{ 0x7290,␉0x00000000, CHIP_FAMILY_RV560,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1163 | ␉{ 0x7291,␉0x00000000, CHIP_FAMILY_RV560,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1164 | ␊ |
1165 | ␉{ 0x7293,␉0x00000000, CHIP_FAMILY_RV560,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1166 | ␊ |
1167 | ␉{ 0x7297,␉0x00000000, CHIP_FAMILY_RV560,␉␉"ATI Radeon HD Desktop ", kAlopias␉␉ },␊ |
1168 | ␊ |
1169 | ␉/* IGP */␊ |
1170 | ␊ |
1171 | ␉{ 0x791E,␉0x00000000, CHIP_FAMILY_RS690,␉␉"ATI Radeon IGP ", kNull␉␉␉},␊ |
1172 | ␉{ 0x791F,␉0x00000000, CHIP_FAMILY_RS690,␉␉"ATI Radeon IGP ", kNull␉␉␉},␊ |
1173 | ␉{ 0x796C,␉0x00000000, CHIP_FAMILY_RS740,␉␉"ATI Radeon IGP ", kNull␉␉␉},␊ |
1174 | ␉{ 0x796D,␉0x00000000, CHIP_FAMILY_RS740,␉␉"ATI Radeon IGP ", kNull␉␉␉},␊ |
1175 | ␉{ 0x796E,␉0x00000000, CHIP_FAMILY_RS740,␉␉"ATI Radeon IGP ", kNull␉␉␉},␊ |
1176 | ␉{ 0x796F,␉0x00000000, CHIP_FAMILY_RS740,␉␉"ATI Radeon IGP ", kNull␉␉␉},␊ |
1177 | ␊ |
1178 | ␉/* standard/default models */␊ |
1179 | ␊ |
1180 | ␉{ 0x9400,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 XT", kNull␉␉},␊ |
1181 | ␉{ 0x9401,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 GT", kNull␉␉},␊ |
1182 | ␉{ 0x9402,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 GT", kNull␉␉},␊ |
1183 | ␉{ 0x9403,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 GT", kNull␉␉},␊ |
1184 | ␉{ 0x9405,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 GT", kNull␉␉},␊ |
1185 | ␉{ 0x940A,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 GT", kNull␉␉},␊ |
1186 | ␉{ 0x940B,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 GT", kNull␉␉},␊ |
1187 | ␉{ 0x940F,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 GT", kNull␉␉},␊ |
1188 | ␊ |
1189 | ␉{ 0x9440,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉kMotmot␉␉},␊ |
1190 | ␉{ 0x9441,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870 X2", kMotmot␉␉},␊ |
1191 | ␉{ 0x9442,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉kMotmot␉␉},␊ |
1192 | ␉{ 0x9443,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850 X2", kMotmot␉␉},␊ |
1193 | ␉{ 0x9444,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI FirePro V8750 (FireGL)", kMotmot␉␉},␊ |
1194 | ␉{ 0x9446,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI FirePro V7770 (FireGL)",␉␉kMotmot␉␉},␊ |
1195 | ␉{ 0x9447,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI FirePro V8700 Duo (FireGL)",␉kMotmot␉␉},␊ |
1196 | ␉{ 0x944A,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Mobility Radeon HD 4850",␉␉kMotmot␉␉},␊ |
1197 | ␉{ 0x944B,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Mobility Radeon HD 4850 X2",␉kMotmot␉␉},␊ |
1198 | ␉{ 0x944C,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4830 Series",␉␉kMotmot␉␉},␊ |
1199 | ␉{ 0x944E,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4810 Series",␉␉kMotmot␉␉},␊ |
1200 | ␊ |
1201 | ␉{ 0x9450,␉0x00000000, CHIP_FAMILY_RV770,␉␉"AMD FireStream 9270", kMotmot␉␉},␊ |
1202 | ␉{ 0x9452,␉0x00000000, CHIP_FAMILY_RV770,␉␉"AMD FireStream 9250", kMotmot␉␉},␊ |
1203 | ␊ |
1204 | ␉{ 0x9456,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI FirePro V8700 (FireGL)",␉␉kMotmot␉␉},␊ |
1205 | ␉{ 0x945A,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Mobility Radeon HD 4870",␉␉kMotmot␉␉},␊ |
1206 | ␊ |
1207 | ␉{ 0x9460,␉0x00000000, CHIP_FAMILY_RV790,␉␉"ATI Radeon HD 4800 Series",␉␉kMotmot␉␉},␊ |
1208 | ␉{ 0x9462,␉0x00000000, CHIP_FAMILY_RV790,␉␉"ATI Radeon HD 4800 Series",␉␉kMotmot␉␉},␊ |
1209 | ␊ |
1210 | ␉{ 0x9480,␉0x00000000, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650 Series",␉␉kGliff␉␉},␊ |
1211 | ␊ |
1212 | ␉{ 0x9488,␉0x00000000, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650 Series",␉␉kGliff␉␉},␊ |
1213 | ␊ |
1214 | ␉{ 0x9490,␉0x00000000, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4710 Series",␉␉kGliff␉␉},␊ |
1215 | ␉{ 0x9491,␉0x00000000, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600 Series",␉␉kGliff␉␉},␊ |
1216 | ␉{ 0x9495,␉0x00000000, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650 Series",␉␉kGliff␉␉},␊ |
1217 | ␊ |
1218 | ␉{ 0x9498,␉0x00000000, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4710 Series",␉␉kGliff␉␉},␊ |
1219 | ␊ |
1220 | ␉{ 0x94B3,␉0x00000000, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770", kFlicker␉},␊ |
1221 | ␉{ 0x94B4,␉0x00000000, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4700 Series",␉␉kFlicker␉},␊ |
1222 | ␉{ 0x94B5,␉0x00000000, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770", kFlicker␉},␊ |
1223 | ␊ |
1224 | ␉{ 0x94C1,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series", kIago␉␉},␊ |
1225 | ␊ |
1226 | ␉{ 0x94C3,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350 Series", kIago␉␉},␊ |
1227 | ␊ |
1228 | ␉{ 0x94C4,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series", kIago␉␉},␊ |
1229 | ␉{ 0x94C5,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series", kIago␉␉},␊ |
1230 | ␉{ 0x94C6,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series", kIago␉␉},␊ |
1231 | ␉{ 0x94C7,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350", kIago␉␉},␊ |
1232 | ␉{ 0x94C8,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series", kIago␉␉},␊ |
1233 | ␉{ 0x94C9,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series", kIago␉␉},␊ |
1234 | ␊ |
1235 | ␉{ 0x94CB,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series", kIago␉␉},␊ |
1236 | ␉{ 0x94CC,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series", kIago␉␉},␊ |
1237 | ␊ |
1238 | ␉{ 0x9500,␉0x00000000, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3800 Series", kMegalodon␉},␊ |
1239 | ␉{ 0x9501,␉0x00000000, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3690 Series", kMegalodon␉},␊ |
1240 | ␊ |
1241 | ␉{ 0x9505,␉0x00000000, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3800 Series", kMegalodon␉},␊ |
1242 | ␊ |
1243 | ␉{ 0x9507,␉0x00000000, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3830", kMegalodon␉},␊ |
1244 | ␊ |
1245 | ␉{ 0x950F,␉0x00000000, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3870 X2", kMegalodon␉},␊ |
1246 | ␊ |
1247 | ␉{ 0x9511,␉0x00000000, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3850 X2", kMegalodon␉},␊ |
1248 | ␊ |
1249 | ␉{ 0x9513,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3850 X2", kMegalodon␉},␊ |
1250 | ␊ |
1251 | ␉{ 0x9519,␉0x00000000, CHIP_FAMILY_RV670,␉␉"AMD FireStream 9170", kMegalodon␉},␊ |
1252 | ␊ |
1253 | ␉{ 0x9540,␉0x00000000, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4550", kFlicker␉},␊ |
1254 | ␉{ 0x954F,␉0x00000000, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4350",␉␉␉kFlicker␉},␊ |
1255 | ␊ |
1256 | ␉{ 0x9552,␉0x00000000, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4300/4500 Series",␉kShrike␉␉},␊ |
1257 | ␉{ 0x9553,␉0x00000000, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500M/5100M Series",␉kShrike␉␉},␊ |
1258 | ␊ |
1259 | ␉{ 0x9555,␉0x00000000, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD4300/HD4500 series",␉␉kShrike␉␉}, ␊ |
1260 | ␊ |
1261 | ␉{ 0x9581,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kHypoprion␉},␊ |
1262 | ␊ |
1263 | ␉{ 0x9583,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kHypoprion␉},␊ |
1264 | ␊ |
1265 | ␉{ 0x9588,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600 XT",␉␉␉kHypoprion␉},␊ |
1266 | ␉{ 0x9589,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3610 Series",␉␉␉kHypoprion␉},␊ |
1267 | ␉{ 0x958A,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600 X2 Series",␉␉␉kLamna␉␉},␊ |
1268 | ␉{ 0x958B,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600 X2 Series",␉␉␉kLamna␉␉},␊ |
1269 | ␉{ 0x958C,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600 X2 Series",␉␉␉kLamna␉␉},␊ |
1270 | ␉{ 0x958D,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600 X2 Series",␉␉␉kLamna␉␉},␊ |
1271 | ␉{ 0x958E,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600 X2 Series",␉␉␉kLamna␉␉},␊ |
1272 | ␊ |
1273 | ␉{ 0x9591,␉0x00000000, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3600 Series",␉␉␉kMegalodon␉␉},␊ |
1274 | ␊ |
1275 | ␉{ 0x9598,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kMegalodon␉},␊ |
1276 | ␊ |
1277 | ␉{ 0x95C0,␉0x00000000, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3400 Series",␉␉␉kIago␉␉},␊ |
1278 | ␊ |
1279 | ␉{ 0x95C5,␉0x00000000, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3400 Series",␉␉␉kIago␉␉},␊ |
1280 | ␊ |
1281 | ␉/* IGP */␊ |
1282 | ␉{ 0x9610,␉0x00000000, CHIP_FAMILY_RS780,␉␉"ATI Radeon HD 3200 Graphics",␉␉␉kNull␉␉},␊ |
1283 | ␉{ 0x9611,␉0x00000000, CHIP_FAMILY_RS780,␉␉"ATI Radeon 3100 Graphics", ␉kNull␉␉},␊ |
1284 | ␊ |
1285 | ␉{ 0x9614,␉0x00000000, CHIP_FAMILY_RS780,␉␉"ATI Radeon HD 3300 Graphics",␉␉␉kNull␉␉},␊ |
1286 | ␊ |
1287 | ␉{ 0x9616,␉0x00000000, CHIP_FAMILY_RS780,␉␉"ATI Radeon 3000 Graphics", ␉kNull␉␉},␊ |
1288 | ␊ |
1289 | ␉{ 0x9710,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 4200 Series",␉␉␉kNull␉␉},␊ |
1290 | ␊ |
1291 | ␉{ 0x9714,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 4290 Series",␉␉␉kNull␉␉},␊ |
1292 | ␉{ 0x9715,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 4250 Series",␉␉␉kNull␉␉},␊ |
1293 | ␊ |
1294 | ␉{ 0x9723,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 5450 Series",␉␉␉kNull␉␉},␊ |
1295 | ␊ |
1296 | ␉{ 0x9802,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 6310 Series",␉␉␉kNull␉␉},␊ |
1297 | ␉{ 0x9803,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 6310 Series",␉␉␉kNull␉␉},␊ |
1298 | ␉{ 0x9804,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 6310 Series",␉␉␉kNull␉␉},␊ |
1299 | ␉{ 0x9805,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 6250 Series",␉␉␉kNull␉␉},␊ |
1300 | ␉{ 0x9806,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 6320 Series",␉␉␉kNull␉␉},␊ |
1301 | ␊ |
1302 | ␉/* Evergreen */␊ |
1303 | ␉{ 0x688D,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"AMD FireStream 9350 Series",␉␉␉kUakari␉␉},␊ |
1304 | ␊ |
1305 | ␉{ 0x6898,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5800 Series",␉␉␉kUakari␉␉},␊ |
1306 | ␉{ 0x6899,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5800 Series",␉␉␉kUakari␉␉},␊ |
1307 | ␊ |
1308 | //␉{ 0x689B,␉0x00000000, CHIP_FAMILY_???,␉␉"AMD Radeon HD 6800 Series",␉␉␉kNull␉␉},␊ |
1309 | ␉{ 0x689C,␉0x00000000, CHIP_FAMILY_HEMLOCK,␉"ATI Radeon HD 5900 Series",␉␉␉kUakari␉␉},␊ |
1310 | ␊ |
1311 | ␉{ 0x689E,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5800 Series",␉␉␉kUakari␉␉},␊ |
1312 | ␊ |
1313 | ␉{ 0x68A0,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Mobility Radeon HD 5800 Series", kNomascus␉}, // CHIP_FAMILY_BROADWAY ??␊ |
1314 | ␉{ 0x68A1,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Mobility Radeon HD 5800 Series", kNomascus␉}, // CHIP_FAMILY_BROADWAY ??␊ |
1315 | ␊ |
1316 | ␉{ 0x68A8,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"AMD Mobility Radeon HD 6800 Series", kUakari␉␉}, ␊ |
1317 | ␉{ 0x68A9,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI FirePro V5800 (FireGL)",␉␉␉kNull␉␉},␊ |
1318 | ␊ |
1319 | ␊ |
1320 | ␉{ 0x68B0,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5800 Series", kVervet␉␉}, // CHIP_FAMILY_BROADWAY ??␊ |
1321 | ␉{ 0x68B1,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770 Series",␉␉␉kVervet␉␉},␊ |
1322 | ␊ |
1323 | ␉{ 0x68B8,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5700 Series",␉␉␉kVervet␉␉},␊ |
1324 | ␉{ 0x68B9,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5600 Series",␉␉␉kVervet␉␉},␊ |
1325 | ␉{ 0x68BA,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6700 Series",␉␉␉kVervet␉␉},␊ |
1326 | ␊ |
1327 | ␉{ 0x68BE,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5700 Series",␉␉␉kVervet␉␉},␊ |
1328 | ␉{ 0x68BF,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6700 Series",␉␉␉kVervet␉␉},␊ |
1329 | ␊ |
1330 | ␉{ 0x68C0,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"AMD Radeon HD 6570M/5700 Series",␉␉kBaboon␉␉},␊ |
1331 | ␉{ 0x68C1,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"AMD Radeon HD 6500M/5600/5700 Series",␉␉kBaboon␉␉},␊ |
1332 | ␉{ 0x68C8,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5650 Series",␉␉␉kVervet␉␉},␉␊ |
1333 | ␉{ 0x68C9,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI FirePro V3800 (FireGL)",␉␉␉kBaboon␉␉},␊ |
1334 | ␊ |
1335 | ␉{ 0x68D8,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670 Series",␉␉␉kBaboon␉␉},␊ |
1336 | ␉{ 0x68D9,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5500/5600 Series",␉␉kBaboon␉␉},␊ |
1337 | ␉{ 0x68DA,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5500 Series",␉␉␉kBaboon␉␉},␊ |
1338 | ␊ |
1339 | //␉{ 0x68DE,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD ??? Series",␉␉␉kNull␉␉},␊ |
1340 | ␊ |
1341 | ␊ |
1342 | ␉{ 0x68E0,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5400 Series", kEulemur␉},␊ |
1343 | ␉{ 0x68E1,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5400 Series", kEulemur␉},␊ |
1344 | ␊ |
1345 | ␉{ 0x68E4,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6370M Series",␉␉␉kEulemur␉␉},␊ |
1346 | ␉{ 0x68E5,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6300M Series",␉␉␉kEulemur␉␉},␊ |
1347 | ␊ |
1348 | //␉{ 0x68E8,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD ??? Series",␉␉␉kNull␉␉},␊ |
1349 | //␉{ 0x68E9,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD ??? Series",␉␉␉kNull␉␉},␊ |
1350 | ␊ |
1351 | //␉{ 0x68F8,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD ??? Series",␉␉␉kNull␉␉},␊ |
1352 | ␉{ 0x68F9,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470 Series",␉␉␉kEulemur␉␉},␊ |
1353 | ␉{ 0x68FA,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 7300 Series",␉␉␉kNull␉␉},␊ |
1354 | ␊ |
1355 | //␉{ 0x68FE,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD ??? Series",␉␉␉kNull␉␉},␊ |
1356 | ␊ |
1357 | ␊ |
1358 | ␉/* Northen Islands */␊ |
1359 | ␉{ 0x6718,␉0x00000000, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970 Series",␉␉␉kLotus␉␉},␊ |
1360 | ␉{ 0x6719,␉0x00000000, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950 Series",␉␉␉kGibba␉␉},␊ |
1361 | ␊ |
1362 | ␉{ 0x671C,␉0x00000000, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970 Series",␉␉␉kLotus␉␉},␊ |
1363 | ␉{ 0x671D,␉0x00000000, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950 Series",␉␉␉kLotus␉␉},␊ |
1364 | ␊ |
1365 | ␉{ 0x671F,␉0x00000000, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6930 Series",␉␉␉kLotus␉␉},␊ |
1366 | ␊ |
1367 | ␉{ 0x6720,␉0x00000000, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6900M Series",␉␉␉kDuckweed␉␉},␊ |
1368 | ␊ |
1369 | ␉{ 0x6722,␉0x00000000, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6900M Series",␉␉␉kDuckweed␉␉},␊ |
1370 | ␉{ 0x6738,␉0x00000000, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870 Series",␉␉␉kDuckweed␉},␊ |
1371 | ␉{ 0x6739,␉0x00000000, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850 Series",␉␉␉kDuckweed␉},␊ |
1372 | ␊ |
1373 | ␉{ 0x673E,␉0x00000000, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790 Series",␉␉␉kDuckweed␉␉},␊ |
1374 | ␊ |
1375 | ␉{ 0x6740,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6770M Series",␉␉␉kPithecia␉␉},␊ |
1376 | ␉{ 0x6741,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6600M/6700M Series",␉␉kPithecia␉␉},␊ |
1377 | ␊ |
1378 | ␉{ 0x6745,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6600M Series",␉␉␉kPithecia␉␉},␊ |
1379 | ␉{ 0x6750,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6600A Series",␉␉␉kPithecia␉␉},␊ |
1380 | ␊ |
1381 | ␉{ 0x6758,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670 Series",␉␉␉kPithecia␉},␊ |
1382 | ␉{ 0x6759,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6570/7570 Series",␉␉kPithecia␉␉},␊ |
1383 | ␊ |
1384 | ␉{ 0x675D,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 7500 Series",␉␉␉kBulrushes␉␉},␊ |
1385 | ␊ |
1386 | ␉{ 0x675F,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 5500 Series",␉␉␉kBulrushes␉␉},␊ |
1387 | ␉{ 0x6760,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6400M Series",␉␉␉kBulrushes␉␉},␊ |
1388 | ␉{ 0x6761,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6430M Series",␉␉␉kBulrushes␉␉},␊ |
1389 | ␉{ 0x6768,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6400M Series",␉␉␉kBulrushes␉},␊ |
1390 | ␊ |
1391 | ␉{ 0x6770,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6400 Series",␉␉␉kBulrushes␉␉},␊ |
1392 | ␊ |
1393 | ␉{ 0x6772,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 7400A Series",␉␉␉kNull␉␉},␊ |
1394 | ␊ |
1395 | ␉{ 0x6778,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 7000 Series",␉␉␉kNull␉␉},␊ |
1396 | ␉{ 0x6779,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450 Series",␉␉␉kBulrushes␉},␊ |
1397 | ␊ |
1398 | ␉{ 0x677B,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 7400 Series",␉␉␉kNull␉␉},␊ |
1399 | ␊ |
1400 | ␉/* Southen Islands */␊ |
1401 | ␊ |
1402 | ␉{ 0x6780,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7900 Series", kDashimaki␉␉},␊ |
1403 | ␊ |
1404 | //␉{ 0x6784,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1405 | ␊ |
1406 | //␉{ 0x6788,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1407 | ␊ |
1408 | //␉{ 0x678A,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1409 | ␊ |
1410 | ␉{ 0x6790,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7900 Series", kDashimaki␉␉},␊ |
1411 | ␊ |
1412 | ␉{ 0x6798,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970 Series", kDashimaki␉␉},␊ |
1413 | ␉{ 0x6799,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7990 Series", kAji␉␉},␊ |
1414 | ␉{ 0x679A,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950 Series", kDashimaki␉␉},␊ |
1415 | ␊ |
1416 | //␉{ 0x679E,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1417 | //␉{ 0x679F,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1418 | ␊ |
1419 | ␉{ 0x6800,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970M Series", kDashimaki␉},␊ |
1420 | //␉{ 0x6801,␉0x00000000, CHIP_FAMILY_PITCAIRN,␉"AMD Radeon HD ???M Series", kNull␉␉},␊ |
1421 | //␉{ 0x6802,␉0x00000000, CHIP_FAMILY_PITCAIRN,␉"AMD Radeon HD ???M Series", kNull␉␉},␊ |
1422 | ␊ |
1423 | ␉{ 0x6806,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7600 Series", kDashimaki␉},␊ |
1424 | ␊ |
1425 | ␉{ 0x6808,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7600 Series", kDashimaki␉},␊ |
1426 | //␉{ 0x6809,␉0x00000000, CHIP_FAMILY_PITCAIRN,␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1427 | //␉{ 0x6810,␉0x00000000, CHIP_FAMILY_PITCAIRN,␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1428 | ␊ |
1429 | ␉{ 0x6818,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7800 Series", kDashimaki␉},␊ |
1430 | ␉{ 0x6819,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7800 Series", kDashimaki␉},␊ |
1431 | ␉{ 0x6820,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7800M Series", kDashimaki␉},␊ |
1432 | ␉{ 0x6821,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7800M Series", kDashimaki␉},␊ |
1433 | ␊ |
1434 | //␉{ 0x6823,␉0x00000000, CHIP_FAMILY_VERDE,␉␉"AMD Radeon HD ???M Series", kNull␉␉},␊ |
1435 | //␉{ 0x6824,␉0x00000000, CHIP_FAMILY_VERDE,␉␉"AMD Radeon HD 7700M Series", kNull␉␉},␊ |
1436 | ␉{ 0x6825,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7800M Series", kDashimaki␉},␊ |
1437 | //␉{ 0x6826,␉0x00000000, CHIP_FAMILY_VERDE,␉␉"AMD Radeon HD 7700M Series", kNull␉␉},␊ |
1438 | ␉{ 0x6827,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7800M Series", kDashimaki },␊ |
1439 | //␉{ 0x6828,␉0x00000000, CHIP_FAMILY_VERDE,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1440 | //␉{ 0x6829,␉0x00000000, CHIP_FAMILY_VERDE,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1441 | ␊ |
1442 | ␉{ 0x682D,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7700M Series", kDashimaki␉},␊ |
1443 | ␊ |
1444 | ␉{ 0x682F,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7700M Series", kDashimaki␉},␊ |
1445 | ␊ |
1446 | //␉{ 0x6830,␉0x00000000, CHIP_FAMILY_VERDE,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1447 | //␉{ 0x6831,␉0x00000000, CHIP_FAMILY_VERDE,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1448 | ␊ |
1449 | //␉{ 0x6837,␉0x00000000, CHIP_FAMILY_VERDE,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1450 | //␉{ 0x6838,␉0x00000000, CHIP_FAMILY_VERDE,␉␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1451 | ␉{ 0x6839,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7700 Series", kDashimaki␉},␊ |
1452 | ␊ |
1453 | ␉{ 0x683B,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7700 Series", kDashimaki␉},␊ |
1454 | ␊ |
1455 | ␉{ 0x683D,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7700 Series", kDashimaki␉},␊ |
1456 | ␊ |
1457 | ␉{ 0x683F,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7700 Series", kChutoro␉},␊ |
1458 | ␊ |
1459 | ␉{ 0x6840,␉0x00000000, CHIP_FAMILY_LOMBOK,␉␉"AMD Radeon HD 7600M Series", kPondweed },␊ |
1460 | //␉{ 0x6841,␉0x00000000, CHIP_FAMILY_THAMES,␉␉"AMD Radeon HD 7850 Series", kNull␉␉},␊ |
1461 | //␉{ 0x6842,␉0x00000000, CHIP_FAMILY_THAMES,␉␉"AMD Radeon HD 7000M Series", kNull␉␉},␊ |
1462 | //␉{ 0x6843,␉0x00000000, CHIP_FAMILY_THAMES,␉␉"AMD Radeon HD 7670M Series", kNull␉␉},␊ |
1463 | ␊ |
1464 | //␉{ 0x684C,␉0x00000000, CHIP_FAMILY_PITCAIRN,␉"AMD Radeon HD ??? Series", kNull␉␉},␊ |
1465 | ␊ |
1466 | ␉{ 0x0000,␉0x00000000, CHIP_FAMILY_UNKNOW,␉␉NULL,␉␉␉␉␉␉kNull␉␉}␊ |
1467 | };␊ |
1468 | ␊ |
1469 | static value_t aty_name;␊ |
1470 | static value_t aty_nameparent;␊ |
1471 | //static value_t aty_model;␊ |
1472 | ␊ |
1473 | dev_prop_t ati_devprop_list[] = {␊ |
1474 | ␉{FLAGTRUE,␉false,␉"@0,AAPL,boot-display",␉␉␉get_bootdisplay_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1475 | //␉{FLAGTRUE,␉false,␉"@0,ATY,EFIDisplay",␉␉␉NULL,␉␉␉STRVAL("TMDSA")␉␉␉␉␉␉␉},␊ |
1476 | ␊ |
1477 | //␉{FLAGTRUE,␉true,␉"@0,AAPL,vram-memory",␉␉␉get_vrammemory_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1478 | //␉{FLAGTRUE,␉true,␉"@0,compatible",␉␉␉get_name_val,␉␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1479 | //␉{FLAGTRUE,␉true,␉"@0,connector-type",␉␉␉get_conntype_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1480 | //␉{FLAGTRUE,␉true,␉"@0,device_type",␉␉␉NULL,␉␉␉STRVAL("display")␉␉␉␉␉␉},␊ |
1481 | //␉{FLAGTRUE,␉false,␉"@0,display-connect-flags",␉␉NULL,␉␉␉DWRVAL(0)␉␉␉␉␉␉},␊ |
1482 | //␉{FLAGTRUE,␉false,␉"@0,display-link-component-bits",␉NULL,␉␉␉DWRVAL(6)␉␉␉␉␉␉},␊ |
1483 | //␉{FLAGTRUE,␉true,␉"@0,display-type",␉␉␉NULL,␉␉␉STRVAL("NONE")␉␉␉␉␉␉␉},␊ |
1484 | ␉{FLAGTRUE,␉true,␉"@0,name",␉␉␉␉get_name_val,␉␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1485 | //␉{FLAGTRUE,␉true,␉"@0,VRAM,memsize",␉␉␉get_vrammemsize_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1486 | //␉{FLAGTRUE,␉true,␉"@0,ATY,memsize",␉␉␉get_vrammemsize_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1487 | ␊ |
1488 | //␉{FLAGTRUE,␉false,␉"AAPL,aux-power-connected",␉␉NULL,␉␉␉DWRVAL(1)␉␉␉␉␉␉},␊ |
1489 | //␉{FLAGTRUE,␉false,␉"AAPL,backlight-control",␉␉NULL,␉␉␉DWRVAL(0)␉␉␉␉␉␉},␊ |
1490 | //␉{FLAGTRUE,␉false,␉"AAPL,overwrite_binimage",␉␉get_binimage_owr,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1491 | ␉{FLAGTRUE,␉false,␉"ATY,bin_image",␉␉␉get_binimage_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1492 | ␉{FLAGTRUE,␉false,␉"ATY,Copyright",␉␉␉NULL,␉␉␉STRVAL("Copyright AMD Inc. All Rights Reserved. 2005-2012")␉},␊ |
1493 | //␉{FLAGTRUE,␉false,␉"ATY,EFIVersion",␉␉␉NULL,␉␉␉STRVAL("01.00.3180")␉␉␉␉␉␉},␊ |
1494 | ␉{FLAGTRUE,␉false,␉"ATY,Card#",␉␉␉␉get_romrevision_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1495 | ␉{FLAGTRUE,␉false,␉"ATY,VendorID",␉␉␉␉NULL,␉␉␉WRDVAL(0x1002)␉␉␉␉␉},␊ |
1496 | ␉{FLAGTRUE,␉false,␉"ATY,DeviceID",␉␉␉␉get_deviceid_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1497 | ␊ |
1498 | //␉{FLAGTRUE,␉false,␉"ATY,MCLK",␉␉␉␉get_mclk_val,␉␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1499 | //␉{FLAGTRUE,␉false,␉"ATY,SCLK",␉␉␉␉get_sclk_val,␉␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1500 | //␉{FLAGTRUE,␉false,␉"ATY,RefCLK",␉␉␉␉get_refclk_val,␉␉DWRVAL(0x0a8c)␉␉␉},␊ |
1501 | ␉␊ |
1502 | //␉{FLAGTRUE,␉false,␉"ATY,PlatformInfo",␉␉␉get_platforminfo_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1503 | ␊ |
1504 | ␉{FLAGTRUE,␉false,␉"name",␉␉␉␉␉get_nameparent_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1505 | ␉{FLAGTRUE,␉false,␉"device_type",␉␉␉␉get_nameparent_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1506 | ␉{FLAGTRUE,␉false,␉"model",␉␉␉␉get_model_val,␉␉STRVAL("ATI Radeon")␉␉␉␉␉␉},␊ |
1507 | //␉{FLAGTRUE,␉false,␉"VRAM,totalsize",␉␉␉get_vramtotalsize_val,␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1508 | ␉{FLAGTRUE,␉false,␉"hda-gfx",␉␉␉␉get_hdmiaudio,␉␉NULVAL␉␉␉␉␉␉␉␉},␊ |
1509 | ␊ |
1510 | ␉{FLAGTRUE,␉false,␉NULL,␉␉␉␉␉NULL,␉␉␉NULVAL␉␉␉␉␉␉␉␉}␊ |
1511 | };␊ |
1512 | ␊ |
1513 | ␊ |
1514 | bool get_bootdisplay_val(value_t *val)␊ |
1515 | {␊ |
1516 | ␉static uint32_t v = 0;␊ |
1517 | ␉␊ |
1518 | ␉if (v)␊ |
1519 | ␉{␊ |
1520 | ␉␉return false;␊ |
1521 | ␉}␊ |
1522 | ␉if (!card->posted)␊ |
1523 | ␉{␊ |
1524 | ␉␉return false;␊ |
1525 | ␉}␊ |
1526 | ␉v = 1;␊ |
1527 | ␉val->type = kCst;␊ |
1528 | ␉val->size = 4;␊ |
1529 | ␉val->data = (uint8_t *)&v;␊ |
1530 | ␉␊ |
1531 | ␉return true;␊ |
1532 | }␊ |
1533 | ␊ |
1534 | bool get_hdmiaudio(value_t * val)␊ |
1535 | {␊ |
1536 | ␉bool doit = false;␊ |
1537 | ␉if(getBoolForKey(kEnableHDMIAudio, &doit, &bootInfo->chameleonConfig) && doit){␊ |
1538 | ␉␉val->type = kStr;␊ |
1539 | ␉␉val->size = strlen("onboard-1") + 1;␊ |
1540 | ␉␉val->data = (uint8_t *)"onboard-1";␊ |
1541 | ␉␉return true;␊ |
1542 | ␉}␊ |
1543 | ␉return false;␊ |
1544 | }␊ |
1545 | bool get_vrammemory_val(value_t *val)␊ |
1546 | {␊ |
1547 | ␉return false;␊ |
1548 | }␊ |
1549 | ␊ |
1550 | bool get_name_val(value_t *val)␊ |
1551 | {␊ |
1552 | ␉val->type = aty_name.type;␊ |
1553 | ␉val->size = aty_name.size;␊ |
1554 | ␉val->data = aty_name.data;␊ |
1555 | ␉␊ |
1556 | ␉return true;␊ |
1557 | }␊ |
1558 | ␊ |
1559 | bool get_nameparent_val(value_t *val)␊ |
1560 | {␊ |
1561 | ␉val->type = aty_nameparent.type;␊ |
1562 | ␉val->size = aty_nameparent.size;␊ |
1563 | ␉val->data = aty_nameparent.data;␊ |
1564 | ␉␊ |
1565 | ␉return true;␊ |
1566 | }␊ |
1567 | ␊ |
1568 | bool get_model_val(value_t *val)␊ |
1569 | {␊ |
1570 | ␉if (!card->info->model_name)␊ |
1571 | ␉␉return false;␊ |
1572 | ␉␊ |
1573 | ␉val->type = kStr;␊ |
1574 | ␉val->size = strlen(card->info->model_name) + 1;␊ |
1575 | ␉val->data = (uint8_t *)card->info->model_name;␊ |
1576 | ␉␊ |
1577 | ␉return true;␊ |
1578 | }␊ |
1579 | ␊ |
1580 | bool get_conntype_val(value_t *val)␊ |
1581 | {␊ |
1582 | //Connector types:␊ |
1583 | //0×00000010: VGA␊ |
1584 | //0x00000004: DL DVI-I␊ |
1585 | //x000000200: SL DVI-I␊ |
1586 | //0x00000080: S-V␊ |
1587 | //0×00000800: HDMI␊ |
1588 | //0x00000400: DisplayPort␊ |
1589 | //0x00000002: LVDS␊ |
1590 | ␊ |
1591 | ␉return false;␊ |
1592 | }␊ |
1593 | ␊ |
1594 | bool get_vrammemsize_val(value_t *val)␊ |
1595 | {␊ |
1596 | ␉static int idx = -1;␊ |
1597 | ␉static uint64_t memsize;␊ |
1598 | ␉␊ |
1599 | ␉idx++;␊ |
1600 | ␉memsize = ((uint64_t)card->vram_size << 32);␊ |
1601 | ␉if (idx == 0)␊ |
1602 | ␉{␊ |
1603 | ␉␉memsize = memsize | (uint64_t)card->vram_size;␊ |
1604 | ␉}␊ |
1605 | ␉val->type = kCst;␊ |
1606 | ␉val->size = 8;␊ |
1607 | ␉val->data = (uint8_t *)&memsize;␊ |
1608 | ␉␊ |
1609 | ␉return true;␊ |
1610 | }␊ |
1611 | ␊ |
1612 | bool get_binimage_val(value_t *val)␊ |
1613 | {␊ |
1614 | ␉if (!card->rom)␊ |
1615 | ␉{␊ |
1616 | ␉␉return false;␊ |
1617 | ␉}␊ |
1618 | ␉val->type = kPtr;␊ |
1619 | ␉val->size = card->rom_size;␊ |
1620 | ␉val->data = card->rom;␊ |
1621 | ␉␊ |
1622 | ␉return true;␊ |
1623 | }␊ |
1624 | ␊ |
1625 | ␊ |
1626 | bool get_romrevision_val(value_t *val)␊ |
1627 | {␊ |
1628 | ␉uint8_t *rev;␊ |
1629 | ␉if (!card->rom)␊ |
1630 | ␉{␊ |
1631 | ␉␉return false;␊ |
1632 | ␉}␊ |
1633 | ␊ |
1634 | ␉rev = card->rom + *(uint8_t *)(card->rom + OFFSET_TO_GET_ATOMBIOS_STRINGS_START);␊ |
1635 | ␊ |
1636 | ␉val->type = kPtr;␊ |
1637 | ␉val->size = strlen((char *)rev);␊ |
1638 | ␉val->data = malloc(val->size);␊ |
1639 | ␉␊ |
1640 | ␉if (!val->data)␊ |
1641 | ␉{␊ |
1642 | ␉␉return false;␊ |
1643 | ␉}␊ |
1644 | ␊ |
1645 | ␉memcpy(val->data, rev, val->size);␊ |
1646 | ␉␊ |
1647 | ␉return true;␊ |
1648 | }␊ |
1649 | ␊ |
1650 | bool get_deviceid_val(value_t *val)␊ |
1651 | {␊ |
1652 | ␉val->type = kCst;␊ |
1653 | ␉val->size = 2;␊ |
1654 | ␉val->data = (uint8_t *)&card->pci_dev->device_id;␊ |
1655 | ␉␊ |
1656 | ␉return true;␊ |
1657 | }␊ |
1658 | ␊ |
1659 | bool get_mclk_val(value_t *val)␊ |
1660 | {␊ |
1661 | ␉return false;␊ |
1662 | }␊ |
1663 | ␊ |
1664 | bool get_sclk_val(value_t *val)␊ |
1665 | {␊ |
1666 | ␉return false;␊ |
1667 | }␊ |
1668 | ␊ |
1669 | bool get_refclk_val(value_t *val)␊ |
1670 | {␊ |
1671 | ␉return false;␊ |
1672 | }␊ |
1673 | ␊ |
1674 | bool get_platforminfo_val(value_t *val)␊ |
1675 | {␊ |
1676 | ␉val->data = malloc(0x80);␊ |
1677 | ␉if (!val->data)␊ |
1678 | ␉{␊ |
1679 | ␉␉return false;␊ |
1680 | ␉}␊ |
1681 | ␉bzero(val->data, 0x80);␊ |
1682 | ␉␊ |
1683 | ␉val->type␉␉= kPtr;␊ |
1684 | ␉val->size␉␉= 0x80;␊ |
1685 | ␉val->data[0]␉= 1;␊ |
1686 | ␉␊ |
1687 | ␉return true;␊ |
1688 | }␊ |
1689 | ␊ |
1690 | bool get_vramtotalsize_val(value_t *val)␊ |
1691 | {␊ |
1692 | ␊ |
1693 | ␉val->type = kCst;␊ |
1694 | ␉val->size = 4;␊ |
1695 | ␉val->data = (uint8_t *)&card->vram_size;␊ |
1696 | ␉␊ |
1697 | ␉return true;␊ |
1698 | }␊ |
1699 | ␊ |
1700 | void free_val(value_t *val)␊ |
1701 | {␊ |
1702 | ␉if (val->type == kPtr)␊ |
1703 | ␉{␊ |
1704 | ␉␉free(val->data);␊ |
1705 | ␉}␊ |
1706 | ␉␊ |
1707 | ␉bzero(val, sizeof(value_t));␊ |
1708 | }␊ |
1709 | ␊ |
1710 | void devprop_add_list(dev_prop_t devprop_list[])␊ |
1711 | {␊ |
1712 | ␉int i, pnum;␊ |
1713 | ␉value_t *val = malloc(sizeof(value_t));␊ |
1714 | ␉␊ |
1715 | ␉for (i = 0; devprop_list[i].name != NULL; i++)␊ |
1716 | ␉{␊ |
1717 | ␉␉if ((devprop_list[i].flags == FLAGTRUE) || (devprop_list[i].flags | card->flags))␊ |
1718 | ␉␉{␊ |
1719 | ␉␉␉if (devprop_list[i].get_value && devprop_list[i].get_value(val))␊ |
1720 | ␉␉␉{␊ |
1721 | ␉␉␉␉devprop_add_value(card->device, devprop_list[i].name, val->data, val->size);␊ |
1722 | ␉␉␉␉free_val(val);␊ |
1723 | ␉␉␉␉␊ |
1724 | ␉␉␉␉if (devprop_list[i].all_ports)␊ |
1725 | ␉␉␉␉{␊ |
1726 | ␉␉␉␉␉for (pnum = 1; pnum < card->ports; pnum++)␊ |
1727 | ␉␉␉␉␉{␊ |
1728 | ␉␉␉␉␉␉if (devprop_list[i].get_value(val))␊ |
1729 | ␉␉␉␉␉␉{␊ |
1730 | ␉␉␉␉␉␉␉devprop_list[i].name[1] = 0x30 + pnum; // convert to ascii␊ |
1731 | ␉␉␉␉␉␉␉devprop_add_value(card->device, devprop_list[i].name, val->data, val->size);␊ |
1732 | ␉␉␉␉␉␉␉free_val(val);␊ |
1733 | ␉␉␉␉␉␉}␊ |
1734 | ␉␉␉␉␉}␊ |
1735 | ␉␉␉␉␉devprop_list[i].name[1] = 0x30; // write back our "@0," for a next possible card␊ |
1736 | ␉␉␉␉}␊ |
1737 | ␉␉␉}␊ |
1738 | ␉␉␉else␊ |
1739 | ␉␉␉{␊ |
1740 | ␉␉␉␉if (devprop_list[i].default_val.type != kNul)␊ |
1741 | ␉␉␉␉{␊ |
1742 | ␉␉␉␉␉devprop_add_value(card->device, devprop_list[i].name,␊ |
1743 | ␉␉␉␉␉␉devprop_list[i].default_val.type == kCst ?␊ |
1744 | ␉␉␉␉␉␉(uint8_t *)&(devprop_list[i].default_val.data) : devprop_list[i].default_val.data,␊ |
1745 | ␉␉␉␉␉␉devprop_list[i].default_val.size);␊ |
1746 | ␉␉␉␉}␊ |
1747 | ␉␉␉␉␊ |
1748 | ␉␉␉␉if (devprop_list[i].all_ports)␊ |
1749 | ␉␉␉␉{␊ |
1750 | ␉␉␉␉␉for (pnum = 1; pnum < card->ports; pnum++)␊ |
1751 | ␉␉␉␉␉{␊ |
1752 | ␉␉␉␉␉␉if (devprop_list[i].default_val.type != kNul)␊ |
1753 | ␉␉␉␉␉␉{␊ |
1754 | ␉␉␉␉␉␉␉devprop_list[i].name[1] = 0x30 + pnum; // convert to ascii␊ |
1755 | ␉␉␉␉␉␉␉devprop_add_value(card->device, devprop_list[i].name,␊ |
1756 | ␉␉␉␉␉␉␉␉devprop_list[i].default_val.type == kCst ?␊ |
1757 | ␉␉␉␉␉␉␉␉(uint8_t *)&(devprop_list[i].default_val.data) : devprop_list[i].default_val.data,␊ |
1758 | ␉␉␉␉␉␉␉␉devprop_list[i].default_val.size);␊ |
1759 | ␉␉␉␉␉␉}␊ |
1760 | ␉␉␉␉␉}␊ |
1761 | ␉␉␉␉␉devprop_list[i].name[1] = 0x30; // write back our "@0," for a next possible card␊ |
1762 | ␉␉␉␉}␊ |
1763 | ␉␉␉}␊ |
1764 | ␉␉}␊ |
1765 | ␉}␊ |
1766 | ␊ |
1767 | ␉free(val);␊ |
1768 | }␊ |
1769 | ␊ |
1770 | bool validate_rom(option_rom_header_t *rom_header, pci_dt_t *pci_dev)␊ |
1771 | {␊ |
1772 | ␉option_rom_pci_header_t *rom_pci_header;␊ |
1773 | ␉␊ |
1774 | ␉if (rom_header->signature != 0xaa55)␊ |
1775 | ␉{␊ |
1776 | ␉␉verbose("invalid ROM signature \n");␊ |
1777 | ␉␉return false;␊ |
1778 | ␉}␊ |
1779 | ␊ |
1780 | ␉rom_pci_header = (option_rom_pci_header_t *)((uint8_t *)rom_header + rom_header->pci_header_offset);␊ |
1781 | ␉␊ |
1782 | ␉if (rom_pci_header->signature != 0x52494350)␊ |
1783 | ␉{␊ |
1784 | ␉␉return false;␊ |
1785 | ␉}␊ |
1786 | ␉␊ |
1787 | ␉if (rom_pci_header->vendor_id != pci_dev->vendor_id || rom_pci_header->device_id != pci_dev->device_id)␊ |
1788 | ␉{␊ |
1789 | ␉␉return false;␊ |
1790 | ␉}␊ |
1791 | ␉␊ |
1792 | ␉return true;␊ |
1793 | }␊ |
1794 | ␊ |
1795 | bool load_vbios_file(const char *key, uint16_t vendor_id, uint16_t device_id, uint32_t subsys_id)␊ |
1796 | {␊ |
1797 | ␉int fd;␊ |
1798 | ␉char file_name[24];␊ |
1799 | ␉bool do_load = false;␊ |
1800 | ␊ |
1801 | ␉getBoolForKey(key, &do_load, &bootInfo->chameleonConfig);␊ |
1802 | ␉if (!do_load)␊ |
1803 | ␉{␊ |
1804 | ␉␉return false;␊ |
1805 | ␉}␊ |
1806 | ␊ |
1807 | ␉sprintf(file_name, "/Extra/%04x_%04x_%08x.rom", vendor_id, device_id, subsys_id);␊ |
1808 | ␉if ((fd = open_bvdev("bt(0,0)", file_name, 0)) < 0)␊ |
1809 | ␉{␊ |
1810 | ␉␉return false;␊ |
1811 | ␉}␊ |
1812 | ␊ |
1813 | ␉card->rom_size = file_size(fd);␊ |
1814 | ␉card->rom = malloc(card->rom_size);␊ |
1815 | ␉if (!card->rom)␊ |
1816 | ␉{␊ |
1817 | ␉␉return false;␊ |
1818 | ␉}␊ |
1819 | ␊ |
1820 | ␉read(fd, (char *)card->rom, card->rom_size);␊ |
1821 | ␊ |
1822 | ␉if (!validate_rom((option_rom_header_t *)card->rom, card->pci_dev))␊ |
1823 | ␉{␊ |
1824 | ␉␉card->rom_size = 0;␊ |
1825 | ␉␉card->rom = 0;␊ |
1826 | ␉␉return false;␊ |
1827 | ␉}␊ |
1828 | ␉␊ |
1829 | ␉card->rom_size = ((option_rom_header_t *)card->rom)->rom_size * 512;␊ |
1830 | ␊ |
1831 | ␉close(fd);␊ |
1832 | ␊ |
1833 | ␉return true;␊ |
1834 | }␊ |
1835 | ␊ |
1836 | void get_vram_size(void)␊ |
1837 | {␊ |
1838 | ␉ati_chip_family_t chip_family = card->info->chip_family;␊ |
1839 | ␉␊ |
1840 | ␉card->vram_size = 0;␊ |
1841 | ␊ |
1842 | ␉if (chip_family >= CHIP_FAMILY_CEDAR)␊ |
1843 | ␉{␊ |
1844 | ␉␉// size in MB on evergreen␊ |
1845 | ␉␉// XXX watch for overflow!!!␊ |
1846 | ␉␉card->vram_size = RegRead32(R600_CONFIG_MEMSIZE) * 1024 * 1024;␊ |
1847 | ␉}␊ |
1848 | ␉else␊ |
1849 | ␉{␊ |
1850 | ␉␉if (chip_family >= CHIP_FAMILY_R600)␊ |
1851 | ␉␉{␊ |
1852 | ␉␉␉card->vram_size = RegRead32(R600_CONFIG_MEMSIZE);␊ |
1853 | ␉␉}␊ |
1854 | ␉}␊ |
1855 | }␊ |
1856 | ␊ |
1857 | bool read_vbios(bool from_pci)␊ |
1858 | {␊ |
1859 | ␉option_rom_header_t *rom_addr;␊ |
1860 | ␉␊ |
1861 | ␉if (from_pci)␊ |
1862 | ␉{␊ |
1863 | ␉␉rom_addr = (option_rom_header_t *)(pci_config_read32(card->pci_dev->dev.addr, PCI_ROM_ADDRESS) & ~0x7ff);␊ |
1864 | ␉␉verbose(" @0x%x", rom_addr);␊ |
1865 | ␉}␊ |
1866 | ␉else␊ |
1867 | ␉␉rom_addr = (option_rom_header_t *)0xc0000;␊ |
1868 | ␉␊ |
1869 | ␉if (!validate_rom(rom_addr, card->pci_dev))␊ |
1870 | ␉{␊ |
1871 | ␉␉return false;␊ |
1872 | ␉}␊ |
1873 | ␉card->rom_size = rom_addr->rom_size * 512;␊ |
1874 | ␉if (!card->rom_size)␊ |
1875 | ␉␉return false;␊ |
1876 | ␉␊ |
1877 | ␉card->rom = malloc(card->rom_size);␊ |
1878 | ␉if (!card->rom)␊ |
1879 | ␉␉return false;␊ |
1880 | ␉␊ |
1881 | ␉memcpy(card->rom, (void *)rom_addr, card->rom_size);␊ |
1882 | ␉␊ |
1883 | ␉return true;␊ |
1884 | }␊ |
1885 | ␊ |
1886 | bool read_disabled_vbios(void)␊ |
1887 | {␊ |
1888 | ␉bool ret = false;␊ |
1889 | ␉ati_chip_family_t chip_family = card->info->chip_family;␊ |
1890 | ␉␊ |
1891 | ␉if (chip_family >= CHIP_FAMILY_RV770)␊ |
1892 | ␉{␊ |
1893 | ␉␉uint32_t viph_control␉␉= RegRead32(RADEON_VIPH_CONTROL);␊ |
1894 | ␉␉uint32_t bus_cntl␉␉= RegRead32(RADEON_BUS_CNTL);␊ |
1895 | ␉␉uint32_t d1vga_control␉␉= RegRead32(AVIVO_D1VGA_CONTROL);␊ |
1896 | ␉␉uint32_t d2vga_control␉␉= RegRead32(AVIVO_D2VGA_CONTROL);␊ |
1897 | ␉␉uint32_t vga_render_control␉= RegRead32(AVIVO_VGA_RENDER_CONTROL);␊ |
1898 | ␉␉uint32_t rom_cntl␉␉= RegRead32(R600_ROM_CNTL);␊ |
1899 | ␉␉uint32_t cg_spll_func_cntl␉= 0;␊ |
1900 | ␉␉uint32_t cg_spll_status;␊ |
1901 | ␉␉␊ |
1902 | ␉␉// disable VIP␊ |
1903 | ␉␉RegWrite32(RADEON_VIPH_CONTROL, (viph_control & ~RADEON_VIPH_EN));␊ |
1904 | ␉␉␊ |
1905 | ␉␉// enable the rom␊ |
1906 | ␉␉RegWrite32(RADEON_BUS_CNTL, (bus_cntl & ~RADEON_BUS_BIOS_DIS_ROM));␊ |
1907 | ␉␉␊ |
1908 | ␉␉// Disable VGA mode␊ |
1909 | ␉␉RegWrite32(AVIVO_D1VGA_CONTROL, (d1vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE | AVIVO_DVGA_CONTROL_TIMING_SELECT)));␊ |
1910 | ␉␉RegWrite32(AVIVO_D2VGA_CONTROL, (d2vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE | AVIVO_DVGA_CONTROL_TIMING_SELECT)));␊ |
1911 | ␉␉RegWrite32(AVIVO_VGA_RENDER_CONTROL, (vga_render_control & ~AVIVO_VGA_VSTATUS_CNTL_MASK));␊ |
1912 | ␉␉␊ |
1913 | ␉␉if (chip_family == CHIP_FAMILY_RV730)␊ |
1914 | ␉␉{␊ |
1915 | ␉␉␉cg_spll_func_cntl = RegRead32(R600_CG_SPLL_FUNC_CNTL);␊ |
1916 | ␉␉␉␊ |
1917 | ␉␉␉// enable bypass mode␊ |
1918 | ␉␉␉RegWrite32(R600_CG_SPLL_FUNC_CNTL, (cg_spll_func_cntl | R600_SPLL_BYPASS_EN));␊ |
1919 | ␉␉␉␊ |
1920 | ␉␉␉// wait for SPLL_CHG_STATUS to change to 1␊ |
1921 | ␉␉␉cg_spll_status = 0;␊ |
1922 | ␉␉␉while (!(cg_spll_status & R600_SPLL_CHG_STATUS))␊ |
1923 | ␉␉␉␉cg_spll_status = RegRead32(R600_CG_SPLL_STATUS);␊ |
1924 | ␉␉␉␊ |
1925 | ␉␉␉RegWrite32(R600_ROM_CNTL, (rom_cntl & ~R600_SCK_OVERWRITE));␊ |
1926 | ␉␉}␊ |
1927 | ␉␉else {␊ |
1928 | ␉␉␉RegWrite32(R600_ROM_CNTL, (rom_cntl | R600_SCK_OVERWRITE));␊ |
1929 | ␉␉}␊ |
1930 | ␊ |
1931 | ␉␉ret = read_vbios(true);␊ |
1932 | ␉␉␊ |
1933 | ␉␉// restore regs␊ |
1934 | ␉␉if (chip_family == CHIP_FAMILY_RV730)␊ |
1935 | ␉␉{␊ |
1936 | ␉␉␉RegWrite32(R600_CG_SPLL_FUNC_CNTL, cg_spll_func_cntl);␊ |
1937 | ␉␉␉␊ |
1938 | ␉␉␉// wait for SPLL_CHG_STATUS to change to 1␊ |
1939 | ␉␉␉cg_spll_status = 0;␊ |
1940 | ␉␉␉while (!(cg_spll_status & R600_SPLL_CHG_STATUS))␊ |
1941 | ␉␉␉cg_spll_status = RegRead32(R600_CG_SPLL_STATUS);␊ |
1942 | ␉␉}␊ |
1943 | ␉␉RegWrite32(RADEON_VIPH_CONTROL, viph_control);␊ |
1944 | ␉␉RegWrite32(RADEON_BUS_CNTL, bus_cntl);␊ |
1945 | ␉␉RegWrite32(AVIVO_D1VGA_CONTROL, d1vga_control);␊ |
1946 | ␉␉RegWrite32(AVIVO_D2VGA_CONTROL, d2vga_control);␊ |
1947 | ␉␉RegWrite32(AVIVO_VGA_RENDER_CONTROL, vga_render_control);␊ |
1948 | ␉␉RegWrite32(R600_ROM_CNTL, rom_cntl);␊ |
1949 | ␉}␊ |
1950 | ␉else␊ |
1951 | ␉␉if (chip_family >= CHIP_FAMILY_R600)␊ |
1952 | ␉␉{␊ |
1953 | ␉␉␉uint32_t viph_control␉␉␉␉= RegRead32(RADEON_VIPH_CONTROL);␊ |
1954 | ␉␉␉uint32_t bus_cntl␉␉␉␉= RegRead32(RADEON_BUS_CNTL);␊ |
1955 | ␉␉␉uint32_t d1vga_control␉␉␉␉= RegRead32(AVIVO_D1VGA_CONTROL);␊ |
1956 | ␉␉␉uint32_t d2vga_control␉␉␉␉= RegRead32(AVIVO_D2VGA_CONTROL);␊ |
1957 | ␉␉␉uint32_t vga_render_control␉␉␉= RegRead32(AVIVO_VGA_RENDER_CONTROL);␊ |
1958 | ␉␉␉uint32_t rom_cntl␉␉␉␉= RegRead32(R600_ROM_CNTL);␊ |
1959 | ␉␉␉uint32_t general_pwrmgt␉␉␉␉= RegRead32(R600_GENERAL_PWRMGT);␊ |
1960 | ␉␉␉uint32_t low_vid_lower_gpio_cntl␉␉= RegRead32(R600_LOW_VID_LOWER_GPIO_CNTL);␊ |
1961 | ␉␉␉uint32_t medium_vid_lower_gpio_cntl␉␉= RegRead32(R600_MEDIUM_VID_LOWER_GPIO_CNTL);␊ |
1962 | ␉␉␉uint32_t high_vid_lower_gpio_cntl␉␉= RegRead32(R600_HIGH_VID_LOWER_GPIO_CNTL);␊ |
1963 | ␉␉␉uint32_t ctxsw_vid_lower_gpio_cntl␉␉= RegRead32(R600_CTXSW_VID_LOWER_GPIO_CNTL);␊ |
1964 | ␉␉␉uint32_t lower_gpio_enable␉␉␉= RegRead32(R600_LOWER_GPIO_ENABLE);␊ |
1965 | ␉␉␉␊ |
1966 | ␉␉␉// disable VIP␊ |
1967 | ␉␉␉RegWrite32(RADEON_VIPH_CONTROL, (viph_control & ~RADEON_VIPH_EN));␊ |
1968 | ␉␉␉␊ |
1969 | ␉␉␉// enable the rom␊ |
1970 | ␉␉␉RegWrite32(RADEON_BUS_CNTL, (bus_cntl & ~RADEON_BUS_BIOS_DIS_ROM));␊ |
1971 | ␉␉␉␊ |
1972 | ␉␉␉// Disable VGA mode␊ |
1973 | ␉␉␉RegWrite32(AVIVO_D1VGA_CONTROL, (d1vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE | AVIVO_DVGA_CONTROL_TIMING_SELECT)));␊ |
1974 | ␉␉␉RegWrite32(AVIVO_D2VGA_CONTROL, (d2vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE | AVIVO_DVGA_CONTROL_TIMING_SELECT)));␊ |
1975 | ␉␉␉RegWrite32(AVIVO_VGA_RENDER_CONTROL, (vga_render_control & ~AVIVO_VGA_VSTATUS_CNTL_MASK));␊ |
1976 | ␉␉␉RegWrite32(R600_ROM_CNTL, ((rom_cntl & ~R600_SCK_PRESCALE_CRYSTAL_CLK_MASK) | (1 << R600_SCK_PRESCALE_CRYSTAL_CLK_SHIFT) | R600_SCK_OVERWRITE));␊ |
1977 | ␉␉␉RegWrite32(R600_GENERAL_PWRMGT, (general_pwrmgt & ~R600_OPEN_DRAIN_PADS));␊ |
1978 | ␉␉␉RegWrite32(R600_LOW_VID_LOWER_GPIO_CNTL, (low_vid_lower_gpio_cntl & ~0x400));␊ |
1979 | ␉␉␉RegWrite32(R600_MEDIUM_VID_LOWER_GPIO_CNTL, (medium_vid_lower_gpio_cntl & ~0x400));␊ |
1980 | ␉␉␉RegWrite32(R600_HIGH_VID_LOWER_GPIO_CNTL, (high_vid_lower_gpio_cntl & ~0x400));␊ |
1981 | ␉␉␉RegWrite32(R600_CTXSW_VID_LOWER_GPIO_CNTL, (ctxsw_vid_lower_gpio_cntl & ~0x400));␊ |
1982 | ␉␉␉RegWrite32(R600_LOWER_GPIO_ENABLE, (lower_gpio_enable | 0x400));␊ |
1983 | ␉␉␉␊ |
1984 | ␉␉␉ret = read_vbios(true);␊ |
1985 | ␉␉␉␊ |
1986 | ␉␉␉// restore regs␊ |
1987 | ␉␉␉RegWrite32(RADEON_VIPH_CONTROL, viph_control);␊ |
1988 | ␉␉␉RegWrite32(RADEON_BUS_CNTL, bus_cntl);␊ |
1989 | ␉␉␉RegWrite32(AVIVO_D1VGA_CONTROL, d1vga_control);␊ |
1990 | ␉␉␉RegWrite32(AVIVO_D2VGA_CONTROL, d2vga_control);␊ |
1991 | ␉␉␉RegWrite32(AVIVO_VGA_RENDER_CONTROL, vga_render_control);␊ |
1992 | ␉␉␉RegWrite32(R600_ROM_CNTL, rom_cntl);␊ |
1993 | ␉␉␉RegWrite32(R600_GENERAL_PWRMGT, general_pwrmgt);␊ |
1994 | ␉␉␉RegWrite32(R600_LOW_VID_LOWER_GPIO_CNTL, low_vid_lower_gpio_cntl);␊ |
1995 | ␉␉␉RegWrite32(R600_MEDIUM_VID_LOWER_GPIO_CNTL, medium_vid_lower_gpio_cntl);␊ |
1996 | ␉␉␉RegWrite32(R600_HIGH_VID_LOWER_GPIO_CNTL, high_vid_lower_gpio_cntl);␊ |
1997 | ␉␉␉RegWrite32(R600_CTXSW_VID_LOWER_GPIO_CNTL, ctxsw_vid_lower_gpio_cntl);␊ |
1998 | ␉␉␉RegWrite32(R600_LOWER_GPIO_ENABLE, lower_gpio_enable);␊ |
1999 | ␉␉}␊ |
2000 | ␊ |
2001 | ␉return ret;␊ |
2002 | }␊ |
2003 | ␊ |
2004 | bool radeon_card_posted(void)␊ |
2005 | {␊ |
2006 | ␉uint32_t reg;␊ |
2007 | ␉␊ |
2008 | ␉// first check CRTCs␊ |
2009 | ␉reg = RegRead32(RADEON_CRTC_GEN_CNTL) | RegRead32(RADEON_CRTC2_GEN_CNTL);␊ |
2010 | ␉if (reg & RADEON_CRTC_EN)␊ |
2011 | ␉{␊ |
2012 | ␉␉return true;␊ |
2013 | ␉}␊ |
2014 | ␉␊ |
2015 | ␉// then check MEM_SIZE, in case something turned the crtcs off␊ |
2016 | ␉reg = RegRead32(R600_CONFIG_MEMSIZE);␊ |
2017 | ␉if (reg)␊ |
2018 | ␉{␊ |
2019 | ␉␉return true;␊ |
2020 | ␉}␊ |
2021 | ␉␊ |
2022 | ␉return false;␊ |
2023 | }␊ |
2024 | ␊ |
2025 | #if 0␊ |
2026 | bool devprop_add_pci_config_space(void)␊ |
2027 | {␊ |
2028 | ␉int offset;␊ |
2029 | ␉␊ |
2030 | ␉uint8_t *config_space = malloc(0x100);␊ |
2031 | ␉if (!config_space)␊ |
2032 | ␉{␊ |
2033 | ␉␉return false;␊ |
2034 | ␉}␊ |
2035 | ␉␊ |
2036 | ␉for (offset = 0; offset < 0x100; offset += 4)␊ |
2037 | ␉␉config_space[offset / 4] = pci_config_read32(card->pci_dev->dev.addr, offset);␊ |
2038 | ␉␊ |
2039 | ␉devprop_add_value(card->device, "ATY,PCIConfigSpace", config_space, 0x100);␊ |
2040 | ␉free(config_space);␊ |
2041 | ␉␊ |
2042 | ␉return true;␊ |
2043 | }␊ |
2044 | #endif␊ |
2045 | ␊ |
2046 | static char␉name[24];␊ |
2047 | static char␉name_parent[24];␊ |
2048 | ␊ |
2049 | static bool init_card(pci_dt_t *pci_dev)␊ |
2050 | {␊ |
2051 | ␉bool␉add_vbios = true;␊ |
2052 | ␉int␉␉i;␊ |
2053 | ␉int␉␉n_ports = 0;␊ |
2054 | ␉␊ |
2055 | ␉card = malloc(sizeof(card_t));␊ |
2056 | ␉if (!card)␊ |
2057 | ␉{␊ |
2058 | ␉␉return false;␊ |
2059 | ␉}␊ |
2060 | ␉bzero(card, sizeof(card_t));␊ |
2061 | ␊ |
2062 | ␉card->pci_dev = pci_dev;␊ |
2063 | ␉␊ |
2064 | ␉for (i = 0; radeon_cards[i].device_id ; i++)␊ |
2065 | ␉{␊ |
2066 | ␉␉if (radeon_cards[i].device_id == pci_dev->device_id)␊ |
2067 | ␉␉{␊ |
2068 | ␉␉␉card->info = &radeon_cards[i];␊ |
2069 | ␉␉␉if ((radeon_cards[i].subsys_id == 0x00000000) || (radeon_cards[i].subsys_id == pci_dev->subsys_id.subsys_id))␊ |
2070 | ␉␉␉{␊ |
2071 | ␉␉␉␉break;␊ |
2072 | ␉␉␉}␊ |
2073 | ␉␉}␊ |
2074 | ␉}␊ |
2075 | ␊ |
2076 | //␉if (!card->info->device_id || !card->info->cfg_name)␊ |
2077 | ␉if (!card->info->device_id)␊ |
2078 | ␉{␊ |
2079 | ␉␉verbose("Unsupported ATI card! Device ID: [%04x:%04x] Subsystem ID: [%08x] \n", ␊ |
2080 | ␉␉␉␉pci_dev->vendor_id, pci_dev->device_id, pci_dev->subsys_id.subsys_id);␊ |
2081 | ␉␉return false;␊ |
2082 | ␉}␊ |
2083 | ␉␊ |
2084 | ␉card->fb␉␉= (uint8_t *)(pci_config_read32(pci_dev->dev.addr, PCI_BASE_ADDRESS_0) & ~0x0f);␊ |
2085 | ␉card->mmio␉␉= (uint8_t *)(pci_config_read32(pci_dev->dev.addr, PCI_BASE_ADDRESS_2) & ~0x0f);␊ |
2086 | ␉card->io␉␉= (uint8_t *)(pci_config_read32(pci_dev->dev.addr, PCI_BASE_ADDRESS_4) & ~0x03);␊ |
2087 | ␊ |
2088 | ␉verbose("ATI Framebuffer Addr: @0x%08X MMIO Addr: @0x%08X I/O Port Addr: @0x%08X ROM Addr: @0x%08X\n",␊ |
2089 | ␉␉card->fb, card->mmio, card->io, pci_config_read32(pci_dev->dev.addr, PCI_ROM_ADDRESS));␊ |
2090 | ␉␊ |
2091 | ␉card->posted = radeon_card_posted();␊ |
2092 | ␉verbose("ATI card %s, ", card->posted ? "POSTed" : "non-POSTed");␊ |
2093 | ␉␊ |
2094 | ␉get_vram_size();␊ |
2095 | ␉␊ |
2096 | ␉getBoolForKey(kATYbinimage, &add_vbios, &bootInfo->chameleonConfig);␊ |
2097 | ␉␊ |
2098 | ␉if (add_vbios)␊ |
2099 | ␉{␊ |
2100 | ␉␉if (!load_vbios_file(kUseAtiROM, pci_dev->vendor_id, pci_dev->device_id, pci_dev->subsys_id.subsys_id))␊ |
2101 | ␉␉{␊ |
2102 | ␉␉␉verbose("reading VBIOS from %s", card->posted ? "legacy space" : "PCI ROM");␊ |
2103 | ␉␉␉if (card->posted)␊ |
2104 | ␉␉␉{␊ |
2105 | ␉␉␉␉read_vbios(false);␊ |
2106 | ␉␉␉}␊ |
2107 | ␉␉␉else␊ |
2108 | ␉␉␉{␊ |
2109 | ␉␉␉␉read_disabled_vbios();␊ |
2110 | ␉␉␉}␊ |
2111 | ␉␉␉verbose("\n");␊ |
2112 | ␉␉}␊ |
2113 | ␉}␊ |
2114 | ␊ |
2115 | //␉card->ports = 2; // default - Azi: default is card_configs␊ |
2116 | ␊ |
2117 | ␉if (card->info->chip_family >= CHIP_FAMILY_CEDAR)␊ |
2118 | ␉{␊ |
2119 | ␉␉card->flags |= EVERGREEN;␊ |
2120 | //␉␉card->ports = 3; //Azi: use the AtiPorts key if needed␊ |
2121 | ␉}␊ |
2122 | ␊ |
2123 | //␉atN = 0;␊ |
2124 | ␊ |
2125 | ␉// Check AtiConfig key for a framebuffer name,␊ |
2126 | ␉card->cfg_name = getStringForKey(kAtiConfig, &bootInfo->chameleonConfig);␊ |
2127 | ␉// if none,␊ |
2128 | ␉if (!card->cfg_name)␊ |
2129 | ␉{␊ |
2130 | ␉␉// use the device fb key on radeon_cards, to retrive the default name from card_configs.␊ |
2131 | ␉␉card->cfg_name = card_configs[card->info->cfg_name].name;␊ |
2132 | ␉␉// Uncommented the following line and added verbose for debugging AtiPorts issues on some cards␊ |
2133 | ␉␉card->ports = card_configs[card->info->cfg_name].ports;␊ |
2134 | ␉␉// Report number of ports card reports␊ |
2135 | ␉␉verbose("Card reported ports: %d\n", card->ports);␊ |
2136 | ␉␉␊ |
2137 | ␉␉// which means one of the fb's or kNull␊ |
2138 | ␉␉verbose("Framebuffer set to: %s using device's default.\n", card->cfg_name);␊ |
2139 | ␉}␊ |
2140 | ␉else␊ |
2141 | ␉{␊ |
2142 | ␉␉// else, use the fb name returned by AtiConfig.␊ |
2143 | ␉␉verbose("Framebuffer set to: %s using AtiConfig=%s\n", card->cfg_name, card->cfg_name);␊ |
2144 | ␉}␊ |
2145 | ␊ |
2146 | ␉// Check AtiPorts key for nr of ports,␊ |
2147 | ␉card->ports = getIntForKey(kAtiPorts, &n_ports, &bootInfo->chameleonConfig);␊ |
2148 | ␉// if a value bigger than 0 ?? is found, (do we need >= 0 ?? that's null FB on card_configs)␊ |
2149 | ␉if (n_ports > 0)␊ |
2150 | ␉{␊ |
2151 | ␉␉card->ports = n_ports; // use it.␊ |
2152 | ␉␉verbose("Number of ports set to: %d using AtiPorts=%d\n", card->ports, card->ports);␊ |
2153 | ␉}␊ |
2154 | ␉else// if (card->cfg_name > 0) // do we want 0 ports if fb is kNull or mistyped ?␊ |
2155 | ␉{␊ |
2156 | ␉␉// else, match fb name with card_configs list and retrive default nr of ports.␊ |
2157 | ␉␉for (i = 0; i < kCfgEnd; i++)␊ |
2158 | ␉␉␉if (strcmp(card->cfg_name, card_configs[i].name) == 0)␊ |
2159 | ␉␉␉{␊ |
2160 | ␉␉␉␉card->ports = card_configs[i].ports; // default␊ |
2161 | ␉␉␉}␊ |
2162 | ␊ |
2163 | ␉␉verbose("Number of ports set to: %d using framebuffer's default.\n", card->ports);␊ |
2164 | ␉}␊ |
2165 | //␉else␊ |
2166 | //␉␉card->ports = 2/1 ?; // set a min if 0 ports ?␊ |
2167 | //␉␉verbose("Nr of ports set to min: %d\n", card->ports);␊ |
2168 | ␊ |
2169 | ␉sprintf(name, "ATY,%s", card->cfg_name);␊ |
2170 | ␉aty_name.type = kStr;␊ |
2171 | ␉aty_name.size = strlen(name) + 1;␊ |
2172 | ␉aty_name.data = (uint8_t *)name;␊ |
2173 | ␉␊ |
2174 | ␉sprintf(name_parent, "ATY,%sParent", card->cfg_name);␊ |
2175 | ␉aty_nameparent.type = kStr;␊ |
2176 | ␉aty_nameparent.size = strlen(name_parent) + 1;␊ |
2177 | ␉aty_nameparent.data = (uint8_t *)name_parent;␊ |
2178 | ␉␊ |
2179 | ␉return true;␊ |
2180 | }␊ |
2181 | ␊ |
2182 | bool setup_ati_devprop(pci_dt_t *ati_dev)␊ |
2183 | {␊ |
2184 | ␉char *devicepath;␊ |
2185 | ␊ |
2186 | ␉if (!init_card(ati_dev))␊ |
2187 | ␉{␊ |
2188 | ␉␉return false;␊ |
2189 | ␉}␊ |
2190 | ␊ |
2191 | ␉// -------------------------------------------------␊ |
2192 | ␉// Find a better way to do this (in device_inject.c)␊ |
2193 | ␉if (!string)␊ |
2194 | ␉{␊ |
2195 | ␉␉string = devprop_create_string();␊ |
2196 | ␉}␊ |
2197 | ␉devicepath = get_pci_dev_path(ati_dev);␊ |
2198 | ␉card->device = devprop_add_device(string, devicepath);␊ |
2199 | ␉if (!card->device)␊ |
2200 | ␉{␊ |
2201 | ␉␉return false;␊ |
2202 | ␉}␊ |
2203 | ␉// -------------------------------------------------␊ |
2204 | ␉␊ |
2205 | #if 0␊ |
2206 | ␉uint64_t fb␉= (uint32_t)card->fb;␊ |
2207 | ␉uint64_t mmio␉= (uint32_t)card->mmio;␊ |
2208 | ␉uint64_t io␉= (uint32_t)card->io;␊ |
2209 | ␉devprop_add_value(card->device, "ATY,FrameBufferOffset", &fb, 8);␊ |
2210 | ␉devprop_add_value(card->device, "ATY,RegisterSpaceOffset", &mmio, 8);␊ |
2211 | ␉devprop_add_value(card->device, "ATY,IOSpaceOffset", &io, 8);␊ |
2212 | #endif␊ |
2213 | ␉␊ |
2214 | ␉devprop_add_list(ati_devprop_list);␊ |
2215 | ␊ |
2216 | ␉// -------------------------------------------------␊ |
2217 | ␉// Find a better way to do this (in device_inject.c)␊ |
2218 | ␉//Azi: XXX tried to fix a malloc error in vain; this is related to XCode 4 compilation!␊ |
2219 | ␉stringdata = malloc(sizeof(uint8_t) * string->length);␊ |
2220 | ␉memcpy(stringdata, (uint8_t*)devprop_generate_string(string), string->length);␊ |
2221 | ␉stringlength = string->length;␊ |
2222 | ␉// -------------------------------------------------␊ |
2223 | ␉␊ |
2224 | ␉verbose("%s %dMB [%04x:%04x] (subsys [%04x:%04x]) (%s:%s) :: %s\n",␊ |
2225 | ␉␉␉card->info->model_name, (uint32_t)(card->vram_size / (1024 * 1024)),␊ |
2226 | ␉␉␉ati_dev->vendor_id, ati_dev->device_id,␊ |
2227 | ␉␉␉ati_dev->subsys_id.subsys.vendor_id, ati_dev->subsys_id.subsys.device_id,␊ |
2228 | ␉␉␉chip_family_name[card->info->chip_family], card->cfg_name, ␊ |
2229 | ␉␉␉devicepath);␊ |
2230 | ␉␊ |
2231 | ␉free(card);␊ |
2232 | ␉␊ |
2233 | ␉return true;␊ |
2234 | }␊ |
2235 | |