bootinfo.c 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /*
  2. * Extracted from arch/m68k/kernel/setup.c.
  3. * Should be properly generalized and put somewhere else.
  4. * Jesper
  5. */
  6. #include <linux/types.h>
  7. #include <linux/kernel.h>
  8. #include <linux/string.h>
  9. #include <linux/init.h>
  10. #include <asm/setup.h>
  11. #include <asm/bootinfo.h>
  12. extern char cmd_line[CL_SIZE];
  13. extern int num_memory;
  14. extern int m68k_realnum_memory;
  15. extern struct mem_info memory[NUM_MEMINFO];
  16. extern struct mem_info m68k_memory[NUM_MEMINFO];
  17. extern struct mem_info ramdisk;
  18. extern int amiga_parse_bootinfo(const struct bi_record *);
  19. extern int atari_parse_bootinfo(const struct bi_record *);
  20. extern int mac_parse_bootinfo(const struct bi_record *);
  21. void __init parse_bootinfo(const struct bi_record *record)
  22. {
  23. while (record->tag != BI_LAST) {
  24. int unknown = 0;
  25. const u_long *data = record->data;
  26. switch (record->tag) {
  27. case BI_MACHTYPE:
  28. case BI_CPUTYPE:
  29. case BI_FPUTYPE:
  30. case BI_MMUTYPE:
  31. /* Already set up by head.S */
  32. break;
  33. case BI_MEMCHUNK:
  34. if (num_memory < NUM_MEMINFO) {
  35. memory[num_memory].addr = data[0];
  36. memory[num_memory].size = data[1];
  37. num_memory++;
  38. /* FIXME: duplicate for m68k drivers. */
  39. m68k_memory[m68k_realnum_memory].addr = data[0];
  40. m68k_memory[m68k_realnum_memory].size = data[1];
  41. m68k_realnum_memory++;
  42. } else
  43. printk("parse_bootinfo: too many memory chunks\n");
  44. break;
  45. case BI_RAMDISK:
  46. ramdisk.addr = data[0];
  47. ramdisk.size = data[1];
  48. break;
  49. case BI_COMMAND_LINE:
  50. strlcpy(cmd_line, (const char *)data, sizeof(cmd_line));
  51. break;
  52. default:
  53. if (MACH_IS_AMIGA)
  54. unknown = amiga_parse_bootinfo(record);
  55. else if (MACH_IS_ATARI)
  56. unknown = atari_parse_bootinfo(record);
  57. else if (MACH_IS_MAC)
  58. unknown = mac_parse_bootinfo(record);
  59. else
  60. unknown = 1;
  61. }
  62. if (unknown)
  63. printk("parse_bootinfo: unknown tag 0x%04x ignored\n",
  64. record->tag);
  65. record = (struct bi_record *)((u_long)record+record->size);
  66. }
  67. }