pmon_prom.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. /*
  2. *
  3. * BRIEF MODULE DESCRIPTION
  4. * PROM library initialisation code, assuming a version of
  5. * pmon is the boot code.
  6. *
  7. * Copyright 2000 MontaVista Software Inc.
  8. * Author: MontaVista Software, Inc.
  9. * ppopov@mvista.com or source@mvista.com
  10. *
  11. * This file was derived from Carsten Langgaard's
  12. * arch/mips/mips-boards/xx files.
  13. *
  14. * Carsten Langgaard, carstenl@mips.com
  15. * Copyright (C) 1999,2000 MIPS Technologies, Inc. All rights reserved.
  16. *
  17. * This program is free software; you can redistribute it and/or modify it
  18. * under the terms of the GNU General Public License as published by the
  19. * Free Software Foundation; either version 2 of the License, or (at your
  20. * option) any later version.
  21. *
  22. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
  23. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  24. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN
  25. * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  26. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  27. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  28. * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
  29. * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  30. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  31. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  32. *
  33. * You should have received a copy of the GNU General Public License along
  34. * with this program; if not, write to the Free Software Foundation, Inc.,
  35. * 675 Mass Ave, Cambridge, MA 02139, USA.
  36. */
  37. #include <linux/config.h>
  38. #include <linux/kernel.h>
  39. #include <linux/init.h>
  40. #include <linux/string.h>
  41. #include <asm/bootinfo.h>
  42. extern int prom_argc;
  43. extern char **prom_argv, **prom_envp;
  44. typedef struct
  45. {
  46. char *name;
  47. /* char *val; */
  48. }t_env_var;
  49. char * __init prom_getcmdline(void)
  50. {
  51. return &(arcs_cmdline[0]);
  52. }
  53. void __init prom_init_cmdline(void)
  54. {
  55. char *cp;
  56. int actr;
  57. actr = 1; /* Always ignore argv[0] */
  58. cp = &(arcs_cmdline[0]);
  59. while(actr < prom_argc) {
  60. strcpy(cp, prom_argv[actr]);
  61. cp += strlen(prom_argv[actr]);
  62. *cp++ = ' ';
  63. actr++;
  64. }
  65. if (cp != &(arcs_cmdline[0])) /* get rid of trailing space */
  66. --cp;
  67. *cp = '\0';
  68. }
  69. char *prom_getenv(char *envname)
  70. {
  71. /*
  72. * Return a pointer to the given environment variable.
  73. * Environment variables are stored in the form of "memsize=64".
  74. */
  75. t_env_var *env = (t_env_var *)prom_envp;
  76. int i;
  77. i = strlen(envname);
  78. while(env->name) {
  79. if(strncmp(envname, env->name, i) == 0) {
  80. return(env->name + strlen(envname) + 1);
  81. }
  82. env++;
  83. }
  84. return(NULL);
  85. }
  86. static inline unsigned char str2hexnum(unsigned char c)
  87. {
  88. if(c >= '0' && c <= '9')
  89. return c - '0';
  90. if(c >= 'a' && c <= 'f')
  91. return c - 'a' + 10;
  92. return 0; /* foo */
  93. }
  94. unsigned long __init prom_free_prom_memory(void)
  95. {
  96. return 0;
  97. }
  98. unsigned long __init prom_get_memsize(void)
  99. {
  100. char *memsize_str;
  101. unsigned int memsize;
  102. memsize_str = prom_getenv("memsize");
  103. if (!memsize_str) {
  104. #ifdef CONFIG_MIPS_ITE8172
  105. memsize = 32;
  106. #elif defined(CONFIG_MIPS_IVR)
  107. memsize = 64;
  108. #else
  109. memsize = 8;
  110. #endif
  111. printk("memsize unknown: setting to %dMB\n", memsize);
  112. } else {
  113. printk("memsize: %s\n", memsize_str);
  114. memsize = simple_strtol(memsize_str, NULL, 0);
  115. }
  116. return memsize;
  117. }