more ci abstract
This commit is contained in:
		
							
								
								
									
										61
									
								
								src/portable/chipidea/ci_hs/ci_hs_imxrt.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								src/portable/chipidea/ci_hs/ci_hs_imxrt.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,61 @@
 | 
			
		||||
/*
 | 
			
		||||
 * The MIT License (MIT)
 | 
			
		||||
 *
 | 
			
		||||
 * Copyright (c) 2021, Ha Thach (tinyusb.org)
 | 
			
		||||
 *
 | 
			
		||||
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 | 
			
		||||
 * of this software and associated documentation files (the "Software"), to deal
 | 
			
		||||
 * in the Software without restriction, including without limitation the rights
 | 
			
		||||
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | 
			
		||||
 * copies of the Software, and to permit persons to whom the Software is
 | 
			
		||||
 * furnished to do so, subject to the following conditions:
 | 
			
		||||
 *
 | 
			
		||||
 * The above copyright notice and this permission notice shall be included in
 | 
			
		||||
 * all copies or substantial portions of the Software.
 | 
			
		||||
 *
 | 
			
		||||
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
			
		||||
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
			
		||||
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
			
		||||
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
			
		||||
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
			
		||||
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | 
			
		||||
 * THE SOFTWARE.
 | 
			
		||||
 *
 | 
			
		||||
 * This file is part of the TinyUSB stack.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef _CI_HS_IMXRT_H_
 | 
			
		||||
#define _CI_HS_IMXRT_H_
 | 
			
		||||
 | 
			
		||||
#ifdef __cplusplus
 | 
			
		||||
 extern "C" {
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#include "fsl_device_registers.h"
 | 
			
		||||
 | 
			
		||||
static const dcd_controller_t _dcd_controller[] =
 | 
			
		||||
{
 | 
			
		||||
  // RT1010 and RT1020 only has 1 USB controller
 | 
			
		||||
  #if FSL_FEATURE_SOC_USBHS_COUNT == 1
 | 
			
		||||
    { .regs = (ci_hs_regs_t*) USB_BASE , .irqnum = USB_OTG1_IRQn, .ep_count = 8 }
 | 
			
		||||
  #else
 | 
			
		||||
    { .regs = (ci_hs_regs_t*) USB1_BASE, .irqnum = USB_OTG1_IRQn, .ep_count = 8 },
 | 
			
		||||
    { .regs = (ci_hs_regs_t*) USB2_BASE, .irqnum = USB_OTG2_IRQn, .ep_count = 8 }
 | 
			
		||||
  #endif
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
void dcd_int_enable(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  NVIC_EnableIRQ(_dcd_controller[rhport].irqnum);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void dcd_int_disable(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  NVIC_DisableIRQ(_dcd_controller[rhport].irqnum);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifdef __cplusplus
 | 
			
		||||
 }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
							
								
								
									
										57
									
								
								src/portable/chipidea/ci_hs/ci_hs_lpc18_43.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								src/portable/chipidea/ci_hs/ci_hs_lpc18_43.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,57 @@
 | 
			
		||||
/*
 | 
			
		||||
 * The MIT License (MIT)
 | 
			
		||||
 *
 | 
			
		||||
 * Copyright (c) 2021, Ha Thach (tinyusb.org)
 | 
			
		||||
 *
 | 
			
		||||
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 | 
			
		||||
 * of this software and associated documentation files (the "Software"), to deal
 | 
			
		||||
 * in the Software without restriction, including without limitation the rights
 | 
			
		||||
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | 
			
		||||
 * copies of the Software, and to permit persons to whom the Software is
 | 
			
		||||
 * furnished to do so, subject to the following conditions:
 | 
			
		||||
 *
 | 
			
		||||
 * The above copyright notice and this permission notice shall be included in
 | 
			
		||||
 * all copies or substantial portions of the Software.
 | 
			
		||||
 *
 | 
			
		||||
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
			
		||||
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
			
		||||
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
			
		||||
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
			
		||||
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
			
		||||
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | 
			
		||||
 * THE SOFTWARE.
 | 
			
		||||
 *
 | 
			
		||||
 * This file is part of the TinyUSB stack.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef _CI_HS_LPC18_43_H_
 | 
			
		||||
#define _CI_HS_LPC18_43_H_
 | 
			
		||||
 | 
			
		||||
#ifdef __cplusplus
 | 
			
		||||
 extern "C" {
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// LPCOpen for 18xx & 43xx
 | 
			
		||||
#include "chip.h"
 | 
			
		||||
 | 
			
		||||
static const dcd_controller_t _dcd_controller[] =
 | 
			
		||||
{
 | 
			
		||||
  { .regs = (ci_hs_regs_t*) LPC_USB0_BASE, .irqnum = USB0_IRQn, .ep_count = 6 },
 | 
			
		||||
  { .regs = (ci_hs_regs_t*) LPC_USB1_BASE, .irqnum = USB1_IRQn, .ep_count = 4 }
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
void dcd_int_enable(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  NVIC_EnableIRQ(_dcd_controller[rhport].irqnum);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void dcd_int_disable(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  NVIC_DisableIRQ(_dcd_controller[rhport].irqnum);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifdef __cplusplus
 | 
			
		||||
 }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
@@ -85,49 +85,57 @@ enum {
 | 
			
		||||
typedef struct
 | 
			
		||||
{
 | 
			
		||||
  //------------- ID + HW Parameter Registers-------------//
 | 
			
		||||
  __I  uint32_t TU_RESERVED[64]; ///< For iMX RT10xx, but not used by LPC18XX/LPC43XX
 | 
			
		||||
  volatile uint32_t TU_RESERVED[64]; ///< For iMX RT10xx, but not used by LPC18XX/LPC43XX
 | 
			
		||||
 | 
			
		||||
  //------------- Capability Registers-------------//
 | 
			
		||||
  __I  uint8_t  CAPLENGTH;       ///< Capability Registers Length
 | 
			
		||||
  __I  uint8_t  TU_RESERVED[1];
 | 
			
		||||
  __I  uint16_t HCIVERSION;      ///< Host Controller Interface Version
 | 
			
		||||
  volatile uint8_t  CAPLENGTH;       ///< Capability Registers Length
 | 
			
		||||
  volatile uint8_t  TU_RESERVED[1];
 | 
			
		||||
  volatile uint16_t HCIVERSION;      ///< Host Controller Interface Version
 | 
			
		||||
 | 
			
		||||
  __I  uint32_t HCSPARAMS;       ///< Host Controller Structural Parameters
 | 
			
		||||
  __I  uint32_t HCCPARAMS;       ///< Host Controller Capability Parameters
 | 
			
		||||
  __I  uint32_t TU_RESERVED[5];
 | 
			
		||||
  volatile uint32_t HCSPARAMS;       ///< Host Controller Structural Parameters
 | 
			
		||||
  volatile uint32_t HCCPARAMS;       ///< Host Controller Capability Parameters
 | 
			
		||||
  volatile uint32_t TU_RESERVED[5];
 | 
			
		||||
 | 
			
		||||
  __I  uint16_t DCIVERSION;      ///< Device Controller Interface Version
 | 
			
		||||
  __I  uint8_t  TU_RESERVED[2];
 | 
			
		||||
  volatile uint16_t DCIVERSION;      ///< Device Controller Interface Version
 | 
			
		||||
  volatile uint8_t  TU_RESERVED[2];
 | 
			
		||||
 | 
			
		||||
  __I  uint32_t DCCPARAMS;       ///< Device Controller Capability Parameters
 | 
			
		||||
  __I  uint32_t TU_RESERVED[6];
 | 
			
		||||
  volatile uint32_t DCCPARAMS;       ///< Device Controller Capability Parameters
 | 
			
		||||
  volatile uint32_t TU_RESERVED[6];
 | 
			
		||||
 | 
			
		||||
  //------------- Operational Registers -------------//
 | 
			
		||||
  __IO uint32_t USBCMD;          ///< USB Command Register
 | 
			
		||||
  __IO uint32_t USBSTS;          ///< USB Status Register
 | 
			
		||||
  __IO uint32_t USBINTR;         ///< Interrupt Enable Register
 | 
			
		||||
  __IO uint32_t FRINDEX;         ///< USB Frame Index
 | 
			
		||||
  __I  uint32_t TU_RESERVED;
 | 
			
		||||
  __IO uint32_t DEVICEADDR;      ///< Device Address
 | 
			
		||||
  __IO uint32_t ENDPTLISTADDR;   ///< Endpoint List Address
 | 
			
		||||
  __I  uint32_t TU_RESERVED;
 | 
			
		||||
  __IO uint32_t BURSTSIZE;       ///< Programmable Burst Size
 | 
			
		||||
  __IO uint32_t TXFILLTUNING;    ///< TX FIFO Fill Tuning
 | 
			
		||||
       uint32_t TU_RESERVED[4];
 | 
			
		||||
  __IO uint32_t ENDPTNAK;        ///< Endpoint NAK
 | 
			
		||||
  __IO uint32_t ENDPTNAKEN;      ///< Endpoint NAK Enable
 | 
			
		||||
  __I  uint32_t TU_RESERVED;
 | 
			
		||||
  __IO uint32_t PORTSC1;         ///< Port Status & Control
 | 
			
		||||
  __I  uint32_t TU_RESERVED[7];
 | 
			
		||||
  __IO uint32_t OTGSC;           ///< On-The-Go Status & control
 | 
			
		||||
  __IO uint32_t USBMODE;         ///< USB Device Mode
 | 
			
		||||
  __IO uint32_t ENDPTSETUPSTAT;  ///< Endpoint Setup Status
 | 
			
		||||
  __IO uint32_t ENDPTPRIME;      ///< Endpoint Prime
 | 
			
		||||
  __IO uint32_t ENDPTFLUSH;      ///< Endpoint Flush
 | 
			
		||||
  __I  uint32_t ENDPTSTAT;       ///< Endpoint Status
 | 
			
		||||
  __IO uint32_t ENDPTCOMPLETE;   ///< Endpoint Complete
 | 
			
		||||
  __IO uint32_t ENDPTCTRL[8];    ///< Endpoint Control 0 - 7
 | 
			
		||||
} dcd_registers_t, hcd_registers_t;
 | 
			
		||||
  volatile uint32_t USBCMD;          ///< USB Command Register
 | 
			
		||||
  volatile uint32_t USBSTS;          ///< USB Status Register
 | 
			
		||||
  volatile uint32_t USBINTR;         ///< Interrupt Enable Register
 | 
			
		||||
  volatile uint32_t FRINDEX;         ///< USB Frame Index
 | 
			
		||||
  volatile uint32_t TU_RESERVED;
 | 
			
		||||
  volatile uint32_t DEVICEADDR;      ///< Device Address
 | 
			
		||||
  volatile uint32_t ENDPTLISTADDR;   ///< Endpoint List Address
 | 
			
		||||
  volatile uint32_t TU_RESERVED;
 | 
			
		||||
  volatile uint32_t BURSTSIZE;       ///< Programmable Burst Size
 | 
			
		||||
  volatile uint32_t TXFILLTUNING;    ///< TX FIFO Fill Tuning
 | 
			
		||||
           uint32_t TU_RESERVED[4];
 | 
			
		||||
  volatile uint32_t ENDPTNAK;        ///< Endpoint NAK
 | 
			
		||||
  volatile uint32_t ENDPTNAKEN;      ///< Endpoint NAK Enable
 | 
			
		||||
  volatile uint32_t TU_RESERVED;
 | 
			
		||||
  volatile uint32_t PORTSC1;         ///< Port Status & Control
 | 
			
		||||
  volatile uint32_t TU_RESERVED[7];
 | 
			
		||||
  volatile uint32_t OTGSC;           ///< On-The-Go Status & control
 | 
			
		||||
  volatile uint32_t USBMODE;         ///< USB Device Mode
 | 
			
		||||
  volatile uint32_t ENDPTSETUPSTAT;  ///< Endpoint Setup Status
 | 
			
		||||
  volatile uint32_t ENDPTPRIME;      ///< Endpoint Prime
 | 
			
		||||
  volatile uint32_t ENDPTFLUSH;      ///< Endpoint Flush
 | 
			
		||||
  volatile uint32_t ENDPTSTAT;       ///< Endpoint Status
 | 
			
		||||
  volatile uint32_t ENDPTCOMPLETE;   ///< Endpoint Complete
 | 
			
		||||
  volatile uint32_t ENDPTCTRL[8];    ///< Endpoint Control 0 - 7
 | 
			
		||||
} ci_hs_regs_t, hcd_registers_t;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
typedef struct
 | 
			
		||||
{
 | 
			
		||||
  ci_hs_regs_t* regs;
 | 
			
		||||
  const uint32_t irqnum;
 | 
			
		||||
  const uint8_t ep_count; // Max bi-directional Endpoints
 | 
			
		||||
}dcd_controller_t;
 | 
			
		||||
 | 
			
		||||
#ifdef __cplusplus
 | 
			
		||||
 }
 | 
			
		||||
 
 | 
			
		||||
@@ -25,25 +25,24 @@
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "tusb_option.h"
 | 
			
		||||
#include "device/dcd_attr.h"
 | 
			
		||||
 | 
			
		||||
#if TUSB_OPT_DEVICE_ENABLED && \
 | 
			
		||||
    (CFG_TUSB_MCU == OPT_MCU_LPC18XX || CFG_TUSB_MCU == OPT_MCU_LPC43XX || CFG_TUSB_MCU == OPT_MCU_MIMXRT10XX)
 | 
			
		||||
#if TUSB_OPT_DEVICE_ENABLED && defined(DCD_ATTR_CONTROLLER_CHIPIDEA_HS)
 | 
			
		||||
 | 
			
		||||
//--------------------------------------------------------------------+
 | 
			
		||||
// INCLUDE
 | 
			
		||||
//--------------------------------------------------------------------+
 | 
			
		||||
#if CFG_TUSB_MCU == OPT_MCU_MIMXRT10XX
 | 
			
		||||
  #include "fsl_device_registers.h"
 | 
			
		||||
  #define INCLUDE_FSL_DEVICE_REGISTERS
 | 
			
		||||
#else
 | 
			
		||||
  // LPCOpen for 18xx & 43xx
 | 
			
		||||
  #include "chip.h"
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#include "common/tusb_common.h"
 | 
			
		||||
#include "device/dcd.h"
 | 
			
		||||
#include "ci_hs_type.h"
 | 
			
		||||
 | 
			
		||||
#if CFG_TUSB_MCU == OPT_MCU_MIMXRT10XX
 | 
			
		||||
  #include "ci_hs_imxrt.h"
 | 
			
		||||
#elif TU_CHECK_MCU(OPT_MCU_LPC18XX, OPT_MCU_LPC43XX)
 | 
			
		||||
  #include "ci_hs_lpc18_43.h"
 | 
			
		||||
#else
 | 
			
		||||
  #error "Unsupported MCUs"
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#if defined(__CORTEX_M) && __CORTEX_M == 7 && __DCACHE_PRESENT == 1
 | 
			
		||||
  #define CleanInvalidateDCache_by_Addr   SCB_CleanInvalidateDCache_by_Addr
 | 
			
		||||
#else
 | 
			
		||||
@@ -144,33 +143,6 @@ TU_VERIFY_STATIC( sizeof(dcd_qhd_t) == 64, "size is not correct");
 | 
			
		||||
// Variables
 | 
			
		||||
//--------------------------------------------------------------------+
 | 
			
		||||
 | 
			
		||||
typedef struct
 | 
			
		||||
{
 | 
			
		||||
  dcd_registers_t* regs;  // registers
 | 
			
		||||
  const IRQn_Type irqnum; // IRQ number
 | 
			
		||||
  const uint8_t ep_count; // Max bi-directional Endpoints
 | 
			
		||||
}dcd_controller_t;
 | 
			
		||||
 | 
			
		||||
#if CFG_TUSB_MCU == OPT_MCU_MIMXRT10XX
 | 
			
		||||
  static const dcd_controller_t _dcd_controller[] =
 | 
			
		||||
  {
 | 
			
		||||
    // RT1010 and RT1020 only has 1 USB controller
 | 
			
		||||
    #if FSL_FEATURE_SOC_USBHS_COUNT == 1
 | 
			
		||||
      { .regs = (dcd_registers_t*) USB_BASE , .irqnum = USB_OTG1_IRQn, .ep_count = 8 }
 | 
			
		||||
    #else
 | 
			
		||||
      { .regs = (dcd_registers_t*) USB1_BASE, .irqnum = USB_OTG1_IRQn, .ep_count = 8 },
 | 
			
		||||
      { .regs = (dcd_registers_t*) USB2_BASE, .irqnum = USB_OTG2_IRQn, .ep_count = 8 }
 | 
			
		||||
    #endif
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
#else
 | 
			
		||||
  static const dcd_controller_t _dcd_controller[] =
 | 
			
		||||
  {
 | 
			
		||||
    { .regs = (dcd_registers_t*) LPC_USB0_BASE, .irqnum = USB0_IRQn, .ep_count = 6 },
 | 
			
		||||
    { .regs = (dcd_registers_t*) LPC_USB1_BASE, .irqnum = USB1_IRQn, .ep_count = 4 }
 | 
			
		||||
  };
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define QTD_NEXT_INVALID 0x01
 | 
			
		||||
 | 
			
		||||
typedef struct {
 | 
			
		||||
@@ -191,7 +163,7 @@ static dcd_data_t _dcd_data;
 | 
			
		||||
/// follows LPC43xx User Manual 23.10.3
 | 
			
		||||
static void bus_reset(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
 | 
			
		||||
  // The reset value for all endpoint types is the control endpoint. If one endpoint
 | 
			
		||||
  // direction is enabled and the paired endpoint of opposite direction is disabled, then the
 | 
			
		||||
@@ -231,7 +203,7 @@ void dcd_init(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  tu_memclr(&_dcd_data, sizeof(dcd_data_t));
 | 
			
		||||
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
 | 
			
		||||
  // Reset controller
 | 
			
		||||
  dcd_reg->USBCMD |= USBCMD_RESET;
 | 
			
		||||
@@ -255,40 +227,30 @@ void dcd_init(uint8_t rhport)
 | 
			
		||||
  dcd_reg->USBCMD |= USBCMD_RUN_STOP; // Connect
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void dcd_int_enable(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  NVIC_EnableIRQ(_dcd_controller[rhport].irqnum);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void dcd_int_disable(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  NVIC_DisableIRQ(_dcd_controller[rhport].irqnum);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void dcd_set_address(uint8_t rhport, uint8_t dev_addr)
 | 
			
		||||
{
 | 
			
		||||
  // Response with status first before changing device address
 | 
			
		||||
  dcd_edpt_xfer(rhport, tu_edpt_addr(0, TUSB_DIR_IN), NULL, 0);
 | 
			
		||||
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  dcd_reg->DEVICEADDR = (dev_addr << 25) | TU_BIT(24);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void dcd_remote_wakeup(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  dcd_reg->PORTSC1 |= PORTSC1_FORCE_PORT_RESUME;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void dcd_connect(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  dcd_reg->USBCMD |= USBCMD_RUN_STOP;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void dcd_disconnect(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  dcd_reg->USBCMD &= ~USBCMD_RUN_STOP;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -334,7 +296,7 @@ void dcd_edpt_stall(uint8_t rhport, uint8_t ep_addr)
 | 
			
		||||
  uint8_t const epnum  = tu_edpt_number(ep_addr);
 | 
			
		||||
  uint8_t const dir    = tu_edpt_dir(ep_addr);
 | 
			
		||||
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  dcd_reg->ENDPTCTRL[epnum] |= ENDPTCTRL_STALL << (dir ? 16 : 0);
 | 
			
		||||
 | 
			
		||||
  // flush to abort any primed buffer
 | 
			
		||||
@@ -347,7 +309,7 @@ void dcd_edpt_clear_stall(uint8_t rhport, uint8_t ep_addr)
 | 
			
		||||
  uint8_t const dir   = tu_edpt_dir(ep_addr);
 | 
			
		||||
 | 
			
		||||
  // data toggle also need to be reset
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  dcd_reg->ENDPTCTRL[epnum] |= ENDPTCTRL_TOGGLE_RESET << ( dir ? 16 : 0 );
 | 
			
		||||
  dcd_reg->ENDPTCTRL[epnum] &= ~(ENDPTCTRL_STALL << ( dir  ? 16 : 0));
 | 
			
		||||
}
 | 
			
		||||
@@ -376,7 +338,7 @@ bool dcd_edpt_open(uint8_t rhport, tusb_desc_endpoint_t const * p_endpoint_desc)
 | 
			
		||||
  CleanInvalidateDCache_by_Addr((uint32_t*) &_dcd_data, sizeof(dcd_data_t));
 | 
			
		||||
 | 
			
		||||
  // Enable EP Control
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
 | 
			
		||||
  uint32_t const epctrl = (p_endpoint_desc->bmAttributes.xfer << ENDPTCTRL_TYPE_POS) | ENDPTCTRL_ENABLE | ENDPTCTRL_TOGGLE_RESET;
 | 
			
		||||
 | 
			
		||||
@@ -393,7 +355,7 @@ bool dcd_edpt_open(uint8_t rhport, tusb_desc_endpoint_t const * p_endpoint_desc)
 | 
			
		||||
 | 
			
		||||
void dcd_edpt_close_all (uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
 | 
			
		||||
  // Disable all non-control endpoints
 | 
			
		||||
  for( uint8_t epnum=1; epnum < _dcd_controller[rhport].ep_count; epnum++)
 | 
			
		||||
@@ -411,7 +373,7 @@ void dcd_edpt_close(uint8_t rhport, uint8_t ep_addr)
 | 
			
		||||
  uint8_t const epnum  = tu_edpt_number(ep_addr);
 | 
			
		||||
  uint8_t const dir    = tu_edpt_dir(ep_addr);
 | 
			
		||||
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
 | 
			
		||||
  _dcd_data.qhd[epnum][dir].qtd_overlay.halted = 1;
 | 
			
		||||
 | 
			
		||||
@@ -426,7 +388,7 @@ void dcd_edpt_close(uint8_t rhport, uint8_t ep_addr)
 | 
			
		||||
 | 
			
		||||
static void qhd_start_xfer(uint8_t rhport, uint8_t epnum, uint8_t dir)
 | 
			
		||||
{
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  dcd_qhd_t* p_qhd = &_dcd_data.qhd[epnum][dir];
 | 
			
		||||
  dcd_qtd_t* p_qtd = &_dcd_data.qtd[epnum][dir];
 | 
			
		||||
 | 
			
		||||
@@ -542,7 +504,7 @@ static void process_edpt_complete_isr(uint8_t rhport, uint8_t epnum, uint8_t dir
 | 
			
		||||
 | 
			
		||||
  if ( result != XFER_RESULT_SUCCESS )
 | 
			
		||||
  {
 | 
			
		||||
    dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
    ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
    // flush to abort error buffer
 | 
			
		||||
    dcd_reg->ENDPTFLUSH = TU_BIT(epnum + (dir ? 16 : 0));
 | 
			
		||||
  }
 | 
			
		||||
@@ -566,7 +528,7 @@ static void process_edpt_complete_isr(uint8_t rhport, uint8_t epnum, uint8_t dir
 | 
			
		||||
 | 
			
		||||
void dcd_int_handler(uint8_t rhport)
 | 
			
		||||
{
 | 
			
		||||
  dcd_registers_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
  ci_hs_regs_t* dcd_reg = _dcd_controller[rhport].regs;
 | 
			
		||||
 | 
			
		||||
  uint32_t const int_enable = dcd_reg->USBINTR;
 | 
			
		||||
  uint32_t const int_status = dcd_reg->USBSTS & int_enable;
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user