xref: /openbmc/linux/drivers/w1/masters/omap_hdq.c (revision baa7eb025ab14f3cba2e35c0a8648f9c9f01d24f)
1 /*
2  * drivers/w1/masters/omap_hdq.c
3  *
4  * Copyright (C) 2007 Texas Instruments, Inc.
5  *
6  * This file is licensed under the terms of the GNU General Public License
7  * version 2. This program is licensed "as is" without any warranty of any
8  * kind, whether express or implied.
9  *
10  */
11 #include <linux/kernel.h>
12 #include <linux/module.h>
13 #include <linux/platform_device.h>
14 #include <linux/interrupt.h>
15 #include <linux/slab.h>
16 #include <linux/err.h>
17 #include <linux/clk.h>
18 #include <linux/io.h>
19 #include <linux/sched.h>
20 
21 #include <asm/irq.h>
22 #include <mach/hardware.h>
23 
24 #include "../w1.h"
25 #include "../w1_int.h"
26 
27 #define	MOD_NAME	"OMAP_HDQ:"
28 
29 #define OMAP_HDQ_REVISION			0x00
30 #define OMAP_HDQ_TX_DATA			0x04
31 #define OMAP_HDQ_RX_DATA			0x08
32 #define OMAP_HDQ_CTRL_STATUS			0x0c
33 #define OMAP_HDQ_CTRL_STATUS_INTERRUPTMASK	(1<<6)
34 #define OMAP_HDQ_CTRL_STATUS_CLOCKENABLE	(1<<5)
35 #define OMAP_HDQ_CTRL_STATUS_GO			(1<<4)
36 #define OMAP_HDQ_CTRL_STATUS_INITIALIZATION	(1<<2)
37 #define OMAP_HDQ_CTRL_STATUS_DIR		(1<<1)
38 #define OMAP_HDQ_CTRL_STATUS_MODE		(1<<0)
39 #define OMAP_HDQ_INT_STATUS			0x10
40 #define OMAP_HDQ_INT_STATUS_TXCOMPLETE		(1<<2)
41 #define OMAP_HDQ_INT_STATUS_RXCOMPLETE		(1<<1)
42 #define OMAP_HDQ_INT_STATUS_TIMEOUT		(1<<0)
43 #define OMAP_HDQ_SYSCONFIG			0x14
44 #define OMAP_HDQ_SYSCONFIG_SOFTRESET		(1<<1)
45 #define OMAP_HDQ_SYSCONFIG_AUTOIDLE		(1<<0)
46 #define OMAP_HDQ_SYSSTATUS			0x18
47 #define OMAP_HDQ_SYSSTATUS_RESETDONE		(1<<0)
48 
49 #define OMAP_HDQ_FLAG_CLEAR			0
50 #define OMAP_HDQ_FLAG_SET			1
51 #define OMAP_HDQ_TIMEOUT			(HZ/5)
52 
53 #define OMAP_HDQ_MAX_USER			4
54 
55 static DECLARE_WAIT_QUEUE_HEAD(hdq_wait_queue);
56 static int w1_id;
57 
58 struct hdq_data {
59 	struct device		*dev;
60 	void __iomem		*hdq_base;
61 	/* lock status update */
62 	struct  mutex		hdq_mutex;
63 	int			hdq_usecount;
64 	struct	clk		*hdq_ick;
65 	struct	clk		*hdq_fck;
66 	u8			hdq_irqstatus;
67 	/* device lock */
68 	spinlock_t		hdq_spinlock;
69 	/*
70 	 * Used to control the call to omap_hdq_get and omap_hdq_put.
71 	 * HDQ Protocol: Write the CMD|REG_address first, followed by
72 	 * the data wrire or read.
73 	 */
74 	int			init_trans;
75 };
76 
77 static int __devinit omap_hdq_probe(struct platform_device *pdev);
78 static int omap_hdq_remove(struct platform_device *pdev);
79 
80 static struct platform_driver omap_hdq_driver = {
81 	.probe =	omap_hdq_probe,
82 	.remove =	omap_hdq_remove,
83 	.driver =	{
84 		.name =	"omap_hdq",
85 	},
86 };
87 
88 static u8 omap_w1_read_byte(void *_hdq);
89 static void omap_w1_write_byte(void *_hdq, u8 byte);
90 static u8 omap_w1_reset_bus(void *_hdq);
91 static void omap_w1_search_bus(void *_hdq, struct w1_master *master_dev,
92 		u8 search_type,	w1_slave_found_callback slave_found);
93 
94 
95 static struct w1_bus_master omap_w1_master = {
96 	.read_byte	= omap_w1_read_byte,
97 	.write_byte	= omap_w1_write_byte,
98 	.reset_bus	= omap_w1_reset_bus,
99 	.search		= omap_w1_search_bus,
100 };
101 
102 /* HDQ register I/O routines */
103 static inline u8 hdq_reg_in(struct hdq_data *hdq_data, u32 offset)
104 {
105 	return __raw_readb(hdq_data->hdq_base + offset);
106 }
107 
108 static inline void hdq_reg_out(struct hdq_data *hdq_data, u32 offset, u8 val)
109 {
110 	__raw_writeb(val, hdq_data->hdq_base + offset);
111 }
112 
113 static inline u8 hdq_reg_merge(struct hdq_data *hdq_data, u32 offset,
114 			u8 val, u8 mask)
115 {
116 	u8 new_val = (__raw_readb(hdq_data->hdq_base + offset) & ~mask)
117 			| (val & mask);
118 	__raw_writeb(new_val, hdq_data->hdq_base + offset);
119 
120 	return new_val;
121 }
122 
123 /*
124  * Wait for one or more bits in flag change.
125  * HDQ_FLAG_SET: wait until any bit in the flag is set.
126  * HDQ_FLAG_CLEAR: wait until all bits in the flag are cleared.
127  * return 0 on success and -ETIMEDOUT in the case of timeout.
128  */
129 static int hdq_wait_for_flag(struct hdq_data *hdq_data, u32 offset,
130 		u8 flag, u8 flag_set, u8 *status)
131 {
132 	int ret = 0;
133 	unsigned long timeout = jiffies + OMAP_HDQ_TIMEOUT;
134 
135 	if (flag_set == OMAP_HDQ_FLAG_CLEAR) {
136 		/* wait for the flag clear */
137 		while (((*status = hdq_reg_in(hdq_data, offset)) & flag)
138 			&& time_before(jiffies, timeout)) {
139 			schedule_timeout_uninterruptible(1);
140 		}
141 		if (*status & flag)
142 			ret = -ETIMEDOUT;
143 	} else if (flag_set == OMAP_HDQ_FLAG_SET) {
144 		/* wait for the flag set */
145 		while (!((*status = hdq_reg_in(hdq_data, offset)) & flag)
146 			&& time_before(jiffies, timeout)) {
147 			schedule_timeout_uninterruptible(1);
148 		}
149 		if (!(*status & flag))
150 			ret = -ETIMEDOUT;
151 	} else
152 		return -EINVAL;
153 
154 	return ret;
155 }
156 
157 /* write out a byte and fill *status with HDQ_INT_STATUS */
158 static int hdq_write_byte(struct hdq_data *hdq_data, u8 val, u8 *status)
159 {
160 	int ret;
161 	u8 tmp_status;
162 	unsigned long irqflags;
163 
164 	*status = 0;
165 
166 	spin_lock_irqsave(&hdq_data->hdq_spinlock, irqflags);
167 	/* clear interrupt flags via a dummy read */
168 	hdq_reg_in(hdq_data, OMAP_HDQ_INT_STATUS);
169 	/* ISR loads it with new INT_STATUS */
170 	hdq_data->hdq_irqstatus = 0;
171 	spin_unlock_irqrestore(&hdq_data->hdq_spinlock, irqflags);
172 
173 	hdq_reg_out(hdq_data, OMAP_HDQ_TX_DATA, val);
174 
175 	/* set the GO bit */
176 	hdq_reg_merge(hdq_data, OMAP_HDQ_CTRL_STATUS, OMAP_HDQ_CTRL_STATUS_GO,
177 		OMAP_HDQ_CTRL_STATUS_DIR | OMAP_HDQ_CTRL_STATUS_GO);
178 	/* wait for the TXCOMPLETE bit */
179 	ret = wait_event_timeout(hdq_wait_queue,
180 		hdq_data->hdq_irqstatus, OMAP_HDQ_TIMEOUT);
181 	if (ret == 0) {
182 		dev_dbg(hdq_data->dev, "TX wait elapsed\n");
183 		goto out;
184 	}
185 
186 	*status = hdq_data->hdq_irqstatus;
187 	/* check irqstatus */
188 	if (!(*status & OMAP_HDQ_INT_STATUS_TXCOMPLETE)) {
189 		dev_dbg(hdq_data->dev, "timeout waiting for"
190 			"TXCOMPLETE/RXCOMPLETE, %x", *status);
191 		ret = -ETIMEDOUT;
192 		goto out;
193 	}
194 
195 	/* wait for the GO bit return to zero */
196 	ret = hdq_wait_for_flag(hdq_data, OMAP_HDQ_CTRL_STATUS,
197 			OMAP_HDQ_CTRL_STATUS_GO,
198 			OMAP_HDQ_FLAG_CLEAR, &tmp_status);
199 	if (ret) {
200 		dev_dbg(hdq_data->dev, "timeout waiting GO bit"
201 			"return to zero, %x", tmp_status);
202 	}
203 
204 out:
205 	return ret;
206 }
207 
208 /* HDQ Interrupt service routine */
209 static irqreturn_t hdq_isr(int irq, void *_hdq)
210 {
211 	struct hdq_data *hdq_data = _hdq;
212 	unsigned long irqflags;
213 
214 	spin_lock_irqsave(&hdq_data->hdq_spinlock, irqflags);
215 	hdq_data->hdq_irqstatus = hdq_reg_in(hdq_data, OMAP_HDQ_INT_STATUS);
216 	spin_unlock_irqrestore(&hdq_data->hdq_spinlock, irqflags);
217 	dev_dbg(hdq_data->dev, "hdq_isr: %x", hdq_data->hdq_irqstatus);
218 
219 	if (hdq_data->hdq_irqstatus &
220 		(OMAP_HDQ_INT_STATUS_TXCOMPLETE | OMAP_HDQ_INT_STATUS_RXCOMPLETE
221 		| OMAP_HDQ_INT_STATUS_TIMEOUT)) {
222 		/* wake up sleeping process */
223 		wake_up(&hdq_wait_queue);
224 	}
225 
226 	return IRQ_HANDLED;
227 }
228 
229 /* HDQ Mode: always return success */
230 static u8 omap_w1_reset_bus(void *_hdq)
231 {
232 	return 0;
233 }
234 
235 /* W1 search callback function */
236 static void omap_w1_search_bus(void *_hdq, struct w1_master *master_dev,
237 		u8 search_type, w1_slave_found_callback slave_found)
238 {
239 	u64 module_id, rn_le, cs, id;
240 
241 	if (w1_id)
242 		module_id = w1_id;
243 	else
244 		module_id = 0x1;
245 
246 	rn_le = cpu_to_le64(module_id);
247 	/*
248 	 * HDQ might not obey truly the 1-wire spec.
249 	 * So calculate CRC based on module parameter.
250 	 */
251 	cs = w1_calc_crc8((u8 *)&rn_le, 7);
252 	id = (cs << 56) | module_id;
253 
254 	slave_found(master_dev, id);
255 }
256 
257 static int _omap_hdq_reset(struct hdq_data *hdq_data)
258 {
259 	int ret;
260 	u8 tmp_status;
261 
262 	hdq_reg_out(hdq_data, OMAP_HDQ_SYSCONFIG, OMAP_HDQ_SYSCONFIG_SOFTRESET);
263 	/*
264 	 * Select HDQ mode & enable clocks.
265 	 * It is observed that INT flags can't be cleared via a read and GO/INIT
266 	 * won't return to zero if interrupt is disabled. So we always enable
267 	 * interrupt.
268 	 */
269 	hdq_reg_out(hdq_data, OMAP_HDQ_CTRL_STATUS,
270 		OMAP_HDQ_CTRL_STATUS_CLOCKENABLE |
271 		OMAP_HDQ_CTRL_STATUS_INTERRUPTMASK);
272 
273 	/* wait for reset to complete */
274 	ret = hdq_wait_for_flag(hdq_data, OMAP_HDQ_SYSSTATUS,
275 		OMAP_HDQ_SYSSTATUS_RESETDONE, OMAP_HDQ_FLAG_SET, &tmp_status);
276 	if (ret)
277 		dev_dbg(hdq_data->dev, "timeout waiting HDQ reset, %x",
278 				tmp_status);
279 	else {
280 		hdq_reg_out(hdq_data, OMAP_HDQ_CTRL_STATUS,
281 			OMAP_HDQ_CTRL_STATUS_CLOCKENABLE |
282 			OMAP_HDQ_CTRL_STATUS_INTERRUPTMASK);
283 		hdq_reg_out(hdq_data, OMAP_HDQ_SYSCONFIG,
284 			OMAP_HDQ_SYSCONFIG_AUTOIDLE);
285 	}
286 
287 	return ret;
288 }
289 
290 /* Issue break pulse to the device */
291 static int omap_hdq_break(struct hdq_data *hdq_data)
292 {
293 	int ret = 0;
294 	u8 tmp_status;
295 	unsigned long irqflags;
296 
297 	ret = mutex_lock_interruptible(&hdq_data->hdq_mutex);
298 	if (ret < 0) {
299 		dev_dbg(hdq_data->dev, "Could not acquire mutex\n");
300 		ret = -EINTR;
301 		goto rtn;
302 	}
303 
304 	spin_lock_irqsave(&hdq_data->hdq_spinlock, irqflags);
305 	/* clear interrupt flags via a dummy read */
306 	hdq_reg_in(hdq_data, OMAP_HDQ_INT_STATUS);
307 	/* ISR loads it with new INT_STATUS */
308 	hdq_data->hdq_irqstatus = 0;
309 	spin_unlock_irqrestore(&hdq_data->hdq_spinlock, irqflags);
310 
311 	/* set the INIT and GO bit */
312 	hdq_reg_merge(hdq_data, OMAP_HDQ_CTRL_STATUS,
313 		OMAP_HDQ_CTRL_STATUS_INITIALIZATION | OMAP_HDQ_CTRL_STATUS_GO,
314 		OMAP_HDQ_CTRL_STATUS_DIR | OMAP_HDQ_CTRL_STATUS_INITIALIZATION |
315 		OMAP_HDQ_CTRL_STATUS_GO);
316 
317 	/* wait for the TIMEOUT bit */
318 	ret = wait_event_timeout(hdq_wait_queue,
319 		hdq_data->hdq_irqstatus, OMAP_HDQ_TIMEOUT);
320 	if (ret == 0) {
321 		dev_dbg(hdq_data->dev, "break wait elapsed\n");
322 		ret = -EINTR;
323 		goto out;
324 	}
325 
326 	tmp_status = hdq_data->hdq_irqstatus;
327 	/* check irqstatus */
328 	if (!(tmp_status & OMAP_HDQ_INT_STATUS_TIMEOUT)) {
329 		dev_dbg(hdq_data->dev, "timeout waiting for TIMEOUT, %x",
330 				tmp_status);
331 		ret = -ETIMEDOUT;
332 		goto out;
333 	}
334 	/*
335 	 * wait for both INIT and GO bits rerurn to zero.
336 	 * zero wait time expected for interrupt mode.
337 	 */
338 	ret = hdq_wait_for_flag(hdq_data, OMAP_HDQ_CTRL_STATUS,
339 			OMAP_HDQ_CTRL_STATUS_INITIALIZATION |
340 			OMAP_HDQ_CTRL_STATUS_GO, OMAP_HDQ_FLAG_CLEAR,
341 			&tmp_status);
342 	if (ret)
343 		dev_dbg(hdq_data->dev, "timeout waiting INIT&GO bits"
344 			"return to zero, %x", tmp_status);
345 
346 out:
347 	mutex_unlock(&hdq_data->hdq_mutex);
348 rtn:
349 	return ret;
350 }
351 
352 static int hdq_read_byte(struct hdq_data *hdq_data, u8 *val)
353 {
354 	int ret = 0;
355 	u8 status;
356 	unsigned long timeout = jiffies + OMAP_HDQ_TIMEOUT;
357 
358 	ret = mutex_lock_interruptible(&hdq_data->hdq_mutex);
359 	if (ret < 0) {
360 		ret = -EINTR;
361 		goto rtn;
362 	}
363 
364 	if (!hdq_data->hdq_usecount) {
365 		ret = -EINVAL;
366 		goto out;
367 	}
368 
369 	if (!(hdq_data->hdq_irqstatus & OMAP_HDQ_INT_STATUS_RXCOMPLETE)) {
370 		hdq_reg_merge(hdq_data, OMAP_HDQ_CTRL_STATUS,
371 			OMAP_HDQ_CTRL_STATUS_DIR | OMAP_HDQ_CTRL_STATUS_GO,
372 			OMAP_HDQ_CTRL_STATUS_DIR | OMAP_HDQ_CTRL_STATUS_GO);
373 		/*
374 		 * The RX comes immediately after TX. It
375 		 * triggers another interrupt before we
376 		 * sleep. So we have to wait for RXCOMPLETE bit.
377 		 */
378 		while (!(hdq_data->hdq_irqstatus
379 			& OMAP_HDQ_INT_STATUS_RXCOMPLETE)
380 			&& time_before(jiffies, timeout)) {
381 			schedule_timeout_uninterruptible(1);
382 		}
383 		hdq_reg_merge(hdq_data, OMAP_HDQ_CTRL_STATUS, 0,
384 			OMAP_HDQ_CTRL_STATUS_DIR);
385 		status = hdq_data->hdq_irqstatus;
386 		/* check irqstatus */
387 		if (!(status & OMAP_HDQ_INT_STATUS_RXCOMPLETE)) {
388 			dev_dbg(hdq_data->dev, "timeout waiting for"
389 				"RXCOMPLETE, %x", status);
390 			ret = -ETIMEDOUT;
391 			goto out;
392 		}
393 	}
394 	/* the data is ready. Read it in! */
395 	*val = hdq_reg_in(hdq_data, OMAP_HDQ_RX_DATA);
396 out:
397 	mutex_unlock(&hdq_data->hdq_mutex);
398 rtn:
399 	return 0;
400 
401 }
402 
403 /* Enable clocks and set the controller to HDQ mode */
404 static int omap_hdq_get(struct hdq_data *hdq_data)
405 {
406 	int ret = 0;
407 
408 	ret = mutex_lock_interruptible(&hdq_data->hdq_mutex);
409 	if (ret < 0) {
410 		ret = -EINTR;
411 		goto rtn;
412 	}
413 
414 	if (OMAP_HDQ_MAX_USER == hdq_data->hdq_usecount) {
415 		dev_dbg(hdq_data->dev, "attempt to exceed the max use count");
416 		ret = -EINVAL;
417 		goto out;
418 	} else {
419 		hdq_data->hdq_usecount++;
420 		try_module_get(THIS_MODULE);
421 		if (1 == hdq_data->hdq_usecount) {
422 			if (clk_enable(hdq_data->hdq_ick)) {
423 				dev_dbg(hdq_data->dev, "Can not enable ick\n");
424 				ret = -ENODEV;
425 				goto clk_err;
426 			}
427 			if (clk_enable(hdq_data->hdq_fck)) {
428 				dev_dbg(hdq_data->dev, "Can not enable fck\n");
429 				clk_disable(hdq_data->hdq_ick);
430 				ret = -ENODEV;
431 				goto clk_err;
432 			}
433 
434 			/* make sure HDQ is out of reset */
435 			if (!(hdq_reg_in(hdq_data, OMAP_HDQ_SYSSTATUS) &
436 				OMAP_HDQ_SYSSTATUS_RESETDONE)) {
437 				ret = _omap_hdq_reset(hdq_data);
438 				if (ret)
439 					/* back up the count */
440 					hdq_data->hdq_usecount--;
441 			} else {
442 				/* select HDQ mode & enable clocks */
443 				hdq_reg_out(hdq_data, OMAP_HDQ_CTRL_STATUS,
444 					OMAP_HDQ_CTRL_STATUS_CLOCKENABLE |
445 					OMAP_HDQ_CTRL_STATUS_INTERRUPTMASK);
446 				hdq_reg_out(hdq_data, OMAP_HDQ_SYSCONFIG,
447 					OMAP_HDQ_SYSCONFIG_AUTOIDLE);
448 				hdq_reg_in(hdq_data, OMAP_HDQ_INT_STATUS);
449 			}
450 		}
451 	}
452 
453 clk_err:
454 	clk_put(hdq_data->hdq_ick);
455 	clk_put(hdq_data->hdq_fck);
456 out:
457 	mutex_unlock(&hdq_data->hdq_mutex);
458 rtn:
459 	return ret;
460 }
461 
462 /* Disable clocks to the module */
463 static int omap_hdq_put(struct hdq_data *hdq_data)
464 {
465 	int ret = 0;
466 
467 	ret = mutex_lock_interruptible(&hdq_data->hdq_mutex);
468 	if (ret < 0)
469 		return -EINTR;
470 
471 	if (0 == hdq_data->hdq_usecount) {
472 		dev_dbg(hdq_data->dev, "attempt to decrement use count"
473 			"when it is zero");
474 		ret = -EINVAL;
475 	} else {
476 		hdq_data->hdq_usecount--;
477 		module_put(THIS_MODULE);
478 		if (0 == hdq_data->hdq_usecount) {
479 			clk_disable(hdq_data->hdq_ick);
480 			clk_disable(hdq_data->hdq_fck);
481 		}
482 	}
483 	mutex_unlock(&hdq_data->hdq_mutex);
484 
485 	return ret;
486 }
487 
488 /* Read a byte of data from the device */
489 static u8 omap_w1_read_byte(void *_hdq)
490 {
491 	struct hdq_data *hdq_data = _hdq;
492 	u8 val = 0;
493 	int ret;
494 
495 	ret = hdq_read_byte(hdq_data, &val);
496 	if (ret) {
497 		ret = mutex_lock_interruptible(&hdq_data->hdq_mutex);
498 		if (ret < 0) {
499 			dev_dbg(hdq_data->dev, "Could not acquire mutex\n");
500 			return -EINTR;
501 		}
502 		hdq_data->init_trans = 0;
503 		mutex_unlock(&hdq_data->hdq_mutex);
504 		omap_hdq_put(hdq_data);
505 		return -1;
506 	}
507 
508 	/* Write followed by a read, release the module */
509 	if (hdq_data->init_trans) {
510 		ret = mutex_lock_interruptible(&hdq_data->hdq_mutex);
511 		if (ret < 0) {
512 			dev_dbg(hdq_data->dev, "Could not acquire mutex\n");
513 			return -EINTR;
514 		}
515 		hdq_data->init_trans = 0;
516 		mutex_unlock(&hdq_data->hdq_mutex);
517 		omap_hdq_put(hdq_data);
518 	}
519 
520 	return val;
521 }
522 
523 /* Write a byte of data to the device */
524 static void omap_w1_write_byte(void *_hdq, u8 byte)
525 {
526 	struct hdq_data *hdq_data = _hdq;
527 	int ret;
528 	u8 status;
529 
530 	/* First write to initialize the transfer */
531 	if (hdq_data->init_trans == 0)
532 		omap_hdq_get(hdq_data);
533 
534 	ret = mutex_lock_interruptible(&hdq_data->hdq_mutex);
535 	if (ret < 0) {
536 		dev_dbg(hdq_data->dev, "Could not acquire mutex\n");
537 		return;
538 	}
539 	hdq_data->init_trans++;
540 	mutex_unlock(&hdq_data->hdq_mutex);
541 
542 	ret = hdq_write_byte(hdq_data, byte, &status);
543 	if (ret == 0) {
544 		dev_dbg(hdq_data->dev, "TX failure:Ctrl status %x\n", status);
545 		return;
546 	}
547 
548 	/* Second write, data transfered. Release the module */
549 	if (hdq_data->init_trans > 1) {
550 		omap_hdq_put(hdq_data);
551 		ret = mutex_lock_interruptible(&hdq_data->hdq_mutex);
552 		if (ret < 0) {
553 			dev_dbg(hdq_data->dev, "Could not acquire mutex\n");
554 			return;
555 		}
556 		hdq_data->init_trans = 0;
557 		mutex_unlock(&hdq_data->hdq_mutex);
558 	}
559 
560 	return;
561 }
562 
563 static int __devinit omap_hdq_probe(struct platform_device *pdev)
564 {
565 	struct hdq_data *hdq_data;
566 	struct resource *res;
567 	int ret, irq;
568 	u8 rev;
569 
570 	hdq_data = kmalloc(sizeof(*hdq_data), GFP_KERNEL);
571 	if (!hdq_data) {
572 		dev_dbg(&pdev->dev, "unable to allocate memory\n");
573 		ret = -ENOMEM;
574 		goto err_kmalloc;
575 	}
576 
577 	hdq_data->dev = &pdev->dev;
578 	platform_set_drvdata(pdev, hdq_data);
579 
580 	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
581 	if (!res) {
582 		dev_dbg(&pdev->dev, "unable to get resource\n");
583 		ret = -ENXIO;
584 		goto err_resource;
585 	}
586 
587 	hdq_data->hdq_base = ioremap(res->start, SZ_4K);
588 	if (!hdq_data->hdq_base) {
589 		dev_dbg(&pdev->dev, "ioremap failed\n");
590 		ret = -EINVAL;
591 		goto err_ioremap;
592 	}
593 
594 	/* get interface & functional clock objects */
595 	hdq_data->hdq_ick = clk_get(&pdev->dev, "ick");
596 	hdq_data->hdq_fck = clk_get(&pdev->dev, "fck");
597 
598 	if (IS_ERR(hdq_data->hdq_ick) || IS_ERR(hdq_data->hdq_fck)) {
599 		dev_dbg(&pdev->dev, "Can't get HDQ clock objects\n");
600 		if (IS_ERR(hdq_data->hdq_ick)) {
601 			ret = PTR_ERR(hdq_data->hdq_ick);
602 			goto err_clk;
603 		}
604 		if (IS_ERR(hdq_data->hdq_fck)) {
605 			ret = PTR_ERR(hdq_data->hdq_fck);
606 			clk_put(hdq_data->hdq_ick);
607 			goto err_clk;
608 		}
609 	}
610 
611 	hdq_data->hdq_usecount = 0;
612 	mutex_init(&hdq_data->hdq_mutex);
613 
614 	if (clk_enable(hdq_data->hdq_ick)) {
615 		dev_dbg(&pdev->dev, "Can not enable ick\n");
616 		ret = -ENODEV;
617 		goto err_intfclk;
618 	}
619 
620 	if (clk_enable(hdq_data->hdq_fck)) {
621 		dev_dbg(&pdev->dev, "Can not enable fck\n");
622 		ret = -ENODEV;
623 		goto err_fnclk;
624 	}
625 
626 	rev = hdq_reg_in(hdq_data, OMAP_HDQ_REVISION);
627 	dev_info(&pdev->dev, "OMAP HDQ Hardware Rev %c.%c. Driver in %s mode\n",
628 		(rev >> 4) + '0', (rev & 0x0f) + '0', "Interrupt");
629 
630 	spin_lock_init(&hdq_data->hdq_spinlock);
631 
632 	irq = platform_get_irq(pdev, 0);
633 	if (irq	< 0) {
634 		ret = -ENXIO;
635 		goto err_irq;
636 	}
637 
638 	ret = request_irq(irq, hdq_isr, IRQF_DISABLED, "omap_hdq", hdq_data);
639 	if (ret < 0) {
640 		dev_dbg(&pdev->dev, "could not request irq\n");
641 		goto err_irq;
642 	}
643 
644 	omap_hdq_break(hdq_data);
645 
646 	/* don't clock the HDQ until it is needed */
647 	clk_disable(hdq_data->hdq_ick);
648 	clk_disable(hdq_data->hdq_fck);
649 
650 	omap_w1_master.data = hdq_data;
651 
652 	ret = w1_add_master_device(&omap_w1_master);
653 	if (ret) {
654 		dev_dbg(&pdev->dev, "Failure in registering w1 master\n");
655 		goto err_w1;
656 	}
657 
658 	return 0;
659 
660 err_w1:
661 err_irq:
662 	clk_disable(hdq_data->hdq_fck);
663 
664 err_fnclk:
665 	clk_disable(hdq_data->hdq_ick);
666 
667 err_intfclk:
668 	clk_put(hdq_data->hdq_ick);
669 	clk_put(hdq_data->hdq_fck);
670 
671 err_clk:
672 	iounmap(hdq_data->hdq_base);
673 
674 err_ioremap:
675 err_resource:
676 	platform_set_drvdata(pdev, NULL);
677 	kfree(hdq_data);
678 
679 err_kmalloc:
680 	return ret;
681 
682 }
683 
684 static int omap_hdq_remove(struct platform_device *pdev)
685 {
686 	struct hdq_data *hdq_data = platform_get_drvdata(pdev);
687 
688 	mutex_lock(&hdq_data->hdq_mutex);
689 
690 	if (hdq_data->hdq_usecount) {
691 		dev_dbg(&pdev->dev, "removed when use count is not zero\n");
692 		mutex_unlock(&hdq_data->hdq_mutex);
693 		return -EBUSY;
694 	}
695 
696 	mutex_unlock(&hdq_data->hdq_mutex);
697 
698 	/* remove module dependency */
699 	clk_put(hdq_data->hdq_ick);
700 	clk_put(hdq_data->hdq_fck);
701 	free_irq(INT_24XX_HDQ_IRQ, hdq_data);
702 	platform_set_drvdata(pdev, NULL);
703 	iounmap(hdq_data->hdq_base);
704 	kfree(hdq_data);
705 
706 	return 0;
707 }
708 
709 static int __init
710 omap_hdq_init(void)
711 {
712 	return platform_driver_register(&omap_hdq_driver);
713 }
714 module_init(omap_hdq_init);
715 
716 static void __exit
717 omap_hdq_exit(void)
718 {
719 	platform_driver_unregister(&omap_hdq_driver);
720 }
721 module_exit(omap_hdq_exit);
722 
723 module_param(w1_id, int, S_IRUSR);
724 MODULE_PARM_DESC(w1_id, "1-wire id for the slave detection");
725 
726 MODULE_AUTHOR("Texas Instruments");
727 MODULE_DESCRIPTION("HDQ driver Library");
728 MODULE_LICENSE("GPL");
729