Lines Matching refs:i2c
42 void (*setreg)(struct ocores_i2c *i2c, int reg, u8 value);
43 u8 (*getreg)(struct ocores_i2c *i2c, int reg);
80 static void oc_setreg_8(struct ocores_i2c *i2c, int reg, u8 value) in oc_setreg_8() argument
82 iowrite8(value, i2c->base + (reg << i2c->reg_shift)); in oc_setreg_8()
85 static void oc_setreg_16(struct ocores_i2c *i2c, int reg, u8 value) in oc_setreg_16() argument
87 iowrite16(value, i2c->base + (reg << i2c->reg_shift)); in oc_setreg_16()
90 static void oc_setreg_32(struct ocores_i2c *i2c, int reg, u8 value) in oc_setreg_32() argument
92 iowrite32(value, i2c->base + (reg << i2c->reg_shift)); in oc_setreg_32()
95 static void oc_setreg_16be(struct ocores_i2c *i2c, int reg, u8 value) in oc_setreg_16be() argument
97 iowrite16be(value, i2c->base + (reg << i2c->reg_shift)); in oc_setreg_16be()
100 static void oc_setreg_32be(struct ocores_i2c *i2c, int reg, u8 value) in oc_setreg_32be() argument
102 iowrite32be(value, i2c->base + (reg << i2c->reg_shift)); in oc_setreg_32be()
105 static inline u8 oc_getreg_8(struct ocores_i2c *i2c, int reg) in oc_getreg_8() argument
107 return ioread8(i2c->base + (reg << i2c->reg_shift)); in oc_getreg_8()
110 static inline u8 oc_getreg_16(struct ocores_i2c *i2c, int reg) in oc_getreg_16() argument
112 return ioread16(i2c->base + (reg << i2c->reg_shift)); in oc_getreg_16()
115 static inline u8 oc_getreg_32(struct ocores_i2c *i2c, int reg) in oc_getreg_32() argument
117 return ioread32(i2c->base + (reg << i2c->reg_shift)); in oc_getreg_32()
120 static inline u8 oc_getreg_16be(struct ocores_i2c *i2c, int reg) in oc_getreg_16be() argument
122 return ioread16be(i2c->base + (reg << i2c->reg_shift)); in oc_getreg_16be()
125 static inline u8 oc_getreg_32be(struct ocores_i2c *i2c, int reg) in oc_getreg_32be() argument
127 return ioread32be(i2c->base + (reg << i2c->reg_shift)); in oc_getreg_32be()
130 static inline void oc_setreg(struct ocores_i2c *i2c, int reg, u8 value) in oc_setreg() argument
132 i2c->setreg(i2c, reg, value); in oc_setreg()
135 static inline u8 oc_getreg(struct ocores_i2c *i2c, int reg) in oc_getreg() argument
137 return i2c->getreg(i2c, reg); in oc_getreg()
140 static void ocores_process(struct ocores_i2c *i2c) in ocores_process() argument
142 struct i2c_msg *msg = i2c->msg; in ocores_process()
143 u8 stat = oc_getreg(i2c, OCI2C_STATUS); in ocores_process()
145 if ((i2c->state == STATE_DONE) || (i2c->state == STATE_ERROR)) { in ocores_process()
147 oc_setreg(i2c, OCI2C_CMD, OCI2C_CMD_IACK); in ocores_process()
148 wake_up(&i2c->wait); in ocores_process()
154 i2c->state = STATE_ERROR; in ocores_process()
155 oc_setreg(i2c, OCI2C_CMD, OCI2C_CMD_STOP); in ocores_process()
159 if ((i2c->state == STATE_START) || (i2c->state == STATE_WRITE)) { in ocores_process()
160 i2c->state = in ocores_process()
164 i2c->state = STATE_ERROR; in ocores_process()
165 oc_setreg(i2c, OCI2C_CMD, OCI2C_CMD_STOP); in ocores_process()
169 msg->buf[i2c->pos++] = oc_getreg(i2c, OCI2C_DATA); in ocores_process()
172 if (i2c->pos == msg->len) { in ocores_process()
173 i2c->nmsgs--; in ocores_process()
174 i2c->msg++; in ocores_process()
175 i2c->pos = 0; in ocores_process()
176 msg = i2c->msg; in ocores_process()
178 if (i2c->nmsgs) { /* end? */ in ocores_process()
183 i2c->state = STATE_START; in ocores_process()
185 oc_setreg(i2c, OCI2C_DATA, addr); in ocores_process()
186 oc_setreg(i2c, OCI2C_CMD, OCI2C_CMD_START); in ocores_process()
189 i2c->state = (msg->flags & I2C_M_RD) in ocores_process()
192 i2c->state = STATE_DONE; in ocores_process()
193 oc_setreg(i2c, OCI2C_CMD, OCI2C_CMD_STOP); in ocores_process()
198 if (i2c->state == STATE_READ) { in ocores_process()
199 oc_setreg(i2c, OCI2C_CMD, i2c->pos == (msg->len-1) ? in ocores_process()
202 oc_setreg(i2c, OCI2C_DATA, msg->buf[i2c->pos++]); in ocores_process()
203 oc_setreg(i2c, OCI2C_CMD, OCI2C_CMD_WRITE); in ocores_process()
209 struct ocores_i2c *i2c = dev_id; in ocores_isr() local
211 ocores_process(i2c); in ocores_isr()
218 struct ocores_i2c *i2c = i2c_get_adapdata(adap); in ocores_xfer() local
220 i2c->msg = msgs; in ocores_xfer()
221 i2c->pos = 0; in ocores_xfer()
222 i2c->nmsgs = num; in ocores_xfer()
223 i2c->state = STATE_START; in ocores_xfer()
225 oc_setreg(i2c, OCI2C_DATA, in ocores_xfer()
226 (i2c->msg->addr << 1) | in ocores_xfer()
227 ((i2c->msg->flags & I2C_M_RD) ? 1:0)); in ocores_xfer()
229 oc_setreg(i2c, OCI2C_CMD, OCI2C_CMD_START); in ocores_xfer()
231 if (wait_event_timeout(i2c->wait, (i2c->state == STATE_ERROR) || in ocores_xfer()
232 (i2c->state == STATE_DONE), HZ)) in ocores_xfer()
233 return (i2c->state == STATE_DONE) ? num : -EIO; in ocores_xfer()
238 static int ocores_init(struct device *dev, struct ocores_i2c *i2c) in ocores_init() argument
242 u8 ctrl = oc_getreg(i2c, OCI2C_CONTROL); in ocores_init()
245 oc_setreg(i2c, OCI2C_CONTROL, ctrl & ~(OCI2C_CTRL_EN|OCI2C_CTRL_IEN)); in ocores_init()
247 prescale = (i2c->ip_clock_khz / (5 * i2c->bus_clock_khz)) - 1; in ocores_init()
250 diff = i2c->ip_clock_khz / (5 * (prescale + 1)) - i2c->bus_clock_khz; in ocores_init()
251 if (abs(diff) > i2c->bus_clock_khz / 10) { in ocores_init()
254 i2c->ip_clock_khz, i2c->bus_clock_khz); in ocores_init()
258 oc_setreg(i2c, OCI2C_PRELOW, prescale & 0xff); in ocores_init()
259 oc_setreg(i2c, OCI2C_PREHIGH, prescale >> 8); in ocores_init()
262 oc_setreg(i2c, OCI2C_CMD, OCI2C_CMD_IACK); in ocores_init()
263 oc_setreg(i2c, OCI2C_CONTROL, ctrl | OCI2C_CTRL_IEN | OCI2C_CTRL_EN); in ocores_init()
303 static u8 oc_getreg_grlib(struct ocores_i2c *i2c, int reg) in oc_getreg_grlib() argument
309 rd = ioread32be(i2c->base + (rreg << i2c->reg_shift)); in oc_getreg_grlib()
316 static void oc_setreg_grlib(struct ocores_i2c *i2c, int reg, u8 value) in oc_setreg_grlib() argument
323 curr = ioread32be(i2c->base + (rreg << i2c->reg_shift)); in oc_setreg_grlib()
331 iowrite32be(wr, i2c->base + (rreg << i2c->reg_shift)); in oc_setreg_grlib()
335 struct ocores_i2c *i2c) in ocores_i2c_of_probe() argument
343 if (of_property_read_u32(np, "reg-shift", &i2c->reg_shift)) { in ocores_i2c_of_probe()
351 i2c->reg_shift = ilog2(val); in ocores_i2c_of_probe()
359 i2c->bus_clock_khz = 100; in ocores_i2c_of_probe()
361 i2c->clk = devm_clk_get(&pdev->dev, NULL); in ocores_i2c_of_probe()
363 if (!IS_ERR(i2c->clk)) { in ocores_i2c_of_probe()
364 int ret = clk_prepare_enable(i2c->clk); in ocores_i2c_of_probe()
371 i2c->ip_clock_khz = clk_get_rate(i2c->clk) / 1000; in ocores_i2c_of_probe()
373 i2c->bus_clock_khz = clock_frequency / 1000; in ocores_i2c_of_probe()
376 if (i2c->ip_clock_khz == 0) { in ocores_i2c_of_probe()
382 clk_disable_unprepare(i2c->clk); in ocores_i2c_of_probe()
385 i2c->ip_clock_khz = clock_frequency / 1000; in ocores_i2c_of_probe()
389 i2c->ip_clock_khz = val / 1000; in ocores_i2c_of_probe()
391 i2c->bus_clock_khz = clock_frequency / 1000; in ocores_i2c_of_probe()
396 &i2c->reg_io_width); in ocores_i2c_of_probe()
401 i2c->setreg = oc_setreg_grlib; in ocores_i2c_of_probe()
402 i2c->getreg = oc_getreg_grlib; in ocores_i2c_of_probe()
408 #define ocores_i2c_of_probe(pdev,i2c) -ENODEV argument
413 struct ocores_i2c *i2c; in ocores_i2c_probe() local
424 i2c = devm_kzalloc(&pdev->dev, sizeof(*i2c), GFP_KERNEL); in ocores_i2c_probe()
425 if (!i2c) in ocores_i2c_probe()
429 i2c->base = devm_ioremap_resource(&pdev->dev, res); in ocores_i2c_probe()
430 if (IS_ERR(i2c->base)) in ocores_i2c_probe()
431 return PTR_ERR(i2c->base); in ocores_i2c_probe()
435 i2c->reg_shift = pdata->reg_shift; in ocores_i2c_probe()
436 i2c->reg_io_width = pdata->reg_io_width; in ocores_i2c_probe()
437 i2c->ip_clock_khz = pdata->clock_khz; in ocores_i2c_probe()
438 i2c->bus_clock_khz = 100; in ocores_i2c_probe()
440 ret = ocores_i2c_of_probe(pdev, i2c); in ocores_i2c_probe()
445 if (i2c->reg_io_width == 0) in ocores_i2c_probe()
446 i2c->reg_io_width = 1; /* Set to default value */ in ocores_i2c_probe()
448 if (!i2c->setreg || !i2c->getreg) { in ocores_i2c_probe()
452 switch (i2c->reg_io_width) { in ocores_i2c_probe()
454 i2c->setreg = oc_setreg_8; in ocores_i2c_probe()
455 i2c->getreg = oc_getreg_8; in ocores_i2c_probe()
459 i2c->setreg = be ? oc_setreg_16be : oc_setreg_16; in ocores_i2c_probe()
460 i2c->getreg = be ? oc_getreg_16be : oc_getreg_16; in ocores_i2c_probe()
464 i2c->setreg = be ? oc_setreg_32be : oc_setreg_32; in ocores_i2c_probe()
465 i2c->getreg = be ? oc_getreg_32be : oc_getreg_32; in ocores_i2c_probe()
470 i2c->reg_io_width); in ocores_i2c_probe()
476 ret = ocores_init(&pdev->dev, i2c); in ocores_i2c_probe()
480 init_waitqueue_head(&i2c->wait); in ocores_i2c_probe()
482 pdev->name, i2c); in ocores_i2c_probe()
489 platform_set_drvdata(pdev, i2c); in ocores_i2c_probe()
490 i2c->adap = ocores_adapter; in ocores_i2c_probe()
491 i2c_set_adapdata(&i2c->adap, i2c); in ocores_i2c_probe()
492 i2c->adap.dev.parent = &pdev->dev; in ocores_i2c_probe()
493 i2c->adap.dev.of_node = pdev->dev.of_node; in ocores_i2c_probe()
496 ret = i2c_add_adapter(&i2c->adap); in ocores_i2c_probe()
503 i2c_new_device(&i2c->adap, pdata->devices + i); in ocores_i2c_probe()
509 clk_disable_unprepare(i2c->clk); in ocores_i2c_probe()
515 struct ocores_i2c *i2c = platform_get_drvdata(pdev); in ocores_i2c_remove() local
518 oc_setreg(i2c, OCI2C_CONTROL, oc_getreg(i2c, OCI2C_CONTROL) in ocores_i2c_remove()
522 i2c_del_adapter(&i2c->adap); in ocores_i2c_remove()
524 if (!IS_ERR(i2c->clk)) in ocores_i2c_remove()
525 clk_disable_unprepare(i2c->clk); in ocores_i2c_remove()
533 struct ocores_i2c *i2c = dev_get_drvdata(dev); in ocores_i2c_suspend() local
534 u8 ctrl = oc_getreg(i2c, OCI2C_CONTROL); in ocores_i2c_suspend()
537 oc_setreg(i2c, OCI2C_CONTROL, ctrl & ~(OCI2C_CTRL_EN|OCI2C_CTRL_IEN)); in ocores_i2c_suspend()
539 if (!IS_ERR(i2c->clk)) in ocores_i2c_suspend()
540 clk_disable_unprepare(i2c->clk); in ocores_i2c_suspend()
546 struct ocores_i2c *i2c = dev_get_drvdata(dev); in ocores_i2c_resume() local
548 if (!IS_ERR(i2c->clk)) { in ocores_i2c_resume()
550 int ret = clk_prepare_enable(i2c->clk); in ocores_i2c_resume()
557 rate = clk_get_rate(i2c->clk) / 1000; in ocores_i2c_resume()
559 i2c->ip_clock_khz = rate; in ocores_i2c_resume()
561 return ocores_init(dev, i2c); in ocores_i2c_resume()