xref: /openbmc/linux/drivers/i2c/busses/i2c-pnx.c (revision df2634f43f5106947f3735a0b61a6527a4b278cd)
1 /*
2  * Provides I2C support for Philips PNX010x/PNX4008 boards.
3  *
4  * Authors: Dennis Kovalev <dkovalev@ru.mvista.com>
5  *	    Vitaly Wool <vwool@ru.mvista.com>
6  *
7  * 2004-2006 (c) MontaVista Software, Inc. This file is licensed under
8  * the terms of the GNU General Public License version 2. This program
9  * is licensed "as is" without any warranty of any kind, whether express
10  * or implied.
11  */
12 
13 #include <linux/module.h>
14 #include <linux/interrupt.h>
15 #include <linux/ioport.h>
16 #include <linux/delay.h>
17 #include <linux/i2c.h>
18 #include <linux/timer.h>
19 #include <linux/completion.h>
20 #include <linux/platform_device.h>
21 #include <linux/i2c-pnx.h>
22 #include <linux/io.h>
23 #include <linux/err.h>
24 #include <linux/clk.h>
25 #include <linux/slab.h>
26 
27 #include <mach/hardware.h>
28 #include <mach/i2c.h>
29 
30 #define I2C_PNX_TIMEOUT		10 /* msec */
31 #define I2C_PNX_SPEED_KHZ	100
32 #define I2C_PNX_REGION_SIZE	0x100
33 
34 static inline int wait_timeout(long timeout, struct i2c_pnx_algo_data *data)
35 {
36 	while (timeout > 0 &&
37 			(ioread32(I2C_REG_STS(data)) & mstatus_active)) {
38 		mdelay(1);
39 		timeout--;
40 	}
41 	return (timeout <= 0);
42 }
43 
44 static inline int wait_reset(long timeout, struct i2c_pnx_algo_data *data)
45 {
46 	while (timeout > 0 &&
47 			(ioread32(I2C_REG_CTL(data)) & mcntrl_reset)) {
48 		mdelay(1);
49 		timeout--;
50 	}
51 	return (timeout <= 0);
52 }
53 
54 static inline void i2c_pnx_arm_timer(struct i2c_pnx_algo_data *alg_data)
55 {
56 	struct timer_list *timer = &alg_data->mif.timer;
57 	unsigned long expires = msecs_to_jiffies(I2C_PNX_TIMEOUT);
58 
59 	if (expires <= 1)
60 		expires = 2;
61 
62 	del_timer_sync(timer);
63 
64 	dev_dbg(&alg_data->adapter.dev, "Timer armed at %lu plus %lu jiffies.\n",
65 		jiffies, expires);
66 
67 	timer->expires = jiffies + expires;
68 	timer->data = (unsigned long)&alg_data;
69 
70 	add_timer(timer);
71 }
72 
73 /**
74  * i2c_pnx_start - start a device
75  * @slave_addr:		slave address
76  * @adap:		pointer to adapter structure
77  *
78  * Generate a START signal in the desired mode.
79  */
80 static int i2c_pnx_start(unsigned char slave_addr,
81 	struct i2c_pnx_algo_data *alg_data)
82 {
83 	dev_dbg(&alg_data->adapter.dev, "%s(): addr 0x%x mode %d\n", __func__,
84 		slave_addr, alg_data->mif.mode);
85 
86 	/* Check for 7 bit slave addresses only */
87 	if (slave_addr & ~0x7f) {
88 		dev_err(&alg_data->adapter.dev,
89 			"%s: Invalid slave address %x. Only 7-bit addresses are supported\n",
90 			alg_data->adapter.name, slave_addr);
91 		return -EINVAL;
92 	}
93 
94 	/* First, make sure bus is idle */
95 	if (wait_timeout(I2C_PNX_TIMEOUT, alg_data)) {
96 		/* Somebody else is monopolizing the bus */
97 		dev_err(&alg_data->adapter.dev,
98 			"%s: Bus busy. Slave addr = %02x, cntrl = %x, stat = %x\n",
99 			alg_data->adapter.name, slave_addr,
100 			ioread32(I2C_REG_CTL(alg_data)),
101 			ioread32(I2C_REG_STS(alg_data)));
102 		return -EBUSY;
103 	} else if (ioread32(I2C_REG_STS(alg_data)) & mstatus_afi) {
104 		/* Sorry, we lost the bus */
105 		dev_err(&alg_data->adapter.dev,
106 		        "%s: Arbitration failure. Slave addr = %02x\n",
107 			alg_data->adapter.name, slave_addr);
108 		return -EIO;
109 	}
110 
111 	/*
112 	 * OK, I2C is enabled and we have the bus.
113 	 * Clear the current TDI and AFI status flags.
114 	 */
115 	iowrite32(ioread32(I2C_REG_STS(alg_data)) | mstatus_tdi | mstatus_afi,
116 		  I2C_REG_STS(alg_data));
117 
118 	dev_dbg(&alg_data->adapter.dev, "%s(): sending %#x\n", __func__,
119 		(slave_addr << 1) | start_bit | alg_data->mif.mode);
120 
121 	/* Write the slave address, START bit and R/W bit */
122 	iowrite32((slave_addr << 1) | start_bit | alg_data->mif.mode,
123 		  I2C_REG_TX(alg_data));
124 
125 	dev_dbg(&alg_data->adapter.dev, "%s(): exit\n", __func__);
126 
127 	return 0;
128 }
129 
130 /**
131  * i2c_pnx_stop - stop a device
132  * @adap:		pointer to I2C adapter structure
133  *
134  * Generate a STOP signal to terminate the master transaction.
135  */
136 static void i2c_pnx_stop(struct i2c_pnx_algo_data *alg_data)
137 {
138 	/* Only 1 msec max timeout due to interrupt context */
139 	long timeout = 1000;
140 
141 	dev_dbg(&alg_data->adapter.dev, "%s(): entering: stat = %04x.\n",
142 		__func__, ioread32(I2C_REG_STS(alg_data)));
143 
144 	/* Write a STOP bit to TX FIFO */
145 	iowrite32(0xff | stop_bit, I2C_REG_TX(alg_data));
146 
147 	/* Wait until the STOP is seen. */
148 	while (timeout > 0 &&
149 	       (ioread32(I2C_REG_STS(alg_data)) & mstatus_active)) {
150 		/* may be called from interrupt context */
151 		udelay(1);
152 		timeout--;
153 	}
154 
155 	dev_dbg(&alg_data->adapter.dev, "%s(): exiting: stat = %04x.\n",
156 		__func__, ioread32(I2C_REG_STS(alg_data)));
157 }
158 
159 /**
160  * i2c_pnx_master_xmit - transmit data to slave
161  * @adap:		pointer to I2C adapter structure
162  *
163  * Sends one byte of data to the slave
164  */
165 static int i2c_pnx_master_xmit(struct i2c_pnx_algo_data *alg_data)
166 {
167 	u32 val;
168 
169 	dev_dbg(&alg_data->adapter.dev, "%s(): entering: stat = %04x.\n",
170 		__func__, ioread32(I2C_REG_STS(alg_data)));
171 
172 	if (alg_data->mif.len > 0) {
173 		/* We still have something to talk about... */
174 		val = *alg_data->mif.buf++;
175 
176 		if (alg_data->mif.len == 1)
177 			val |= stop_bit;
178 
179 		alg_data->mif.len--;
180 		iowrite32(val, I2C_REG_TX(alg_data));
181 
182 		dev_dbg(&alg_data->adapter.dev, "%s(): xmit %#x [%d]\n",
183 			__func__, val, alg_data->mif.len + 1);
184 
185 		if (alg_data->mif.len == 0) {
186 			if (alg_data->last) {
187 				/* Wait until the STOP is seen. */
188 				if (wait_timeout(I2C_PNX_TIMEOUT, alg_data))
189 					dev_err(&alg_data->adapter.dev,
190 						"The bus is still active after timeout\n");
191 			}
192 			/* Disable master interrupts */
193 			iowrite32(ioread32(I2C_REG_CTL(alg_data)) &
194 				~(mcntrl_afie | mcntrl_naie | mcntrl_drmie),
195 				  I2C_REG_CTL(alg_data));
196 
197 			del_timer_sync(&alg_data->mif.timer);
198 
199 			dev_dbg(&alg_data->adapter.dev,
200 				"%s(): Waking up xfer routine.\n",
201 				__func__);
202 
203 			complete(&alg_data->mif.complete);
204 		}
205 	} else if (alg_data->mif.len == 0) {
206 		/* zero-sized transfer */
207 		i2c_pnx_stop(alg_data);
208 
209 		/* Disable master interrupts. */
210 		iowrite32(ioread32(I2C_REG_CTL(alg_data)) &
211 			~(mcntrl_afie | mcntrl_naie | mcntrl_drmie),
212 			  I2C_REG_CTL(alg_data));
213 
214 		/* Stop timer. */
215 		del_timer_sync(&alg_data->mif.timer);
216 		dev_dbg(&alg_data->adapter.dev,
217 			"%s(): Waking up xfer routine after zero-xfer.\n",
218 			__func__);
219 
220 		complete(&alg_data->mif.complete);
221 	}
222 
223 	dev_dbg(&alg_data->adapter.dev, "%s(): exiting: stat = %04x.\n",
224 		__func__, ioread32(I2C_REG_STS(alg_data)));
225 
226 	return 0;
227 }
228 
229 /**
230  * i2c_pnx_master_rcv - receive data from slave
231  * @adap:		pointer to I2C adapter structure
232  *
233  * Reads one byte data from the slave
234  */
235 static int i2c_pnx_master_rcv(struct i2c_pnx_algo_data *alg_data)
236 {
237 	unsigned int val = 0;
238 	u32 ctl = 0;
239 
240 	dev_dbg(&alg_data->adapter.dev, "%s(): entering: stat = %04x.\n",
241 		__func__, ioread32(I2C_REG_STS(alg_data)));
242 
243 	/* Check, whether there is already data,
244 	 * or we didn't 'ask' for it yet.
245 	 */
246 	if (ioread32(I2C_REG_STS(alg_data)) & mstatus_rfe) {
247 		dev_dbg(&alg_data->adapter.dev,
248 			"%s(): Write dummy data to fill Rx-fifo...\n",
249 			__func__);
250 
251 		if (alg_data->mif.len == 1) {
252 			/* Last byte, do not acknowledge next rcv. */
253 			val |= stop_bit;
254 
255 			/*
256 			 * Enable interrupt RFDAIE (data in Rx fifo),
257 			 * and disable DRMIE (need data for Tx)
258 			 */
259 			ctl = ioread32(I2C_REG_CTL(alg_data));
260 			ctl |= mcntrl_rffie | mcntrl_daie;
261 			ctl &= ~mcntrl_drmie;
262 			iowrite32(ctl, I2C_REG_CTL(alg_data));
263 		}
264 
265 		/*
266 		 * Now we'll 'ask' for data:
267 		 * For each byte we want to receive, we must
268 		 * write a (dummy) byte to the Tx-FIFO.
269 		 */
270 		iowrite32(val, I2C_REG_TX(alg_data));
271 
272 		return 0;
273 	}
274 
275 	/* Handle data. */
276 	if (alg_data->mif.len > 0) {
277 		val = ioread32(I2C_REG_RX(alg_data));
278 		*alg_data->mif.buf++ = (u8) (val & 0xff);
279 		dev_dbg(&alg_data->adapter.dev, "%s(): rcv 0x%x [%d]\n",
280 			__func__, val, alg_data->mif.len);
281 
282 		alg_data->mif.len--;
283 		if (alg_data->mif.len == 0) {
284 			if (alg_data->last)
285 				/* Wait until the STOP is seen. */
286 				if (wait_timeout(I2C_PNX_TIMEOUT, alg_data))
287 					dev_err(&alg_data->adapter.dev,
288 						"The bus is still active after timeout\n");
289 
290 			/* Disable master interrupts */
291 			ctl = ioread32(I2C_REG_CTL(alg_data));
292 			ctl &= ~(mcntrl_afie | mcntrl_naie | mcntrl_rffie |
293 				 mcntrl_drmie | mcntrl_daie);
294 			iowrite32(ctl, I2C_REG_CTL(alg_data));
295 
296 			/* Kill timer. */
297 			del_timer_sync(&alg_data->mif.timer);
298 			complete(&alg_data->mif.complete);
299 		}
300 	}
301 
302 	dev_dbg(&alg_data->adapter.dev, "%s(): exiting: stat = %04x.\n",
303 		__func__, ioread32(I2C_REG_STS(alg_data)));
304 
305 	return 0;
306 }
307 
308 static irqreturn_t i2c_pnx_interrupt(int irq, void *dev_id)
309 {
310 	struct i2c_pnx_algo_data *alg_data = dev_id;
311 	u32 stat, ctl;
312 
313 	dev_dbg(&alg_data->adapter.dev,
314 		"%s(): mstat = %x mctrl = %x, mode = %d\n",
315 		__func__,
316 		ioread32(I2C_REG_STS(alg_data)),
317 		ioread32(I2C_REG_CTL(alg_data)),
318 		alg_data->mif.mode);
319 	stat = ioread32(I2C_REG_STS(alg_data));
320 
321 	/* let's see what kind of event this is */
322 	if (stat & mstatus_afi) {
323 		/* We lost arbitration in the midst of a transfer */
324 		alg_data->mif.ret = -EIO;
325 
326 		/* Disable master interrupts. */
327 		ctl = ioread32(I2C_REG_CTL(alg_data));
328 		ctl &= ~(mcntrl_afie | mcntrl_naie | mcntrl_rffie |
329 			 mcntrl_drmie);
330 		iowrite32(ctl, I2C_REG_CTL(alg_data));
331 
332 		/* Stop timer, to prevent timeout. */
333 		del_timer_sync(&alg_data->mif.timer);
334 		complete(&alg_data->mif.complete);
335 	} else if (stat & mstatus_nai) {
336 		/* Slave did not acknowledge, generate a STOP */
337 		dev_dbg(&alg_data->adapter.dev,
338 			"%s(): Slave did not acknowledge, generating a STOP.\n",
339 			__func__);
340 		i2c_pnx_stop(alg_data);
341 
342 		/* Disable master interrupts. */
343 		ctl = ioread32(I2C_REG_CTL(alg_data));
344 		ctl &= ~(mcntrl_afie | mcntrl_naie | mcntrl_rffie |
345 			 mcntrl_drmie);
346 		iowrite32(ctl, I2C_REG_CTL(alg_data));
347 
348 		/* Our return value. */
349 		alg_data->mif.ret = -EIO;
350 
351 		/* Stop timer, to prevent timeout. */
352 		del_timer_sync(&alg_data->mif.timer);
353 		complete(&alg_data->mif.complete);
354 	} else {
355 		/*
356 		 * Two options:
357 		 * - Master Tx needs data.
358 		 * - There is data in the Rx-fifo
359 		 * The latter is only the case if we have requested for data,
360 		 * via a dummy write. (See 'i2c_pnx_master_rcv'.)
361 		 * We therefore check, as a sanity check, whether that interrupt
362 		 * has been enabled.
363 		 */
364 		if ((stat & mstatus_drmi) || !(stat & mstatus_rfe)) {
365 			if (alg_data->mif.mode == I2C_SMBUS_WRITE) {
366 				i2c_pnx_master_xmit(alg_data);
367 			} else if (alg_data->mif.mode == I2C_SMBUS_READ) {
368 				i2c_pnx_master_rcv(alg_data);
369 			}
370 		}
371 	}
372 
373 	/* Clear TDI and AFI bits */
374 	stat = ioread32(I2C_REG_STS(alg_data));
375 	iowrite32(stat | mstatus_tdi | mstatus_afi, I2C_REG_STS(alg_data));
376 
377 	dev_dbg(&alg_data->adapter.dev,
378 		"%s(): exiting, stat = %x ctrl = %x.\n",
379 		 __func__, ioread32(I2C_REG_STS(alg_data)),
380 		 ioread32(I2C_REG_CTL(alg_data)));
381 
382 	return IRQ_HANDLED;
383 }
384 
385 static void i2c_pnx_timeout(unsigned long data)
386 {
387 	struct i2c_pnx_algo_data *alg_data = (struct i2c_pnx_algo_data *)data;
388 	u32 ctl;
389 
390 	dev_err(&alg_data->adapter.dev,
391 		"Master timed out. stat = %04x, cntrl = %04x. Resetting master...\n",
392 		ioread32(I2C_REG_STS(alg_data)),
393 		ioread32(I2C_REG_CTL(alg_data)));
394 
395 	/* Reset master and disable interrupts */
396 	ctl = ioread32(I2C_REG_CTL(alg_data));
397 	ctl &= ~(mcntrl_afie | mcntrl_naie | mcntrl_rffie | mcntrl_drmie);
398 	iowrite32(ctl, I2C_REG_CTL(alg_data));
399 
400 	ctl |= mcntrl_reset;
401 	iowrite32(ctl, I2C_REG_CTL(alg_data));
402 	wait_reset(I2C_PNX_TIMEOUT, alg_data);
403 	alg_data->mif.ret = -EIO;
404 	complete(&alg_data->mif.complete);
405 }
406 
407 static inline void bus_reset_if_active(struct i2c_pnx_algo_data *alg_data)
408 {
409 	u32 stat;
410 
411 	if ((stat = ioread32(I2C_REG_STS(alg_data))) & mstatus_active) {
412 		dev_err(&alg_data->adapter.dev,
413 			"%s: Bus is still active after xfer. Reset it...\n",
414 			alg_data->adapter.name);
415 		iowrite32(ioread32(I2C_REG_CTL(alg_data)) | mcntrl_reset,
416 			  I2C_REG_CTL(alg_data));
417 		wait_reset(I2C_PNX_TIMEOUT, alg_data);
418 	} else if (!(stat & mstatus_rfe) || !(stat & mstatus_tfe)) {
419 		/* If there is data in the fifo's after transfer,
420 		 * flush fifo's by reset.
421 		 */
422 		iowrite32(ioread32(I2C_REG_CTL(alg_data)) | mcntrl_reset,
423 			  I2C_REG_CTL(alg_data));
424 		wait_reset(I2C_PNX_TIMEOUT, alg_data);
425 	} else if (stat & mstatus_nai) {
426 		iowrite32(ioread32(I2C_REG_CTL(alg_data)) | mcntrl_reset,
427 			  I2C_REG_CTL(alg_data));
428 		wait_reset(I2C_PNX_TIMEOUT, alg_data);
429 	}
430 }
431 
432 /**
433  * i2c_pnx_xfer - generic transfer entry point
434  * @adap:		pointer to I2C adapter structure
435  * @msgs:		array of messages
436  * @num:		number of messages
437  *
438  * Initiates the transfer
439  */
440 static int
441 i2c_pnx_xfer(struct i2c_adapter *adap, struct i2c_msg *msgs, int num)
442 {
443 	struct i2c_msg *pmsg;
444 	int rc = 0, completed = 0, i;
445 	struct i2c_pnx_algo_data *alg_data = adap->algo_data;
446 	u32 stat = ioread32(I2C_REG_STS(alg_data));
447 
448 	dev_dbg(&alg_data->adapter.dev,
449 		"%s(): entering: %d messages, stat = %04x.\n",
450 		__func__, num, ioread32(I2C_REG_STS(alg_data)));
451 
452 	bus_reset_if_active(alg_data);
453 
454 	/* Process transactions in a loop. */
455 	for (i = 0; rc >= 0 && i < num; i++) {
456 		u8 addr;
457 
458 		pmsg = &msgs[i];
459 		addr = pmsg->addr;
460 
461 		if (pmsg->flags & I2C_M_TEN) {
462 			dev_err(&alg_data->adapter.dev,
463 				"%s: 10 bits addr not supported!\n",
464 				alg_data->adapter.name);
465 			rc = -EINVAL;
466 			break;
467 		}
468 
469 		alg_data->mif.buf = pmsg->buf;
470 		alg_data->mif.len = pmsg->len;
471 		alg_data->mif.mode = (pmsg->flags & I2C_M_RD) ?
472 			I2C_SMBUS_READ : I2C_SMBUS_WRITE;
473 		alg_data->mif.ret = 0;
474 		alg_data->last = (i == num - 1);
475 
476 		dev_dbg(&alg_data->adapter.dev, "%s(): mode %d, %d bytes\n",
477 			__func__, alg_data->mif.mode, alg_data->mif.len);
478 
479 		i2c_pnx_arm_timer(alg_data);
480 
481 		/* initialize the completion var */
482 		init_completion(&alg_data->mif.complete);
483 
484 		/* Enable master interrupt */
485 		iowrite32(ioread32(I2C_REG_CTL(alg_data)) | mcntrl_afie |
486 				mcntrl_naie | mcntrl_drmie,
487 			  I2C_REG_CTL(alg_data));
488 
489 		/* Put start-code and slave-address on the bus. */
490 		rc = i2c_pnx_start(addr, alg_data);
491 		if (rc < 0)
492 			break;
493 
494 		/* Wait for completion */
495 		wait_for_completion(&alg_data->mif.complete);
496 
497 		if (!(rc = alg_data->mif.ret))
498 			completed++;
499 		dev_dbg(&alg_data->adapter.dev,
500 			"%s(): Complete, return code = %d.\n",
501 			__func__, rc);
502 
503 		/* Clear TDI and AFI bits in case they are set. */
504 		if ((stat = ioread32(I2C_REG_STS(alg_data))) & mstatus_tdi) {
505 			dev_dbg(&alg_data->adapter.dev,
506 				"%s: TDI still set... clearing now.\n",
507 				alg_data->adapter.name);
508 			iowrite32(stat, I2C_REG_STS(alg_data));
509 		}
510 		if ((stat = ioread32(I2C_REG_STS(alg_data))) & mstatus_afi) {
511 			dev_dbg(&alg_data->adapter.dev,
512 				"%s: AFI still set... clearing now.\n",
513 				alg_data->adapter.name);
514 			iowrite32(stat, I2C_REG_STS(alg_data));
515 		}
516 	}
517 
518 	bus_reset_if_active(alg_data);
519 
520 	/* Cleanup to be sure... */
521 	alg_data->mif.buf = NULL;
522 	alg_data->mif.len = 0;
523 
524 	dev_dbg(&alg_data->adapter.dev, "%s(): exiting, stat = %x\n",
525 		__func__, ioread32(I2C_REG_STS(alg_data)));
526 
527 	if (completed != num)
528 		return ((rc < 0) ? rc : -EREMOTEIO);
529 
530 	return num;
531 }
532 
533 static u32 i2c_pnx_func(struct i2c_adapter *adapter)
534 {
535 	return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL;
536 }
537 
538 static struct i2c_algorithm pnx_algorithm = {
539 	.master_xfer = i2c_pnx_xfer,
540 	.functionality = i2c_pnx_func,
541 };
542 
543 #ifdef CONFIG_PM
544 static int i2c_pnx_controller_suspend(struct platform_device *pdev,
545 				      pm_message_t state)
546 {
547 	struct i2c_pnx_algo_data *alg_data = platform_get_drvdata(pdev);
548 
549 	/* FIXME: shouldn't this be clk_disable? */
550 	clk_enable(alg_data->clk);
551 
552 	return 0;
553 }
554 
555 static int i2c_pnx_controller_resume(struct platform_device *pdev)
556 {
557 	struct i2c_pnx_algo_data *alg_data = platform_get_drvdata(pdev);
558 
559 	return clk_enable(alg_data->clk);
560 }
561 #else
562 #define i2c_pnx_controller_suspend	NULL
563 #define i2c_pnx_controller_resume	NULL
564 #endif
565 
566 static int __devinit i2c_pnx_probe(struct platform_device *pdev)
567 {
568 	unsigned long tmp;
569 	int ret = 0;
570 	struct i2c_pnx_algo_data *alg_data;
571 	unsigned long freq;
572 	struct i2c_pnx_data *i2c_pnx = pdev->dev.platform_data;
573 
574 	if (!i2c_pnx || !i2c_pnx->name) {
575 		dev_err(&pdev->dev, "%s: no platform data supplied\n",
576 		       __func__);
577 		ret = -EINVAL;
578 		goto out;
579 	}
580 
581 	alg_data = kzalloc(sizeof(*alg_data), GFP_KERNEL);
582 	if (!alg_data) {
583 		ret = -ENOMEM;
584 		goto err_kzalloc;
585 	}
586 
587 	platform_set_drvdata(pdev, alg_data);
588 
589 	strlcpy(alg_data->adapter.name, i2c_pnx->name,
590 		sizeof(alg_data->adapter.name));
591 	alg_data->adapter.dev.parent = &pdev->dev;
592 	alg_data->adapter.algo = &pnx_algorithm;
593 	alg_data->adapter.algo_data = alg_data;
594 	alg_data->adapter.nr = pdev->id;
595 	alg_data->i2c_pnx = i2c_pnx;
596 
597 	alg_data->clk = clk_get(&pdev->dev, NULL);
598 	if (IS_ERR(alg_data->clk)) {
599 		ret = PTR_ERR(alg_data->clk);
600 		goto out_drvdata;
601 	}
602 
603 	init_timer(&alg_data->mif.timer);
604 	alg_data->mif.timer.function = i2c_pnx_timeout;
605 	alg_data->mif.timer.data = (unsigned long)alg_data;
606 
607 	/* Register I/O resource */
608 	if (!request_mem_region(i2c_pnx->base, I2C_PNX_REGION_SIZE,
609 				pdev->name)) {
610 		dev_err(&pdev->dev,
611 		       "I/O region 0x%08x for I2C already in use.\n",
612 		       i2c_pnx->base);
613 		ret = -ENODEV;
614 		goto out_clkget;
615 	}
616 
617 	alg_data->ioaddr = ioremap(i2c_pnx->base, I2C_PNX_REGION_SIZE);
618 	if (!alg_data->ioaddr) {
619 		dev_err(&pdev->dev, "Couldn't ioremap I2C I/O region\n");
620 		ret = -ENOMEM;
621 		goto out_release;
622 	}
623 
624 	ret = clk_enable(alg_data->clk);
625 	if (ret)
626 		goto out_unmap;
627 
628 	freq = clk_get_rate(alg_data->clk);
629 
630 	/*
631 	 * Clock Divisor High This value is the number of system clocks
632 	 * the serial clock (SCL) will be high.
633 	 * For example, if the system clock period is 50 ns and the maximum
634 	 * desired serial period is 10000 ns (100 kHz), then CLKHI would be
635 	 * set to 0.5*(f_sys/f_i2c)-2=0.5*(20e6/100e3)-2=98. The actual value
636 	 * programmed into CLKHI will vary from this slightly due to
637 	 * variations in the output pad's rise and fall times as well as
638 	 * the deglitching filter length.
639 	 */
640 
641 	tmp = ((freq / 1000) / I2C_PNX_SPEED_KHZ) / 2 - 2;
642 	if (tmp > 0x3FF)
643 		tmp = 0x3FF;
644 	iowrite32(tmp, I2C_REG_CKH(alg_data));
645 	iowrite32(tmp, I2C_REG_CKL(alg_data));
646 
647 	iowrite32(mcntrl_reset, I2C_REG_CTL(alg_data));
648 	if (wait_reset(I2C_PNX_TIMEOUT, alg_data)) {
649 		ret = -ENODEV;
650 		goto out_clock;
651 	}
652 	init_completion(&alg_data->mif.complete);
653 
654 	ret = request_irq(i2c_pnx->irq, i2c_pnx_interrupt,
655 			0, pdev->name, alg_data);
656 	if (ret)
657 		goto out_clock;
658 
659 	/* Register this adapter with the I2C subsystem */
660 	ret = i2c_add_numbered_adapter(&alg_data->adapter);
661 	if (ret < 0) {
662 		dev_err(&pdev->dev, "I2C: Failed to add bus\n");
663 		goto out_irq;
664 	}
665 
666 	dev_dbg(&pdev->dev, "%s: Master at %#8x, irq %d.\n",
667 	       alg_data->adapter.name, i2c_pnx->base, i2c_pnx->irq);
668 
669 	return 0;
670 
671 out_irq:
672 	free_irq(i2c_pnx->irq, alg_data);
673 out_clock:
674 	clk_disable(alg_data->clk);
675 out_unmap:
676 	iounmap(alg_data->ioaddr);
677 out_release:
678 	release_mem_region(i2c_pnx->base, I2C_PNX_REGION_SIZE);
679 out_clkget:
680 	clk_put(alg_data->clk);
681 out_drvdata:
682 	kfree(alg_data);
683 err_kzalloc:
684 	platform_set_drvdata(pdev, NULL);
685 out:
686 	return ret;
687 }
688 
689 static int __devexit i2c_pnx_remove(struct platform_device *pdev)
690 {
691 	struct i2c_pnx_algo_data *alg_data = platform_get_drvdata(pdev);
692 	struct i2c_pnx_data *i2c_pnx = alg_data->i2c_pnx;
693 
694 	free_irq(i2c_pnx->irq, alg_data);
695 	i2c_del_adapter(&alg_data->adapter);
696 	clk_disable(alg_data->clk);
697 	iounmap(alg_data->ioaddr);
698 	release_mem_region(i2c_pnx->base, I2C_PNX_REGION_SIZE);
699 	clk_put(alg_data->clk);
700 	kfree(alg_data);
701 	platform_set_drvdata(pdev, NULL);
702 
703 	return 0;
704 }
705 
706 static struct platform_driver i2c_pnx_driver = {
707 	.driver = {
708 		.name = "pnx-i2c",
709 		.owner = THIS_MODULE,
710 	},
711 	.probe = i2c_pnx_probe,
712 	.remove = __devexit_p(i2c_pnx_remove),
713 	.suspend = i2c_pnx_controller_suspend,
714 	.resume = i2c_pnx_controller_resume,
715 };
716 
717 static int __init i2c_adap_pnx_init(void)
718 {
719 	return platform_driver_register(&i2c_pnx_driver);
720 }
721 
722 static void __exit i2c_adap_pnx_exit(void)
723 {
724 	platform_driver_unregister(&i2c_pnx_driver);
725 }
726 
727 MODULE_AUTHOR("Vitaly Wool, Dennis Kovalev <source@mvista.com>");
728 MODULE_DESCRIPTION("I2C driver for Philips IP3204-based I2C busses");
729 MODULE_LICENSE("GPL");
730 MODULE_ALIAS("platform:pnx-i2c");
731 
732 /* We need to make sure I2C is initialized before USB */
733 subsys_initcall(i2c_adap_pnx_init);
734 module_exit(i2c_adap_pnx_exit);
735