4 * Internal I2C bus driver for NetUP Universal Dual DVB-CI
6 * Copyright (C) 2014 NetUP Inc.
7 * Copyright (C) 2014 Sergey Kozlov <serjk@netup.ru>
8 * Copyright (C) 2014 Abylay Ospan <aospan@netup.ru>
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
21 #include <linux/module.h>
22 #include <linux/moduleparam.h>
23 #include <linux/init.h>
24 #include <linux/delay.h>
25 #include "netup_unidvb.h"
27 #define NETUP_I2C_BUS0_ADDR 0x4800
28 #define NETUP_I2C_BUS1_ADDR 0x4840
29 #define NETUP_I2C_TIMEOUT 1000
31 /* twi_ctrl0_stat reg bits */
32 #define TWI_IRQEN_COMPL 0x1
33 #define TWI_IRQEN_ANACK 0x2
34 #define TWI_IRQEN_DNACK 0x4
35 #define TWI_IRQ_COMPL (TWI_IRQEN_COMPL << 8)
36 #define TWI_IRQ_ANACK (TWI_IRQEN_ANACK << 8)
37 #define TWI_IRQ_DNACK (TWI_IRQEN_DNACK << 8)
38 #define TWI_IRQ_TX 0x800
39 #define TWI_IRQ_RX 0x1000
40 #define TWI_IRQEN (TWI_IRQEN_COMPL | TWI_IRQEN_ANACK | TWI_IRQEN_DNACK)
41 /* twi_addr_ctrl1 reg bits*/
42 #define TWI_TRANSFER 0x100
43 #define TWI_NOSTOP 0x200
44 #define TWI_SOFT_RESET 0x2000
45 /* twi_clkdiv reg value */
46 #define TWI_CLKDIV 156
47 /* fifo_stat_ctrl reg bits */
48 #define FIFO_IRQEN 0x8000
49 #define FIFO_RESET 0x4000
53 struct netup_i2c_fifo_regs
{
61 } __packed
__aligned(1);
63 struct netup_i2c_regs
{
65 __le16 twi_ctrl0_stat
;
66 __le16 twi_addr_ctrl1
;
69 struct netup_i2c_fifo_regs tx_fifo
;
71 struct netup_i2c_fifo_regs rx_fifo
;
72 } __packed
__aligned(1);
74 irqreturn_t
netup_i2c_interrupt(struct netup_i2c
*i2c
)
78 irqreturn_t iret
= IRQ_HANDLED
;
80 spin_lock_irqsave(&i2c
->lock
, flags
);
81 reg
= readw(&i2c
->regs
->twi_ctrl0_stat
);
82 writew(reg
& ~TWI_IRQEN
, &i2c
->regs
->twi_ctrl0_stat
);
83 dev_dbg(i2c
->adap
.dev
.parent
,
84 "%s(): twi_ctrl0_state 0x%x\n", __func__
, reg
);
85 if ((reg
& TWI_IRQEN_COMPL
) != 0 && (reg
& TWI_IRQ_COMPL
)) {
86 dev_dbg(i2c
->adap
.dev
.parent
,
87 "%s(): TWI_IRQEN_COMPL\n", __func__
);
88 i2c
->state
= STATE_DONE
;
91 if ((reg
& TWI_IRQEN_ANACK
) != 0 && (reg
& TWI_IRQ_ANACK
)) {
92 dev_dbg(i2c
->adap
.dev
.parent
,
93 "%s(): TWI_IRQEN_ANACK\n", __func__
);
94 i2c
->state
= STATE_ERROR
;
97 if ((reg
& TWI_IRQEN_DNACK
) != 0 && (reg
& TWI_IRQ_DNACK
)) {
98 dev_dbg(i2c
->adap
.dev
.parent
,
99 "%s(): TWI_IRQEN_DNACK\n", __func__
);
100 i2c
->state
= STATE_ERROR
;
103 if ((reg
& TWI_IRQ_RX
) != 0) {
104 tmp
= readw(&i2c
->regs
->rx_fifo
.stat_ctrl
);
105 writew(tmp
& ~FIFO_IRQEN
, &i2c
->regs
->rx_fifo
.stat_ctrl
);
106 i2c
->state
= STATE_WANT_READ
;
107 dev_dbg(i2c
->adap
.dev
.parent
,
108 "%s(): want read\n", __func__
);
111 if ((reg
& TWI_IRQ_TX
) != 0) {
112 tmp
= readw(&i2c
->regs
->tx_fifo
.stat_ctrl
);
113 writew(tmp
& ~FIFO_IRQEN
, &i2c
->regs
->tx_fifo
.stat_ctrl
);
114 i2c
->state
= STATE_WANT_WRITE
;
115 dev_dbg(i2c
->adap
.dev
.parent
,
116 "%s(): want write\n", __func__
);
119 dev_warn(&i2c
->adap
.dev
, "%s(): not mine interrupt\n", __func__
);
122 spin_unlock_irqrestore(&i2c
->lock
, flags
);
123 if (iret
== IRQ_HANDLED
)
128 static void netup_i2c_reset(struct netup_i2c
*i2c
)
130 dev_dbg(i2c
->adap
.dev
.parent
, "%s()\n", __func__
);
131 i2c
->state
= STATE_DONE
;
132 writew(TWI_SOFT_RESET
, &i2c
->regs
->twi_addr_ctrl1
);
133 writew(TWI_CLKDIV
, &i2c
->regs
->clkdiv
);
134 writew(FIFO_RESET
, &i2c
->regs
->tx_fifo
.stat_ctrl
);
135 writew(FIFO_RESET
, &i2c
->regs
->rx_fifo
.stat_ctrl
);
136 writew(0x800, &i2c
->regs
->tx_fifo
.stat_ctrl
);
137 writew(0x800, &i2c
->regs
->rx_fifo
.stat_ctrl
);
140 static void netup_i2c_fifo_tx(struct netup_i2c
*i2c
)
143 u32 fifo_space
= FIFO_SIZE
-
144 (readw(&i2c
->regs
->tx_fifo
.stat_ctrl
) & 0x3f);
145 u32 msg_length
= i2c
->msg
->len
- i2c
->xmit_size
;
147 msg_length
= (msg_length
< fifo_space
? msg_length
: fifo_space
);
148 while (msg_length
--) {
149 data
= i2c
->msg
->buf
[i2c
->xmit_size
++];
150 writeb(data
, &i2c
->regs
->tx_fifo
.data8
);
151 dev_dbg(i2c
->adap
.dev
.parent
,
152 "%s(): write 0x%02x\n", __func__
, data
);
154 if (i2c
->xmit_size
< i2c
->msg
->len
) {
155 dev_dbg(i2c
->adap
.dev
.parent
,
156 "%s(): TX IRQ enabled\n", __func__
);
157 writew(readw(&i2c
->regs
->tx_fifo
.stat_ctrl
) | FIFO_IRQEN
,
158 &i2c
->regs
->tx_fifo
.stat_ctrl
);
162 static void netup_i2c_fifo_rx(struct netup_i2c
*i2c
)
165 u32 fifo_size
= readw(&i2c
->regs
->rx_fifo
.stat_ctrl
) & 0x3f;
167 dev_dbg(i2c
->adap
.dev
.parent
,
168 "%s(): RX fifo size %d\n", __func__
, fifo_size
);
169 while (fifo_size
--) {
170 data
= readb(&i2c
->regs
->rx_fifo
.data8
);
171 if ((i2c
->msg
->flags
& I2C_M_RD
) != 0 &&
172 i2c
->xmit_size
< i2c
->msg
->len
) {
173 i2c
->msg
->buf
[i2c
->xmit_size
++] = data
;
174 dev_dbg(i2c
->adap
.dev
.parent
,
175 "%s(): read 0x%02x\n", __func__
, data
);
178 if (i2c
->xmit_size
< i2c
->msg
->len
) {
179 dev_dbg(i2c
->adap
.dev
.parent
,
180 "%s(): RX IRQ enabled\n", __func__
);
181 writew(readw(&i2c
->regs
->rx_fifo
.stat_ctrl
) | FIFO_IRQEN
,
182 &i2c
->regs
->rx_fifo
.stat_ctrl
);
186 static void netup_i2c_start_xfer(struct netup_i2c
*i2c
)
188 u16 rdflag
= ((i2c
->msg
->flags
& I2C_M_RD
) ? 1 : 0);
189 u16 reg
= readw(&i2c
->regs
->twi_ctrl0_stat
);
191 writew(TWI_IRQEN
| reg
, &i2c
->regs
->twi_ctrl0_stat
);
192 writew(i2c
->msg
->len
, &i2c
->regs
->length
);
193 writew(TWI_TRANSFER
| (i2c
->msg
->addr
<< 1) | rdflag
,
194 &i2c
->regs
->twi_addr_ctrl1
);
195 dev_dbg(i2c
->adap
.dev
.parent
,
196 "%s(): length %d twi_addr_ctrl1 0x%x twi_ctrl0_stat 0x%x\n",
197 __func__
, readw(&i2c
->regs
->length
),
198 readw(&i2c
->regs
->twi_addr_ctrl1
),
199 readw(&i2c
->regs
->twi_ctrl0_stat
));
200 i2c
->state
= STATE_WAIT
;
203 netup_i2c_fifo_tx(i2c
);
205 writew(FIFO_IRQEN
| readw(&i2c
->regs
->rx_fifo
.stat_ctrl
),
206 &i2c
->regs
->rx_fifo
.stat_ctrl
);
209 static int netup_i2c_xfer(struct i2c_adapter
*adap
,
210 struct i2c_msg
*msgs
, int num
)
213 int i
, trans_done
, res
= num
;
214 struct netup_i2c
*i2c
= i2c_get_adapdata(adap
);
217 spin_lock_irqsave(&i2c
->lock
, flags
);
218 if (i2c
->state
!= STATE_DONE
) {
219 dev_dbg(i2c
->adap
.dev
.parent
,
220 "%s(): i2c->state == %d, resetting I2C\n",
221 __func__
, i2c
->state
);
222 netup_i2c_reset(i2c
);
224 dev_dbg(i2c
->adap
.dev
.parent
, "%s() num %d\n", __func__
, num
);
225 for (i
= 0; i
< num
; i
++) {
227 netup_i2c_start_xfer(i2c
);
229 while (!trans_done
) {
230 spin_unlock_irqrestore(&i2c
->lock
, flags
);
231 if (wait_event_timeout(i2c
->wq
,
232 i2c
->state
!= STATE_WAIT
,
233 msecs_to_jiffies(NETUP_I2C_TIMEOUT
))) {
234 spin_lock_irqsave(&i2c
->lock
, flags
);
235 switch (i2c
->state
) {
236 case STATE_WANT_READ
:
237 netup_i2c_fifo_rx(i2c
);
239 case STATE_WANT_WRITE
:
240 netup_i2c_fifo_tx(i2c
);
243 if ((i2c
->msg
->flags
& I2C_M_RD
) != 0 &&
244 i2c
->xmit_size
!= i2c
->msg
->len
)
245 netup_i2c_fifo_rx(i2c
);
246 dev_dbg(i2c
->adap
.dev
.parent
,
253 dev_dbg(i2c
->adap
.dev
.parent
,
254 "%s(): error state\n",
258 dev_dbg(i2c
->adap
.dev
.parent
,
259 "%s(): invalid state %d\n",
260 __func__
, i2c
->state
);
265 i2c
->state
= STATE_WAIT
;
267 &i2c
->regs
->twi_ctrl0_stat
);
268 writew(TWI_IRQEN
| reg
,
269 &i2c
->regs
->twi_ctrl0_stat
);
271 spin_unlock_irqrestore(&i2c
->lock
, flags
);
273 spin_lock_irqsave(&i2c
->lock
, flags
);
274 dev_dbg(i2c
->adap
.dev
.parent
,
275 "%s(): wait timeout\n", __func__
);
279 spin_lock_irqsave(&i2c
->lock
, flags
);
283 spin_unlock_irqrestore(&i2c
->lock
, flags
);
284 dev_dbg(i2c
->adap
.dev
.parent
, "%s(): result %d\n", __func__
, res
);
288 static u32
netup_i2c_func(struct i2c_adapter
*adap
)
290 return I2C_FUNC_I2C
| I2C_FUNC_SMBUS_EMUL
;
293 static const struct i2c_algorithm netup_i2c_algorithm
= {
294 .master_xfer
= netup_i2c_xfer
,
295 .functionality
= netup_i2c_func
,
298 static const struct i2c_adapter netup_i2c_adapter
= {
299 .owner
= THIS_MODULE
,
300 .name
= NETUP_UNIDVB_NAME
,
301 .class = I2C_CLASS_HWMON
| I2C_CLASS_SPD
,
302 .algo
= &netup_i2c_algorithm
,
305 static int netup_i2c_init(struct netup_unidvb_dev
*ndev
, int bus_num
)
308 struct netup_i2c
*i2c
;
310 if (bus_num
< 0 || bus_num
> 1) {
311 dev_err(&ndev
->pci_dev
->dev
,
312 "%s(): invalid bus_num %d\n", __func__
, bus_num
);
315 i2c
= &ndev
->i2c
[bus_num
];
316 spin_lock_init(&i2c
->lock
);
317 init_waitqueue_head(&i2c
->wq
);
318 i2c
->regs
= (struct netup_i2c_regs __iomem
*)(ndev
->bmmio0
+
319 (bus_num
== 0 ? NETUP_I2C_BUS0_ADDR
: NETUP_I2C_BUS1_ADDR
));
320 netup_i2c_reset(i2c
);
321 i2c
->adap
= netup_i2c_adapter
;
322 i2c
->adap
.dev
.parent
= &ndev
->pci_dev
->dev
;
323 i2c_set_adapdata(&i2c
->adap
, i2c
);
324 ret
= i2c_add_adapter(&i2c
->adap
);
327 dev_info(&ndev
->pci_dev
->dev
,
328 "%s(): registered I2C bus %d at 0x%x\n",
330 bus_num
, (bus_num
== 0 ?
331 NETUP_I2C_BUS0_ADDR
:
332 NETUP_I2C_BUS1_ADDR
));
336 static void netup_i2c_remove(struct netup_unidvb_dev
*ndev
, int bus_num
)
338 struct netup_i2c
*i2c
;
340 if (bus_num
< 0 || bus_num
> 1) {
341 dev_err(&ndev
->pci_dev
->dev
,
342 "%s(): invalid bus number %d\n", __func__
, bus_num
);
345 i2c
= &ndev
->i2c
[bus_num
];
346 netup_i2c_reset(i2c
);
348 i2c_del_adapter(&i2c
->adap
);
349 dev_info(&ndev
->pci_dev
->dev
,
350 "netup_i2c_remove: unregistered I2C bus %d\n", bus_num
);
353 int netup_i2c_register(struct netup_unidvb_dev
*ndev
)
357 ret
= netup_i2c_init(ndev
, 0);
360 ret
= netup_i2c_init(ndev
, 1);
362 netup_i2c_remove(ndev
, 0);
368 void netup_i2c_unregister(struct netup_unidvb_dev
*ndev
)
370 netup_i2c_remove(ndev
, 0);
371 netup_i2c_remove(ndev
, 1);