2019-06-05 16:05:56 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* arch/arm/src/cxd56xx/cxd56_usbdev.h
|
|
|
|
*
|
2021-01-24 16:28:57 +01:00
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at
|
2019-06-05 16:05:56 +02:00
|
|
|
*
|
2021-01-24 16:28:57 +01:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2019-06-05 16:05:56 +02:00
|
|
|
*
|
2021-01-24 16:28:57 +01:00
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
2019-06-05 16:05:56 +02:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2020-01-07 15:21:58 +01:00
|
|
|
#ifndef __ARCH_ARM_SRC_CXD56XX_CXD56_USBDEV_H
|
|
|
|
#define __ARCH_ARM_SRC_CXD56XX_CXD56_USBDEV_H
|
2019-06-05 16:05:56 +02:00
|
|
|
|
2019-06-10 15:00:57 +02:00
|
|
|
/****************************************************************************
|
2019-06-05 16:05:56 +02:00
|
|
|
* Included Files
|
2019-06-10 15:00:57 +02:00
|
|
|
****************************************************************************/
|
2019-06-05 16:05:56 +02:00
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
2019-06-10 15:00:57 +02:00
|
|
|
/****************************************************************************
|
2019-06-05 16:05:56 +02:00
|
|
|
* Pre-processor Definitions
|
2019-06-10 15:00:57 +02:00
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/* Register offsets */
|
2019-06-05 16:05:56 +02:00
|
|
|
|
|
|
|
/* Common Register Offsets */
|
|
|
|
|
|
|
|
#define CXD56_USB_IN_EP_CONTROL(x) (CXD56_USBDEV_BASE + 0x0000 + ((x) * 0x20))
|
|
|
|
#define CXD56_USB_IN_EP_STATUS(x) (CXD56_USBDEV_BASE + 0x0004 + ((x) * 0x20))
|
|
|
|
#define CXD56_USB_IN_EP_BUFSIZE(x) (CXD56_USBDEV_BASE + 0x0008 + ((x) * 0x20))
|
|
|
|
#define CXD56_USB_IN_EP_MAXPKTSIZE(x) (CXD56_USBDEV_BASE + 0x000c + ((x) * 0x20))
|
|
|
|
#define CXD56_USB_IN_EP_DATADESC(x) (CXD56_USBDEV_BASE + 0x0014 + ((x) * 0x20))
|
|
|
|
|
|
|
|
#define CXD56_USB_OUT_EP_CONTROL(x) (CXD56_USBDEV_BASE + 0x0200 + ((x) * 0x20))
|
|
|
|
#define CXD56_USB_OUT_EP_STATUS(x) (CXD56_USBDEV_BASE + 0x0204 + ((x) * 0x20))
|
|
|
|
#define CXD56_USB_OUT_EP_BUFSIZE(x) (CXD56_USBDEV_BASE + 0x020c + ((x) * 0x20))
|
|
|
|
#define CXD56_USB_OUT_EP_SETUP(x) (CXD56_USBDEV_BASE + 0x0210 + ((x) * 0x20))
|
|
|
|
#define CXD56_USB_OUT_EP_DATADESC(x) (CXD56_USBDEV_BASE + 0x0214 + ((x) * 0x20))
|
|
|
|
|
|
|
|
#define CXD56_USB_DEV_CONFIG (CXD56_USBDEV_BASE + 0x0400)
|
|
|
|
#define CXD56_USB_DEV_CONTROL (CXD56_USBDEV_BASE + 0x0404)
|
|
|
|
#define CXD56_USB_DEV_STATUS (CXD56_USBDEV_BASE + 0x0408)
|
|
|
|
#define CXD56_USB_DEV_INTR (CXD56_USBDEV_BASE + 0x040c)
|
|
|
|
#define CXD56_USB_DEV_INTR_MASK (CXD56_USBDEV_BASE + 0x0410)
|
|
|
|
#define CXD56_USB_DEV_EP_INTR (CXD56_USBDEV_BASE + 0x0414)
|
|
|
|
#define CXD56_USB_DEV_EP_INTR_MASK (CXD56_USBDEV_BASE + 0x0418)
|
|
|
|
|
|
|
|
#define CXD56_USB_DEV_UDC_EP0 (CXD56_USBDEV_BASE + 0x0504)
|
|
|
|
#define CXD56_USB_DEV_UDC_EP1 (CXD56_USBDEV_BASE + 0x0508)
|
|
|
|
#define CXD56_USB_DEV_UDC_EP2 (CXD56_USBDEV_BASE + 0x050c)
|
|
|
|
#define CXD56_USB_DEV_UDC_EP3 (CXD56_USBDEV_BASE + 0x0510)
|
|
|
|
#define CXD56_USB_DEV_UDC_EP4 (CXD56_USBDEV_BASE + 0x0514)
|
|
|
|
#define CXD56_USB_DEV_UDC_EP5 (CXD56_USBDEV_BASE + 0x0518)
|
|
|
|
#define CXD56_USB_DEV_UDC_EP6 (CXD56_USBDEV_BASE + 0x051c)
|
|
|
|
#define CXD56_USB_DEV_UDC_EP(x) (CXD56_USB_DEV_UDC_EP0 + ((x) * 4))
|
|
|
|
|
|
|
|
#define CXD56_USB_SYS_INTR (CXD56_USBDEV_BASE + 0x0800)
|
|
|
|
#define CXD56_USB_SYS_INTR_MASK (CXD56_USBDEV_BASE + 0x0804)
|
|
|
|
#define CXD56_USB_BUSY (CXD56_USBDEV_BASE + 0x0808)
|
|
|
|
#define CXD56_USB_VBUS_CTRL (CXD56_USBDEV_BASE + 0x080c)
|
|
|
|
#define CXD56_USB_RESET (CXD56_USBDEV_BASE + 0x0810)
|
|
|
|
|
|
|
|
#define CXD56_USB_SUSPEND_MASK (CXD56_USBDEV_BASE + 0x081c)
|
|
|
|
|
|
|
|
#define CXD56_USB_PJ_DEMAND (CXD56_USBDEV_BASE + 0x0830)
|
|
|
|
|
|
|
|
#define CXD56_USB_PHY_CONFIG0 (CXD56_USBDEV_BASE + 0x083c)
|
|
|
|
#define CXD56_USB_PHY_CONFIG1 (CXD56_USBDEV_BASE + 0x0840)
|
|
|
|
#define CXD56_USB_PHY_CONFIG2 (CXD56_USBDEV_BASE + 0x0844)
|
|
|
|
|
|
|
|
/* EP types */
|
|
|
|
|
|
|
|
#define USB_EP_CONTROL 0
|
|
|
|
#define USB_EP_ISOCHRONOUS 1
|
|
|
|
#define USB_EP_BULK 2
|
|
|
|
#define USB_EP_INTERRUPT 3
|
|
|
|
|
|
|
|
/* EP control bits */
|
|
|
|
|
|
|
|
#define USB_MRXFLUSH (1<<12)
|
|
|
|
#define USB_CLOSEDESC (1<<11)
|
|
|
|
#define USB_SENDNULL (1<<10)
|
|
|
|
#define USB_RRDY (1<<9)
|
|
|
|
#define USB_CNAK (1<<8)
|
|
|
|
#define USB_SNAK (1<<7)
|
|
|
|
#define USB_NAK (1<<6)
|
|
|
|
#define USB_ET(x) ((x)<<4)
|
|
|
|
#define USB_P (1<<3)
|
|
|
|
#define USB_SN (1<<2)
|
|
|
|
#define USB_F (1<<1)
|
|
|
|
#define USB_STALL (1<<0)
|
|
|
|
|
|
|
|
/* USB device configuration */
|
|
|
|
|
|
|
|
#define USB_CONFIG_DDR (1<<19)
|
|
|
|
#define USB_CONFIG_SET_DESC (1<<18)
|
|
|
|
#define USB_CONFIG_CSR_PRG (1<<17)
|
|
|
|
#define USB_CONFIG_HALT_STATUS (1<<16)
|
|
|
|
#define USB_CONFIG_HS_TIMEOUT_CALIB(x) (((x)&7)<<13)
|
|
|
|
#define USB_CONFIG_FS_TIMEOUT_CALIB(x) (((x)&7)<<10)
|
|
|
|
#define USB_CONFIG_PHY_ERROR_DETECT (1<<9)
|
|
|
|
#define USB_CONFIG_STATUS_1 (1<<8)
|
|
|
|
#define USB_CONFIG_STATUS (1<<7)
|
|
|
|
#define USB_CONFIG_DIR (1<<6)
|
|
|
|
#define USB_CONFIG_PI (1<<5)
|
|
|
|
#define USB_CONFIG_SS (1<<4)
|
|
|
|
#define USB_CONFIG_SP (1<<3)
|
|
|
|
#define USB_CONFIG_RWKP (1<<2)
|
|
|
|
#define USB_CONFIG_SPD(x) (((x)&3))
|
|
|
|
#define USB_CONFIG_HS 0
|
|
|
|
#define USB_CONFIG_FS 1
|
|
|
|
#define USB_CONFIG_SPD_MASK 3
|
|
|
|
|
|
|
|
/* USB device control */
|
|
|
|
|
|
|
|
#define USB_CTRL_THLEN(x) (((x)&0xff)<<24)
|
|
|
|
#define USB_CTRL_BRLEN(x) (((x)&0xff)<<16)
|
|
|
|
#define USB_CTRL_SRXFLUSH (1<<14)
|
|
|
|
#define USB_CTRL_CSR_DONE (1<<13)
|
|
|
|
#define USB_CTRL_DEVNAK (1<<12)
|
|
|
|
#define USB_CTRL_SCALE (1<<11)
|
|
|
|
#define USB_CTRL_SD (1<<10)
|
|
|
|
#define USB_CTRL_MODE (1<<9)
|
|
|
|
#define USB_CTRL_BREN (1<<8)
|
|
|
|
#define USB_CTRL_THE (1<<7)
|
|
|
|
#define USB_CTRL_BF (1<<6)
|
|
|
|
#define USB_CTRL_BE (1<<5)
|
|
|
|
#define USB_CTRL_DU (1<<4)
|
|
|
|
#define USB_CTRL_TDE (1<<3)
|
|
|
|
#define USB_CTRL_RDE (1<<2)
|
|
|
|
#define USB_CTRL_RES (1<<0)
|
|
|
|
|
|
|
|
/* USB device status bits */
|
|
|
|
|
|
|
|
#define USB_STATUS_RMTWKP_STATE (1<<17)
|
|
|
|
#define USB_STATUS_PHYERROR (1<<16)
|
|
|
|
#define USB_STATUS_RXFIFOEMPTY (1<<15)
|
|
|
|
#define USB_STATUS_SPD_SHIFT 13
|
|
|
|
#define USB_STATUS_SPD_MASK (3<<USB_STATUS_SPD_SHIFT)
|
|
|
|
#define USB_STATUS_SPD(x) (((x) & USB_STATUS_SPD_MASK) >> USB_STATUS_SPD_SHIFT)
|
|
|
|
#define USB_STATUS_SUSP (1<<12)
|
|
|
|
#define USB_STATUS_ALT(x) (((x)>>8)&0xf)
|
|
|
|
#define USB_STATUS_INTF(x) (((x)>>4)&0xf)
|
|
|
|
#define USB_STATUS_CFG(x) (((x)>>0)&0xf)
|
|
|
|
|
|
|
|
/* USB device interrupt bits */
|
|
|
|
|
|
|
|
#define USB_INT_RMTWKP_STATE (1<<7)
|
|
|
|
#define USB_INT_ENUM (1<<6)
|
|
|
|
#define USB_INT_SOF (1<<5)
|
|
|
|
#define USB_INT_US (1<<4)
|
|
|
|
#define USB_INT_UR (1<<3)
|
|
|
|
#define USB_INT_ES (1<<2)
|
|
|
|
#define USB_INT_SI (1<<1)
|
|
|
|
#define USB_INT_SC (1<<0)
|
|
|
|
|
|
|
|
/* USB system interrupt bits */
|
|
|
|
|
|
|
|
#define USB_INT_VBUS_DISC (1<<3)
|
|
|
|
#define USB_INT_VBUS_CONN (1<<2)
|
|
|
|
#define USB_INT_RESUME (1<<1)
|
|
|
|
#define USB_INT_READY (1<<0)
|
|
|
|
|
|
|
|
/* USB endpoint interrupt bits */
|
|
|
|
|
|
|
|
#define USB_INT_CDC_CLEAR (1<<28) /* */
|
|
|
|
#define USB_INT_XFERDONE (1<<27) /* Tfansfer Done/Transmit FIFO Empty */
|
2019-09-11 16:56:56 +02:00
|
|
|
#define USB_INT_RSS (1<<26) /* Received Set Stall Indication */
|
2019-06-05 16:05:56 +02:00
|
|
|
#define USB_INT_RCS (1<<25) /* Received Clear Stall Indication */
|
|
|
|
#define USB_INT_TXEMPTY (1<<24) /* Transmit FIFO Empty */
|
|
|
|
#define USB_INT_ISO_IN_DONE (1<<23) /* Isochronous IN transaction for the current microframe is complete */
|
|
|
|
#define USB_INT_RX_PKT_SIZE(x) (((x)>>11)&0xfff) /* Receive Packet Size */
|
|
|
|
#define USB_INT_TDC (1<<10) /* Transmit DMA Completion */
|
|
|
|
#define USB_INT_HE (1<<9) /* Error response on the host bus */
|
|
|
|
#define USB_INT_MRXFIFOEMPTY (1<<8) /* Receive Address FIFO Empty Status */
|
|
|
|
#define USB_INT_BNA (1<<7) /* Buffer Not Available */
|
|
|
|
#define USB_INT_IN (1<<6) /* IN token has been received */
|
|
|
|
#define USB_INT_OUT(x) ((x) & (3 << 4)) /* OUT packet has been received. */
|
|
|
|
#define USB_INT_OUT_DATA (1 << 4)
|
|
|
|
#define USB_INT_OUT_SETUP (2 << 4)
|
|
|
|
|
|
|
|
/* PHY Configuration 0 bits */
|
|
|
|
|
|
|
|
#define PHY_STAGSELECT (1u<<31)
|
|
|
|
#define PHY_SHORTCKT_PROT (1u<<30)
|
|
|
|
#define PHY_HSFALLCNTRL (1u<<29)
|
|
|
|
#define PHY_HSRXOFFSET(x) (((x)&3)<<27)
|
|
|
|
#define PHY_HSRXEQUALIZE (1u<<26)
|
|
|
|
#define PHY_INSQUETUNE(x) (((x)&3)<<24)
|
|
|
|
#define PHY_ZHSDRV(x) (((x)&3)<<22)
|
|
|
|
#define PHY_IHSTX(x) (((x)&0xf)<<18)
|
|
|
|
#define PHY_INHSRFRED (1u<<17)
|
|
|
|
#define PHY_INFSRFCNTL (1u<<16)
|
|
|
|
#define PHY_INHSIPLUSENABLE (1u<<15)
|
|
|
|
#define PHY_INHSIPLUS (1u<<14)
|
|
|
|
#define PHY_INHSIMINUS (1u<<13)
|
|
|
|
#define PHY_INHSDRVSLEW (1u<<12)
|
|
|
|
#define PHY_INLFSFBCAP (1u<<11)
|
|
|
|
#define PHY_INTRCC1MA (1u<<10)
|
|
|
|
#define PHY_INCURRENTENABLE (1u<<9)
|
|
|
|
#define PHY_INAFETRIM(x) ((x)&0x1ff)
|
|
|
|
|
|
|
|
/* PHY Configuration 1 bits */
|
|
|
|
|
|
|
|
#define PHY_STRB_BYPASS (1u<<31)
|
|
|
|
#define PHY_STRB (1u<<30)
|
|
|
|
#define PHY_DITHER_DISABLE_RECT (1u<<29)
|
|
|
|
#define PHY_DITHER_DISABLE_TRI (1u<<28)
|
|
|
|
#define PHY_FRAC_CONTROL (1u<<27)
|
|
|
|
#define PHY_PLLENABLE (1u<<26)
|
|
|
|
#define PHY_FRAC_INPUT(x) (((x)&0xffff)<<10)
|
|
|
|
#define PHY_ODF(x) (((x)&0x7)<<7)
|
|
|
|
#define PHY_NDIV(x) ((x)&0x3f)
|
|
|
|
|
|
|
|
/* DMA descriptor status bits */
|
|
|
|
|
|
|
|
#define DESC_BS_SHIFT 30
|
|
|
|
#define DESC_BS_MASK (3 << DESC_BS_SHIFT)
|
|
|
|
#define DESC_BS_HOST_READY (0 << DESC_BS_SHIFT)
|
|
|
|
#define DESC_BS_DMA_BUSY (1 << DESC_BS_SHIFT)
|
|
|
|
#define DESC_BS_DMA_DONE (2 << DESC_BS_SHIFT)
|
|
|
|
#define DESC_BS_HOST_BUSY (3 << DESC_BS_SHIFT)
|
|
|
|
#define IS_BS_HOST_READY(desc) (((desc)->status & DESC_BS_MASK) == DESC_BS_HOST_READY)
|
|
|
|
#define IS_BS_DMA_BUSY(desc) (((desc)->status & DESC_BS_MASK) == DESC_BS_DMA_BUSY)
|
|
|
|
#define IS_BS_DMA_DONE(desc) (((desc)->status & DESC_BS_MASK) == DESC_BS_DMA_DONE)
|
|
|
|
#define IS_BS_HOST_BUSY(desc) (((desc)->status & DESC_BS_MASK) == DESC_BS_HOST_BUSY)
|
|
|
|
|
|
|
|
/* There is same definitions for TX/RX */
|
|
|
|
|
|
|
|
#define DESC_STS_SHIFT 28
|
|
|
|
#define DESC_STS_MASK (3 << DESC_STS_SHIFT)
|
|
|
|
#define DESC_STS_SUCCESS (0 << DESC_STS_SHIFT)
|
|
|
|
#define DESC_STS_DESERR (1 << DESC_STS_SHIFT)
|
|
|
|
#define DESC_STS_BUFERR (3 << DESC_STS_SHIFT)
|
|
|
|
#define IS_STS_SUCCESS(desc) (((desc)->status & DESC_STS_MASK) == DESC_STS_SUCCESS)
|
|
|
|
#define IS_STS_DESERR(desc) (((desc)->status & DESC_STS_MASK) == DESC_STS_DESERR)
|
|
|
|
#define IS_STS_BUFERR(desc) (((desc)->status & DESC_STS_MASK) == DESC_STS_BUFERR)
|
|
|
|
|
|
|
|
#define DESC_LAST (1 << 27)
|
|
|
|
|
|
|
|
#define DESC_SIZE_MASK (0xffff)
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: cxd56_usbdev_setsigno
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* cxd56xx usb device driver attach / detach event signal
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
int cxd56_usbdev_setsigno(int signo);
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: cxd56_usbdev_procfs_register
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Register the usbdev procfs file system entry
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifdef CONFIG_FS_PROCFS_REGISTER
|
|
|
|
int cxd56_usbdev_procfs_register(void);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* __ARCH_ARM_SRC_CXD56XX_CXD56_USBDEV_H */
|