board.c 32 KB

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