patch-2_6_7-vs1_9_1_12
[linux-2.6.git] / arch / ppc / kernel / cputable.c
1 /*
2  *  arch/ppc/kernel/cputable.c
3  *
4  *  Copyright (C) 2001 Ben. Herrenschmidt (benh@kernel.crashing.org)
5  *
6  *  This program is free software; you can redistribute it and/or
7  *  modify it under the terms of the GNU General Public License
8  *  as published by the Free Software Foundation; either version
9  *  2 of the License, or (at your option) any later version.
10  */
11
12 #include <linux/config.h>
13 #include <linux/string.h>
14 #include <linux/sched.h>
15 #include <linux/threads.h>
16 #include <linux/init.h>
17 #include <asm/cputable.h>
18
19 struct cpu_spec* cur_cpu_spec[NR_CPUS];
20
21 extern void __setup_cpu_601(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
22 extern void __setup_cpu_603(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
23 extern void __setup_cpu_604(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
24 extern void __setup_cpu_750(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
25 extern void __setup_cpu_750cx(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
26 extern void __setup_cpu_750fx(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
27 extern void __setup_cpu_7400(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
28 extern void __setup_cpu_7410(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
29 extern void __setup_cpu_745x(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
30 extern void __setup_cpu_power3(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
31 extern void __setup_cpu_power4(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
32 extern void __setup_cpu_ppc970(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
33 extern void __setup_cpu_8xx(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
34 extern void __setup_cpu_generic(unsigned long offset, int cpu_nr, struct cpu_spec* spec);
35
36 #define CLASSIC_PPC (!defined(CONFIG_8xx) && !defined(CONFIG_4xx) && \
37                      !defined(CONFIG_POWER3) && !defined(CONFIG_POWER4))
38
39 /* This table only contains "desktop" CPUs, it need to be filled with embedded
40  * ones as well...
41  */
42 #define COMMON_PPC      (PPC_FEATURE_32 | PPC_FEATURE_HAS_FPU | \
43                          PPC_FEATURE_HAS_MMU)
44
45 /* We only set the altivec features if the kernel was compiled with altivec
46  * support
47  */
48 #ifdef CONFIG_ALTIVEC
49 #define CPU_FTR_ALTIVEC_COMP            CPU_FTR_ALTIVEC
50 #define PPC_FEATURE_ALTIVEC_COMP        PPC_FEATURE_HAS_ALTIVEC  
51 #else
52 #define CPU_FTR_ALTIVEC_COMP            0
53 #define PPC_FEATURE_ALTIVEC_COMP        0
54 #endif
55
56 /* We need to mark all pages as being coherent if we're SMP or we
57  * have a 754x and an MPC107 host bridge. */
58 #if defined(CONFIG_SMP) || defined(CONFIG_MPC10X_BRIDGE)
59 #define CPU_FTR_COMMON                  CPU_FTR_NEED_COHERENT
60 #else
61 #define CPU_FTR_COMMON                  0
62 #endif
63
64 struct cpu_spec cpu_specs[] = {
65 #if CLASSIC_PPC
66     {   /* 601 */
67         0xffff0000, 0x00010000, "601",
68         CPU_FTR_COMMON |
69         CPU_FTR_601 | CPU_FTR_HPTE_TABLE,
70         COMMON_PPC | PPC_FEATURE_601_INSTR | PPC_FEATURE_UNIFIED_CACHE,
71         32, 32,
72         __setup_cpu_601
73     },
74     {   /* 603 */
75         0xffff0000, 0x00030000, "603",
76         CPU_FTR_COMMON |
77         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
78         CPU_FTR_CAN_NAP,
79         COMMON_PPC,
80         32, 32,
81         __setup_cpu_603
82     },
83     {   /* 603e */
84         0xffff0000, 0x00060000, "603e",
85         CPU_FTR_COMMON |
86         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
87         CPU_FTR_CAN_NAP,
88         COMMON_PPC,
89         32, 32,
90         __setup_cpu_603
91     },
92     {   /* 603ev */
93         0xffff0000, 0x00070000, "603ev",
94         CPU_FTR_COMMON |
95         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
96         CPU_FTR_CAN_NAP,
97         COMMON_PPC,
98         32, 32,
99         __setup_cpu_603
100     },
101     {   /* 604 */
102         0xffff0000, 0x00040000, "604",
103         CPU_FTR_COMMON |
104         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_604_PERF_MON |
105         CPU_FTR_HPTE_TABLE,
106         COMMON_PPC,
107         32, 32,
108         __setup_cpu_604
109     },
110     {   /* 604e */
111         0xfffff000, 0x00090000, "604e",
112         CPU_FTR_COMMON |
113         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_604_PERF_MON |
114         CPU_FTR_HPTE_TABLE,
115         COMMON_PPC,
116         32, 32,
117         __setup_cpu_604
118     },
119     {   /* 604r */
120         0xffff0000, 0x00090000, "604r",
121         CPU_FTR_COMMON |
122         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_604_PERF_MON |
123         CPU_FTR_HPTE_TABLE,
124         COMMON_PPC,
125         32, 32,
126         __setup_cpu_604
127     },
128     {   /* 604ev */
129         0xffff0000, 0x000a0000, "604ev",
130         CPU_FTR_COMMON |
131         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_604_PERF_MON |
132         CPU_FTR_HPTE_TABLE,
133         COMMON_PPC,
134         32, 32,
135         __setup_cpu_604
136     },
137     {   /* 740/750 (0x4202, don't support TAU ?) */
138         0xffffffff, 0x00084202, "740/750",
139         CPU_FTR_COMMON |
140         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
141         CPU_FTR_L2CR | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP,
142         COMMON_PPC,
143         32, 32,
144         __setup_cpu_750
145     },
146     {   /* 745/755 */
147         0xfffff000, 0x00083000, "745/755",
148         CPU_FTR_COMMON |
149         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
150         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP,
151         COMMON_PPC,
152         32, 32,
153         __setup_cpu_750
154     },
155     {   /* 750CX (80100 and 8010x?) */
156         0xfffffff0, 0x00080100, "750CX",
157         CPU_FTR_COMMON |
158         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
159         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP,
160         COMMON_PPC,
161         32, 32,
162         __setup_cpu_750cx
163     },
164     {   /* 750CX (82201 and 82202) */
165         0xfffffff0, 0x00082200, "750CX",
166         CPU_FTR_COMMON |
167         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
168         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP,
169         COMMON_PPC,
170         32, 32,
171         __setup_cpu_750cx
172     },
173     {   /* 750CXe (82214) */
174         0xfffffff0, 0x00082210, "750CXe",
175         CPU_FTR_COMMON |
176         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
177         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP,
178         COMMON_PPC,
179         32, 32,
180         __setup_cpu_750cx
181     },
182     {   /* 750FX rev 1.x */
183         0xffffff00, 0x70000100, "750FX",
184         CPU_FTR_COMMON |
185         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
186         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP |
187         CPU_FTR_DUAL_PLL_750FX | CPU_FTR_NO_DPM,
188         COMMON_PPC,
189         32, 32,
190         __setup_cpu_750
191     },
192     {   /* 750FX rev 2.0 must disable HID0[DPM] */
193         0xffffffff, 0x70000200, "750FX",
194         CPU_FTR_COMMON |
195         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
196         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP |
197         CPU_FTR_NO_DPM,
198         COMMON_PPC,
199         32, 32,
200         __setup_cpu_750
201     },
202     {   /* 750FX (All revs except 2.0) */
203         0xffff0000, 0x70000000, "750FX",
204         CPU_FTR_COMMON |
205         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
206         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP |
207         CPU_FTR_DUAL_PLL_750FX | CPU_FTR_HAS_HIGH_BATS,
208         COMMON_PPC,
209         32, 32,
210         __setup_cpu_750fx
211     },
212     {   /* 750GX */
213         0xffff0000, 0x70020000, "750GX",
214         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
215         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP |
216         CPU_FTR_DUAL_PLL_750FX | CPU_FTR_HAS_HIGH_BATS,
217         COMMON_PPC,
218         32, 32,
219         __setup_cpu_750fx
220     },
221     {   /* 740/750 (L2CR bit need fixup for 740) */
222         0xffff0000, 0x00080000, "740/750",
223         CPU_FTR_COMMON |
224         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
225         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_HPTE_TABLE | CPU_FTR_CAN_NAP,
226         COMMON_PPC,
227         32, 32,
228         __setup_cpu_750
229     },
230     {   /* 7400 rev 1.1 ? (no TAU) */
231         0xffffffff, 0x000c1101, "7400 (1.1)",
232         CPU_FTR_COMMON |
233         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
234         CPU_FTR_L2CR | CPU_FTR_ALTIVEC_COMP | CPU_FTR_HPTE_TABLE |
235         CPU_FTR_CAN_NAP,
236         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
237         32, 32,
238         __setup_cpu_7400
239     },
240     {   /* 7400 */
241         0xffff0000, 0x000c0000, "7400",
242         CPU_FTR_COMMON |
243         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
244         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_ALTIVEC_COMP | CPU_FTR_HPTE_TABLE |
245         CPU_FTR_CAN_NAP,
246         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
247         32, 32,
248         __setup_cpu_7400
249     },
250     {   /* 7410 */
251         0xffff0000, 0x800c0000, "7410",
252         CPU_FTR_COMMON |
253         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
254         CPU_FTR_L2CR | CPU_FTR_TAU | CPU_FTR_ALTIVEC_COMP | CPU_FTR_HPTE_TABLE |
255         CPU_FTR_CAN_NAP,
256         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
257         32, 32,
258         __setup_cpu_7410
259     },
260     {   /* 7450 2.0 - no doze/nap */
261         0xffffffff, 0x80000200, "7450",
262         CPU_FTR_COMMON |
263         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB |
264         CPU_FTR_L2CR | CPU_FTR_ALTIVEC_COMP | CPU_FTR_L3CR |
265         CPU_FTR_HPTE_TABLE | CPU_FTR_SPEC7450,
266         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
267         32, 32,
268         __setup_cpu_745x
269     },
270     {   /* 7450 2.1 */
271         0xffffffff, 0x80000201, "7450",
272         CPU_FTR_COMMON |
273         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_CAN_NAP |
274         CPU_FTR_L2CR | CPU_FTR_ALTIVEC_COMP | CPU_FTR_L3CR |
275         CPU_FTR_HPTE_TABLE | CPU_FTR_SPEC7450 | CPU_FTR_NAP_DISABLE_L2_PR |
276         CPU_FTR_L3_DISABLE_NAP,
277         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
278         32, 32,
279         __setup_cpu_745x
280     },
281     {   /* 7450 2.3 and newer */
282         0xffff0000, 0x80000000, "7450",
283         CPU_FTR_COMMON |
284         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_CAN_NAP |
285         CPU_FTR_L2CR | CPU_FTR_ALTIVEC_COMP | CPU_FTR_L3CR |
286         CPU_FTR_HPTE_TABLE | CPU_FTR_SPEC7450 | CPU_FTR_NAP_DISABLE_L2_PR,
287         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
288         32, 32,
289         __setup_cpu_745x
290     },
291     {   /* 7455 rev 1.x */
292         0xffffff00, 0x80010100, "7455",
293         CPU_FTR_COMMON |
294         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB |
295         CPU_FTR_L2CR | CPU_FTR_ALTIVEC_COMP | CPU_FTR_L3CR |
296         CPU_FTR_HPTE_TABLE | CPU_FTR_SPEC7450 | CPU_FTR_HAS_HIGH_BATS,
297         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
298         32, 32,
299         __setup_cpu_745x
300     },
301     {   /* 7455 rev 2.0 */
302         0xffffffff, 0x80010200, "7455",
303         CPU_FTR_COMMON |
304         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_CAN_NAP |
305         CPU_FTR_L2CR | CPU_FTR_ALTIVEC_COMP | CPU_FTR_L3CR |
306         CPU_FTR_HPTE_TABLE | CPU_FTR_SPEC7450 | CPU_FTR_NAP_DISABLE_L2_PR |
307         CPU_FTR_L3_DISABLE_NAP | CPU_FTR_HAS_HIGH_BATS,
308         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
309         32, 32,
310         __setup_cpu_745x
311     },
312     {   /* 7455 others */
313         0xffff0000, 0x80010000, "7455",
314         CPU_FTR_COMMON |
315         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_CAN_NAP |
316         CPU_FTR_L2CR | CPU_FTR_ALTIVEC_COMP | CPU_FTR_L3CR |
317         CPU_FTR_HPTE_TABLE | CPU_FTR_SPEC7450 | CPU_FTR_NAP_DISABLE_L2_PR |
318         CPU_FTR_HAS_HIGH_BATS,
319         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
320         32, 32,
321         __setup_cpu_745x
322     },
323     {   /* 7457 */
324         0xffff0000, 0x80020000, "7457",
325         CPU_FTR_COMMON |
326         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_CAN_NAP |
327         CPU_FTR_L2CR | CPU_FTR_ALTIVEC_COMP | CPU_FTR_L3CR |
328         CPU_FTR_HPTE_TABLE | CPU_FTR_SPEC7450 | CPU_FTR_NAP_DISABLE_L2_PR |
329         CPU_FTR_HAS_HIGH_BATS,
330         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
331         32, 32,
332         __setup_cpu_745x
333     },
334     {   /* 7447A */
335         0xffff0000, 0x80030000, "7447A",
336         CPU_FTR_COMMON |
337         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_CAN_NAP |
338         CPU_FTR_L2CR | CPU_FTR_ALTIVEC_COMP |
339         CPU_FTR_HPTE_TABLE | CPU_FTR_SPEC7450 | CPU_FTR_NAP_DISABLE_L2_PR |
340         CPU_FTR_HAS_HIGH_BATS,
341         COMMON_PPC | PPC_FEATURE_ALTIVEC_COMP,
342         32, 32,
343         __setup_cpu_745x
344     },
345     {   /* 82xx (8240, 8245, 8260 are all 603e cores) */
346         0x7fff0000, 0x00810000, "82xx",
347         CPU_FTR_COMMON |
348         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB,
349         COMMON_PPC,
350         32, 32,
351         __setup_cpu_603
352     },
353     {   /* 8280 is a G2_LE (603e core, plus some) */
354         0x7fff0000, 0x00820000, "8280",
355         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_CAN_DOZE | CPU_FTR_USE_TB |
356         CPU_FTR_CAN_NAP | CPU_FTR_HAS_HIGH_BATS,
357         COMMON_PPC,
358         32, 32,
359         __setup_cpu_603
360     },
361     {   /* default match, we assume split I/D cache & TB (non-601)... */
362         0x00000000, 0x00000000, "(generic PPC)",
363         CPU_FTR_COMMON |
364         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_HPTE_TABLE,
365         COMMON_PPC,
366         32, 32,
367         __setup_cpu_generic
368     },
369 #endif /* CLASSIC_PPC */
370 #ifdef CONFIG_PPC64BRIDGE
371     {   /* Power3 */
372         0xffff0000, 0x00400000, "Power3 (630)",
373         CPU_FTR_COMMON |
374         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_HPTE_TABLE,
375         COMMON_PPC | PPC_FEATURE_64,
376         128, 128,
377         __setup_cpu_power3
378     },
379     {   /* Power3+ */
380         0xffff0000, 0x00410000, "Power3 (630+)",
381         CPU_FTR_COMMON |
382         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_HPTE_TABLE,
383         COMMON_PPC | PPC_FEATURE_64,
384         128, 128,
385         __setup_cpu_power3
386     },
387         {       /* I-star */
388                 0xffff0000, 0x00360000, "I-star",
389                 CPU_FTR_COMMON |
390                 CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_HPTE_TABLE,
391                 COMMON_PPC | PPC_FEATURE_64,
392                 128, 128,
393                 __setup_cpu_power3
394         },
395         {       /* S-star */
396                 0xffff0000, 0x00370000, "S-star",
397                 CPU_FTR_COMMON |
398                 CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_HPTE_TABLE,
399                 COMMON_PPC | PPC_FEATURE_64,
400                 128, 128,
401                 __setup_cpu_power3
402         },
403 #endif /* CONFIG_PPC64BRIDGE */
404 #ifdef CONFIG_POWER4
405     {   /* Power4 */
406         0xffff0000, 0x00350000, "Power4",
407         CPU_FTR_COMMON |
408         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_HPTE_TABLE,
409         COMMON_PPC | PPC_FEATURE_64,
410         128, 128,
411         __setup_cpu_power4
412     },
413     {   /* PPC970 */
414         0xffff0000, 0x00390000, "PPC970",
415         CPU_FTR_COMMON |
416         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB | CPU_FTR_HPTE_TABLE |
417         CPU_FTR_ALTIVEC_COMP | CPU_FTR_CAN_NAP,
418         COMMON_PPC | PPC_FEATURE_64 | PPC_FEATURE_ALTIVEC_COMP,
419         128, 128,
420         __setup_cpu_ppc970
421     },
422 #endif /* CONFIG_POWER4 */
423 #ifdef CONFIG_8xx
424     {   /* 8xx */
425         0xffff0000, 0x00500000, "8xx",
426                 /* CPU_FTR_CAN_DOZE is possible, if the 8xx code is there.... */
427         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
428         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
429         16, 16,
430         __setup_cpu_8xx /* Empty */
431     },
432 #endif /* CONFIG_8xx */
433 #ifdef CONFIG_40x
434     {   /* 403GC */
435         0xffffff00, 0x00200200, "403GC",
436         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
437         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
438         16, 16,
439         0, /*__setup_cpu_403 */
440     },
441     {   /* 403GCX */
442         0xffffff00, 0x00201400, "403GCX",
443         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
444         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
445         16, 16,
446         0, /*__setup_cpu_403 */
447     },
448     {   /* 403G ?? */
449         0xffff0000, 0x00200000, "403G ??",
450         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
451         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
452         16, 16,
453         0, /*__setup_cpu_403 */
454     },
455     {   /* 405GP */
456         0xffff0000, 0x40110000, "405GP",
457         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
458         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC,
459         32, 32,
460         0, /*__setup_cpu_405 */
461     },
462     {   /* STB 03xxx */
463         0xffff0000, 0x40130000, "STB03xxx",
464         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
465         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC,
466         32, 32,
467         0, /*__setup_cpu_405 */
468     },
469     {   /* STB 04xxx */
470         0xffff0000, 0x41810000, "STB04xxx",
471         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
472         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC,
473         32, 32,
474         0, /*__setup_cpu_405 */
475     },
476     {   /* NP405L */
477         0xffff0000, 0x41610000, "NP405L",
478         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
479         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC,
480         32, 32,
481         0, /*__setup_cpu_405 */
482     },
483     {   /* NP4GS3 */
484         0xffff0000, 0x40B10000, "NP4GS3",
485         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
486         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC,
487         32, 32,
488         0, /*__setup_cpu_405 */
489     },
490     {   /* NP405H */
491         0xffff0000, 0x41410000, "NP405H",
492         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
493         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC,
494         32, 32,
495         0, /*__setup_cpu_405 */
496      },
497      {  /* 405GPr */
498         0xffff0000, 0x50910000, "405GPr",
499         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
500         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC,
501         32, 32,
502         0, /*__setup_cpu_405 */
503     },
504     {   /* STBx25xx */
505         0xffff0000, 0x51510000, "STBx25xx",
506         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
507         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC,
508         32, 32,
509         0, /*__setup_cpu_405 */
510      },
511      {  /* 405LP */
512         0xffff0000, 0x41F10000, "405LP",
513         CPU_FTR_SPLIT_ID_CACHE |  CPU_FTR_USE_TB,
514         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
515         32, 32,
516         0, /*__setup_cpu_405 */
517      },
518      {  /* Xilinx Virtex-II Pro  */
519         0xffff0000, 0x20010000, "Virtex-II Pro",
520         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
521         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC,
522         32, 32,
523         0, /*__setup_cpu_405 */
524      },
525
526 #endif /* CONFIG_40x */
527 #ifdef CONFIG_44x
528     { /* 440GP Rev. B */
529         0xf0000fff, 0x40000440, "440GP Rev. B",
530         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
531         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
532         32, 32,
533         0, /*__setup_cpu_440 */
534     },
535     { /* 440GP Rev. C */
536         0xf0000fff, 0x40000481, "440GP Rev. C",
537         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
538         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
539         32, 32,
540         0, /*__setup_cpu_440 */
541     },
542     { /* 440GX Rev. A */
543         0xf0000fff, 0x50000850, "440GX Rev. A",
544         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
545         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
546         32, 32,
547         0, /*__setup_cpu_440 */
548     },
549     { /* 440GX Rev. B */
550         0xf0000fff, 0x50000851, "440GX Rev. B",
551         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
552         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
553         32, 32,
554         0, /*__setup_cpu_440 */
555     },
556     { /* 440GX Rev. C */
557         0xf0000fff, 0x50000892, "440GX Rev. C",
558         CPU_FTR_SPLIT_ID_CACHE | CPU_FTR_USE_TB,
559         PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU,
560         32, 32,
561         0, /*__setup_cpu_440 */
562     },
563 #endif /* CONFIG_44x */
564 #if !CLASSIC_PPC
565     {   /* default match */
566         0x00000000, 0x00000000, "(generic PPC)",
567         CPU_FTR_COMMON,
568         PPC_FEATURE_32,
569         32, 32,
570         0,
571     }
572 #endif /* !CLASSIC_PPC */
573 };