minix/drivers/usbd/hcd/musb/musb_regs.h
Kees Jongenburger ed3391fd23 arm:adding the usbd source code.
Change-Id: Ia3c50a8c5e11bf20100354de266913112cc236f9

http://gerrit.minix3.org/#/c/2689/
2014-07-28 17:05:38 +02:00

126 lines
4.4 KiB
C
Executable file

/*
* Common MUSB core registers definitions
*/
#ifndef _MUSB_REGS_H_
#define _MUSB_REGS_H_
#include <usb/hcd_common.h>
/*===========================================================================*
* MUSB core register offsets *
*===========================================================================*/
#define MUSB_REG_FADDR 0x00u
#define MUSB_REG_POWER 0x01u
#define MUSB_REG_INTRTX 0x02u
#define MUSB_REG_INTRRX 0x04u
#define MUSB_REG_INTRTXE 0x06u
#define MUSB_REG_INTRRXE 0x08u
#define MUSB_REG_INTRUSB 0x0Au
#define MUSB_REG_INTRUSBE 0x0Bu
#define MUSB_REG_FRAME 0x0Cu
#define MUSB_REG_INDEX 0x0Eu
#define MUSB_REG_TESTMODE 0x0Fu
/* Proxy registers for endpoint configuration,
* that correspond to specific endpoint's register space
* selected with MUSB_REG_INDEX */
#define MUSB_REG_TXMAXP 0x10u
#define MUSB_REG_PERI_CSR0 0x12u
#define MUSB_REG_HOST_CSR0 MUSB_REG_PERI_CSR0
#define MUSB_REG_PERI_TXCSR MUSB_REG_PERI_CSR0
#define MUSB_REG_HOST_TXCSR MUSB_REG_PERI_CSR0
#define MUSB_REG_RXMAXP 0x14u
#define MUSB_REG_PERI_RXCSR 0x16u
#define MUSB_REG_HOST_RXCSR MUSB_PERI_RXCSR
#define MUSB_REG_COUNT0 0x18u
#define MUSB_REG_RXCOUNT MUSB_COUNT0
#define MUSB_REG_HOST_TYPE0 0x1Au
#define MUSB_REG_HOST_TXTYPE MUSB_HOST_TYPE0
#define MUSB_REG_HOST_NAKLIMIT0 0x1Bu
#define MUSB_REG_HOST_TXINTERVAL MUSB_HOST_NAKLIMIT0
#define MUSB_REG_HOST_RXTYPE 0x1Cu
#define MUSB_REG_HOST_RXINTERVAL 0x1Du
#define MUSB_REG_CONFIGDATA 0x1Fu
#define MUSB_REG_FIFO0 0x20u
#define MUSB_REG_FIFO1 0x24u
#define MUSB_REG_FIFO2 0x28u
#define MUSB_REG_FIFO3 0x2Cu
#define MUSB_REG_FIFO4 0x30u
#define MUSB_REG_FIFO_LEN 0x04u
#define MUSB_REG_DEVCTL 0x60u
#define MUSB_REG_TXFIFOSZ 0x62u
#define MUSB_REG_RXFIFOSZ 0x63u
#define MUSB_REG_TXFIFOADDR 0x64u
#define MUSB_REG_RXFIFOADDR 0x66u
#define MUSB_REG_TXFUNCADDR 0x80u
#define MUSB_REG_TXHUBADDR 0x82u
#define MUSB_REG_TXHUBPORT 0x83u
#define MUSB_REG_RXFUNCADDR 0x84u
#define MUSB_REG_RXHUBADDR 0x86u
#define MUSB_REG_RXHUBPORT 0x87u
/*===========================================================================*
* MUSB core register values *
*===========================================================================*/
/* POWER */
#define MUSB_VAL_POWER_ENSUSPM HCD_BIT(0)
#define MUSB_VAL_POWER_SUSPENDM HCD_BIT(1)
#define MUSB_VAL_POWER_RESUME HCD_BIT(2)
#define MUSB_VAL_POWER_RESET HCD_BIT(3)
#define MUSB_VAL_POWER_HSMODE HCD_BIT(4)
#define MUSB_VAL_POWER_HSEN HCD_BIT(5)
#define MUSB_VAL_POWER_SOFTCONN HCD_BIT(6)
#define MUSB_VAL_POWER_ISOUPDATE HCD_BIT(7)
/* DEVCTL */
#define MUSB_VAL_DEVCTL_SESSION HCD_BIT(0)
#define MUSB_VAL_DEVCTL_HOSTREQ HCD_BIT(1)
#define MUSB_VAL_DEVCTL_HOSTMODE HCD_BIT(2)
#define MUSB_VAL_DEVCTL_VBUS_1 HCD_BIT(3)
#define MUSB_VAL_DEVCTL_VBUS_2 HCD_BIT(4)
#define MUSB_VAL_DEVCTL_VBUS_3 (HCD_BIT(3) | HCD_BIT(4))
#define MUSB_VAL_DEVCTL_LSDEV HCD_BIT(5)
#define MUSB_VAL_DEVCTL_FSDEV HCD_BIT(6)
#define MUSB_VAL_DEVCTL_BDEVICE HCD_BIT(7)
/* INTRUSBE */
#define MUSB_VAL_INTRUSBE_SUSPEND HCD_BIT(0)
#define MUSB_VAL_INTRUSBE_RESUME HCD_BIT(1)
#define MUSB_VAL_INTRUSBE_RESET_BABBLE HCD_BIT(2)
#define MUSB_VAL_INTRUSBE_SOF HCD_BIT(3)
#define MUSB_VAL_INTRUSBE_CONN HCD_BIT(4)
#define MUSB_VAL_INTRUSBE_DISCON HCD_BIT(5)
#define MUSB_VAL_INTRUSBE_SESSREQ HCD_BIT(6)
#define MUSB_VAL_INTRUSBE_VBUSERR HCD_BIT(7)
/* HOST_TYPE0 */
#define MUSB_VAL_HOST_TYPE0_MASK (HCD_BIT(6) | HCD_BIT(7))
#define MUSB_VAL_HOST_TYPE0_HIGH_SPEED HCD_BIT(6)
#define MUSB_VAL_HOST_TYPE0_FULL_SPEED HCD_BIT(7)
#define MUSB_VAL_HOST_TYPE0_LOW_SPEED (HCD_BIT(6) | HCD_BIT(7))
/* INTRTXE */
#define MUSB_VAL_INTRTXE_EP0 HCD_BIT(0)
#define MUSB_VAL_INTRTXE_EP1TX HCD_BIT(1)
#define MUSB_VAL_INTRTXE_EP2TX HCD_BIT(2)
#define MUSB_VAL_INTRTXE_EP3TX HCD_BIT(3)
#define MUSB_VAL_INTRTXE_EP4TX HCD_BIT(4)
/* HOST_CSR0 */
#define MUSB_VAL_HOST_CSR0_RXPKTRDY HCD_BIT(0)
#define MUSB_VAL_HOST_CSR0_TXPKTRDY HCD_BIT(1)
#define MUSB_VAL_HOST_CSR0_RXSTALL HCD_BIT(2)
#define MUSB_VAL_HOST_CSR0_SETUPPKT HCD_BIT(3)
#define MUSB_VAL_HOST_CSR0_ERROR HCD_BIT(4)
#define MUSB_VAL_HOST_CSR0_REQPKT HCD_BIT(5)
#define MUSB_VAL_HOST_CSR0_STATUSPKT HCD_BIT(6)
#define MUSB_VAL_HOST_CSR0_NAK_TIMEOUT HCD_BIT(7)
#define MUSB_VAL_HOST_CSR0_FLUSHFIFO HCD_BIT(8)
#endif /* !_MUSB_REGS_H_ */