]>
Commit | Line | Data |
---|---|---|
1da177e4 LT |
1 | #ifndef __ASM_SH_BUGS_H |
2 | #define __ASM_SH_BUGS_H | |
3 | ||
4 | /* | |
5 | * This is included by init/main.c to check for architecture-dependent bugs. | |
6 | * | |
7 | * Needs: | |
8 | * void check_bugs(void); | |
9 | */ | |
10 | ||
11 | /* | |
12 | * I don't know of any Super-H bugs yet. | |
13 | */ | |
14 | ||
15 | #include <asm/processor.h> | |
16 | ||
17 | static void __init check_bugs(void) | |
18 | { | |
1da177e4 | 19 | extern unsigned long loops_per_jiffy; |
41504c39 | 20 | char *p = &init_utsname()->machine[2]; /* "sh" */ |
1da177e4 | 21 | |
11c19656 | 22 | current_cpu_data.loops_per_jiffy = loops_per_jiffy; |
1da177e4 | 23 | |
11c19656 | 24 | switch (current_cpu_data.type) { |
14bea95b | 25 | case CPU_SH7619: |
1da177e4 LT |
26 | *p++ = '2'; |
27 | break; | |
b229632a YS |
28 | case CPU_SH7206: |
29 | *p++ = '2'; | |
30 | *p++ = 'a'; | |
31 | break; | |
d89ddd1c | 32 | case CPU_SH7705 ... CPU_SH7729: |
1da177e4 LT |
33 | *p++ = '3'; |
34 | break; | |
35 | case CPU_SH7750 ... CPU_SH4_501: | |
36 | *p++ = '4'; | |
37 | break; | |
2b1bd1ac | 38 | case CPU_SH7770 ... CPU_SHX3: |
5b19c908 PM |
39 | *p++ = '4'; |
40 | *p++ = 'a'; | |
41 | break; | |
870e8a24 | 42 | case CPU_SH7343 ... CPU_SH7722: |
41504c39 PM |
43 | *p++ = '4'; |
44 | *p++ = 'a'; | |
45 | *p++ = 'l'; | |
46 | *p++ = '-'; | |
47 | *p++ = 'd'; | |
48 | *p++ = 's'; | |
49 | *p++ = 'p'; | |
50 | break; | |
1da177e4 LT |
51 | default: |
52 | *p++ = '?'; | |
53 | *p++ = '!'; | |
54 | break; | |
55 | } | |
56 | ||
11c19656 | 57 | printk("CPU: %s\n", get_cpu_subtype(¤t_cpu_data)); |
1da177e4 LT |
58 | |
59 | #ifndef __LITTLE_ENDIAN__ | |
60 | /* 'eb' means 'Endian Big' */ | |
61 | *p++ = 'e'; | |
62 | *p++ = 'b'; | |
63 | #endif | |
64 | *p = '\0'; | |
65 | } | |
66 | #endif /* __ASM_SH_BUGS_H */ |