bugs.h 1.1 KB

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