boot.h 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. /*
  2. * boot.h
  3. *
  4. */
  5. /*
  6. Copyright (c) 2007-2018, MIPS Tech, LLC and/or its affiliated group companies or licensors
  7. All rights reserved.
  8. Redistribution and use in source and binary forms, with or without modification, are
  9. permitted provided that the following conditions are met:
  10. 1. Redistributions of source code must retain the above copyright notice, this list of
  11. conditions and the following disclaimer.
  12. 2. Redistributions in binary form must reproduce the above copyright notice, this list
  13. of conditions and the following disclaimer in the documentation and/or other materials
  14. provided with the distribution.
  15. 3. Neither the name of the copyright holder nor the names of its contributors may be
  16. used to endorse or promote products derived from this software without specific prior
  17. written permission.
  18. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
  19. EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  20. OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
  21. SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  22. SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
  23. OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  24. HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  25. OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  26. SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27. */
  28. #include <mips/m32c0.h>
  29. #ifdef EVA // use direct mapping
  30. #define GIC_SH_WEDGE_ADDR *((volatile unsigned int*) (0x1bdc0280))
  31. #define GCR_CONFIG_ADDR 0x1fbf8000 // Boot address of the GCR registers
  32. #define GCR_CONFIG_ADDR_PB 0xbfbf8000 // Post Boot address of the GCR registers
  33. #define GIC_P_BASE_ADDR 0x1bdc0000 // physical address of the GIC
  34. #define GIC_BASE_ADDR 0x1bdc0000 // Boot address address of the GIC
  35. #define GIC_BASE_ADDR_PB 0xbbdc0000 // Post Boot address address of the GIC
  36. #define CPC_P_BASE_ADDR 0x1bde0001 // physical address of the CPC including enable bit
  37. #define CPC_BASE_ADDR 0x1bde0000 // Boot address address of the CPC
  38. #define CPC_BASE_ADDR_PB 0xbbde0000 // Post Boot address address of the CPC
  39. #define STACK_BASE_ADDR 0x02000000 /* Change: Base on memory size. */
  40. #elif defined MPU
  41. #define GIC_SH_WEDGE_ADDR *((volatile unsigned int*) (0x1bdc0280))
  42. #define GCR_CONFIG_ADDR 0x1fbf8000 // MPU Direct map address of the GCR registers
  43. #define GCR_CONFIG_ADDR_PB 0x1fbf8000 // Post Boot address of the GCR registers
  44. #define GIC_P_BASE_ADDR 0x1bdc0000 // physical address of the GIC
  45. #define GIC_BASE_ADDR 0x1bdc0000 // MPU Direct address address of the GIC
  46. #define GIC_BASE_ADDR_PB 0x1bdc0000 // Post Boot address address of the GIC
  47. #define CPC_P_BASE_ADDR 0x1bde0001 // physical address of the CPC
  48. #define CPC_BASE_ADDR 0x1bde0000 // MPU Direct address address of the CPC
  49. #define CPC_BASE_ADDR_PB 0x1bde0000 // Post Boot address address of the CPC
  50. #define STACK_BASE_ADDR 0x00200000 /* Change: Base on memory size. */
  51. #define CDMM_P_BASE_ADDR 0x1fc10000 // physical address of the CDMM Register
  52. #define MPU_CDMM_OFFSET (64*3)
  53. #define MPU_ACSR 0
  54. #define MPU_Config 0x8
  55. #define MPU_SegmentControl0 0x10
  56. #define MPU_SegmentControl1 0x14
  57. #define MPU_SegmentControl2 0x18
  58. #define MPU_SegmentControl3 0x1c
  59. #else
  60. #define GIC_SH_WEDGE_ADDR *((volatile unsigned int*) (0xbbdc0280))
  61. #define GCR_CONFIG_ADDR 0xbfbf8000 // KSEG1 address of the GCR registers
  62. #define GCR_CONFIG_ADDR_PB 0xbfbf8000 // Post Boot address of the GCR registers
  63. #define GIC_P_BASE_ADDR 0x1bdc0000 // physical address of the GIC
  64. #define GIC_BASE_ADDR 0xbbdc0000 // KSEG1 address address of the GIC
  65. #define GIC_BASE_ADDR_PB 0xbbdc0000 // Post Boot address address of the GIC
  66. #define CPC_P_BASE_ADDR 0x1bde0001 // physical address of the CPC including enable bit
  67. #define CPC_BASE_ADDR 0xbbde0000 // KSEG1 address address of the CPC
  68. #define CPC_BASE_ADDR_PB 0xbbde0000 // Post Boot address address of the CPC
  69. #define STACK_BASE_ADDR 0x80200000 /* Change: Base on memory size. */
  70. #endif
  71. #define STACK_SIZE_LOG2 16 /* 64Kbytes each */
  72. /**************************************************************************************
  73. Register use while executing in this file: ("GLOBAL" denotes a common value.)
  74. **************************************************************************************/
  75. // o32 $2 - $7 (v0, v1, a0 - a3) reserved for program use
  76. // p32 $2 - $7 (t4, t5, a0 - a3) reserved for program use
  77. /* o32 t0 Core number. Only core 0 is active after reset. */
  78. /* p32 a4 Core number. Only core 0 is active after reset. */
  79. #define r8_core_num $8
  80. /* o32 t1 MT ASE VPE number that this TC is bound to (0 if non-MT.) */
  81. /* p32 a5 MT ASE VPE number that this TC is bound to (0 if non-MT.) */
  82. #define r9_vpe_num $9
  83. /* o32 t2 Core implements the MT ASE. */
  84. /* p32 a6 Core implements the MT ASE. */
  85. #define r10_has_mt_ase $10
  86. /* o32 t3 Core is part of a Coherent Processing System. */
  87. /* p32 a7 Core is part of a Coherent Processing System. */
  88. #define r11_is_cps $11
  89. // $12 - $15 (t4 - t7 o32 or t0 - t3 n32/64/p32) are free to use
  90. // $16, $17 (s0 and s1) are free to use
  91. #define r18_tc_num $18 /* s2 MT ASE TC number (0 if non-MT.) */
  92. #define r19_more_cores $19 /* s3 Number of cores in CPS in addition to core 0. GLOBAL! */
  93. #define r20_more_vpes $20 /* s4 Number of vpes in this core in addition to vpe 0. */
  94. #define r21_more_tcs $21 /* s5 Number of tcs in vpe in addition to the first. */
  95. #define r22_gcr_addr $22 /* s6 Uncached (kseg1) base address of the Global Config Registers. */
  96. #define r23_cpu_num $23 /* s7 Unique per vpe "cpu" identifier (CP0 EBase[CPUNUM]). */
  97. #define r24_boston_byte $24 /* t8 flash address of boston_lcd_display_byte function */
  98. #define r25_coreid $25 /* t9 Copy of cp0 PRiD GLOBAL! */
  99. // $26 /* k0 Interrupt handler scratch */
  100. // $27 /* k1 Interrupt handler scratch */
  101. // $28 gp and $29 sp
  102. #define r30_cpc_addr $30 /* s8 Address of CPC register block after cpc_init. 0 indicates no CPC. */
  103. // $31 ra