1 // SPDX-License-Identifier: GPL-2.0+
3 * Renesas RCar IIC driver
8 * Copyright (C) 2011, 2013 Renesas Solutions Corp.
16 #include <linux/bitops.h>
17 #include <linux/delay.h>
19 struct rcar_iic_priv {
26 #define RCAR_IIC_ICDR 0x00
27 #define RCAR_IIC_ICCR 0x04
28 #define RCAR_IIC_ICSR 0x08
29 #define RCAR_IIC_ICIC 0x0c
30 #define RCAR_IIC_ICCL 0x10
31 #define RCAR_IIC_ICCH 0x14
34 #define RCAR_IIC_ICCR_ICE BIT(7)
35 #define RCAR_IIC_ICCR_RACK BIT(6)
36 #define RCAR_IIC_ICCR_RTS BIT(4)
37 #define RCAR_IIC_ICCR_BUSY BIT(2)
38 #define RCAR_IIC_ICCR_SCP BIT(0)
41 #define RCAR_IC_BUSY BIT(4)
42 #define RCAR_IC_TACK BIT(2)
43 #define RCAR_IC_DTE BIT(0)
47 static void sh_irq_dte(struct udevice *dev)
49 struct rcar_iic_priv *priv = dev_get_priv(dev);
52 for (i = 0; i < IRQ_WAIT; i++) {
53 if (RCAR_IC_DTE & readb(priv->base + RCAR_IIC_ICSR))
59 static int sh_irq_dte_with_tack(struct udevice *dev)
61 struct rcar_iic_priv *priv = dev_get_priv(dev);
65 for (i = 0; i < IRQ_WAIT; i++) {
66 icsr = readb(priv->base + RCAR_IIC_ICSR);
67 if (RCAR_IC_DTE & icsr)
69 if (RCAR_IC_TACK & icsr)
76 static void sh_irq_busy(struct udevice *dev)
78 struct rcar_iic_priv *priv = dev_get_priv(dev);
81 for (i = 0; i < IRQ_WAIT; i++) {
82 if (!(RCAR_IC_BUSY & readb(priv->base + RCAR_IIC_ICSR)))
88 static int rcar_iic_set_addr(struct udevice *dev, u8 chip, u8 read)
90 struct rcar_iic_priv *priv = dev_get_priv(dev);
92 clrbits_8(priv->base + RCAR_IIC_ICCR, RCAR_IIC_ICCR_ICE);
93 setbits_8(priv->base + RCAR_IIC_ICCR, RCAR_IIC_ICCR_ICE);
95 writeb(priv->iccl, priv->base + RCAR_IIC_ICCL);
96 writeb(priv->icch, priv->base + RCAR_IIC_ICCH);
97 writeb(RCAR_IC_TACK, priv->base + RCAR_IIC_ICIC);
99 writeb(RCAR_IIC_ICCR_ICE | RCAR_IIC_ICCR_RTS | RCAR_IIC_ICCR_BUSY,
100 priv->base + RCAR_IIC_ICCR);
103 clrbits_8(priv->base + RCAR_IIC_ICSR, RCAR_IC_TACK);
104 writeb(chip << 1 | read, priv->base + RCAR_IIC_ICDR);
105 return sh_irq_dte_with_tack(dev);
108 static void rcar_iic_finish(struct udevice *dev)
110 struct rcar_iic_priv *priv = dev_get_priv(dev);
112 writeb(0, priv->base + RCAR_IIC_ICSR);
113 clrbits_8(priv->base + RCAR_IIC_ICCR, RCAR_IIC_ICCR_ICE);
116 static int rcar_iic_read_common(struct udevice *dev, struct i2c_msg *msg)
118 struct rcar_iic_priv *priv = dev_get_priv(dev);
119 int i, ret = -EREMOTEIO;
121 if (rcar_iic_set_addr(dev, msg->addr, 1) != 0)
126 writeb(RCAR_IIC_ICCR_ICE | RCAR_IIC_ICCR_SCP,
127 priv->base + RCAR_IIC_ICCR);
129 for (i = 0; i < msg->len; i++) {
130 if (sh_irq_dte_with_tack(dev) != 0)
133 msg->buf[i] = readb(priv->base + RCAR_IIC_ICDR) & 0xff;
135 if (msg->len - 1 == i) {
136 writeb(RCAR_IIC_ICCR_ICE | RCAR_IIC_ICCR_RACK,
137 priv->base + RCAR_IIC_ICCR);
145 rcar_iic_finish(dev);
149 static int rcar_iic_write_common(struct udevice *dev, struct i2c_msg *msg)
151 struct rcar_iic_priv *priv = dev_get_priv(dev);
152 int i, ret = -EREMOTEIO;
154 if (rcar_iic_set_addr(dev, msg->addr, 0) != 0)
159 for (i = 0; i < msg->len; i++) {
160 writeb(msg->buf[i], priv->base + RCAR_IIC_ICDR);
161 if (sh_irq_dte_with_tack(dev) != 0)
165 if (msg->flags & I2C_M_STOP) {
166 writeb(RCAR_IIC_ICCR_ICE | RCAR_IIC_ICCR_RTS,
167 priv->base + RCAR_IIC_ICCR);
168 if (sh_irq_dte_with_tack(dev) != 0)
176 rcar_iic_finish(dev);
180 static int rcar_iic_xfer(struct udevice *dev, struct i2c_msg *msg, int nmsgs)
184 for (; nmsgs > 0; nmsgs--, msg++) {
185 if (msg->flags & I2C_M_RD)
186 ret = rcar_iic_read_common(dev, msg);
188 ret = rcar_iic_write_common(dev, msg);
197 static int rcar_iic_set_speed(struct udevice *dev, uint speed)
199 struct rcar_iic_priv *priv = dev_get_priv(dev);
200 const unsigned int ratio_high = 4;
201 const unsigned int ratio_low = 5;
204 clkrate = clk_get_rate(&priv->clk);
209 * Calculate the value for ICCL and ICCH. From the data sheet:
210 * iccl = (p-clock / transfer-rate) * (L / (L + H))
211 * icch = (p clock / transfer rate) * (H / (L + H))
212 * where L and H are the SCL low and high ratio.
214 denom = speed * (ratio_high + ratio_low);
215 priv->iccl = DIV_ROUND_CLOSEST(clkrate * ratio_low, denom);
216 priv->icch = DIV_ROUND_CLOSEST(clkrate * ratio_high, denom);
221 static int rcar_iic_probe_chip(struct udevice *dev, uint addr, uint flags)
223 struct rcar_iic_priv *priv = dev_get_priv(dev);
226 rcar_iic_set_addr(dev, addr, 1);
227 writeb(RCAR_IIC_ICCR_ICE | RCAR_IIC_ICCR_SCP,
228 priv->base + RCAR_IIC_ICCR);
229 ret = sh_irq_dte_with_tack(dev);
230 rcar_iic_finish(dev);
235 static int rcar_iic_probe(struct udevice *dev)
237 struct rcar_iic_priv *priv = dev_get_priv(dev);
240 priv->base = dev_read_addr_ptr(dev);
242 ret = clk_get_by_index(dev, 0, &priv->clk);
246 ret = clk_enable(&priv->clk);
250 rcar_iic_finish(dev);
252 return rcar_iic_set_speed(dev, I2C_SPEED_STANDARD_RATE);
255 static const struct dm_i2c_ops rcar_iic_ops = {
256 .xfer = rcar_iic_xfer,
257 .probe_chip = rcar_iic_probe_chip,
258 .set_bus_speed = rcar_iic_set_speed,
261 static const struct udevice_id rcar_iic_ids[] = {
262 { .compatible = "renesas,rmobile-iic" },
266 U_BOOT_DRIVER(iic_rcar) = {
269 .of_match = rcar_iic_ids,
270 .probe = rcar_iic_probe,
271 .priv_auto = sizeof(struct rcar_iic_priv),
272 .ops = &rcar_iic_ops,