kona_i2c.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730
  1. /*
  2. * Copyright 2013 Broadcom Corporation.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #include <common.h>
  7. #include <asm/io.h>
  8. #include <asm/errno.h>
  9. #include <asm/arch/sysmap.h>
  10. #include <asm/kona-common/clk.h>
  11. #include <i2c.h>
  12. /* Hardware register offsets and field defintions */
  13. #define CS_OFFSET 0x00000020
  14. #define CS_ACK_SHIFT 3
  15. #define CS_ACK_MASK 0x00000008
  16. #define CS_ACK_CMD_GEN_START 0x00000000
  17. #define CS_ACK_CMD_GEN_RESTART 0x00000001
  18. #define CS_CMD_SHIFT 1
  19. #define CS_CMD_CMD_NO_ACTION 0x00000000
  20. #define CS_CMD_CMD_START_RESTART 0x00000001
  21. #define CS_CMD_CMD_STOP 0x00000002
  22. #define CS_EN_SHIFT 0
  23. #define CS_EN_CMD_ENABLE_BSC 0x00000001
  24. #define TIM_OFFSET 0x00000024
  25. #define TIM_PRESCALE_SHIFT 6
  26. #define TIM_P_SHIFT 3
  27. #define TIM_NO_DIV_SHIFT 2
  28. #define TIM_DIV_SHIFT 0
  29. #define DAT_OFFSET 0x00000028
  30. #define TOUT_OFFSET 0x0000002c
  31. #define TXFCR_OFFSET 0x0000003c
  32. #define TXFCR_FIFO_FLUSH_MASK 0x00000080
  33. #define TXFCR_FIFO_EN_MASK 0x00000040
  34. #define IER_OFFSET 0x00000044
  35. #define IER_READ_COMPLETE_INT_MASK 0x00000010
  36. #define IER_I2C_INT_EN_MASK 0x00000008
  37. #define IER_FIFO_INT_EN_MASK 0x00000002
  38. #define IER_NOACK_EN_MASK 0x00000001
  39. #define ISR_OFFSET 0x00000048
  40. #define ISR_RESERVED_MASK 0xffffff60
  41. #define ISR_CMDBUSY_MASK 0x00000080
  42. #define ISR_READ_COMPLETE_MASK 0x00000010
  43. #define ISR_SES_DONE_MASK 0x00000008
  44. #define ISR_ERR_MASK 0x00000004
  45. #define ISR_TXFIFOEMPTY_MASK 0x00000002
  46. #define ISR_NOACK_MASK 0x00000001
  47. #define CLKEN_OFFSET 0x0000004c
  48. #define CLKEN_AUTOSENSE_OFF_MASK 0x00000080
  49. #define CLKEN_M_SHIFT 4
  50. #define CLKEN_N_SHIFT 1
  51. #define CLKEN_CLKEN_MASK 0x00000001
  52. #define FIFO_STATUS_OFFSET 0x00000054
  53. #define FIFO_STATUS_RXFIFO_EMPTY_MASK 0x00000004
  54. #define FIFO_STATUS_TXFIFO_EMPTY_MASK 0x00000010
  55. #define HSTIM_OFFSET 0x00000058
  56. #define HSTIM_HS_MODE_MASK 0x00008000
  57. #define HSTIM_HS_HOLD_SHIFT 10
  58. #define HSTIM_HS_HIGH_PHASE_SHIFT 5
  59. #define HSTIM_HS_SETUP_SHIFT 0
  60. #define PADCTL_OFFSET 0x0000005c
  61. #define PADCTL_PAD_OUT_EN_MASK 0x00000004
  62. #define RXFCR_OFFSET 0x00000068
  63. #define RXFCR_NACK_EN_SHIFT 7
  64. #define RXFCR_READ_COUNT_SHIFT 0
  65. #define RXFIFORDOUT_OFFSET 0x0000006c
  66. /* Locally used constants */
  67. #define MAX_RX_FIFO_SIZE 64U /* bytes */
  68. #define MAX_TX_FIFO_SIZE 64U /* bytes */
  69. #define I2C_TIMEOUT 100000 /* usecs */
  70. #define WAIT_INT_CHK 100 /* usecs */
  71. #if I2C_TIMEOUT % WAIT_INT_CHK
  72. #error I2C_TIMEOUT must be a multiple of WAIT_INT_CHK
  73. #endif
  74. /* Operations that can be commanded to the controller */
  75. enum bcm_kona_cmd_t {
  76. BCM_CMD_NOACTION = 0,
  77. BCM_CMD_START,
  78. BCM_CMD_RESTART,
  79. BCM_CMD_STOP,
  80. };
  81. enum bus_speed_index {
  82. BCM_SPD_100K = 0,
  83. BCM_SPD_400K,
  84. BCM_SPD_1MHZ,
  85. };
  86. /* Internal divider settings for standard mode, fast mode and fast mode plus */
  87. struct bus_speed_cfg {
  88. uint8_t time_m; /* Number of cycles for setup time */
  89. uint8_t time_n; /* Number of cycles for hold time */
  90. uint8_t prescale; /* Prescale divider */
  91. uint8_t time_p; /* Timing coefficient */
  92. uint8_t no_div; /* Disable clock divider */
  93. uint8_t time_div; /* Post-prescale divider */
  94. };
  95. static const struct bus_speed_cfg std_cfg_table[] = {
  96. [BCM_SPD_100K] = {0x01, 0x01, 0x03, 0x06, 0x00, 0x02},
  97. [BCM_SPD_400K] = {0x05, 0x01, 0x03, 0x05, 0x01, 0x02},
  98. [BCM_SPD_1MHZ] = {0x01, 0x01, 0x03, 0x01, 0x01, 0x03},
  99. };
  100. struct bcm_kona_i2c_dev {
  101. void *base;
  102. uint speed;
  103. const struct bus_speed_cfg *std_cfg;
  104. };
  105. /* Keep these two defines in sync */
  106. #define DEF_SPD 100000
  107. #define DEF_SPD_ENUM BCM_SPD_100K
  108. #define DEF_DEVICE(num) \
  109. {(void *)CONFIG_SYS_I2C_BASE##num, DEF_SPD, &std_cfg_table[DEF_SPD_ENUM]}
  110. static struct bcm_kona_i2c_dev g_i2c_devs[CONFIG_SYS_MAX_I2C_BUS] = {
  111. #ifdef CONFIG_SYS_I2C_BASE0
  112. DEF_DEVICE(0),
  113. #endif
  114. #ifdef CONFIG_SYS_I2C_BASE1
  115. DEF_DEVICE(1),
  116. #endif
  117. #ifdef CONFIG_SYS_I2C_BASE2
  118. DEF_DEVICE(2),
  119. #endif
  120. #ifdef CONFIG_SYS_I2C_BASE3
  121. DEF_DEVICE(3),
  122. #endif
  123. #ifdef CONFIG_SYS_I2C_BASE4
  124. DEF_DEVICE(4),
  125. #endif
  126. #ifdef CONFIG_SYS_I2C_BASE5
  127. DEF_DEVICE(5),
  128. #endif
  129. };
  130. #define I2C_M_TEN 0x0010 /* ten bit address */
  131. #define I2C_M_RD 0x0001 /* read data */
  132. #define I2C_M_NOSTART 0x4000 /* no restart between msgs */
  133. struct i2c_msg {
  134. uint16_t addr;
  135. uint16_t flags;
  136. uint16_t len;
  137. uint8_t *buf;
  138. };
  139. static void bcm_kona_i2c_send_cmd_to_ctrl(struct bcm_kona_i2c_dev *dev,
  140. enum bcm_kona_cmd_t cmd)
  141. {
  142. debug("%s, %d\n", __func__, cmd);
  143. switch (cmd) {
  144. case BCM_CMD_NOACTION:
  145. writel((CS_CMD_CMD_NO_ACTION << CS_CMD_SHIFT) |
  146. (CS_EN_CMD_ENABLE_BSC << CS_EN_SHIFT),
  147. dev->base + CS_OFFSET);
  148. break;
  149. case BCM_CMD_START:
  150. writel((CS_ACK_CMD_GEN_START << CS_ACK_SHIFT) |
  151. (CS_CMD_CMD_START_RESTART << CS_CMD_SHIFT) |
  152. (CS_EN_CMD_ENABLE_BSC << CS_EN_SHIFT),
  153. dev->base + CS_OFFSET);
  154. break;
  155. case BCM_CMD_RESTART:
  156. writel((CS_ACK_CMD_GEN_RESTART << CS_ACK_SHIFT) |
  157. (CS_CMD_CMD_START_RESTART << CS_CMD_SHIFT) |
  158. (CS_EN_CMD_ENABLE_BSC << CS_EN_SHIFT),
  159. dev->base + CS_OFFSET);
  160. break;
  161. case BCM_CMD_STOP:
  162. writel((CS_CMD_CMD_STOP << CS_CMD_SHIFT) |
  163. (CS_EN_CMD_ENABLE_BSC << CS_EN_SHIFT),
  164. dev->base + CS_OFFSET);
  165. break;
  166. default:
  167. printf("Unknown command %d\n", cmd);
  168. }
  169. }
  170. static void bcm_kona_i2c_enable_clock(struct bcm_kona_i2c_dev *dev)
  171. {
  172. writel(readl(dev->base + CLKEN_OFFSET) | CLKEN_CLKEN_MASK,
  173. dev->base + CLKEN_OFFSET);
  174. }
  175. static void bcm_kona_i2c_disable_clock(struct bcm_kona_i2c_dev *dev)
  176. {
  177. writel(readl(dev->base + CLKEN_OFFSET) & ~CLKEN_CLKEN_MASK,
  178. dev->base + CLKEN_OFFSET);
  179. }
  180. /* Wait until at least one of the mask bit(s) are set */
  181. static unsigned long wait_for_int_timeout(struct bcm_kona_i2c_dev *dev,
  182. unsigned long time_left,
  183. uint32_t mask)
  184. {
  185. uint32_t status;
  186. while (time_left) {
  187. status = readl(dev->base + ISR_OFFSET);
  188. if ((status & ~ISR_RESERVED_MASK) == 0) {
  189. debug("Bogus I2C interrupt 0x%x\n", status);
  190. continue;
  191. }
  192. /* Must flush the TX FIFO when NAK detected */
  193. if (status & ISR_NOACK_MASK)
  194. writel(TXFCR_FIFO_FLUSH_MASK | TXFCR_FIFO_EN_MASK,
  195. dev->base + TXFCR_OFFSET);
  196. writel(status & ~ISR_RESERVED_MASK, dev->base + ISR_OFFSET);
  197. if (status & mask) {
  198. /* We are done since one of the mask bits are set */
  199. return time_left;
  200. }
  201. udelay(WAIT_INT_CHK);
  202. time_left -= WAIT_INT_CHK;
  203. }
  204. return 0;
  205. }
  206. /* Send command to I2C bus */
  207. static int bcm_kona_send_i2c_cmd(struct bcm_kona_i2c_dev *dev,
  208. enum bcm_kona_cmd_t cmd)
  209. {
  210. int rc = 0;
  211. unsigned long time_left = I2C_TIMEOUT;
  212. /* Send the command */
  213. bcm_kona_i2c_send_cmd_to_ctrl(dev, cmd);
  214. /* Wait for transaction to finish or timeout */
  215. time_left = wait_for_int_timeout(dev, time_left, IER_I2C_INT_EN_MASK);
  216. if (!time_left) {
  217. printf("controller timed out\n");
  218. rc = -ETIMEDOUT;
  219. }
  220. /* Clear command */
  221. bcm_kona_i2c_send_cmd_to_ctrl(dev, BCM_CMD_NOACTION);
  222. return rc;
  223. }
  224. /* Read a single RX FIFO worth of data from the i2c bus */
  225. static int bcm_kona_i2c_read_fifo_single(struct bcm_kona_i2c_dev *dev,
  226. uint8_t *buf, unsigned int len,
  227. unsigned int last_byte_nak)
  228. {
  229. unsigned long time_left = I2C_TIMEOUT;
  230. /* Start the RX FIFO */
  231. writel((last_byte_nak << RXFCR_NACK_EN_SHIFT) |
  232. (len << RXFCR_READ_COUNT_SHIFT), dev->base + RXFCR_OFFSET);
  233. /* Wait for FIFO read to complete */
  234. time_left =
  235. wait_for_int_timeout(dev, time_left, IER_READ_COMPLETE_INT_MASK);
  236. if (!time_left) {
  237. printf("RX FIFO time out\n");
  238. return -EREMOTEIO;
  239. }
  240. /* Read data from FIFO */
  241. for (; len > 0; len--, buf++)
  242. *buf = readl(dev->base + RXFIFORDOUT_OFFSET);
  243. return 0;
  244. }
  245. /* Read any amount of data using the RX FIFO from the i2c bus */
  246. static int bcm_kona_i2c_read_fifo(struct bcm_kona_i2c_dev *dev,
  247. struct i2c_msg *msg)
  248. {
  249. unsigned int bytes_to_read = MAX_RX_FIFO_SIZE;
  250. unsigned int last_byte_nak = 0;
  251. unsigned int bytes_read = 0;
  252. int rc;
  253. uint8_t *tmp_buf = msg->buf;
  254. while (bytes_read < msg->len) {
  255. if (msg->len - bytes_read <= MAX_RX_FIFO_SIZE) {
  256. last_byte_nak = 1; /* NAK last byte of transfer */
  257. bytes_to_read = msg->len - bytes_read;
  258. }
  259. rc = bcm_kona_i2c_read_fifo_single(dev, tmp_buf, bytes_to_read,
  260. last_byte_nak);
  261. if (rc < 0)
  262. return -EREMOTEIO;
  263. bytes_read += bytes_to_read;
  264. tmp_buf += bytes_to_read;
  265. }
  266. return 0;
  267. }
  268. /* Write a single byte of data to the i2c bus */
  269. static int bcm_kona_i2c_write_byte(struct bcm_kona_i2c_dev *dev, uint8_t data,
  270. unsigned int nak_expected)
  271. {
  272. unsigned long time_left = I2C_TIMEOUT;
  273. unsigned int nak_received;
  274. /* Clear pending session done interrupt */
  275. writel(ISR_SES_DONE_MASK, dev->base + ISR_OFFSET);
  276. /* Send one byte of data */
  277. writel(data, dev->base + DAT_OFFSET);
  278. time_left = wait_for_int_timeout(dev, time_left, IER_I2C_INT_EN_MASK);
  279. if (!time_left) {
  280. debug("controller timed out\n");
  281. return -ETIMEDOUT;
  282. }
  283. nak_received = readl(dev->base + CS_OFFSET) & CS_ACK_MASK ? 1 : 0;
  284. if (nak_received ^ nak_expected) {
  285. debug("unexpected NAK/ACK\n");
  286. return -EREMOTEIO;
  287. }
  288. return 0;
  289. }
  290. /* Write a single TX FIFO worth of data to the i2c bus */
  291. static int bcm_kona_i2c_write_fifo_single(struct bcm_kona_i2c_dev *dev,
  292. uint8_t *buf, unsigned int len)
  293. {
  294. int k;
  295. unsigned long time_left = I2C_TIMEOUT;
  296. unsigned int fifo_status;
  297. /* Write data into FIFO */
  298. for (k = 0; k < len; k++)
  299. writel(buf[k], (dev->base + DAT_OFFSET));
  300. /* Wait for FIFO to empty */
  301. do {
  302. time_left =
  303. wait_for_int_timeout(dev, time_left,
  304. (IER_FIFO_INT_EN_MASK |
  305. IER_NOACK_EN_MASK));
  306. fifo_status = readl(dev->base + FIFO_STATUS_OFFSET);
  307. } while (time_left && !(fifo_status & FIFO_STATUS_TXFIFO_EMPTY_MASK));
  308. /* Check if there was a NAK */
  309. if (readl(dev->base + CS_OFFSET) & CS_ACK_MASK) {
  310. printf("unexpected NAK\n");
  311. return -EREMOTEIO;
  312. }
  313. /* Check if a timeout occured */
  314. if (!time_left) {
  315. printf("completion timed out\n");
  316. return -EREMOTEIO;
  317. }
  318. return 0;
  319. }
  320. /* Write any amount of data using TX FIFO to the i2c bus */
  321. static int bcm_kona_i2c_write_fifo(struct bcm_kona_i2c_dev *dev,
  322. struct i2c_msg *msg)
  323. {
  324. unsigned int bytes_to_write = MAX_TX_FIFO_SIZE;
  325. unsigned int bytes_written = 0;
  326. int rc;
  327. uint8_t *tmp_buf = msg->buf;
  328. while (bytes_written < msg->len) {
  329. if (msg->len - bytes_written <= MAX_TX_FIFO_SIZE)
  330. bytes_to_write = msg->len - bytes_written;
  331. rc = bcm_kona_i2c_write_fifo_single(dev, tmp_buf,
  332. bytes_to_write);
  333. if (rc < 0)
  334. return -EREMOTEIO;
  335. bytes_written += bytes_to_write;
  336. tmp_buf += bytes_to_write;
  337. }
  338. return 0;
  339. }
  340. /* Send i2c address */
  341. static int bcm_kona_i2c_do_addr(struct bcm_kona_i2c_dev *dev,
  342. struct i2c_msg *msg)
  343. {
  344. unsigned char addr;
  345. if (msg->flags & I2C_M_TEN) {
  346. /* First byte is 11110XX0 where XX is upper 2 bits */
  347. addr = 0xf0 | ((msg->addr & 0x300) >> 7);
  348. if (bcm_kona_i2c_write_byte(dev, addr, 0) < 0)
  349. return -EREMOTEIO;
  350. /* Second byte is the remaining 8 bits */
  351. addr = msg->addr & 0xff;
  352. if (bcm_kona_i2c_write_byte(dev, addr, 0) < 0)
  353. return -EREMOTEIO;
  354. if (msg->flags & I2C_M_RD) {
  355. /* For read, send restart command */
  356. if (bcm_kona_send_i2c_cmd(dev, BCM_CMD_RESTART) < 0)
  357. return -EREMOTEIO;
  358. /* Then re-send the first byte with the read bit set */
  359. addr = 0xf0 | ((msg->addr & 0x300) >> 7) | 0x01;
  360. if (bcm_kona_i2c_write_byte(dev, addr, 0) < 0)
  361. return -EREMOTEIO;
  362. }
  363. } else {
  364. addr = msg->addr << 1;
  365. if (msg->flags & I2C_M_RD)
  366. addr |= 1;
  367. if (bcm_kona_i2c_write_byte(dev, addr, 0) < 0)
  368. return -EREMOTEIO;
  369. }
  370. return 0;
  371. }
  372. static void bcm_kona_i2c_enable_autosense(struct bcm_kona_i2c_dev *dev)
  373. {
  374. writel(readl(dev->base + CLKEN_OFFSET) & ~CLKEN_AUTOSENSE_OFF_MASK,
  375. dev->base + CLKEN_OFFSET);
  376. }
  377. static void bcm_kona_i2c_config_timing(struct bcm_kona_i2c_dev *dev)
  378. {
  379. writel(readl(dev->base + HSTIM_OFFSET) & ~HSTIM_HS_MODE_MASK,
  380. dev->base + HSTIM_OFFSET);
  381. writel((dev->std_cfg->prescale << TIM_PRESCALE_SHIFT) |
  382. (dev->std_cfg->time_p << TIM_P_SHIFT) |
  383. (dev->std_cfg->no_div << TIM_NO_DIV_SHIFT) |
  384. (dev->std_cfg->time_div << TIM_DIV_SHIFT),
  385. dev->base + TIM_OFFSET);
  386. writel((dev->std_cfg->time_m << CLKEN_M_SHIFT) |
  387. (dev->std_cfg->time_n << CLKEN_N_SHIFT) |
  388. CLKEN_CLKEN_MASK, dev->base + CLKEN_OFFSET);
  389. }
  390. /* Master transfer function */
  391. static int bcm_kona_i2c_xfer(struct bcm_kona_i2c_dev *dev,
  392. struct i2c_msg msgs[], int num)
  393. {
  394. struct i2c_msg *pmsg;
  395. int rc = 0;
  396. int i;
  397. /* Enable pad output */
  398. writel(0, dev->base + PADCTL_OFFSET);
  399. /* Enable internal clocks */
  400. bcm_kona_i2c_enable_clock(dev);
  401. /* Send start command */
  402. rc = bcm_kona_send_i2c_cmd(dev, BCM_CMD_START);
  403. if (rc < 0) {
  404. printf("Start command failed rc = %d\n", rc);
  405. goto xfer_disable_pad;
  406. }
  407. /* Loop through all messages */
  408. for (i = 0; i < num; i++) {
  409. pmsg = &msgs[i];
  410. /* Send restart for subsequent messages */
  411. if ((i != 0) && ((pmsg->flags & I2C_M_NOSTART) == 0)) {
  412. rc = bcm_kona_send_i2c_cmd(dev, BCM_CMD_RESTART);
  413. if (rc < 0) {
  414. printf("restart cmd failed rc = %d\n", rc);
  415. goto xfer_send_stop;
  416. }
  417. }
  418. /* Send slave address */
  419. if (!(pmsg->flags & I2C_M_NOSTART)) {
  420. rc = bcm_kona_i2c_do_addr(dev, pmsg);
  421. if (rc < 0) {
  422. debug("NAK from addr %2.2x msg#%d rc = %d\n",
  423. pmsg->addr, i, rc);
  424. goto xfer_send_stop;
  425. }
  426. }
  427. /* Perform data transfer */
  428. if (pmsg->flags & I2C_M_RD) {
  429. rc = bcm_kona_i2c_read_fifo(dev, pmsg);
  430. if (rc < 0) {
  431. printf("read failure\n");
  432. goto xfer_send_stop;
  433. }
  434. } else {
  435. rc = bcm_kona_i2c_write_fifo(dev, pmsg);
  436. if (rc < 0) {
  437. printf("write failure");
  438. goto xfer_send_stop;
  439. }
  440. }
  441. }
  442. rc = num;
  443. xfer_send_stop:
  444. /* Send a STOP command */
  445. bcm_kona_send_i2c_cmd(dev, BCM_CMD_STOP);
  446. xfer_disable_pad:
  447. /* Disable pad output */
  448. writel(PADCTL_PAD_OUT_EN_MASK, dev->base + PADCTL_OFFSET);
  449. /* Stop internal clock */
  450. bcm_kona_i2c_disable_clock(dev);
  451. return rc;
  452. }
  453. static uint bcm_kona_i2c_assign_bus_speed(struct bcm_kona_i2c_dev *dev,
  454. uint speed)
  455. {
  456. switch (speed) {
  457. case 100000:
  458. dev->std_cfg = &std_cfg_table[BCM_SPD_100K];
  459. break;
  460. case 400000:
  461. dev->std_cfg = &std_cfg_table[BCM_SPD_400K];
  462. break;
  463. case 1000000:
  464. dev->std_cfg = &std_cfg_table[BCM_SPD_1MHZ];
  465. break;
  466. default:
  467. printf("%d hz bus speed not supported\n", speed);
  468. return -EINVAL;
  469. }
  470. dev->speed = speed;
  471. return 0;
  472. }
  473. static void bcm_kona_i2c_init(struct bcm_kona_i2c_dev *dev)
  474. {
  475. /* Parse bus speed */
  476. bcm_kona_i2c_assign_bus_speed(dev, dev->speed);
  477. /* Enable internal clocks */
  478. bcm_kona_i2c_enable_clock(dev);
  479. /* Configure internal dividers */
  480. bcm_kona_i2c_config_timing(dev);
  481. /* Disable timeout */
  482. writel(0, dev->base + TOUT_OFFSET);
  483. /* Enable autosense */
  484. bcm_kona_i2c_enable_autosense(dev);
  485. /* Enable TX FIFO */
  486. writel(TXFCR_FIFO_FLUSH_MASK | TXFCR_FIFO_EN_MASK,
  487. dev->base + TXFCR_OFFSET);
  488. /* Mask all interrupts */
  489. writel(0, dev->base + IER_OFFSET);
  490. /* Clear all pending interrupts */
  491. writel(ISR_CMDBUSY_MASK |
  492. ISR_READ_COMPLETE_MASK |
  493. ISR_SES_DONE_MASK |
  494. ISR_ERR_MASK |
  495. ISR_TXFIFOEMPTY_MASK | ISR_NOACK_MASK, dev->base + ISR_OFFSET);
  496. /* Enable the controller but leave it idle */
  497. bcm_kona_i2c_send_cmd_to_ctrl(dev, BCM_CMD_NOACTION);
  498. /* Disable pad output */
  499. writel(PADCTL_PAD_OUT_EN_MASK, dev->base + PADCTL_OFFSET);
  500. }
  501. /*
  502. * uboot layer
  503. */
  504. struct bcm_kona_i2c_dev *kona_get_dev(struct i2c_adapter *adap)
  505. {
  506. return &g_i2c_devs[adap->hwadapnr];
  507. }
  508. static void kona_i2c_init(struct i2c_adapter *adap, int speed, int slaveaddr)
  509. {
  510. struct bcm_kona_i2c_dev *dev = kona_get_dev(adap);
  511. if (clk_bsc_enable(dev->base))
  512. return;
  513. bcm_kona_i2c_init(dev);
  514. }
  515. static int kona_i2c_read(struct i2c_adapter *adap, uchar chip, uint addr,
  516. int alen, uchar *buffer, int len)
  517. {
  518. /* msg[0] writes the addr, msg[1] reads the data */
  519. struct i2c_msg msg[2];
  520. unsigned char msgbuf0[64];
  521. struct bcm_kona_i2c_dev *dev = kona_get_dev(adap);
  522. msg[0].addr = chip;
  523. msg[0].flags = 0;
  524. msg[0].len = 1;
  525. msg[0].buf = msgbuf0; /* msgbuf0 contains incrementing reg addr */
  526. msg[1].addr = chip;
  527. msg[1].flags = I2C_M_RD;
  528. /* msg[1].buf dest ptr increments each read */
  529. msgbuf0[0] = (unsigned char)addr;
  530. msg[1].buf = buffer;
  531. msg[1].len = len;
  532. if (bcm_kona_i2c_xfer(dev, msg, 2) < 0) {
  533. /* Sending 2 i2c messages */
  534. kona_i2c_init(adap, adap->speed, adap->slaveaddr);
  535. debug("I2C read: I/O error\n");
  536. return -EIO;
  537. }
  538. return 0;
  539. }
  540. static int kona_i2c_write(struct i2c_adapter *adap, uchar chip, uint addr,
  541. int alen, uchar *buffer, int len)
  542. {
  543. struct i2c_msg msg[1];
  544. unsigned char msgbuf0[64];
  545. unsigned int i;
  546. struct bcm_kona_i2c_dev *dev = kona_get_dev(adap);
  547. msg[0].addr = chip;
  548. msg[0].flags = 0;
  549. msg[0].len = 2; /* addr byte plus data */
  550. msg[0].buf = msgbuf0;
  551. for (i = 0; i < len; i++) {
  552. msgbuf0[0] = addr++;
  553. msgbuf0[1] = buffer[i];
  554. if (bcm_kona_i2c_xfer(dev, msg, 1) < 0) {
  555. kona_i2c_init(adap, adap->speed, adap->slaveaddr);
  556. debug("I2C write: I/O error\n");
  557. return -EIO;
  558. }
  559. }
  560. return 0;
  561. }
  562. static int kona_i2c_probe(struct i2c_adapter *adap, uchar chip)
  563. {
  564. uchar tmp;
  565. /*
  566. * read addr 0x0 of the given chip.
  567. */
  568. return kona_i2c_read(adap, chip, 0x0, 1, &tmp, 1);
  569. }
  570. static uint kona_i2c_set_bus_speed(struct i2c_adapter *adap, uint speed)
  571. {
  572. struct bcm_kona_i2c_dev *dev = kona_get_dev(adap);
  573. return bcm_kona_i2c_assign_bus_speed(dev, speed);
  574. }
  575. /*
  576. * Register kona i2c adapters. Keep the order below so
  577. * that the bus number matches the adapter number.
  578. */
  579. #define DEF_ADAPTER(num) \
  580. U_BOOT_I2C_ADAP_COMPLETE(kona##num, kona_i2c_init, kona_i2c_probe, \
  581. kona_i2c_read, kona_i2c_write, \
  582. kona_i2c_set_bus_speed, DEF_SPD, 0x00, num)
  583. #ifdef CONFIG_SYS_I2C_BASE0
  584. DEF_ADAPTER(0)
  585. #endif
  586. #ifdef CONFIG_SYS_I2C_BASE1
  587. DEF_ADAPTER(1)
  588. #endif
  589. #ifdef CONFIG_SYS_I2C_BASE2
  590. DEF_ADAPTER(2)
  591. #endif
  592. #ifdef CONFIG_SYS_I2C_BASE3
  593. DEF_ADAPTER(3)
  594. #endif
  595. #ifdef CONFIG_SYS_I2C_BASE4
  596. DEF_ADAPTER(4)
  597. #endif
  598. #ifdef CONFIG_SYS_I2C_BASE5
  599. DEF_ADAPTER(5)
  600. #endif