blob: aeee8da9c54f57dea4036b12686fcf9ec002951a [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#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
17static void __init check_bugs(void)
18{
Linus Torvalds1da177e2005-04-16 15:20:36 -070019 extern unsigned long loops_per_jiffy;
Paul Mundt41504c32006-12-11 20:28:03 +090020 char *p = &init_utsname()->machine[2]; /* "sh" */
Linus Torvalds1da177e2005-04-16 15:20:36 -070021
Paul Mundt11c19652006-12-25 10:19:56 +090022 current_cpu_data.loops_per_jiffy = loops_per_jiffy;
Linus Torvalds1da177e2005-04-16 15:20:36 -070023
Paul Mundt11c19652006-12-25 10:19:56 +090024 switch (current_cpu_data.type) {
Paul Mundt14bea952007-06-11 10:18:45 +090025 case CPU_SH7619:
Linus Torvalds1da177e2005-04-16 15:20:36 -070026 *p++ = '2';
27 break;
Yoshinori Satob2296322006-11-05 16:18:08 +090028 case CPU_SH7206:
29 *p++ = '2';
30 *p++ = 'a';
31 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -070032 case CPU_SH7705 ... CPU_SH7300:
33 *p++ = '3';
34 break;
35 case CPU_SH7750 ... CPU_SH4_501:
36 *p++ = '4';
37 break;
Paul Mundt2b1bd1a2007-06-20 18:27:10 +090038 case CPU_SH7770 ... CPU_SHX3:
Paul Mundt5b19c902006-09-27 14:31:40 +090039 *p++ = '4';
40 *p++ = 'a';
41 break;
Paul Mundt41504c32006-12-11 20:28:03 +090042 case CPU_SH73180 ... CPU_SH7722:
43 *p++ = '4';
44 *p++ = 'a';
45 *p++ = 'l';
46 *p++ = '-';
47 *p++ = 'd';
48 *p++ = 's';
49 *p++ = 'p';
50 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -070051 default:
52 *p++ = '?';
53 *p++ = '!';
54 break;
55 }
56
Paul Mundt11c19652006-12-25 10:19:56 +090057 printk("CPU: %s\n", get_cpu_subtype(&current_cpu_data));
Linus Torvalds1da177e2005-04-16 15:20:36 -070058
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 */