blob: 46260fcbdf4bab4208bb871b89b355e73c31b49b [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 Mundte82da212009-08-15 10:48:13 +090024 switch (current_cpu_data.family) {
25 case CPU_FAMILY_SH2:
Linus Torvalds1da177e2005-04-16 15:20:36 -070026 *p++ = '2';
27 break;
Paul Mundte82da212009-08-15 10:48:13 +090028 case CPU_FAMILY_SH2A:
Yoshinori Satob2296322006-11-05 16:18:08 +090029 *p++ = '2';
30 *p++ = 'a';
31 break;
Paul Mundte82da212009-08-15 10:48:13 +090032 case CPU_FAMILY_SH3:
Linus Torvalds1da177e2005-04-16 15:20:36 -070033 *p++ = '3';
34 break;
Paul Mundte82da212009-08-15 10:48:13 +090035 case CPU_FAMILY_SH4:
Linus Torvalds1da177e2005-04-16 15:20:36 -070036 *p++ = '4';
37 break;
Paul Mundte82da212009-08-15 10:48:13 +090038 case CPU_FAMILY_SH4A:
Paul Mundt5b19c902006-09-27 14:31:40 +090039 *p++ = '4';
40 *p++ = 'a';
41 break;
Paul Mundte82da212009-08-15 10:48:13 +090042 case CPU_FAMILY_SH4AL_DSP:
Paul Mundt41504c32006-12-11 20:28:03 +090043 *p++ = '4';
44 *p++ = 'a';
45 *p++ = 'l';
46 *p++ = '-';
47 *p++ = 'd';
48 *p++ = 's';
49 *p++ = 'p';
50 break;
Paul Mundte82da212009-08-15 10:48:13 +090051 case CPU_FAMILY_SH5:
Paul Mundt29e0d202007-11-22 13:11:39 +090052 *p++ = '6';
53 *p++ = '4';
54 break;
Paul Mundte82da212009-08-15 10:48:13 +090055 case CPU_FAMILY_UNKNOWN:
Paul Mundt29e0d202007-11-22 13:11:39 +090056 /*
Paul Mundte82da212009-08-15 10:48:13 +090057 * Specifically use CPU_FAMILY_UNKNOWN rather than
58 * default:, so we're able to have the compiler whine
59 * about unhandled enumerations.
Paul Mundt29e0d202007-11-22 13:11:39 +090060 */
Linus Torvalds1da177e2005-04-16 15:20:36 -070061 break;
62 }
63
Paul Mundt11c19652006-12-25 10:19:56 +090064 printk("CPU: %s\n", get_cpu_subtype(&current_cpu_data));
Linus Torvalds1da177e2005-04-16 15:20:36 -070065
66#ifndef __LITTLE_ENDIAN__
67 /* 'eb' means 'Endian Big' */
68 *p++ = 'e';
69 *p++ = 'b';
70#endif
71 *p = '\0';
72}
73#endif /* __ASM_SH_BUGS_H */