board.c 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * board.c
  4. *
  5. * Board functions for TI AM335X based boards
  6. *
  7. * Copyright (C) 2011, Texas Instruments, Incorporated - http://www.ti.com/
  8. */
  9. #include <common.h>
  10. #include <dm.h>
  11. #include <errno.h>
  12. #include <spl.h>
  13. #include <serial.h>
  14. #include <asm/arch/cpu.h>
  15. #include <asm/arch/hardware.h>
  16. #include <asm/arch/omap.h>
  17. #include <asm/arch/ddr_defs.h>
  18. #include <asm/arch/clock.h>
  19. #include <asm/arch/clk_synthesizer.h>
  20. #include <asm/arch/gpio.h>
  21. #include <asm/arch/mmc_host_def.h>
  22. #include <asm/arch/sys_proto.h>
  23. #include <asm/arch/mem.h>
  24. #include <asm/io.h>
  25. #include <asm/emif.h>
  26. #include <asm/gpio.h>
  27. #include <asm/omap_common.h>
  28. #include <asm/omap_sec_common.h>
  29. #include <asm/omap_mmc.h>
  30. #include <i2c.h>
  31. #include <miiphy.h>
  32. #include <cpsw.h>
  33. #include <power/tps65217.h>
  34. #include <power/tps65910.h>
  35. #include <environment.h>
  36. #include <watchdog.h>
  37. #include <environment.h>
  38. #include "../common/board_detect.h"
  39. #include "board.h"
  40. DECLARE_GLOBAL_DATA_PTR;
  41. /* GPIO that controls power to DDR on EVM-SK */
  42. #define GPIO_TO_PIN(bank, gpio) (32 * (bank) + (gpio))
  43. #define GPIO_DDR_VTT_EN GPIO_TO_PIN(0, 7)
  44. #define ICE_GPIO_DDR_VTT_EN GPIO_TO_PIN(0, 18)
  45. #define GPIO_PR1_MII_CTRL GPIO_TO_PIN(3, 4)
  46. #define GPIO_MUX_MII_CTRL GPIO_TO_PIN(3, 10)
  47. #define GPIO_FET_SWITCH_CTRL GPIO_TO_PIN(0, 7)
  48. #define GPIO_PHY_RESET GPIO_TO_PIN(2, 5)
  49. #define GPIO_ETH0_MODE GPIO_TO_PIN(0, 11)
  50. #define GPIO_ETH1_MODE GPIO_TO_PIN(1, 26)
  51. static struct ctrl_dev *cdev = (struct ctrl_dev *)CTRL_DEVICE_BASE;
  52. #define GPIO0_RISINGDETECT (AM33XX_GPIO0_BASE + OMAP_GPIO_RISINGDETECT)
  53. #define GPIO1_RISINGDETECT (AM33XX_GPIO1_BASE + OMAP_GPIO_RISINGDETECT)
  54. #define GPIO0_IRQSTATUS1 (AM33XX_GPIO0_BASE + OMAP_GPIO_IRQSTATUS1)
  55. #define GPIO1_IRQSTATUS1 (AM33XX_GPIO1_BASE + OMAP_GPIO_IRQSTATUS1)
  56. #define GPIO0_IRQSTATUSRAW (AM33XX_GPIO0_BASE + 0x024)
  57. #define GPIO1_IRQSTATUSRAW (AM33XX_GPIO1_BASE + 0x024)
  58. /*
  59. * Read header information from EEPROM into global structure.
  60. */
  61. #ifdef CONFIG_TI_I2C_BOARD_DETECT
  62. void do_board_detect(void)
  63. {
  64. enable_i2c0_pin_mux();
  65. i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, CONFIG_SYS_OMAP24_I2C_SLAVE);
  66. if (ti_i2c_eeprom_am_get(CONFIG_EEPROM_BUS_ADDRESS,
  67. CONFIG_EEPROM_CHIP_ADDRESS))
  68. printf("ti_i2c_eeprom_init failed\n");
  69. }
  70. #endif
  71. #ifndef CONFIG_DM_SERIAL
  72. struct serial_device *default_serial_console(void)
  73. {
  74. if (board_is_icev2())
  75. return &eserial4_device;
  76. else
  77. return &eserial1_device;
  78. }
  79. #endif
  80. #ifndef CONFIG_SKIP_LOWLEVEL_INIT
  81. static const struct ddr_data ddr2_data = {
  82. .datardsratio0 = MT47H128M16RT25E_RD_DQS,
  83. .datafwsratio0 = MT47H128M16RT25E_PHY_FIFO_WE,
  84. .datawrsratio0 = MT47H128M16RT25E_PHY_WR_DATA,
  85. };
  86. static const struct cmd_control ddr2_cmd_ctrl_data = {
  87. .cmd0csratio = MT47H128M16RT25E_RATIO,
  88. .cmd1csratio = MT47H128M16RT25E_RATIO,
  89. .cmd2csratio = MT47H128M16RT25E_RATIO,
  90. };
  91. static const struct emif_regs ddr2_emif_reg_data = {
  92. .sdram_config = MT47H128M16RT25E_EMIF_SDCFG,
  93. .ref_ctrl = MT47H128M16RT25E_EMIF_SDREF,
  94. .sdram_tim1 = MT47H128M16RT25E_EMIF_TIM1,
  95. .sdram_tim2 = MT47H128M16RT25E_EMIF_TIM2,
  96. .sdram_tim3 = MT47H128M16RT25E_EMIF_TIM3,
  97. .emif_ddr_phy_ctlr_1 = MT47H128M16RT25E_EMIF_READ_LATENCY,
  98. };
  99. static const struct emif_regs ddr2_evm_emif_reg_data = {
  100. .sdram_config = MT47H128M16RT25E_EMIF_SDCFG,
  101. .ref_ctrl = MT47H128M16RT25E_EMIF_SDREF,
  102. .sdram_tim1 = MT47H128M16RT25E_EMIF_TIM1,
  103. .sdram_tim2 = MT47H128M16RT25E_EMIF_TIM2,
  104. .sdram_tim3 = MT47H128M16RT25E_EMIF_TIM3,
  105. .ocp_config = EMIF_OCP_CONFIG_AM335X_EVM,
  106. .emif_ddr_phy_ctlr_1 = MT47H128M16RT25E_EMIF_READ_LATENCY,
  107. };
  108. static const struct ddr_data ddr3_data = {
  109. .datardsratio0 = MT41J128MJT125_RD_DQS,
  110. .datawdsratio0 = MT41J128MJT125_WR_DQS,
  111. .datafwsratio0 = MT41J128MJT125_PHY_FIFO_WE,
  112. .datawrsratio0 = MT41J128MJT125_PHY_WR_DATA,
  113. };
  114. static const struct ddr_data ddr3_beagleblack_data = {
  115. .datardsratio0 = MT41K256M16HA125E_RD_DQS,
  116. .datawdsratio0 = MT41K256M16HA125E_WR_DQS,
  117. .datafwsratio0 = MT41K256M16HA125E_PHY_FIFO_WE,
  118. .datawrsratio0 = MT41K256M16HA125E_PHY_WR_DATA,
  119. };
  120. static const struct ddr_data ddr3_evm_data = {
  121. .datardsratio0 = MT41J512M8RH125_RD_DQS,
  122. .datawdsratio0 = MT41J512M8RH125_WR_DQS,
  123. .datafwsratio0 = MT41J512M8RH125_PHY_FIFO_WE,
  124. .datawrsratio0 = MT41J512M8RH125_PHY_WR_DATA,
  125. };
  126. static const struct ddr_data ddr3_icev2_data = {
  127. .datardsratio0 = MT41J128MJT125_RD_DQS_400MHz,
  128. .datawdsratio0 = MT41J128MJT125_WR_DQS_400MHz,
  129. .datafwsratio0 = MT41J128MJT125_PHY_FIFO_WE_400MHz,
  130. .datawrsratio0 = MT41J128MJT125_PHY_WR_DATA_400MHz,
  131. };
  132. static const struct cmd_control ddr3_cmd_ctrl_data = {
  133. .cmd0csratio = MT41J128MJT125_RATIO,
  134. .cmd0iclkout = MT41J128MJT125_INVERT_CLKOUT,
  135. .cmd1csratio = MT41J128MJT125_RATIO,
  136. .cmd1iclkout = MT41J128MJT125_INVERT_CLKOUT,
  137. .cmd2csratio = MT41J128MJT125_RATIO,
  138. .cmd2iclkout = MT41J128MJT125_INVERT_CLKOUT,
  139. };
  140. static const struct cmd_control ddr3_beagleblack_cmd_ctrl_data = {
  141. .cmd0csratio = MT41K256M16HA125E_RATIO,
  142. .cmd0iclkout = MT41K256M16HA125E_INVERT_CLKOUT,
  143. .cmd1csratio = MT41K256M16HA125E_RATIO,
  144. .cmd1iclkout = MT41K256M16HA125E_INVERT_CLKOUT,
  145. .cmd2csratio = MT41K256M16HA125E_RATIO,
  146. .cmd2iclkout = MT41K256M16HA125E_INVERT_CLKOUT,
  147. };
  148. static const struct cmd_control ddr3_evm_cmd_ctrl_data = {
  149. .cmd0csratio = MT41J512M8RH125_RATIO,
  150. .cmd0iclkout = MT41J512M8RH125_INVERT_CLKOUT,
  151. .cmd1csratio = MT41J512M8RH125_RATIO,
  152. .cmd1iclkout = MT41J512M8RH125_INVERT_CLKOUT,
  153. .cmd2csratio = MT41J512M8RH125_RATIO,
  154. .cmd2iclkout = MT41J512M8RH125_INVERT_CLKOUT,
  155. };
  156. static const struct cmd_control ddr3_icev2_cmd_ctrl_data = {
  157. .cmd0csratio = MT41J128MJT125_RATIO_400MHz,
  158. .cmd0iclkout = MT41J128MJT125_INVERT_CLKOUT_400MHz,
  159. .cmd1csratio = MT41J128MJT125_RATIO_400MHz,
  160. .cmd1iclkout = MT41J128MJT125_INVERT_CLKOUT_400MHz,
  161. .cmd2csratio = MT41J128MJT125_RATIO_400MHz,
  162. .cmd2iclkout = MT41J128MJT125_INVERT_CLKOUT_400MHz,
  163. };
  164. static struct emif_regs ddr3_emif_reg_data = {
  165. .sdram_config = MT41J128MJT125_EMIF_SDCFG,
  166. .ref_ctrl = MT41J128MJT125_EMIF_SDREF,
  167. .sdram_tim1 = MT41J128MJT125_EMIF_TIM1,
  168. .sdram_tim2 = MT41J128MJT125_EMIF_TIM2,
  169. .sdram_tim3 = MT41J128MJT125_EMIF_TIM3,
  170. .zq_config = MT41J128MJT125_ZQ_CFG,
  171. .emif_ddr_phy_ctlr_1 = MT41J128MJT125_EMIF_READ_LATENCY |
  172. PHY_EN_DYN_PWRDN,
  173. };
  174. static struct emif_regs ddr3_beagleblack_emif_reg_data = {
  175. .sdram_config = MT41K256M16HA125E_EMIF_SDCFG,
  176. .ref_ctrl = MT41K256M16HA125E_EMIF_SDREF,
  177. .sdram_tim1 = MT41K256M16HA125E_EMIF_TIM1,
  178. .sdram_tim2 = MT41K256M16HA125E_EMIF_TIM2,
  179. .sdram_tim3 = MT41K256M16HA125E_EMIF_TIM3,
  180. .ocp_config = EMIF_OCP_CONFIG_BEAGLEBONE_BLACK,
  181. .zq_config = MT41K256M16HA125E_ZQ_CFG,
  182. .emif_ddr_phy_ctlr_1 = MT41K256M16HA125E_EMIF_READ_LATENCY,
  183. };
  184. static struct emif_regs ddr3_evm_emif_reg_data = {
  185. .sdram_config = MT41J512M8RH125_EMIF_SDCFG,
  186. .ref_ctrl = MT41J512M8RH125_EMIF_SDREF,
  187. .sdram_tim1 = MT41J512M8RH125_EMIF_TIM1,
  188. .sdram_tim2 = MT41J512M8RH125_EMIF_TIM2,
  189. .sdram_tim3 = MT41J512M8RH125_EMIF_TIM3,
  190. .ocp_config = EMIF_OCP_CONFIG_AM335X_EVM,
  191. .zq_config = MT41J512M8RH125_ZQ_CFG,
  192. .emif_ddr_phy_ctlr_1 = MT41J512M8RH125_EMIF_READ_LATENCY |
  193. PHY_EN_DYN_PWRDN,
  194. };
  195. static struct emif_regs ddr3_icev2_emif_reg_data = {
  196. .sdram_config = MT41J128MJT125_EMIF_SDCFG_400MHz,
  197. .ref_ctrl = MT41J128MJT125_EMIF_SDREF_400MHz,
  198. .sdram_tim1 = MT41J128MJT125_EMIF_TIM1_400MHz,
  199. .sdram_tim2 = MT41J128MJT125_EMIF_TIM2_400MHz,
  200. .sdram_tim3 = MT41J128MJT125_EMIF_TIM3_400MHz,
  201. .zq_config = MT41J128MJT125_ZQ_CFG_400MHz,
  202. .emif_ddr_phy_ctlr_1 = MT41J128MJT125_EMIF_READ_LATENCY_400MHz |
  203. PHY_EN_DYN_PWRDN,
  204. };
  205. #ifdef CONFIG_SPL_OS_BOOT
  206. int spl_start_uboot(void)
  207. {
  208. #ifdef CONFIG_SPL_SERIAL_SUPPORT
  209. /* break into full u-boot on 'c' */
  210. if (serial_tstc() && serial_getc() == 'c')
  211. return 1;
  212. #endif
  213. #ifdef CONFIG_SPL_ENV_SUPPORT
  214. env_init();
  215. env_load();
  216. if (env_get_yesno("boot_os") != 1)
  217. return 1;
  218. #endif
  219. return 0;
  220. }
  221. #endif
  222. const struct dpll_params *get_dpll_ddr_params(void)
  223. {
  224. int ind = get_sys_clk_index();
  225. if (board_is_evm_sk())
  226. return &dpll_ddr3_303MHz[ind];
  227. else if (board_is_pb() || board_is_bone_lt() || board_is_icev2())
  228. return &dpll_ddr3_400MHz[ind];
  229. else if (board_is_evm_15_or_later())
  230. return &dpll_ddr3_303MHz[ind];
  231. else
  232. return &dpll_ddr2_266MHz[ind];
  233. }
  234. static u8 bone_not_connected_to_ac_power(void)
  235. {
  236. if (board_is_bone()) {
  237. uchar pmic_status_reg;
  238. if (tps65217_reg_read(TPS65217_STATUS,
  239. &pmic_status_reg))
  240. return 1;
  241. if (!(pmic_status_reg & TPS65217_PWR_SRC_AC_BITMASK)) {
  242. puts("No AC power, switching to default OPP\n");
  243. return 1;
  244. }
  245. }
  246. return 0;
  247. }
  248. const struct dpll_params *get_dpll_mpu_params(void)
  249. {
  250. int ind = get_sys_clk_index();
  251. int freq = am335x_get_efuse_mpu_max_freq(cdev);
  252. if (bone_not_connected_to_ac_power())
  253. freq = MPUPLL_M_600;
  254. if (board_is_pb() || board_is_bone_lt())
  255. freq = MPUPLL_M_1000;
  256. switch (freq) {
  257. case MPUPLL_M_1000:
  258. return &dpll_mpu_opp[ind][5];
  259. case MPUPLL_M_800:
  260. return &dpll_mpu_opp[ind][4];
  261. case MPUPLL_M_720:
  262. return &dpll_mpu_opp[ind][3];
  263. case MPUPLL_M_600:
  264. return &dpll_mpu_opp[ind][2];
  265. case MPUPLL_M_500:
  266. return &dpll_mpu_opp100;
  267. case MPUPLL_M_300:
  268. return &dpll_mpu_opp[ind][0];
  269. }
  270. return &dpll_mpu_opp[ind][0];
  271. }
  272. static void scale_vcores_bone(int freq)
  273. {
  274. int usb_cur_lim, mpu_vdd;
  275. /*
  276. * Only perform PMIC configurations if board rev > A1
  277. * on Beaglebone White
  278. */
  279. if (board_is_bone() && !strncmp(board_ti_get_rev(), "00A1", 4))
  280. return;
  281. if (i2c_probe(TPS65217_CHIP_PM))
  282. return;
  283. /*
  284. * On Beaglebone White we need to ensure we have AC power
  285. * before increasing the frequency.
  286. */
  287. if (bone_not_connected_to_ac_power())
  288. freq = MPUPLL_M_600;
  289. /*
  290. * Override what we have detected since we know if we have
  291. * a Beaglebone Black it supports 1GHz.
  292. */
  293. if (board_is_pb() || board_is_bone_lt())
  294. freq = MPUPLL_M_1000;
  295. switch (freq) {
  296. case MPUPLL_M_1000:
  297. mpu_vdd = TPS65217_DCDC_VOLT_SEL_1325MV;
  298. usb_cur_lim = TPS65217_USB_INPUT_CUR_LIMIT_1800MA;
  299. break;
  300. case MPUPLL_M_800:
  301. mpu_vdd = TPS65217_DCDC_VOLT_SEL_1275MV;
  302. usb_cur_lim = TPS65217_USB_INPUT_CUR_LIMIT_1300MA;
  303. break;
  304. case MPUPLL_M_720:
  305. mpu_vdd = TPS65217_DCDC_VOLT_SEL_1200MV;
  306. usb_cur_lim = TPS65217_USB_INPUT_CUR_LIMIT_1300MA;
  307. break;
  308. case MPUPLL_M_600:
  309. case MPUPLL_M_500:
  310. case MPUPLL_M_300:
  311. default:
  312. mpu_vdd = TPS65217_DCDC_VOLT_SEL_1100MV;
  313. usb_cur_lim = TPS65217_USB_INPUT_CUR_LIMIT_1300MA;
  314. break;
  315. }
  316. if (tps65217_reg_write(TPS65217_PROT_LEVEL_NONE,
  317. TPS65217_POWER_PATH,
  318. usb_cur_lim,
  319. TPS65217_USB_INPUT_CUR_LIMIT_MASK))
  320. puts("tps65217_reg_write failure\n");
  321. /* Set DCDC3 (CORE) voltage to 1.10V */
  322. if (tps65217_voltage_update(TPS65217_DEFDCDC3,
  323. TPS65217_DCDC_VOLT_SEL_1100MV)) {
  324. puts("tps65217_voltage_update failure\n");
  325. return;
  326. }
  327. /* Set DCDC2 (MPU) voltage */
  328. if (tps65217_voltage_update(TPS65217_DEFDCDC2, mpu_vdd)) {
  329. puts("tps65217_voltage_update failure\n");
  330. return;
  331. }
  332. /*
  333. * Set LDO3, LDO4 output voltage to 3.3V for Beaglebone.
  334. * Set LDO3 to 1.8V and LDO4 to 3.3V for Beaglebone Black.
  335. */
  336. if (board_is_bone()) {
  337. if (tps65217_reg_write(TPS65217_PROT_LEVEL_2,
  338. TPS65217_DEFLS1,
  339. TPS65217_LDO_VOLTAGE_OUT_3_3,
  340. TPS65217_LDO_MASK))
  341. puts("tps65217_reg_write failure\n");
  342. } else {
  343. if (tps65217_reg_write(TPS65217_PROT_LEVEL_2,
  344. TPS65217_DEFLS1,
  345. TPS65217_LDO_VOLTAGE_OUT_1_8,
  346. TPS65217_LDO_MASK))
  347. puts("tps65217_reg_write failure\n");
  348. }
  349. if (tps65217_reg_write(TPS65217_PROT_LEVEL_2,
  350. TPS65217_DEFLS2,
  351. TPS65217_LDO_VOLTAGE_OUT_3_3,
  352. TPS65217_LDO_MASK))
  353. puts("tps65217_reg_write failure\n");
  354. }
  355. void scale_vcores_generic(int freq)
  356. {
  357. int sil_rev, mpu_vdd;
  358. /*
  359. * The GP EVM, IDK and EVM SK use a TPS65910 PMIC. For all
  360. * MPU frequencies we support we use a CORE voltage of
  361. * 1.10V. For MPU voltage we need to switch based on
  362. * the frequency we are running at.
  363. */
  364. if (i2c_probe(TPS65910_CTRL_I2C_ADDR))
  365. return;
  366. /*
  367. * Depending on MPU clock and PG we will need a different
  368. * VDD to drive at that speed.
  369. */
  370. sil_rev = readl(&cdev->deviceid) >> 28;
  371. mpu_vdd = am335x_get_tps65910_mpu_vdd(sil_rev, freq);
  372. /* Tell the TPS65910 to use i2c */
  373. tps65910_set_i2c_control();
  374. /* First update MPU voltage. */
  375. if (tps65910_voltage_update(MPU, mpu_vdd))
  376. return;
  377. /* Second, update the CORE voltage. */
  378. if (tps65910_voltage_update(CORE, TPS65910_OP_REG_SEL_1_1_0))
  379. return;
  380. }
  381. void gpi2c_init(void)
  382. {
  383. /* When needed to be invoked prior to BSS initialization */
  384. static bool first_time = true;
  385. if (first_time) {
  386. enable_i2c0_pin_mux();
  387. i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED,
  388. CONFIG_SYS_OMAP24_I2C_SLAVE);
  389. first_time = false;
  390. }
  391. }
  392. void scale_vcores(void)
  393. {
  394. int freq;
  395. gpi2c_init();
  396. freq = am335x_get_efuse_mpu_max_freq(cdev);
  397. if (board_is_beaglebonex())
  398. scale_vcores_bone(freq);
  399. else
  400. scale_vcores_generic(freq);
  401. }
  402. void set_uart_mux_conf(void)
  403. {
  404. #if CONFIG_CONS_INDEX == 1
  405. enable_uart0_pin_mux();
  406. #elif CONFIG_CONS_INDEX == 2
  407. enable_uart1_pin_mux();
  408. #elif CONFIG_CONS_INDEX == 3
  409. enable_uart2_pin_mux();
  410. #elif CONFIG_CONS_INDEX == 4
  411. enable_uart3_pin_mux();
  412. #elif CONFIG_CONS_INDEX == 5
  413. enable_uart4_pin_mux();
  414. #elif CONFIG_CONS_INDEX == 6
  415. enable_uart5_pin_mux();
  416. #endif
  417. }
  418. void set_mux_conf_regs(void)
  419. {
  420. enable_board_pin_mux();
  421. }
  422. const struct ctrl_ioregs ioregs_evmsk = {
  423. .cm0ioctl = MT41J128MJT125_IOCTRL_VALUE,
  424. .cm1ioctl = MT41J128MJT125_IOCTRL_VALUE,
  425. .cm2ioctl = MT41J128MJT125_IOCTRL_VALUE,
  426. .dt0ioctl = MT41J128MJT125_IOCTRL_VALUE,
  427. .dt1ioctl = MT41J128MJT125_IOCTRL_VALUE,
  428. };
  429. const struct ctrl_ioregs ioregs_bonelt = {
  430. .cm0ioctl = MT41K256M16HA125E_IOCTRL_VALUE,
  431. .cm1ioctl = MT41K256M16HA125E_IOCTRL_VALUE,
  432. .cm2ioctl = MT41K256M16HA125E_IOCTRL_VALUE,
  433. .dt0ioctl = MT41K256M16HA125E_IOCTRL_VALUE,
  434. .dt1ioctl = MT41K256M16HA125E_IOCTRL_VALUE,
  435. };
  436. const struct ctrl_ioregs ioregs_evm15 = {
  437. .cm0ioctl = MT41J512M8RH125_IOCTRL_VALUE,
  438. .cm1ioctl = MT41J512M8RH125_IOCTRL_VALUE,
  439. .cm2ioctl = MT41J512M8RH125_IOCTRL_VALUE,
  440. .dt0ioctl = MT41J512M8RH125_IOCTRL_VALUE,
  441. .dt1ioctl = MT41J512M8RH125_IOCTRL_VALUE,
  442. };
  443. const struct ctrl_ioregs ioregs = {
  444. .cm0ioctl = MT47H128M16RT25E_IOCTRL_VALUE,
  445. .cm1ioctl = MT47H128M16RT25E_IOCTRL_VALUE,
  446. .cm2ioctl = MT47H128M16RT25E_IOCTRL_VALUE,
  447. .dt0ioctl = MT47H128M16RT25E_IOCTRL_VALUE,
  448. .dt1ioctl = MT47H128M16RT25E_IOCTRL_VALUE,
  449. };
  450. void sdram_init(void)
  451. {
  452. if (board_is_evm_sk()) {
  453. /*
  454. * EVM SK 1.2A and later use gpio0_7 to enable DDR3.
  455. * This is safe enough to do on older revs.
  456. */
  457. gpio_request(GPIO_DDR_VTT_EN, "ddr_vtt_en");
  458. gpio_direction_output(GPIO_DDR_VTT_EN, 1);
  459. }
  460. if (board_is_icev2()) {
  461. gpio_request(ICE_GPIO_DDR_VTT_EN, "ddr_vtt_en");
  462. gpio_direction_output(ICE_GPIO_DDR_VTT_EN, 1);
  463. }
  464. if (board_is_evm_sk())
  465. config_ddr(303, &ioregs_evmsk, &ddr3_data,
  466. &ddr3_cmd_ctrl_data, &ddr3_emif_reg_data, 0);
  467. else if (board_is_pb() || board_is_bone_lt())
  468. config_ddr(400, &ioregs_bonelt,
  469. &ddr3_beagleblack_data,
  470. &ddr3_beagleblack_cmd_ctrl_data,
  471. &ddr3_beagleblack_emif_reg_data, 0);
  472. else if (board_is_evm_15_or_later())
  473. config_ddr(303, &ioregs_evm15, &ddr3_evm_data,
  474. &ddr3_evm_cmd_ctrl_data, &ddr3_evm_emif_reg_data, 0);
  475. else if (board_is_icev2())
  476. config_ddr(400, &ioregs_evmsk, &ddr3_icev2_data,
  477. &ddr3_icev2_cmd_ctrl_data, &ddr3_icev2_emif_reg_data,
  478. 0);
  479. else if (board_is_gp_evm())
  480. config_ddr(266, &ioregs, &ddr2_data,
  481. &ddr2_cmd_ctrl_data, &ddr2_evm_emif_reg_data, 0);
  482. else
  483. config_ddr(266, &ioregs, &ddr2_data,
  484. &ddr2_cmd_ctrl_data, &ddr2_emif_reg_data, 0);
  485. }
  486. #endif
  487. #if defined(CONFIG_CLOCK_SYNTHESIZER) && (!defined(CONFIG_SPL_BUILD) || \
  488. (defined(CONFIG_SPL_ETH_SUPPORT) && defined(CONFIG_SPL_BUILD)))
  489. static void request_and_set_gpio(int gpio, char *name, int val)
  490. {
  491. int ret;
  492. ret = gpio_request(gpio, name);
  493. if (ret < 0) {
  494. printf("%s: Unable to request %s\n", __func__, name);
  495. return;
  496. }
  497. ret = gpio_direction_output(gpio, 0);
  498. if (ret < 0) {
  499. printf("%s: Unable to set %s as output\n", __func__, name);
  500. goto err_free_gpio;
  501. }
  502. gpio_set_value(gpio, val);
  503. return;
  504. err_free_gpio:
  505. gpio_free(gpio);
  506. }
  507. #define REQUEST_AND_SET_GPIO(N) request_and_set_gpio(N, #N, 1);
  508. #define REQUEST_AND_CLR_GPIO(N) request_and_set_gpio(N, #N, 0);
  509. /**
  510. * RMII mode on ICEv2 board needs 50MHz clock. Given the clock
  511. * synthesizer With a capacitor of 18pF, and 25MHz input clock cycle
  512. * PLL1 gives an output of 100MHz. So, configuring the div2/3 as 2 to
  513. * give 50MHz output for Eth0 and 1.
  514. */
  515. static struct clk_synth cdce913_data = {
  516. .id = 0x81,
  517. .capacitor = 0x90,
  518. .mux = 0x6d,
  519. .pdiv2 = 0x2,
  520. .pdiv3 = 0x2,
  521. };
  522. #endif
  523. /*
  524. * Basic board specific setup. Pinmux has been handled already.
  525. */
  526. int board_init(void)
  527. {
  528. #if defined(CONFIG_HW_WATCHDOG)
  529. hw_watchdog_init();
  530. #endif
  531. gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE + 0x100;
  532. #if defined(CONFIG_NOR) || defined(CONFIG_NAND)
  533. gpmc_init();
  534. #endif
  535. #if defined(CONFIG_CLOCK_SYNTHESIZER) && (!defined(CONFIG_SPL_BUILD) || \
  536. (defined(CONFIG_SPL_ETH_SUPPORT) && defined(CONFIG_SPL_BUILD)))
  537. if (board_is_icev2()) {
  538. int rv;
  539. u32 reg;
  540. REQUEST_AND_SET_GPIO(GPIO_PR1_MII_CTRL);
  541. /* Make J19 status available on GPIO1_26 */
  542. REQUEST_AND_CLR_GPIO(GPIO_MUX_MII_CTRL);
  543. REQUEST_AND_SET_GPIO(GPIO_FET_SWITCH_CTRL);
  544. /*
  545. * Both ports can be set as RMII-CPSW or MII-PRU-ETH using
  546. * jumpers near the port. Read the jumper value and set
  547. * the pinmux, external mux and PHY clock accordingly.
  548. * As jumper line is overridden by PHY RX_DV pin immediately
  549. * after bootstrap (power-up/reset), we need to sample
  550. * it during PHY reset using GPIO rising edge detection.
  551. */
  552. REQUEST_AND_SET_GPIO(GPIO_PHY_RESET);
  553. /* Enable rising edge IRQ on GPIO0_11 and GPIO 1_26 */
  554. reg = readl(GPIO0_RISINGDETECT) | BIT(11);
  555. writel(reg, GPIO0_RISINGDETECT);
  556. reg = readl(GPIO1_RISINGDETECT) | BIT(26);
  557. writel(reg, GPIO1_RISINGDETECT);
  558. /* Reset PHYs to capture the Jumper setting */
  559. gpio_set_value(GPIO_PHY_RESET, 0);
  560. udelay(2); /* PHY datasheet states 1uS min. */
  561. gpio_set_value(GPIO_PHY_RESET, 1);
  562. reg = readl(GPIO0_IRQSTATUSRAW) & BIT(11);
  563. if (reg) {
  564. writel(reg, GPIO0_IRQSTATUS1); /* clear irq */
  565. /* RMII mode */
  566. printf("ETH0, CPSW\n");
  567. } else {
  568. /* MII mode */
  569. printf("ETH0, PRU\n");
  570. cdce913_data.pdiv3 = 4; /* 25MHz PHY clk */
  571. }
  572. reg = readl(GPIO1_IRQSTATUSRAW) & BIT(26);
  573. if (reg) {
  574. writel(reg, GPIO1_IRQSTATUS1); /* clear irq */
  575. /* RMII mode */
  576. printf("ETH1, CPSW\n");
  577. gpio_set_value(GPIO_MUX_MII_CTRL, 1);
  578. } else {
  579. /* MII mode */
  580. printf("ETH1, PRU\n");
  581. cdce913_data.pdiv2 = 4; /* 25MHz PHY clk */
  582. }
  583. /* disable rising edge IRQs */
  584. reg = readl(GPIO0_RISINGDETECT) & ~BIT(11);
  585. writel(reg, GPIO0_RISINGDETECT);
  586. reg = readl(GPIO1_RISINGDETECT) & ~BIT(26);
  587. writel(reg, GPIO1_RISINGDETECT);
  588. rv = setup_clock_synthesizer(&cdce913_data);
  589. if (rv) {
  590. printf("Clock synthesizer setup failed %d\n", rv);
  591. return rv;
  592. }
  593. /* reset PHYs */
  594. gpio_set_value(GPIO_PHY_RESET, 0);
  595. udelay(2); /* PHY datasheet states 1uS min. */
  596. gpio_set_value(GPIO_PHY_RESET, 1);
  597. }
  598. #endif
  599. return 0;
  600. }
  601. #ifdef CONFIG_BOARD_LATE_INIT
  602. int board_late_init(void)
  603. {
  604. #if !defined(CONFIG_SPL_BUILD)
  605. uint8_t mac_addr[6];
  606. uint32_t mac_hi, mac_lo;
  607. #endif
  608. #ifdef CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
  609. char *name = NULL;
  610. if (board_is_bone_lt()) {
  611. /* BeagleBoard.org BeagleBone Black Wireless: */
  612. if (!strncmp(board_ti_get_rev(), "BWA", 3)) {
  613. name = "BBBW";
  614. }
  615. /* SeeedStudio BeagleBone Green Wireless */
  616. if (!strncmp(board_ti_get_rev(), "GW1", 3)) {
  617. name = "BBGW";
  618. }
  619. /* BeagleBoard.org BeagleBone Blue */
  620. if (!strncmp(board_ti_get_rev(), "BLA", 3)) {
  621. name = "BBBL";
  622. }
  623. }
  624. if (board_is_bbg1())
  625. name = "BBG1";
  626. set_board_info_env(name);
  627. /*
  628. * Default FIT boot on HS devices. Non FIT images are not allowed
  629. * on HS devices.
  630. */
  631. if (get_device_type() == HS_DEVICE)
  632. env_set("boot_fit", "1");
  633. #endif
  634. #if !defined(CONFIG_SPL_BUILD)
  635. /* try reading mac address from efuse */
  636. mac_lo = readl(&cdev->macid0l);
  637. mac_hi = readl(&cdev->macid0h);
  638. mac_addr[0] = mac_hi & 0xFF;
  639. mac_addr[1] = (mac_hi & 0xFF00) >> 8;
  640. mac_addr[2] = (mac_hi & 0xFF0000) >> 16;
  641. mac_addr[3] = (mac_hi & 0xFF000000) >> 24;
  642. mac_addr[4] = mac_lo & 0xFF;
  643. mac_addr[5] = (mac_lo & 0xFF00) >> 8;
  644. if (!env_get("ethaddr")) {
  645. printf("<ethaddr> not set. Validating first E-fuse MAC\n");
  646. if (is_valid_ethaddr(mac_addr))
  647. eth_env_set_enetaddr("ethaddr", mac_addr);
  648. }
  649. mac_lo = readl(&cdev->macid1l);
  650. mac_hi = readl(&cdev->macid1h);
  651. mac_addr[0] = mac_hi & 0xFF;
  652. mac_addr[1] = (mac_hi & 0xFF00) >> 8;
  653. mac_addr[2] = (mac_hi & 0xFF0000) >> 16;
  654. mac_addr[3] = (mac_hi & 0xFF000000) >> 24;
  655. mac_addr[4] = mac_lo & 0xFF;
  656. mac_addr[5] = (mac_lo & 0xFF00) >> 8;
  657. if (!env_get("eth1addr")) {
  658. if (is_valid_ethaddr(mac_addr))
  659. eth_env_set_enetaddr("eth1addr", mac_addr);
  660. }
  661. #endif
  662. if (!env_get("serial#")) {
  663. char *board_serial = env_get("board_serial");
  664. char *ethaddr = env_get("ethaddr");
  665. if (!board_serial || !strncmp(board_serial, "unknown", 7))
  666. env_set("serial#", ethaddr);
  667. else
  668. env_set("serial#", board_serial);
  669. }
  670. return 0;
  671. }
  672. #endif
  673. #ifndef CONFIG_DM_ETH
  674. #if (defined(CONFIG_DRIVER_TI_CPSW) && !defined(CONFIG_SPL_BUILD)) || \
  675. (defined(CONFIG_SPL_ETH_SUPPORT) && defined(CONFIG_SPL_BUILD))
  676. static void cpsw_control(int enabled)
  677. {
  678. /* VTP can be added here */
  679. return;
  680. }
  681. static struct cpsw_slave_data cpsw_slaves[] = {
  682. {
  683. .slave_reg_ofs = 0x208,
  684. .sliver_reg_ofs = 0xd80,
  685. .phy_addr = 0,
  686. },
  687. {
  688. .slave_reg_ofs = 0x308,
  689. .sliver_reg_ofs = 0xdc0,
  690. .phy_addr = 1,
  691. },
  692. };
  693. static struct cpsw_platform_data cpsw_data = {
  694. .mdio_base = CPSW_MDIO_BASE,
  695. .cpsw_base = CPSW_BASE,
  696. .mdio_div = 0xff,
  697. .channels = 8,
  698. .cpdma_reg_ofs = 0x800,
  699. .slaves = 1,
  700. .slave_data = cpsw_slaves,
  701. .ale_reg_ofs = 0xd00,
  702. .ale_entries = 1024,
  703. .host_port_reg_ofs = 0x108,
  704. .hw_stats_reg_ofs = 0x900,
  705. .bd_ram_ofs = 0x2000,
  706. .mac_control = (1 << 5),
  707. .control = cpsw_control,
  708. .host_port_num = 0,
  709. .version = CPSW_CTRL_VERSION_2,
  710. };
  711. #endif
  712. #if ((defined(CONFIG_SPL_ETH_SUPPORT) || defined(CONFIG_SPL_USB_ETHER)) &&\
  713. defined(CONFIG_SPL_BUILD)) || \
  714. ((defined(CONFIG_DRIVER_TI_CPSW) || \
  715. defined(CONFIG_USB_ETHER) && defined(CONFIG_MUSB_GADGET)) && \
  716. !defined(CONFIG_SPL_BUILD))
  717. /*
  718. * This function will:
  719. * Read the eFuse for MAC addresses, and set ethaddr/eth1addr/usbnet_devaddr
  720. * in the environment
  721. * Perform fixups to the PHY present on certain boards. We only need this
  722. * function in:
  723. * - SPL with either CPSW or USB ethernet support
  724. * - Full U-Boot, with either CPSW or USB ethernet
  725. * Build in only these cases to avoid warnings about unused variables
  726. * when we build an SPL that has neither option but full U-Boot will.
  727. */
  728. int board_eth_init(bd_t *bis)
  729. {
  730. int rv, n = 0;
  731. #if defined(CONFIG_USB_ETHER) && \
  732. (!defined(CONFIG_SPL_BUILD) || defined(CONFIG_SPL_USB_ETHER))
  733. uint8_t mac_addr[6];
  734. uint32_t mac_hi, mac_lo;
  735. /*
  736. * use efuse mac address for USB ethernet as we know that
  737. * both CPSW and USB ethernet will never be active at the same time
  738. */
  739. mac_lo = readl(&cdev->macid0l);
  740. mac_hi = readl(&cdev->macid0h);
  741. mac_addr[0] = mac_hi & 0xFF;
  742. mac_addr[1] = (mac_hi & 0xFF00) >> 8;
  743. mac_addr[2] = (mac_hi & 0xFF0000) >> 16;
  744. mac_addr[3] = (mac_hi & 0xFF000000) >> 24;
  745. mac_addr[4] = mac_lo & 0xFF;
  746. mac_addr[5] = (mac_lo & 0xFF00) >> 8;
  747. #endif
  748. #if (defined(CONFIG_DRIVER_TI_CPSW) && !defined(CONFIG_SPL_BUILD)) || \
  749. (defined(CONFIG_SPL_ETH_SUPPORT) && defined(CONFIG_SPL_BUILD))
  750. #ifdef CONFIG_DRIVER_TI_CPSW
  751. if (board_is_bone() || board_is_bone_lt() ||
  752. board_is_idk()) {
  753. writel(MII_MODE_ENABLE, &cdev->miisel);
  754. cpsw_slaves[0].phy_if = cpsw_slaves[1].phy_if =
  755. PHY_INTERFACE_MODE_MII;
  756. } else if (board_is_icev2()) {
  757. writel(RMII_MODE_ENABLE | RMII_CHIPCKL_ENABLE, &cdev->miisel);
  758. cpsw_slaves[0].phy_if = PHY_INTERFACE_MODE_RMII;
  759. cpsw_slaves[1].phy_if = PHY_INTERFACE_MODE_RMII;
  760. cpsw_slaves[0].phy_addr = 1;
  761. cpsw_slaves[1].phy_addr = 3;
  762. } else {
  763. writel((RGMII_MODE_ENABLE | RGMII_INT_DELAY), &cdev->miisel);
  764. cpsw_slaves[0].phy_if = cpsw_slaves[1].phy_if =
  765. PHY_INTERFACE_MODE_RGMII;
  766. }
  767. rv = cpsw_register(&cpsw_data);
  768. if (rv < 0)
  769. printf("Error %d registering CPSW switch\n", rv);
  770. else
  771. n += rv;
  772. #endif
  773. /*
  774. *
  775. * CPSW RGMII Internal Delay Mode is not supported in all PVT
  776. * operating points. So we must set the TX clock delay feature
  777. * in the AR8051 PHY. Since we only support a single ethernet
  778. * device in U-Boot, we only do this for the first instance.
  779. */
  780. #define AR8051_PHY_DEBUG_ADDR_REG 0x1d
  781. #define AR8051_PHY_DEBUG_DATA_REG 0x1e
  782. #define AR8051_DEBUG_RGMII_CLK_DLY_REG 0x5
  783. #define AR8051_RGMII_TX_CLK_DLY 0x100
  784. if (board_is_evm_sk() || board_is_gp_evm()) {
  785. const char *devname;
  786. devname = miiphy_get_current_dev();
  787. miiphy_write(devname, 0x0, AR8051_PHY_DEBUG_ADDR_REG,
  788. AR8051_DEBUG_RGMII_CLK_DLY_REG);
  789. miiphy_write(devname, 0x0, AR8051_PHY_DEBUG_DATA_REG,
  790. AR8051_RGMII_TX_CLK_DLY);
  791. }
  792. #endif
  793. #if defined(CONFIG_USB_ETHER) && \
  794. (!defined(CONFIG_SPL_BUILD) || defined(CONFIG_SPL_USB_ETHER))
  795. if (is_valid_ethaddr(mac_addr))
  796. eth_env_set_enetaddr("usbnet_devaddr", mac_addr);
  797. rv = usb_eth_initialize(bis);
  798. if (rv < 0)
  799. printf("Error %d registering USB_ETHER\n", rv);
  800. else
  801. n += rv;
  802. #endif
  803. return n;
  804. }
  805. #endif
  806. #endif /* CONFIG_DM_ETH */
  807. #ifdef CONFIG_SPL_LOAD_FIT
  808. int board_fit_config_name_match(const char *name)
  809. {
  810. if (board_is_gp_evm() && !strcmp(name, "am335x-evm"))
  811. return 0;
  812. else if (board_is_bone() && !strcmp(name, "am335x-bone"))
  813. return 0;
  814. else if (board_is_bone_lt() && !strcmp(name, "am335x-boneblack"))
  815. return 0;
  816. else if (board_is_pb() && !strcmp(name, "am335x-pocketbeagle"))
  817. return 0;
  818. else if (board_is_evm_sk() && !strcmp(name, "am335x-evmsk"))
  819. return 0;
  820. else if (board_is_bbg1() && !strcmp(name, "am335x-bonegreen"))
  821. return 0;
  822. else if (board_is_icev2() && !strcmp(name, "am335x-icev2"))
  823. return 0;
  824. else
  825. return -1;
  826. }
  827. #endif
  828. #ifdef CONFIG_TI_SECURE_DEVICE
  829. void board_fit_image_post_process(void **p_image, size_t *p_size)
  830. {
  831. secure_boot_verify_image(p_image, p_size);
  832. }
  833. #endif
  834. #if !CONFIG_IS_ENABLED(OF_CONTROL)
  835. static const struct omap_hsmmc_plat am335x_mmc0_platdata = {
  836. .base_addr = (struct hsmmc *)OMAP_HSMMC1_BASE,
  837. .cfg.host_caps = MMC_MODE_HS_52MHz | MMC_MODE_HS | MMC_MODE_4BIT,
  838. .cfg.f_min = 400000,
  839. .cfg.f_max = 52000000,
  840. .cfg.voltages = MMC_VDD_32_33 | MMC_VDD_33_34 | MMC_VDD_165_195,
  841. .cfg.b_max = CONFIG_SYS_MMC_MAX_BLK_COUNT,
  842. };
  843. U_BOOT_DEVICE(am335x_mmc0) = {
  844. .name = "omap_hsmmc",
  845. .platdata = &am335x_mmc0_platdata,
  846. };
  847. static const struct omap_hsmmc_plat am335x_mmc1_platdata = {
  848. .base_addr = (struct hsmmc *)OMAP_HSMMC2_BASE,
  849. .cfg.host_caps = MMC_MODE_HS_52MHz | MMC_MODE_HS | MMC_MODE_8BIT,
  850. .cfg.f_min = 400000,
  851. .cfg.f_max = 52000000,
  852. .cfg.voltages = MMC_VDD_32_33 | MMC_VDD_33_34 | MMC_VDD_165_195,
  853. .cfg.b_max = CONFIG_SYS_MMC_MAX_BLK_COUNT,
  854. };
  855. U_BOOT_DEVICE(am335x_mmc1) = {
  856. .name = "omap_hsmmc",
  857. .platdata = &am335x_mmc1_platdata,
  858. };
  859. #endif