| 
									
										
										
										
											2012-09-06 20:27:06 +05:30
										 |  |  | /*
 | 
					
						
							|  |  |  |  * omap_usb.h -- omap usb2 phy header file | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com
 | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation; either version 2 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Author: Kishon Vijay Abraham I <kishon@ti.com> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef __DRIVERS_OMAP_USB2_H
 | 
					
						
							|  |  |  | #define __DRIVERS_OMAP_USB2_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-25 08:21:48 +05:30
										 |  |  | #include <linux/io.h>
 | 
					
						
							| 
									
										
										
										
											2012-09-06 20:27:06 +05:30
										 |  |  | #include <linux/usb/otg.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-25 08:21:48 +05:30
										 |  |  | struct usb_dpll_params { | 
					
						
							|  |  |  | 	u16	m; | 
					
						
							|  |  |  | 	u8	n; | 
					
						
							|  |  |  | 	u8	freq:3; | 
					
						
							|  |  |  | 	u8	sd; | 
					
						
							|  |  |  | 	u32	mf; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-06 20:27:06 +05:30
										 |  |  | struct omap_usb { | 
					
						
							|  |  |  | 	struct usb_phy		phy; | 
					
						
							|  |  |  | 	struct phy_companion	*comparator; | 
					
						
							| 
									
										
										
										
											2013-01-25 08:21:48 +05:30
										 |  |  | 	void __iomem		*pll_ctrl_base; | 
					
						
							| 
									
										
										
										
											2012-09-06 20:27:06 +05:30
										 |  |  | 	struct device		*dev; | 
					
						
							| 
									
										
										
										
											2013-01-25 15:54:00 +05:30
										 |  |  | 	struct device		*control_dev; | 
					
						
							| 
									
										
										
										
											2012-09-06 20:27:06 +05:30
										 |  |  | 	struct clk		*wkupclk; | 
					
						
							| 
									
										
										
										
											2013-01-25 08:21:48 +05:30
										 |  |  | 	struct clk		*sys_clk; | 
					
						
							|  |  |  | 	struct clk		*optclk; | 
					
						
							| 
									
										
										
										
											2012-09-06 20:27:06 +05:30
										 |  |  | 	u8			is_suspended:1; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define	phy_to_omapusb(x)	container_of((x), struct omap_usb, phy)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if defined(CONFIG_OMAP_USB2) || defined(CONFIG_OMAP_USB2_MODULE)
 | 
					
						
							|  |  |  | extern int omap_usb2_set_comparator(struct phy_companion *comparator); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | static inline int omap_usb2_set_comparator(struct phy_companion *comparator) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return -ENODEV; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-25 08:21:48 +05:30
										 |  |  | static inline u32 omap_usb_readl(void __iomem *addr, unsigned offset) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return __raw_readl(addr + offset); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void omap_usb_writel(void __iomem *addr, unsigned offset, | 
					
						
							|  |  |  | 	u32 data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	__raw_writel(data, addr + offset); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-06 20:27:06 +05:30
										 |  |  | #endif /* __DRIVERS_OMAP_USB_H */
 |