stm32f7_i2c.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (C) Copyright 2017 STMicroelectronics
  4. */
  5. #include <common.h>
  6. #include <clk.h>
  7. #include <dm.h>
  8. #include <i2c.h>
  9. #include <reset.h>
  10. #include <dm/device.h>
  11. #include <linux/io.h>
  12. /* STM32 I2C registers */
  13. struct stm32_i2c_regs {
  14. u32 cr1; /* I2C control register 1 */
  15. u32 cr2; /* I2C control register 2 */
  16. u32 oar1; /* I2C own address 1 register */
  17. u32 oar2; /* I2C own address 2 register */
  18. u32 timingr; /* I2C timing register */
  19. u32 timeoutr; /* I2C timeout register */
  20. u32 isr; /* I2C interrupt and status register */
  21. u32 icr; /* I2C interrupt clear register */
  22. u32 pecr; /* I2C packet error checking register */
  23. u32 rxdr; /* I2C receive data register */
  24. u32 txdr; /* I2C transmit data register */
  25. };
  26. #define STM32_I2C_CR1 0x00
  27. #define STM32_I2C_CR2 0x04
  28. #define STM32_I2C_TIMINGR 0x10
  29. #define STM32_I2C_ISR 0x18
  30. #define STM32_I2C_ICR 0x1C
  31. #define STM32_I2C_RXDR 0x24
  32. #define STM32_I2C_TXDR 0x28
  33. /* STM32 I2C control 1 */
  34. #define STM32_I2C_CR1_ANFOFF BIT(12)
  35. #define STM32_I2C_CR1_ERRIE BIT(7)
  36. #define STM32_I2C_CR1_TCIE BIT(6)
  37. #define STM32_I2C_CR1_STOPIE BIT(5)
  38. #define STM32_I2C_CR1_NACKIE BIT(4)
  39. #define STM32_I2C_CR1_ADDRIE BIT(3)
  40. #define STM32_I2C_CR1_RXIE BIT(2)
  41. #define STM32_I2C_CR1_TXIE BIT(1)
  42. #define STM32_I2C_CR1_PE BIT(0)
  43. /* STM32 I2C control 2 */
  44. #define STM32_I2C_CR2_AUTOEND BIT(25)
  45. #define STM32_I2C_CR2_RELOAD BIT(24)
  46. #define STM32_I2C_CR2_NBYTES_MASK GENMASK(23, 16)
  47. #define STM32_I2C_CR2_NBYTES(n) ((n & 0xff) << 16)
  48. #define STM32_I2C_CR2_NACK BIT(15)
  49. #define STM32_I2C_CR2_STOP BIT(14)
  50. #define STM32_I2C_CR2_START BIT(13)
  51. #define STM32_I2C_CR2_HEAD10R BIT(12)
  52. #define STM32_I2C_CR2_ADD10 BIT(11)
  53. #define STM32_I2C_CR2_RD_WRN BIT(10)
  54. #define STM32_I2C_CR2_SADD10_MASK GENMASK(9, 0)
  55. #define STM32_I2C_CR2_SADD10(n) (n & STM32_I2C_CR2_SADD10_MASK)
  56. #define STM32_I2C_CR2_SADD7_MASK GENMASK(7, 1)
  57. #define STM32_I2C_CR2_SADD7(n) ((n & 0x7f) << 1)
  58. #define STM32_I2C_CR2_RESET_MASK (STM32_I2C_CR2_HEAD10R \
  59. | STM32_I2C_CR2_NBYTES_MASK \
  60. | STM32_I2C_CR2_SADD7_MASK \
  61. | STM32_I2C_CR2_RELOAD \
  62. | STM32_I2C_CR2_RD_WRN)
  63. /* STM32 I2C Interrupt Status */
  64. #define STM32_I2C_ISR_BUSY BIT(15)
  65. #define STM32_I2C_ISR_ARLO BIT(9)
  66. #define STM32_I2C_ISR_BERR BIT(8)
  67. #define STM32_I2C_ISR_TCR BIT(7)
  68. #define STM32_I2C_ISR_TC BIT(6)
  69. #define STM32_I2C_ISR_STOPF BIT(5)
  70. #define STM32_I2C_ISR_NACKF BIT(4)
  71. #define STM32_I2C_ISR_ADDR BIT(3)
  72. #define STM32_I2C_ISR_RXNE BIT(2)
  73. #define STM32_I2C_ISR_TXIS BIT(1)
  74. #define STM32_I2C_ISR_TXE BIT(0)
  75. #define STM32_I2C_ISR_ERRORS (STM32_I2C_ISR_BERR \
  76. | STM32_I2C_ISR_ARLO)
  77. /* STM32 I2C Interrupt Clear */
  78. #define STM32_I2C_ICR_ARLOCF BIT(9)
  79. #define STM32_I2C_ICR_BERRCF BIT(8)
  80. #define STM32_I2C_ICR_STOPCF BIT(5)
  81. #define STM32_I2C_ICR_NACKCF BIT(4)
  82. /* STM32 I2C Timing */
  83. #define STM32_I2C_TIMINGR_PRESC(n) ((n & 0xf) << 28)
  84. #define STM32_I2C_TIMINGR_SCLDEL(n) ((n & 0xf) << 20)
  85. #define STM32_I2C_TIMINGR_SDADEL(n) ((n & 0xf) << 16)
  86. #define STM32_I2C_TIMINGR_SCLH(n) ((n & 0xff) << 8)
  87. #define STM32_I2C_TIMINGR_SCLL(n) (n & 0xff)
  88. #define STM32_I2C_MAX_LEN 0xff
  89. #define STM32_I2C_DNF_DEFAULT 0
  90. #define STM32_I2C_DNF_MAX 16
  91. #define STM32_I2C_ANALOG_FILTER_ENABLE 1
  92. #define STM32_I2C_ANALOG_FILTER_DELAY_MIN 50 /* ns */
  93. #define STM32_I2C_ANALOG_FILTER_DELAY_MAX 260 /* ns */
  94. #define STM32_I2C_RISE_TIME_DEFAULT 25 /* ns */
  95. #define STM32_I2C_FALL_TIME_DEFAULT 10 /* ns */
  96. #define STM32_PRESC_MAX BIT(4)
  97. #define STM32_SCLDEL_MAX BIT(4)
  98. #define STM32_SDADEL_MAX BIT(4)
  99. #define STM32_SCLH_MAX BIT(8)
  100. #define STM32_SCLL_MAX BIT(8)
  101. #define STM32_NSEC_PER_SEC 1000000000L
  102. #define STANDARD_RATE 100000
  103. #define FAST_RATE 400000
  104. #define FAST_PLUS_RATE 1000000
  105. enum stm32_i2c_speed {
  106. STM32_I2C_SPEED_STANDARD, /* 100 kHz */
  107. STM32_I2C_SPEED_FAST, /* 400 kHz */
  108. STM32_I2C_SPEED_FAST_PLUS, /* 1 MHz */
  109. STM32_I2C_SPEED_END,
  110. };
  111. /**
  112. * struct stm32_i2c_spec - private i2c specification timing
  113. * @rate: I2C bus speed (Hz)
  114. * @rate_min: 80% of I2C bus speed (Hz)
  115. * @rate_max: 120% of I2C bus speed (Hz)
  116. * @fall_max: Max fall time of both SDA and SCL signals (ns)
  117. * @rise_max: Max rise time of both SDA and SCL signals (ns)
  118. * @hddat_min: Min data hold time (ns)
  119. * @vddat_max: Max data valid time (ns)
  120. * @sudat_min: Min data setup time (ns)
  121. * @l_min: Min low period of the SCL clock (ns)
  122. * @h_min: Min high period of the SCL clock (ns)
  123. */
  124. struct stm32_i2c_spec {
  125. u32 rate;
  126. u32 rate_min;
  127. u32 rate_max;
  128. u32 fall_max;
  129. u32 rise_max;
  130. u32 hddat_min;
  131. u32 vddat_max;
  132. u32 sudat_min;
  133. u32 l_min;
  134. u32 h_min;
  135. };
  136. /**
  137. * struct stm32_i2c_setup - private I2C timing setup parameters
  138. * @speed: I2C speed mode (standard, Fast Plus)
  139. * @speed_freq: I2C speed frequency (Hz)
  140. * @clock_src: I2C clock source frequency (Hz)
  141. * @rise_time: Rise time (ns)
  142. * @fall_time: Fall time (ns)
  143. * @dnf: Digital filter coefficient (0-16)
  144. * @analog_filter: Analog filter delay (On/Off)
  145. */
  146. struct stm32_i2c_setup {
  147. enum stm32_i2c_speed speed;
  148. u32 speed_freq;
  149. u32 clock_src;
  150. u32 rise_time;
  151. u32 fall_time;
  152. u8 dnf;
  153. bool analog_filter;
  154. };
  155. /**
  156. * struct stm32_i2c_timings - private I2C output parameters
  157. * @prec: Prescaler value
  158. * @scldel: Data setup time
  159. * @sdadel: Data hold time
  160. * @sclh: SCL high period (master mode)
  161. * @sclh: SCL low period (master mode)
  162. */
  163. struct stm32_i2c_timings {
  164. struct list_head node;
  165. u8 presc;
  166. u8 scldel;
  167. u8 sdadel;
  168. u8 sclh;
  169. u8 scll;
  170. };
  171. struct stm32_i2c_priv {
  172. struct stm32_i2c_regs *regs;
  173. struct clk clk;
  174. struct stm32_i2c_setup *setup;
  175. int speed;
  176. };
  177. static struct stm32_i2c_spec i2c_specs[] = {
  178. [STM32_I2C_SPEED_STANDARD] = {
  179. .rate = STANDARD_RATE,
  180. .rate_min = 8000,
  181. .rate_max = 120000,
  182. .fall_max = 300,
  183. .rise_max = 1000,
  184. .hddat_min = 0,
  185. .vddat_max = 3450,
  186. .sudat_min = 250,
  187. .l_min = 4700,
  188. .h_min = 4000,
  189. },
  190. [STM32_I2C_SPEED_FAST] = {
  191. .rate = FAST_RATE,
  192. .rate_min = 320000,
  193. .rate_max = 480000,
  194. .fall_max = 300,
  195. .rise_max = 300,
  196. .hddat_min = 0,
  197. .vddat_max = 900,
  198. .sudat_min = 100,
  199. .l_min = 1300,
  200. .h_min = 600,
  201. },
  202. [STM32_I2C_SPEED_FAST_PLUS] = {
  203. .rate = FAST_PLUS_RATE,
  204. .rate_min = 800000,
  205. .rate_max = 1200000,
  206. .fall_max = 100,
  207. .rise_max = 120,
  208. .hddat_min = 0,
  209. .vddat_max = 450,
  210. .sudat_min = 50,
  211. .l_min = 500,
  212. .h_min = 260,
  213. },
  214. };
  215. static struct stm32_i2c_setup stm32f7_setup = {
  216. .rise_time = STM32_I2C_RISE_TIME_DEFAULT,
  217. .fall_time = STM32_I2C_FALL_TIME_DEFAULT,
  218. .dnf = STM32_I2C_DNF_DEFAULT,
  219. .analog_filter = STM32_I2C_ANALOG_FILTER_ENABLE,
  220. };
  221. static int stm32_i2c_check_device_busy(struct stm32_i2c_priv *i2c_priv)
  222. {
  223. struct stm32_i2c_regs *regs = i2c_priv->regs;
  224. u32 status = readl(&regs->isr);
  225. if (status & STM32_I2C_ISR_BUSY)
  226. return -EBUSY;
  227. return 0;
  228. }
  229. static void stm32_i2c_message_start(struct stm32_i2c_priv *i2c_priv,
  230. struct i2c_msg *msg, bool stop)
  231. {
  232. struct stm32_i2c_regs *regs = i2c_priv->regs;
  233. u32 cr2 = readl(&regs->cr2);
  234. /* Set transfer direction */
  235. cr2 &= ~STM32_I2C_CR2_RD_WRN;
  236. if (msg->flags & I2C_M_RD)
  237. cr2 |= STM32_I2C_CR2_RD_WRN;
  238. /* Set slave address */
  239. cr2 &= ~(STM32_I2C_CR2_HEAD10R | STM32_I2C_CR2_ADD10);
  240. if (msg->flags & I2C_M_TEN) {
  241. cr2 &= ~STM32_I2C_CR2_SADD10_MASK;
  242. cr2 |= STM32_I2C_CR2_SADD10(msg->addr);
  243. cr2 |= STM32_I2C_CR2_ADD10;
  244. } else {
  245. cr2 &= ~STM32_I2C_CR2_SADD7_MASK;
  246. cr2 |= STM32_I2C_CR2_SADD7(msg->addr);
  247. }
  248. /* Set nb bytes to transfer and reload or autoend bits */
  249. cr2 &= ~(STM32_I2C_CR2_NBYTES_MASK | STM32_I2C_CR2_RELOAD |
  250. STM32_I2C_CR2_AUTOEND);
  251. if (msg->len > STM32_I2C_MAX_LEN) {
  252. cr2 |= STM32_I2C_CR2_NBYTES(STM32_I2C_MAX_LEN);
  253. cr2 |= STM32_I2C_CR2_RELOAD;
  254. } else {
  255. cr2 |= STM32_I2C_CR2_NBYTES(msg->len);
  256. }
  257. /* Write configurations register */
  258. writel(cr2, &regs->cr2);
  259. /* START/ReSTART generation */
  260. setbits_le32(&regs->cr2, STM32_I2C_CR2_START);
  261. }
  262. /*
  263. * RELOAD mode must be selected if total number of data bytes to be
  264. * sent is greater than MAX_LEN
  265. */
  266. static void stm32_i2c_handle_reload(struct stm32_i2c_priv *i2c_priv,
  267. struct i2c_msg *msg, bool stop)
  268. {
  269. struct stm32_i2c_regs *regs = i2c_priv->regs;
  270. u32 cr2 = readl(&regs->cr2);
  271. cr2 &= ~STM32_I2C_CR2_NBYTES_MASK;
  272. if (msg->len > STM32_I2C_MAX_LEN) {
  273. cr2 |= STM32_I2C_CR2_NBYTES(STM32_I2C_MAX_LEN);
  274. } else {
  275. cr2 &= ~STM32_I2C_CR2_RELOAD;
  276. cr2 |= STM32_I2C_CR2_NBYTES(msg->len);
  277. }
  278. writel(cr2, &regs->cr2);
  279. }
  280. static int stm32_i2c_wait_flags(struct stm32_i2c_priv *i2c_priv,
  281. u32 flags, u32 *status)
  282. {
  283. struct stm32_i2c_regs *regs = i2c_priv->regs;
  284. u32 time_start = get_timer(0);
  285. *status = readl(&regs->isr);
  286. while (!(*status & flags)) {
  287. if (get_timer(time_start) > CONFIG_SYS_HZ) {
  288. debug("%s: i2c timeout\n", __func__);
  289. return -ETIMEDOUT;
  290. }
  291. *status = readl(&regs->isr);
  292. }
  293. return 0;
  294. }
  295. static int stm32_i2c_check_end_of_message(struct stm32_i2c_priv *i2c_priv)
  296. {
  297. struct stm32_i2c_regs *regs = i2c_priv->regs;
  298. u32 mask = STM32_I2C_ISR_ERRORS | STM32_I2C_ISR_NACKF |
  299. STM32_I2C_ISR_STOPF;
  300. u32 status;
  301. int ret;
  302. ret = stm32_i2c_wait_flags(i2c_priv, mask, &status);
  303. if (ret)
  304. return ret;
  305. if (status & STM32_I2C_ISR_BERR) {
  306. debug("%s: Bus error\n", __func__);
  307. /* Clear BERR flag */
  308. setbits_le32(&regs->icr, STM32_I2C_ICR_BERRCF);
  309. return -EIO;
  310. }
  311. if (status & STM32_I2C_ISR_ARLO) {
  312. debug("%s: Arbitration lost\n", __func__);
  313. /* Clear ARLO flag */
  314. setbits_le32(&regs->icr, STM32_I2C_ICR_ARLOCF);
  315. return -EAGAIN;
  316. }
  317. if (status & STM32_I2C_ISR_NACKF) {
  318. debug("%s: Receive NACK\n", __func__);
  319. /* Clear NACK flag */
  320. setbits_le32(&regs->icr, STM32_I2C_ICR_NACKCF);
  321. /* Wait until STOPF flag is set */
  322. mask = STM32_I2C_ISR_STOPF;
  323. ret = stm32_i2c_wait_flags(i2c_priv, mask, &status);
  324. if (ret)
  325. return ret;
  326. ret = -EIO;
  327. }
  328. if (status & STM32_I2C_ISR_STOPF) {
  329. /* Clear STOP flag */
  330. setbits_le32(&regs->icr, STM32_I2C_ICR_STOPCF);
  331. /* Clear control register 2 */
  332. setbits_le32(&regs->cr2, STM32_I2C_CR2_RESET_MASK);
  333. }
  334. return ret;
  335. }
  336. static int stm32_i2c_message_xfer(struct stm32_i2c_priv *i2c_priv,
  337. struct i2c_msg *msg, bool stop)
  338. {
  339. struct stm32_i2c_regs *regs = i2c_priv->regs;
  340. u32 status;
  341. u32 mask = msg->flags & I2C_M_RD ? STM32_I2C_ISR_RXNE :
  342. STM32_I2C_ISR_TXIS | STM32_I2C_ISR_NACKF;
  343. int bytes_to_rw = msg->len > STM32_I2C_MAX_LEN ?
  344. STM32_I2C_MAX_LEN : msg->len;
  345. int ret = 0;
  346. /* Add errors */
  347. mask |= STM32_I2C_ISR_ERRORS;
  348. stm32_i2c_message_start(i2c_priv, msg, stop);
  349. while (msg->len) {
  350. /*
  351. * Wait until TXIS/NACKF/BERR/ARLO flags or
  352. * RXNE/BERR/ARLO flags are set
  353. */
  354. ret = stm32_i2c_wait_flags(i2c_priv, mask, &status);
  355. if (ret)
  356. break;
  357. if (status & (STM32_I2C_ISR_NACKF | STM32_I2C_ISR_ERRORS))
  358. break;
  359. if (status & STM32_I2C_ISR_RXNE) {
  360. *msg->buf++ = readb(&regs->rxdr);
  361. msg->len--;
  362. bytes_to_rw--;
  363. }
  364. if (status & STM32_I2C_ISR_TXIS) {
  365. writeb(*msg->buf++, &regs->txdr);
  366. msg->len--;
  367. bytes_to_rw--;
  368. }
  369. if (!bytes_to_rw && msg->len) {
  370. /* Wait until TCR flag is set */
  371. mask = STM32_I2C_ISR_TCR;
  372. ret = stm32_i2c_wait_flags(i2c_priv, mask, &status);
  373. if (ret)
  374. break;
  375. bytes_to_rw = msg->len > STM32_I2C_MAX_LEN ?
  376. STM32_I2C_MAX_LEN : msg->len;
  377. mask = msg->flags & I2C_M_RD ? STM32_I2C_ISR_RXNE :
  378. STM32_I2C_ISR_TXIS | STM32_I2C_ISR_NACKF;
  379. stm32_i2c_handle_reload(i2c_priv, msg, stop);
  380. } else if (!bytes_to_rw) {
  381. /* Wait until TC flag is set */
  382. mask = STM32_I2C_ISR_TC;
  383. ret = stm32_i2c_wait_flags(i2c_priv, mask, &status);
  384. if (ret)
  385. break;
  386. if (!stop)
  387. /* Message sent, new message has to be sent */
  388. return 0;
  389. }
  390. }
  391. /* End of transfer, send stop condition */
  392. mask = STM32_I2C_CR2_STOP;
  393. setbits_le32(&regs->cr2, mask);
  394. return stm32_i2c_check_end_of_message(i2c_priv);
  395. }
  396. static int stm32_i2c_xfer(struct udevice *bus, struct i2c_msg *msg,
  397. int nmsgs)
  398. {
  399. struct stm32_i2c_priv *i2c_priv = dev_get_priv(bus);
  400. int ret;
  401. ret = stm32_i2c_check_device_busy(i2c_priv);
  402. if (ret)
  403. return ret;
  404. for (; nmsgs > 0; nmsgs--, msg++) {
  405. ret = stm32_i2c_message_xfer(i2c_priv, msg, nmsgs == 1);
  406. if (ret)
  407. return ret;
  408. }
  409. return 0;
  410. }
  411. static int stm32_i2c_compute_solutions(struct stm32_i2c_setup *setup,
  412. struct list_head *solutions)
  413. {
  414. struct stm32_i2c_timings *v;
  415. u32 p_prev = STM32_PRESC_MAX;
  416. u32 i2cclk = DIV_ROUND_CLOSEST(STM32_NSEC_PER_SEC,
  417. setup->clock_src);
  418. u32 af_delay_min, af_delay_max;
  419. u16 p, l, a;
  420. int sdadel_min, sdadel_max, scldel_min;
  421. int ret = 0;
  422. af_delay_min = setup->analog_filter ?
  423. STM32_I2C_ANALOG_FILTER_DELAY_MIN : 0;
  424. af_delay_max = setup->analog_filter ?
  425. STM32_I2C_ANALOG_FILTER_DELAY_MAX : 0;
  426. sdadel_min = setup->fall_time - i2c_specs[setup->speed].hddat_min -
  427. af_delay_min - (setup->dnf + 3) * i2cclk;
  428. sdadel_max = i2c_specs[setup->speed].vddat_max - setup->rise_time -
  429. af_delay_max - (setup->dnf + 4) * i2cclk;
  430. scldel_min = setup->rise_time + i2c_specs[setup->speed].sudat_min;
  431. if (sdadel_min < 0)
  432. sdadel_min = 0;
  433. if (sdadel_max < 0)
  434. sdadel_max = 0;
  435. debug("%s: SDADEL(min/max): %i/%i, SCLDEL(Min): %i\n", __func__,
  436. sdadel_min, sdadel_max, scldel_min);
  437. /* Compute possible values for PRESC, SCLDEL and SDADEL */
  438. for (p = 0; p < STM32_PRESC_MAX; p++) {
  439. for (l = 0; l < STM32_SCLDEL_MAX; l++) {
  440. u32 scldel = (l + 1) * (p + 1) * i2cclk;
  441. if (scldel < scldel_min)
  442. continue;
  443. for (a = 0; a < STM32_SDADEL_MAX; a++) {
  444. u32 sdadel = (a * (p + 1) + 1) * i2cclk;
  445. if (((sdadel >= sdadel_min) &&
  446. (sdadel <= sdadel_max)) &&
  447. (p != p_prev)) {
  448. v = calloc(1, sizeof(*v));
  449. if (!v)
  450. return -ENOMEM;
  451. v->presc = p;
  452. v->scldel = l;
  453. v->sdadel = a;
  454. p_prev = p;
  455. list_add_tail(&v->node, solutions);
  456. }
  457. }
  458. }
  459. }
  460. if (list_empty(solutions)) {
  461. pr_err("%s: no Prescaler solution\n", __func__);
  462. ret = -EPERM;
  463. }
  464. return ret;
  465. }
  466. static int stm32_i2c_choose_solution(struct stm32_i2c_setup *setup,
  467. struct list_head *solutions,
  468. struct stm32_i2c_timings *s)
  469. {
  470. struct stm32_i2c_timings *v;
  471. u32 i2cbus = DIV_ROUND_CLOSEST(STM32_NSEC_PER_SEC,
  472. setup->speed_freq);
  473. u32 clk_error_prev = i2cbus;
  474. u32 i2cclk = DIV_ROUND_CLOSEST(STM32_NSEC_PER_SEC,
  475. setup->clock_src);
  476. u32 clk_min, clk_max;
  477. u32 af_delay_min;
  478. u32 dnf_delay;
  479. u32 tsync;
  480. u16 l, h;
  481. bool sol_found = false;
  482. int ret = 0;
  483. af_delay_min = setup->analog_filter ?
  484. STM32_I2C_ANALOG_FILTER_DELAY_MIN : 0;
  485. dnf_delay = setup->dnf * i2cclk;
  486. tsync = af_delay_min + dnf_delay + (2 * i2cclk);
  487. clk_max = STM32_NSEC_PER_SEC / i2c_specs[setup->speed].rate_min;
  488. clk_min = STM32_NSEC_PER_SEC / i2c_specs[setup->speed].rate_max;
  489. /*
  490. * Among Prescaler possibilities discovered above figures out SCL Low
  491. * and High Period. Provided:
  492. * - SCL Low Period has to be higher than Low Period of the SCL Clock
  493. * defined by I2C Specification. I2C Clock has to be lower than
  494. * (SCL Low Period - Analog/Digital filters) / 4.
  495. * - SCL High Period has to be lower than High Period of the SCL Clock
  496. * defined by I2C Specification
  497. * - I2C Clock has to be lower than SCL High Period
  498. */
  499. list_for_each_entry(v, solutions, node) {
  500. u32 prescaler = (v->presc + 1) * i2cclk;
  501. for (l = 0; l < STM32_SCLL_MAX; l++) {
  502. u32 tscl_l = (l + 1) * prescaler + tsync;
  503. if ((tscl_l < i2c_specs[setup->speed].l_min) ||
  504. (i2cclk >=
  505. ((tscl_l - af_delay_min - dnf_delay) / 4))) {
  506. continue;
  507. }
  508. for (h = 0; h < STM32_SCLH_MAX; h++) {
  509. u32 tscl_h = (h + 1) * prescaler + tsync;
  510. u32 tscl = tscl_l + tscl_h +
  511. setup->rise_time + setup->fall_time;
  512. if ((tscl >= clk_min) && (tscl <= clk_max) &&
  513. (tscl_h >= i2c_specs[setup->speed].h_min) &&
  514. (i2cclk < tscl_h)) {
  515. int clk_error = tscl - i2cbus;
  516. if (clk_error < 0)
  517. clk_error = -clk_error;
  518. if (clk_error < clk_error_prev) {
  519. clk_error_prev = clk_error;
  520. v->scll = l;
  521. v->sclh = h;
  522. sol_found = true;
  523. memcpy(s, v, sizeof(*s));
  524. }
  525. }
  526. }
  527. }
  528. }
  529. if (!sol_found) {
  530. pr_err("%s: no solution at all\n", __func__);
  531. ret = -EPERM;
  532. }
  533. return ret;
  534. }
  535. static int stm32_i2c_compute_timing(struct stm32_i2c_priv *i2c_priv,
  536. struct stm32_i2c_setup *setup,
  537. struct stm32_i2c_timings *output)
  538. {
  539. struct stm32_i2c_timings *v, *_v;
  540. struct list_head solutions;
  541. int ret;
  542. if (setup->speed >= STM32_I2C_SPEED_END) {
  543. pr_err("%s: speed out of bound {%d/%d}\n", __func__,
  544. setup->speed, STM32_I2C_SPEED_END - 1);
  545. return -EINVAL;
  546. }
  547. if ((setup->rise_time > i2c_specs[setup->speed].rise_max) ||
  548. (setup->fall_time > i2c_specs[setup->speed].fall_max)) {
  549. pr_err("%s :timings out of bound Rise{%d>%d}/Fall{%d>%d}\n",
  550. __func__,
  551. setup->rise_time, i2c_specs[setup->speed].rise_max,
  552. setup->fall_time, i2c_specs[setup->speed].fall_max);
  553. return -EINVAL;
  554. }
  555. if (setup->dnf > STM32_I2C_DNF_MAX) {
  556. pr_err("%s: DNF out of bound %d/%d\n", __func__,
  557. setup->dnf, STM32_I2C_DNF_MAX);
  558. return -EINVAL;
  559. }
  560. if (setup->speed_freq > i2c_specs[setup->speed].rate) {
  561. pr_err("%s: Freq {%d/%d}\n", __func__,
  562. setup->speed_freq, i2c_specs[setup->speed].rate);
  563. return -EINVAL;
  564. }
  565. INIT_LIST_HEAD(&solutions);
  566. ret = stm32_i2c_compute_solutions(setup, &solutions);
  567. if (ret)
  568. goto exit;
  569. ret = stm32_i2c_choose_solution(setup, &solutions, output);
  570. if (ret)
  571. goto exit;
  572. debug("%s: Presc: %i, scldel: %i, sdadel: %i, scll: %i, sclh: %i\n",
  573. __func__, output->presc,
  574. output->scldel, output->sdadel,
  575. output->scll, output->sclh);
  576. exit:
  577. /* Release list and memory */
  578. list_for_each_entry_safe(v, _v, &solutions, node) {
  579. list_del(&v->node);
  580. free(v);
  581. }
  582. return ret;
  583. }
  584. static int stm32_i2c_setup_timing(struct stm32_i2c_priv *i2c_priv,
  585. struct stm32_i2c_timings *timing)
  586. {
  587. struct stm32_i2c_setup *setup = i2c_priv->setup;
  588. int ret = 0;
  589. setup->speed = i2c_priv->speed;
  590. setup->speed_freq = i2c_specs[setup->speed].rate;
  591. setup->clock_src = clk_get_rate(&i2c_priv->clk);
  592. if (!setup->clock_src) {
  593. pr_err("%s: clock rate is 0\n", __func__);
  594. return -EINVAL;
  595. }
  596. do {
  597. ret = stm32_i2c_compute_timing(i2c_priv, setup, timing);
  598. if (ret) {
  599. debug("%s: failed to compute I2C timings.\n",
  600. __func__);
  601. if (i2c_priv->speed > STM32_I2C_SPEED_STANDARD) {
  602. i2c_priv->speed--;
  603. setup->speed = i2c_priv->speed;
  604. setup->speed_freq =
  605. i2c_specs[setup->speed].rate;
  606. debug("%s: downgrade I2C Speed Freq to (%i)\n",
  607. __func__, i2c_specs[setup->speed].rate);
  608. } else {
  609. break;
  610. }
  611. }
  612. } while (ret);
  613. if (ret) {
  614. pr_err("%s: impossible to compute I2C timings.\n", __func__);
  615. return ret;
  616. }
  617. debug("%s: I2C Speed(%i), Freq(%i), Clk Source(%i)\n", __func__,
  618. setup->speed, setup->speed_freq, setup->clock_src);
  619. debug("%s: I2C Rise(%i) and Fall(%i) Time\n", __func__,
  620. setup->rise_time, setup->fall_time);
  621. debug("%s: I2C Analog Filter(%s), DNF(%i)\n", __func__,
  622. setup->analog_filter ? "On" : "Off", setup->dnf);
  623. return 0;
  624. }
  625. static int stm32_i2c_hw_config(struct stm32_i2c_priv *i2c_priv)
  626. {
  627. struct stm32_i2c_regs *regs = i2c_priv->regs;
  628. struct stm32_i2c_timings t;
  629. int ret;
  630. u32 timing = 0;
  631. ret = stm32_i2c_setup_timing(i2c_priv, &t);
  632. if (ret)
  633. return ret;
  634. /* Disable I2C */
  635. clrbits_le32(&regs->cr1, STM32_I2C_CR1_PE);
  636. /* Timing settings */
  637. timing |= STM32_I2C_TIMINGR_PRESC(t.presc);
  638. timing |= STM32_I2C_TIMINGR_SCLDEL(t.scldel);
  639. timing |= STM32_I2C_TIMINGR_SDADEL(t.sdadel);
  640. timing |= STM32_I2C_TIMINGR_SCLH(t.sclh);
  641. timing |= STM32_I2C_TIMINGR_SCLL(t.scll);
  642. writel(timing, &regs->timingr);
  643. /* Enable I2C */
  644. if (i2c_priv->setup->analog_filter)
  645. clrbits_le32(&regs->cr1, STM32_I2C_CR1_ANFOFF);
  646. else
  647. setbits_le32(&regs->cr1, STM32_I2C_CR1_ANFOFF);
  648. setbits_le32(&regs->cr1, STM32_I2C_CR1_PE);
  649. return 0;
  650. }
  651. static int stm32_i2c_set_bus_speed(struct udevice *bus, unsigned int speed)
  652. {
  653. struct stm32_i2c_priv *i2c_priv = dev_get_priv(bus);
  654. switch (speed) {
  655. case STANDARD_RATE:
  656. i2c_priv->speed = STM32_I2C_SPEED_STANDARD;
  657. break;
  658. case FAST_RATE:
  659. i2c_priv->speed = STM32_I2C_SPEED_FAST;
  660. break;
  661. case FAST_PLUS_RATE:
  662. i2c_priv->speed = STM32_I2C_SPEED_FAST_PLUS;
  663. break;
  664. default:
  665. debug("%s: Speed %d not supported\n", __func__, speed);
  666. return -EINVAL;
  667. }
  668. return stm32_i2c_hw_config(i2c_priv);
  669. }
  670. static int stm32_i2c_probe(struct udevice *dev)
  671. {
  672. struct stm32_i2c_priv *i2c_priv = dev_get_priv(dev);
  673. struct reset_ctl reset_ctl;
  674. fdt_addr_t addr;
  675. int ret;
  676. addr = dev_read_addr(dev);
  677. if (addr == FDT_ADDR_T_NONE)
  678. return -EINVAL;
  679. i2c_priv->regs = (struct stm32_i2c_regs *)addr;
  680. ret = clk_get_by_index(dev, 0, &i2c_priv->clk);
  681. if (ret)
  682. return ret;
  683. ret = clk_enable(&i2c_priv->clk);
  684. if (ret)
  685. goto clk_free;
  686. ret = reset_get_by_index(dev, 0, &reset_ctl);
  687. if (ret)
  688. goto clk_disable;
  689. reset_assert(&reset_ctl);
  690. udelay(2);
  691. reset_deassert(&reset_ctl);
  692. return 0;
  693. clk_disable:
  694. clk_disable(&i2c_priv->clk);
  695. clk_free:
  696. clk_free(&i2c_priv->clk);
  697. return ret;
  698. }
  699. static int stm32_ofdata_to_platdata(struct udevice *dev)
  700. {
  701. struct stm32_i2c_priv *i2c_priv = dev_get_priv(dev);
  702. u32 rise_time, fall_time;
  703. i2c_priv->setup = (struct stm32_i2c_setup *)dev_get_driver_data(dev);
  704. if (!i2c_priv->setup)
  705. return -EINVAL;
  706. rise_time = dev_read_u32_default(dev, "i2c-scl-rising-time-ns", 0);
  707. if (rise_time)
  708. i2c_priv->setup->rise_time = rise_time;
  709. fall_time = dev_read_u32_default(dev, "i2c-scl-falling-time-ns", 0);
  710. if (fall_time)
  711. i2c_priv->setup->fall_time = fall_time;
  712. return 0;
  713. }
  714. static const struct dm_i2c_ops stm32_i2c_ops = {
  715. .xfer = stm32_i2c_xfer,
  716. .set_bus_speed = stm32_i2c_set_bus_speed,
  717. };
  718. static const struct udevice_id stm32_i2c_of_match[] = {
  719. { .compatible = "st,stm32f7-i2c", .data = (ulong)&stm32f7_setup },
  720. {}
  721. };
  722. U_BOOT_DRIVER(stm32f7_i2c) = {
  723. .name = "stm32f7-i2c",
  724. .id = UCLASS_I2C,
  725. .of_match = stm32_i2c_of_match,
  726. .ofdata_to_platdata = stm32_ofdata_to_platdata,
  727. .probe = stm32_i2c_probe,
  728. .priv_auto_alloc_size = sizeof(struct stm32_i2c_priv),
  729. .ops = &stm32_i2c_ops,
  730. };