decstation.c 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. /*
  2. * arch/mips/dec/decstation.c
  3. */
  4. #include <asm/sections.h>
  5. #define RELOC
  6. #define INITRD
  7. #define DEBUG_BOOT
  8. /*
  9. * Magic number indicating REX PROM available on DECSTATION.
  10. */
  11. #define REX_PROM_MAGIC 0x30464354
  12. #define REX_PROM_CLEARCACHE 0x7c/4
  13. #define REX_PROM_PRINTF 0x30/4
  14. #define VEC_RESET 0xBFC00000 /* Prom base address */
  15. #define PMAX_PROM_ENTRY(x) (VEC_RESET+((x)*8)) /* Prom jump table */
  16. #define PMAX_PROM_PRINTF PMAX_PROM_ENTRY(17)
  17. #define PARAM (k_start + 0x2000)
  18. #define LOADER_TYPE (*(unsigned char *) (PARAM+0x210))
  19. #define INITRD_START (*(unsigned long *) (PARAM+0x218))
  20. #define INITRD_SIZE (*(unsigned long *) (PARAM+0x21c))
  21. extern int _ftext; /* begin and end of kernel image */
  22. extern void kernel_entry(int, char **, unsigned long, int *);
  23. void * memcpy(void * dest, const void *src, unsigned int count)
  24. {
  25. unsigned long *tmp = (unsigned long *) dest, *s = (unsigned long *) src;
  26. count >>= 2;
  27. while (count--)
  28. *tmp++ = *s++;
  29. return dest;
  30. }
  31. void dec_entry(int argc, char **argv,
  32. unsigned long magic, int *prom_vec)
  33. {
  34. void (*rex_clear_cache)(void);
  35. int (*prom_printf)(char *, ...);
  36. unsigned long k_start, len;
  37. /*
  38. * The DS5100 leaves cpu with BEV enabled, clear it.
  39. */
  40. asm( "lui\t$8,0x3000\n\t"
  41. "mtc0\t$8,$12\n\t"
  42. ".section\t.sdata\n\t"
  43. ".section\t.sbss\n\t"
  44. ".section\t.text"
  45. : : : "$8");
  46. #ifdef DEBUG_BOOT
  47. if (magic == REX_PROM_MAGIC) {
  48. prom_printf = (int (*)(char *, ...)) *(prom_vec + REX_PROM_PRINTF);
  49. } else {
  50. prom_printf = (int (*)(char *, ...)) PMAX_PROM_PRINTF;
  51. }
  52. prom_printf("Launching kernel...\n");
  53. #endif
  54. k_start = (unsigned long) (&kernel_entry) & 0xffff0000;
  55. #ifdef RELOC
  56. /*
  57. * Now copy kernel image to its destination.
  58. */
  59. len = ((unsigned long) (&_end) - k_start);
  60. memcpy((void *)k_start, &_ftext, len);
  61. #endif
  62. if (magic == REX_PROM_MAGIC) {
  63. rex_clear_cache = (void (*)(void)) * (prom_vec + REX_PROM_CLEARCACHE);
  64. rex_clear_cache();
  65. }
  66. kernel_entry(argc, argv, magic, prom_vec);
  67. }