prom.c
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:4k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /***********************************************************************
  2.  *
  3.  * Copyright 2001 MontaVista Software Inc.
  4.  * Author: jsun@mvista.com or jsun@junsun.net
  5.  *
  6.  * arch/mips/ddb5xxx/common/prom.c
  7.  *     prom.c file.
  8.  *
  9.  * This program is free software; you can redistribute  it and/or modify it
  10.  * under  the terms of  the GNU General  Public License as published by the
  11.  * Free Software Foundation;  either version 2 of the  License, or (at your
  12.  * option) any later version.
  13.  *
  14.  ***********************************************************************
  15.  */
  16. #include <linux/config.h>
  17. #include <linux/init.h>
  18. #include <linux/mm.h>
  19. #include <linux/sched.h>
  20. #include <linux/bootmem.h>
  21. #include <asm/addrspace.h>
  22. #include <asm/bootinfo.h>
  23. #include <asm/ddb5xxx/ddb5xxx.h>
  24. #include <asm/debug.h>
  25. char arcs_cmdline[CL_SIZE];
  26. void ddb5477_runtime_detection(void);
  27. const char *get_system_type(void)
  28. {
  29. switch (mips_machtype) {
  30. case MACH_NEC_DDB5074: return "NEC DDB Vrc-5074";
  31. case MACH_NEC_DDB5476: return "NEC DDB Vrc-5476";
  32. case MACH_NEC_DDB5477: return "NEC DDB Vrc-5477";
  33. case MACH_NEC_ROCKHOPPER: return "NEC Rockhopper";
  34. case MACH_NEC_ROCKHOPPERII: return "NEC RockhopperII";
  35. default: return "Unknown NEC board";
  36. }
  37. }
  38. /* [jsun@junsun.net] PMON passes arguments in C main() style */
  39. void __init prom_init(int argc, const char **arg)
  40. {
  41. int i;
  42. /* arg[0] is "g", the rest is boot parameters */
  43. arcs_cmdline[0] = '';
  44. for (i = 1; i < argc; i++) {
  45. if (strlen(arcs_cmdline) + strlen(arg[i] + 1)
  46.     >= sizeof(arcs_cmdline))
  47. break;
  48. strcat(arcs_cmdline, arg[i]);
  49. strcat(arcs_cmdline, " ");
  50. }
  51. /* by default all these boards use dhcp/nfs root fs */
  52. strcat(arcs_cmdline, "ip=bootp");
  53. mips_machgroup = MACH_GROUP_NEC_DDB;
  54. #if defined(CONFIG_DDB5074)
  55. mips_machtype = MACH_NEC_DDB5074;
  56. add_memory_region(0, DDB_SDRAM_SIZE, BOOT_MEM_RAM);
  57. #elif defined(CONFIG_DDB5476)
  58. mips_machtype = MACH_NEC_DDB5476;
  59. add_memory_region(0, DDB_SDRAM_SIZE, BOOT_MEM_RAM);
  60. #elif defined(CONFIG_DDB5477)
  61. ddb5477_runtime_detection();
  62. add_memory_region(0, board_ram_size, BOOT_MEM_RAM);
  63. #endif
  64. }
  65. void __init prom_free_prom_memory(void)
  66. {
  67. }
  68. #if defined(CONFIG_DDB5477)
  69. #define DEFAULT_LCS1_BASE 0x19000000
  70. #define TESTVAL1 'K'
  71. #define TESTVAL2 'S'
  72. int board_ram_size;
  73. void ddb5477_runtime_detection(void)
  74. {
  75. volatile char *test_offset;
  76. char saved_test_byte;
  77.         /* Determine if this is a DDB5477 board, or a BSB-VR0300
  78.            base board.  We can tell by checking for the location of
  79.            the NVRAM.  It lives at the beginning of LCS1 on the DDB5477,
  80.            and the beginning of LCS1 on the BSB-VR0300 is flash memory.
  81.            The first 2K of the NVRAM are reserved, so don't we'll poke
  82.            around just after that.
  83.          */
  84. /* We can only use the PCI bus to distinquish between
  85.    the Rockhopper and RockhopperII backplanes and this must
  86.    wait until ddb5477_board_init() in setup.c after the 5477
  87.    is initialized.  So, until then handle
  88.    both Rockhopper and RockhopperII backplanes as Rockhopper 1
  89.  */
  90.         test_offset = (char *)KSEG1ADDR(DEFAULT_LCS1_BASE + 0x800);
  91.         saved_test_byte = *test_offset;
  92.         *test_offset = TESTVAL1;
  93.         if (*test_offset != TESTVAL1) {
  94.                 /* We couldn't set our test value, so it must not be NVRAM,
  95.                    so it's a BSB_VR0300 */
  96. mips_machtype = MACH_NEC_ROCKHOPPER;
  97.         } else {
  98.                 /* We may have gotten lucky, and the TESTVAL1 was already
  99.                    stored at the test location, so we must check a second
  100.                    test value */
  101.                 *test_offset = TESTVAL2;
  102.                 if (*test_offset != TESTVAL2) {
  103.                         /* OK, we couldn't set this value either, so it must
  104.                            definately be a BSB_VR0300 */
  105. mips_machtype = MACH_NEC_ROCKHOPPER;
  106.                 } else {
  107.                         /* We could change the value twice, so it must be
  108.                         NVRAM, so it's a DDB_VRC5477 */
  109. mips_machtype = MACH_NEC_DDB5477;
  110.                 }
  111.         }
  112.         /* Restore the original byte */
  113.         *test_offset = saved_test_byte;
  114. /* before we know a better way, we will trust PMON for getting
  115.  * RAM size
  116.  */
  117. board_ram_size = 1 << (36 - (ddb_in32(DDB_SDRAM0) & 0xf));
  118. db_run(printk("DDB run-time detection : %s, %d MB RAMn",
  119. mips_machtype == MACH_NEC_DDB5477 ?
  120. "DDB5477" : "Rockhopper",
  121. board_ram_size >> 20));
  122. /* we can't handle ram size > 128 MB */
  123. db_assert(board_ram_size <= (128 << 20));
  124. }
  125. #endif