pf0100_otp.inc 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2014-2016, Toradex AG
  4. */
  5. // Register Output for PF0100 programmer
  6. // Customer: Toradex AG
  7. // Program: Colibri iMX6
  8. // Sample marking:
  9. // Date: 24.07.2015
  10. // Time: 10:52:58
  11. // Generated from Spreadsheet Revision: P1.8
  12. /* sed commands to get from programmer script to struct */
  13. /* sed -e 's/^WRITE_I2C:\(..\):\(..\)/\{pmic_i2c, 0x\1, 0x\2\},/g' -e 's/^DELAY:\([0-9]*\)/\{pmic_delay, 0, \1\},/g' pf0100_otp_Colibri_iMX6.txt > pf0100_otp.inc
  14. sed -i -e 's/^VPGM:ON/\{pmic_vpgm, 0, 1},/g' -e 's/^VPGM:OFF/\{pmic_vpgm, 0, 0},/g' pf0100_otp.inc
  15. sed -i -e 's/^PWRON: HIGH/\{pmic_pwr, 0, 1},/g' -e 's/^PWRON:LOW/\{pmic_pwr, 0, 0},/g' pf0100_otp.inc */
  16. enum { pmic_i2c, pmic_delay, pmic_vpgm, pmic_pwr };
  17. struct pmic_otp_prog_t{
  18. unsigned char cmd;
  19. unsigned char reg;
  20. unsigned short value;
  21. };
  22. struct pmic_otp_prog_t pmic_otp_prog[] = {
  23. {pmic_i2c, 0x7F, 0x01}, // Access FSL EXT Page 1
  24. {pmic_i2c, 0xA0, 0x2B}, // Auto gen from Row94
  25. {pmic_i2c, 0xA1, 0x01}, // Auto gen from Row95
  26. {pmic_i2c, 0xA2, 0x05}, // Auto gen from Row96
  27. {pmic_i2c, 0xA8, 0x2B}, // Auto gen from Row102
  28. {pmic_i2c, 0xA9, 0x02}, // Auto gen from Row103
  29. {pmic_i2c, 0xAA, 0x01}, // Auto gen from Row104
  30. {pmic_i2c, 0xAC, 0x18}, // Auto gen from Row106
  31. {pmic_i2c, 0xAE, 0x01}, // Auto gen from Row108
  32. {pmic_i2c, 0xB0, 0x2C}, // Auto gen from Row110
  33. {pmic_i2c, 0xB1, 0x04}, // Auto gen from Row111
  34. {pmic_i2c, 0xB2, 0x01}, // Auto gen from Row112
  35. {pmic_i2c, 0xB4, 0x2C}, // Auto gen from Row114
  36. {pmic_i2c, 0xB5, 0x04}, // Auto gen from Row115
  37. {pmic_i2c, 0xB6, 0x01}, // Auto gen from Row116
  38. {pmic_i2c, 0xB8, 0x18}, // Auto gen from Row118
  39. {pmic_i2c, 0xBA, 0x01}, // Auto gen from Row120
  40. {pmic_i2c, 0xBD, 0x0E}, // Auto gen from Row123
  41. {pmic_i2c, 0xC0, 0x06}, // Auto gen from Row126
  42. {pmic_i2c, 0xC4, 0x04}, // Auto gen from Row130
  43. {pmic_i2c, 0xC8, 0x0E}, // Auto gen from Row134
  44. {pmic_i2c, 0xCC, 0x0E}, // Auto gen from Row138
  45. {pmic_i2c, 0xCD, 0x05}, // Auto gen from Row139
  46. {pmic_i2c, 0xD0, 0x0C}, // Auto gen from Row142
  47. {pmic_i2c, 0xD5, 0x07}, // Auto gen from Row147
  48. {pmic_i2c, 0xD8, 0x07}, // Auto gen from Row150
  49. {pmic_i2c, 0xD9, 0x06}, // Auto gen from Row151
  50. {pmic_i2c, 0xDC, 0x0A}, // Auto gen from Row154
  51. {pmic_i2c, 0xDD, 0x03}, // Auto gen from Row155
  52. {pmic_i2c, 0xE0, 0x05}, // Auto gen from Row158
  53. #if 0 /* TBB mode */
  54. {pmic_i2c, 0xE4, 0x80}, // TBB_POR = 1
  55. {pmic_delay, 0, 10},
  56. #else
  57. // Write OTP
  58. {pmic_i2c, 0xE4, 0x02}, // FUSE POR1=1
  59. {pmic_i2c, 0xE5, 0x02}, // FUSE POR2=1
  60. {pmic_i2c, 0xE6, 0x02}, // FUSE POR3=1
  61. {pmic_i2c, 0xF0, 0x1F}, // Enable ECC for fuse banks 1 to 5 by writing to OTP EN ECC0 register
  62. {pmic_i2c, 0xF1, 0x1F}, // Enable ECC for fuse banks 6 to 10 by writing to OTP EN ECC1 register
  63. {pmic_i2c, 0x7F, 0x02}, // Access PF0100 EXT Page2
  64. {pmic_i2c, 0xD0, 0x1F}, // Set Auto ECC for fuse banks 1 to 5 by writing to OTP AUTO ECC0 register
  65. {pmic_i2c, 0xD1, 0x1F}, // Set Auto ECC for fuse banks 6 to 10 by writing to OTP AUTO ECC1 register
  66. //-----------------------------------------------------------------------------------
  67. {pmic_i2c, 0xF1, 0x00}, // Reset Bank 1 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  68. {pmic_i2c, 0xF2, 0x00}, // Reset Bank 2 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  69. {pmic_i2c, 0xF3, 0x00}, // Reset Bank 3 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  70. {pmic_i2c, 0xF4, 0x00}, // Reset Bank 4 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  71. {pmic_i2c, 0xF5, 0x00}, // Reset Bank 5 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  72. {pmic_i2c, 0xF6, 0x00}, // Reset Bank 6 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  73. {pmic_i2c, 0xF7, 0x00}, // Reset Bank 7 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  74. {pmic_i2c, 0xF8, 0x00}, // Reset Bank 8 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  75. {pmic_i2c, 0xF9, 0x00}, // Reset Bank 9 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  76. {pmic_i2c, 0xFA, 0x00}, // Reset Bank 10 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  77. //-----------------------------------------------------------------------------------
  78. {pmic_vpgm, 0, 1}, // Turn ON 8V SWBST
  79. //VPGM:DOWN:n
  80. //VPGM:UP:n
  81. {pmic_delay, 0, 500}, // Adds 500msec delay to allow VPGM time to ramp up
  82. //-----------------------------------------------------------------------------------
  83. // PF0100 OTP MANUAL-PROGRAMMING (BANK 1 thru 10)
  84. //-----------------------------------------------------------------------------------
  85. // BANK 1
  86. //-----------------------------------------------------------------------------------
  87. {pmic_i2c, 0xF1, 0x00}, // Reset Bank 1 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  88. {pmic_i2c, 0xF1, 0x03}, // Set Bank 1 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  89. {pmic_i2c, 0xF1, 0x0B}, // Set Bank 1 ANTIFUSE_EN
  90. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  91. {pmic_i2c, 0xF1, 0x03}, // Reset Bank 1 ANTIFUSE_EN
  92. {pmic_i2c, 0xF1, 0x00}, // Reset Bank 1 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  93. //-----------------------------------------------------------------------------------
  94. // BANK 2
  95. //-----------------------------------------------------------------------------------
  96. {pmic_i2c, 0xF2, 0x00}, // Reset Bank 2 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  97. {pmic_i2c, 0xF2, 0x03}, // Set Bank 2 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  98. {pmic_i2c, 0xF2, 0x0B}, // Set Bank 2 ANTIFUSE_EN
  99. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  100. {pmic_i2c, 0xF2, 0x03}, // Reset Bank 2 ANTIFUSE_EN
  101. {pmic_i2c, 0xF2, 0x00}, // Reset Bank 2 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  102. //-----------------------------------------------------------------------------------
  103. // BANK 3
  104. //-----------------------------------------------------------------------------------
  105. {pmic_i2c, 0xF3, 0x00}, // Reset Bank 3 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  106. {pmic_i2c, 0xF3, 0x03}, // Set Bank 3 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  107. {pmic_i2c, 0xF3, 0x0B}, // Set Bank 3 ANTIFUSE_EN
  108. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  109. {pmic_i2c, 0xF3, 0x03}, // Reset Bank 3 ANTIFUSE_EN
  110. {pmic_i2c, 0xF3, 0x00}, // Reset Bank 3 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  111. //-----------------------------------------------------------------------------------
  112. // BANK 4
  113. //-----------------------------------------------------------------------------------
  114. {pmic_i2c, 0xF4, 0x00}, // Reset Bank 4 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  115. {pmic_i2c, 0xF4, 0x03}, // Set Bank 4 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  116. {pmic_i2c, 0xF4, 0x0B}, // Set Bank 4 ANTIFUSE_EN
  117. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  118. {pmic_i2c, 0xF4, 0x03}, // Reset Bank 4 ANTIFUSE_EN
  119. {pmic_i2c, 0xF4, 0x00}, // Reset Bank 4 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  120. //-----------------------------------------------------------------------------------
  121. // BANK 5
  122. //-----------------------------------------------------------------------------------
  123. {pmic_i2c, 0xF5, 0x00}, // Reset Bank 5 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  124. {pmic_i2c, 0xF5, 0x03}, // Set Bank 5 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  125. {pmic_i2c, 0xF5, 0x0B}, // Set Bank 5 ANTIFUSE_EN
  126. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  127. {pmic_i2c, 0xF5, 0x03}, // Reset Bank 5 ANTIFUSE_EN
  128. {pmic_i2c, 0xF5, 0x00}, // Reset Bank 5 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  129. //-----------------------------------------------------------------------------------
  130. // BANK 6
  131. //-----------------------------------------------------------------------------------
  132. {pmic_i2c, 0xF6, 0x00}, // Reset Bank 6 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  133. {pmic_i2c, 0xF6, 0x03}, // Set Bank 6 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  134. {pmic_i2c, 0xF6, 0x0B}, // Set Bank 6 ANTIFUSE_EN
  135. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  136. {pmic_i2c, 0xF6, 0x03}, // Reset Bank 6 ANTIFUSE_EN
  137. {pmic_i2c, 0xF6, 0x00}, // Reset Bank 6 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  138. //-----------------------------------------------------------------------------------
  139. // BANK 7
  140. //-----------------------------------------------------------------------------------
  141. {pmic_i2c, 0xF7, 0x00}, // Reset Bank 7 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  142. {pmic_i2c, 0xF7, 0x03}, // Set Bank 7 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  143. {pmic_i2c, 0xF7, 0x0B}, // Set Bank 7 ANTIFUSE_EN
  144. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  145. {pmic_i2c, 0xF7, 0x03}, // Reset Bank 7 ANTIFUSE_EN
  146. {pmic_i2c, 0xF7, 0x00}, // Reset Bank 7 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  147. //-----------------------------------------------------------------------------------
  148. // BANK 8
  149. //-----------------------------------------------------------------------------------
  150. {pmic_i2c, 0xF8, 0x00}, // Reset Bank 8 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  151. {pmic_i2c, 0xF8, 0x03}, // Set Bank 8 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  152. {pmic_i2c, 0xF8, 0x0B}, // Set Bank 8 ANTIFUSE_EN
  153. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  154. {pmic_i2c, 0xF8, 0x03}, // Reset Bank 8 ANTIFUSE_EN
  155. {pmic_i2c, 0xF8, 0x00}, // Reset Bank 8 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  156. //-----------------------------------------------------------------------------------
  157. // BANK 9
  158. //-----------------------------------------------------------------------------------
  159. {pmic_i2c, 0xF9, 0x00}, // Reset Bank 9 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  160. {pmic_i2c, 0xF9, 0x03}, // Set Bank 9 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  161. {pmic_i2c, 0xF9, 0x0B}, // Set Bank 9 ANTIFUSE_EN
  162. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  163. {pmic_i2c, 0xF9, 0x03}, // Reset Bank 9 ANTIFUSE_EN
  164. {pmic_i2c, 0xF9, 0x00}, // Reset Bank 9 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  165. //-----------------------------------------------------------------------------------
  166. // BANK 10
  167. //-----------------------------------------------------------------------------------
  168. {pmic_i2c, 0xFA, 0x00}, // Reset Bank 10 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  169. {pmic_i2c, 0xFA, 0x03}, // Set Bank 10 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  170. {pmic_i2c, 0xFA, 0x0B}, // Set Bank 10 ANTIFUSE_EN
  171. {pmic_delay, 0, 10}, // Allow time for bank programming to complete
  172. {pmic_i2c, 0xFA, 0x03}, // Reset Bank 10 ANTIFUSE_EN
  173. {pmic_i2c, 0xFA, 0x00}, // Reset Bank 10 ANTIFUSE_RW and ANTIFUSE_BYPASS bits
  174. //-----------------------------------------------------------------------------------
  175. {pmic_vpgm, 0, 0}, // Turn off 8V SWBST
  176. {pmic_delay, 0, 500}, // Adds delay to allow VPGM to bleed off
  177. {pmic_i2c, 0xD0, 0x00}, // Clear
  178. {pmic_i2c, 0xD1, 0x00}, // Clear
  179. {pmic_pwr, 0, 0}, // PWRON LOW to reload new OTP data
  180. {pmic_delay, 0, 500},
  181. {pmic_pwr, 0, 1},
  182. #endif
  183. };