ddr3_training_leveling.c 64 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) Marvell International Ltd. and its affiliates
  4. */
  5. #include "ddr3_init.h"
  6. #define WL_ITERATION_NUM 10
  7. static u32 pup_mask_table[] = {
  8. 0x000000ff,
  9. 0x0000ff00,
  10. 0x00ff0000,
  11. 0xff000000
  12. };
  13. static struct write_supp_result wr_supp_res[MAX_INTERFACE_NUM][MAX_BUS_NUM];
  14. static int ddr3_tip_dynamic_write_leveling_seq(u32 dev_num);
  15. static int ddr3_tip_dynamic_read_leveling_seq(u32 dev_num);
  16. static int ddr3_tip_dynamic_per_bit_read_leveling_seq(u32 dev_num);
  17. static int ddr3_tip_wl_supp_align_phase_shift(u32 dev_num, u32 if_id,
  18. u32 bus_id);
  19. static int ddr3_tip_xsb_compare_test(u32 dev_num, u32 if_id, u32 bus_id,
  20. u32 edge_offset);
  21. u32 ddr3_tip_max_cs_get(u32 dev_num)
  22. {
  23. u32 c_cs, if_id, bus_id;
  24. static u32 max_cs;
  25. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  26. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  27. if (!max_cs) {
  28. CHECK_STATUS(ddr3_tip_get_first_active_if((u8)dev_num,
  29. tm->if_act_mask,
  30. &if_id));
  31. for (bus_id = 0; bus_id < octets_per_if_num; bus_id++) {
  32. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_id);
  33. break;
  34. }
  35. for (c_cs = 0; c_cs < NUM_OF_CS; c_cs++) {
  36. VALIDATE_ACTIVE(tm->
  37. interface_params[if_id].as_bus_params[bus_id].
  38. cs_bitmask, c_cs);
  39. max_cs++;
  40. }
  41. }
  42. return max_cs;
  43. }
  44. enum {
  45. PASS,
  46. FAIL
  47. };
  48. /*****************************************************************************
  49. Dynamic read leveling
  50. ******************************************************************************/
  51. int ddr3_tip_dynamic_read_leveling(u32 dev_num, u32 freq)
  52. {
  53. u32 data, mask;
  54. u32 max_cs = ddr3_tip_max_cs_get(dev_num);
  55. u32 bus_num, if_id, cl_val;
  56. enum hws_speed_bin speed_bin_index;
  57. /* save current CS value */
  58. u32 cs_enable_reg_val[MAX_INTERFACE_NUM] = { 0 };
  59. int is_any_pup_fail = 0;
  60. u32 data_read[MAX_INTERFACE_NUM + 1] = { 0 };
  61. u8 rl_values[NUM_OF_CS][MAX_BUS_NUM][MAX_INTERFACE_NUM];
  62. struct pattern_info *pattern_table = ddr3_tip_get_pattern_table();
  63. u16 *mask_results_pup_reg_map = ddr3_tip_get_mask_results_pup_reg_map();
  64. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  65. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  66. for (effective_cs = 0; effective_cs < NUM_OF_CS; effective_cs++)
  67. for (bus_num = 0; bus_num < MAX_BUS_NUM; bus_num++)
  68. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++)
  69. rl_values[effective_cs][bus_num][if_id] = 0;
  70. for (effective_cs = 0; effective_cs < max_cs; effective_cs++) {
  71. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  72. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  73. training_result[training_stage][if_id] = TEST_SUCCESS;
  74. /* save current cs enable reg val */
  75. CHECK_STATUS(ddr3_tip_if_read
  76. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  77. DUAL_DUNIT_CFG_REG, cs_enable_reg_val,
  78. MASK_ALL_BITS));
  79. /* enable single cs */
  80. CHECK_STATUS(ddr3_tip_if_write
  81. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  82. DUAL_DUNIT_CFG_REG, (1 << 3), (1 << 3)));
  83. }
  84. ddr3_tip_reset_fifo_ptr(dev_num);
  85. /*
  86. * Phase 1: Load pattern (using ODPG)
  87. *
  88. * enter Read Leveling mode
  89. * only 27 bits are masked
  90. * assuming non multi-CS configuration
  91. * write to CS = 0 for the non multi CS configuration, note
  92. * that the results shall be read back to the required CS !!!
  93. */
  94. /* BUS count is 0 shifted 26 */
  95. CHECK_STATUS(ddr3_tip_if_write
  96. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  97. ODPG_DATA_CTRL_REG, 0x3, 0x3));
  98. CHECK_STATUS(ddr3_tip_configure_odpg
  99. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE, 0,
  100. pattern_table[PATTERN_RL].num_of_phases_tx, 0,
  101. pattern_table[PATTERN_RL].num_of_phases_rx, 0, 0,
  102. effective_cs, STRESS_NONE, DURATION_SINGLE));
  103. /* load pattern to ODPG */
  104. ddr3_tip_load_pattern_to_odpg(dev_num, ACCESS_TYPE_MULTICAST,
  105. PARAM_NOT_CARE, PATTERN_RL,
  106. pattern_table[PATTERN_RL].
  107. start_addr);
  108. /*
  109. * Phase 2: ODPG to Read Leveling mode
  110. */
  111. /* General Training Opcode register */
  112. CHECK_STATUS(ddr3_tip_if_write
  113. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  114. ODPG_WR_RD_MODE_ENA_REG, 0,
  115. MASK_ALL_BITS));
  116. CHECK_STATUS(ddr3_tip_if_write
  117. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  118. GENERAL_TRAINING_OPCODE_REG,
  119. (0x301b01 | effective_cs << 2), 0x3c3fef));
  120. /* Object1 opcode register 0 & 1 */
  121. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  122. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  123. speed_bin_index =
  124. tm->interface_params[if_id].speed_bin_index;
  125. cl_val =
  126. cas_latency_table[speed_bin_index].cl_val[freq];
  127. data = (cl_val << 17) | (0x3 << 25);
  128. mask = (0xff << 9) | (0x1f << 17) | (0x3 << 25);
  129. CHECK_STATUS(ddr3_tip_if_write
  130. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  131. OPCODE_REG0_REG(1), data, mask));
  132. }
  133. /* Set iteration count to max value */
  134. CHECK_STATUS(ddr3_tip_if_write
  135. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  136. OPCODE_REG1_REG(1), 0xd00, 0xd00));
  137. /*
  138. * Phase 2: Mask config
  139. */
  140. ddr3_tip_dynamic_read_leveling_seq(dev_num);
  141. /*
  142. * Phase 3: Read Leveling execution
  143. */
  144. /* temporary jira dunit=14751 */
  145. CHECK_STATUS(ddr3_tip_if_write
  146. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  147. TRAINING_DBG_1_REG, 0, (u32)(1 << 31)));
  148. /* configure phy reset value */
  149. CHECK_STATUS(ddr3_tip_if_write
  150. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  151. TRAINING_DBG_3_REG, (0x7f << 24),
  152. (u32)(0xff << 24)));
  153. /* data pup rd reset enable */
  154. CHECK_STATUS(ddr3_tip_if_write
  155. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  156. SDRAM_CFG_REG, 0, (1 << 30)));
  157. /* data pup rd reset disable */
  158. CHECK_STATUS(ddr3_tip_if_write
  159. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  160. SDRAM_CFG_REG, (1 << 30), (1 << 30)));
  161. /* training SW override & training RL mode */
  162. CHECK_STATUS(ddr3_tip_if_write
  163. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  164. TRAINING_SW_2_REG, 0x1, 0x9));
  165. /* training enable */
  166. CHECK_STATUS(ddr3_tip_if_write
  167. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  168. TRAINING_REG, (1 << 24) | (1 << 20),
  169. (1 << 24) | (1 << 20)));
  170. CHECK_STATUS(ddr3_tip_if_write
  171. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  172. TRAINING_REG, (u32)(1 << 31), (u32)(1 << 31)));
  173. /* trigger training */
  174. mv_ddr_training_enable();
  175. /* check for training done */
  176. if (mv_ddr_is_training_done(MAX_POLLING_ITERATIONS, &data) != MV_OK) {
  177. DEBUG_LEVELING(DEBUG_LEVEL_ERROR, ("training done failed\n"));
  178. return MV_FAIL;
  179. }
  180. /* check for training pass */
  181. if (data != PASS)
  182. DEBUG_LEVELING(DEBUG_LEVEL_INFO, ("training result failed\n"));
  183. /* disable odpg; switch back to functional mode */
  184. mv_ddr_odpg_disable();
  185. if (mv_ddr_is_odpg_done(MAX_POLLING_ITERATIONS) != MV_OK) {
  186. DEBUG_LEVELING(DEBUG_LEVEL_ERROR, ("odpg disable failed\n"));
  187. return MV_FAIL;
  188. }
  189. ddr3_tip_if_write(0, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  190. ODPG_DATA_CTRL_REG, 0, MASK_ALL_BITS);
  191. /* double loop on bus, pup */
  192. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  193. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  194. /* check training done */
  195. is_any_pup_fail = 0;
  196. for (bus_num = 0;
  197. bus_num < octets_per_if_num;
  198. bus_num++) {
  199. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_num);
  200. if (ddr3_tip_if_polling
  201. (dev_num, ACCESS_TYPE_UNICAST,
  202. if_id, (1 << 25), (1 << 25),
  203. mask_results_pup_reg_map[bus_num],
  204. MAX_POLLING_ITERATIONS) != MV_OK) {
  205. DEBUG_LEVELING(DEBUG_LEVEL_ERROR,
  206. ("\n_r_l: DDR3 poll failed(2) for IF %d CS %d bus %d",
  207. if_id, effective_cs, bus_num));
  208. is_any_pup_fail = 1;
  209. } else {
  210. /* read result per pup */
  211. CHECK_STATUS(ddr3_tip_if_read
  212. (dev_num,
  213. ACCESS_TYPE_UNICAST,
  214. if_id,
  215. mask_results_pup_reg_map
  216. [bus_num], data_read,
  217. 0xff));
  218. rl_values[effective_cs][bus_num]
  219. [if_id] = (u8)data_read[if_id];
  220. }
  221. }
  222. if (is_any_pup_fail == 1) {
  223. training_result[training_stage][if_id] =
  224. TEST_FAILED;
  225. if (debug_mode == 0)
  226. return MV_FAIL;
  227. }
  228. }
  229. DEBUG_LEVELING(DEBUG_LEVEL_INFO, ("RL exit read leveling\n"));
  230. /*
  231. * Phase 3: Exit Read Leveling
  232. */
  233. CHECK_STATUS(ddr3_tip_if_write
  234. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  235. TRAINING_SW_2_REG, (1 << 3), (1 << 3)));
  236. CHECK_STATUS(ddr3_tip_if_write
  237. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  238. TRAINING_SW_1_REG, (1 << 16), (1 << 16)));
  239. /* set ODPG to functional */
  240. CHECK_STATUS(ddr3_tip_if_write
  241. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  242. ODPG_DATA_CTRL_REG, 0x0, MASK_ALL_BITS));
  243. /*
  244. * Copy the result from the effective CS search to the
  245. * real Functional CS
  246. */
  247. /*ddr3_tip_write_cs_result(dev_num, RL_PHY_REG(0); */
  248. CHECK_STATUS(ddr3_tip_if_write
  249. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  250. ODPG_DATA_CTRL_REG, 0x0, MASK_ALL_BITS));
  251. }
  252. for (effective_cs = 0; effective_cs < max_cs; effective_cs++) {
  253. /* double loop on bus, pup */
  254. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  255. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  256. for (bus_num = 0;
  257. bus_num < octets_per_if_num;
  258. bus_num++) {
  259. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_num);
  260. /* read result per pup from arry */
  261. data = rl_values[effective_cs][bus_num][if_id];
  262. data = (data & 0x1f) |
  263. (((data & 0xe0) >> 5) << 6);
  264. ddr3_tip_bus_write(dev_num,
  265. ACCESS_TYPE_UNICAST,
  266. if_id,
  267. ACCESS_TYPE_UNICAST,
  268. bus_num, DDR_PHY_DATA,
  269. RL_PHY_REG(effective_cs),
  270. data);
  271. }
  272. }
  273. }
  274. /* Set to 0 after each loop to avoid illegal value may be used */
  275. effective_cs = 0;
  276. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  277. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  278. /* restore cs enable value */
  279. CHECK_STATUS(ddr3_tip_if_write
  280. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  281. DUAL_DUNIT_CFG_REG, cs_enable_reg_val[if_id],
  282. MASK_ALL_BITS));
  283. if (odt_config != 0) {
  284. CHECK_STATUS(ddr3_tip_write_additional_odt_setting
  285. (dev_num, if_id));
  286. }
  287. }
  288. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  289. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  290. if (training_result[training_stage][if_id] == TEST_FAILED)
  291. return MV_FAIL;
  292. }
  293. return MV_OK;
  294. }
  295. /*
  296. * Legacy Dynamic write leveling
  297. */
  298. int ddr3_tip_legacy_dynamic_write_leveling(u32 dev_num)
  299. {
  300. u32 c_cs, if_id, cs_mask = 0;
  301. u32 max_cs = ddr3_tip_max_cs_get(dev_num);
  302. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  303. /*
  304. * In TRAINIUNG reg (0x15b0) write 0x80000008 | cs_mask:
  305. * Trn_start
  306. * cs_mask = 0x1 <<20 Trn_CS0 - CS0 is included in the DDR3 training
  307. * cs_mask = 0x1 <<21 Trn_CS1 - CS1 is included in the DDR3 training
  308. * cs_mask = 0x1 <<22 Trn_CS2 - CS2 is included in the DDR3 training
  309. * cs_mask = 0x1 <<23 Trn_CS3 - CS3 is included in the DDR3 training
  310. * Trn_auto_seq = write leveling
  311. */
  312. for (c_cs = 0; c_cs < max_cs; c_cs++)
  313. cs_mask = cs_mask | 1 << (20 + c_cs);
  314. for (if_id = 0; if_id < MAX_INTERFACE_NUM; if_id++) {
  315. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  316. CHECK_STATUS(ddr3_tip_if_write
  317. (dev_num, ACCESS_TYPE_MULTICAST, 0,
  318. TRAINING_REG, (0x80000008 | cs_mask),
  319. 0xffffffff));
  320. mdelay(20);
  321. if (ddr3_tip_if_polling
  322. (dev_num, ACCESS_TYPE_UNICAST, if_id, 0,
  323. (u32)0x80000000, TRAINING_REG,
  324. MAX_POLLING_ITERATIONS) != MV_OK) {
  325. DEBUG_LEVELING(DEBUG_LEVEL_ERROR,
  326. ("polling failed for Old WL result\n"));
  327. return MV_FAIL;
  328. }
  329. }
  330. return MV_OK;
  331. }
  332. /*
  333. * Legacy Dynamic read leveling
  334. */
  335. int ddr3_tip_legacy_dynamic_read_leveling(u32 dev_num)
  336. {
  337. u32 c_cs, if_id, cs_mask = 0;
  338. u32 max_cs = ddr3_tip_max_cs_get(dev_num);
  339. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  340. /*
  341. * In TRAINIUNG reg (0x15b0) write 0x80000040 | cs_mask:
  342. * Trn_start
  343. * cs_mask = 0x1 <<20 Trn_CS0 - CS0 is included in the DDR3 training
  344. * cs_mask = 0x1 <<21 Trn_CS1 - CS1 is included in the DDR3 training
  345. * cs_mask = 0x1 <<22 Trn_CS2 - CS2 is included in the DDR3 training
  346. * cs_mask = 0x1 <<23 Trn_CS3 - CS3 is included in the DDR3 training
  347. * Trn_auto_seq = Read Leveling using training pattern
  348. */
  349. for (c_cs = 0; c_cs < max_cs; c_cs++)
  350. cs_mask = cs_mask | 1 << (20 + c_cs);
  351. CHECK_STATUS(ddr3_tip_if_write
  352. (dev_num, ACCESS_TYPE_MULTICAST, 0, TRAINING_REG,
  353. (0x80000040 | cs_mask), 0xffffffff));
  354. mdelay(100);
  355. for (if_id = 0; if_id < MAX_INTERFACE_NUM; if_id++) {
  356. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  357. if (ddr3_tip_if_polling
  358. (dev_num, ACCESS_TYPE_UNICAST, if_id, 0,
  359. (u32)0x80000000, TRAINING_REG,
  360. MAX_POLLING_ITERATIONS) != MV_OK) {
  361. DEBUG_LEVELING(DEBUG_LEVEL_ERROR,
  362. ("polling failed for Old RL result\n"));
  363. return MV_FAIL;
  364. }
  365. }
  366. return MV_OK;
  367. }
  368. /*
  369. * Dynamic per bit read leveling
  370. */
  371. int ddr3_tip_dynamic_per_bit_read_leveling(u32 dev_num, u32 freq)
  372. {
  373. u32 data, mask;
  374. u32 bus_num, if_id, cl_val, bit_num;
  375. u32 curr_numb, curr_min_delay;
  376. int adll_array[3] = { 0, -0xa, 0x14 };
  377. u32 phyreg3_arr[MAX_INTERFACE_NUM][MAX_BUS_NUM];
  378. enum hws_speed_bin speed_bin_index;
  379. int is_any_pup_fail = 0;
  380. int break_loop = 0;
  381. u32 cs_enable_reg_val[MAX_INTERFACE_NUM]; /* save current CS value */
  382. u32 data_read[MAX_INTERFACE_NUM];
  383. int per_bit_rl_pup_status[MAX_INTERFACE_NUM][MAX_BUS_NUM];
  384. u32 data2_write[MAX_INTERFACE_NUM][MAX_BUS_NUM];
  385. struct pattern_info *pattern_table = ddr3_tip_get_pattern_table();
  386. u16 *mask_results_dq_reg_map = ddr3_tip_get_mask_results_dq_reg();
  387. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  388. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  389. for (if_id = 0; if_id < MAX_INTERFACE_NUM; if_id++) {
  390. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  391. for (bus_num = 0;
  392. bus_num <= octets_per_if_num; bus_num++) {
  393. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_num);
  394. per_bit_rl_pup_status[if_id][bus_num] = 0;
  395. data2_write[if_id][bus_num] = 0;
  396. /* read current value of phy register 0x3 */
  397. CHECK_STATUS(ddr3_tip_bus_read
  398. (dev_num, if_id, ACCESS_TYPE_UNICAST,
  399. bus_num, DDR_PHY_DATA,
  400. CRX_PHY_REG(0),
  401. &phyreg3_arr[if_id][bus_num]));
  402. }
  403. }
  404. /* NEW RL machine */
  405. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  406. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  407. training_result[training_stage][if_id] = TEST_SUCCESS;
  408. /* save current cs enable reg val */
  409. CHECK_STATUS(ddr3_tip_if_read
  410. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  411. DUAL_DUNIT_CFG_REG, &cs_enable_reg_val[if_id],
  412. MASK_ALL_BITS));
  413. /* enable single cs */
  414. CHECK_STATUS(ddr3_tip_if_write
  415. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  416. DUAL_DUNIT_CFG_REG, (1 << 3), (1 << 3)));
  417. }
  418. ddr3_tip_reset_fifo_ptr(dev_num);
  419. for (curr_numb = 0; curr_numb < 3; curr_numb++) {
  420. /*
  421. * Phase 1: Load pattern (using ODPG)
  422. *
  423. * enter Read Leveling mode
  424. * only 27 bits are masked
  425. * assuming non multi-CS configuration
  426. * write to CS = 0 for the non multi CS configuration, note that
  427. * the results shall be read back to the required CS !!!
  428. */
  429. /* BUS count is 0 shifted 26 */
  430. CHECK_STATUS(ddr3_tip_if_write
  431. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  432. ODPG_DATA_CTRL_REG, 0x3, 0x3));
  433. CHECK_STATUS(ddr3_tip_configure_odpg
  434. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE, 0,
  435. pattern_table[PATTERN_TEST].num_of_phases_tx, 0,
  436. pattern_table[PATTERN_TEST].num_of_phases_rx, 0,
  437. 0, 0, STRESS_NONE, DURATION_SINGLE));
  438. /* load pattern to ODPG */
  439. ddr3_tip_load_pattern_to_odpg(dev_num, ACCESS_TYPE_MULTICAST,
  440. PARAM_NOT_CARE, PATTERN_TEST,
  441. pattern_table[PATTERN_TEST].
  442. start_addr);
  443. /*
  444. * Phase 2: ODPG to Read Leveling mode
  445. */
  446. /* General Training Opcode register */
  447. CHECK_STATUS(ddr3_tip_if_write
  448. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  449. ODPG_WR_RD_MODE_ENA_REG, 0,
  450. MASK_ALL_BITS));
  451. CHECK_STATUS(ddr3_tip_if_write
  452. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  453. GENERAL_TRAINING_OPCODE_REG, 0x301b01, 0x3c3fef));
  454. /* Object1 opcode register 0 & 1 */
  455. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  456. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  457. speed_bin_index =
  458. tm->interface_params[if_id].speed_bin_index;
  459. cl_val =
  460. cas_latency_table[speed_bin_index].cl_val[freq];
  461. data = (cl_val << 17) | (0x3 << 25);
  462. mask = (0xff << 9) | (0x1f << 17) | (0x3 << 25);
  463. CHECK_STATUS(ddr3_tip_if_write
  464. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  465. OPCODE_REG0_REG(1), data, mask));
  466. }
  467. /* Set iteration count to max value */
  468. CHECK_STATUS(ddr3_tip_if_write
  469. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  470. OPCODE_REG1_REG(1), 0xd00, 0xd00));
  471. /*
  472. * Phase 2: Mask config
  473. */
  474. ddr3_tip_dynamic_per_bit_read_leveling_seq(dev_num);
  475. /*
  476. * Phase 3: Read Leveling execution
  477. */
  478. /* temporary jira dunit=14751 */
  479. CHECK_STATUS(ddr3_tip_if_write
  480. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  481. TRAINING_DBG_1_REG, 0, (u32)(1 << 31)));
  482. /* configure phy reset value */
  483. CHECK_STATUS(ddr3_tip_if_write
  484. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  485. TRAINING_DBG_3_REG, (0x7f << 24),
  486. (u32)(0xff << 24)));
  487. /* data pup rd reset enable */
  488. CHECK_STATUS(ddr3_tip_if_write
  489. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  490. SDRAM_CFG_REG, 0, (1 << 30)));
  491. /* data pup rd reset disable */
  492. CHECK_STATUS(ddr3_tip_if_write
  493. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  494. SDRAM_CFG_REG, (1 << 30), (1 << 30)));
  495. /* training SW override & training RL mode */
  496. CHECK_STATUS(ddr3_tip_if_write
  497. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  498. TRAINING_SW_2_REG, 0x1, 0x9));
  499. /* training enable */
  500. CHECK_STATUS(ddr3_tip_if_write
  501. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  502. TRAINING_REG, (1 << 24) | (1 << 20),
  503. (1 << 24) | (1 << 20)));
  504. CHECK_STATUS(ddr3_tip_if_write
  505. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  506. TRAINING_REG, (u32)(1 << 31), (u32)(1 << 31)));
  507. /* trigger training */
  508. mv_ddr_training_enable();
  509. /* check for training done */
  510. if (mv_ddr_is_training_done(MAX_POLLING_ITERATIONS, &data) != MV_OK) {
  511. DEBUG_LEVELING(DEBUG_LEVEL_ERROR, ("training done failed\n"));
  512. return MV_FAIL;
  513. }
  514. /* check for training pass */
  515. if (data != PASS)
  516. DEBUG_LEVELING(DEBUG_LEVEL_INFO, ("training result failed\n"));
  517. /* disable odpg; switch back to functional mode */
  518. mv_ddr_odpg_disable();
  519. if (mv_ddr_is_odpg_done(MAX_POLLING_ITERATIONS) != MV_OK) {
  520. DEBUG_LEVELING(DEBUG_LEVEL_ERROR, ("odpg disable failed\n"));
  521. return MV_FAIL;
  522. }
  523. ddr3_tip_if_write(0, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  524. ODPG_DATA_CTRL_REG, 0, MASK_ALL_BITS);
  525. /* double loop on bus, pup */
  526. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  527. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  528. /* check training done */
  529. for (bus_num = 0;
  530. bus_num < octets_per_if_num;
  531. bus_num++) {
  532. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_num);
  533. if (per_bit_rl_pup_status[if_id][bus_num]
  534. == 0) {
  535. curr_min_delay = 0;
  536. for (bit_num = 0; bit_num < 8;
  537. bit_num++) {
  538. if (ddr3_tip_if_polling
  539. (dev_num,
  540. ACCESS_TYPE_UNICAST,
  541. if_id, (1 << 25),
  542. (1 << 25),
  543. mask_results_dq_reg_map
  544. [bus_num * 8 + bit_num],
  545. MAX_POLLING_ITERATIONS) !=
  546. MV_OK) {
  547. DEBUG_LEVELING
  548. (DEBUG_LEVEL_ERROR,
  549. ("\n_r_l: DDR3 poll failed(2) for bus %d bit %d\n",
  550. bus_num,
  551. bit_num));
  552. } else {
  553. /* read result per pup */
  554. CHECK_STATUS
  555. (ddr3_tip_if_read
  556. (dev_num,
  557. ACCESS_TYPE_UNICAST,
  558. if_id,
  559. mask_results_dq_reg_map
  560. [bus_num * 8 +
  561. bit_num],
  562. data_read,
  563. MASK_ALL_BITS));
  564. data =
  565. (data_read
  566. [if_id] &
  567. 0x1f) |
  568. ((data_read
  569. [if_id] &
  570. 0xe0) << 1);
  571. if (curr_min_delay == 0)
  572. curr_min_delay =
  573. data;
  574. else if (data <
  575. curr_min_delay)
  576. curr_min_delay =
  577. data;
  578. if (data > data2_write[if_id][bus_num])
  579. data2_write
  580. [if_id]
  581. [bus_num] =
  582. data;
  583. }
  584. }
  585. if (data2_write[if_id][bus_num] <=
  586. (curr_min_delay +
  587. MAX_DQ_READ_LEVELING_DELAY)) {
  588. per_bit_rl_pup_status[if_id]
  589. [bus_num] = 1;
  590. }
  591. }
  592. }
  593. }
  594. /* check if there is need to search new phyreg3 value */
  595. if (curr_numb < 2) {
  596. /* if there is DLL that is not checked yet */
  597. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1;
  598. if_id++) {
  599. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  600. for (bus_num = 0;
  601. bus_num < octets_per_if_num;
  602. bus_num++) {
  603. VALIDATE_BUS_ACTIVE(tm->bus_act_mask,
  604. bus_num);
  605. if (per_bit_rl_pup_status[if_id]
  606. [bus_num] != 1) {
  607. /* go to next ADLL value */
  608. CHECK_STATUS
  609. (ddr3_tip_bus_write
  610. (dev_num,
  611. ACCESS_TYPE_UNICAST,
  612. if_id,
  613. ACCESS_TYPE_UNICAST,
  614. bus_num, DDR_PHY_DATA,
  615. CRX_PHY_REG(0),
  616. (phyreg3_arr[if_id]
  617. [bus_num] +
  618. adll_array[curr_numb])));
  619. break_loop = 1;
  620. break;
  621. }
  622. }
  623. if (break_loop)
  624. break;
  625. }
  626. } /* if (curr_numb < 2) */
  627. if (!break_loop)
  628. break;
  629. } /* for ( curr_numb = 0; curr_numb <3; curr_numb++) */
  630. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  631. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  632. for (bus_num = 0; bus_num < octets_per_if_num;
  633. bus_num++) {
  634. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_num);
  635. if (per_bit_rl_pup_status[if_id][bus_num] == 1)
  636. ddr3_tip_bus_write(dev_num,
  637. ACCESS_TYPE_UNICAST,
  638. if_id,
  639. ACCESS_TYPE_UNICAST,
  640. bus_num, DDR_PHY_DATA,
  641. RL_PHY_REG(effective_cs),
  642. data2_write[if_id]
  643. [bus_num]);
  644. else
  645. is_any_pup_fail = 1;
  646. }
  647. /* TBD flow does not support multi CS */
  648. /*
  649. * cs_bitmask = tm->interface_params[if_id].
  650. * as_bus_params[bus_num].cs_bitmask;
  651. */
  652. /* divide by 4 is used for retrieving the CS number */
  653. /*
  654. * TBD BC2 - what is the PHY address for other
  655. * CS ddr3_tip_write_cs_result() ???
  656. */
  657. /*
  658. * find what should be written to PHY
  659. * - max delay that is less than threshold
  660. */
  661. if (is_any_pup_fail == 1) {
  662. training_result[training_stage][if_id] = TEST_FAILED;
  663. if (debug_mode == 0)
  664. return MV_FAIL;
  665. }
  666. }
  667. DEBUG_LEVELING(DEBUG_LEVEL_INFO, ("RL exit read leveling\n"));
  668. /*
  669. * Phase 3: Exit Read Leveling
  670. */
  671. CHECK_STATUS(ddr3_tip_if_write
  672. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  673. TRAINING_SW_2_REG, (1 << 3), (1 << 3)));
  674. CHECK_STATUS(ddr3_tip_if_write
  675. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  676. TRAINING_SW_1_REG, (1 << 16), (1 << 16)));
  677. /* set ODPG to functional */
  678. CHECK_STATUS(ddr3_tip_if_write
  679. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  680. ODPG_DATA_CTRL_REG, 0x0, MASK_ALL_BITS));
  681. /*
  682. * Copy the result from the effective CS search to the real
  683. * Functional CS
  684. */
  685. ddr3_tip_write_cs_result(dev_num, RL_PHY_REG(0));
  686. CHECK_STATUS(ddr3_tip_if_write
  687. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  688. ODPG_DATA_CTRL_REG, 0x0, MASK_ALL_BITS));
  689. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  690. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  691. /* restore cs enable value */
  692. CHECK_STATUS(ddr3_tip_if_write
  693. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  694. DUAL_DUNIT_CFG_REG, cs_enable_reg_val[if_id],
  695. MASK_ALL_BITS));
  696. if (odt_config != 0) {
  697. CHECK_STATUS(ddr3_tip_write_additional_odt_setting
  698. (dev_num, if_id));
  699. }
  700. }
  701. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  702. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  703. if (training_result[training_stage][if_id] == TEST_FAILED)
  704. return MV_FAIL;
  705. }
  706. return MV_OK;
  707. }
  708. int ddr3_tip_calc_cs_mask(u32 dev_num, u32 if_id, u32 effective_cs,
  709. u32 *cs_mask)
  710. {
  711. u32 all_bus_cs = 0, same_bus_cs;
  712. u32 bus_cnt;
  713. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  714. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  715. *cs_mask = same_bus_cs = CS_BIT_MASK;
  716. /*
  717. * In some of the devices (such as BC2), the CS is per pup and there
  718. * for mixed mode is valid on like other devices where CS configuration
  719. * is per interface.
  720. * In order to know that, we do 'Or' and 'And' operation between all
  721. * CS (of the pups).
  722. * If they are they are not the same then it's mixed mode so all CS
  723. * should be configured (when configuring the MRS)
  724. */
  725. for (bus_cnt = 0; bus_cnt < octets_per_if_num; bus_cnt++) {
  726. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_cnt);
  727. all_bus_cs |= tm->interface_params[if_id].
  728. as_bus_params[bus_cnt].cs_bitmask;
  729. same_bus_cs &= tm->interface_params[if_id].
  730. as_bus_params[bus_cnt].cs_bitmask;
  731. /* cs enable is active low */
  732. *cs_mask &= ~tm->interface_params[if_id].
  733. as_bus_params[bus_cnt].cs_bitmask;
  734. }
  735. if (all_bus_cs == same_bus_cs)
  736. *cs_mask = (*cs_mask | (~(1 << effective_cs))) & CS_BIT_MASK;
  737. return MV_OK;
  738. }
  739. /*
  740. * Dynamic write leveling
  741. */
  742. int ddr3_tip_dynamic_write_leveling(u32 dev_num, int phase_remove)
  743. {
  744. u32 reg_data = 0, temp = 0, iter, if_id, bus_cnt;
  745. u32 cs_enable_reg_val[MAX_INTERFACE_NUM] = { 0 };
  746. u32 cs_mask[MAX_INTERFACE_NUM];
  747. u32 read_data_sample_delay_vals[MAX_INTERFACE_NUM] = { 0 };
  748. u32 read_data_ready_delay_vals[MAX_INTERFACE_NUM] = { 0 };
  749. /* 0 for failure */
  750. u32 res_values[MAX_INTERFACE_NUM * MAX_BUS_NUM] = { 0 };
  751. u32 test_res = 0; /* 0 - success for all pup */
  752. u32 data_read[MAX_INTERFACE_NUM];
  753. u8 wl_values[NUM_OF_CS][MAX_BUS_NUM][MAX_INTERFACE_NUM];
  754. u16 *mask_results_pup_reg_map = ddr3_tip_get_mask_results_pup_reg_map();
  755. u32 cs_mask0[MAX_INTERFACE_NUM] = { 0 };
  756. u32 max_cs = ddr3_tip_max_cs_get(dev_num);
  757. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  758. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  759. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  760. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  761. training_result[training_stage][if_id] = TEST_SUCCESS;
  762. /* save Read Data Sample Delay */
  763. CHECK_STATUS(ddr3_tip_if_read
  764. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  765. RD_DATA_SMPL_DLYS_REG,
  766. read_data_sample_delay_vals, MASK_ALL_BITS));
  767. /* save Read Data Ready Delay */
  768. CHECK_STATUS(ddr3_tip_if_read
  769. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  770. RD_DATA_RDY_DLYS_REG, read_data_ready_delay_vals,
  771. MASK_ALL_BITS));
  772. /* save current cs reg val */
  773. CHECK_STATUS(ddr3_tip_if_read
  774. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  775. DUAL_DUNIT_CFG_REG, cs_enable_reg_val, MASK_ALL_BITS));
  776. }
  777. if (ddr3_tip_dev_attr_get(dev_num, MV_ATTR_TIP_REV) < MV_TIP_REV_3) {
  778. /* Enable multi-CS */
  779. CHECK_STATUS(ddr3_tip_if_write
  780. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  781. DUAL_DUNIT_CFG_REG, 0, (1 << 3)));
  782. }
  783. /*
  784. * Phase 1: DRAM 2 Write Leveling mode
  785. */
  786. /*Assert 10 refresh commands to DRAM to all CS */
  787. for (iter = 0; iter < WL_ITERATION_NUM; iter++) {
  788. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  789. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  790. CHECK_STATUS(ddr3_tip_if_write
  791. (dev_num, ACCESS_TYPE_UNICAST,
  792. if_id, SDRAM_OP_REG,
  793. (u32)((~(0xf) << 8) | 0x2), 0xf1f));
  794. }
  795. }
  796. /* check controller back to normal */
  797. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  798. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  799. if (ddr3_tip_if_polling
  800. (dev_num, ACCESS_TYPE_UNICAST, if_id, 0, 0x1f,
  801. SDRAM_OP_REG, MAX_POLLING_ITERATIONS) != MV_OK) {
  802. DEBUG_LEVELING(DEBUG_LEVEL_ERROR,
  803. ("WL: DDR3 poll failed(3)"));
  804. }
  805. }
  806. for (effective_cs = 0; effective_cs < max_cs; effective_cs++) {
  807. /*enable write leveling to all cs - Q off , WL n */
  808. /* calculate interface cs mask */
  809. CHECK_STATUS(ddr3_tip_write_mrs_cmd(dev_num, cs_mask0, MR_CMD1,
  810. 0x1000, 0x1080));
  811. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  812. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  813. /* cs enable is active low */
  814. ddr3_tip_calc_cs_mask(dev_num, if_id, effective_cs,
  815. &cs_mask[if_id]);
  816. }
  817. if (ddr3_tip_dev_attr_get(dev_num, MV_ATTR_TIP_REV) >= MV_TIP_REV_3) {
  818. /* Enable Output buffer to relevant CS - Q on , WL on */
  819. CHECK_STATUS(ddr3_tip_write_mrs_cmd
  820. (dev_num, cs_mask, MR_CMD1, 0x80, 0x1080));
  821. /*enable odt for relevant CS */
  822. CHECK_STATUS(ddr3_tip_if_write
  823. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  824. 0x1498, (0x3 << (effective_cs * 2)), 0xf));
  825. } else {
  826. /* FIXME: should be the same as _CPU case */
  827. CHECK_STATUS(ddr3_tip_write_mrs_cmd
  828. (dev_num, cs_mask, MR_CMD1, 0xc0, 0x12c4));
  829. }
  830. /*
  831. * Phase 2: Set training IP to write leveling mode
  832. */
  833. CHECK_STATUS(ddr3_tip_dynamic_write_leveling_seq(dev_num));
  834. /* phase 3: trigger training */
  835. mv_ddr_training_enable();
  836. /* check for training done */
  837. if (mv_ddr_is_training_done(MAX_POLLING_ITERATIONS, data_read) != MV_OK) {
  838. DEBUG_LEVELING(DEBUG_LEVEL_ERROR, ("training done failed\n"));
  839. } else { /* check for training pass */
  840. reg_data = data_read[0];
  841. #if defined(CONFIG_ARMADA_38X) /* JIRA #1498 for 16 bit with ECC */
  842. if (tm->bus_act_mask == 0xb) /* set to data to 0 to skip the check */
  843. reg_data = 0;
  844. #endif
  845. if (reg_data != PASS)
  846. DEBUG_LEVELING(DEBUG_LEVEL_INFO, ("training result failed\n"));
  847. /* check for training completion per bus */
  848. for (bus_cnt = 0; bus_cnt < octets_per_if_num; bus_cnt++) {
  849. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_cnt);
  850. /* training status */
  851. ddr3_tip_if_read(0, ACCESS_TYPE_UNICAST, 0,
  852. mask_results_pup_reg_map[bus_cnt],
  853. data_read, MASK_ALL_BITS);
  854. reg_data = data_read[0];
  855. DEBUG_LEVELING(DEBUG_LEVEL_TRACE, ("WL: IF %d BUS %d reg 0x%x\n",
  856. 0, bus_cnt, reg_data));
  857. if ((reg_data & (1 << 25)) == 0)
  858. res_values[bus_cnt] = 1;
  859. ddr3_tip_if_read(0, ACCESS_TYPE_UNICAST, 0,
  860. mask_results_pup_reg_map[bus_cnt],
  861. data_read, 0xff);
  862. /*
  863. * Save the read value that should be
  864. * write to PHY register
  865. */
  866. wl_values[effective_cs][bus_cnt][0] = (u8)data_read[0];
  867. }
  868. }
  869. /*
  870. * Phase 3.5: Validate result
  871. */
  872. for (if_id = 0; if_id < MAX_INTERFACE_NUM; if_id++) {
  873. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  874. for (bus_cnt = 0; bus_cnt < octets_per_if_num; bus_cnt++) {
  875. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_cnt);
  876. /*
  877. * Read result control register according to subphy
  878. * "16" below is for a half-phase
  879. */
  880. reg_data = wl_values[effective_cs][bus_cnt][if_id] + 16;
  881. /*
  882. * Write to WL register: ADLL [4:0], Phase [8:6],
  883. * Centralization ADLL [15:10] + 0x10
  884. */
  885. reg_data = (reg_data & 0x1f) |
  886. (((reg_data & 0xe0) >> 5) << 6) |
  887. (((reg_data & 0x1f) + phy_reg1_val) << 10);
  888. /* Search with WL CS0 subphy reg */
  889. ddr3_tip_bus_write(dev_num, ACCESS_TYPE_UNICAST, if_id,
  890. ACCESS_TYPE_UNICAST, bus_cnt,
  891. DDR_PHY_DATA, WL_PHY_REG(0), reg_data);
  892. /*
  893. * Check for change in data read from DRAM.
  894. * If changed, fix the result
  895. */
  896. CHECK_STATUS(ddr3_tip_if_read
  897. (dev_num,
  898. ACCESS_TYPE_UNICAST,
  899. if_id,
  900. TRAINING_WL_REG,
  901. data_read, MASK_ALL_BITS));
  902. if (((data_read[if_id] & (1 << (bus_cnt + 20))) >>
  903. (bus_cnt + 20)) == 0) {
  904. DEBUG_LEVELING(
  905. DEBUG_LEVEL_ERROR,
  906. ("WLValues was changed from 0x%X",
  907. wl_values[effective_cs]
  908. [bus_cnt][if_id]));
  909. wl_values[effective_cs]
  910. [bus_cnt][if_id] += 32;
  911. DEBUG_LEVELING(
  912. DEBUG_LEVEL_ERROR,
  913. ("to 0x%X",
  914. wl_values[effective_cs]
  915. [bus_cnt][if_id]));
  916. }
  917. }
  918. }
  919. /*
  920. * Phase 4: Exit write leveling mode
  921. */
  922. /* disable DQs toggling */
  923. CHECK_STATUS(ddr3_tip_if_write
  924. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  925. WL_DQS_PATTERN_REG, 0x0, 0x1));
  926. /* Update MRS 1 (WL off) */
  927. if (ddr3_tip_dev_attr_get(dev_num, MV_ATTR_TIP_REV) >= MV_TIP_REV_3) {
  928. CHECK_STATUS(ddr3_tip_write_mrs_cmd(dev_num, cs_mask0, MR_CMD1,
  929. 0x1000, 0x1080));
  930. } else {
  931. /* FIXME: should be same as _CPU case */
  932. CHECK_STATUS(ddr3_tip_write_mrs_cmd(dev_num, cs_mask0, MR_CMD1,
  933. 0x1000, 0x12c4));
  934. }
  935. /* Update MRS 1 (return to functional mode - Q on , WL off) */
  936. CHECK_STATUS(ddr3_tip_write_mrs_cmd
  937. (dev_num, cs_mask0, MR_CMD1, 0x0, 0x1080));
  938. /* set phy to normal mode */
  939. CHECK_STATUS(ddr3_tip_if_write
  940. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  941. TRAINING_SW_2_REG, 0x5, 0x7));
  942. /* exit sw override mode */
  943. CHECK_STATUS(ddr3_tip_if_write
  944. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  945. TRAINING_SW_2_REG, 0x4, 0x7));
  946. }
  947. /*
  948. * Phase 5: Load WL values to each PHY
  949. */
  950. for (effective_cs = 0; effective_cs < max_cs; effective_cs++) {
  951. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  952. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  953. test_res = 0;
  954. for (bus_cnt = 0;
  955. bus_cnt < octets_per_if_num;
  956. bus_cnt++) {
  957. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_cnt);
  958. /* check if result == pass */
  959. if (res_values
  960. [(if_id *
  961. octets_per_if_num) +
  962. bus_cnt] == 0) {
  963. /*
  964. * read result control register
  965. * according to pup
  966. */
  967. reg_data =
  968. wl_values[effective_cs][bus_cnt]
  969. [if_id];
  970. /*
  971. * Write into write leveling register
  972. * ([4:0] ADLL, [8:6] Phase, [15:10]
  973. * (centralization) ADLL + 0x10)
  974. */
  975. reg_data =
  976. (reg_data & 0x1f) |
  977. (((reg_data & 0xe0) >> 5) << 6) |
  978. (((reg_data & 0x1f) +
  979. phy_reg1_val) << 10);
  980. /*
  981. * in case phase remove should be executed
  982. * need to remove more than one phase.
  983. * this will take place only in low frequency,
  984. * where there could be more than one phase between sub-phys
  985. */
  986. if (phase_remove == 1) {
  987. temp = (reg_data >> WR_LVL_PH_SEL_OFFS) & WR_LVL_PH_SEL_PHASE1;
  988. reg_data &= ~(WR_LVL_PH_SEL_MASK << WR_LVL_PH_SEL_OFFS);
  989. reg_data |= (temp << WR_LVL_PH_SEL_OFFS);
  990. }
  991. ddr3_tip_bus_write(
  992. dev_num,
  993. ACCESS_TYPE_UNICAST,
  994. if_id,
  995. ACCESS_TYPE_UNICAST,
  996. bus_cnt,
  997. DDR_PHY_DATA,
  998. WL_PHY_REG(effective_cs),
  999. reg_data);
  1000. } else {
  1001. test_res = 1;
  1002. /*
  1003. * read result control register
  1004. * according to pup
  1005. */
  1006. CHECK_STATUS(ddr3_tip_if_read
  1007. (dev_num,
  1008. ACCESS_TYPE_UNICAST,
  1009. if_id,
  1010. mask_results_pup_reg_map
  1011. [bus_cnt], data_read,
  1012. 0xff));
  1013. reg_data = data_read[if_id];
  1014. DEBUG_LEVELING(
  1015. DEBUG_LEVEL_ERROR,
  1016. ("WL: IF %d BUS %d failed, reg 0x%x\n",
  1017. if_id, bus_cnt, reg_data));
  1018. }
  1019. }
  1020. if (test_res != 0) {
  1021. training_result[training_stage][if_id] =
  1022. TEST_FAILED;
  1023. }
  1024. }
  1025. }
  1026. /* Set to 0 after each loop to avoid illegal value may be used */
  1027. effective_cs = 0;
  1028. /*
  1029. * Copy the result from the effective CS search to the real
  1030. * Functional CS
  1031. */
  1032. /* ddr3_tip_write_cs_result(dev_num, WL_PHY_REG(0); */
  1033. /* restore saved values */
  1034. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  1035. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  1036. /* restore Read Data Sample Delay */
  1037. CHECK_STATUS(ddr3_tip_if_write
  1038. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  1039. RD_DATA_SMPL_DLYS_REG,
  1040. read_data_sample_delay_vals[if_id],
  1041. MASK_ALL_BITS));
  1042. /* restore Read Data Ready Delay */
  1043. CHECK_STATUS(ddr3_tip_if_write
  1044. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  1045. RD_DATA_RDY_DLYS_REG,
  1046. read_data_ready_delay_vals[if_id],
  1047. MASK_ALL_BITS));
  1048. /* enable multi cs */
  1049. CHECK_STATUS(ddr3_tip_if_write
  1050. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  1051. DUAL_DUNIT_CFG_REG, cs_enable_reg_val[if_id],
  1052. MASK_ALL_BITS));
  1053. }
  1054. if (ddr3_tip_dev_attr_get(dev_num, MV_ATTR_TIP_REV) >= MV_TIP_REV_3) {
  1055. /* Disable modt0 for CS0 training - need to adjust for multi-CS
  1056. * in case of ddr4 set 0xf else 0
  1057. */
  1058. if (odt_config != 0) {
  1059. CHECK_STATUS(ddr3_tip_if_write(dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1060. SDRAM_ODT_CTRL_HIGH_REG, 0x0, 0xf));
  1061. }
  1062. else {
  1063. CHECK_STATUS(ddr3_tip_if_write(dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1064. SDRAM_ODT_CTRL_HIGH_REG, 0xf, 0xf));
  1065. }
  1066. }
  1067. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  1068. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  1069. if (training_result[training_stage][if_id] == TEST_FAILED)
  1070. return MV_FAIL;
  1071. }
  1072. return MV_OK;
  1073. }
  1074. /*
  1075. * Dynamic write leveling supplementary
  1076. */
  1077. int ddr3_tip_dynamic_write_leveling_supp(u32 dev_num)
  1078. {
  1079. int adll_offset;
  1080. u32 if_id, bus_id, data, data_tmp;
  1081. int is_if_fail = 0;
  1082. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  1083. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  1084. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  1085. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  1086. is_if_fail = 0;
  1087. for (bus_id = 0; bus_id < octets_per_if_num; bus_id++) {
  1088. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_id);
  1089. wr_supp_res[if_id][bus_id].is_pup_fail = 1;
  1090. CHECK_STATUS(ddr3_tip_bus_read
  1091. (dev_num, if_id, ACCESS_TYPE_UNICAST,
  1092. bus_id, DDR_PHY_DATA,
  1093. CTX_PHY_REG(effective_cs),
  1094. &data));
  1095. DEBUG_LEVELING(
  1096. DEBUG_LEVEL_TRACE,
  1097. ("WL Supp: adll_offset=0 data delay = %d\n",
  1098. data));
  1099. if (ddr3_tip_wl_supp_align_phase_shift
  1100. (dev_num, if_id, bus_id) == MV_OK) {
  1101. DEBUG_LEVELING(
  1102. DEBUG_LEVEL_TRACE,
  1103. ("WL Supp: IF %d bus_id %d adll_offset=0 Success !\n",
  1104. if_id, bus_id));
  1105. continue;
  1106. }
  1107. /* change adll */
  1108. adll_offset = 5;
  1109. CHECK_STATUS(ddr3_tip_bus_write
  1110. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  1111. ACCESS_TYPE_UNICAST, bus_id, DDR_PHY_DATA,
  1112. CTX_PHY_REG(effective_cs),
  1113. data + adll_offset));
  1114. CHECK_STATUS(ddr3_tip_bus_read
  1115. (dev_num, if_id, ACCESS_TYPE_UNICAST,
  1116. bus_id, DDR_PHY_DATA,
  1117. CTX_PHY_REG(effective_cs),
  1118. &data_tmp));
  1119. DEBUG_LEVELING(
  1120. DEBUG_LEVEL_TRACE,
  1121. ("WL Supp: adll_offset= %d data delay = %d\n",
  1122. adll_offset, data_tmp));
  1123. if (ddr3_tip_wl_supp_align_phase_shift
  1124. (dev_num, if_id, bus_id) == MV_OK) {
  1125. DEBUG_LEVELING(
  1126. DEBUG_LEVEL_TRACE,
  1127. ("WL Supp: IF %d bus_id %d adll_offset= %d Success !\n",
  1128. if_id, bus_id, adll_offset));
  1129. continue;
  1130. }
  1131. /* change adll */
  1132. adll_offset = -5;
  1133. CHECK_STATUS(ddr3_tip_bus_write
  1134. (dev_num, ACCESS_TYPE_UNICAST, if_id,
  1135. ACCESS_TYPE_UNICAST, bus_id, DDR_PHY_DATA,
  1136. CTX_PHY_REG(effective_cs),
  1137. data + adll_offset));
  1138. CHECK_STATUS(ddr3_tip_bus_read
  1139. (dev_num, if_id, ACCESS_TYPE_UNICAST,
  1140. bus_id, DDR_PHY_DATA,
  1141. CTX_PHY_REG(effective_cs),
  1142. &data_tmp));
  1143. DEBUG_LEVELING(
  1144. DEBUG_LEVEL_TRACE,
  1145. ("WL Supp: adll_offset= %d data delay = %d\n",
  1146. adll_offset, data_tmp));
  1147. if (ddr3_tip_wl_supp_align_phase_shift
  1148. (dev_num, if_id, bus_id) == MV_OK) {
  1149. DEBUG_LEVELING(
  1150. DEBUG_LEVEL_TRACE,
  1151. ("WL Supp: IF %d bus_id %d adll_offset= %d Success !\n",
  1152. if_id, bus_id, adll_offset));
  1153. continue;
  1154. } else {
  1155. DEBUG_LEVELING(
  1156. DEBUG_LEVEL_ERROR,
  1157. ("WL Supp: IF %d bus_id %d Failed !\n",
  1158. if_id, bus_id));
  1159. is_if_fail = 1;
  1160. }
  1161. }
  1162. if (is_if_fail == 1) {
  1163. DEBUG_LEVELING(DEBUG_LEVEL_ERROR,
  1164. ("WL Supp: CS# %d: IF %d failed\n",
  1165. effective_cs, if_id));
  1166. training_result[training_stage][if_id] = TEST_FAILED;
  1167. } else {
  1168. training_result[training_stage][if_id] = TEST_SUCCESS;
  1169. }
  1170. }
  1171. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  1172. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  1173. if (training_result[training_stage][if_id] == TEST_FAILED)
  1174. return MV_FAIL;
  1175. }
  1176. return MV_OK;
  1177. }
  1178. /*
  1179. * Phase Shift
  1180. */
  1181. static int ddr3_tip_wl_supp_align_phase_shift(u32 dev_num, u32 if_id,
  1182. u32 bus_id)
  1183. {
  1184. u32 original_phase;
  1185. u32 data, write_data;
  1186. wr_supp_res[if_id][bus_id].stage = PHASE_SHIFT;
  1187. if (ddr3_tip_xsb_compare_test
  1188. (dev_num, if_id, bus_id, 0) == MV_OK)
  1189. return MV_OK;
  1190. /* Read current phase */
  1191. CHECK_STATUS(ddr3_tip_bus_read
  1192. (dev_num, if_id, ACCESS_TYPE_UNICAST, bus_id,
  1193. DDR_PHY_DATA, WL_PHY_REG(effective_cs), &data));
  1194. original_phase = (data >> 6) & 0x7;
  1195. /* Set phase (0x0[6-8]) -2 */
  1196. if (original_phase >= 1) {
  1197. if (original_phase == 1)
  1198. write_data = data & ~0x1df;
  1199. else
  1200. write_data = (data & ~0x1c0) |
  1201. ((original_phase - 2) << 6);
  1202. ddr3_tip_bus_write(dev_num, ACCESS_TYPE_UNICAST, if_id,
  1203. ACCESS_TYPE_UNICAST, bus_id, DDR_PHY_DATA,
  1204. WL_PHY_REG(effective_cs), write_data);
  1205. if (ddr3_tip_xsb_compare_test
  1206. (dev_num, if_id, bus_id, -2) == MV_OK)
  1207. return MV_OK;
  1208. }
  1209. /* Set phase (0x0[6-8]) +2 */
  1210. if (original_phase <= 5) {
  1211. write_data = (data & ~0x1c0) |
  1212. ((original_phase + 2) << 6);
  1213. ddr3_tip_bus_write(dev_num, ACCESS_TYPE_UNICAST, if_id,
  1214. ACCESS_TYPE_UNICAST, bus_id, DDR_PHY_DATA,
  1215. WL_PHY_REG(effective_cs), write_data);
  1216. if (ddr3_tip_xsb_compare_test
  1217. (dev_num, if_id, bus_id, 2) == MV_OK)
  1218. return MV_OK;
  1219. }
  1220. /* Set phase (0x0[6-8]) +4 */
  1221. if (original_phase <= 3) {
  1222. write_data = (data & ~0x1c0) |
  1223. ((original_phase + 4) << 6);
  1224. ddr3_tip_bus_write(dev_num, ACCESS_TYPE_UNICAST, if_id,
  1225. ACCESS_TYPE_UNICAST, bus_id, DDR_PHY_DATA,
  1226. WL_PHY_REG(effective_cs), write_data);
  1227. if (ddr3_tip_xsb_compare_test
  1228. (dev_num, if_id, bus_id, 4) == MV_OK)
  1229. return MV_OK;
  1230. }
  1231. /* Set phase (0x0[6-8]) +6 */
  1232. if (original_phase <= 1) {
  1233. write_data = (data & ~0x1c0) |
  1234. ((original_phase + 6) << 6);
  1235. ddr3_tip_bus_write(dev_num, ACCESS_TYPE_UNICAST, if_id,
  1236. ACCESS_TYPE_UNICAST, bus_id, DDR_PHY_DATA,
  1237. WL_PHY_REG(effective_cs), write_data);
  1238. if (ddr3_tip_xsb_compare_test
  1239. (dev_num, if_id, bus_id, 6) == MV_OK)
  1240. return MV_OK;
  1241. }
  1242. /* Write original WL result back */
  1243. ddr3_tip_bus_write(dev_num, ACCESS_TYPE_UNICAST, if_id,
  1244. ACCESS_TYPE_UNICAST, bus_id, DDR_PHY_DATA,
  1245. WL_PHY_REG(effective_cs), data);
  1246. wr_supp_res[if_id][bus_id].is_pup_fail = 1;
  1247. return MV_FAIL;
  1248. }
  1249. /*
  1250. * Compare Test
  1251. */
  1252. static int ddr3_tip_xsb_compare_test(u32 dev_num, u32 if_id, u32 bus_id,
  1253. u32 edge_offset)
  1254. {
  1255. u32 num_of_succ_byte_compare, word_in_pattern;
  1256. u32 word_offset, i, num_of_word_mult;
  1257. u32 read_pattern[TEST_PATTERN_LENGTH * 2];
  1258. struct pattern_info *pattern_table = ddr3_tip_get_pattern_table();
  1259. u32 pattern_test_pattern_table[8];
  1260. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  1261. /* 3 below for INTERFACE_BUS_MASK_16BIT */
  1262. num_of_word_mult = (tm->bus_act_mask == 3) ? 1 : 2;
  1263. for (i = 0; i < 8; i++) {
  1264. pattern_test_pattern_table[i] =
  1265. pattern_table_get_word(dev_num, PATTERN_TEST, (u8)i);
  1266. }
  1267. /* External write, read and compare */
  1268. CHECK_STATUS(ddr3_tip_load_pattern_to_mem(dev_num, PATTERN_TEST));
  1269. CHECK_STATUS(ddr3_tip_reset_fifo_ptr(dev_num));
  1270. CHECK_STATUS(ddr3_tip_ext_read
  1271. (dev_num, if_id,
  1272. ((pattern_table[PATTERN_TEST].start_addr << 3) +
  1273. ((SDRAM_CS_SIZE + 1) * effective_cs)), 1, read_pattern));
  1274. DEBUG_LEVELING(
  1275. DEBUG_LEVEL_TRACE,
  1276. ("XSB-compt CS#%d: IF %d bus_id %d 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x\n",
  1277. effective_cs, if_id, bus_id,
  1278. read_pattern[0], read_pattern[1],
  1279. read_pattern[2], read_pattern[3],
  1280. read_pattern[4], read_pattern[5],
  1281. read_pattern[6], read_pattern[7]));
  1282. /* compare byte per pup */
  1283. num_of_succ_byte_compare = 0;
  1284. for (word_in_pattern = start_xsb_offset;
  1285. word_in_pattern < (TEST_PATTERN_LENGTH * num_of_word_mult);
  1286. word_in_pattern++) {
  1287. word_offset = word_in_pattern;
  1288. if ((word_offset > (TEST_PATTERN_LENGTH * 2 - 1)))
  1289. continue;
  1290. if ((read_pattern[word_in_pattern] & pup_mask_table[bus_id]) ==
  1291. (pattern_test_pattern_table[word_offset] &
  1292. pup_mask_table[bus_id]))
  1293. num_of_succ_byte_compare++;
  1294. }
  1295. if ((TEST_PATTERN_LENGTH * num_of_word_mult - start_xsb_offset) ==
  1296. num_of_succ_byte_compare) {
  1297. wr_supp_res[if_id][bus_id].stage = edge_offset;
  1298. DEBUG_LEVELING(DEBUG_LEVEL_TRACE,
  1299. ("supplementary: shift to %d for if %d pup %d success\n",
  1300. edge_offset, if_id, bus_id));
  1301. wr_supp_res[if_id][bus_id].is_pup_fail = 0;
  1302. return MV_OK;
  1303. } else {
  1304. DEBUG_LEVELING(
  1305. DEBUG_LEVEL_TRACE,
  1306. ("XSB-compt CS#%d: IF %d bus_id %d num_of_succ_byte_compare %d - Fail!\n",
  1307. effective_cs, if_id, bus_id, num_of_succ_byte_compare));
  1308. DEBUG_LEVELING(
  1309. DEBUG_LEVEL_TRACE,
  1310. ("XSB-compt: expected 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x\n",
  1311. pattern_test_pattern_table[0],
  1312. pattern_test_pattern_table[1],
  1313. pattern_test_pattern_table[2],
  1314. pattern_test_pattern_table[3],
  1315. pattern_test_pattern_table[4],
  1316. pattern_test_pattern_table[5],
  1317. pattern_test_pattern_table[6],
  1318. pattern_test_pattern_table[7]));
  1319. DEBUG_LEVELING(
  1320. DEBUG_LEVEL_TRACE,
  1321. ("XSB-compt: recieved 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x 0x%x\n",
  1322. read_pattern[0], read_pattern[1],
  1323. read_pattern[2], read_pattern[3],
  1324. read_pattern[4], read_pattern[5],
  1325. read_pattern[6], read_pattern[7]));
  1326. return MV_FAIL;
  1327. }
  1328. }
  1329. /*
  1330. * Dynamic write leveling sequence
  1331. */
  1332. static int ddr3_tip_dynamic_write_leveling_seq(u32 dev_num)
  1333. {
  1334. u32 bus_id, dq_id;
  1335. u16 *mask_results_pup_reg_map = ddr3_tip_get_mask_results_pup_reg_map();
  1336. u16 *mask_results_dq_reg_map = ddr3_tip_get_mask_results_dq_reg();
  1337. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  1338. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  1339. CHECK_STATUS(ddr3_tip_if_write
  1340. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1341. TRAINING_SW_2_REG, 0x1, 0x5));
  1342. CHECK_STATUS(ddr3_tip_if_write
  1343. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1344. TRAINING_WL_REG, 0x50, 0xff));
  1345. CHECK_STATUS(ddr3_tip_if_write
  1346. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1347. TRAINING_WL_REG, 0x5c, 0xff));
  1348. CHECK_STATUS(ddr3_tip_if_write
  1349. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1350. GENERAL_TRAINING_OPCODE_REG, 0x381b82, 0x3c3faf));
  1351. CHECK_STATUS(ddr3_tip_if_write
  1352. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1353. OPCODE_REG0_REG(1), (0x3 << 25), (0x3ffff << 9)));
  1354. CHECK_STATUS(ddr3_tip_if_write
  1355. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1356. OPCODE_REG1_REG(1), 0x80, 0xffff));
  1357. CHECK_STATUS(ddr3_tip_if_write
  1358. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1359. WL_DONE_CNTR_REF_REG, 0x14, 0xff));
  1360. CHECK_STATUS(ddr3_tip_if_write
  1361. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1362. TRAINING_WL_REG, 0xff5c, 0xffff));
  1363. /* mask PBS */
  1364. for (dq_id = 0; dq_id < MAX_DQ_NUM; dq_id++) {
  1365. CHECK_STATUS(ddr3_tip_if_write
  1366. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1367. mask_results_dq_reg_map[dq_id], 0x1 << 24,
  1368. 0x1 << 24));
  1369. }
  1370. /* Mask all results */
  1371. for (bus_id = 0; bus_id < octets_per_if_num; bus_id++) {
  1372. CHECK_STATUS(ddr3_tip_if_write
  1373. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1374. mask_results_pup_reg_map[bus_id], 0x1 << 24,
  1375. 0x1 << 24));
  1376. }
  1377. /* Unmask only wanted */
  1378. for (bus_id = 0; bus_id < octets_per_if_num; bus_id++) {
  1379. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_id);
  1380. CHECK_STATUS(ddr3_tip_if_write
  1381. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1382. mask_results_pup_reg_map[bus_id], 0, 0x1 << 24));
  1383. }
  1384. CHECK_STATUS(ddr3_tip_if_write
  1385. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1386. WL_DQS_PATTERN_REG, 0x1, 0x1));
  1387. return MV_OK;
  1388. }
  1389. /*
  1390. * Dynamic read leveling sequence
  1391. */
  1392. static int ddr3_tip_dynamic_read_leveling_seq(u32 dev_num)
  1393. {
  1394. u32 bus_id, dq_id;
  1395. u16 *mask_results_pup_reg_map = ddr3_tip_get_mask_results_pup_reg_map();
  1396. u16 *mask_results_dq_reg_map = ddr3_tip_get_mask_results_dq_reg();
  1397. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  1398. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  1399. /* mask PBS */
  1400. for (dq_id = 0; dq_id < MAX_DQ_NUM; dq_id++) {
  1401. CHECK_STATUS(ddr3_tip_if_write
  1402. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1403. mask_results_dq_reg_map[dq_id], 0x1 << 24,
  1404. 0x1 << 24));
  1405. }
  1406. /* Mask all results */
  1407. for (bus_id = 0; bus_id < octets_per_if_num; bus_id++) {
  1408. CHECK_STATUS(ddr3_tip_if_write
  1409. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1410. mask_results_pup_reg_map[bus_id], 0x1 << 24,
  1411. 0x1 << 24));
  1412. }
  1413. /* Unmask only wanted */
  1414. for (bus_id = 0; bus_id < octets_per_if_num; bus_id++) {
  1415. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_id);
  1416. CHECK_STATUS(ddr3_tip_if_write
  1417. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1418. mask_results_pup_reg_map[bus_id], 0, 0x1 << 24));
  1419. }
  1420. return MV_OK;
  1421. }
  1422. /*
  1423. * Dynamic read leveling sequence
  1424. */
  1425. static int ddr3_tip_dynamic_per_bit_read_leveling_seq(u32 dev_num)
  1426. {
  1427. u32 bus_id, dq_id;
  1428. u16 *mask_results_pup_reg_map = ddr3_tip_get_mask_results_pup_reg_map();
  1429. u16 *mask_results_dq_reg_map = ddr3_tip_get_mask_results_dq_reg();
  1430. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  1431. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  1432. /* mask PBS */
  1433. for (dq_id = 0; dq_id < MAX_DQ_NUM; dq_id++) {
  1434. CHECK_STATUS(ddr3_tip_if_write
  1435. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1436. mask_results_dq_reg_map[dq_id], 0x1 << 24,
  1437. 0x1 << 24));
  1438. }
  1439. /* Mask all results */
  1440. for (bus_id = 0; bus_id < octets_per_if_num; bus_id++) {
  1441. CHECK_STATUS(ddr3_tip_if_write
  1442. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1443. mask_results_pup_reg_map[bus_id], 0x1 << 24,
  1444. 0x1 << 24));
  1445. }
  1446. /* Unmask only wanted */
  1447. for (dq_id = 0; dq_id < MAX_DQ_NUM; dq_id++) {
  1448. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, dq_id / 8);
  1449. CHECK_STATUS(ddr3_tip_if_write
  1450. (dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE,
  1451. mask_results_dq_reg_map[dq_id], 0x0 << 24,
  1452. 0x1 << 24));
  1453. }
  1454. return MV_OK;
  1455. }
  1456. /*
  1457. * Print write leveling supplementary results
  1458. */
  1459. int ddr3_tip_print_wl_supp_result(u32 dev_num)
  1460. {
  1461. u32 bus_id = 0, if_id = 0;
  1462. u32 octets_per_if_num = ddr3_tip_dev_attr_get(dev_num, MV_ATTR_OCTET_PER_INTERFACE);
  1463. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  1464. DEBUG_LEVELING(DEBUG_LEVEL_INFO,
  1465. ("I/F0 PUP0 Result[0 - success, 1-fail] ...\n"));
  1466. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  1467. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  1468. for (bus_id = 0; bus_id < octets_per_if_num;
  1469. bus_id++) {
  1470. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_id);
  1471. DEBUG_LEVELING(DEBUG_LEVEL_INFO,
  1472. ("%d ,", wr_supp_res[if_id]
  1473. [bus_id].is_pup_fail));
  1474. }
  1475. }
  1476. DEBUG_LEVELING(
  1477. DEBUG_LEVEL_INFO,
  1478. ("I/F0 PUP0 Stage[0-phase_shift, 1-clock_shift, 2-align_shift] ...\n"));
  1479. for (if_id = 0; if_id <= MAX_INTERFACE_NUM - 1; if_id++) {
  1480. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  1481. for (bus_id = 0; bus_id < octets_per_if_num;
  1482. bus_id++) {
  1483. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, bus_id);
  1484. DEBUG_LEVELING(DEBUG_LEVEL_INFO,
  1485. ("%d ,", wr_supp_res[if_id]
  1486. [bus_id].stage));
  1487. }
  1488. }
  1489. return MV_OK;
  1490. }
  1491. #define RD_FIFO_PTR_LOW_STAT_INDIR_ADDR 0x9a
  1492. #define RD_FIFO_PTR_HIGH_STAT_INDIR_ADDR 0x9b
  1493. /* position of falling dqs edge in fifo; walking 1 */
  1494. #define RD_FIFO_DQS_FALL_EDGE_POS_0 0x1
  1495. #define RD_FIFO_DQS_FALL_EDGE_POS_1 0x2
  1496. #define RD_FIFO_DQS_FALL_EDGE_POS_2 0x4
  1497. #define RD_FIFO_DQS_FALL_EDGE_POS_3 0x8
  1498. #define RD_FIFO_DQS_FALL_EDGE_POS_4 0x10 /* lock */
  1499. /* position of rising dqs edge in fifo; walking 0 */
  1500. #define RD_FIFO_DQS_RISE_EDGE_POS_0 0x1fff
  1501. #define RD_FIFO_DQS_RISE_EDGE_POS_1 0x3ffe
  1502. #define RD_FIFO_DQS_RISE_EDGE_POS_2 0x3ffd
  1503. #define RD_FIFO_DQS_RISE_EDGE_POS_3 0x3ffb
  1504. #define RD_FIFO_DQS_RISE_EDGE_POS_4 0x3ff7 /* lock */
  1505. #define TEST_ADDR 0x8
  1506. #define TAPS_PER_UI 32
  1507. #define UI_PER_RD_SAMPLE 4
  1508. #define TAPS_PER_RD_SAMPLE ((UI_PER_RD_SAMPLE) * (TAPS_PER_UI))
  1509. #define MAX_RD_SAMPLES 32
  1510. #define MAX_RL_VALUE ((MAX_RD_SAMPLES) * (TAPS_PER_RD_SAMPLE))
  1511. #define RD_FIFO_DLY 8
  1512. #define STEP_SIZE 64
  1513. #define RL_JITTER_WIDTH_LMT 20
  1514. #define ADLL_TAPS_IN_CYCLE 64
  1515. enum rl_dqs_burst_state {
  1516. RL_AHEAD = 0,
  1517. RL_INSIDE,
  1518. RL_BEHIND
  1519. };
  1520. int mv_ddr_rl_dqs_burst(u32 dev_num, u32 if_id, u32 freq)
  1521. {
  1522. enum rl_dqs_burst_state rl_state[NUM_OF_CS][MAX_BUS_NUM][MAX_INTERFACE_NUM] = { { {0} } };
  1523. enum hws_ddr_phy subphy_type = DDR_PHY_DATA;
  1524. struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
  1525. int cl_val = tm->interface_params[0].cas_l;
  1526. int rl_adll_val, rl_phase_val, sdr_cycle_incr, rd_sample, rd_ready;
  1527. int final_rd_sample, final_rd_ready;
  1528. int i, subphy_id, step;
  1529. int pass_lock_num = 0;
  1530. int init_pass_lock_num;
  1531. int phase_delta;
  1532. int min_phase, max_phase;
  1533. u32 max_cs = ddr3_tip_max_cs_get(dev_num);
  1534. u32 rl_values[NUM_OF_CS][MAX_BUS_NUM][MAX_INTERFACE_NUM] = { { {0} } };
  1535. u32 rl_min_values[NUM_OF_CS][MAX_BUS_NUM][MAX_INTERFACE_NUM] = { { {0} } };
  1536. u32 rl_max_values[NUM_OF_CS][MAX_BUS_NUM][MAX_INTERFACE_NUM] = { { {0} } };
  1537. u32 rl_val, rl_min_val[NUM_OF_CS], rl_max_val[NUM_OF_CS];
  1538. u32 reg_val_low, reg_val_high;
  1539. u32 reg_val, reg_mask;
  1540. uintptr_t test_addr = TEST_ADDR;
  1541. /* initialization */
  1542. if (ddr3_if_ecc_enabled()) {
  1543. ddr3_tip_if_read(dev_num, ACCESS_TYPE_UNICAST, if_id, TRAINING_SW_2_REG,
  1544. &reg_val, MASK_ALL_BITS);
  1545. reg_mask = (TRAINING_ECC_MUX_MASK << TRAINING_ECC_MUX_OFFS) |
  1546. (TRAINING_SW_OVRD_MASK << TRAINING_SW_OVRD_OFFS);
  1547. reg_val &= ~reg_mask;
  1548. reg_val |= (TRAINING_ECC_MUX_DIS << TRAINING_ECC_MUX_OFFS) |
  1549. (TRAINING_SW_OVRD_ENA << TRAINING_SW_OVRD_OFFS);
  1550. ddr3_tip_if_write(0, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE, TRAINING_SW_2_REG,
  1551. reg_val, MASK_ALL_BITS);
  1552. ddr3_tip_if_read(dev_num, ACCESS_TYPE_UNICAST, if_id, TRAINING_REG,
  1553. &reg_val, MASK_ALL_BITS);
  1554. reg_mask = (TRN_START_MASK << TRN_START_OFFS);
  1555. reg_val &= ~reg_mask;
  1556. reg_val |= TRN_START_ENA << TRN_START_OFFS;
  1557. ddr3_tip_if_write(0, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE, TRAINING_REG,
  1558. reg_val, MASK_ALL_BITS);
  1559. }
  1560. for (effective_cs = 0; effective_cs < max_cs; effective_cs++)
  1561. for (subphy_id = 0; subphy_id < MAX_BUS_NUM; subphy_id++)
  1562. for (if_id = 0; if_id < MAX_INTERFACE_NUM; if_id++)
  1563. if (IS_BUS_ACTIVE(tm->bus_act_mask, subphy_id) == 0)
  1564. pass_lock_num++; /* increment on inactive subphys */
  1565. init_pass_lock_num = pass_lock_num / max_cs;
  1566. for (effective_cs = 0; effective_cs < max_cs; effective_cs++) {
  1567. for (if_id = 0; if_id < MAX_INTERFACE_NUM; if_id++) {
  1568. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  1569. training_result[training_stage][if_id] = TEST_SUCCESS;
  1570. }
  1571. }
  1572. /* search for dqs edges per subphy */
  1573. if_id = 0;
  1574. for (effective_cs = 0; effective_cs < max_cs; effective_cs++) {
  1575. pass_lock_num = init_pass_lock_num;
  1576. ddr3_tip_if_write(0, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE, ODPG_DATA_CTRL_REG,
  1577. effective_cs << ODPG_DATA_CS_OFFS,
  1578. ODPG_DATA_CS_MASK << ODPG_DATA_CS_OFFS);
  1579. rl_min_val[effective_cs] = MAX_RL_VALUE;
  1580. rl_max_val[effective_cs] = 0;
  1581. step = STEP_SIZE;
  1582. for (i = 0; i < MAX_RL_VALUE; i += step) {
  1583. rl_val = 0;
  1584. sdr_cycle_incr = i / TAPS_PER_RD_SAMPLE; /* sdr cycle increment */
  1585. rd_sample = cl_val + 2 * sdr_cycle_incr;
  1586. /* fifo out to in delay in search is constant */
  1587. rd_ready = rd_sample + RD_FIFO_DLY;
  1588. ddr3_tip_if_write(0, ACCESS_TYPE_UNICAST, 0, RD_DATA_SMPL_DLYS_REG,
  1589. rd_sample << RD_SMPL_DLY_CS_OFFS(effective_cs),
  1590. RD_SMPL_DLY_CS_MASK << RD_SMPL_DLY_CS_OFFS(effective_cs));
  1591. ddr3_tip_if_write(0, ACCESS_TYPE_UNICAST, 0, RD_DATA_RDY_DLYS_REG,
  1592. rd_ready << RD_RDY_DLY_CS_OFFS(effective_cs),
  1593. RD_RDY_DLY_CS_MASK << RD_RDY_DLY_CS_OFFS(effective_cs));
  1594. /* one sdr (single data rate) cycle incremented on every four phases of ddr clock */
  1595. sdr_cycle_incr = i % TAPS_PER_RD_SAMPLE;
  1596. rl_adll_val = sdr_cycle_incr % MAX_RD_SAMPLES;
  1597. rl_phase_val = sdr_cycle_incr / MAX_RD_SAMPLES;
  1598. rl_val = ((rl_adll_val & RL_REF_DLY_MASK) << RL_REF_DLY_OFFS) |
  1599. ((rl_phase_val & RL_PH_SEL_MASK) << RL_PH_SEL_OFFS);
  1600. /* write to all subphys (even to not connected or locked) */
  1601. ddr3_tip_bus_write(dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE, ACCESS_TYPE_MULTICAST,
  1602. 0, DDR_PHY_DATA, RL_PHY_REG(effective_cs), rl_val);
  1603. /* reset read fifo assertion */
  1604. ddr3_tip_if_write(dev_num, ACCESS_TYPE_MULTICAST, if_id, SDRAM_CFG_REG,
  1605. DATA_PUP_RD_RESET_ENA << DATA_PUP_RD_RESET_OFFS,
  1606. DATA_PUP_RD_RESET_MASK << DATA_PUP_RD_RESET_OFFS);
  1607. /* reset read fifo deassertion */
  1608. ddr3_tip_if_write(dev_num, ACCESS_TYPE_MULTICAST, if_id, SDRAM_CFG_REG,
  1609. DATA_PUP_RD_RESET_DIS << DATA_PUP_RD_RESET_OFFS,
  1610. DATA_PUP_RD_RESET_MASK << DATA_PUP_RD_RESET_OFFS);
  1611. /* perform one read burst */
  1612. if (MV_DDR_IS_64BIT_DRAM_MODE(tm->bus_act_mask))
  1613. readq(test_addr);
  1614. else
  1615. readl(test_addr);
  1616. /* progress read ptr; decide on rl state per byte */
  1617. for (subphy_id = 0; subphy_id < MAX_BUS_NUM; subphy_id++) {
  1618. if (rl_state[effective_cs][subphy_id][if_id] == RL_BEHIND)
  1619. continue; /* skip locked subphys */
  1620. ddr3_tip_bus_read(dev_num, if_id, ACCESS_TYPE_UNICAST, subphy_id, DDR_PHY_DATA,
  1621. RD_FIFO_PTR_LOW_STAT_INDIR_ADDR, &reg_val_low);
  1622. ddr3_tip_bus_read(dev_num, if_id, ACCESS_TYPE_UNICAST, subphy_id, DDR_PHY_DATA,
  1623. RD_FIFO_PTR_HIGH_STAT_INDIR_ADDR, &reg_val_high);
  1624. DEBUG_LEVELING(DEBUG_LEVEL_TRACE,
  1625. ("%s: cs %d, step %d, subphy %d, state %d, low 0x%04x, high 0x%04x; move to ",
  1626. __func__, effective_cs, i, subphy_id,
  1627. rl_state[effective_cs][subphy_id][if_id],
  1628. reg_val_low, reg_val_high));
  1629. switch (rl_state[effective_cs][subphy_id][if_id]) {
  1630. case RL_AHEAD:
  1631. /* improve search resolution getting closer to the window */
  1632. if (reg_val_low == RD_FIFO_DQS_FALL_EDGE_POS_4 &&
  1633. reg_val_high == RD_FIFO_DQS_RISE_EDGE_POS_4) {
  1634. rl_state[effective_cs][subphy_id][if_id] = RL_INSIDE;
  1635. rl_values[effective_cs][subphy_id][if_id] = i;
  1636. rl_min_values[effective_cs][subphy_id][if_id] = i;
  1637. DEBUG_LEVELING(DEBUG_LEVEL_TRACE,
  1638. ("new state %d\n",
  1639. rl_state[effective_cs][subphy_id][if_id]));
  1640. } else if (reg_val_low == RD_FIFO_DQS_FALL_EDGE_POS_3 &&
  1641. reg_val_high == RD_FIFO_DQS_RISE_EDGE_POS_3) {
  1642. step = (step < 2) ? step : 2;
  1643. } else if (reg_val_low == RD_FIFO_DQS_FALL_EDGE_POS_2 &&
  1644. reg_val_high == RD_FIFO_DQS_RISE_EDGE_POS_2) {
  1645. step = (step < 16) ? step : 16;
  1646. } else if (reg_val_low == RD_FIFO_DQS_FALL_EDGE_POS_1 &&
  1647. reg_val_high == RD_FIFO_DQS_RISE_EDGE_POS_1) {
  1648. step = (step < 32) ? step : 32;
  1649. } else if (reg_val_low == RD_FIFO_DQS_FALL_EDGE_POS_0 &&
  1650. reg_val_high == RD_FIFO_DQS_RISE_EDGE_POS_0) {
  1651. step = (step < 64) ? step : 64;
  1652. } else {
  1653. /* otherwise, step is unchanged */
  1654. }
  1655. break;
  1656. case RL_INSIDE:
  1657. if (reg_val_low == RD_FIFO_DQS_FALL_EDGE_POS_4 &&
  1658. reg_val_high == RD_FIFO_DQS_RISE_EDGE_POS_4) {
  1659. rl_max_values[effective_cs][subphy_id][if_id] = i;
  1660. if ((rl_max_values[effective_cs][subphy_id][if_id] -
  1661. rl_min_values[effective_cs][subphy_id][if_id]) >
  1662. ADLL_TAPS_IN_CYCLE) {
  1663. rl_state[effective_cs][subphy_id][if_id] = RL_BEHIND;
  1664. rl_values[effective_cs][subphy_id][if_id] =
  1665. (i + rl_values[effective_cs][subphy_id][if_id]) / 2;
  1666. pass_lock_num++;
  1667. DEBUG_LEVELING(DEBUG_LEVEL_TRACE,
  1668. ("new lock %d\n", pass_lock_num));
  1669. if (rl_min_val[effective_cs] >
  1670. rl_values[effective_cs][subphy_id][if_id])
  1671. rl_min_val[effective_cs] =
  1672. rl_values[effective_cs][subphy_id][if_id];
  1673. if (rl_max_val[effective_cs] <
  1674. rl_values[effective_cs][subphy_id][if_id])
  1675. rl_max_val[effective_cs] =
  1676. rl_values[effective_cs][subphy_id][if_id];
  1677. step = 2;
  1678. }
  1679. }
  1680. if (reg_val_low != RD_FIFO_DQS_FALL_EDGE_POS_4 ||
  1681. reg_val_high != RD_FIFO_DQS_RISE_EDGE_POS_4) {
  1682. if ((i - rl_values[effective_cs][subphy_id][if_id]) <
  1683. RL_JITTER_WIDTH_LMT) {
  1684. /* inside the jitter; not valid segment */
  1685. rl_state[effective_cs][subphy_id][if_id] = RL_AHEAD;
  1686. DEBUG_LEVELING(DEBUG_LEVEL_TRACE,
  1687. ("new state %d; jitter on mask\n",
  1688. rl_state[effective_cs][subphy_id][if_id]));
  1689. } else { /* finished valid segment */
  1690. rl_state[effective_cs][subphy_id][if_id] = RL_BEHIND;
  1691. rl_values[effective_cs][subphy_id][if_id] =
  1692. (i + rl_values[effective_cs][subphy_id][if_id]) / 2;
  1693. DEBUG_LEVELING(DEBUG_LEVEL_TRACE,
  1694. ("new state %d, solution %d\n",
  1695. rl_state[effective_cs][subphy_id][if_id],
  1696. rl_values[effective_cs][subphy_id][if_id]));
  1697. pass_lock_num++;
  1698. DEBUG_LEVELING(DEBUG_LEVEL_TRACE,
  1699. ("new lock %d\n", pass_lock_num));
  1700. if (rl_min_val[effective_cs] >
  1701. rl_values[effective_cs][subphy_id][if_id])
  1702. rl_min_val[effective_cs] =
  1703. rl_values[effective_cs][subphy_id][if_id];
  1704. if (rl_max_val[effective_cs] <
  1705. rl_values[effective_cs][subphy_id][if_id])
  1706. rl_max_val[effective_cs] =
  1707. rl_values[effective_cs][subphy_id][if_id];
  1708. step = 2;
  1709. }
  1710. }
  1711. break;
  1712. case RL_BEHIND: /* do nothing */
  1713. break;
  1714. }
  1715. DEBUG_LEVELING(DEBUG_LEVEL_TRACE, ("\n"));
  1716. }
  1717. DEBUG_LEVELING(DEBUG_LEVEL_TRACE, ("pass_lock_num %d\n", pass_lock_num));
  1718. /* exit condition */
  1719. if (pass_lock_num == MAX_BUS_NUM)
  1720. break;
  1721. } /* for-loop on i */
  1722. if (pass_lock_num != MAX_BUS_NUM) {
  1723. DEBUG_LEVELING(DEBUG_LEVEL_ERROR,
  1724. ("%s: cs %d, pass_lock_num %d, max_bus_num %d, init_pass_lock_num %d\n",
  1725. __func__, effective_cs, pass_lock_num, MAX_BUS_NUM, init_pass_lock_num));
  1726. for (subphy_id = 0; subphy_id < MAX_BUS_NUM; subphy_id++) {
  1727. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, subphy_id);
  1728. DEBUG_LEVELING(DEBUG_LEVEL_ERROR,
  1729. ("%s: subphy %d %s\n",
  1730. __func__, subphy_id,
  1731. (rl_state[effective_cs][subphy_id][if_id] == RL_BEHIND) ?
  1732. "locked" : "not locked"));
  1733. }
  1734. }
  1735. } /* for-loop on effective_cs */
  1736. /* post-processing read leveling results */
  1737. if_id = 0;
  1738. for (effective_cs = 0; effective_cs < max_cs; effective_cs++) {
  1739. phase_delta = 0;
  1740. i = rl_min_val[effective_cs];
  1741. sdr_cycle_incr = i / TAPS_PER_RD_SAMPLE; /* sdr cycle increment */
  1742. rd_sample = cl_val + 2 * sdr_cycle_incr;
  1743. rd_ready = rd_sample + RD_FIFO_DLY;
  1744. min_phase = (rl_min_val[effective_cs] - (sdr_cycle_incr * TAPS_PER_RD_SAMPLE)) % MAX_RD_SAMPLES;
  1745. max_phase = (rl_max_val[effective_cs] - (sdr_cycle_incr * TAPS_PER_RD_SAMPLE)) % MAX_RD_SAMPLES;
  1746. final_rd_sample = rd_sample;
  1747. final_rd_ready = rd_ready;
  1748. ddr3_tip_if_write(0, ACCESS_TYPE_UNICAST, 0, RD_DATA_SMPL_DLYS_REG,
  1749. rd_sample << RD_SMPL_DLY_CS_OFFS(effective_cs),
  1750. RD_SMPL_DLY_CS_MASK << RD_SMPL_DLY_CS_OFFS(effective_cs));
  1751. ddr3_tip_if_write(0, ACCESS_TYPE_UNICAST, 0, RD_DATA_RDY_DLYS_REG,
  1752. rd_ready << RD_RDY_DLY_CS_OFFS(effective_cs),
  1753. RD_RDY_DLY_CS_MASK << RD_RDY_DLY_CS_OFFS(effective_cs));
  1754. DEBUG_LEVELING(DEBUG_LEVEL_INFO,
  1755. ("%s: cs %d, min phase %d, max phase %d, read sample %d\n",
  1756. __func__, effective_cs, min_phase, max_phase, rd_sample));
  1757. for (subphy_id = 0; subphy_id < MAX_BUS_NUM; subphy_id++) {
  1758. VALIDATE_BUS_ACTIVE(tm->bus_act_mask, subphy_id);
  1759. /* reduce sdr cycle per cs; extract rl adll and phase values */
  1760. i = rl_values[effective_cs][subphy_id][if_id] - (sdr_cycle_incr * TAPS_PER_RD_SAMPLE);
  1761. rl_adll_val = i % MAX_RD_SAMPLES;
  1762. rl_phase_val = i / MAX_RD_SAMPLES;
  1763. rl_phase_val -= phase_delta;
  1764. DEBUG_LEVELING(DEBUG_LEVEL_INFO,
  1765. ("%s: final results: cs %d, subphy %d, read sample %d read ready %d, rl_phase_val %d, rl_adll_val %d\n",
  1766. __func__, effective_cs, subphy_id, final_rd_sample,
  1767. final_rd_ready, rl_phase_val, rl_adll_val));
  1768. rl_val = ((rl_adll_val & RL_REF_DLY_MASK) << RL_REF_DLY_OFFS) |
  1769. ((rl_phase_val & RL_PH_SEL_MASK) << RL_PH_SEL_OFFS);
  1770. ddr3_tip_bus_write(dev_num, ACCESS_TYPE_MULTICAST, PARAM_NOT_CARE, ACCESS_TYPE_UNICAST,
  1771. subphy_id, subphy_type, RL_PHY_REG(effective_cs), rl_val);
  1772. }
  1773. } /* for-loop on effective cs */
  1774. for (if_id = 0; if_id < MAX_INTERFACE_NUM; if_id++) {
  1775. VALIDATE_IF_ACTIVE(tm->if_act_mask, if_id);
  1776. if (odt_config != 0)
  1777. CHECK_STATUS(ddr3_tip_write_additional_odt_setting(dev_num, if_id));
  1778. }
  1779. /* reset read fifo assertion */
  1780. ddr3_tip_if_write(dev_num, ACCESS_TYPE_MULTICAST, if_id, SDRAM_CFG_REG,
  1781. DATA_PUP_RD_RESET_ENA << DATA_PUP_RD_RESET_OFFS,
  1782. DATA_PUP_RD_RESET_MASK << DATA_PUP_RD_RESET_OFFS);
  1783. /* reset read fifo deassertion */
  1784. ddr3_tip_if_write(dev_num, ACCESS_TYPE_MULTICAST, if_id, SDRAM_CFG_REG,
  1785. DATA_PUP_RD_RESET_DIS << DATA_PUP_RD_RESET_OFFS,
  1786. DATA_PUP_RD_RESET_MASK << DATA_PUP_RD_RESET_OFFS);
  1787. return MV_OK;
  1788. }