init.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. /*
  2. * Copyright (C) 1999, 2000, 2004, 2005 MIPS Technologies, Inc.
  3. * All rights reserved.
  4. * Authors: Carsten Langgaard <carstenl@mips.com>
  5. * Maciej W. Rozycki <macro@mips.com>
  6. * Portions copyright (C) 2009 Cisco Systems, Inc.
  7. *
  8. * This program is free software; you can distribute it and/or modify it
  9. * under the terms of the GNU General Public License (Version 2) as
  10. * published by the Free Software Foundation.
  11. *
  12. * This program is distributed in the hope it will be useful, but WITHOUT
  13. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  14. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
  15. * for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License along
  18. * with this program; if not, write to the Free Software Foundation, Inc.,
  19. * 59 Temple Place - Suite 330, Boston MA 02111-1307, USA.
  20. *
  21. * PROM library initialisation code.
  22. */
  23. #include <linux/init.h>
  24. #include <linux/string.h>
  25. #include <linux/kernel.h>
  26. #include <asm/bootinfo.h>
  27. #include <linux/io.h>
  28. #include <asm/cacheflush.h>
  29. #include <asm/traps.h>
  30. #include <asm/mips-boards/prom.h>
  31. #include <asm/mips-boards/generic.h>
  32. #include <asm/mach-powertv/asic.h>
  33. static int *_prom_envp;
  34. unsigned long _prom_memsize;
  35. /*
  36. * YAMON (32-bit PROM) pass arguments and environment as 32-bit pointer.
  37. * This macro take care of sign extension, if running in 64-bit mode.
  38. */
  39. #define prom_envp(index) ((char *)(long)_prom_envp[(index)])
  40. char *prom_getenv(char *envname)
  41. {
  42. char *result = NULL;
  43. if (_prom_envp != NULL) {
  44. /*
  45. * Return a pointer to the given environment variable.
  46. * In 64-bit mode: we're using 64-bit pointers, but all pointers
  47. * in the PROM structures are only 32-bit, so we need some
  48. * workarounds, if we are running in 64-bit mode.
  49. */
  50. int i, index = 0;
  51. i = strlen(envname);
  52. while (prom_envp(index)) {
  53. if (strncmp(envname, prom_envp(index), i) == 0) {
  54. result = prom_envp(index + 1);
  55. break;
  56. }
  57. index += 2;
  58. }
  59. }
  60. return result;
  61. }
  62. /* TODO: Verify on linux-mips mailing list that the following two */
  63. /* functions are correct */
  64. /* TODO: Copy NMI and EJTAG exception vectors to memory from the */
  65. /* BootROM exception vectors. Flush their cache entries. test it. */
  66. static void __init mips_nmi_setup(void)
  67. {
  68. void *base;
  69. #if defined(CONFIG_CPU_MIPS32_R1)
  70. base = cpu_has_veic ?
  71. (void *)(CAC_BASE + 0xa80) :
  72. (void *)(CAC_BASE + 0x380);
  73. #elif defined(CONFIG_CPU_MIPS32_R2)
  74. base = (void *)0xbfc00000;
  75. #else
  76. #error NMI exception handler address not defined
  77. #endif
  78. }
  79. static void __init mips_ejtag_setup(void)
  80. {
  81. void *base;
  82. #if defined(CONFIG_CPU_MIPS32_R1)
  83. base = cpu_has_veic ?
  84. (void *)(CAC_BASE + 0xa00) :
  85. (void *)(CAC_BASE + 0x300);
  86. #elif defined(CONFIG_CPU_MIPS32_R2)
  87. base = (void *)0xbfc00480;
  88. #else
  89. #error EJTAG exception handler address not defined
  90. #endif
  91. }
  92. void __init prom_init(void)
  93. {
  94. int prom_argc;
  95. char *prom_argv;
  96. prom_argc = fw_arg0;
  97. prom_argv = (char *) fw_arg1;
  98. _prom_envp = (int *) fw_arg2;
  99. _prom_memsize = (unsigned long) fw_arg3;
  100. board_nmi_handler_setup = mips_nmi_setup;
  101. board_ejtag_handler_setup = mips_ejtag_setup;
  102. if (prom_argc == 1) {
  103. strlcat(arcs_cmdline, " ", COMMAND_LINE_SIZE);
  104. strlcat(arcs_cmdline, prom_argv, COMMAND_LINE_SIZE);
  105. }
  106. configure_platform();
  107. prom_meminit();
  108. #ifndef CONFIG_BOOTLOADER_DRIVER
  109. pr_info("\nBootloader driver isn't loaded...\n");
  110. #endif
  111. }