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 "libsa.h"␊ |
9 | #include "saio_internal.h"␊ |
10 | #include "bootstruct.h"␊ |
11 | #include "pci.h"␊ |
12 | #include "platform.h"␊ |
13 | #include "device_inject.h"␊ |
14 | #include "ati_reg.h"␊ |
15 | ␊ |
16 | #define OFFSET_TO_GET_ATOMBIOS_STRINGS_START 0x6e␊ |
17 | ␊ |
18 | #define kUseAtiROM␉␉␉␉"UseAtiROM"␊ |
19 | #define kAtiConfig␉␉␉␉"AtiConfig"␊ |
20 | #define kAtiPorts␉␉␉␉"AtiPorts"␊ |
21 | #define kATYbinimage␉␉␉␉"ATYbinimage"␊ |
22 | ␊ |
23 | #define Reg32(reg)␉␉␉␉(*(volatile uint32_t *)(card->mmio + reg))␊ |
24 | #define RegRead32(reg)␉␉␉(Reg32(reg))␊ |
25 | #define RegWrite32(reg, value)␉(Reg32(reg) = value)␊ |
26 | ␊ |
27 | typedef enum {␊ |
28 | ␉kNul,␊ |
29 | ␉kStr,␊ |
30 | ␉kPtr,␊ |
31 | ␉kCst␊ |
32 | } type_t;␊ |
33 | ␊ |
34 | typedef enum {␊ |
35 | ␉CHIP_FAMILY_UNKNOW,␊ |
36 | ␉/* IGP */␊ |
37 | ␉CHIP_FAMILY_RS600,␊ |
38 | ␉CHIP_FAMILY_RS690,␊ |
39 | ␉CHIP_FAMILY_RS740,␊ |
40 | ␉CHIP_FAMILY_RS780,␊ |
41 | ␉CHIP_FAMILY_RS880,␊ |
42 | ␉/* R600 */␊ |
43 | ␉CHIP_FAMILY_R600,␊ |
44 | ␉CHIP_FAMILY_RV610,␊ |
45 | ␉CHIP_FAMILY_RV620,␊ |
46 | ␉CHIP_FAMILY_RV630,␊ |
47 | ␉CHIP_FAMILY_RV635,␊ |
48 | ␉CHIP_FAMILY_RV670,␊ |
49 | ␉/* R700 */␊ |
50 | ␉CHIP_FAMILY_RV710,␊ |
51 | ␉CHIP_FAMILY_RV730,␊ |
52 | ␉CHIP_FAMILY_RV740,␊ |
53 | ␉CHIP_FAMILY_RV770,␊ |
54 | ␉CHIP_FAMILY_RV772,␊ |
55 | ␉CHIP_FAMILY_RV790,␊ |
56 | ␉/* Evergreen */␊ |
57 | ␉CHIP_FAMILY_CEDAR,␊ |
58 | ␉CHIP_FAMILY_CYPRESS,␊ |
59 | ␉CHIP_FAMILY_HEMLOCK,␊ |
60 | ␉CHIP_FAMILY_JUNIPER,␊ |
61 | ␉CHIP_FAMILY_REDWOOD,␊ |
62 | ␉CHIP_FAMILY_BROADWAY,␊ |
63 | ␉/* Northern Islands */␊ |
64 | ␉CHIP_FAMILY_ANTILLES,␊ |
65 | ␉CHIP_FAMILY_BARTS,␊ |
66 | ␉CHIP_FAMILY_CAICOS,␊ |
67 | ␉CHIP_FAMILY_CAYMAN,␊ |
68 | ␉CHIP_FAMILY_TURKS,␊ |
69 | ␉/* Southern Islands */␊ |
70 | ␉CHIP_FAMILY_TAHITI,␊ |
71 | ␉CHIP_FAMILY_PITCAIRN,␊ |
72 | ␉CHIP_FAMILY_CAPEVERDE,␊ |
73 | //␉CHIP_FAMILY_THAMES,␊ |
74 | //␉CHIP_FAMILY_LOMBOK,␊ |
75 | //␉CHIP_FAMILY_NEWZEALAND,␊ |
76 | ␉CHIP_FAMILY_LAST␊ |
77 | } chip_family_t;␊ |
78 | ␊ |
79 | static const char *chip_family_name[] = {␊ |
80 | ␉"UNKNOW",␊ |
81 | ␉/* IGP */␊ |
82 | ␉"RS600",␊ |
83 | ␉"RS690",␊ |
84 | ␉"RS740",␊ |
85 | ␉"RS780",␊ |
86 | ␉"RS880",␊ |
87 | ␉/* R600 */␊ |
88 | ␉"R600",␊ |
89 | ␉"RV610",␊ |
90 | ␉"RV620",␊ |
91 | ␉"RV630",␊ |
92 | ␉"RV635",␊ |
93 | ␉"RV670",␊ |
94 | ␉/* R700 */␊ |
95 | ␉"RV710",␊ |
96 | ␉"RV730",␊ |
97 | ␉"RV740",␊ |
98 | ␉"RV772",␊ |
99 | ␉"RV770",␊ |
100 | ␉"RV790",␊ |
101 | ␉/* Evergreen */␊ |
102 | ␉"Cedar",␊ |
103 | ␉"Cypress",␊ |
104 | ␉"Hemlock",␊ |
105 | ␉"Juniper",␊ |
106 | ␉"Redwood",␊ |
107 | ␉"Broadway",␊ |
108 | ␉/* Northern Islands */␊ |
109 | ␉"Antilles",␊ |
110 | ␉"Barts",␊ |
111 | ␉"Caicos",␊ |
112 | ␉"Cayman",␊ |
113 | ␉"Turks",␊ |
114 | ␉/* Southern Islands */␊ |
115 | ␉"Tahiti",␊ |
116 | ␉"Pitcairn",␊ |
117 | ␉"CapeVerde",␊ |
118 | //␉"Thames",␊ |
119 | //␉"Lombok",␊ |
120 | //␉"NewZealand",␊ |
121 | ␉""␊ |
122 | };␊ |
123 | ␊ |
124 | typedef struct {␊ |
125 | ␉const char␉␉*name;␊ |
126 | ␉uint8_t␉␉␉ports;␊ |
127 | } card_config_t;␊ |
128 | ␊ |
129 | static card_config_t card_configs[] = {␊ |
130 | ␉{NULL,␉␉␉0},␊ |
131 | ␉{"Alopias",␉␉2},␊ |
132 | ␉{"Alouatta",␉␉4},␊ |
133 | ␉{"Baboon",␉␉3},␊ |
134 | ␉{"Cardinal",␉␉2},␊ |
135 | ␉{"Caretta",␉␉1},␊ |
136 | ␉{"Colobus",␉␉2},␊ |
137 | ␉{"Douc",␉␉2},␊ |
138 | ␉{"Eulemur",␉␉3},␊ |
139 | ␉{"Flicker",␉␉3},␊ |
140 | ␉{"Galago",␉␉2},␊ |
141 | ␉{"Gliff",␉␉3},␊ |
142 | ␉{"Hoolock",␉␉3},␊ |
143 | ␉{"Hypoprion",␉␉2},␊ |
144 | ␉{"Iago",␉␉2},␊ |
145 | ␉{"Kakapo",␉␉3},␊ |
146 | ␉{"Kipunji",␉␉4},␊ |
147 | ␉{"Lamna",␉␉2},␊ |
148 | ␉{"Langur",␉␉3},␊ |
149 | ␉{"Megalodon",␉␉3},␊ |
150 | ␉{"Motmot",␉␉2},␊ |
151 | ␉{"Nomascus",␉␉5},␊ |
152 | ␉{"Orangutan",␉␉2},␊ |
153 | ␉{"Peregrine",␉␉2},␊ |
154 | ␉{"Quail",␉␉3},␊ |
155 | ␉{"Raven",␉␉3},␊ |
156 | ␉{"Shrike",␉␉3},␊ |
157 | ␉{"Sphyrna",␉␉1},␊ |
158 | ␉{"Triakis",␉␉2},␊ |
159 | ␉{"Uakari",␉␉4},␊ |
160 | ␉{"Vervet",␉␉4},␊ |
161 | ␉{"Zonalis",␉␉6},␊ |
162 | ␉{"Pithecia",␉␉3},␊ |
163 | ␉{"Bulrushes",␉␉6},␊ |
164 | ␉{"Cattail",␉␉4},␊ |
165 | ␉{"Hydrilla",␉␉5},␊ |
166 | ␉{"Duckweed",␉␉4},␊ |
167 | ␉{"Fanwort",␉␉4},␊ |
168 | ␉{"Elodea",␉␉5},␊ |
169 | ␉{"Kudzu",␉␉2},␊ |
170 | ␉{"Gibba",␉␉5},␊ |
171 | ␉{"Lotus",␉␉3},␊ |
172 | ␉{"Ipomoea",␉␉3},␊ |
173 | ␉{"Mangabey",␉␉2},␊ |
174 | ␉{"Muskgrass",␉␉4},␊ |
175 | ␉{"Juncus",␉␉4}␊ |
176 | };␊ |
177 | ␊ |
178 | typedef enum {␊ |
179 | ␉kNull,␊ |
180 | ␉kAlopias,␊ |
181 | ␉kAlouatta,␊ |
182 | ␉kBaboon,␊ |
183 | ␉kCardinal,␊ |
184 | ␉kCaretta,␊ |
185 | ␉kColobus,␊ |
186 | ␉kDouc,␊ |
187 | ␉kEulemur,␊ |
188 | ␉kFlicker,␊ |
189 | ␉kGalago,␊ |
190 | ␉kGliff,␊ |
191 | ␉kHoolock,␊ |
192 | ␉kHypoprion,␊ |
193 | ␉kIago,␊ |
194 | ␉kKakapo,␊ |
195 | ␉kKipunji,␊ |
196 | ␉kLamna,␊ |
197 | ␉kLangur,␊ |
198 | ␉kMegalodon,␊ |
199 | ␉kMotmot,␊ |
200 | ␉kNomascus,␊ |
201 | ␉kOrangutan,␊ |
202 | ␉kPeregrine,␊ |
203 | ␉kQuail,␊ |
204 | ␉kRaven,␊ |
205 | ␉kShrike,␊ |
206 | ␉kSphyrna,␊ |
207 | ␉kTriakis,␊ |
208 | ␉kUakari,␊ |
209 | ␉kVervet,␊ |
210 | ␉kZonalis,␊ |
211 | ␉kPithecia,␊ |
212 | ␉kBulrushes,␊ |
213 | ␉kCattail,␊ |
214 | ␉kHydrilla,␊ |
215 | ␉kDuckweed,␊ |
216 | ␉kFanwort,␊ |
217 | ␉kElodea,␊ |
218 | ␉kKudzu,␊ |
219 | ␉kGibba,␊ |
220 | ␉kLotus,␊ |
221 | ␉kIpomoea,␊ |
222 | ␉kMangabey,␊ |
223 | ␉kMuskgrass,␊ |
224 | ␉kJuncus,␊ |
225 | ␉kCfgEnd␊ |
226 | } config_name_t;␊ |
227 | ␊ |
228 | typedef struct {␊ |
229 | ␉uint16_t␉␉␉␉device_id;␊ |
230 | ␉uint32_t␉␉␉␉subsys_id;␊ |
231 | ␉chip_family_t␉␉␉chip_family;␊ |
232 | ␉const char␉␉␉␉*model_name;␊ |
233 | ␉config_name_t␉␉␉cfg_name;␊ |
234 | ␉uint8_t␉␉␉␉max_ports;␊ |
235 | } radeon_card_info_t;␊ |
236 | ␊ |
237 | static radeon_card_info_t radeon_cards[] = {␊ |
238 | ␉␊ |
239 | ␉// Earlier cards are not supported␊ |
240 | ␉//␊ |
241 | ␉// Layout is device_id, subsys_id (subsystem id plus vendor id), chip_family_name, display name, frame buffer␊ |
242 | ␉// Cards are grouped by device id and vendor id then sorted by subsystem id to make it easier to add new cards␊ |
243 | ␉// ␊ |
244 | ␉{ 0x9400,␉0x25521002, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 XT",␉␉␉kNull␉␉, 0 },␊ |
245 | ␉{ 0x9400,␉0x30001002, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 PRO",␉␉␉kNull␉␉, 0 },␊ |
246 | ␊ |
247 | ␉{ 0x9440,␉0x0851174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870",␉␉␉␉kMotmot␉␉, 0 },␊ |
248 | ␉{ 0x9440,␉0x114A174B, CHIP_FAMILY_RV770,␉␉"Sapphire Radeon HD4870 Vapor-X",␉␉kCardinal␉, 0 },␊ |
249 | ␉{ 0x9440,␉0x24401682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870",␉␉␉␉kMotmot␉␉, 0 },␊ |
250 | ␉{ 0x9440,␉0x24411682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870",␉␉␉␉kMotmot␉␉, 0 },␊ |
251 | ␉{ 0x9440,␉0x24441682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870",␉␉␉␉kMotmot␉␉, 0 },␊ |
252 | ␉{ 0x9440,␉0x24451682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870",␉␉␉␉kMotmot␉␉, 0 },␊ |
253 | ␊ |
254 | ␉{ 0x9441,␉0x24401682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870 X2",␉␉␉kMotmot␉␉, 0 },␊ |
255 | ␊ |
256 | ␉{ 0x9442,␉0x080110B0, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850",␉␉␉␉kMotmot␉␉, 0 },␊ |
257 | ␉{ 0x9442,␉0x24701682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850",␉␉␉␉kMotmot␉␉, 0 },␊ |
258 | ␉{ 0x9442,␉0x24711682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850",␉␉␉␉kMotmot␉␉, 0 },␊ |
259 | ␉{ 0x9442,␉0xE104174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850",␉␉␉␉kMotmot␉␉, 0 },␊ |
260 | ␊ |
261 | ␉{ 0x944A,␉0x30001043, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
262 | ␉{ 0x944A,␉0x30001458, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
263 | ␉{ 0x944A,␉0x30001462, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
264 | ␉{ 0x944A,␉0x30001545, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
265 | ␉{ 0x944A,␉0x30001682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
266 | ␉{ 0x944A,␉0x3000174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
267 | ␉{ 0x944A,␉0x30001787, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
268 | ␉{ 0x944A,␉0x300017AF, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
269 | ␊ |
270 | ␉{ 0x944C,␉0x24801682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4830",␉␉␉␉kMotmot␉␉, 0 },␊ |
271 | ␉{ 0x944C,␉0x24811682, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4830",␉␉␉␉kMotmot␉␉, 0 },␊ |
272 | ␊ |
273 | ␉{ 0x944E,␉0x3260174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4810 Series",␉␉␉kMotmot␉␉, 0 },␊ |
274 | ␉{ 0x944E,␉0x3261174B, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4810 series",␉␉␉kMotmot␉␉, 0 },␊ |
275 | ␉{ 0x944E,␉0x30001787, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4730 Series",␉␉␉kMotmot␉␉, 0 },␊ |
276 | ␉{ 0x944E,␉0x30101787, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4810 Series",␉␉␉kMotmot␉␉, 0 },␊ |
277 | ␉{ 0x944E,␉0x31001787, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4820",␉␉␉␉kMotmot␉␉, 0 },␊ |
278 | ␉␊ |
279 | ␉{ 0x9480,␉0x3628103C, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650M",␉␉␉␉kGliff␉␉, 0 },␊ |
280 | ␉{ 0x9480,␉0x9035104D, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650M",␉␉␉␉kGliff␉␉, 0 },␊ |
281 | ␊ |
282 | ␉{ 0x9490,␉0x4710174B, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4710",␉␉␉␉kNull␉␉, 0 },␊ |
283 | ␉{ 0x9490,␉0x20031787, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4670",␉␉␉␉kFlicker␉, 0 },␊ |
284 | ␉{ 0x9490,␉0x30501787, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4710",␉␉␉␉kNull␉␉, 0 },␊ |
285 | ␉{ 0x9490,␉0x300017AF, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4710",␉␉␉␉kNull␉␉, 0 },␊ |
286 | ␉␊ |
287 | ␉{ 0x9498,␉0x21CF1458, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600 Series",␉␉␉kNull␉␉, 0 },␊ |
288 | ␉{ 0x9498,␉0x24511682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650",␉␉␉␉kNull␉␉, 0 },␊ |
289 | ␉{ 0x9498,␉0x24521682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650",␉␉␉␉kNull␉␉, 0 },␊ |
290 | ␉{ 0x9498,␉0x24541682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4650",␉␉␉␉kNull␉␉, 0 },␊ |
291 | ␉{ 0x9498,␉0x29331682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4670",␉␉␉␉kNull␉␉, 0 },␊ |
292 | ␉{ 0x9498,␉0x29341682, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4670",␉␉␉␉kNull␉␉, 0 },␊ |
293 | ␉{ 0x9498,␉0x30501787, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4700",␉␉␉␉kNull␉␉, 0 },␊ |
294 | ␉{ 0x9498,␉0x31001787, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4720",␉␉␉␉kNull␉␉, 0 },␊ |
295 | ␉␊ |
296 | ␉{ 0x94B3,␉0x0D001002, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770",␉␉␉␉kFlicker␉, 0 },␊ |
297 | ␉{ 0x94B3,␉0x29001682, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770",␉␉␉␉kFlicker␉, 0 },␊ |
298 | ␉{ 0x94B3,␉0x1170174B, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770",␉␉␉␉kFlicker␉, 0 },␊ |
299 | ␉␊ |
300 | ␉{ 0x94C1,␉0x0D021002, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT",␉␉␉kNull␉␉, 0 },␊ |
301 | ␉{ 0x94C1,␉0x10021002, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Pro",␉␉␉kNull␉␉, 0 },␊ |
302 | ␉{ 0x94C1,␉0x0D021028, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT",␉␉␉kNull␉␉, 0 },␊ |
303 | ␉{ 0x94C1,␉0x21741458, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT",␉␉␉kNull␉␉, 0 },␊ |
304 | ␉{ 0x94C1,␉0x10331462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT",␉␉␉kNull␉␉, 0 },␊ |
305 | ␉{ 0x94C1,␉0x10401462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT",␉␉␉kNull␉␉, 0 },␊ |
306 | ␉{ 0x94C1,␉0x11101462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 XT",␉␉␉kNull␉␉, 0 },␊ |
307 | ␉␊ |
308 | ␉{ 0x94C3,␉0x03421002, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
309 | ␉{ 0x94C3,␉0x30001025, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350 Series",␉␉␉kNull␉␉, 0 },␊ |
310 | ␉{ 0x94C3,␉0x03021028, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
311 | ␉{ 0x94C3,␉0x04021028, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
312 | ␉{ 0x94C3,␉0x216A1458, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
313 | ␉{ 0x94C3,␉0x21721458, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
314 | ␉{ 0x94C3,␉0x30001458, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 3410",␉␉␉␉kNull␉␉, 0 },␊ |
315 | ␉{ 0x94C3,␉0x10321462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
316 | ␉{ 0x94C3,␉0x10411462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400",␉␉␉␉kNull␉␉, 0 },␊ |
317 | ␉{ 0x94C3,␉0x11041462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400",␉␉␉␉kNull␉␉, 0 },␊ |
318 | ␉{ 0x94C3,␉0x11051462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400",␉␉␉␉kNull␉␉, 0 },␊ |
319 | ␉{ 0x94C3,␉0x30001462, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 3410",␉␉␉␉kNull␉␉, 0 },␊ |
320 | ␉{ 0x94C3,␉0x2247148C, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 LE",␉␉␉kNull␉␉, 0 },␊ |
321 | ␉{ 0x94C3,␉0x3000148C, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350 Series",␉␉␉kNull␉␉, 0 },␊ |
322 | ␉{ 0x94C3,␉0x30001642, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 3410",␉␉␉␉kNull␉␉, 0 },␊ |
323 | ␉{ 0x94C3,␉0x37161642, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
324 | ␉{ 0x94C3,␉0x3000174B, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350 Series",␉␉␉kNull␉␉, 0 },␊ |
325 | ␉{ 0x94C3,␉0xE370174B, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
326 | ␉{ 0x94C3,␉0xE400174B, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
327 | ␉{ 0x94C3,␉0x203817AF, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400",␉␉␉␉kNull␉␉, 0 },␊ |
328 | ␉{ 0x94C3,␉0x22471787, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 LE",␉␉␉kNull␉␉, 0 },␊ |
329 | ␉{ 0x94C3,␉0x30001787, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350 Series",␉␉␉kNull␉␉, 0 },␊ |
330 | ␉{ 0x94C3,␉0x01011A93, CHIP_FAMILY_RV610,␉␉"Qimonda Radeon HD 2400 PRO",␉␉␉kNull␉␉, 0 },␊ |
331 | ␉␊ |
332 | ␉{ 0x9501,␉0x25421002, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3870",␉␉␉␉kNull␉␉, 0 },␊ |
333 | ␉{ 0x9501,␉0x30001002, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3690",␉␉␉␉kNull␉␉, 0 },␊ |
334 | ␉{ 0x9501,␉0x3000174B, CHIP_FAMILY_RV670,␉␉"Sapphire Radeon HD 3690",␉␉␉kNull␉␉, 0 },␊ |
335 | ␉{ 0x9501,␉0x4750174B, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750",␉␉␉␉kNull␉␉, 0 },␊ |
336 | ␉{ 0x9501,␉0x30001787, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3690",␉␉␉␉kNull␉␉, 0 },␊ |
337 | ␉␊ |
338 | ␉{ 0x9505,␉0x25421002, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3850",␉␉␉␉kNull␉␉, 0 },␊ |
339 | ␉{ 0x9505,␉0x30001002, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3690",␉␉␉␉kNull␉␉, 0 },␊ |
340 | ␉{ 0x9505,␉0x30011043, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4730",␉␉␉␉kNull␉␉, 0 },␊ |
341 | ␉{ 0x9505,␉0x3000148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3850",␉␉␉␉kNull␉␉, 0 },␊ |
342 | ␉{ 0x9505,␉0x3001148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4730",␉␉␉␉kNull␉␉, 0 },␊ |
343 | ␉{ 0x9505,␉0x3002148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4730",␉␉␉␉kNull␉␉, 0 },␊ |
344 | ␉{ 0x9505,␉0x3003148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750",␉␉␉␉kNull␉␉, 0 },␊ |
345 | ␉{ 0x9505,␉0x3004148C, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750",␉␉␉␉kNull␉␉, 0 },␊ |
346 | ␉{ 0x9505,␉0x3000174B, CHIP_FAMILY_RV670,␉␉"Sapphire Radeon HD 3690",␉␉␉kNull␉␉, 0 },␊ |
347 | ␉{ 0x9505,␉0x3001174B, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750",␉␉␉␉kNull␉␉, 0 },␊ |
348 | ␉{ 0x9505,␉0x3010174B, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750",␉␉␉␉kNull␉␉, 0 },␊ |
349 | ␉{ 0x9505,␉0x4730174B, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4730",␉␉␉␉kNull␉␉, 0 },␊ |
350 | ␉{ 0x9505,␉0x30001787, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 3690",␉␉␉␉kNull␉␉, 0 },␊ |
351 | ␉{ 0x9505,␉0x301017AF, CHIP_FAMILY_RV670,␉␉"ATI Radeon HD 4750",␉␉␉␉kNull␉␉, 0 },␊ |
352 | ␉␊ |
353 | ␉{ 0x9540,␉0x4590174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4590",␉␉␉␉kNull␉␉, 0 },␊ |
354 | ␉{ 0x9540,␉0x30501787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4590",␉␉␉␉kNull␉␉, 0 },␊ |
355 | ␊ |
356 | ␉{ 0x954F,␉0x16131462, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4550",␉␉␉␉kNull␉␉, 0 },␊ |
357 | ␉{ 0x954F,␉0x20081787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4350",␉␉␉␉kNull␉␉, 0 },␊ |
358 | ␉{ 0x954F,␉0x29201682, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4550",␉␉␉␉kNull␉␉, 0 },␊ |
359 | ␉{ 0x954F,␉0x29211682, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4550",␉␉␉␉kNull␉␉, 0 },␊ |
360 | ␉{ 0x954F,␉0x30901682, CHIP_FAMILY_RV710,␉␉"XFX Radeon HD 4570",␉␉␉␉kNull␉␉, 0 },␊ |
361 | ␉{ 0x954F,␉0x30501787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4450",␉␉␉␉kNull␉␉, 0 },␊ |
362 | ␉{ 0x954F,␉0x31001787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4520",␉␉␉␉kNull␉␉, 0 },␊ |
363 | ␉{ 0x954F,␉0x3000174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4520",␉␉␉␉kNull␉␉, 0 },␊ |
364 | ␉{ 0x954F,␉0x301017AF, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4450",␉␉␉␉kNull␉␉, 0 },␊ |
365 | ␉{ 0x954F,␉0x4450174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4450",␉␉␉␉kNull␉␉, 0 },␊ |
366 | ␉{ 0x954F,␉0x4570174B, CHIP_FAMILY_RV710,␉␉"Sapphire Radeon HD 4570",␉␉␉kNull␉␉, 0 },␊ |
367 | ␉{ 0x954F,␉0xE990174B, CHIP_FAMILY_RV710,␉␉"Sapphire Radeon HD 4350",␉␉␉kNull␉␉, 0 },␊ |
368 | ␊ |
369 | ␉{ 0x9552,␉0x04341028, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon 4330",␉␉␉kShrike␉␉, 0 },␊ |
370 | ␉{ 0x9552,␉0x308B103C, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4300 Series",␉␉kShrike␉␉, 0 },␊ |
371 | ␉{ 0x9552,␉0x3000148C, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500 Series",␉␉kNull␉␉, 0 },␊ |
372 | ␉{ 0x9552,␉0x3000174B, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500 Series",␉␉kNull␉␉, 0 },␊ |
373 | ␉{ 0x9552,␉0x30001787, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500 Series",␉␉kNull␉␉, 0 },␊ |
374 | ␉{ 0x9552,␉0x300017AF, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500 Series",␉␉kNull␉␉, 0 },␊ |
375 | ␊ |
376 | ␉{ 0x9553,␉0x18751043, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4570",␉␉␉kShrike␉␉, 0 },␊ |
377 | ␉{ 0x9553,␉0x1B321043, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4570",␉␉␉kShrike␉␉, 0 },␊ |
378 | ␊ |
379 | ␉{ 0x9581,␉0x95811002, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kNull␉␉, 0 },␊ |
380 | ␉{ 0x9581,␉0x3000148C, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kNull␉␉, 0 },␊ |
381 | ␊ |
382 | ␉{ 0x9583,␉0x3000148C, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kNull␉␉, 0 },␊ |
383 | ␊ |
384 | ␉{ 0x9588,␉0x01021A93, CHIP_FAMILY_RV630,␉␉"Qimonda Radeon HD 2600 XT",␉␉␉kNull␉␉, 0 },␊ |
385 | ␊ |
386 | ␉{ 0x9589,␉0x30001462, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3610",␉␉␉␉kNull␉␉, 0 },␊ |
387 | ␉{ 0x9589,␉0x0E41174B, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kNull␉␉, 0 },␊ |
388 | ␉{ 0x9589,␉0x30001787, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kNull␉␉, 0 },␊ |
389 | ␉{ 0x9589,␉0x01001A93, CHIP_FAMILY_RV630,␉␉"Qimonda Radeon HD 2600 PRO",␉␉␉kNull␉␉, 0 },␊ |
390 | ␊ |
391 | ␉{ 0x9591,␉0x2303148C, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3600 Series",␉␉␉kNull␉␉, 0 },␊ |
392 | ␊ |
393 | ␉{ 0x9598,␉0xB3831002, CHIP_FAMILY_RV635,␉␉"ATI All-in-Wonder HD",␉␉␉␉kNull␉␉, 0 },␊ |
394 | ␉{ 0x9598,␉0x30001043, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3730",␉␉␉␉kNull␉␉, 0 },␊ |
395 | ␉{ 0x9598,␉0x30011043, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4570",␉␉␉␉kNull␉␉, 0 },␊ |
396 | ␉{ 0x9598,␉0x3000148C, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3730",␉␉␉␉kNull␉␉, 0 },␊ |
397 | ␉{ 0x9598,␉0x3001148C, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4580",␉␉␉␉kNull␉␉, 0 },␊ |
398 | ␉{ 0x9598,␉0x3031148C, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4570",␉␉␉␉kNull␉␉, 0 },␊ |
399 | ␉{ 0x9598,␉0x30001545, CHIP_FAMILY_RV635,␉␉"VisionTek Radeon HD 2600 XT",␉␉␉kNull␉␉, 0 },␊ |
400 | ␉{ 0x9598,␉0x30011545, CHIP_FAMILY_RV635,␉␉"VisionTek Radeon HD 2600 Pro",␉␉␉kNull␉␉, 0 },␊ |
401 | ␉{ 0x9598,␉0x3000174B, CHIP_FAMILY_RV635,␉␉"Sapphire Radeon HD 3730",␉␉␉kNull␉␉, 0 },␊ |
402 | ␉{ 0x9598,␉0x3001174B, CHIP_FAMILY_RV635,␉␉"Sapphire Radeon HD 3750",␉␉␉kNull␉␉, 0 },␊ |
403 | ␉{ 0x9598,␉0x4570174B, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4570",␉␉␉␉kNull␉␉, 0 },␊ |
404 | ␉{ 0x9598,␉0x4580174B, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4580",␉␉␉␉kNull␉␉, 0 },␊ |
405 | ␉{ 0x9598,␉0x4610174B, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4610",␉␉␉␉kNull␉␉, 0 },␊ |
406 | ␉{ 0x9598,␉0x300117AF, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3750",␉␉␉␉kNull␉␉, 0 },␊ |
407 | ␉{ 0x9598,␉0x301017AF, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4570",␉␉␉␉kNull␉␉, 0 },␊ |
408 | ␉{ 0x9598,␉0x301117AF, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4580",␉␉␉␉kNull␉␉, 0 },␊ |
409 | ␉{ 0x9598,␉0x30501787, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 4610",␉␉␉␉kNull␉␉, 0 },␊ |
410 | ␊ |
411 | ␉{ 0x95C0,␉0x3000148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3550",␉␉␉␉kNull␉␉, 0 },␊ |
412 | ␉{ 0x95C0,␉0xE3901745, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3550",␉␉␉␉kNull␉␉, 0 },␊ |
413 | ␉{ 0x95C0,␉0x3000174B, CHIP_FAMILY_RV620,␉␉"Sapphire Radeon HD 3550",␉␉␉kNull␉␉, 0 },␊ |
414 | ␉{ 0x95C0,␉0x3002174B, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3570",␉␉␉␉kNull␉␉, 0 },␊ |
415 | ␉{ 0x95C0,␉0x3020174B, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250",␉␉␉␉kNull␉␉, 0 },␊ |
416 | ␊ |
417 | ␉{ 0x95C5,␉0x3000148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3450",␉␉␉␉kNull␉␉, 0 },␊ |
418 | ␉{ 0x95C5,␉0x3001148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 3550",␉␉␉␉kNull␉␉, 0 },␊ |
419 | ␉{ 0x95C5,␉0x3002148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4230",␉␉␉␉kNull␉␉, 0 },␊ |
420 | ␉{ 0x95C5,␉0x3003148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250",␉␉␉␉kNull␉␉, 0 },␊ |
421 | ␉{ 0x95C5,␉0x3032148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250",␉␉␉␉kNull␉␉, 0 },␊ |
422 | ␉{ 0x95C5,␉0x3033148C, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4230",␉␉␉␉kNull␉␉, 0 },␊ |
423 | ␉{ 0x95C5,␉0x3010174B, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250",␉␉␉␉kNull␉␉, 0 },␊ |
424 | ␉{ 0x95C5,␉0x4250174B, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250",␉␉␉␉kNull␉␉, 0 },␊ |
425 | ␉{ 0x95C5,␉0x30501787, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4250",␉␉␉␉kNull␉␉, 0 },␊ |
426 | ␉{ 0x95C5,␉0x301017AF, CHIP_FAMILY_RV620,␉␉"ATI Radeon HD 4230",␉␉␉␉kNull␉␉, 0 },␊ |
427 | ␉{ 0x95C5,␉0x01041A93, CHIP_FAMILY_RV620,␉␉"Qimonda Radeon HD 3450",␉␉␉kNull␉␉, 0 },␊ |
428 | ␉{ 0x95C5,␉0x01051A93, CHIP_FAMILY_RV620,␉␉"Qimonda Radeon HD 3450",␉␉␉kNull␉␉, 0 },␊ |
429 | ␊ |
430 | ␉/* Evergreen */␊ |
431 | ␉{ 0x6898,␉0x0B001002, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870",␉␉␉␉kZonalis␉, 0 },␊ |
432 | ␉{ 0x6898,␉0x032E1043, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870",␉␉␉␉kUakari␉␉, 0 },␊ |
433 | ␉{ 0x6898,␉0x00D0106B, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870",␉␉␉␉kLangur␉␉, 0 },␊ |
434 | ␉{ 0x6898,␉0xE140174B, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870",␉␉␉␉kUakari␉␉, 0 },␊ |
435 | ␉{ 0x6898,␉0x29611682, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5870",␉␉␉␉kUakari␉␉, 0 },␊ |
436 | ␊ |
437 | ␉{ 0x6899,␉0x21E41458, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5850",␉␉␉␉kUakari␉␉, 0 },␊ |
438 | ␉{ 0x6899,␉0xE140174B, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5850",␉␉␉␉kUakari␉␉, 0 },␊ |
439 | ␉{ 0x6899,␉0xE174174B, CHIP_FAMILY_CYPRESS,␉"ATI Sapphire Radeon HD 5850",␉␉␉kUakari␉␉, 0 },␊ |
440 | ␉{ 0x6899,␉0x200A1787, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5850",␉␉␉␉kUakari␉␉, 0 },␊ |
441 | ␉{ 0x6899,␉0x22901787, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5850",␉␉␉␉kUakari␉␉, 0 },␊ |
442 | ␊ |
443 | ␉{ 0x689C,␉0x03521043, CHIP_FAMILY_HEMLOCK,␉"ASUS ARES",␉␉␉␉␉kUakari␉␉, 0 },␊ |
444 | ␉{ 0x689C,␉0x039E1043, CHIP_FAMILY_HEMLOCK,␉"ASUS EAH5870 Series",␉␉␉␉kUakari␉␉, 0 },␊ |
445 | ␊ |
446 | ␉{ 0x689C,␉0x30201682, CHIP_FAMILY_HEMLOCK,␉"ATI Radeon HD 5970",␉␉␉␉kUakari␉␉, 0 },␊ |
447 | ␊ |
448 | ␉{ 0x68A0,␉0x043A1028, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5870",␉␉␉kNomascus␉, 0 },␊ |
449 | ␊ |
450 | ␉{ 0x68A1,␉0x144D103C, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kNomascus␉, 0 },␊ |
451 | ␉{ 0x68A1,␉0x1522103C, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5850",␉␉␉kHoolock␉, 0 },␊ |
452 | ␊ |
453 | ␉{ 0x68A8,␉0x050E1025, CHIP_FAMILY_CYPRESS,␉"AMD Radeon HD 6850M",␉␉␉␉kUakari␉␉, 0 },␊ |
454 | ␊ |
455 | ␉{ 0x68B8,␉0x00CF106B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kHoolock␉, 0 },␊ |
456 | ␉{ 0x68B8,␉0x21D71458, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kVervet␉␉, 0 },␊ |
457 | ␉{ 0x68B8,␉0x21F61458, CHIP_FAMILY_JUNIPER,␉"GigaByte HD5770 R577SL-1GD",␉␉␉kVervet␉␉, 0 },␊ |
458 | ␉{ 0x68B8,␉0x29901682, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kVervet␉␉, 0 },␊ |
459 | ␉{ 0x68B8,␉0x29911682, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kVervet␉␉, 0 },␊ |
460 | ␉{ 0x68B8,␉0x1482174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kVervet␉␉, 0 },␊ |
461 | ␉{ 0x68B8,␉0xE144174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kHoolock␉, 0 },␊ |
462 | ␉{ 0x68B8,␉0xE147174B, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kVervet␉␉, 0 },␊ |
463 | ␉{ 0x68B8,␉0x200A1787, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kVervet␉␉, 0 },␊ |
464 | ␉{ 0x68B8,␉0x200B1787, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kVervet␉␉, 0 },␊ |
465 | ␉{ 0x68B8,␉0x22881787, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5770",␉␉␉␉kVervet␉␉, 0 },␊ |
466 | ␊ |
467 | ␉{ 0x68BA,␉0x03FE1043, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770",␉␉␉␉kVervet␉␉, 0 },␊ |
468 | ␉{ 0x68BA,␉0x1482174B, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770",␉␉␉␉kVervet␉␉, 0 },␊ |
469 | ␉{ 0x68BA,␉0x174B1482, CHIP_FAMILY_JUNIPER,␉"ATI Sapphire Radeon HD 6770",␉␉kVervet␉␉, 0 },␊ |
470 | ␉{ 0x68BA,␉0x200A1787, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770",␉␉␉␉kVervet␉␉, 0 },␊ |
471 | ␉{ 0x68BA,␉0x21421462, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770",␉␉␉␉kVervet␉␉, 0 },␊ |
472 | ␉{ 0x68BA,␉0x31501682, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770",␉␉␉␉kVervet␉␉, 0 },␊ |
473 | ␉{ 0x68BA,␉0x31521682, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770",␉␉␉␉kVervet␉␉, 0 },␊ |
474 | ␉{ 0x68BA,␉0x31531682, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770",␉␉␉␉kVervet␉␉, 0 },␊ |
475 | ␉{ 0x68BA,␉0xE144174B, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6770",␉␉␉␉kVervet␉␉, 0 },␊ |
476 | ␊ |
477 | ␉{ 0x68BE,␉0x22881787, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5750",␉␉␉␉kVervet␉␉, 0 },␊ |
478 | ␊ |
479 | ␉{ 0x68BF,␉0x220E1458, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6750",␉␉␉␉kVervet␉␉, 0 },␊ |
480 | ␉{ 0x68BF,␉0x31401682, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6750",␉␉␉␉kVervet␉␉, 0 },␊ |
481 | ␊ |
482 | ␉{ 0x68C0,␉0x1594103C, CHIP_FAMILY_REDWOOD,␉"AMD Radeon HD 6570M",␉␉␉␉kNull␉␉, 0 },␊ |
483 | ␉{ 0x68C0,␉0x392717AA, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5730",␉␉␉kNull␉␉, 0 },␊ |
484 | ␉{ 0x68C0,␉0x395217AA, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5730",␉␉␉kNull␉␉, 0 },␊ |
485 | ␊ |
486 | ␉{ 0x68C1,␉0x02051025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
487 | ␉{ 0x68C1,␉0x02961025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
488 | ␉{ 0x68C1,␉0x030A1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
489 | ␉{ 0x68C1,␉0x033D1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
490 | ␉{ 0x68C1,␉0x033E1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kNull␉␉, 0 },␊ |
491 | ␉{ 0x68C1,␉0x03471025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
492 | ␉{ 0x68C1,␉0x03561025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
493 | ␉{ 0x68C1,␉0x03581025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
494 | ␉{ 0x68C1,␉0x035A1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
495 | ␉{ 0x68C1,␉0x035C1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
496 | ␉{ 0x68C1,␉0x03641025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
497 | ␉{ 0x68C1,␉0x03791025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
498 | ␉{ 0x68C1,␉0x037E1025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
499 | ␉{ 0x68C1,␉0x03821025, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5750",␉␉␉kNull␉␉, 0 },␊ |
500 | ␉{ 0x68C1,␉0x9071104D, CHIP_FAMILY_REDWOOD,␉"ATI Mobility Radeon HD 5650",␉␉␉kEulemur␉, 0 },␊ |
501 | ␊ |
502 | ␉{ 0x68C8,␉0x2306103C, CHIP_FAMILY_REDWOOD,␉"ATI FirePro V4800 (FireGL)",␉␉␉kNull␉␉, 0 },␊ |
503 | ␊ |
504 | ␉{ 0x68D8,␉0x03561043, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670",␉␉␉␉kBaboon␉␉, 0 },␊ |
505 | ␊ |
506 | ␉{ 0x68D8,␉0x21D91458, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670",␉␉␉␉kBaboon␉␉, 0 },␊ |
507 | ␉{ 0x68D8,␉0x5690174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5690",␉␉␉␉kNull␉␉, 0 },␊ |
508 | ␉{ 0x68D8,␉0x5730174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5730",␉␉␉␉kNull␉␉, 0 },␊ |
509 | ␉{ 0x68D8,␉0xE151174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5670",␉␉␉␉kEulemur␉, 0 },␊ |
510 | ␉{ 0x68D8,␉0x30001787, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5730",␉␉␉␉kNull␉␉, 0 },␊ |
511 | ␉{ 0x68D8,␉0x301017AF, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5730",␉␉␉␉kNull␉␉, 0 },␊ |
512 | ␉{ 0x68D8,␉0x301117AF, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5690",␉␉␉␉kNull␉␉, 0 },␊ |
513 | ␊ |
514 | ␉{ 0x68D9,␉0x301017AF, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5630",␉␉␉␉kNull␉␉, 0 },␊ |
515 | ␊ |
516 | ␉{ 0x68DA,␉0x5630174B, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5630",␉␉␉␉kNull␉␉, 0 },␊ |
517 | ␉{ 0x68DA,␉0x30001787, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5630",␉␉␉␉kNull␉␉, 0 },␊ |
518 | ␉{ 0x68DA,␉0x301017AF, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5630",␉␉␉␉kNull␉␉, 0 },␊ |
519 | ␊ |
520 | ␉{ 0x68E0,␉0x04561028, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M",␉␉␉␉kEulemur␉, 0 },␊ |
521 | ␉{ 0x68E0,␉0x1433103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470M",␉␉␉␉kEulemur␉, 0 },␊ |
522 | ␊ |
523 | ␉{ 0x68E1,␉0x1426103C, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5430M",␉␉␉␉kEulemur␉, 0 },␊ |
524 | ␊ |
525 | ␉{ 0x68E4,␉0x1426103C, CHIP_FAMILY_CEDAR,␉␉"AMD Radeon HD 6370M",␉␉␉␉kNull␉␉, 0 },␊ |
526 | ␉{ 0x68E4,␉0x397917AA, CHIP_FAMILY_CEDAR,␉␉"AMD Radeon HD 6370M",␉␉␉␉kNull␉␉, 0 },␊ |
527 | ␊ |
528 | ␉{ 0x68F9,␉0x010E1002, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450",␉␉␉␉kEulemur␉, 0 },␊ |
529 | ␉{ 0x68F9,␉0x03741043, CHIP_FAMILY_CEDAR,␉␉"ASUS EAH5450",␉␉␉␉␉kEulemur␉, 0 },␊ |
530 | ␉{ 0x68F9,␉0x03CA1043, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450",␉␉␉␉kEulemur␉, 0 },␊ |
531 | ␉{ 0x68F9,␉0x20091787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450",␉␉␉␉kEulemur␉, 0 },␊ |
532 | ␉{ 0x68F9,␉0x22911787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450",␉␉␉␉kEulemur␉, 0 },␊ |
533 | ␉{ 0x68F9,␉0x23401462, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450",␉␉␉␉kEulemur␉, 0 },␊ |
534 | ␉{ 0x68F9,␉0x30001787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470",␉␉␉␉kNull␉␉, 0 },␊ |
535 | ␉{ 0x68F9,␉0x30011787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5530",␉␉␉␉kNull␉␉, 0 },␊ |
536 | ␉{ 0x68F9,␉0x30021787, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5490",␉␉␉␉kNull␉␉, 0 },␊ |
537 | ␉{ 0x68F9,␉0x301117AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470",␉␉␉␉kNull␉␉, 0 },␊ |
538 | ␉{ 0x68F9,␉0x301217AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5490",␉␉␉␉kNull␉␉, 0 },␊ |
539 | ␉{ 0x68F9,␉0x301317AF, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470",␉␉␉␉kNull␉␉, 0 },␊ |
540 | ␉{ 0x68F9,␉0x5470174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5470",␉␉␉␉kNull␉␉, 0 },␊ |
541 | ␉{ 0x68F9,␉0x5490174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5490",␉␉␉␉kNull␉␉, 0 },␊ |
542 | ␉{ 0x68F9,␉0x5530174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5530",␉␉␉␉kNull␉␉, 0 },␊ |
543 | ␉{ 0x68F9,␉0xE145174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450",␉␉␉␉kEulemur␉, 0 },␊ |
544 | ␉{ 0x68F9,␉0xE153174B, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5450",␉␉␉␉kEulemur␉, 0 },␊ |
545 | ␊ |
546 | ␉/* Northen Islands */␊ |
547 | ␉{ 0x6718,␉0x0B001002, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970",␉␉␉␉kGibba␉␉, 0 },␊ |
548 | ␉{ 0x6718,␉0x20101458, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970",␉␉␉␉kGibba␉␉, 0 },␊ |
549 | ␉{ 0x6718,␉0x22001458, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970",␉␉␉␉kGibba␉␉, 0 },␊ |
550 | ␉{ 0x6718,␉0x23061787, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970",␉␉␉␉kGibba␉␉, 0 },␊ |
551 | ␉{ 0x6718,␉0x23701462, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970",␉␉␉␉kGibba␉␉, 0 },␊ |
552 | ␉{ 0x6718,␉0x31301682, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970",␉␉␉␉kGibba␉␉, 0 },␊ |
553 | ␉{ 0x6718,␉0x67181002, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970",␉␉␉␉kGibba␉␉, 0 },␊ |
554 | ␊ |
555 | ␉{ 0x6719,␉0x03D41043, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950",␉␉␉␉kNull␉␉, 0 },␊ |
556 | ␉{ 0x6719,␉0x0B001002, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950",␉␉␉␉kGibba␉␉, 0 },␊ |
557 | ␉{ 0x6719,␉0x186B174B, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950",␉␉␉␉kNull␉␉, 0 },␊ |
558 | ␉{ 0x6719,␉0x20101787, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950",␉␉␉␉kGibba␉␉, 0 },␊ |
559 | ␉{ 0x6719,␉0x21FD1458, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950",␉␉␉␉kGibba␉␉, 0 },␊ |
560 | ␉{ 0x6719,␉0x23071787, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950",␉␉␉␉kNull␉␉, 0 },␊ |
561 | ␊ |
562 | ␉{ 0x671D,␉0x0B2A1002, CHIP_FAMILY_ANTILLES,␉"AMD Radeon HD 6990",␉␉␉␉kNull␉␉, 0 },␊ |
563 | ␉{ 0x671D,␉0x1B2A1002, CHIP_FAMILY_ANTILLES,␉"AMD Radeon HD 6990",␉␉␉␉kNull␉␉, 0 },␊ |
564 | ␉{ 0x671D,␉0x31601682, CHIP_FAMILY_ANTILLES,␉"AMD Radeon HD 6990",␉␉␉␉kNull␉␉, 0 },␊ |
565 | ␊ |
566 | ␉{ 0x6720,␉0x04901028, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M",␉␉␉␉kElodea␉␉, 0 },␊ |
567 | ␉{ 0x6720,␉0x04BA1028, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6970M",␉␉␉␉kElodea␉␉, 0 },␊ |
568 | ␉{ 0x6720,␉0x51041558, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6990M",␉␉␉␉kElodea␉␉, 0 },␊ |
569 | ␊ |
570 | ␉{ 0x6738,␉0x00D01002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
571 | ␉{ 0x6738,␉0x03AE1043, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
572 | ␉{ 0x6738,␉0x03C61043, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
573 | ␉{ 0x6738,␉0x174B174B, CHIP_FAMILY_BARTS,␉␉"Sapphire Radeon HD6870",␉␉␉kBulrushes␉, 0 },␊ |
574 | ␉{ 0x6738,␉0x20101787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
575 | ␉{ 0x6738,␉0x21FA1002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
576 | ␉{ 0x6738,␉0x21FA1458, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
577 | ␉{ 0x6738,␉0x23051787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
578 | ␉{ 0x6738,␉0x25101462, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
579 | ␉{ 0x6738,␉0x31031682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
580 | ␉{ 0x6738,␉0x31041682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
581 | ␉{ 0x6738,␉0x31071682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
582 | ␉{ 0x6738,␉0x31081682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 }, // ?? kJuncus ??␊ |
583 | ␉{ 0x6738,␉0x67381002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
584 | ␉{ 0x6738,␉0xE178174B, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870",␉␉␉␉kDuckweed␉, 0 },␊ |
585 | ␊ |
586 | ␉{ 0x6739,␉0x03B41043, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850",␉␉␉␉kDuckweed␉, 0 },␊ |
587 | ␉{ 0x6739,␉0x21F81458, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850",␉␉␉␉kBulrushes␉, 0 },␊ |
588 | ␉{ 0x6739,␉0x23041787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850",␉␉␉␉kDuckweed␉, 0 },␊ |
589 | ␉{ 0x6739,␉0x24411462, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850",␉␉␉␉kDuckweed␉, 0 },␊ |
590 | ␉{ 0x6739,␉0x31101682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850",␉␉␉␉kDuckweed␉, 0 },␊ |
591 | ␉{ 0x6739,␉0x67391002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850",␉␉␉␉kDuckweed␉, 0 },␊ |
592 | ␉{ 0x6739,␉0xAA881002, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850",␉␉␉␉kDuckweed␉, 0 },␊ |
593 | ␉{ 0x6739,␉0xE177174B, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850",␉␉␉␉kDuckweed␉, 0 },␊ |
594 | ␊ |
595 | ␉{ 0x673E,␉0x174B174B, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790", kNull␉␉, 0 },␊ |
596 | ␉{ 0x673E,␉0x23101787, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790", kNull␉␉, 0 },␊ |
597 | ␉{ 0x673E,␉0x31701682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790", kNull␉␉, 0 },␊ |
598 | ␉{ 0x673E,␉0x31721682, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790", kNull␉␉, 0 },␊ |
599 | ␊ |
600 | ␉{ 0x6740,␉0x04A31028, CHIP_FAMILY_TURKS,␉␉"Dell HD 6770M", kNull␉␉, 0 }, // ??␊ |
601 | ␉{ 0x6740,␉0x1D121043, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6730M",␉␉␉␉kNull␉␉, 0 },␊ |
602 | ␉{ 0x6740,␉0x1631103C, CHIP_FAMILY_TURKS,␉␉"AMD FirePro M5950",␉␉␉␉kNull␉␉, 0 },␊ |
603 | ␉{ 0x6740,␉0x1657103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6770M",␉␉␉␉kNull␉␉, 0 },␊ |
604 | ␉{ 0x6740,␉0x165A103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6770M",␉␉␉␉kNull␉␉, 0 },␊ |
605 | ␉{ 0x6740,␉0x3388103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6770M",␉␉␉␉kNull␉␉, 0 },␊ |
606 | ␉{ 0x6740,␉0x3389103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6770M",␉␉␉␉kNull␉␉, 0 }, // ?? kHydrilla ??␊ |
607 | ␉{ 0x6740,␉0x6740106B, CHIP_FAMILY_TURKS,␉␉"Apple HD 6770M",␉␉␉␉kNull␉␉, 0 }, // ??␊ |
608 | ␊ |
609 | ␉{ 0x6741,␉0x050E1025, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6650M",␉␉␉␉kNull␉␉, 0 },␊ |
610 | ␉{ 0x6741,␉0x05131025, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6650M",␉␉␉␉kNull␉␉, 0 },␊ |
611 | ␉{ 0x6741,␉0x1646103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6750M",␉␉␉␉kNull␉␉, 0 },␊ |
612 | ␉{ 0x6741,␉0x1688103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 7690M",␉␉␉␉kNull␉␉, 0 },␊ |
613 | ␉{ 0x6741,␉0x358D103C, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6630M/6650M/6750M",␉␉kNull␉␉, 0 },␊ |
614 | ␉{ 0x6741,␉0x9080104D, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6630M",␉␉␉␉kNull␉␉, 0 },␊ |
615 | ␊ |
616 | ␉{ 0x6758,␉0x00121028, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670",␉␉␉␉kBulrushes␉, 0 },␊ |
617 | ␉{ 0x6758,␉0x22051458, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670",␉␉␉␉kBulrushes␉, 0 },␊ |
618 | ␉{ 0x6758,␉0x31811682, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670",␉␉␉␉kBulrushes␉, 0 },␊ |
619 | ␉{ 0x6758,␉0x31831682, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670",␉␉␉␉kBulrushes␉, 0 },␊ |
620 | ␉{ 0x6758,␉0x67581002, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670",␉␉␉␉kBulrushes␉, 0 },␊ |
621 | ␉{ 0x6758,␉0xE1941746, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670",␉␉␉␉kBulrushes␉, 0 },␊ |
622 | ␉{ 0x6758,␉0xE194174B, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670",␉␉␉␉kBulrushes␉, 0 },␊ |
623 | ␊ |
624 | ␉{ 0x6759,␉0x20121787, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6570",␉␉␉␉kPithecia␉, 0 },␊ |
625 | ␉{ 0x6759,␉0xE193174B, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6570",␉␉␉␉kNull␉␉, 0 },␊ |
626 | ␊ |
627 | ␉{ 0x6760,␉0x00031179, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M",␉␉␉␉kNull␉␉, 0 },␊ |
628 | ␉{ 0x6760,␉0x04C11028, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M",␉␉␉␉kNull␉␉, 0 },␊ |
629 | ␉{ 0x6760,␉0x04CA1028, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M",␉␉␉␉kNull␉␉, 0 },␊ |
630 | ␉{ 0x6760,␉0x04CC1028, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M",␉␉␉␉kNull␉␉, 0 },␊ |
631 | ␉{ 0x6760,␉0x101C1043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450M",␉␉␉␉kNull␉␉, 0 },␊ |
632 | ␉{ 0x6760,␉0x165A103C, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6470M",␉␉␉␉kNull␉␉, 0 },␊ |
633 | ␉{ 0x6760,␉0x167D103C, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6470M",␉␉␉␉kNull␉␉, 0 },␊ |
634 | ␉{ 0x6760,␉0x1CB21043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6470M",␉␉␉␉kNull␉␉, 0 },␊ |
635 | ␊ |
636 | ␉{ 0x6779,␉0x00001002, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
637 | ␉{ 0x6779,␉0x03DA1043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450", kBulrushes␉, 0 },␊ |
638 | ␉{ 0x6779,␉0x03DC1043, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
639 | ␉{ 0x6779,␉0x20121787, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
640 | ␉{ 0x6779,␉0x21201028, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
641 | ␉{ 0x6779,␉0x21251462, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
642 | ␉{ 0x6779,␉0x22031458, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
643 | ␉{ 0x6779,␉0x22041458, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
644 | ␉{ 0x6779,␉0x23111787, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
645 | ␉{ 0x6779,␉0x32001682, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
646 | ␉{ 0x6779,␉0x64501092, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
647 | ␉{ 0x6779,␉0x909D1B0A, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
648 | ␉{ 0x6779,␉0xE164174B, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
649 | ␉{ 0x6779,␉0xE180174B, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kPithecia␉, 0 },␊ |
650 | ␉{ 0x6779,␉0xE190174B, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
651 | ␉{ 0x6779,␉0xE199174B, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450",␉␉␉␉kBulrushes␉, 0 },␊ |
652 | ␊ |
653 | ␉/* Southen Islands */␊ |
654 | ␊ |
655 | ␉{ 0x6798,␉0x04181043, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kNull␉␉, 0 },␊ |
656 | ␉{ 0x6798,␉0x04201043, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kNull␉␉, 0 },␊ |
657 | ␉{ 0x6798,␉0x0B001002, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kNull␉␉, 0 },␊ |
658 | ␉{ 0x6798,␉0x201C1787, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kNull␉␉, 0 },␊ |
659 | ␉{ 0x6798,␉0x254D1458, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kNull␉␉, 0 },␊ |
660 | ␉{ 0x6798,␉0x32101682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kNull␉␉, 0 },␊ |
661 | ␉{ 0x6798,␉0x32111682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kNull␉␉, 0 },␊ |
662 | ␉{ 0x6798,␉0x32121682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kNull␉␉, 0 },␊ |
663 | ␉{ 0x6798,␉0x32131682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970", kNull␉␉, 0 },␊ |
664 | ␊ |
665 | ␉{ 0x679A,␉0x0B001002, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kNull␉␉, 0 },␊ |
666 | ␉{ 0x679A,␉0x23161787, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kNull␉␉, 0 },␊ |
667 | ␉{ 0x679A,␉0x254C1458, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kNull␉␉, 0 },␊ |
668 | ␉{ 0x679A,␉0x27601462, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kNull␉␉, 0 },␊ |
669 | ␉{ 0x679A,␉0x32211682, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kNull␉␉, 0 },␊ |
670 | ␉{ 0x679A,␉0xE207174B, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950", kNull␉␉, 0 },␊ |
671 | ␊ |
672 | ␉/* standard/default models */␊ |
673 | ␉{ 0x9400,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 XT",␉␉␉kNull␉␉, 0 },␊ |
674 | ␉{ 0x9405,␉0x00000000, CHIP_FAMILY_R600,␉␉"ATI Radeon HD 2900 GT",␉␉␉kNull␉␉, 0 },␊ |
675 | ␊ |
676 | ␉{ 0x9440,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
677 | ␉{ 0x9441,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4870 X2",␉␉␉kMotmot␉␉, 0 },␊ |
678 | ␉{ 0x9442,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
679 | ␉{ 0x9443,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4850 X2",␉␉␉kMotmot␉␉, 0 },␊ |
680 | ␉{ 0x944A,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
681 | ␉{ 0x944C,␉0x00000000, CHIP_FAMILY_RV770,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
682 | ␉{ 0x944E,␉0x00000000, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4700 Series",␉␉␉kMotmot␉␉, 0 },␊ |
683 | ␊ |
684 | ␉{ 0x9450,␉0x00000000, CHIP_FAMILY_RV770,␉␉"AMD FireStream 9270",␉␉␉␉kMotmot␉␉, 0 },␊ |
685 | ␉{ 0x9452,␉0x00000000, CHIP_FAMILY_RV770,␉␉"AMD FireStream 9250",␉␉␉␉kMotmot␉␉, 0 },␊ |
686 | ␊ |
687 | ␉{ 0x9460,␉0x00000000, CHIP_FAMILY_RV790,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
688 | ␉{ 0x9462,␉0x00000000, CHIP_FAMILY_RV790,␉␉"ATI Radeon HD 4800 Series",␉␉␉kMotmot␉␉, 0 },␊ |
689 | ␊ |
690 | ␉{ 0x9480,␉0x00000000, CHIP_FAMILY_RV730,␉␉"ATI Mobility Radeon HD 4650 Series",␉␉kGliff␉␉, 0 },␊ |
691 | ␊ |
692 | ␉{ 0x9490,␉0x00000000, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600 Series",␉␉␉kFlicker␉, 0 },␊ |
693 | ␉{ 0x9498,␉0x00000000, CHIP_FAMILY_RV730,␉␉"ATI Radeon HD 4600 Series",␉␉␉kFlicker␉, 0 },␊ |
694 | ␊ |
695 | ␉{ 0x94B3,␉0x00000000, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770",␉␉␉␉kFlicker␉, 0 },␊ |
696 | ␉{ 0x94B4,␉0x00000000, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4700 Series",␉␉␉kFlicker␉, 0 },␊ |
697 | ␉{ 0x94B5,␉0x00000000, CHIP_FAMILY_RV740,␉␉"ATI Radeon HD 4770",␉␉␉␉kFlicker␉, 0 },␊ |
698 | ␊ |
699 | ␉{ 0x94C1,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series",␉␉␉kIago␉␉, 0 },␊ |
700 | ␉{ 0x94C3,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series",␉␉␉kIago␉␉, 0 },␊ |
701 | ␉{ 0x94C7,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2350",␉␉␉␉kIago␉␉, 0 },␊ |
702 | ␉{ 0x94CC,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 2400 Series",␉␉␉kIago␉␉, 0 },␊ |
703 | ␊ |
704 | ␉{ 0x9501,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3800 Series",␉␉␉kMegalodon␉, 0 },␊ |
705 | ␉{ 0x9505,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3800 Series",␉␉␉kMegalodon␉, 0 },␊ |
706 | ␉{ 0x9507,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3830",␉␉␉␉kMegalodon␉, 0 },␊ |
707 | ␉{ 0x950F,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3870 X2",␉␉␉kMegalodon␉, 0 },␊ |
708 | ␊ |
709 | ␉{ 0x9513,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3850 X2",␉␉␉kMegalodon␉, 0 },␊ |
710 | ␉{ 0x9519,␉0x00000000, CHIP_FAMILY_RV630,␉␉"AMD FireStream 9170",␉␉␉␉kMegalodon␉, 0 },␊ |
711 | ␊ |
712 | ␉{ 0x9540,␉0x00000000, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4550",␉␉␉␉kNull␉␉, 0 },␊ |
713 | ␉{ 0x954F,␉0x00000000, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500 Series",␉␉kNull␉␉, 0 },␊ |
714 | ␊ |
715 | ␉{ 0x9552,␉0x00000000, CHIP_FAMILY_RV710,␉␉"ATI Radeon HD 4300/4500 Series",␉␉kShrike␉␉, 0 },␊ |
716 | ␉{ 0x9553,␉0x00000000, CHIP_FAMILY_RV710,␉␉"ATI Mobility Radeon HD 4500/5100 Series",␉kShrike ␉, 0 },␊ |
717 | ␊ |
718 | ␉{ 0x9581,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kNull␉␉, 0 },␊ |
719 | ␉{ 0x9583,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kNull␉␉, 0 },␊ |
720 | ␊ |
721 | ␉{ 0x9588,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600 XT",␉␉␉kNull␉␉, 0 },␊ |
722 | ␉{ 0x9589,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3610 Series",␉␉␉kNull␉␉, 0 },␊ |
723 | ␉{ 0x958A,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 2600 X2 Series",␉␉␉kLamna␉␉, 0 },␊ |
724 | ␊ |
725 | ␉{ 0x9591,␉0x00000000, CHIP_FAMILY_RV635,␉␉"ATI Radeon HD 3600 Series",␉␉␉kNull␉␉, 0 },␊ |
726 | ␉{ 0x9598,␉0x00000000, CHIP_FAMILY_RV630,␉␉"ATI Radeon HD 3600 Series",␉␉␉kMegalodon␉, 0 },␊ |
727 | ␊ |
728 | ␉{ 0x95C0,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 3400 Series",␉␉␉kIago␉␉, 0 },␊ |
729 | ␉{ 0x95C5,␉0x00000000, CHIP_FAMILY_RV610,␉␉"ATI Radeon HD 3400 Series",␉␉␉kIago␉␉, 0 },␊ |
730 | ␊ |
731 | ␉/* IGP */␊ |
732 | ␉{ 0x9610,␉0x00000000, CHIP_FAMILY_RS780,␉␉"ATI Radeon HD 3200 Graphics",␉␉␉kNull␉␉, 0 },␊ |
733 | ␉{ 0x9611,␉0x00000000, CHIP_FAMILY_RS780,␉␉"ATI Radeon 3100 Graphics",␉␉␉kNull␉␉, 0 },␊ |
734 | ␉{ 0x9614,␉0x00000000, CHIP_FAMILY_RS780,␉␉"ATI Radeon HD 3300 Graphics",␉␉␉kNull␉␉, 0 },␊ |
735 | ␉{ 0x9616,␉0x00000000, CHIP_FAMILY_RS780,␉␉"ATI Radeon 3000 Graphics",␉␉␉kNull␉␉, 0 },␊ |
736 | ␊ |
737 | ␉{ 0x9710,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 4200",␉␉␉␉kNull␉␉, 0 },␊ |
738 | ␉{ 0x9714,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 4290",␉␉␉␉kNull␉␉, 0 },␊ |
739 | ␉{ 0x9715,␉0x00000000, CHIP_FAMILY_RS880,␉␉"ATI Radeon HD 4250",␉␉␉␉kNull␉␉, 0 },␊ |
740 | ␊ |
741 | ␉/* Evergreen */␊ |
742 | ␉{ 0x688D,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"AMD FireStream 9350",␉␉␉␉kUakari␉␉, 0 },␊ |
743 | ␊ |
744 | ␉{ 0x6898,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5800 Series",␉␉␉kUakari␉␉, 0 },␊ |
745 | ␉{ 0x6899,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5800 Series",␉␉␉kUakari␉␉, 0 },␊ |
746 | ␊ |
747 | ␉{ 0x689C,␉0x00000000, CHIP_FAMILY_HEMLOCK,␉"ATI Radeon HD 5900 Series",␉␉␉kUakari␉␉, 0 },␊ |
748 | ␊ |
749 | ␉{ 0x689E,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Radeon HD 5800 Series",␉␉␉kUakari␉␉, 0 },␊ |
750 | ␊ |
751 | ␉{ 0x68A0,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5800 Series",␉␉kNomascus␉, 0 }, // CHIP_FAMILY_BROADWAY ??␊ |
752 | ␉{ 0x68A1,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5800 Series",␉␉kNomascus␉, 0 }, // CHIP_FAMILY_BROADWAY ??␊ |
753 | ␊ |
754 | ␉{ 0x68A8,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"AMD Mobility Radeon HD 6800 Series",␉␉kUakari␉␉, 0 }, ␊ |
755 | ␊ |
756 | ␉{ 0x68B0,␉0x00000000, CHIP_FAMILY_CYPRESS,␉"ATI Mobility Radeon HD 5800 Series",␉␉kNull␉␉, 0 }, // CHIP_FAMILY_BROADWAY ??␊ |
757 | ␊ |
758 | ␉{ 0x68B8,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5700 Series",␉␉␉kVervet␉␉, 0 },␊ |
759 | ␉{ 0x68B9,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5600 Series",␉␉␉kVervet␉␉, 0 },␊ |
760 | ␉{ 0x68BA,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 6700 Series",␉␉␉kVervet␉␉, 0 },␊ |
761 | ␊ |
762 | ␉{ 0x68BE,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"ATI Radeon HD 5700 Series",␉␉␉kVervet␉␉, 0 },␊ |
763 | ␉{ 0x68BF,␉0x00000000, CHIP_FAMILY_JUNIPER,␉"AMD Radeon HD 6700 Series",␉␉␉kVervet␉␉, 0 },␊ |
764 | ␊ |
765 | ␉{ 0x68C0,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"AMD Radeon HD 6570M/5700 Series",␉␉kNull␉␉, 0 },␊ |
766 | ␉{ 0x68C1,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"AMD Radeon HD 6500M/5600/5700 Series",␉␉kNull␉␉, 0 },␊ |
767 | ␊ |
768 | ␉{ 0x68D8,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5600 Series",␉␉␉kBaboon␉␉, 0 },␊ |
769 | ␉{ 0x68D9,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5500/5600 Series",␉␉kBaboon␉␉, 0 },␊ |
770 | ␉{ 0x68DA,␉0x00000000, CHIP_FAMILY_REDWOOD,␉"ATI Radeon HD 5500 Series",␉␉␉kBaboon␉␉, 0 },␊ |
771 | ␊ |
772 | ␉{ 0x68E0,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Mobility Radeon HD 5400 Series",␉␉kEulemur␉, 0 },␊ |
773 | ␉{ 0x68E1,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Mobility Radeon HD 5400 Series",␉␉kEulemur␉, 0 },␊ |
774 | ␊ |
775 | ␉{ 0x68E4,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 6300M Series",␉␉␉kNull␉␉, 0 },␊ |
776 | ␊ |
777 | ␉{ 0x68F9,␉0x00000000, CHIP_FAMILY_CEDAR,␉␉"ATI Radeon HD 5400 Series",␉␉␉kNull␉␉, 0 },␊ |
778 | ␊ |
779 | ␉/* Northen Islands */␊ |
780 | ␉{ 0x6718,␉0x00000000, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6970 Series",␉␉␉kNull␉␉, 0 },␊ |
781 | ␉{ 0x6719,␉0x00000000, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6950 Series",␉␉␉kGibba␉␉, 0 },␊ |
782 | ␊ |
783 | ␉{ 0x671D,␉0x00000000, CHIP_FAMILY_ANTILLES,␉"AMD Radeon HD 6900 Series",␉␉␉kNull␉␉, 0 },␊ |
784 | ␊ |
785 | ␉{ 0x671F,␉0x00000000, CHIP_FAMILY_CAYMAN,␉␉"AMD Radeon HD 6900 Series",␉␉␉kNull␉␉, 0 },␊ |
786 | ␊ |
787 | ␉{ 0x6720,␉0x00000000, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6900M Series",␉␉␉kNull␉␉, 0 },␊ |
788 | ␊ |
789 | ␉{ 0x6738,␉0x00000000, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6870 Series",␉␉␉kDuckweed␉, 0 },␊ |
790 | ␉{ 0x6739,␉0x00000000, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6850 Series",␉␉␉kDuckweed␉, 0 },␊ |
791 | ␊ |
792 | ␉{ 0x673E,␉0x00000000, CHIP_FAMILY_BARTS,␉␉"AMD Radeon HD 6790 Series",␉␉␉kNull␉␉, 0 },␊ |
793 | ␊ |
794 | ␉{ 0x6740,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6700M Series",␉␉␉kNull␉␉, 0 },␊ |
795 | ␉{ 0x6741,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6600M/6700M Series",␉␉kNull␉␉, 0 },␊ |
796 | ␊ |
797 | ␉{ 0x6750,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6600A Series",␉␉␉kNull␉␉, 0 },␊ |
798 | ␊ |
799 | ␉{ 0x6758,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6670 Series",␉␉␉kBulrushes␉, 0 },␊ |
800 | ␉{ 0x6759,␉0x00000000, CHIP_FAMILY_TURKS,␉␉"AMD Radeon HD 6570/7570 Series",␉␉kNull␉␉, 0 },␊ |
801 | ␉{ 0x6760,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6400M Series",␉␉␉kNull␉␉, 0 },␊ |
802 | ␉{ 0x6761,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6430M Series",␉␉␉kNull␉␉, 0 },␊ |
803 | ␊ |
804 | ␉{ 0x6770,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6400 Series",␉␉␉kNull␉␉, 0 },␊ |
805 | ␊ |
806 | ␉{ 0x6779,␉0x00000000, CHIP_FAMILY_CAICOS,␉␉"AMD Radeon HD 6450 Series",␉␉␉kBulrushes␉, 0 },␊ |
807 | ␊ |
808 | ␉/* Southen Islands */␊ |
809 | ␊ |
810 | ␉{ 0x6798,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7970 Series",␉␉␉kNull␉␉},␊ |
811 | ␊ |
812 | ␉{ 0x679A,␉0x00000000, CHIP_FAMILY_TAHITI,␉␉"AMD Radeon HD 7950 Series", kNull␉␉}, //␊ |
813 | ␊ |
814 | };␊ |
815 | ␊ |
816 | typedef struct {␊ |
817 | ␉struct DevPropDevice␉*device;␊ |
818 | ␉radeon_card_info_t␉␉*info;␊ |
819 | ␉pci_dt_t␉␉␉␉*pci_dev;␊ |
820 | ␉uint8_t␉␉␉␉␉*fb;␊ |
821 | ␉uint8_t␉␉␉␉␉*mmio;␊ |
822 | ␉uint8_t␉␉␉␉␉*io;␊ |
823 | ␉uint8_t␉␉␉␉␉*rom;␊ |
824 | ␉uint32_t␉␉␉␉rom_size;␊ |
825 | ␉uint32_t␉␉␉␉vram_size;␊ |
826 | ␉const char␉␉␉␉*cfg_name;␊ |
827 | ␉uint8_t␉␉␉␉␉ports;␊ |
828 | ␉uint32_t␉␉␉␉flags;␊ |
829 | ␉bool␉␉␉␉␉posted;␊ |
830 | } card_t;␊ |
831 | card_t *card;␊ |
832 | ␊ |
833 | /* Flags */␊ |
834 | #define MKFLAG(n)␉␉␉(1 << n)␊ |
835 | #define FLAGTRUE␉␉␉MKFLAG(0)␊ |
836 | #define EVERGREEN␉␉␉MKFLAG(1)␊ |
837 | ␊ |
838 | //static uint8_t atN = 0;␊ |
839 | ␊ |
840 | typedef struct {␊ |
841 | ␉type_t␉␉␉␉␉type;␊ |
842 | ␉uint32_t␉␉␉␉size;␊ |
843 | ␉uint8_t␉␉␉␉␉*data;␊ |
844 | } value_t;␊ |
845 | ␊ |
846 | static value_t aty_name;␊ |
847 | static value_t aty_nameparent;␊ |
848 | //static value_t aty_model;␊ |
849 | ␊ |
850 | #define DATVAL(x)␉␉␉{kPtr, sizeof(x), (uint8_t *)x}␊ |
851 | #define STRVAL(x)␉␉␉{kStr, sizeof(x), (uint8_t *)x}␊ |
852 | #define BYTVAL(x)␉␉␉{kCst, 1, (uint8_t *)x}␊ |
853 | #define WRDVAL(x)␉␉␉{kCst, 2, (uint8_t *)x}␊ |
854 | #define DWRVAL(x)␉␉␉{kCst, 4, (uint8_t *)x}␊ |
855 | #define QWRVAL(x)␉␉␉{kCst, 8, (uint8_t *)x}␊ |
856 | #define NULVAL␉␉␉␉{kNul, 0, (uint8_t *)NULL}␊ |
857 | ␊ |
858 | bool get_bootdisplay_val(value_t *val);␊ |
859 | bool get_vrammemory_val(value_t *val);␊ |
860 | bool get_name_val(value_t *val);␊ |
861 | bool get_nameparent_val(value_t *val);␊ |
862 | bool get_model_val(value_t *val);␊ |
863 | bool get_conntype_val(value_t *val);␊ |
864 | bool get_vrammemsize_val(value_t *val);␊ |
865 | bool get_binimage_val(value_t *val);␊ |
866 | bool get_romrevision_val(value_t *val);␊ |
867 | bool get_deviceid_val(value_t *val);␊ |
868 | bool get_mclk_val(value_t *val);␊ |
869 | bool get_sclk_val(value_t *val);␊ |
870 | bool get_refclk_val(value_t *val);␊ |
871 | bool get_platforminfo_val(value_t *val);␊ |
872 | bool get_vramtotalsize_val(value_t *val);␊ |
873 | ␊ |
874 | typedef struct {␊ |
875 | ␉uint32_t␉␉␉␉flags;␊ |
876 | ␉bool␉␉␉␉␉all_ports;␊ |
877 | ␉char␉␉␉␉␉*name;␊ |
878 | ␉bool␉␉␉␉␉(*get_value)(value_t *val);␊ |
879 | ␉value_t␉␉␉␉␉default_val;␊ |
880 | } dev_prop_t;␊ |
881 | ␊ |
882 | dev_prop_t ati_devprop_list[] = {␊ |
883 | ␉{FLAGTRUE,␉false,␉"@0,AAPL,boot-display",␉␉get_bootdisplay_val,␉NULVAL␉␉␉␉␉␉␉},␊ |
884 | //␉{FLAGTRUE,␉false,␉"@0,ATY,EFIDisplay",␉␉NULL,␉␉␉␉␉STRVAL("TMDSA")␉␉␉␉␉},␊ |
885 | ␉␊ |
886 | //␉{FLAGTRUE,␉true,␉"@0,AAPL,vram-memory",␉␉get_vrammemory_val,␉␉NULVAL␉␉␉␉␉␉␉},␊ |
887 | //␉{FLAGTRUE,␉true,␉"@0,compatible",␉␉␉get_name_val,␉␉␉NULVAL␉␉␉␉␉␉␉},␊ |
888 | //␉{FLAGTRUE,␉true,␉"@0,connector-type",␉␉get_conntype_val,␉␉NULVAL␉␉␉␉␉␉␉},␊ |
889 | //␉{FLAGTRUE,␉true,␉"@0,device_type",␉␉␉NULL,␉␉␉␉␉STRVAL("display")␉␉␉␉},␊ |
890 | //␉{FLAGTRUE,␉false,␉"@0,display-connect-flags", NULL,␉␉␉␉␉DWRVAL((uint32_t)0)␉␉␉␉},␊ |
891 | //␉{FLAGTRUE,␉true,␉"@0,display-type",␉␉␉NULL,␉␉␉␉␉STRVAL("NONE")␉␉␉␉␉},␊ |
892 | ␉{FLAGTRUE,␉true,␉"@0,name",␉␉␉␉␉get_name_val,␉␉␉NULVAL␉␉␉␉␉␉␉},␊ |
893 | //␉{FLAGTRUE,␉true,␉"@0,VRAM,memsize",␉␉␉get_vrammemsize_val,␉NULVAL␉␉␉␉␉␉␉},␊ |
894 | ␉␊ |
895 | //␉{FLAGTRUE,␉false,␉"AAPL,aux-power-connected", NULL,␉␉␉␉␉DWRVAL((uint32_t)1)␉␉␉␉},␊ |
896 | //␉{FLAGTRUE,␉false,␉"AAPL,backlight-control",␉NULL,␉␉␉␉␉DWRVAL((uint32_t)0)␉␉␉␉},␊ |
897 | ␉{FLAGTRUE,␉false,␉"ATY,bin_image",␉␉␉get_binimage_val,␉␉NULVAL␉␉␉␉␉␉␉},␊ |
898 | ␉{FLAGTRUE,␉false,␉"ATY,Copyright",␉␉␉NULL,␉STRVAL("Copyright AMD Inc. All Rights Reserved. 2005-2010") },␊ |
899 | ␉{FLAGTRUE,␉false,␉"ATY,Card#",␉␉␉␉get_romrevision_val,␉NULVAL␉␉␉␉␉␉␉},␊ |
900 | ␉{FLAGTRUE,␉false,␉"ATY,VendorID",␉␉␉␉NULL,␉␉␉␉␉WRDVAL((uint16_t)0x1002)␉␉},␊ |
901 | ␉{FLAGTRUE,␉false,␉"ATY,DeviceID",␉␉␉␉get_deviceid_val,␉␉NULVAL␉␉␉␉␉␉␉},␊ |
902 | ␉␊ |
903 | //␉{FLAGTRUE,␉false,␉"ATY,MCLK",␉␉␉␉␉get_mclk_val,␉␉␉NULVAL␉␉␉␉␉␉␉},␊ |
904 | //␉{FLAGTRUE,␉false,␉"ATY,SCLK",␉␉␉␉␉get_sclk_val,␉␉␉NULVAL␉␉␉␉␉␉␉},␊ |
905 | //␉{FLAGTRUE,␉false,␉"ATY,RefCLK",␉␉␉␉get_refclk_val,␉␉␉DWRVAL((uint32_t)0x0a8c)␉␉},␊ |
906 | ␉␊ |
907 | //␉{FLAGTRUE,␉false,␉"ATY,PlatformInfo",␉␉␉get_platforminfo_val,␉NULVAL␉␉␉␉␉␉␉},␊ |
908 | ␉␊ |
909 | ␉{FLAGTRUE,␉false,␉"name",␉␉␉␉␉␉get_nameparent_val,␉␉NULVAL␉␉␉␉␉␉␉},␊ |
910 | ␉{FLAGTRUE,␉false,␉"device_type",␉␉␉␉get_nameparent_val,␉␉NULVAL␉␉␉␉␉␉␉},␊ |
911 | ␉{FLAGTRUE,␉false,␉"model",␉␉␉␉␉get_model_val,␉␉␉STRVAL("ATI Radeon")␉␉␉},␊ |
912 | //␉{FLAGTRUE,␉false,␉"VRAM,totalsize",␉␉␉get_vramtotalsize_val,␉NULVAL␉␉␉␉␉␉␉},␊ |
913 | ␉␊ |
914 | ␉{FLAGTRUE,␉false,␉NULL,␉␉␉␉␉␉NULL,␉␉␉␉␉NULVAL␉␉␉␉␉␉␉}␊ |
915 | };␊ |
916 | ␊ |
917 | bool get_bootdisplay_val(value_t *val)␊ |
918 | {␊ |
919 | ␉static uint32_t v = 0;␊ |
920 | ␉␊ |
921 | ␉if (v)␊ |
922 | ␉␉return false;␊ |
923 | ␉␊ |
924 | ␉if (!card->posted)␊ |
925 | ␉␉return false;␊ |
926 | ␉␊ |
927 | ␉v = 1;␊ |
928 | ␉val->type = kCst;␊ |
929 | ␉val->size = 4;␊ |
930 | ␉val->data = (uint8_t *)&v;␊ |
931 | ␉␊ |
932 | ␉return true;␊ |
933 | }␊ |
934 | ␊ |
935 | bool get_vrammemory_val(value_t *val)␊ |
936 | {␊ |
937 | ␉return false;␊ |
938 | }␊ |
939 | ␊ |
940 | bool get_name_val(value_t *val)␊ |
941 | {␊ |
942 | ␉val->type = aty_name.type;␊ |
943 | ␉val->size = aty_name.size;␊ |
944 | ␉val->data = aty_name.data;␊ |
945 | ␉␊ |
946 | ␉return true;␊ |
947 | }␊ |
948 | ␊ |
949 | bool get_nameparent_val(value_t *val)␊ |
950 | {␊ |
951 | ␉val->type = aty_nameparent.type;␊ |
952 | ␉val->size = aty_nameparent.size;␊ |
953 | ␉val->data = aty_nameparent.data;␊ |
954 | ␉␊ |
955 | ␉return true;␊ |
956 | }␊ |
957 | ␊ |
958 | bool get_model_val(value_t *val)␊ |
959 | {␊ |
960 | ␉if (!card->info->model_name)␊ |
961 | ␉␉return false;␊ |
962 | ␉␊ |
963 | ␉val->type = kStr;␊ |
964 | ␉val->size = strlen(card->info->model_name) + 1;␊ |
965 | ␉val->data = (uint8_t *)card->info->model_name;␊ |
966 | ␉␊ |
967 | ␉return true;␊ |
968 | }␊ |
969 | ␊ |
970 | bool get_conntype_val(value_t *val)␊ |
971 | {␊ |
972 | //Connector types:␊ |
973 | //0x4 : DisplayPort␊ |
974 | //0x400: DL DVI-I␊ |
975 | //0x800: HDMI␊ |
976 | ␊ |
977 | ␉return false;␊ |
978 | }␊ |
979 | ␊ |
980 | bool get_vrammemsize_val(value_t *val)␊ |
981 | {␊ |
982 | ␉static int idx = -1;␊ |
983 | ␉static uint64_t memsize;␊ |
984 | ␉␊ |
985 | ␉idx++;␊ |
986 | ␉memsize = ((uint64_t)card->vram_size << 32);␊ |
987 | ␉if (idx == 0)␊ |
988 | ␉␉memsize = memsize | (uint64_t)card->vram_size;␊ |
989 | ␉␊ |
990 | ␉val->type = kCst;␊ |
991 | ␉val->size = 8;␊ |
992 | ␉val->data = (uint8_t *)&memsize;␊ |
993 | ␉␊ |
994 | ␉return true;␊ |
995 | }␊ |
996 | ␊ |
997 | bool get_binimage_val(value_t *val)␊ |
998 | {␊ |
999 | ␉if (!card->rom)␊ |
1000 | ␉␉return false;␊ |
1001 | ␉␊ |
1002 | ␉val->type = kPtr;␊ |
1003 | ␉val->size = card->rom_size;␊ |
1004 | ␉val->data = card->rom;␊ |
1005 | ␉␊ |
1006 | ␉return true;␊ |
1007 | }␊ |
1008 | ␊ |
1009 | bool get_romrevision_val(value_t *val)␊ |
1010 | {␊ |
1011 | ␉uint8_t *rev;␊ |
1012 | ␉if (!card->rom)␊ |
1013 | ␉␉return false;␊ |
1014 | ␉␊ |
1015 | ␉rev = card->rom + *(uint8_t *)(card->rom + OFFSET_TO_GET_ATOMBIOS_STRINGS_START);␊ |
1016 | ␊ |
1017 | ␉val->type = kPtr;␊ |
1018 | ␉val->size = strlen((char *)rev);␊ |
1019 | ␉val->data = malloc(val->size);␊ |
1020 | ␉␊ |
1021 | ␉if (!val->data)␊ |
1022 | ␉␉return false;␊ |
1023 | ␉␊ |
1024 | ␉memcpy(val->data, rev, val->size);␊ |
1025 | ␉␊ |
1026 | ␉return true;␊ |
1027 | }␊ |
1028 | ␊ |
1029 | bool get_deviceid_val(value_t *val)␊ |
1030 | {␊ |
1031 | ␉val->type = kCst;␊ |
1032 | ␉val->size = 2;␊ |
1033 | ␉val->data = (uint8_t *)&card->pci_dev->device_id;␊ |
1034 | ␉␊ |
1035 | ␉return true;␊ |
1036 | }␊ |
1037 | ␊ |
1038 | bool get_mclk_val(value_t *val)␊ |
1039 | {␊ |
1040 | ␉return false;␊ |
1041 | }␊ |
1042 | ␊ |
1043 | bool get_sclk_val(value_t *val)␊ |
1044 | {␊ |
1045 | ␉return false;␊ |
1046 | }␊ |
1047 | ␊ |
1048 | bool get_refclk_val(value_t *val)␊ |
1049 | {␊ |
1050 | ␉return false;␊ |
1051 | }␊ |
1052 | ␊ |
1053 | bool get_platforminfo_val(value_t *val)␊ |
1054 | {␊ |
1055 | ␉val->data = malloc(0x80);␊ |
1056 | ␉if (!val->data)␊ |
1057 | ␉␉return false;␊ |
1058 | ␉␊ |
1059 | ␉bzero(val->data, 0x80);␊ |
1060 | ␉␊ |
1061 | ␉val->type␉␉= kPtr;␊ |
1062 | ␉val->size␉␉= 0x80;␊ |
1063 | ␉val->data[0]␉= 1;␊ |
1064 | ␉␊ |
1065 | ␉return true;␊ |
1066 | }␊ |
1067 | ␊ |
1068 | bool get_vramtotalsize_val(value_t *val)␊ |
1069 | {␊ |
1070 | ␉val->type = kCst;␊ |
1071 | ␉val->size = 4;␊ |
1072 | ␉val->data = (uint8_t *)&card->vram_size;␊ |
1073 | ␉␊ |
1074 | ␉return true;␊ |
1075 | }␊ |
1076 | ␊ |
1077 | void free_val(value_t *val)␊ |
1078 | {␊ |
1079 | ␉if (val->type == kPtr)␊ |
1080 | ␉␉free(val->data);␊ |
1081 | ␉␊ |
1082 | ␉bzero(val, sizeof(value_t));␊ |
1083 | }␊ |
1084 | ␊ |
1085 | void devprop_add_list(dev_prop_t devprop_list[])␊ |
1086 | {␊ |
1087 | ␉value_t *val = malloc(sizeof(value_t));␊ |
1088 | ␉int i, pnum;␊ |
1089 | ␉␊ |
1090 | ␉for (i = 0; devprop_list[i].name != NULL; i++)␊ |
1091 | ␉{␊ |
1092 | ␉␉if ((devprop_list[i].flags == FLAGTRUE) || (devprop_list[i].flags | card->flags))␊ |
1093 | ␉␉{␊ |
1094 | ␉␉␉if (devprop_list[i].get_value && devprop_list[i].get_value(val))␊ |
1095 | ␉␉␉{␊ |
1096 | ␉␉␉␉devprop_add_value(card->device, devprop_list[i].name, val->data, val->size);␊ |
1097 | ␉␉␉␉free_val(val);␊ |
1098 | ␉␉␉␉␊ |
1099 | ␉␉␉␉if (devprop_list[i].all_ports)␊ |
1100 | ␉␉␉␉{␊ |
1101 | ␉␉␉␉␉for (pnum = 1; pnum < card->ports; pnum++)␊ |
1102 | ␉␉␉␉␉{␊ |
1103 | ␉␉␉␉␉␉if (devprop_list[i].get_value(val))␊ |
1104 | ␉␉␉␉␉␉{␊ |
1105 | ␉␉␉␉␉␉␉devprop_list[i].name[1] = 0x30 + pnum; // convert to ascii␊ |
1106 | ␉␉␉␉␉␉␉devprop_add_value(card->device, devprop_list[i].name, val->data, val->size);␊ |
1107 | ␉␉␉␉␉␉␉free_val(val);␊ |
1108 | ␉␉␉␉␉␉}␊ |
1109 | ␉␉␉␉␉}␊ |
1110 | ␉␉␉␉␉devprop_list[i].name[1] = 0x30; // write back our "@0," for a next possible card␊ |
1111 | ␉␉␉␉}␊ |
1112 | ␉␉␉}␊ |
1113 | ␉␉␉else␊ |
1114 | ␉␉␉{␊ |
1115 | ␉␉␉␉if (devprop_list[i].default_val.type != kNul)␊ |
1116 | ␉␉␉␉{␊ |
1117 | ␉␉␉␉␉devprop_add_value(card->device, devprop_list[i].name,␊ |
1118 | ␉␉␉␉␉␉devprop_list[i].default_val.type == kCst ?␊ |
1119 | ␉␉␉␉␉␉(uint8_t *)&(devprop_list[i].default_val.data) : devprop_list[i].default_val.data,␊ |
1120 | ␉␉␉␉␉␉devprop_list[i].default_val.size);␊ |
1121 | ␉␉␉␉}␊ |
1122 | ␉␉␉␉␊ |
1123 | ␉␉␉␉if (devprop_list[i].all_ports)␊ |
1124 | ␉␉␉␉{␊ |
1125 | ␉␉␉␉␉for (pnum = 1; pnum < card->ports; pnum++)␊ |
1126 | ␉␉␉␉␉{␊ |
1127 | ␉␉␉␉␉␉if (devprop_list[i].default_val.type != kNul)␊ |
1128 | ␉␉␉␉␉␉{␊ |
1129 | ␉␉␉␉␉␉␉devprop_list[i].name[1] = 0x30 + pnum; // convert to ascii␊ |
1130 | ␉␉␉␉␉␉␉devprop_add_value(card->device, devprop_list[i].name,␊ |
1131 | ␉␉␉␉␉␉␉␉devprop_list[i].default_val.type == kCst ?␊ |
1132 | ␉␉␉␉␉␉␉␉(uint8_t *)&(devprop_list[i].default_val.data) : devprop_list[i].default_val.data,␊ |
1133 | ␉␉␉␉␉␉␉␉devprop_list[i].default_val.size);␊ |
1134 | ␉␉␉␉␉␉}␊ |
1135 | ␉␉␉␉␉}␊ |
1136 | ␉␉␉␉␉devprop_list[i].name[1] = 0x30; // write back our "@0," for a next possible card␊ |
1137 | ␉␉␉␉}␊ |
1138 | ␉␉␉}␊ |
1139 | ␉␉}␊ |
1140 | ␉}␊ |
1141 | ␊ |
1142 | ␉free(val);␊ |
1143 | }␊ |
1144 | ␊ |
1145 | bool validate_rom(option_rom_header_t *rom_header, pci_dt_t *pci_dev)␊ |
1146 | {␊ |
1147 | ␉option_rom_pci_header_t *rom_pci_header;␊ |
1148 | ␉␊ |
1149 | ␉if (rom_header->signature != 0xaa55)␊ |
1150 | ␉␉return false;␊ |
1151 | ␉␊ |
1152 | ␉rom_pci_header = (option_rom_pci_header_t *)((uint8_t *)rom_header + rom_header->pci_header_offset);␊ |
1153 | ␉␊ |
1154 | ␉if (rom_pci_header->signature != 0x52494350)␊ |
1155 | ␉␉return false;␊ |
1156 | ␉␊ |
1157 | ␉if (rom_pci_header->vendor_id != pci_dev->vendor_id || rom_pci_header->device_id != pci_dev->device_id)␊ |
1158 | ␉␉return false;␊ |
1159 | ␉␊ |
1160 | ␉return true;␊ |
1161 | }␊ |
1162 | ␊ |
1163 | bool load_vbios_file(const char *key, uint16_t vendor_id, uint16_t device_id, uint32_t subsys_id)␊ |
1164 | {␊ |
1165 | ␉int fd;␊ |
1166 | ␉char file_name[24];␊ |
1167 | ␉bool do_load = false;␊ |
1168 | ␉␊ |
1169 | ␉getBoolForKey(key, &do_load, &bootInfo->chameleonConfig);␊ |
1170 | ␉if (!do_load)␊ |
1171 | ␉␉return false;␊ |
1172 | ␉␊ |
1173 | ␉sprintf(file_name, "/Extra/%04x_%04x_%08x.rom", vendor_id, device_id, subsys_id);␊ |
1174 | ␉if ((fd = open_bvdev("bt(0,0)", file_name, 0)) < 0)␊ |
1175 | ␉␉return false;␊ |
1176 | ␉␊ |
1177 | ␉card->rom_size = file_size(fd);␊ |
1178 | ␉card->rom = malloc(card->rom_size);␊ |
1179 | ␉if (!card->rom)␊ |
1180 | ␉␉return false;␊ |
1181 | ␉␊ |
1182 | ␉read(fd, (char *)card->rom, card->rom_size);␊ |
1183 | ␉␊ |
1184 | ␉if (!validate_rom((option_rom_header_t *)card->rom, card->pci_dev))␊ |
1185 | ␉{␊ |
1186 | ␉␉card->rom_size = 0;␊ |
1187 | ␉␉card->rom = 0;␊ |
1188 | ␉␉return false;␊ |
1189 | ␉}␊ |
1190 | ␉␊ |
1191 | ␉card->rom_size = ((option_rom_header_t *)card->rom)->rom_size * 512;␊ |
1192 | ␉␊ |
1193 | ␉close(fd);␊ |
1194 | ␉␊ |
1195 | ␉return true;␊ |
1196 | }␊ |
1197 | ␊ |
1198 | void get_vram_size(void)␊ |
1199 | {␊ |
1200 | ␉chip_family_t chip_family = card->info->chip_family;␊ |
1201 | ␉␊ |
1202 | ␉card->vram_size = 0;␊ |
1203 | ␉␊ |
1204 | ␉if (chip_family >= CHIP_FAMILY_CEDAR)␊ |
1205 | ␉␉// size in MB on evergreen␊ |
1206 | ␉␉// XXX watch for overflow!!!␊ |
1207 | ␉␉card->vram_size = RegRead32(R600_CONFIG_MEMSIZE) * 1024 * 1024;␊ |
1208 | ␉else␊ |
1209 | ␉␉if (chip_family >= CHIP_FAMILY_R600)␊ |
1210 | ␉␉␉card->vram_size = RegRead32(R600_CONFIG_MEMSIZE);␊ |
1211 | }␊ |
1212 | ␊ |
1213 | bool read_vbios(bool from_pci)␊ |
1214 | {␊ |
1215 | ␉option_rom_header_t *rom_addr;␊ |
1216 | ␉␊ |
1217 | ␉if (from_pci)␊ |
1218 | ␉{␊ |
1219 | ␉␉rom_addr = (option_rom_header_t *)(pci_config_read32(card->pci_dev->dev.addr, PCI_ROM_ADDRESS) & ~0x7ff);␊ |
1220 | ␉␉verbose(" @0x%x", rom_addr);␊ |
1221 | ␉}␊ |
1222 | ␉else␊ |
1223 | ␉␉rom_addr = (option_rom_header_t *)0xc0000;␊ |
1224 | ␉␊ |
1225 | ␉if (!validate_rom(rom_addr, card->pci_dev))␊ |
1226 | ␉␉return false;␊ |
1227 | ␉␊ |
1228 | ␉card->rom_size = rom_addr->rom_size * 512;␊ |
1229 | ␉if (!card->rom_size)␊ |
1230 | ␉␉return false;␊ |
1231 | ␉␊ |
1232 | ␉card->rom = malloc(card->rom_size);␊ |
1233 | ␉if (!card->rom)␊ |
1234 | ␉␉return false;␊ |
1235 | ␉␊ |
1236 | ␉memcpy(card->rom, (void *)rom_addr, card->rom_size);␊ |
1237 | ␉␊ |
1238 | ␉return true;␊ |
1239 | }␊ |
1240 | ␊ |
1241 | bool read_disabled_vbios(void)␊ |
1242 | {␊ |
1243 | ␉bool ret = false;␊ |
1244 | ␉chip_family_t chip_family = card->info->chip_family;␊ |
1245 | ␉␊ |
1246 | ␉if (chip_family >= CHIP_FAMILY_RV770)␊ |
1247 | ␉{␊ |
1248 | ␉␉uint32_t viph_control␉␉= RegRead32(RADEON_VIPH_CONTROL);␊ |
1249 | ␉␉uint32_t bus_cntl␉␉␉= RegRead32(RADEON_BUS_CNTL);␊ |
1250 | ␉␉uint32_t d1vga_control␉␉= RegRead32(AVIVO_D1VGA_CONTROL);␊ |
1251 | ␉␉uint32_t d2vga_control␉␉= RegRead32(AVIVO_D2VGA_CONTROL);␊ |
1252 | ␉␉uint32_t vga_render_control = RegRead32(AVIVO_VGA_RENDER_CONTROL);␊ |
1253 | ␉␉uint32_t rom_cntl␉␉␉= RegRead32(R600_ROM_CNTL);␊ |
1254 | ␉␉uint32_t cg_spll_func_cntl␉= 0;␊ |
1255 | ␉␉uint32_t cg_spll_status;␊ |
1256 | ␉␉␊ |
1257 | ␉␉// disable VIP␊ |
1258 | ␉␉RegWrite32(RADEON_VIPH_CONTROL, (viph_control & ~RADEON_VIPH_EN));␊ |
1259 | ␉␉␊ |
1260 | ␉␉// enable the rom␊ |
1261 | ␉␉RegWrite32(RADEON_BUS_CNTL, (bus_cntl & ~RADEON_BUS_BIOS_DIS_ROM));␊ |
1262 | ␉␉␊ |
1263 | ␉␉// Disable VGA mode␊ |
1264 | ␉␉RegWrite32(AVIVO_D1VGA_CONTROL, (d1vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE | AVIVO_DVGA_CONTROL_TIMING_SELECT)));␊ |
1265 | ␉␉RegWrite32(AVIVO_D2VGA_CONTROL, (d2vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE | AVIVO_DVGA_CONTROL_TIMING_SELECT)));␊ |
1266 | ␉␉RegWrite32(AVIVO_VGA_RENDER_CONTROL, (vga_render_control & ~AVIVO_VGA_VSTATUS_CNTL_MASK));␊ |
1267 | ␉␉␊ |
1268 | ␉␉if (chip_family == CHIP_FAMILY_RV730)␊ |
1269 | ␉␉{␊ |
1270 | ␉␉␉cg_spll_func_cntl = RegRead32(R600_CG_SPLL_FUNC_CNTL);␊ |
1271 | ␉␉␉␊ |
1272 | ␉␉␉// enable bypass mode␊ |
1273 | ␉␉␉RegWrite32(R600_CG_SPLL_FUNC_CNTL, (cg_spll_func_cntl | R600_SPLL_BYPASS_EN));␊ |
1274 | ␉␉␉␊ |
1275 | ␉␉␉// wait for SPLL_CHG_STATUS to change to 1␊ |
1276 | ␉␉␉cg_spll_status = 0;␊ |
1277 | ␉␉␉while (!(cg_spll_status & R600_SPLL_CHG_STATUS))␊ |
1278 | ␉␉␉␉cg_spll_status = RegRead32(R600_CG_SPLL_STATUS);␊ |
1279 | ␉␉␉␊ |
1280 | ␉␉␉RegWrite32(R600_ROM_CNTL, (rom_cntl & ~R600_SCK_OVERWRITE));␊ |
1281 | ␉␉}␊ |
1282 | ␉␉else␊ |
1283 | ␉␉␉RegWrite32(R600_ROM_CNTL, (rom_cntl | R600_SCK_OVERWRITE));␊ |
1284 | ␉␉␊ |
1285 | ␉␉ret = read_vbios(true);␊ |
1286 | ␉␉␊ |
1287 | ␉␉// restore regs␊ |
1288 | ␉␉if (chip_family == CHIP_FAMILY_RV730)␊ |
1289 | ␉␉{␊ |
1290 | ␉␉␉RegWrite32(R600_CG_SPLL_FUNC_CNTL, cg_spll_func_cntl);␊ |
1291 | ␉␉␉␊ |
1292 | ␉␉␉// wait for SPLL_CHG_STATUS to change to 1␊ |
1293 | ␉␉␉cg_spll_status = 0;␊ |
1294 | ␉␉␉while (!(cg_spll_status & R600_SPLL_CHG_STATUS))␊ |
1295 | ␉␉␉cg_spll_status = RegRead32(R600_CG_SPLL_STATUS);␊ |
1296 | ␉␉}␊ |
1297 | ␉␉RegWrite32(RADEON_VIPH_CONTROL, viph_control);␊ |
1298 | ␉␉RegWrite32(RADEON_BUS_CNTL, bus_cntl);␊ |
1299 | ␉␉RegWrite32(AVIVO_D1VGA_CONTROL, d1vga_control);␊ |
1300 | ␉␉RegWrite32(AVIVO_D2VGA_CONTROL, d2vga_control);␊ |
1301 | ␉␉RegWrite32(AVIVO_VGA_RENDER_CONTROL, vga_render_control);␊ |
1302 | ␉␉RegWrite32(R600_ROM_CNTL, rom_cntl);␊ |
1303 | ␉}␊ |
1304 | ␉else␊ |
1305 | ␉␉if (chip_family >= CHIP_FAMILY_R600)␊ |
1306 | ␉␉{␊ |
1307 | ␉␉␉uint32_t viph_control␉␉␉␉= RegRead32(RADEON_VIPH_CONTROL);␊ |
1308 | ␉␉␉uint32_t bus_cntl␉␉␉␉␉= RegRead32(RADEON_BUS_CNTL);␊ |
1309 | ␉␉␉uint32_t d1vga_control␉␉␉␉= RegRead32(AVIVO_D1VGA_CONTROL);␊ |
1310 | ␉␉␉uint32_t d2vga_control␉␉␉␉= RegRead32(AVIVO_D2VGA_CONTROL);␊ |
1311 | ␉␉␉uint32_t vga_render_control␉␉␉= RegRead32(AVIVO_VGA_RENDER_CONTROL);␊ |
1312 | ␉␉␉uint32_t rom_cntl␉␉␉␉␉= RegRead32(R600_ROM_CNTL);␊ |
1313 | ␉␉␉uint32_t general_pwrmgt␉␉␉␉= RegRead32(R600_GENERAL_PWRMGT);␊ |
1314 | ␉␉␉uint32_t low_vid_lower_gpio_cntl␉= RegRead32(R600_LOW_VID_LOWER_GPIO_CNTL);␊ |
1315 | ␉␉␉uint32_t medium_vid_lower_gpio_cntl = RegRead32(R600_MEDIUM_VID_LOWER_GPIO_CNTL);␊ |
1316 | ␉␉␉uint32_t high_vid_lower_gpio_cntl␉= RegRead32(R600_HIGH_VID_LOWER_GPIO_CNTL);␊ |
1317 | ␉␉␉uint32_t ctxsw_vid_lower_gpio_cntl␉= RegRead32(R600_CTXSW_VID_LOWER_GPIO_CNTL);␊ |
1318 | ␉␉␉uint32_t lower_gpio_enable␉␉␉= RegRead32(R600_LOWER_GPIO_ENABLE);␊ |
1319 | ␉␉␉␊ |
1320 | ␉␉␉// disable VIP␊ |
1321 | ␉␉␉RegWrite32(RADEON_VIPH_CONTROL, (viph_control & ~RADEON_VIPH_EN));␊ |
1322 | ␉␉␉␊ |
1323 | ␉␉␉// enable the rom␊ |
1324 | ␉␉␉RegWrite32(RADEON_BUS_CNTL, (bus_cntl & ~RADEON_BUS_BIOS_DIS_ROM));␊ |
1325 | ␉␉␉␊ |
1326 | ␉␉␉// Disable VGA mode␊ |
1327 | ␉␉␉RegWrite32(AVIVO_D1VGA_CONTROL, (d1vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE | AVIVO_DVGA_CONTROL_TIMING_SELECT)));␊ |
1328 | ␉␉␉RegWrite32(AVIVO_D2VGA_CONTROL, (d2vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE | AVIVO_DVGA_CONTROL_TIMING_SELECT)));␊ |
1329 | ␉␉␉RegWrite32(AVIVO_VGA_RENDER_CONTROL, (vga_render_control & ~AVIVO_VGA_VSTATUS_CNTL_MASK));␊ |
1330 | ␉␉␉RegWrite32(R600_ROM_CNTL, ((rom_cntl & ~R600_SCK_PRESCALE_CRYSTAL_CLK_MASK) | (1 << R600_SCK_PRESCALE_CRYSTAL_CLK_SHIFT) | R600_SCK_OVERWRITE));␊ |
1331 | ␉␉␉RegWrite32(R600_GENERAL_PWRMGT, (general_pwrmgt & ~R600_OPEN_DRAIN_PADS));␊ |
1332 | ␉␉␉RegWrite32(R600_LOW_VID_LOWER_GPIO_CNTL, (low_vid_lower_gpio_cntl & ~0x400));␊ |
1333 | ␉␉␉RegWrite32(R600_MEDIUM_VID_LOWER_GPIO_CNTL, (medium_vid_lower_gpio_cntl & ~0x400));␊ |
1334 | ␉␉␉RegWrite32(R600_HIGH_VID_LOWER_GPIO_CNTL, (high_vid_lower_gpio_cntl & ~0x400));␊ |
1335 | ␉␉␉RegWrite32(R600_CTXSW_VID_LOWER_GPIO_CNTL, (ctxsw_vid_lower_gpio_cntl & ~0x400));␊ |
1336 | ␉␉␉RegWrite32(R600_LOWER_GPIO_ENABLE, (lower_gpio_enable | 0x400));␊ |
1337 | ␉␉␉␊ |
1338 | ␉␉␉ret = read_vbios(true);␊ |
1339 | ␉␉␉␊ |
1340 | ␉␉␉// restore regs␊ |
1341 | ␉␉␉RegWrite32(RADEON_VIPH_CONTROL, viph_control);␊ |
1342 | ␉␉␉RegWrite32(RADEON_BUS_CNTL, bus_cntl);␊ |
1343 | ␉␉␉RegWrite32(AVIVO_D1VGA_CONTROL, d1vga_control);␊ |
1344 | ␉␉␉RegWrite32(AVIVO_D2VGA_CONTROL, d2vga_control);␊ |
1345 | ␉␉␉RegWrite32(AVIVO_VGA_RENDER_CONTROL, vga_render_control);␊ |
1346 | ␉␉␉RegWrite32(R600_ROM_CNTL, rom_cntl);␊ |
1347 | ␉␉␉RegWrite32(R600_GENERAL_PWRMGT, general_pwrmgt);␊ |
1348 | ␉␉␉RegWrite32(R600_LOW_VID_LOWER_GPIO_CNTL, low_vid_lower_gpio_cntl);␊ |
1349 | ␉␉␉RegWrite32(R600_MEDIUM_VID_LOWER_GPIO_CNTL, medium_vid_lower_gpio_cntl);␊ |
1350 | ␉␉␉RegWrite32(R600_HIGH_VID_LOWER_GPIO_CNTL, high_vid_lower_gpio_cntl);␊ |
1351 | ␉␉␉RegWrite32(R600_CTXSW_VID_LOWER_GPIO_CNTL, ctxsw_vid_lower_gpio_cntl);␊ |
1352 | ␉␉␉RegWrite32(R600_LOWER_GPIO_ENABLE, lower_gpio_enable);␊ |
1353 | ␉␉}␊ |
1354 | ␊ |
1355 | ␉return ret;␊ |
1356 | }␊ |
1357 | ␊ |
1358 | bool radeon_card_posted(void)␊ |
1359 | {␊ |
1360 | ␉uint32_t reg;␊ |
1361 | ␉␊ |
1362 | ␉// first check CRTCs␊ |
1363 | ␉reg = RegRead32(RADEON_CRTC_GEN_CNTL) | RegRead32(RADEON_CRTC2_GEN_CNTL);␊ |
1364 | ␉if (reg & RADEON_CRTC_EN)␊ |
1365 | ␉␉return true;␊ |
1366 | ␉␊ |
1367 | ␉// then check MEM_SIZE, in case something turned the crtcs off␊ |
1368 | ␉reg = RegRead32(R600_CONFIG_MEMSIZE);␊ |
1369 | ␉if (reg)␊ |
1370 | ␉␉return true;␊ |
1371 | ␉␊ |
1372 | ␉return false;␊ |
1373 | }␊ |
1374 | ␊ |
1375 | #if 0␊ |
1376 | bool devprop_add_pci_config_space(void)␊ |
1377 | {␊ |
1378 | ␉int offset;␊ |
1379 | ␉␊ |
1380 | ␉uint8_t *config_space = malloc(0x100);␊ |
1381 | ␉if (!config_space)␊ |
1382 | ␉␉return false;␊ |
1383 | ␉␊ |
1384 | ␉for (offset = 0; offset < 0x100; offset += 4)␊ |
1385 | ␉␉config_space[offset / 4] = pci_config_read32(card->pci_dev->dev.addr, offset);␊ |
1386 | ␉␊ |
1387 | ␉devprop_add_value(card->device, "ATY,PCIConfigSpace", config_space, 0x100);␊ |
1388 | ␉free(config_space);␊ |
1389 | ␉␊ |
1390 | ␉return true;␊ |
1391 | }␊ |
1392 | #endif␊ |
1393 | ␊ |
1394 | static bool init_card(pci_dt_t *pci_dev)␊ |
1395 | {␊ |
1396 | ␉bool␉add_vbios = true;␊ |
1397 | ␉char␉name[24];␊ |
1398 | ␉char␉name_parent[24];␊ |
1399 | ␉int␉␉i;␊ |
1400 | ␉int␉␉n_ports = 0;␊ |
1401 | ␉␊ |
1402 | ␉card = malloc(sizeof(card_t));␊ |
1403 | ␉if (!card)␊ |
1404 | ␉␉return false;␊ |
1405 | ␉bzero(card, sizeof(card_t));␊ |
1406 | ␉␊ |
1407 | ␉card->pci_dev = pci_dev;␊ |
1408 | ␉␊ |
1409 | ␉for (i = 0; radeon_cards[i].device_id ; i++)␊ |
1410 | ␉{␊ |
1411 | ␉␉if (radeon_cards[i].device_id == pci_dev->device_id)␊ |
1412 | ␉␉{␊ |
1413 | ␉␉␉card->info = &radeon_cards[i];␊ |
1414 | ␉␉␉if ((radeon_cards[i].subsys_id == 0x00000000) ||␊ |
1415 | ␉␉␉␉(radeon_cards[i].subsys_id == pci_dev->subsys_id.subsys_id))␊ |
1416 | ␉␉␉␉break;␊ |
1417 | ␉␉}␊ |
1418 | ␉}␊ |
1419 | ␉␊ |
1420 | //␉if (!card->info->device_id || !card->info->cfg_name)␊ |
1421 | ␉if (!card->info->device_id)␊ |
1422 | ␉{␊ |
1423 | ␉␉printf("Unsupported card!\n");␊ |
1424 | ␉␉return false;␊ |
1425 | ␉}␊ |
1426 | ␉␊ |
1427 | ␉card->fb␉␉= (uint8_t *)(pci_config_read32(pci_dev->dev.addr, PCI_BASE_ADDRESS_0) & ~0x0f);␊ |
1428 | ␉card->mmio␉␉= (uint8_t *)(pci_config_read32(pci_dev->dev.addr, PCI_BASE_ADDRESS_2) & ~0x0f);␊ |
1429 | ␉card->io␉␉= (uint8_t *)(pci_config_read32(pci_dev->dev.addr, PCI_BASE_ADDRESS_4) & ~0x03);␊ |
1430 | ␉␊ |
1431 | ␉verbose("Framebuffer @0x%08X MMIO @0x%08X␉I/O Port @0x%08X ROM Addr @0x%08X\n",␊ |
1432 | ␉␉card->fb, card->mmio, card->io, pci_config_read32(pci_dev->dev.addr, PCI_ROM_ADDRESS));␊ |
1433 | ␉␊ |
1434 | ␉card->posted = radeon_card_posted();␊ |
1435 | ␉verbose("ATI card %s, ", card->posted ? "POSTed" : "non-POSTed");␊ |
1436 | ␉␊ |
1437 | ␉get_vram_size();␊ |
1438 | ␉␊ |
1439 | ␉getBoolForKey(kATYbinimage, &add_vbios, &bootInfo->chameleonConfig);␊ |
1440 | ␉␊ |
1441 | ␉if (add_vbios)␊ |
1442 | ␉{␊ |
1443 | ␉␉if (!load_vbios_file(kUseAtiROM, pci_dev->vendor_id, pci_dev->device_id, pci_dev->subsys_id.subsys_id))␊ |
1444 | ␉␉{␊ |
1445 | ␉␉␉verbose("reading VBIOS from %s", card->posted ? "legacy space" : "PCI ROM");␊ |
1446 | ␉␉␉if (card->posted)␊ |
1447 | ␉␉␉␉read_vbios(false);␊ |
1448 | ␉␉␉else␊ |
1449 | ␉␉␉␉read_disabled_vbios();␊ |
1450 | ␉␉␉verbose("\n");␊ |
1451 | ␉␉}␊ |
1452 | ␉}␊ |
1453 | ␉␊ |
1454 | //␉card->ports = 2; // default - Azi: default is card_configs␊ |
1455 | ␉␊ |
1456 | ␉if (card->info->chip_family >= CHIP_FAMILY_CEDAR)␊ |
1457 | ␉{␊ |
1458 | ␉␉card->flags |= EVERGREEN;␊ |
1459 | //␉␉card->ports = 3; //Azi: use the AtiPorts key if needed␊ |
1460 | ␉}␊ |
1461 | ␉␊ |
1462 | //␉atN = 0;␊ |
1463 | ␉␊ |
1464 | ␉// Check AtiConfig key for a framebuffer name,␊ |
1465 | ␉card->cfg_name = getStringForKey(kAtiConfig, &bootInfo->chameleonConfig);␊ |
1466 | ␉// if none,␊ |
1467 | ␉if (!card->cfg_name)␊ |
1468 | ␉{␊ |
1469 | ␉␉// use cfg_name on radeon_cards, to retrive the default name from card_configs,␊ |
1470 | ␉␉card->cfg_name = card_configs[card->info->cfg_name].name;␊ |
1471 | ␉␉// and leave ports alone!␊ |
1472 | //␉␉card->ports = card_configs[card->info->cfg_name].ports;␊ |
1473 | ␉␉␊ |
1474 | ␉␉// which means one of the fb's or kNull␊ |
1475 | ␉␉verbose("Framebuffer set to device's default: %s\n", card->cfg_name);␊ |
1476 | ␉}␊ |
1477 | ␉else␊ |
1478 | ␉{␊ |
1479 | ␉␉// else, use the fb name returned by AtiConfig.␊ |
1480 | ␉␉verbose("(AtiConfig) Framebuffer set to: %s\n", card->cfg_name);␊ |
1481 | ␉}␊ |
1482 | ␉␊ |
1483 | ␉// Check AtiPorts key for nr of ports,␊ |
1484 | ␉card->ports = getIntForKey(kAtiPorts, &n_ports, &bootInfo->chameleonConfig);␊ |
1485 | ␉// if a value bigger than 0 ?? is found, (do we need >= 0 ?? that's null FB on card_configs)␊ |
1486 | ␉if (n_ports > 0)␊ |
1487 | ␉{␊ |
1488 | ␉␉card->ports = n_ports; // use it.␊ |
1489 | ␉␉verbose("(AtiPorts) Nr of ports set to: %d\n", card->ports);␊ |
1490 | }␊ |
1491 | ␉else// if (card->cfg_name > 0) // do we want 0 ports if fb is kNull or mistyped ?␊ |
1492 | ␉{␊ |
1493 | ␉␉// use max_ports value on radeon_cards␊ |
1494 | ␉␉card->ports = card->info->max_ports;␊ |
1495 | ␉␉// if max_ports value is 0␊ |
1496 | ␉␉if (card->ports <= 0)␊ |
1497 | ␉␉{␊ |
1498 | ␉␉␉// match cfg_name with card_configs list and retrive default nr of ports.␊ |
1499 | ␉␉␉for (i = 0; i < kCfgEnd; i++)␊ |
1500 | ␉␉␉{␊ |
1501 | ␉␉␉␉if (strcmp(card->cfg_name, card_configs[i].name) == 0)␊ |
1502 | ␉␉␉␉␉card->ports = card_configs[i].ports; // default␊ |
1503 | ␉␉␉}␊ |
1504 | ␉␉␉verbose("Nr of ports set to framebuffer's default: %d\n", card->ports);␊ |
1505 | ␉␉}␊ |
1506 | ␉␉else␊ |
1507 | ␉␉{␊ |
1508 | ␉␉␉verbose("Nr of ports set to card's ?? max: %d\n", card->ports);␊ |
1509 | ␉␉}␊ |
1510 | ␉}␊ |
1511 | //␉else␊ |
1512 | //␉␉card->ports = 2/1 ?; // set a min if 0 ports ?␊ |
1513 | //␉␉verbose("Nr of ports set to min: %d\n", card->ports);␊ |
1514 | ␉␊ |
1515 | ␉sprintf(name, "ATY,%s", card->cfg_name);␊ |
1516 | ␉aty_name.type = kStr;␊ |
1517 | ␉aty_name.size = strlen(name) + 1;␊ |
1518 | ␉aty_name.data = (uint8_t *)name;␊ |
1519 | ␉␊ |
1520 | ␉sprintf(name_parent, "ATY,%sParent", card->cfg_name);␊ |
1521 | ␉aty_nameparent.type = kStr;␊ |
1522 | ␉aty_nameparent.size = strlen(name_parent) + 1;␊ |
1523 | ␉aty_nameparent.data = (uint8_t *)name_parent;␊ |
1524 | ␉␊ |
1525 | ␉return true;␊ |
1526 | }␊ |
1527 | ␊ |
1528 | bool setup_ati_devprop(pci_dt_t *ati_dev)␊ |
1529 | {␊ |
1530 | ␉char *devicepath;␊ |
1531 | ␉␊ |
1532 | ␉if (!init_card(ati_dev))␊ |
1533 | ␉␉return false;␊ |
1534 | ␉␊ |
1535 | ␉// -------------------------------------------------␊ |
1536 | ␉// Find a better way to do this (in device_inject.c)␊ |
1537 | ␉if (!string)␊ |
1538 | ␉␉string = devprop_create_string();␊ |
1539 | ␉␊ |
1540 | ␉devicepath = get_pci_dev_path(ati_dev);␊ |
1541 | ␉card->device = devprop_add_device(string, devicepath);␊ |
1542 | ␉if (!card->device)␊ |
1543 | ␉␉return false;␊ |
1544 | ␉// -------------------------------------------------␊ |
1545 | ␉␊ |
1546 | #if 0␊ |
1547 | ␉uint64_t fb␉␉= (uint32_t)card->fb;␊ |
1548 | ␉uint64_t mmio␉= (uint32_t)card->mmio;␊ |
1549 | ␉uint64_t io␉␉= (uint32_t)card->io;␊ |
1550 | ␉devprop_add_value(card->device, "ATY,FrameBufferOffset", &fb, 8);␊ |
1551 | ␉devprop_add_value(card->device, "ATY,RegisterSpaceOffset", &mmio, 8);␊ |
1552 | ␉devprop_add_value(card->device, "ATY,IOSpaceOffset", &io, 8);␊ |
1553 | #endif␊ |
1554 | ␉␊ |
1555 | ␉devprop_add_list(ati_devprop_list);␊ |
1556 | ␉␊ |
1557 | ␉// -------------------------------------------------␊ |
1558 | ␉// Find a better way to do this (in device_inject.c)␊ |
1559 | ␉//Azi: XXX tried to fix a malloc error in vain; this is related to XCode 4 compilation!␊ |
1560 | ␉stringdata = malloc(sizeof(uint8_t) * string->length);␊ |
1561 | ␉memcpy(stringdata, (uint8_t*)devprop_generate_string(string), string->length);␊ |
1562 | ␉stringlength = string->length;␊ |
1563 | ␉// -------------------------------------------------␊ |
1564 | ␉␊ |
1565 | ␉verbose("ATI %s %s %dMB (%s) [%04x:%04x] (subsys [%04x:%04x]):: %s\n",␊ |
1566 | ␉␉␉chip_family_name[card->info->chip_family], card->info->model_name,␊ |
1567 | ␉␉␉(uint32_t)(card->vram_size / (1024 * 1024)), card->cfg_name,␊ |
1568 | ␉␉␉ati_dev->vendor_id, ati_dev->device_id,␊ |
1569 | ␉␉␉ati_dev->subsys_id.subsys.vendor_id, ati_dev->subsys_id.subsys.device_id,␊ |
1570 | ␉␉␉devicepath);␊ |
1571 | ␉␊ |
1572 | ␉free(card);␊ |
1573 | ␉␊ |
1574 | ␉return true;␊ |
1575 | }␊ |
1576 | |