diff options
| author | Vivek Mahajan <vivek.mahajan@freescale.com> | 2009-05-25 17:23:16 +0530 | 
|---|---|---|
| committer | Wolfgang Denk <wd@denx.de> | 2009-06-12 20:47:17 +0200 | 
| commit | 4ef01010aa4799c759d75e67007fdd3a38c88c8a (patch) | |
| tree | 6a063cc588e2f6bc7e74ef40751dee48538def6d /include | |
| parent | ed90d2c87158e5114b6009fa95bb6417e4b27b3e (diff) | |
| download | olio-uboot-2014.01-4ef01010aa4799c759d75e67007fdd3a38c88c8a.tar.xz olio-uboot-2014.01-4ef01010aa4799c759d75e67007fdd3a38c88c8a.zip | |
mpc83xx: USB: Reorganized its support
The following patch reorganizes/reworks the USB support for mpc83xx
as under:-
  * Moves the 83xx USB clock init from drivers/usb/host/ehci-fsl.c to
    cpu/mpx83xx/cpu_init.c
  * Board specific usb_phy_type is read from the environment
  * Adds USB EHCI specific structure in include/usb/ehci-fsl.h
  * Copyrights revamped in most of the following files
Signed-off-by: Vivek Mahajan <vivek.mahajan@freescale.com>
Signed-off-by: Remy Bohmer <linux@bohmer.net>
Diffstat (limited to 'include')
| -rw-r--r-- | include/asm-ppc/immap_83xx.h | 5 | ||||
| -rw-r--r-- | include/usb/ehci-fsl.h | 63 | 
2 files changed, 66 insertions, 2 deletions
| diff --git a/include/asm-ppc/immap_83xx.h b/include/asm-ppc/immap_83xx.h index 1e67de6c9..8f945a151 100644 --- a/include/asm-ppc/immap_83xx.h +++ b/include/asm-ppc/immap_83xx.h @@ -1,5 +1,5 @@  /* - * (C) Copyright 2004-2007 Freescale Semiconductor, Inc. + * (C) Copyright 2004-2009 Freescale Semiconductor, Inc.   *   * MPC83xx Internal Memory Map   * @@ -897,4 +897,7 @@ typedef struct immap {  #define CONFIG_SYS_MPC83xx_ESDHC_OFFSET	(0x2e000)  #define CONFIG_SYS_MPC83xx_ESDHC_ADDR	(CONFIG_SYS_IMMR + CONFIG_SYS_MPC83xx_ESDHC_OFFSET) +#define CONFIG_SYS_MPC83xx_USB_OFFSET	0x23000 +#define CONFIG_SYS_MPC83xx_USB_ADDR \ +			(CONFIG_SYS_IMMR + CONFIG_SYS_MPC83xx_USB_OFFSET)  #endif				/* __IMMAP_83xx__ */ diff --git a/include/usb/ehci-fsl.h b/include/usb/ehci-fsl.h index c429af125..7ae948c67 100644 --- a/include/usb/ehci-fsl.h +++ b/include/usb/ehci-fsl.h @@ -1,5 +1,5 @@  /* - * Copyright (c) 2005 freescale semiconductor + * Copyright (c) 2005, 2009 Freescale Semiconductor, Inc   * Copyright (c) 2005 MontaVista Software   * Copyright (c) 2008 Excito Elektronik i Sk=E5ne AB   * @@ -22,6 +22,8 @@  #ifndef _EHCI_FSL_H  #define _EHCI_FSL_H +#include <asm/processor.h> +  /* Global offsets */  #define FSL_SKIP_PCI		0x100 @@ -83,4 +85,63 @@  #define MPC83XX_SCCR_USB_DRCM_01	0x00100000  #define MPC83XX_SCCR_USB_DRCM_10	0x00200000 +#if defined(CONFIG_MPC83XX) +#define CONFIG_SYS_MPC8xxx_USB_ADDR CONFIG_SYS_MPC83xx_USB_ADDR +#endif + +/* + * USB Registers + */ +struct usb_ehci { +	u8	res1[0x100]; +	u16	caplength;	/* 0x100 - Capability Register Length */ +	u16	hciversion;	/* 0x102 - Host Interface Version */ +	u32	hcsparams;	/* 0x104 - Host Structural Parameters */ +	u32	hccparams;	/* 0x108 - Host Capability Parameters */ +	u8	res2[0x14]; +	u32	dciversion;	/* 0x120 - Device Interface Version */ +	u32	dciparams;	/* 0x124 - Device Controller Params */ +	u8	res3[0x18]; +	u32	usbcmd;		/* 0x140 - USB Command */ +	u32	usbsts;		/* 0x144 - USB Status */ +	u32	usbintr;	/* 0x148 - USB Interrupt Enable */ +	u32	frindex;	/* 0x14C - USB Frame Index */ +	u8	res4[0x4]; +	u32	perlistbase;	/* 0x154 - Periodic List Base +					 - USB Device Address */ +	u32	ep_list_addr;	/* 0x158 - Next Asynchronous List +					 - End Point Address */ +	u8	res5[0x4]; +	u32	burstsize;	/* 0x160 - Programmable Burst Size */ +	u32	txfilltuning;	/* 0x164 - Host TT Transmit +					   pre-buffer packet tuning */ +	u8	res6[0x8]; +	u32	ulpi_viewpoint;	/* 0x170 - ULPI Reister Access */ +	u8	res7[0xc]; +	u32	config_flag;	/* 0x180 - Configured Flag Register */ +	u32	portsc;		/* 0x184 - Port status/control */ +	u8	res8[0x20]; +	u32	usbmode;	/* 0x1a8 - USB Device Mode */ +	u32	epsetupstat;	/* 0x1ac - End Point Setup Status */ +	u32	epprime;	/* 0x1b0 - End Point Init Status */ +	u32	epflush;	/* 0x1b4 - End Point De-initlialize */ +	u32	epstatus;	/* 0x1b8 - End Point Status */ +	u32	epcomplete;	/* 0x1bc - End Point Complete */ +	u32	epctrl0;	/* 0x1c0 - End Point Control 0 */ +	u32	epctrl1;	/* 0x1c4 - End Point Control 1 */ +	u32	epctrl2;	/* 0x1c8 - End Point Control 2 */ +	u32	epctrl3;	/* 0x1cc - End Point Control 3 */ +	u32	epctrl4;	/* 0x1d0 - End Point Control 4 */ +	u32	epctrl5;	/* 0x1d4 - End Point Control 5 */ +	u8	res9[0x228]; +	u32	snoop1;		/* 0x400 - Snoop 1 */ +	u32	snoop2;		/* 0x404 - Snoop 2 */ +	u32	age_cnt_limit;	/* 0x408 - Age Count Threshold */ +	u32	prictrl;	/* 0x40c - Priority Control */ +	u32	sictrl;		/* 0x410 - System Interface Control */ +	u8	res10[0xEC]; +	u32	control;	/* 0x500 - Control */ +	u8	res11[0xafc]; +}; +  #endif /* _EHCI_FSL_H */ |