2 * Copyright (C) 2017 Sanechips Technology Co., Ltd.
3 * Copyright 2017 Linaro Ltd.
5 * Author: Baoyou Xie <baoyou.xie@linaro.org>
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
12 #include <linux/clk.h>
13 #include <linux/i2c.h>
14 #include <linux/interrupt.h>
16 #include <linux/module.h>
17 #include <linux/platform_device.h>
20 #define REG_DEVADDR_H 0x0C
21 #define REG_DEVADDR_L 0x10
22 #define REG_CLK_DIV_FS 0x14
23 #define REG_CLK_DIV_HS 0x18
24 #define REG_WRCONF 0x1C
25 #define REG_RDCONF 0x20
30 #define I2C_MASTER BIT(0)
31 #define I2C_ADDR_MODE_TEN BIT(1)
32 #define I2C_IRQ_MSK_ENABLE BIT(3)
33 #define I2C_RW_READ BIT(4)
34 #define I2C_CMB_RW_EN BIT(5)
35 #define I2C_START BIT(6)
37 #define I2C_ADDR_LOW_MASK GENMASK(6, 0)
38 #define I2C_ADDR_LOW_SHIFT 0
39 #define I2C_ADDR_HI_MASK GENMASK(2, 0)
40 #define I2C_ADDR_HI_SHIFT 7
42 #define I2C_WFIFO_RESET BIT(7)
43 #define I2C_RFIFO_RESET BIT(7)
45 #define I2C_IRQ_ACK_CLEAR BIT(7)
46 #define I2C_INT_MASK GENMASK(6, 0)
48 #define I2C_TRANS_DONE BIT(0)
49 #define I2C_SR_EDEVICE BIT(1)
50 #define I2C_SR_EDATA BIT(2)
52 #define I2C_FIFO_MAX 16
54 #define I2C_TIMEOUT msecs_to_jiffies(1000)
56 #define DEV(i2c) ((i2c)->adap.dev.parent)
59 struct i2c_adapter adap
;
61 struct completion complete
;
63 void __iomem
*reg_base
;
73 static void zx2967_i2c_writel(struct zx2967_i2c
*i2c
,
74 u32 val
, unsigned long reg
)
76 writel_relaxed(val
, i2c
->reg_base
+ reg
);
79 static u32
zx2967_i2c_readl(struct zx2967_i2c
*i2c
, unsigned long reg
)
81 return readl_relaxed(i2c
->reg_base
+ reg
);
84 static void zx2967_i2c_writesb(struct zx2967_i2c
*i2c
,
85 void *data
, unsigned long reg
, int len
)
87 writesb(i2c
->reg_base
+ reg
, data
, len
);
90 static void zx2967_i2c_readsb(struct zx2967_i2c
*i2c
,
91 void *data
, unsigned long reg
, int len
)
93 readsb(i2c
->reg_base
+ reg
, data
, len
);
96 static void zx2967_i2c_start_ctrl(struct zx2967_i2c
*i2c
)
101 status
= zx2967_i2c_readl(i2c
, REG_STAT
);
102 status
|= I2C_IRQ_ACK_CLEAR
;
103 zx2967_i2c_writel(i2c
, status
, REG_STAT
);
105 ctl
= zx2967_i2c_readl(i2c
, REG_CMD
);
110 ctl
&= ~I2C_CMB_RW_EN
;
112 zx2967_i2c_writel(i2c
, ctl
, REG_CMD
);
115 static void zx2967_i2c_flush_fifos(struct zx2967_i2c
*i2c
)
122 val
= I2C_RFIFO_RESET
;
125 val
= I2C_WFIFO_RESET
;
128 val
|= zx2967_i2c_readl(i2c
, offset
);
129 zx2967_i2c_writel(i2c
, val
, offset
);
132 static int zx2967_i2c_empty_rx_fifo(struct zx2967_i2c
*i2c
, u32 size
)
134 u8 val
[I2C_FIFO_MAX
] = {0};
137 if (size
> I2C_FIFO_MAX
) {
138 dev_err(DEV(i2c
), "fifo size %d over the max value %d\n",
143 zx2967_i2c_readsb(i2c
, val
, REG_DATA
, size
);
144 for (i
= 0; i
< size
; i
++) {
145 *i2c
->cur_trans
++ = val
[i
];
154 static int zx2967_i2c_fill_tx_fifo(struct zx2967_i2c
*i2c
)
156 size_t residue
= i2c
->residue
;
157 u8
*buf
= i2c
->cur_trans
;
160 dev_err(DEV(i2c
), "residue is %d\n", (int)residue
);
164 if (residue
<= I2C_FIFO_MAX
) {
165 zx2967_i2c_writesb(i2c
, buf
, REG_DATA
, residue
);
167 /* Again update before writing to FIFO to make sure isr sees. */
169 i2c
->cur_trans
= NULL
;
171 zx2967_i2c_writesb(i2c
, buf
, REG_DATA
, I2C_FIFO_MAX
);
172 i2c
->residue
-= I2C_FIFO_MAX
;
173 i2c
->cur_trans
+= I2C_FIFO_MAX
;
181 static int zx2967_i2c_reset_hardware(struct zx2967_i2c
*i2c
)
186 val
= I2C_MASTER
| I2C_IRQ_MSK_ENABLE
;
187 zx2967_i2c_writel(i2c
, val
, REG_CMD
);
189 clk_div
= clk_get_rate(i2c
->clk
) / i2c
->clk_freq
- 1;
190 zx2967_i2c_writel(i2c
, clk_div
, REG_CLK_DIV_FS
);
191 zx2967_i2c_writel(i2c
, clk_div
, REG_CLK_DIV_HS
);
193 zx2967_i2c_writel(i2c
, I2C_FIFO_MAX
- 1, REG_WRCONF
);
194 zx2967_i2c_writel(i2c
, I2C_FIFO_MAX
- 1, REG_RDCONF
);
195 zx2967_i2c_writel(i2c
, 1, REG_RDCONF
);
197 zx2967_i2c_flush_fifos(i2c
);
202 static void zx2967_i2c_isr_clr(struct zx2967_i2c
*i2c
)
206 status
= zx2967_i2c_readl(i2c
, REG_STAT
);
207 status
|= I2C_IRQ_ACK_CLEAR
;
208 zx2967_i2c_writel(i2c
, status
, REG_STAT
);
211 static irqreturn_t
zx2967_i2c_isr(int irq
, void *dev_id
)
214 struct zx2967_i2c
*i2c
= (struct zx2967_i2c
*)dev_id
;
216 status
= zx2967_i2c_readl(i2c
, REG_STAT
) & I2C_INT_MASK
;
217 zx2967_i2c_isr_clr(i2c
);
219 if (status
& I2C_SR_EDEVICE
)
221 else if (status
& I2C_SR_EDATA
)
223 else if (status
& I2C_TRANS_DONE
)
228 complete(&i2c
->complete
);
233 static void zx2967_set_addr(struct zx2967_i2c
*i2c
, u16 addr
)
237 val
= (addr
>> I2C_ADDR_LOW_SHIFT
) & I2C_ADDR_LOW_MASK
;
238 zx2967_i2c_writel(i2c
, val
, REG_DEVADDR_L
);
240 val
= (addr
>> I2C_ADDR_HI_SHIFT
) & I2C_ADDR_HI_MASK
;
241 zx2967_i2c_writel(i2c
, val
, REG_DEVADDR_H
);
243 val
= zx2967_i2c_readl(i2c
, REG_CMD
) | I2C_ADDR_MODE_TEN
;
245 val
= zx2967_i2c_readl(i2c
, REG_CMD
) & ~I2C_ADDR_MODE_TEN
;
246 zx2967_i2c_writel(i2c
, val
, REG_CMD
);
249 static int zx2967_i2c_xfer_bytes(struct zx2967_i2c
*i2c
, u32 bytes
)
251 unsigned long time_left
;
252 int rd
= i2c
->msg_rd
;
255 reinit_completion(&i2c
->complete
);
258 zx2967_i2c_writel(i2c
, bytes
- 1, REG_RDCONF
);
260 ret
= zx2967_i2c_fill_tx_fifo(i2c
);
265 zx2967_i2c_start_ctrl(i2c
);
267 time_left
= wait_for_completion_timeout(&i2c
->complete
,
275 return rd
? zx2967_i2c_empty_rx_fifo(i2c
, bytes
) : 0;
278 static int zx2967_i2c_xfer_msg(struct zx2967_i2c
*i2c
,
287 zx2967_i2c_flush_fifos(i2c
);
289 i2c
->cur_trans
= msg
->buf
;
290 i2c
->residue
= msg
->len
;
291 i2c
->access_cnt
= msg
->len
/ I2C_FIFO_MAX
;
292 i2c
->msg_rd
= msg
->flags
& I2C_M_RD
;
294 for (i
= 0; i
< i2c
->access_cnt
; i
++) {
295 ret
= zx2967_i2c_xfer_bytes(i2c
, I2C_FIFO_MAX
);
300 if (i2c
->residue
> 0) {
301 ret
= zx2967_i2c_xfer_bytes(i2c
, i2c
->residue
);
312 static int zx2967_i2c_xfer(struct i2c_adapter
*adap
,
313 struct i2c_msg
*msgs
, int num
)
315 struct zx2967_i2c
*i2c
= i2c_get_adapdata(adap
);
319 if (i2c
->is_suspended
)
322 zx2967_set_addr(i2c
, msgs
->addr
);
324 for (i
= 0; i
< num
; i
++) {
325 ret
= zx2967_i2c_xfer_msg(i2c
, &msgs
[i
]);
334 zx2967_smbus_xfer_prepare(struct zx2967_i2c
*i2c
, u16 addr
,
335 char read_write
, u8 command
, int size
,
336 union i2c_smbus_data
*data
)
340 val
= zx2967_i2c_readl(i2c
, REG_RDCONF
);
341 val
|= I2C_RFIFO_RESET
;
342 zx2967_i2c_writel(i2c
, val
, REG_RDCONF
);
343 zx2967_set_addr(i2c
, addr
);
344 val
= zx2967_i2c_readl(i2c
, REG_CMD
);
346 zx2967_i2c_writel(i2c
, val
, REG_CMD
);
350 zx2967_i2c_writel(i2c
, command
, REG_DATA
);
352 case I2C_SMBUS_BYTE_DATA
:
353 zx2967_i2c_writel(i2c
, command
, REG_DATA
);
354 if (read_write
== I2C_SMBUS_WRITE
)
355 zx2967_i2c_writel(i2c
, data
->byte
, REG_DATA
);
357 case I2C_SMBUS_WORD_DATA
:
358 zx2967_i2c_writel(i2c
, command
, REG_DATA
);
359 if (read_write
== I2C_SMBUS_WRITE
) {
360 zx2967_i2c_writel(i2c
, (data
->word
>> 8), REG_DATA
);
361 zx2967_i2c_writel(i2c
, (data
->word
& 0xff),
368 static int zx2967_smbus_xfer_read(struct zx2967_i2c
*i2c
, int size
,
369 union i2c_smbus_data
*data
)
371 unsigned long time_left
;
375 reinit_completion(&i2c
->complete
);
377 val
= zx2967_i2c_readl(i2c
, REG_CMD
);
378 val
|= I2C_CMB_RW_EN
;
379 zx2967_i2c_writel(i2c
, val
, REG_CMD
);
381 val
= zx2967_i2c_readl(i2c
, REG_CMD
);
383 zx2967_i2c_writel(i2c
, val
, REG_CMD
);
385 time_left
= wait_for_completion_timeout(&i2c
->complete
,
395 case I2C_SMBUS_BYTE_DATA
:
396 val
= zx2967_i2c_readl(i2c
, REG_DATA
);
399 case I2C_SMBUS_WORD_DATA
:
400 case I2C_SMBUS_PROC_CALL
:
401 buf
[0] = zx2967_i2c_readl(i2c
, REG_DATA
);
402 buf
[1] = zx2967_i2c_readl(i2c
, REG_DATA
);
403 data
->word
= (buf
[0] << 8) | buf
[1];
412 static int zx2967_smbus_xfer_write(struct zx2967_i2c
*i2c
)
414 unsigned long time_left
;
417 reinit_completion(&i2c
->complete
);
418 val
= zx2967_i2c_readl(i2c
, REG_CMD
);
420 zx2967_i2c_writel(i2c
, val
, REG_CMD
);
422 time_left
= wait_for_completion_timeout(&i2c
->complete
,
433 static int zx2967_smbus_xfer(struct i2c_adapter
*adap
, u16 addr
,
434 unsigned short flags
, char read_write
,
435 u8 command
, int size
, union i2c_smbus_data
*data
)
437 struct zx2967_i2c
*i2c
= i2c_get_adapdata(adap
);
439 if (size
== I2C_SMBUS_QUICK
)
440 read_write
= I2C_SMBUS_WRITE
;
443 case I2C_SMBUS_QUICK
:
445 case I2C_SMBUS_BYTE_DATA
:
446 case I2C_SMBUS_WORD_DATA
:
447 zx2967_smbus_xfer_prepare(i2c
, addr
, read_write
,
448 command
, size
, data
);
454 if (read_write
== I2C_SMBUS_READ
)
455 return zx2967_smbus_xfer_read(i2c
, size
, data
);
457 return zx2967_smbus_xfer_write(i2c
);
460 static u32
zx2967_i2c_func(struct i2c_adapter
*adap
)
462 return I2C_FUNC_I2C
|
463 I2C_FUNC_SMBUS_QUICK
|
464 I2C_FUNC_SMBUS_BYTE
|
465 I2C_FUNC_SMBUS_BYTE_DATA
|
466 I2C_FUNC_SMBUS_WORD_DATA
|
467 I2C_FUNC_SMBUS_BLOCK_DATA
|
468 I2C_FUNC_SMBUS_PROC_CALL
|
469 I2C_FUNC_SMBUS_I2C_BLOCK
;
472 static int __maybe_unused
zx2967_i2c_suspend(struct device
*dev
)
474 struct zx2967_i2c
*i2c
= dev_get_drvdata(dev
);
476 i2c
->is_suspended
= true;
477 clk_disable_unprepare(i2c
->clk
);
482 static int __maybe_unused
zx2967_i2c_resume(struct device
*dev
)
484 struct zx2967_i2c
*i2c
= dev_get_drvdata(dev
);
486 i2c
->is_suspended
= false;
487 clk_prepare_enable(i2c
->clk
);
492 static SIMPLE_DEV_PM_OPS(zx2967_i2c_dev_pm_ops
,
493 zx2967_i2c_suspend
, zx2967_i2c_resume
);
495 static const struct i2c_algorithm zx2967_i2c_algo
= {
496 .master_xfer
= zx2967_i2c_xfer
,
497 .smbus_xfer
= zx2967_smbus_xfer
,
498 .functionality
= zx2967_i2c_func
,
501 static const struct of_device_id zx2967_i2c_of_match
[] = {
502 { .compatible
= "zte,zx296718-i2c", },
505 MODULE_DEVICE_TABLE(of
, zx2967_i2c_of_match
);
507 static int zx2967_i2c_probe(struct platform_device
*pdev
)
509 struct zx2967_i2c
*i2c
;
510 void __iomem
*reg_base
;
511 struct resource
*res
;
515 i2c
= devm_kzalloc(&pdev
->dev
, sizeof(*i2c
), GFP_KERNEL
);
519 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
520 reg_base
= devm_ioremap_resource(&pdev
->dev
, res
);
521 if (IS_ERR(reg_base
))
522 return PTR_ERR(reg_base
);
524 clk
= devm_clk_get(&pdev
->dev
, NULL
);
526 dev_err(&pdev
->dev
, "missing controller clock");
530 ret
= clk_prepare_enable(clk
);
532 dev_err(&pdev
->dev
, "failed to enable i2c_clk\n");
536 ret
= device_property_read_u32(&pdev
->dev
, "clock-frequency",
539 dev_err(&pdev
->dev
, "missing clock-frequency");
543 ret
= platform_get_irq(pdev
, 0);
548 i2c
->reg_base
= reg_base
;
551 init_completion(&i2c
->complete
);
552 platform_set_drvdata(pdev
, i2c
);
554 ret
= zx2967_i2c_reset_hardware(i2c
);
556 dev_err(&pdev
->dev
, "failed to initialize i2c controller\n");
557 goto err_clk_unprepare
;
560 ret
= devm_request_irq(&pdev
->dev
, i2c
->irq
,
561 zx2967_i2c_isr
, 0, dev_name(&pdev
->dev
), i2c
);
563 dev_err(&pdev
->dev
, "failed to request irq %i\n", i2c
->irq
);
564 goto err_clk_unprepare
;
567 i2c_set_adapdata(&i2c
->adap
, i2c
);
568 strlcpy(i2c
->adap
.name
, "zx2967 i2c adapter",
569 sizeof(i2c
->adap
.name
));
570 i2c
->adap
.algo
= &zx2967_i2c_algo
;
571 i2c
->adap
.nr
= pdev
->id
;
572 i2c
->adap
.dev
.parent
= &pdev
->dev
;
573 i2c
->adap
.dev
.of_node
= pdev
->dev
.of_node
;
575 ret
= i2c_add_numbered_adapter(&i2c
->adap
);
577 goto err_clk_unprepare
;
582 clk_disable_unprepare(i2c
->clk
);
586 static int zx2967_i2c_remove(struct platform_device
*pdev
)
588 struct zx2967_i2c
*i2c
= platform_get_drvdata(pdev
);
590 i2c_del_adapter(&i2c
->adap
);
591 clk_disable_unprepare(i2c
->clk
);
596 static struct platform_driver zx2967_i2c_driver
= {
597 .probe
= zx2967_i2c_probe
,
598 .remove
= zx2967_i2c_remove
,
600 .name
= "zx2967_i2c",
601 .of_match_table
= zx2967_i2c_of_match
,
602 .pm
= &zx2967_i2c_dev_pm_ops
,
605 module_platform_driver(zx2967_i2c_driver
);
607 MODULE_AUTHOR("Baoyou Xie <baoyou.xie@linaro.org>");
608 MODULE_DESCRIPTION("ZTE ZX2967 I2C Bus Controller driver");
609 MODULE_LICENSE("GPL v2");