mach-rtl83xx.h 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (C) 2006-2012 Tony Wu ([email protected])
  4. * Copyright (C) 2020 B. Koblitz
  5. */
  6. #ifndef _MACH_RTL838X_H_
  7. #define _MACH_RTL838X_H_
  8. #include <asm/types.h>
  9. /*
  10. * Register access macros
  11. */
  12. #define RTL838X_SW_BASE ((volatile void *) 0xBB000000)
  13. #define rtl83xx_r32(reg) readl(reg)
  14. #define rtl83xx_w32(val, reg) writel(val, reg)
  15. #define rtl83xx_w32_mask(clear, set, reg) rtl83xx_w32((rtl83xx_r32(reg) & ~(clear)) | (set), reg)
  16. #define rtl83xx_r8(reg) readb(reg)
  17. #define rtl83xx_w8(val, reg) writeb(val, reg)
  18. #define sw_r32(reg) readl(RTL838X_SW_BASE + reg)
  19. #define sw_w32(val, reg) writel(val, RTL838X_SW_BASE + reg)
  20. #define sw_w32_mask(clear, set, reg) \
  21. sw_w32((sw_r32(reg) & ~(clear)) | (set), reg)
  22. #define sw_r64(reg) ((((u64)readl(RTL838X_SW_BASE + reg)) << 32) | \
  23. readl(RTL838X_SW_BASE + reg + 4))
  24. #define sw_w64(val, reg) do { \
  25. writel((u32)((val) >> 32), RTL838X_SW_BASE + reg); \
  26. writel((u32)((val) & 0xffffffff), \
  27. RTL838X_SW_BASE + reg + 4); \
  28. } while (0)
  29. /*
  30. * SPRAM
  31. */
  32. #define RTL838X_ISPRAM_BASE 0x0
  33. #define RTL838X_DSPRAM_BASE 0x0
  34. /*
  35. * IRQ Controller
  36. */
  37. #define RTL838X_IRQ_CPU_BASE 0
  38. #define RTL838X_IRQ_CPU_NUM 8
  39. #define RTL838X_IRQ_ICTL_BASE (RTL838X_IRQ_CPU_BASE + RTL838X_IRQ_CPU_NUM)
  40. #define RTL838X_IRQ_ICTL_NUM 32
  41. #define RTL83XX_IRQ_UART0 31
  42. #define RTL83XX_IRQ_UART1 30
  43. #define RTL83XX_IRQ_TC0 29
  44. #define RTL83XX_IRQ_TC1 28
  45. #define RTL83XX_IRQ_OCPTO 27
  46. #define RTL83XX_IRQ_HLXTO 26
  47. #define RTL83XX_IRQ_SLXTO 25
  48. #define RTL83XX_IRQ_NIC 24
  49. #define RTL83XX_IRQ_GPIO_ABCD 23
  50. #define RTL83XX_IRQ_GPIO_EFGH 22
  51. #define RTL83XX_IRQ_RTC 21
  52. #define RTL83XX_IRQ_SWCORE 20
  53. #define RTL83XX_IRQ_WDT_IP1 19
  54. #define RTL83XX_IRQ_WDT_IP2 18
  55. #define RTL9300_UART1_IRQ 31
  56. #define RTL9300_UART0_IRQ 30
  57. #define RTL9300_USB_H2_IRQ 28
  58. #define RTL9300_NIC_IRQ 24
  59. #define RTL9300_SWCORE_IRQ 23
  60. #define RTL9300_GPIO_ABC_IRQ 13
  61. #define RTL9300_TC4_IRQ 11
  62. #define RTL9300_TC3_IRQ 10
  63. #define RTL9300_TC2_IRQ 9
  64. #define RTL9300_TC1_IRQ 8
  65. #define RTL9300_TC0_IRQ 7
  66. /*
  67. * MIPS32R2 counter
  68. */
  69. #define RTL838X_COMPARE_IRQ (RTL838X_IRQ_CPU_BASE + 7)
  70. /*
  71. * ICTL
  72. * Base address 0xb8003000UL
  73. */
  74. #define RTL838X_ICTL1_IRQ (RTL838X_IRQ_CPU_BASE + 2)
  75. #define RTL838X_ICTL2_IRQ (RTL838X_IRQ_CPU_BASE + 3)
  76. #define RTL838X_ICTL3_IRQ (RTL838X_IRQ_CPU_BASE + 4)
  77. #define RTL838X_ICTL4_IRQ (RTL838X_IRQ_CPU_BASE + 5)
  78. #define RTL838X_ICTL5_IRQ (RTL838X_IRQ_CPU_BASE + 6)
  79. #define GIMR (0x00)
  80. #define UART0_IE (1 << 31)
  81. #define UART1_IE (1 << 30)
  82. #define TC0_IE (1 << 29)
  83. #define TC1_IE (1 << 28)
  84. #define OCPTO_IE (1 << 27)
  85. #define HLXTO_IE (1 << 26)
  86. #define SLXTO_IE (1 << 25)
  87. #define NIC_IE (1 << 24)
  88. #define GPIO_ABCD_IE (1 << 23)
  89. #define GPIO_EFGH_IE (1 << 22)
  90. #define RTC_IE (1 << 21)
  91. #define WDT_IP1_IE (1 << 19)
  92. #define WDT_IP2_IE (1 << 18)
  93. #define GISR (0x04)
  94. #define UART0_IP (1 << 31)
  95. #define UART1_IP (1 << 30)
  96. #define TC0_IP (1 << 29)
  97. #define TC1_IP (1 << 28)
  98. #define OCPTO_IP (1 << 27)
  99. #define HLXTO_IP (1 << 26)
  100. #define SLXTO_IP (1 << 25)
  101. #define NIC_IP (1 << 24)
  102. #define GPIO_ABCD_IP (1 << 23)
  103. #define GPIO_EFGH_IP (1 << 22)
  104. #define RTC_IP (1 << 21)
  105. #define WDT_IP1_IP (1 << 19)
  106. #define WDT_IP2_IP (1 << 18)
  107. /* Interrupt Routing Selection */
  108. #define UART0_RS 2
  109. #define UART1_RS 1
  110. #define TC0_RS 5
  111. #define TC1_RS 1
  112. #define OCPTO_RS 1
  113. #define HLXTO_RS 1
  114. #define SLXTO_RS 1
  115. #define NIC_RS 4
  116. #define GPIO_ABCD_RS 4
  117. #define GPIO_EFGH_RS 4
  118. #define RTC_RS 4
  119. #define SWCORE_RS 3
  120. #define WDT_IP1_RS 4
  121. #define WDT_IP2_RS 5
  122. /* Interrupt IRQ Assignments */
  123. #define UART0_IRQ 31
  124. #define UART1_IRQ 30
  125. #define TC0_IRQ 29
  126. #define TC1_IRQ 28
  127. #define OCPTO_IRQ 27
  128. #define HLXTO_IRQ 26
  129. #define SLXTO_IRQ 25
  130. #define NIC_IRQ 24
  131. #define GPIO_ABCD_IRQ 23
  132. #define GPIO_EFGH_IRQ 22
  133. #define RTC_IRQ 21
  134. #define SWCORE_IRQ 20
  135. #define WDT_IP1_IRQ 19
  136. #define WDT_IP2_IRQ 18
  137. #define SYSTEM_FREQ 200000000
  138. #define RTL838X_UART0_BASE ((volatile void *)(0xb8002000UL))
  139. #define RTL838X_UART0_BAUD 38400 /* ex. 19200 or 38400 or 57600 or 115200 */
  140. #define RTL838X_UART0_FREQ (SYSTEM_FREQ - RTL838X_UART0_BAUD * 24)
  141. #define RTL838X_UART0_MAPBASE 0x18002000UL
  142. #define RTL838X_UART0_MAPSIZE 0x100
  143. #define RTL838X_UART0_IRQ UART0_IRQ
  144. #define RTL838X_UART1_BASE ((volatile void *)(0xb8002100UL))
  145. #define RTL838X_UART1_BAUD 38400 /* ex. 19200 or 38400 or 57600 or 115200 */
  146. #define RTL838X_UART1_FREQ (SYSTEM_FREQ - RTL838X_UART1_BAUD * 24)
  147. #define RTL838X_UART1_MAPBASE 0x18002100UL
  148. #define RTL838X_UART1_MAPSIZE 0x100
  149. #define RTL838X_UART1_IRQ UART1_IRQ
  150. #define UART0_RBR (RTL838X_UART0_BASE + 0x000)
  151. #define UART0_THR (RTL838X_UART0_BASE + 0x000)
  152. #define UART0_DLL (RTL838X_UART0_BASE + 0x000)
  153. #define UART0_IER (RTL838X_UART0_BASE + 0x004)
  154. #define UART0_DLM (RTL838X_UART0_BASE + 0x004)
  155. #define UART0_IIR (RTL838X_UART0_BASE + 0x008)
  156. #define UART0_FCR (RTL838X_UART0_BASE + 0x008)
  157. #define UART0_LCR (RTL838X_UART0_BASE + 0x00C)
  158. #define UART0_MCR (RTL838X_UART0_BASE + 0x010)
  159. #define UART0_LSR (RTL838X_UART0_BASE + 0x014)
  160. #define UART1_RBR (RTL838X_UART1_BASE + 0x000)
  161. #define UART1_THR (RTL838X_UART1_BASE + 0x000)
  162. #define UART1_DLL (RTL838X_UART1_BASE + 0x000)
  163. #define UART1_IER (RTL838X_UART1_BASE + 0x004)
  164. #define UART1_DLM (RTL838X_UART1_BASE + 0x004)
  165. #define UART1_IIR (RTL838X_UART1_BASE + 0x008)
  166. #define UART1_FCR (RTL838X_UART1_BASE + 0x008)
  167. #define UART1_LCR (RTL838X_UART1_BASE + 0x00C)
  168. #define UART1_MCR (RTL838X_UART1_BASE + 0x010)
  169. #define UART1_LSR (RTL838X_UART1_BASE + 0x014)
  170. /*
  171. * Memory Controller
  172. */
  173. #define MC_MCR 0xB8001000
  174. #define MC_MCR_VAL 0x00000000
  175. #define MC_DCR 0xB8001004
  176. #define MC_DCR0_VAL 0x54480000
  177. #define MC_DTCR 0xB8001008
  178. #define MC_DTCR_VAL 0xFFFF05C0
  179. /*
  180. * GPIO
  181. */
  182. #define GPIO_CTRL_REG_BASE ((volatile void *) 0xb8003500)
  183. #define RTL838X_GPIO_PABC_CNR (GPIO_CTRL_REG_BASE + 0x0)
  184. #define RTL838X_GPIO_PABC_TYPE (GPIO_CTRL_REG_BASE + 0x04)
  185. #define RTL838X_GPIO_PABC_DIR (GPIO_CTRL_REG_BASE + 0x8)
  186. #define RTL838X_GPIO_PABC_DATA (GPIO_CTRL_REG_BASE + 0xc)
  187. #define RTL838X_GPIO_PABC_ISR (GPIO_CTRL_REG_BASE + 0x10)
  188. #define RTL838X_GPIO_PAB_IMR (GPIO_CTRL_REG_BASE + 0x14)
  189. #define RTL838X_GPIO_PC_IMR (GPIO_CTRL_REG_BASE + 0x18)
  190. #define RTL930X_GPIO_CTRL_REG_BASE ((volatile void *) 0xb8003300)
  191. #define RTL930X_GPIO_PABCD_DIR (RTL930X_GPIO_CTRL_REG_BASE + 0x8)
  192. #define RTL930X_GPIO_PABCD_DAT (RTL930X_GPIO_CTRL_REG_BASE + 0xc)
  193. #define RTL930X_GPIO_PABCD_ISR (RTL930X_GPIO_CTRL_REG_BASE + 0x10)
  194. #define RTL930X_GPIO_PAB_IMR (RTL930X_GPIO_CTRL_REG_BASE + 0x14)
  195. #define RTL930X_GPIO_PCD_IMR (RTL930X_GPIO_CTRL_REG_BASE + 0x18)
  196. #define RTL838X_MODEL_NAME_INFO (0x00D4)
  197. #define RTL839X_MODEL_NAME_INFO (0x0FF0)
  198. #define RTL93XX_MODEL_NAME_INFO (0x0004)
  199. #define RTL931X_CHIP_INFO_ADDR (0x0008)
  200. #define RTL838X_LED_GLB_CTRL (0xA000)
  201. #define RTL839X_LED_GLB_CTRL (0x00E4)
  202. #define RTL9302_LED_GLB_CTRL (0xcc00)
  203. #define RTL930X_LED_GLB_CTRL (0xCC00)
  204. #define RTL931X_LED_GLB_CTRL (0x0600)
  205. #define RTL838X_EXT_GPIO_DIR (0xA08C)
  206. #define RTL839X_EXT_GPIO_DIR (0x0214)
  207. #define RTL838X_EXT_GPIO_DATA (0xA094)
  208. #define RTL839X_EXT_GPIO_DATA (0x021c)
  209. #define RTL838X_EXT_GPIO_INDRT_ACCESS (0xA09C)
  210. #define RTL839X_EXT_GPIO_INDRT_ACCESS (0x0224)
  211. #define RTL838X_EXTRA_GPIO_CTRL (0xA0E0)
  212. #define RTL838X_DMY_REG5 (0x0144)
  213. #define RTL838X_EXTRA_GPIO_CTRL (0xA0E0)
  214. #define RTL838X_GMII_INTF_SEL (0x1000)
  215. #define RTL838X_IO_DRIVING_ABILITY_CTRL (0x1010)
  216. #define RTL838X_GPIO_A7 31
  217. #define RTL838X_GPIO_A6 30
  218. #define RTL838X_GPIO_A5 29
  219. #define RTL838X_GPIO_A4 28
  220. #define RTL838X_GPIO_A3 27
  221. #define RTL838X_GPIO_A2 26
  222. #define RTL838X_GPIO_A1 25
  223. #define RTL838X_GPIO_A0 24
  224. #define RTL838X_GPIO_B7 23
  225. #define RTL838X_GPIO_B6 22
  226. #define RTL838X_GPIO_B5 21
  227. #define RTL838X_GPIO_B4 20
  228. #define RTL838X_GPIO_B3 19
  229. #define RTL838X_GPIO_B2 18
  230. #define RTL838X_GPIO_B1 17
  231. #define RTL838X_GPIO_B0 16
  232. #define RTL838X_GPIO_C7 15
  233. #define RTL838X_GPIO_C6 14
  234. #define RTL838X_GPIO_C5 13
  235. #define RTL838X_GPIO_C4 12
  236. #define RTL838X_GPIO_C3 11
  237. #define RTL838X_GPIO_C2 10
  238. #define RTL838X_GPIO_C1 9
  239. #define RTL838X_GPIO_C0 8
  240. #define RTL838X_INT_RW_CTRL (0x0058)
  241. #define RTL838X_EXT_VERSION (0x00D0)
  242. #define RTL838X_PLL_CML_CTRL (0x0FF8)
  243. #define RTL838X_STRAP_DBG (0x100C)
  244. /*
  245. * Reset
  246. */
  247. #define RGCR (0x1E70)
  248. #define RTL838X_RST_GLB_CTRL_0 (0x003c)
  249. #define RTL838X_RST_GLB_CTRL_1 (0x0040)
  250. #define RTL839X_RST_GLB_CTRL (0x0014)
  251. #define RTL930X_RST_GLB_CTRL_0 (0x000c)
  252. #define RTL931X_RST_GLB_CTRL (0x0400)
  253. /* LED control by switch */
  254. #define RTL838X_LED_MODE_SEL (0x1004)
  255. #define RTL838X_LED_MODE_CTRL (0xA004)
  256. #define RTL838X_LED_P_EN_CTRL (0xA008)
  257. /* LED control by software */
  258. #define RTL838X_LED_SW_CTRL (0x0128)
  259. #define RTL839X_LED_SW_CTRL (0xA00C)
  260. #define RTL838X_LED_SW_P_EN_CTRL (0xA010)
  261. #define RTL839X_LED_SW_P_EN_CTRL (0x012C)
  262. #define RTL838X_LED0_SW_P_EN_CTRL (0xA010)
  263. #define RTL839X_LED0_SW_P_EN_CTRL (0x012C)
  264. #define RTL838X_LED1_SW_P_EN_CTRL (0xA014)
  265. #define RTL839X_LED1_SW_P_EN_CTRL (0x0130)
  266. #define RTL838X_LED2_SW_P_EN_CTRL (0xA018)
  267. #define RTL839X_LED2_SW_P_EN_CTRL (0x0134)
  268. #define RTL838X_LED_SW_P_CTRL (0xA01C)
  269. #define RTL839X_LED_SW_P_CTRL (0x0144)
  270. #define RTL839X_MAC_EFUSE_CTRL (0x02ac)
  271. /*
  272. * MDIO via Realtek's SMI interface
  273. */
  274. #define RTL838X_SMI_GLB_CTRL (0xa100)
  275. #define RTL838X_SMI_ACCESS_PHY_CTRL_0 (0xa1b8)
  276. #define RTL838X_SMI_ACCESS_PHY_CTRL_1 (0xa1bc)
  277. #define RTL838X_SMI_ACCESS_PHY_CTRL_2 (0xa1c0)
  278. #define RTL838X_SMI_ACCESS_PHY_CTRL_3 (0xa1c4)
  279. #define RTL838X_SMI_PORT0_5_ADDR_CTRL (0xa1c8)
  280. #define RTL838X_SMI_POLL_CTRL (0xa17c)
  281. #define RTL839X_SMI_GLB_CTRL (0x03f8)
  282. #define RTL839X_SMI_PORT_POLLING_CTRL (0x03fc)
  283. #define RTL839X_PHYREG_ACCESS_CTRL (0x03DC)
  284. #define RTL839X_PHYREG_CTRL (0x03E0)
  285. #define RTL839X_PHYREG_PORT_CTRL (0x03E4)
  286. #define RTL839X_PHYREG_DATA_CTRL (0x03F0)
  287. #define RTL839X_PHYREG_MMD_CTRL (0x3F4)
  288. #define RTL930X_SMI_GLB_CTRL (0xCA00)
  289. #define RTL930X_SMI_POLL_CTRL (0xca90)
  290. #define RTL930X_SMI_PORT0_15_POLLING_SEL (0xCA08)
  291. #define RTL930X_SMI_PORT16_27_POLLING_SEL (0xCA0C)
  292. #define RTL930X_SMI_PORT0_5_ADDR (0xCB80)
  293. #define RTL930X_SMI_ACCESS_PHY_CTRL_0 (0xCB70)
  294. #define RTL930X_SMI_ACCESS_PHY_CTRL_1 (0xCB74)
  295. #define RTL930X_SMI_ACCESS_PHY_CTRL_2 (0xCB78)
  296. #define RTL930X_SMI_ACCESS_PHY_CTRL_3 (0xCB7C)
  297. #define RTL931X_SMI_GLB_CTRL1 (0x0CBC)
  298. #define RTL931X_SMI_GLB_CTRL0 (0x0CC0)
  299. #define RTL931X_SMI_PORT_POLLING_CTRL (0x0CCC)
  300. #define RTL931X_SMI_PORT_ADDR (0x0C74)
  301. #define RTL931X_SMI_PORT_POLLING_SEL (0x0C9C)
  302. #define RTL9310_SMI_PORT_POLLING_CTRL (0x0CCC)
  303. #define RTL931X_SMI_INDRT_ACCESS_CTRL_0 (0x0C00)
  304. #define RTL931X_SMI_INDRT_ACCESS_CTRL_1 (0x0C04)
  305. #define RTL931X_SMI_INDRT_ACCESS_CTRL_2 (0x0C08)
  306. #define RTL931X_SMI_INDRT_ACCESS_CTRL_3 (0x0C10)
  307. #define RTL931X_SMI_INDRT_ACCESS_BC_PHYID_CTRL (0x0C14)
  308. #define RTL931X_SMI_INDRT_ACCESS_MMD_CTRL (0xC18)
  309. #define RTL931X_MAC_L2_GLOBAL_CTRL2 (0x1358)
  310. #define RTL931X_MAC_L2_GLOBAL_CTRL1 (0x5548)
  311. /*
  312. * Switch interrupts
  313. */
  314. #define RTL838X_IMR_GLB (0x1100)
  315. #define RTL838X_IMR_PORT_LINK_STS_CHG (0x1104)
  316. #define RTL838X_ISR_GLB_SRC (0x1148)
  317. #define RTL838X_ISR_PORT_LINK_STS_CHG (0x114C)
  318. #define RTL839X_IMR_GLB (0x0064)
  319. #define RTL839X_IMR_PORT_LINK_STS_CHG (0x0068)
  320. #define RTL839X_ISR_GLB_SRC (0x009c)
  321. #define RTL839X_ISR_PORT_LINK_STS_CHG (0x00a0)
  322. #define RTL930X_IMR_GLB (0xC628)
  323. #define RTL930X_IMR_PORT_LINK_STS_CHG (0xC62C)
  324. #define RTL930X_ISR_GLB (0xC658)
  325. #define RTL930X_ISR_PORT_LINK_STS_CHG (0xC660)
  326. // IMR_GLB does not exit on RTL931X
  327. #define RTL931X_IMR_PORT_LINK_STS_CHG (0x126C)
  328. #define RTL931X_ISR_GLB_SRC (0x12B4)
  329. #define RTL931X_ISR_PORT_LINK_STS_CHG (0x12B8)
  330. /* Definition of family IDs */
  331. #define RTL8389_FAMILY_ID (0x8389)
  332. #define RTL8328_FAMILY_ID (0x8328)
  333. #define RTL8390_FAMILY_ID (0x8390)
  334. #define RTL8350_FAMILY_ID (0x8350)
  335. #define RTL8380_FAMILY_ID (0x8380)
  336. #define RTL8330_FAMILY_ID (0x8330)
  337. #define RTL9300_FAMILY_ID (0x9300)
  338. #define RTL9310_FAMILY_ID (0x9310)
  339. /* SPI Support */
  340. #define RTL931X_SPI_CTRL0 (0x103C)
  341. /* Basic SoC Features */
  342. #define RTL838X_CPU_PORT 28
  343. #define RTL839X_CPU_PORT 52
  344. #define RTL930X_CPU_PORT 28
  345. #define RTL931X_CPU_PORT 56
  346. struct rtl83xx_soc_info {
  347. unsigned char *name;
  348. unsigned int id;
  349. unsigned int family;
  350. unsigned char *compatible;
  351. volatile void *sw_base;
  352. volatile void *icu_base;
  353. int cpu_port;
  354. };
  355. /* rtl83xx-related functions used across subsystems */
  356. int rtl838x_smi_wait_op(int timeout);
  357. int rtl838x_read_phy(u32 port, u32 page, u32 reg, u32 *val);
  358. int rtl838x_write_phy(u32 port, u32 page, u32 reg, u32 val);
  359. int rtl839x_read_phy(u32 port, u32 page, u32 reg, u32 *val);
  360. int rtl839x_write_phy(u32 port, u32 page, u32 reg, u32 val);
  361. int rtl930x_read_phy(u32 port, u32 page, u32 reg, u32 *val);
  362. int rtl930x_write_phy(u32 port, u32 page, u32 reg, u32 val);
  363. int rtl931x_read_phy(u32 port, u32 page, u32 reg, u32 *val);
  364. int rtl931x_write_phy(u32 port, u32 page, u32 reg, u32 val);
  365. #endif /* _MACH_RTL838X_H_ */