⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 omap_udc.h

📁 LINUX 2.6.17.4的源码
💻 H
字号:
/* * omap_udc.h -- for omap 3.2 udc, with OTG support * * 2004 (C) Texas Instruments, Inc. * 2004 (C) David Brownell *//* * USB device/endpoint management registers */#define UDC_REG(offset)              __REG16(UDC_BASE + (offset))#define	UDC_REV_REG			UDC_REG(0x0)	/* Revision */#define	UDC_EP_NUM_REG			UDC_REG(0x4)	/* Which endpoint */#	define	UDC_SETUP_SEL		(1 << 6)#	define	UDC_EP_SEL		(1 << 5)#	define	UDC_EP_DIR		(1 << 4)	/* low 4 bits for endpoint number */#define	UDC_DATA_REG			UDC_REG(0x08)	/* Endpoint FIFO */#define	UDC_CTRL_REG			UDC_REG(0x0C)	/* Endpoint control */#	define	UDC_CLR_HALT		(1 << 7)#	define	UDC_SET_HALT		(1 << 6)#	define	UDC_CLRDATA_TOGGLE	(1 << 3)#	define	UDC_SET_FIFO_EN		(1 << 2)#	define	UDC_CLR_EP		(1 << 1)#	define	UDC_RESET_EP		(1 << 0)#define	UDC_STAT_FLG_REG		UDC_REG(0x10)	/* Endpoint status */#	define	UDC_NO_RXPACKET		(1 << 15)#	define	UDC_MISS_IN		(1 << 14)#	define	UDC_DATA_FLUSH		(1 << 13)#	define	UDC_ISO_ERR		(1 << 12)#	define	UDC_ISO_FIFO_EMPTY	(1 << 9)#	define	UDC_ISO_FIFO_FULL	(1 << 8)#	define	UDC_EP_HALTED		(1 << 6)#	define	UDC_STALL		(1 << 5)#	define	UDC_NAK			(1 << 4)#	define	UDC_ACK			(1 << 3)#	define	UDC_FIFO_EN		(1 << 2)#	define	UDC_NON_ISO_FIFO_EMPTY	(1 << 1)#	define	UDC_NON_ISO_FIFO_FULL	(1 << 0)#define	UDC_RXFSTAT_REG			UDC_REG(0x14)	/* OUT bytecount */#define	UDC_SYSCON1_REG			UDC_REG(0x18)	/* System config 1 */#	define	UDC_CFG_LOCK		(1 << 8)#	define	UDC_DATA_ENDIAN		(1 << 7)#	define	UDC_DMA_ENDIAN		(1 << 6)#	define	UDC_NAK_EN		(1 << 4)#	define	UDC_AUTODECODE_DIS	(1 << 3)#	define	UDC_SELF_PWR		(1 << 2)#	define	UDC_SOFF_DIS		(1 << 1)#	define	UDC_PULLUP_EN		(1 << 0)#define	UDC_SYSCON2_REG			UDC_REG(0x1C)	/* System config 2 */#	define	UDC_RMT_WKP		(1 << 6)#	define	UDC_STALL_CMD		(1 << 5)#	define	UDC_DEV_CFG		(1 << 3)#	define	UDC_CLR_CFG		(1 << 2)#define	UDC_DEVSTAT_REG			UDC_REG(0x20)	/* Device status */#	define	UDC_B_HNP_ENABLE	(1 << 9)#	define	UDC_A_HNP_SUPPORT	(1 << 8)#	define	UDC_A_ALT_HNP_SUPPORT	(1 << 7)#	define	UDC_R_WK_OK		(1 << 6)#	define	UDC_USB_RESET		(1 << 5)#	define	UDC_SUS			(1 << 4)#	define	UDC_CFG			(1 << 3)#	define	UDC_ADD			(1 << 2)#	define	UDC_DEF			(1 << 1)#	define	UDC_ATT			(1 << 0)#define	UDC_SOF_REG			UDC_REG(0x24)	/* Start of frame */#	define	UDC_FT_LOCK		(1 << 12)#	define	UDC_TS_OK		(1 << 11)#	define	UDC_TS			0x03ff#define	UDC_IRQ_EN_REG			UDC_REG(0x28)	/* Interrupt enable */#	define	UDC_SOF_IE		(1 << 7)#	define	UDC_EPN_RX_IE		(1 << 5)#	define	UDC_EPN_TX_IE		(1 << 4)#	define	UDC_DS_CHG_IE		(1 << 3)#	define	UDC_EP0_IE		(1 << 0)#define	UDC_DMA_IRQ_EN_REG		UDC_REG(0x2C)	/* DMA irq enable */	/* rx/tx dma channels numbered 1-3 not 0-2 */#	define	UDC_TX_DONE_IE(n)	(1 << (4 * (n) - 2))#	define	UDC_RX_CNT_IE(n)	(1 << (4 * (n) - 3))#	define	UDC_RX_EOT_IE(n)	(1 << (4 * (n) - 4))#define	UDC_IRQ_SRC_REG			UDC_REG(0x30)	/* Interrupt source */#	define	UDC_TXN_DONE		(1 << 10)#	define	UDC_RXN_CNT		(1 << 9)#	define	UDC_RXN_EOT		(1 << 8)#	define	UDC_SOF			(1 << 7)#	define	UDC_EPN_RX		(1 << 5)#	define	UDC_EPN_TX		(1 << 4)#	define	UDC_DS_CHG		(1 << 3)#	define	UDC_SETUP		(1 << 2)#	define	UDC_EP0_RX		(1 << 1)#	define	UDC_EP0_TX		(1 << 0)#	define	UDC_IRQ_SRC_MASK	0x7bf#define	UDC_EPN_STAT_REG		UDC_REG(0x34)	/* EP irq status */#define	UDC_DMAN_STAT_REG		UDC_REG(0x38)	/* DMA irq status */#	define	UDC_DMA_RX_SB		(1 << 12)#	define	UDC_DMA_RX_SRC(x)	(((x)>>8) & 0xf)#	define	UDC_DMA_TX_SRC(x)	(((x)>>0) & 0xf)/* DMA configuration registers:  up to three channels in each direction.  */#define	UDC_RXDMA_CFG_REG		UDC_REG(0x40)	/* 3 eps for RX DMA */#	define	UDC_DMA_REQ		(1 << 12)#define	UDC_TXDMA_CFG_REG		UDC_REG(0x44)	/* 3 eps for TX DMA */#define	UDC_DATA_DMA_REG		UDC_REG(0x48)	/* rx/tx fifo addr *//* rx/tx dma control, numbering channels 1-3 not 0-2 */#define	UDC_TXDMA_REG(chan)		UDC_REG(0x50 - 4 + 4 * (chan))#	define UDC_TXN_EOT		(1 << 15)	/* bytes vs packets */#	define UDC_TXN_START		(1 << 14)	/* start transfer */#	define UDC_TXN_TSC		0x03ff		/* units in xfer */#define	UDC_RXDMA_REG(chan)		UDC_REG(0x60 - 4 + 4 * (chan))#	define UDC_RXN_STOP		(1 << 15)	/* enable EOT irq */#	define UDC_RXN_TC		0x00ff		/* packets in xfer *//* * Endpoint configuration registers (used before CFG_LOCK is set) * UDC_EP_TX_REG(0) is unused */#define	UDC_EP_RX_REG(endpoint)		UDC_REG(0x80 + (endpoint)*4)#	define	UDC_EPN_RX_VALID	(1 << 15)#	define	UDC_EPN_RX_DB		(1 << 14)	/* buffer size in bits 13, 12 */#	define	UDC_EPN_RX_ISO		(1 << 11)	/* buffer pointer in low 11 bits */#define	UDC_EP_TX_REG(endpoint)		UDC_REG(0xc0 + (endpoint)*4)	/* same bitfields as in RX_REG *//*-------------------------------------------------------------------------*/struct omap_req {	struct usb_request		req;	struct list_head		queue;	unsigned			dma_bytes;	unsigned			mapped:1;};struct omap_ep {	struct usb_ep			ep;	struct list_head		queue;	unsigned long			irqs;	struct list_head		iso;	const struct usb_endpoint_descriptor	*desc;	char				name[14];	u16				maxpacket;	u8				bEndpointAddress;	u8				bmAttributes;	unsigned			double_buf:1;	unsigned			stopped:1;	unsigned			fnf:1;	unsigned			has_dma:1;	u8				ackwait;	u8				dma_channel;	u16				dma_counter;	int				lch;	struct omap_udc			*udc;	struct timer_list		timer;};struct omap_udc {	struct usb_gadget		gadget;	struct usb_gadget_driver	*driver;	spinlock_t			lock;	struct omap_ep			ep[32];	u16				devstat;	u16				clr_halt;	struct otg_transceiver		*transceiver;	struct list_head		iso;	unsigned			softconnect:1;	unsigned			vbus_active:1;	unsigned			ep0_pending:1;	unsigned			ep0_in:1;	unsigned			ep0_set_config:1;	unsigned			ep0_reset_config:1;	unsigned			ep0_setup:1;	struct completion		*done;};/*-------------------------------------------------------------------------*/#ifdef DEBUG#define DBG(stuff...)		printk(KERN_DEBUG "udc: " stuff)#else#define DBG(stuff...)		do{}while(0)#endif#ifdef VERBOSE#    define VDBG		DBG#else#    define VDBG(stuff...)	do{}while(0)#endif#define ERR(stuff...)		printk(KERN_ERR "udc: " stuff)#define WARN(stuff...)		printk(KERN_WARNING "udc: " stuff)#define INFO(stuff...)		printk(KERN_INFO "udc: " stuff)/*-------------------------------------------------------------------------*/#define	MOD_CONF_CTRL_0_REG	__REG32(MOD_CONF_CTRL_0)#define	VBUS_W2FC_1510		(1 << 17)	/* 0 gpio0, 1 dvdd2 pin */#define	FUNC_MUX_CTRL_0_REG	__REG32(FUNC_MUX_CTRL_0)#define	VBUS_CTRL_1510		(1 << 19)	/* 1 connected (software) */#define	VBUS_MODE_1510		(1 << 18)	/* 0 hardware, 1 software */#define	HMC_1510	((MOD_CONF_CTRL_0_REG >> 1) & 0x3f)#define	HMC_1610	(OTG_SYSCON_2_REG & 0x3f)#define	HMC		(cpu_is_omap15xx() ? HMC_1510 : HMC_1610)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -