mirror of
https://github.com/hathach/tinyusb.git
synced 2025-01-17 05:32:55 +08:00
more ci abstract
This commit is contained in:
parent
0612433eef
commit
61a9e125db
@ -28,7 +28,9 @@ LDFLAGS += \
|
|||||||
-Wl,--defsym,__stack_size__=0x800 \
|
-Wl,--defsym,__stack_size__=0x800 \
|
||||||
|
|
||||||
SRC_C += \
|
SRC_C += \
|
||||||
src/portable/nxp/transdimension/dcd_transdimension.c \
|
src/portable/chipidea/ci_hs/dcd_ci_hs.c \
|
||||||
|
src/portable/chipidea/ci_hs/hcd_ci_hs.c \
|
||||||
|
src/portable/ehci/ehci.c \
|
||||||
$(MCU_DIR)/system_$(MCU_VARIANT).c \
|
$(MCU_DIR)/system_$(MCU_VARIANT).c \
|
||||||
$(MCU_DIR)/xip/fsl_flexspi_nor_boot.c \
|
$(MCU_DIR)/xip/fsl_flexspi_nor_boot.c \
|
||||||
$(MCU_DIR)/project_template/clock_config.c \
|
$(MCU_DIR)/project_template/clock_config.c \
|
||||||
|
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
|
typedef struct
|
||||||
{
|
{
|
||||||
//------------- ID + HW Parameter Registers-------------//
|
//------------- 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-------------//
|
//------------- Capability Registers-------------//
|
||||||
__I uint8_t CAPLENGTH; ///< Capability Registers Length
|
volatile uint8_t CAPLENGTH; ///< Capability Registers Length
|
||||||
__I uint8_t TU_RESERVED[1];
|
volatile uint8_t TU_RESERVED[1];
|
||||||
__I uint16_t HCIVERSION; ///< Host Controller Interface Version
|
volatile uint16_t HCIVERSION; ///< Host Controller Interface Version
|
||||||
|
|
||||||
__I uint32_t HCSPARAMS; ///< Host Controller Structural Parameters
|
volatile uint32_t HCSPARAMS; ///< Host Controller Structural Parameters
|
||||||
__I uint32_t HCCPARAMS; ///< Host Controller Capability Parameters
|
volatile uint32_t HCCPARAMS; ///< Host Controller Capability Parameters
|
||||||
__I uint32_t TU_RESERVED[5];
|
volatile uint32_t TU_RESERVED[5];
|
||||||
|
|
||||||
__I uint16_t DCIVERSION; ///< Device Controller Interface Version
|
volatile uint16_t DCIVERSION; ///< Device Controller Interface Version
|
||||||
__I uint8_t TU_RESERVED[2];
|
volatile uint8_t TU_RESERVED[2];
|
||||||
|
|
||||||
__I uint32_t DCCPARAMS; ///< Device Controller Capability Parameters
|
volatile uint32_t DCCPARAMS; ///< Device Controller Capability Parameters
|
||||||
__I uint32_t TU_RESERVED[6];
|
volatile uint32_t TU_RESERVED[6];
|
||||||
|
|
||||||
//------------- Operational Registers -------------//
|
//------------- Operational Registers -------------//
|
||||||
__IO uint32_t USBCMD; ///< USB Command Register
|
volatile uint32_t USBCMD; ///< USB Command Register
|
||||||
__IO uint32_t USBSTS; ///< USB Status Register
|
volatile uint32_t USBSTS; ///< USB Status Register
|
||||||
__IO uint32_t USBINTR; ///< Interrupt Enable Register
|
volatile uint32_t USBINTR; ///< Interrupt Enable Register
|
||||||
__IO uint32_t FRINDEX; ///< USB Frame Index
|
volatile uint32_t FRINDEX; ///< USB Frame Index
|
||||||
__I uint32_t TU_RESERVED;
|
volatile uint32_t TU_RESERVED;
|
||||||
__IO uint32_t DEVICEADDR; ///< Device Address
|
volatile uint32_t DEVICEADDR; ///< Device Address
|
||||||
__IO uint32_t ENDPTLISTADDR; ///< Endpoint List Address
|
volatile uint32_t ENDPTLISTADDR; ///< Endpoint List Address
|
||||||
__I uint32_t TU_RESERVED;
|
volatile uint32_t TU_RESERVED;
|
||||||
__IO uint32_t BURSTSIZE; ///< Programmable Burst Size
|
volatile uint32_t BURSTSIZE; ///< Programmable Burst Size
|
||||||
__IO uint32_t TXFILLTUNING; ///< TX FIFO Fill Tuning
|
volatile uint32_t TXFILLTUNING; ///< TX FIFO Fill Tuning
|
||||||
uint32_t TU_RESERVED[4];
|
uint32_t TU_RESERVED[4];
|
||||||
__IO uint32_t ENDPTNAK; ///< Endpoint NAK
|
volatile uint32_t ENDPTNAK; ///< Endpoint NAK
|
||||||
__IO uint32_t ENDPTNAKEN; ///< Endpoint NAK Enable
|
volatile uint32_t ENDPTNAKEN; ///< Endpoint NAK Enable
|
||||||
__I uint32_t TU_RESERVED;
|
volatile uint32_t TU_RESERVED;
|
||||||
__IO uint32_t PORTSC1; ///< Port Status & Control
|
volatile uint32_t PORTSC1; ///< Port Status & Control
|
||||||
__I uint32_t TU_RESERVED[7];
|
volatile uint32_t TU_RESERVED[7];
|
||||||
__IO uint32_t OTGSC; ///< On-The-Go Status & control
|
volatile uint32_t OTGSC; ///< On-The-Go Status & control
|
||||||
__IO uint32_t USBMODE; ///< USB Device Mode
|
volatile uint32_t USBMODE; ///< USB Device Mode
|
||||||
__IO uint32_t ENDPTSETUPSTAT; ///< Endpoint Setup Status
|
volatile uint32_t ENDPTSETUPSTAT; ///< Endpoint Setup Status
|
||||||
__IO uint32_t ENDPTPRIME; ///< Endpoint Prime
|
volatile uint32_t ENDPTPRIME; ///< Endpoint Prime
|
||||||
__IO uint32_t ENDPTFLUSH; ///< Endpoint Flush
|
volatile uint32_t ENDPTFLUSH; ///< Endpoint Flush
|
||||||
__I uint32_t ENDPTSTAT; ///< Endpoint Status
|
volatile uint32_t ENDPTSTAT; ///< Endpoint Status
|
||||||
__IO uint32_t ENDPTCOMPLETE; ///< Endpoint Complete
|
volatile uint32_t ENDPTCOMPLETE; ///< Endpoint Complete
|
||||||
__IO uint32_t ENDPTCTRL[8]; ///< Endpoint Control 0 - 7
|
volatile uint32_t ENDPTCTRL[8]; ///< Endpoint Control 0 - 7
|
||||||
} dcd_registers_t, hcd_registers_t;
|
} 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
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
@ -25,25 +25,24 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "tusb_option.h"
|
#include "tusb_option.h"
|
||||||
|
#include "device/dcd_attr.h"
|
||||||
|
|
||||||
#if TUSB_OPT_DEVICE_ENABLED && \
|
#if TUSB_OPT_DEVICE_ENABLED && defined(DCD_ATTR_CONTROLLER_CHIPIDEA_HS)
|
||||||
(CFG_TUSB_MCU == OPT_MCU_LPC18XX || CFG_TUSB_MCU == OPT_MCU_LPC43XX || CFG_TUSB_MCU == OPT_MCU_MIMXRT10XX)
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// INCLUDE
|
// 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 "device/dcd.h"
|
||||||
#include "ci_hs_type.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
|
#if defined(__CORTEX_M) && __CORTEX_M == 7 && __DCACHE_PRESENT == 1
|
||||||
#define CleanInvalidateDCache_by_Addr SCB_CleanInvalidateDCache_by_Addr
|
#define CleanInvalidateDCache_by_Addr SCB_CleanInvalidateDCache_by_Addr
|
||||||
#else
|
#else
|
||||||
@ -144,33 +143,6 @@ TU_VERIFY_STATIC( sizeof(dcd_qhd_t) == 64, "size is not correct");
|
|||||||
// Variables
|
// 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
|
#define QTD_NEXT_INVALID 0x01
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -191,7 +163,7 @@ static dcd_data_t _dcd_data;
|
|||||||
/// follows LPC43xx User Manual 23.10.3
|
/// follows LPC43xx User Manual 23.10.3
|
||||||
static void bus_reset(uint8_t rhport)
|
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
|
// 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
|
// 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));
|
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
|
// Reset controller
|
||||||
dcd_reg->USBCMD |= USBCMD_RESET;
|
dcd_reg->USBCMD |= USBCMD_RESET;
|
||||||
@ -255,40 +227,30 @@ void dcd_init(uint8_t rhport)
|
|||||||
dcd_reg->USBCMD |= USBCMD_RUN_STOP; // Connect
|
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)
|
void dcd_set_address(uint8_t rhport, uint8_t dev_addr)
|
||||||
{
|
{
|
||||||
// Response with status first before changing device address
|
// Response with status first before changing device address
|
||||||
dcd_edpt_xfer(rhport, tu_edpt_addr(0, TUSB_DIR_IN), NULL, 0);
|
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);
|
dcd_reg->DEVICEADDR = (dev_addr << 25) | TU_BIT(24);
|
||||||
}
|
}
|
||||||
|
|
||||||
void dcd_remote_wakeup(uint8_t rhport)
|
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;
|
dcd_reg->PORTSC1 |= PORTSC1_FORCE_PORT_RESUME;
|
||||||
}
|
}
|
||||||
|
|
||||||
void dcd_connect(uint8_t rhport)
|
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;
|
dcd_reg->USBCMD |= USBCMD_RUN_STOP;
|
||||||
}
|
}
|
||||||
|
|
||||||
void dcd_disconnect(uint8_t rhport)
|
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;
|
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 epnum = tu_edpt_number(ep_addr);
|
||||||
uint8_t const dir = tu_edpt_dir(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);
|
dcd_reg->ENDPTCTRL[epnum] |= ENDPTCTRL_STALL << (dir ? 16 : 0);
|
||||||
|
|
||||||
// flush to abort any primed buffer
|
// 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);
|
uint8_t const dir = tu_edpt_dir(ep_addr);
|
||||||
|
|
||||||
// data toggle also need to be reset
|
// 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_TOGGLE_RESET << ( dir ? 16 : 0 );
|
||||||
dcd_reg->ENDPTCTRL[epnum] &= ~(ENDPTCTRL_STALL << ( 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));
|
CleanInvalidateDCache_by_Addr((uint32_t*) &_dcd_data, sizeof(dcd_data_t));
|
||||||
|
|
||||||
// Enable EP Control
|
// 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;
|
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)
|
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
|
// Disable all non-control endpoints
|
||||||
for( uint8_t epnum=1; epnum < _dcd_controller[rhport].ep_count; epnum++)
|
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 epnum = tu_edpt_number(ep_addr);
|
||||||
uint8_t const dir = tu_edpt_dir(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;
|
_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)
|
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_qhd_t* p_qhd = &_dcd_data.qhd[epnum][dir];
|
||||||
dcd_qtd_t* p_qtd = &_dcd_data.qtd[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 )
|
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
|
// flush to abort error buffer
|
||||||
dcd_reg->ENDPTFLUSH = TU_BIT(epnum + (dir ? 16 : 0));
|
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)
|
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_enable = dcd_reg->USBINTR;
|
||||||
uint32_t const int_status = dcd_reg->USBSTS & int_enable;
|
uint32_t const int_status = dcd_reg->USBSTS & int_enable;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user