platform.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. // See LICENSE for license details.
  2. #ifndef _SIFIVE_PLATFORM_H
  3. #define _SIFIVE_PLATFORM_H
  4. // Some things missing from the official encoding.h
  5. #define MCAUSE_INT 0x80000000
  6. #define MCAUSE_CAUSE 0x7FFFFFFF
  7. #include "sifive/const.h"
  8. #include "sifive/devices/aon.h"
  9. #include "sifive/devices/clint.h"
  10. #include "sifive/devices/gpio.h"
  11. #include "sifive/devices/otp.h"
  12. #include "sifive/devices/plic.h"
  13. #include "sifive/devices/prci.h"
  14. #include "sifive/devices/pwm.h"
  15. #include "sifive/devices/spi.h"
  16. #include "sifive/devices/uart.h"
  17. /****************************************************************************
  18. * Platform definitions
  19. *****************************************************************************/
  20. // Memory map
  21. #define MASKROM_MEM_ADDR _AC(0x00001000,UL)
  22. #define TRAPVEC_TABLE_CTRL_ADDR _AC(0x00001010,UL)
  23. #define OTP_MEM_ADDR _AC(0x00020000,UL)
  24. #define CLINT_CTRL_ADDR _AC(0x02000000,UL)
  25. #define PLIC_CTRL_ADDR _AC(0x0C000000,UL)
  26. #define AON_CTRL_ADDR _AC(0x10000000,UL)
  27. #define PRCI_CTRL_ADDR _AC(0x10008000,UL)
  28. #define OTP_CTRL_ADDR _AC(0x10010000,UL)
  29. #define GPIO_CTRL_ADDR _AC(0x10012000,UL)
  30. #define UART0_CTRL_ADDR _AC(0x10013000,UL)
  31. #define SPI0_CTRL_ADDR _AC(0x10014000,UL)
  32. #define PWM0_CTRL_ADDR _AC(0x10015000,UL)
  33. #define UART1_CTRL_ADDR _AC(0x10023000,UL)
  34. #define SPI1_CTRL_ADDR _AC(0x10024000,UL)
  35. #define PWM1_CTRL_ADDR _AC(0x10025000,UL)
  36. #define SPI2_CTRL_ADDR _AC(0x10034000,UL)
  37. #define PWM2_CTRL_ADDR _AC(0x10035000,UL)
  38. #define SPI0_MEM_ADDR _AC(0x20000000,UL)
  39. #define MEM_CTRL_ADDR _AC(0x80000000,UL)
  40. // IOF masks
  41. #define IOF0_SPI1_MASK _AC(0x000007FC,UL)
  42. #define SPI11_NUM_SS (4)
  43. #define IOF_SPI1_SS0 (2u)
  44. #define IOF_SPI1_SS1 (8u)
  45. #define IOF_SPI1_SS2 (9u)
  46. #define IOF_SPI1_SS3 (10u)
  47. #define IOF_SPI1_MOSI (3u)
  48. #define IOF_SPI1_MISO (4u)
  49. #define IOF_SPI1_SCK (5u)
  50. #define IOF_SPI1_DQ0 (3u)
  51. #define IOF_SPI1_DQ1 (4u)
  52. #define IOF_SPI1_DQ2 (6u)
  53. #define IOF_SPI1_DQ3 (7u)
  54. #define IOF0_SPI2_MASK _AC(0xFC000000,UL)
  55. #define SPI2_NUM_SS (1)
  56. #define IOF_SPI2_SS0 (26u)
  57. #define IOF_SPI2_MOSI (27u)
  58. #define IOF_SPI2_MISO (28u)
  59. #define IOF_SPI2_SCK (29u)
  60. #define IOF_SPI2_DQ0 (27u)
  61. #define IOF_SPI2_DQ1 (28u)
  62. #define IOF_SPI2_DQ2 (30u)
  63. #define IOF_SPI2_DQ3 (31u)
  64. //#define IOF0_I2C_MASK _AC(0x00003000,UL)
  65. #define IOF0_UART0_MASK _AC(0x00030000, UL)
  66. #define IOF_UART0_RX (16u)
  67. #define IOF_UART0_TX (17u)
  68. #define IOF0_UART1_MASK _AC(0x03000000, UL)
  69. #define IOF_UART1_RX (24u)
  70. #define IOF_UART1_TX (25u)
  71. #define IOF1_PWM0_MASK _AC(0x0000000F, UL)
  72. #define IOF1_PWM1_MASK _AC(0x00780000, UL)
  73. #define IOF1_PWM2_MASK _AC(0x00003C00, UL)
  74. // Interrupt numbers
  75. #define INT_RESERVED 0
  76. #define INT_WDOGCMP 1
  77. #define INT_RTCCMP 2
  78. #define INT_UART0_BASE 3
  79. #define INT_UART1_BASE 4
  80. #define INT_SPI0_BASE 5
  81. #define INT_SPI1_BASE 6
  82. #define INT_SPI2_BASE 7
  83. #define INT_GPIO_BASE 8
  84. #define INT_PWM0_BASE 40
  85. #define INT_PWM1_BASE 44
  86. #define INT_PWM2_BASE 48
  87. // Helper functions
  88. #define _REG32(p, i) (*(volatile uint32_t *) ((p) + (i)))
  89. #define _REG32P(p, i) ((volatile uint32_t *) ((p) + (i)))
  90. #define AON_REG(offset) _REG32(AON_CTRL_ADDR, offset)
  91. #define CLINT_REG(offset) _REG32(CLINT_CTRL_ADDR, offset)
  92. #define GPIO_REG(offset) _REG32(GPIO_CTRL_ADDR, offset)
  93. #define OTP_REG(offset) _REG32(OTP_CTRL_ADDR, offset)
  94. #define PLIC_REG(offset) _REG32(PLIC_CTRL_ADDR, offset)
  95. #define PRCI_REG(offset) _REG32(PRCI_CTRL_ADDR, offset)
  96. #define PWM0_REG(offset) _REG32(PWM0_CTRL_ADDR, offset)
  97. #define PWM1_REG(offset) _REG32(PWM1_CTRL_ADDR, offset)
  98. #define PWM2_REG(offset) _REG32(PWM2_CTRL_ADDR, offset)
  99. #define SPI0_REG(offset) _REG32(SPI0_CTRL_ADDR, offset)
  100. #define SPI1_REG(offset) _REG32(SPI1_CTRL_ADDR, offset)
  101. #define SPI2_REG(offset) _REG32(SPI2_CTRL_ADDR, offset)
  102. #define UART0_REG(offset) _REG32(UART0_CTRL_ADDR, offset)
  103. #define UART1_REG(offset) _REG32(UART1_CTRL_ADDR, offset)
  104. // Misc
  105. #include <stdint.h>
  106. #define NUM_GPIO 32
  107. #define PLIC_NUM_INTERRUPTS 52
  108. #define PLIC_NUM_PRIORITIES 7
  109. #include "hifive1.h"
  110. unsigned long get_cpu_freq(void);
  111. unsigned long get_timer_freq(void);
  112. uint64_t get_timer_value(void);
  113. #endif /* _SIFIVE_PLATFORM_H */