mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-01-18 03:52:11 +01:00
Merge branch 'stac/revo-usb' into revolution
Conflicts: flight/Revolution/System/pios_board.c
This commit is contained in:
commit
e3df261213
@ -80,6 +80,7 @@ OPUAVSYNTHDIR = $(OUTDIR)/../uavobject-synthetics/flight
|
|||||||
## BOOTLOADER:
|
## BOOTLOADER:
|
||||||
SRC += main.c
|
SRC += main.c
|
||||||
SRC += pios_board.c
|
SRC += pios_board.c
|
||||||
|
SRC += pios_usb_board_data.c
|
||||||
SRC += bl_fsm.c
|
SRC += bl_fsm.c
|
||||||
|
|
||||||
## PIOS Hardware (STM32F4xx)
|
## PIOS Hardware (STM32F4xx)
|
||||||
@ -91,7 +92,9 @@ SRC += $(FLIGHTLIB)/fifo_buffer.c
|
|||||||
# PIOS Hardware (Common)
|
# PIOS Hardware (Common)
|
||||||
#SRC += $(PIOSCOMMON)/pios_com.c
|
#SRC += $(PIOSCOMMON)/pios_com.c
|
||||||
SRC += $(PIOSCOMMON)/pios_board_info.c
|
SRC += $(PIOSCOMMON)/pios_board_info.c
|
||||||
|
SRC += $(PIOSCOMMON)/pios_com_msg.c
|
||||||
SRC += $(PIOSCOMMON)/printf-stdarg.c
|
SRC += $(PIOSCOMMON)/printf-stdarg.c
|
||||||
|
SRC += $(PIOSCOMMON)/pios_usb_desc_hid_only.c
|
||||||
|
|
||||||
# List C source files here which must be compiled in ARM-Mode (no -mthumb).
|
# List C source files here which must be compiled in ARM-Mode (no -mthumb).
|
||||||
# use file-extension c for "c-only"-files
|
# use file-extension c for "c-only"-files
|
||||||
@ -224,7 +227,7 @@ CFLAGS += -fpromote-loop-indices
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
CFLAGS += -Wall
|
CFLAGS += -Wall
|
||||||
CFLAGS += -Werror
|
#CFLAGS += -Werror
|
||||||
CFLAGS += -Wa,-adhlns=$(addprefix $(OUTDIR)/, $(notdir $(addsuffix .lst, $(basename $<))))
|
CFLAGS += -Wa,-adhlns=$(addprefix $(OUTDIR)/, $(notdir $(addsuffix .lst, $(basename $<))))
|
||||||
# Compiler flags to generate dependency files:
|
# Compiler flags to generate dependency files:
|
||||||
CFLAGS += -MD -MP -MF $(OUTDIR)/dep/$(@F).d
|
CFLAGS += -MD -MP -MF $(OUTDIR)/dep/$(@F).d
|
||||||
|
@ -34,6 +34,9 @@
|
|||||||
#define PIOS_INCLUDE_SPI
|
#define PIOS_INCLUDE_SPI
|
||||||
#define PIOS_INCLUDE_SYS
|
#define PIOS_INCLUDE_SYS
|
||||||
#define PIOS_INCLUDE_IAP
|
#define PIOS_INCLUDE_IAP
|
||||||
|
#define PIOS_INCLUDE_USB
|
||||||
|
#define PIOS_INCLUDE_USB_HID
|
||||||
|
#define PIOS_INCLUDE_COM_MSG
|
||||||
//#define PIOS_INCLUDE_BL_HELPER
|
//#define PIOS_INCLUDE_BL_HELPER
|
||||||
//#define PIOS_INCLUDE_BL_HELPER_WRITE_SUPPORT
|
//#define PIOS_INCLUDE_BL_HELPER_WRITE_SUPPORT
|
||||||
|
|
||||||
|
51
flight/Bootloaders/Revolution/inc/pios_usb_board_data.h
Normal file
51
flight/Bootloaders/Revolution/inc/pios_usb_board_data.h
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @addtogroup PIOS PIOS Core hardware abstraction layer
|
||||||
|
* @{
|
||||||
|
* @addtogroup PIOS_USB_BOARD Board specific USB definitions
|
||||||
|
* @brief Board specific USB definitions
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file pios_usb_board_data.h
|
||||||
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||||
|
* @brief Board specific USB definitions
|
||||||
|
* @see The GNU Public License (GPL) Version 3
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
/*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef PIOS_USB_BOARD_DATA_H
|
||||||
|
#define PIOS_USB_BOARD_DATA_H
|
||||||
|
|
||||||
|
#define PIOS_USB_BOARD_HID_DATA_LENGTH 64
|
||||||
|
|
||||||
|
#define PIOS_USB_BOARD_EP_NUM 2
|
||||||
|
|
||||||
|
#include "pios_usb_defs.h" /* struct usb_* */
|
||||||
|
|
||||||
|
#define PIOS_USB_BOARD_PRODUCT_ID USB_PRODUCT_ID_REVOLUTION
|
||||||
|
#define PIOS_USB_BOARD_DEVICE_VER USB_OP_DEVICE_VER(USB_OP_BOARD_ID_REVOLUTION, USB_OP_BOARD_MODE_BL)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The bootloader uses a simplified report structure
|
||||||
|
* BL: <REPORT_ID><DATA>...<DATA>
|
||||||
|
* FW: <REPORT_ID><LENGTH><DATA>...<DATA>
|
||||||
|
* This define changes the behaviour in pios_usb_hid.c
|
||||||
|
*/
|
||||||
|
#define PIOS_USB_BOARD_BL_HID_HAS_NO_LENGTH_BYTE
|
||||||
|
|
||||||
|
#endif /* PIOS_USB_BOARD_DATA_H */
|
@ -23,11 +23,13 @@
|
|||||||
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <pios.h>
|
|
||||||
#include "bl_fsm.h" /* lfsm_* */
|
|
||||||
|
|
||||||
#include "board_hw_defs.c"
|
#include "board_hw_defs.c"
|
||||||
|
|
||||||
|
#include <pios_board_info.h>
|
||||||
|
#include <pios.h>
|
||||||
|
|
||||||
|
uint32_t pios_com_telem_usb_id;
|
||||||
|
|
||||||
static bool board_init_complete = false;
|
static bool board_init_complete = false;
|
||||||
void PIOS_Board_Init() {
|
void PIOS_Board_Init() {
|
||||||
if (board_init_complete) {
|
if (board_init_complete) {
|
||||||
@ -39,5 +41,30 @@ void PIOS_Board_Init() {
|
|||||||
|
|
||||||
PIOS_LED_Init(&pios_led_cfg);
|
PIOS_LED_Init(&pios_led_cfg);
|
||||||
|
|
||||||
|
|
||||||
|
#if 0 && defined(PIOS_INCLUDE_USB)
|
||||||
|
/* Initialize board specific USB data */
|
||||||
|
PIOS_USB_BOARD_DATA_Init();
|
||||||
|
|
||||||
|
/* Activate the HID-only USB configuration */
|
||||||
|
PIOS_USB_DESC_HID_ONLY_Init();
|
||||||
|
|
||||||
|
uint32_t pios_usb_id;
|
||||||
|
PIOS_USB_Init(&pios_usb_id, &pios_usb_main_cfg);
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_HID) && defined(PIOS_INCLUDE_COM_MSG)
|
||||||
|
uint32_t pios_usb_hid_id;
|
||||||
|
if (PIOS_USB_HID_Init(&pios_usb_hid_id, &pios_usb_hid_cfg, pios_usb_id)) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
if (PIOS_COM_MSG_Init(&pios_com_telem_usb_id, &pios_usb_hid_com_driver, pios_usb_hid_id)) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_USB_HID && PIOS_INCLUDE_COM_MSG */
|
||||||
|
|
||||||
|
PIOS_USBHOOK_Activate();
|
||||||
|
|
||||||
|
#endif /* PIOS_INCLUDE_USB */
|
||||||
|
|
||||||
board_init_complete = true;
|
board_init_complete = true;
|
||||||
}
|
}
|
||||||
|
120
flight/Bootloaders/Revolution/pios_usb_board_data.c
Normal file
120
flight/Bootloaders/Revolution/pios_usb_board_data.c
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @addtogroup PIOS PIOS Core hardware abstraction layer
|
||||||
|
* @{
|
||||||
|
* @addtogroup PIOS_USB_BOARD Board specific USB definitions
|
||||||
|
* @brief Board specific USB definitions
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file pios_usb_board_data.c
|
||||||
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||||
|
* @brief Board specific USB definitions
|
||||||
|
* @see The GNU Public License (GPL) Version 3
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
/*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "pios_usb_board_data.h" /* struct usb_*, USB_* */
|
||||||
|
#include "pios_sys.h" /* PIOS_SYS_SerialNumberGet */
|
||||||
|
#include "pios_usbhook.h" /* PIOS_USBHOOK_* */
|
||||||
|
|
||||||
|
static const uint8_t usb_product_id[22] = {
|
||||||
|
sizeof(usb_product_id),
|
||||||
|
USB_DESC_TYPE_STRING,
|
||||||
|
'R', 0,
|
||||||
|
'e', 0,
|
||||||
|
'v', 0,
|
||||||
|
'o', 0,
|
||||||
|
'l', 0,
|
||||||
|
'u', 0,
|
||||||
|
't', 0,
|
||||||
|
'i', 0,
|
||||||
|
'o', 0,
|
||||||
|
'n', 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
static uint8_t usb_serial_number[52] = {
|
||||||
|
sizeof(usb_serial_number),
|
||||||
|
USB_DESC_TYPE_STRING,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb_string_langid usb_lang_id = {
|
||||||
|
.bLength = sizeof(usb_lang_id),
|
||||||
|
.bDescriptorType = USB_DESC_TYPE_STRING,
|
||||||
|
.bLangID = htousbs(USB_LANGID_ENGLISH_UK),
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t usb_vendor_id[28] = {
|
||||||
|
sizeof(usb_vendor_id),
|
||||||
|
USB_DESC_TYPE_STRING,
|
||||||
|
'o', 0,
|
||||||
|
'p', 0,
|
||||||
|
'e', 0,
|
||||||
|
'n', 0,
|
||||||
|
'p', 0,
|
||||||
|
'i', 0,
|
||||||
|
'l', 0,
|
||||||
|
'o', 0,
|
||||||
|
't', 0,
|
||||||
|
'.', 0,
|
||||||
|
'o', 0,
|
||||||
|
'r', 0,
|
||||||
|
'g', 0
|
||||||
|
};
|
||||||
|
|
||||||
|
int32_t PIOS_USB_BOARD_DATA_Init(void)
|
||||||
|
{
|
||||||
|
/* Load device serial number into serial number string */
|
||||||
|
uint8_t sn[25];
|
||||||
|
PIOS_SYS_SerialNumberGet((char *)sn);
|
||||||
|
for (uint8_t i = 0; sn[i] != '\0' && (2 * i) < usb_serial_number[0]; i++) {
|
||||||
|
usb_serial_number[2 + 2 * i] = sn[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
PIOS_USBHOOK_RegisterString(USB_STRING_DESC_PRODUCT, (uint8_t *)&usb_product_id, sizeof(usb_product_id));
|
||||||
|
PIOS_USBHOOK_RegisterString(USB_STRING_DESC_SERIAL, (uint8_t *)&usb_serial_number, sizeof(usb_serial_number));
|
||||||
|
|
||||||
|
PIOS_USBHOOK_RegisterString(USB_STRING_DESC_LANG, (uint8_t *)&usb_lang_id, sizeof(usb_lang_id));
|
||||||
|
PIOS_USBHOOK_RegisterString(USB_STRING_DESC_VENDOR, (uint8_t *)&usb_vendor_id, sizeof(usb_vendor_id));
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@ -53,7 +53,7 @@ USE_GPS ?= YES
|
|||||||
USE_I2C ?= YES
|
USE_I2C ?= YES
|
||||||
|
|
||||||
# Set to YES when using Code Sourcery toolchain
|
# Set to YES when using Code Sourcery toolchain
|
||||||
CODE_SOURCERY ?= YES
|
CODE_SOURCERY ?= NO
|
||||||
|
|
||||||
# Remove command is different for Code Sourcery on Windows
|
# Remove command is different for Code Sourcery on Windows
|
||||||
ifeq ($(CODE_SOURCERY), YES)
|
ifeq ($(CODE_SOURCERY), YES)
|
||||||
|
@ -33,8 +33,8 @@ OUTDIR := $(TOP)/build/$(TARGET)
|
|||||||
.PHONY: bin
|
.PHONY: bin
|
||||||
bin: $(OUTDIR)/$(TARGET).bin
|
bin: $(OUTDIR)/$(TARGET).bin
|
||||||
|
|
||||||
$(OUTDIR)/$(TARGET).bin: BL_BIN := $(TOP)/build/bl_$(BOARD_NAME)/bl_$(BOARD_NAME).bin
|
BL_BIN = $(TOP)/build/bl_$(BOARD_NAME)/bl_$(BOARD_NAME).bin
|
||||||
$(OUTDIR)/$(TARGET).bin: FW_BIN := $(TOP)/build/fw_$(BOARD_NAME)/fw_$(BOARD_NAME).bin
|
FW_BIN = $(TOP)/build/fw_$(BOARD_NAME)/fw_$(BOARD_NAME).bin
|
||||||
$(OUTDIR)/$(TARGET).bin: $(BL_BIN) $(FW_BIN)
|
$(OUTDIR)/$(TARGET).bin: $(BL_BIN) $(FW_BIN)
|
||||||
$(V0) @echo " FLASH IMG $@"
|
$(V0) @echo " FLASH IMG $@"
|
||||||
$(V1) cat $(BL_BIN) $(FW_BIN) > $@
|
$(V1) cat $(BL_BIN) $(FW_BIN) > $@
|
||||||
|
@ -89,7 +89,6 @@ MODULE_INITCALL(AltitudeInitialize, AltitudeStart)
|
|||||||
static void altitudeTask(void *parameters)
|
static void altitudeTask(void *parameters)
|
||||||
{
|
{
|
||||||
BaroAltitudeData data;
|
BaroAltitudeData data;
|
||||||
portTickType lastSysTime;
|
|
||||||
|
|
||||||
#if defined(PIOS_INCLUDE_HCSR04)
|
#if defined(PIOS_INCLUDE_HCSR04)
|
||||||
SonarAltitudeData sonardata;
|
SonarAltitudeData sonardata;
|
||||||
@ -102,7 +101,6 @@ static void altitudeTask(void *parameters)
|
|||||||
// TODO: Check the pressure sensor and set a warning if it fails test
|
// TODO: Check the pressure sensor and set a warning if it fails test
|
||||||
|
|
||||||
// Main task loop
|
// Main task loop
|
||||||
lastSysTime = xTaskGetTickCount();
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
#if defined(PIOS_INCLUDE_HCSR04)
|
#if defined(PIOS_INCLUDE_HCSR04)
|
||||||
|
@ -170,7 +170,6 @@ int32_t gyro_test;
|
|||||||
static void AttitudeTask(void *parameters)
|
static void AttitudeTask(void *parameters)
|
||||||
{
|
{
|
||||||
uint8_t init = 0;
|
uint8_t init = 0;
|
||||||
portTickType lastSysTime;
|
|
||||||
AlarmsClear(SYSTEMALARMS_ALARM_ATTITUDE);
|
AlarmsClear(SYSTEMALARMS_ALARM_ATTITUDE);
|
||||||
|
|
||||||
// Set critical error and wait until the accel is producing data
|
// Set critical error and wait until the accel is producing data
|
||||||
@ -205,8 +204,6 @@ static void AttitudeTask(void *parameters)
|
|||||||
// Force settings update to make sure rotation loaded
|
// Force settings update to make sure rotation loaded
|
||||||
settingsUpdatedCb(AttitudeSettingsHandle());
|
settingsUpdatedCb(AttitudeSettingsHandle());
|
||||||
|
|
||||||
lastSysTime = xTaskGetTickCount();
|
|
||||||
|
|
||||||
// Main task loop
|
// Main task loop
|
||||||
while (1) {
|
while (1) {
|
||||||
|
|
||||||
|
@ -229,6 +229,12 @@ extern uint32_t pios_com_telem_usb_id;
|
|||||||
// None.
|
// None.
|
||||||
//-------------------------
|
//-------------------------
|
||||||
|
|
||||||
|
//-------------------------
|
||||||
|
// USB
|
||||||
|
//-------------------------
|
||||||
|
#define PIOS_USB_MAX_DEVS 1
|
||||||
|
#define PIOS_USB_ENABLED 1 /* Should remove all references to this */
|
||||||
|
#define PIOS_USB_HID_MAX_DEVS 1
|
||||||
|
|
||||||
#endif /* STM3210E_INS_H_ */
|
#endif /* STM3210E_INS_H_ */
|
||||||
/**
|
/**
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include "pios_usb_defs.h" /* struct usb_*, USB_* */
|
#include "pios_usb_defs.h" /* struct usb_*, USB_* */
|
||||||
#include "pios_usb_board_data.h" /* PIOS_USB_BOARD_* */
|
#include "pios_usb_board_data.h" /* PIOS_USB_BOARD_* */
|
||||||
#include "pios_usbhook.h" /* PIOS_USBHOOK_Register* */
|
#include "pios_usbhook.h" /* PIOS_USBHOOK_Register* */
|
||||||
|
#include "pios_usb_hid.h" /* PIOS_USB_HID_Register* */
|
||||||
|
|
||||||
static const struct usb_device_desc device_desc = {
|
static const struct usb_device_desc device_desc = {
|
||||||
.bLength = sizeof(struct usb_device_desc),
|
.bLength = sizeof(struct usb_device_desc),
|
||||||
@ -249,8 +250,8 @@ int32_t PIOS_USB_DESC_HID_CDC_Init(void)
|
|||||||
|
|
||||||
PIOS_USBHOOK_RegisterDevice((uint8_t *)&device_desc, sizeof(device_desc));
|
PIOS_USBHOOK_RegisterDevice((uint8_t *)&device_desc, sizeof(device_desc));
|
||||||
|
|
||||||
PIOS_USBHOOK_RegisterHidInterface((uint8_t *)&(config_hid_cdc.hid_if), sizeof(config_hid_cdc.hid_if));
|
PIOS_USB_HID_RegisterHidInterface((uint8_t *)&(config_hid_cdc.hid_if), sizeof(config_hid_cdc.hid_if));
|
||||||
PIOS_USBHOOK_RegisterHidReport((uint8_t *)hid_report_desc, sizeof(hid_report_desc));
|
PIOS_USB_HID_RegisterHidReport((uint8_t *)hid_report_desc, sizeof(hid_report_desc));
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include "pios_usb_defs.h" /* struct usb_*, USB_* */
|
#include "pios_usb_defs.h" /* struct usb_*, USB_* */
|
||||||
#include "pios_usb_board_data.h" /* PIOS_USB_BOARD_* */
|
#include "pios_usb_board_data.h" /* PIOS_USB_BOARD_* */
|
||||||
#include "pios_usbhook.h" /* PIOS_USBHOOK_Register* */
|
#include "pios_usbhook.h" /* PIOS_USBHOOK_Register* */
|
||||||
|
#include "pios_usb_hid.h" /* PIOS_USB_HID_Register* */
|
||||||
|
|
||||||
static const struct usb_device_desc device_desc = {
|
static const struct usb_device_desc device_desc = {
|
||||||
.bLength = sizeof(struct usb_device_desc),
|
.bLength = sizeof(struct usb_device_desc),
|
||||||
@ -75,7 +76,7 @@ static const uint8_t hid_report_desc[36] = {
|
|||||||
HID_MAIN_ITEM_1 (HID_TAG_MAIN_INPUT),
|
HID_MAIN_ITEM_1 (HID_TAG_MAIN_INPUT),
|
||||||
0x03, /* Variable, Constant (read-only) */
|
0x03, /* Variable, Constant (read-only) */
|
||||||
|
|
||||||
/* Host -> Host emulated serial channel */
|
/* Host -> Device emulated serial channel */
|
||||||
HID_GLOBAL_ITEM_1 (HID_TAG_GLOBAL_REPORT_ID),
|
HID_GLOBAL_ITEM_1 (HID_TAG_GLOBAL_REPORT_ID),
|
||||||
0x02, /* OpenPilot emulated Serial Channel (Host -> Device) */
|
0x02, /* OpenPilot emulated Serial Channel (Host -> Device) */
|
||||||
HID_LOCAL_ITEM_1 (HID_TAG_LOCAL_USAGE),
|
HID_LOCAL_ITEM_1 (HID_TAG_LOCAL_USAGE),
|
||||||
@ -157,8 +158,8 @@ int32_t PIOS_USB_DESC_HID_ONLY_Init(void)
|
|||||||
|
|
||||||
PIOS_USBHOOK_RegisterDevice((uint8_t *)&device_desc, sizeof(device_desc));
|
PIOS_USBHOOK_RegisterDevice((uint8_t *)&device_desc, sizeof(device_desc));
|
||||||
|
|
||||||
PIOS_USBHOOK_RegisterHidInterface((uint8_t *)&(config_hid_only.hid_if), sizeof(config_hid_only.hid_if));
|
PIOS_USB_HID_RegisterHidInterface((uint8_t *)&(config_hid_only.hid_if), sizeof(config_hid_only.hid_if));
|
||||||
PIOS_USBHOOK_RegisterHidReport((uint8_t *)hid_report_desc, sizeof(hid_report_desc));
|
PIOS_USB_HID_RegisterHidReport((uint8_t *)hid_report_desc, sizeof(hid_report_desc));
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -335,6 +335,7 @@ int32_t PIOS_SPI_RC_PinSet(uint32_t spi_id, uint32_t slave_id, uint8_t pin_value
|
|||||||
* \param[in] spi SPI number (0 or 1)
|
* \param[in] spi SPI number (0 or 1)
|
||||||
* \param[in] b the byte which should be transfered
|
* \param[in] b the byte which should be transfered
|
||||||
*/
|
*/
|
||||||
|
static uint8_t dummy;
|
||||||
int32_t PIOS_SPI_TransferByte(uint32_t spi_id, uint8_t b)
|
int32_t PIOS_SPI_TransferByte(uint32_t spi_id, uint8_t b)
|
||||||
{
|
{
|
||||||
struct pios_spi_dev * spi_dev = (struct pios_spi_dev *)spi_id;
|
struct pios_spi_dev * spi_dev = (struct pios_spi_dev *)spi_id;
|
||||||
@ -342,7 +343,6 @@ int32_t PIOS_SPI_TransferByte(uint32_t spi_id, uint8_t b)
|
|||||||
bool valid = PIOS_SPI_validate(spi_dev);
|
bool valid = PIOS_SPI_validate(spi_dev);
|
||||||
PIOS_Assert(valid)
|
PIOS_Assert(valid)
|
||||||
|
|
||||||
uint8_t dummy;
|
|
||||||
uint8_t rx_byte;
|
uint8_t rx_byte;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -148,7 +148,7 @@ out_fail:
|
|||||||
* \return < 0 on errors
|
* \return < 0 on errors
|
||||||
* \note Applications shouldn't call this function directly, instead please use \ref PIOS_COM layer functions
|
* \note Applications shouldn't call this function directly, instead please use \ref PIOS_COM layer functions
|
||||||
*/
|
*/
|
||||||
int32_t PIOS_USB_ChangeConnectionState(uint32_t Connected)
|
int32_t PIOS_USB_ChangeConnectionState(bool Connected)
|
||||||
{
|
{
|
||||||
// In all cases: re-initialise USB HID driver
|
// In all cases: re-initialise USB HID driver
|
||||||
if (Connected) {
|
if (Connected) {
|
||||||
|
@ -38,6 +38,9 @@
|
|||||||
#include "pios_usb_cdc_priv.h"
|
#include "pios_usb_cdc_priv.h"
|
||||||
#include "pios_usb_board_data.h" /* PIOS_BOARD_*_DATA_LENGTH */
|
#include "pios_usb_board_data.h" /* PIOS_BOARD_*_DATA_LENGTH */
|
||||||
|
|
||||||
|
/* STM32 USB Library Definitions */
|
||||||
|
#include "usb_lib.h"
|
||||||
|
|
||||||
static void PIOS_USB_CDC_RegisterTxCallback(uint32_t usbcdc_id, pios_com_callback tx_out_cb, uint32_t context);
|
static void PIOS_USB_CDC_RegisterTxCallback(uint32_t usbcdc_id, pios_com_callback tx_out_cb, uint32_t context);
|
||||||
static void PIOS_USB_CDC_RegisterRxCallback(uint32_t usbcdc_id, pios_com_callback rx_in_cb, uint32_t context);
|
static void PIOS_USB_CDC_RegisterRxCallback(uint32_t usbcdc_id, pios_com_callback rx_in_cb, uint32_t context);
|
||||||
static void PIOS_USB_CDC_TxStart(uint32_t usbcdc_id, uint16_t tx_bytes_avail);
|
static void PIOS_USB_CDC_TxStart(uint32_t usbcdc_id, uint16_t tx_bytes_avail);
|
||||||
@ -312,6 +315,7 @@ static void PIOS_USB_CDC_DATA_EP_OUT_Callback(void)
|
|||||||
#endif /* PIOS_INCLUDE_FREERTOS */
|
#endif /* PIOS_INCLUDE_FREERTOS */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static uint16_t control_line_state;
|
||||||
RESULT PIOS_USB_CDC_SetControlLineState(void)
|
RESULT PIOS_USB_CDC_SetControlLineState(void)
|
||||||
{
|
{
|
||||||
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)pios_usb_cdc_id;
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)pios_usb_cdc_id;
|
||||||
@ -319,8 +323,6 @@ RESULT PIOS_USB_CDC_SetControlLineState(void)
|
|||||||
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
PIOS_Assert(valid);
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
static uint16_t control_line_state;
|
|
||||||
|
|
||||||
uint8_t wValue0 = pInformation->USBwValue0;
|
uint8_t wValue0 = pInformation->USBwValue0;
|
||||||
uint8_t wValue1 = pInformation->USBwValue1;
|
uint8_t wValue1 = pInformation->USBwValue1;
|
||||||
|
|
||||||
|
@ -38,6 +38,9 @@
|
|||||||
#include "pios_usb_hid_priv.h"
|
#include "pios_usb_hid_priv.h"
|
||||||
#include "pios_usb_board_data.h" /* PIOS_BOARD_*_DATA_LENGTH */
|
#include "pios_usb_board_data.h" /* PIOS_BOARD_*_DATA_LENGTH */
|
||||||
|
|
||||||
|
/* STM32 USB Library Definitions */
|
||||||
|
#include "usb_lib.h"
|
||||||
|
|
||||||
static void PIOS_USB_HID_RegisterTxCallback(uint32_t usbhid_id, pios_com_callback tx_out_cb, uint32_t context);
|
static void PIOS_USB_HID_RegisterTxCallback(uint32_t usbhid_id, pios_com_callback tx_out_cb, uint32_t context);
|
||||||
static void PIOS_USB_HID_RegisterRxCallback(uint32_t usbhid_id, pios_com_callback rx_in_cb, uint32_t context);
|
static void PIOS_USB_HID_RegisterRxCallback(uint32_t usbhid_id, pios_com_callback rx_in_cb, uint32_t context);
|
||||||
static void PIOS_USB_HID_TxStart(uint32_t usbhid_id, uint16_t tx_bytes_avail);
|
static void PIOS_USB_HID_TxStart(uint32_t usbhid_id, uint16_t tx_bytes_avail);
|
||||||
|
@ -36,6 +36,9 @@
|
|||||||
#include "pios_usb_cdc_priv.h" /* PIOS_USB_CDC_* */
|
#include "pios_usb_cdc_priv.h" /* PIOS_USB_CDC_* */
|
||||||
#include "pios_usb_board_data.h" /* PIOS_USB_BOARD_* */
|
#include "pios_usb_board_data.h" /* PIOS_USB_BOARD_* */
|
||||||
|
|
||||||
|
/* STM32 USB Library Definitions */
|
||||||
|
#include "usb_lib.h"
|
||||||
|
|
||||||
static ONE_DESCRIPTOR Device_Descriptor;
|
static ONE_DESCRIPTOR Device_Descriptor;
|
||||||
|
|
||||||
void PIOS_USBHOOK_RegisterDevice(const uint8_t * desc, uint16_t desc_size)
|
void PIOS_USBHOOK_RegisterDevice(const uint8_t * desc, uint16_t desc_size)
|
||||||
@ -64,7 +67,7 @@ void PIOS_USBHOOK_RegisterString(enum usb_string_desc string_id, const uint8_t *
|
|||||||
|
|
||||||
static ONE_DESCRIPTOR Hid_Interface_Descriptor;
|
static ONE_DESCRIPTOR Hid_Interface_Descriptor;
|
||||||
|
|
||||||
void PIOS_USBHOOK_RegisterHidInterface(const uint8_t * desc, uint16_t desc_size)
|
void PIOS_USB_HID_RegisterHidInterface(const uint8_t * desc, uint16_t desc_size)
|
||||||
{
|
{
|
||||||
Hid_Interface_Descriptor.Descriptor = desc;
|
Hid_Interface_Descriptor.Descriptor = desc;
|
||||||
Hid_Interface_Descriptor.Descriptor_Size = desc_size;
|
Hid_Interface_Descriptor.Descriptor_Size = desc_size;
|
||||||
@ -72,7 +75,7 @@ void PIOS_USBHOOK_RegisterHidInterface(const uint8_t * desc, uint16_t desc_size)
|
|||||||
|
|
||||||
static ONE_DESCRIPTOR Hid_Report_Descriptor;
|
static ONE_DESCRIPTOR Hid_Report_Descriptor;
|
||||||
|
|
||||||
void PIOS_USBHOOK_RegisterHidReport(const uint8_t * desc, uint16_t desc_size)
|
void PIOS_USB_HID_RegisterHidReport(const uint8_t * desc, uint16_t desc_size)
|
||||||
{
|
{
|
||||||
Hid_Report_Descriptor.Descriptor = desc;
|
Hid_Report_Descriptor.Descriptor = desc;
|
||||||
Hid_Report_Descriptor.Descriptor_Size = desc_size;
|
Hid_Report_Descriptor.Descriptor_Size = desc_size;
|
||||||
@ -290,6 +293,8 @@ static void PIOS_USBHOOK_Status_Out(void)
|
|||||||
* Output : None.
|
* Output : None.
|
||||||
* Return : USB_UNSUPPORT or USB_SUCCESS.
|
* Return : USB_UNSUPPORT or USB_SUCCESS.
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
extern const uint8_t *PIOS_USB_CDC_GetLineCoding(uint16_t Length);
|
||||||
|
|
||||||
static RESULT PIOS_USBHOOK_Data_Setup(uint8_t RequestNo)
|
static RESULT PIOS_USBHOOK_Data_Setup(uint8_t RequestNo)
|
||||||
{
|
{
|
||||||
const uint8_t *(*CopyRoutine) (uint16_t);
|
const uint8_t *(*CopyRoutine) (uint16_t);
|
||||||
@ -318,7 +323,7 @@ static RESULT PIOS_USBHOOK_Data_Setup(uint8_t RequestNo)
|
|||||||
switch (pInformation->USBwIndex0) {
|
switch (pInformation->USBwIndex0) {
|
||||||
case 0: /* HID Interface */
|
case 0: /* HID Interface */
|
||||||
switch (RequestNo) {
|
switch (RequestNo) {
|
||||||
case GET_PROTOCOL:
|
case USB_HID_REQ_GET_PROTOCOL:
|
||||||
CopyRoutine = PIOS_USBHOOK_GetProtocolValue;
|
CopyRoutine = PIOS_USBHOOK_GetProtocolValue;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -327,7 +332,7 @@ static RESULT PIOS_USBHOOK_Data_Setup(uint8_t RequestNo)
|
|||||||
#if defined(PIOS_INCLUDE_USB_CDC)
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
||||||
case 1: /* CDC Call Control Interface */
|
case 1: /* CDC Call Control Interface */
|
||||||
switch (RequestNo) {
|
switch (RequestNo) {
|
||||||
case GET_LINE_CODING:
|
case USB_CDC_REQ_GET_LINE_CODING:
|
||||||
CopyRoutine = PIOS_USB_CDC_GetLineCoding;
|
CopyRoutine = PIOS_USB_CDC_GetLineCoding;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -363,6 +368,9 @@ static RESULT PIOS_USBHOOK_Data_Setup(uint8_t RequestNo)
|
|||||||
* Output : None.
|
* Output : None.
|
||||||
* Return : USB_UNSUPPORT or USB_SUCCESS.
|
* Return : USB_UNSUPPORT or USB_SUCCESS.
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
extern RESULT PIOS_USB_CDC_SetControlLineState(void);
|
||||||
|
extern RESULT PIOS_USB_CDC_SetLineCoding(void);
|
||||||
|
|
||||||
static RESULT PIOS_USBHOOK_NoData_Setup(uint8_t RequestNo)
|
static RESULT PIOS_USBHOOK_NoData_Setup(uint8_t RequestNo)
|
||||||
{
|
{
|
||||||
switch (Type_Recipient) {
|
switch (Type_Recipient) {
|
||||||
@ -370,7 +378,7 @@ static RESULT PIOS_USBHOOK_NoData_Setup(uint8_t RequestNo)
|
|||||||
switch (pInformation->USBwIndex0) {
|
switch (pInformation->USBwIndex0) {
|
||||||
case 0: /* HID */
|
case 0: /* HID */
|
||||||
switch (RequestNo) {
|
switch (RequestNo) {
|
||||||
case SET_PROTOCOL:
|
case USB_HID_REQ_SET_PROTOCOL:
|
||||||
return PIOS_USBHOOK_SetProtocol();
|
return PIOS_USBHOOK_SetProtocol();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -380,10 +388,10 @@ static RESULT PIOS_USBHOOK_NoData_Setup(uint8_t RequestNo)
|
|||||||
#if defined(PIOS_INCLUDE_USB_CDC)
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
||||||
case 1: /* CDC Call Control Interface */
|
case 1: /* CDC Call Control Interface */
|
||||||
switch (RequestNo) {
|
switch (RequestNo) {
|
||||||
case SET_LINE_CODING:
|
case USB_CDC_REQ_SET_LINE_CODING:
|
||||||
return PIOS_USB_CDC_SetLineCoding();
|
return PIOS_USB_CDC_SetLineCoding();
|
||||||
break;
|
break;
|
||||||
case SET_CONTROL_LINE_STATE:
|
case USB_CDC_REQ_SET_CONTROL_LINE_STATE:
|
||||||
return PIOS_USB_CDC_SetControlLineState();
|
return PIOS_USB_CDC_SetControlLineState();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,75 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usbd_conf_template.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief usb device configuration template file
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USBD_CONF__H__
|
||||||
|
#define __USBD_CONF__H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "stm32f4xx.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
#define USBD_CFG_MAX_NUM 1
|
||||||
|
#define USB_MAX_STR_DESC_SIZ 64
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#endif //__USBD_CONF__H__
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,114 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usbd_core.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Header file for usbd_core.c
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USBD_CORE_H
|
||||||
|
#define __USBD_CORE_H
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_dcd.h"
|
||||||
|
#include "usbd_def.h"
|
||||||
|
#include "usbd_conf.h"
|
||||||
|
|
||||||
|
/** @addtogroup STM32_USB_OTG_DEVICE_LIBRARY
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE
|
||||||
|
* @brief This file is the Header file for usbd_core.c file
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
USBD_OK = 0,
|
||||||
|
USBD_BUSY,
|
||||||
|
USBD_FAIL,
|
||||||
|
}USBD_Status;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Exported_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
void USBD_Init(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_OTG_CORE_ID_TypeDef coreID,
|
||||||
|
USBD_DEVICE *pDevice,
|
||||||
|
USBD_Class_cb_TypeDef *class_cb,
|
||||||
|
USBD_Usr_cb_TypeDef *usr_cb);
|
||||||
|
|
||||||
|
USBD_Status USBD_DeInit(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
USBD_Status USBD_ClrCfg(USB_OTG_CORE_HANDLE *pdev, uint8_t cfgidx);
|
||||||
|
|
||||||
|
USBD_Status USBD_SetCfg(USB_OTG_CORE_HANDLE *pdev, uint8_t cfgidx);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#endif /* __USBD_CORE_H */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -0,0 +1,149 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usbd_def.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief general defines for the usb device library
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
|
||||||
|
#ifndef __USBD_DEF_H
|
||||||
|
#define __USBD_DEF_H
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usbd_conf.h"
|
||||||
|
|
||||||
|
/** @addtogroup STM32_USB_OTG_DEVICE_LIBRARY
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DEF
|
||||||
|
* @brief general defines for the usb device library file
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DEF_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef NULL
|
||||||
|
#define NULL 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define USB_LEN_DEV_QUALIFIER_DESC 0x0A
|
||||||
|
#define USB_LEN_DEV_DESC 0x12
|
||||||
|
#define USB_LEN_CFG_DESC 0x09
|
||||||
|
#define USB_LEN_IF_DESC 0x09
|
||||||
|
#define USB_LEN_EP_DESC 0x07
|
||||||
|
#define USB_LEN_OTG_DESC 0x03
|
||||||
|
|
||||||
|
#define USBD_IDX_LANGID_STR 0x00
|
||||||
|
#define USBD_IDX_MFC_STR 0x01
|
||||||
|
#define USBD_IDX_PRODUCT_STR 0x02
|
||||||
|
#define USBD_IDX_SERIAL_STR 0x03
|
||||||
|
#define USBD_IDX_CONFIG_STR 0x04
|
||||||
|
#define USBD_IDX_INTERFACE_STR 0x05
|
||||||
|
|
||||||
|
#define USB_REQ_TYPE_STANDARD 0x00
|
||||||
|
#define USB_REQ_TYPE_CLASS 0x20
|
||||||
|
#define USB_REQ_TYPE_VENDOR 0x40
|
||||||
|
#define USB_REQ_TYPE_MASK 0x60
|
||||||
|
|
||||||
|
#define USB_REQ_RECIPIENT_DEVICE 0x00
|
||||||
|
#define USB_REQ_RECIPIENT_INTERFACE 0x01
|
||||||
|
#define USB_REQ_RECIPIENT_ENDPOINT 0x02
|
||||||
|
#define USB_REQ_RECIPIENT_MASK 0x03
|
||||||
|
|
||||||
|
#define USB_REQ_GET_STATUS 0x00
|
||||||
|
#define USB_REQ_CLEAR_FEATURE 0x01
|
||||||
|
#define USB_REQ_SET_FEATURE 0x03
|
||||||
|
#define USB_REQ_SET_ADDRESS 0x05
|
||||||
|
#define USB_REQ_GET_DESCRIPTOR 0x06
|
||||||
|
#define USB_REQ_SET_DESCRIPTOR 0x07
|
||||||
|
#define USB_REQ_GET_CONFIGURATION 0x08
|
||||||
|
#define USB_REQ_SET_CONFIGURATION 0x09
|
||||||
|
#define USB_REQ_GET_INTERFACE 0x0A
|
||||||
|
#define USB_REQ_SET_INTERFACE 0x0B
|
||||||
|
#define USB_REQ_SYNCH_FRAME 0x0C
|
||||||
|
|
||||||
|
#define USB_DESC_TYPE_DEVICE 1
|
||||||
|
#define USB_DESC_TYPE_CONFIGURATION 2
|
||||||
|
#define USB_DESC_TYPE_STRING 3
|
||||||
|
#define USB_DESC_TYPE_INTERFACE 4
|
||||||
|
#define USB_DESC_TYPE_ENDPOINT 5
|
||||||
|
#define USB_DESC_TYPE_DEVICE_QUALIFIER 6
|
||||||
|
#define USB_DESC_TYPE_OTHER_SPEED_CONFIGURATION 7
|
||||||
|
|
||||||
|
|
||||||
|
#define USB_CONFIG_REMOTE_WAKEUP 2
|
||||||
|
#define USB_CONFIG_SELF_POWERED 1
|
||||||
|
|
||||||
|
#define USB_FEATURE_EP_HALT 0
|
||||||
|
#define USB_FEATURE_REMOTE_WAKEUP 1
|
||||||
|
#define USB_FEATURE_TEST_MODE 2
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_DEF_Exported_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_DEF_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
#define SWAPBYTE(addr) (((uint16_t)(*((uint8_t *)(addr)))) + \
|
||||||
|
(((uint16_t)(*(((uint8_t *)(addr)) + 1))) << 8))
|
||||||
|
|
||||||
|
#define LOBYTE(x) ((uint8_t)(x & 0x00FF))
|
||||||
|
#define HIBYTE(x) ((uint8_t)((x & 0xFF00) >>8))
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_DEF_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_DEF_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#endif /* __USBD_DEF_H */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -0,0 +1 @@
|
|||||||
|
#define USBD_ITF_MAX_NUM 2
|
@ -0,0 +1,115 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usbd_ioreq.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief header file for the usbd_ioreq.c file
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
|
||||||
|
#ifndef __USBD_IOREQ_H_
|
||||||
|
#define __USBD_IOREQ_H_
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usbd_def.h"
|
||||||
|
#include "usbd_core.h"
|
||||||
|
|
||||||
|
/** @addtogroup STM32_USB_OTG_DEVICE_LIBRARY
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ
|
||||||
|
* @brief header file for the usbd_ioreq.c file
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
USBD_Status USBD_CtlSendData (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
const uint8_t *buf,
|
||||||
|
uint16_t len);
|
||||||
|
|
||||||
|
USBD_Status USBD_CtlContinueSendData (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t *pbuf,
|
||||||
|
uint16_t len);
|
||||||
|
|
||||||
|
USBD_Status USBD_CtlPrepareRx (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t *pbuf,
|
||||||
|
uint16_t len);
|
||||||
|
|
||||||
|
USBD_Status USBD_CtlContinueRx (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t *pbuf,
|
||||||
|
uint16_t len);
|
||||||
|
|
||||||
|
USBD_Status USBD_CtlSendStatus (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
USBD_Status USBD_CtlReceiveStatus (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
uint16_t USBD_GetRxCount (USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint8_t epnum);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#endif /* __USBD_IOREQ_H_ */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -0,0 +1,102 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usbd_req.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief header file for the usbd_req.c file
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
|
||||||
|
#ifndef __USB_REQUEST_H_
|
||||||
|
#define __USB_REQUEST_H_
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usbd_def.h"
|
||||||
|
#include "usbd_core.h"
|
||||||
|
#include "usbd_conf.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup STM32_USB_OTG_DEVICE_LIBRARY
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ
|
||||||
|
* @brief header file for the usbd_ioreq.c file
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
USBD_Status USBD_StdDevReq (USB_OTG_CORE_HANDLE *pdev, USB_SETUP_REQ *req);
|
||||||
|
USBD_Status USBD_StdItfReq (USB_OTG_CORE_HANDLE *pdev, USB_SETUP_REQ *req);
|
||||||
|
USBD_Status USBD_StdEPReq (USB_OTG_CORE_HANDLE *pdev, USB_SETUP_REQ *req);
|
||||||
|
void USBD_ParseSetupRequest( USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req);
|
||||||
|
|
||||||
|
void USBD_CtlError( USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req);
|
||||||
|
|
||||||
|
void USBD_GetString(uint8_t *desc, uint8_t *unicode, uint16_t *len);
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#endif /* __USB_REQUEST_H_ */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -0,0 +1,135 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usbd_usr.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Header file for usbd_usr.c
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USBD_USR_H__
|
||||||
|
#define __USBD_USR_H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usbd_core.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USBD_USER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @addtogroup USBD_MSC_DEMO_USER_CALLBACKS
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_USR
|
||||||
|
* @brief This file is the Header file for usbd_usr.c
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_USR_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern USBD_Usr_cb_TypeDef USR_cb;
|
||||||
|
extern USBD_Usr_cb_TypeDef USR_FS_cb;
|
||||||
|
extern USBD_Usr_cb_TypeDef USR_HS_cb;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_USR_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_USR_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_USR_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
void USBD_USR_Init(void);
|
||||||
|
void USBD_USR_DeviceReset (uint8_t speed);
|
||||||
|
void USBD_USR_DeviceConfigured (void);
|
||||||
|
void USBD_USR_DeviceSuspended(void);
|
||||||
|
void USBD_USR_DeviceResumed(void);
|
||||||
|
|
||||||
|
void USBD_USR_DeviceConnected(void);
|
||||||
|
void USBD_USR_DeviceDisconnected(void);
|
||||||
|
|
||||||
|
void USBD_USR_FS_Init(void);
|
||||||
|
void USBD_USR_FS_DeviceReset (uint8_t speed);
|
||||||
|
void USBD_USR_FS_DeviceConfigured (void);
|
||||||
|
void USBD_USR_FS_DeviceSuspended(void);
|
||||||
|
void USBD_USR_FS_DeviceResumed(void);
|
||||||
|
|
||||||
|
void USBD_USR_FS_DeviceConnected(void);
|
||||||
|
void USBD_USR_FS_DeviceDisconnected(void);
|
||||||
|
|
||||||
|
void USBD_USR_HS_Init(void);
|
||||||
|
void USBD_USR_HS_DeviceReset (uint8_t speed);
|
||||||
|
void USBD_USR_HS_DeviceConfigured (void);
|
||||||
|
void USBD_USR_HS_DeviceSuspended(void);
|
||||||
|
void USBD_USR_HS_DeviceResumed(void);
|
||||||
|
|
||||||
|
void USBD_USR_HS_DeviceConnected(void);
|
||||||
|
void USBD_USR_HS_DeviceDisconnected(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_USR_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#endif /*__USBD_USR_H__*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -0,0 +1,476 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usbd_core.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief This file provides all the USBD core functions.
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usbd_core.h"
|
||||||
|
#include "usbd_req.h"
|
||||||
|
#include "usbd_ioreq.h"
|
||||||
|
#include "usb_dcd_int.h"
|
||||||
|
#include "usb_bsp.h"
|
||||||
|
|
||||||
|
/** @addtogroup STM32_USB_OTG_DEVICE_LIBRARY
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE
|
||||||
|
* @brief usbd core module
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
static uint8_t USBD_SetupStage(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint8_t USBD_DataOutStage(USB_OTG_CORE_HANDLE *pdev , uint8_t epnum);
|
||||||
|
static uint8_t USBD_DataInStage(USB_OTG_CORE_HANDLE *pdev , uint8_t epnum);
|
||||||
|
static uint8_t USBD_SOF(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint8_t USBD_Reset(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint8_t USBD_Suspend(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint8_t USBD_Resume(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
#ifdef VBUS_SENSING_ENABLED
|
||||||
|
static uint8_t USBD_DevConnected(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint8_t USBD_DevDisconnected(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
#endif
|
||||||
|
static uint8_t USBD_IsoINIncomplete(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint8_t USBD_IsoOUTIncomplete(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
USBD_DCD_INT_cb_TypeDef USBD_DCD_INT_cb =
|
||||||
|
{
|
||||||
|
USBD_DataOutStage,
|
||||||
|
USBD_DataInStage,
|
||||||
|
USBD_SetupStage,
|
||||||
|
USBD_SOF,
|
||||||
|
USBD_Reset,
|
||||||
|
USBD_Suspend,
|
||||||
|
USBD_Resume,
|
||||||
|
USBD_IsoINIncomplete,
|
||||||
|
USBD_IsoOUTIncomplete,
|
||||||
|
#ifdef VBUS_SENSING_ENABLED
|
||||||
|
USBD_DevConnected,
|
||||||
|
USBD_DevDisconnected,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
USBD_DCD_INT_cb_TypeDef *USBD_DCD_INT_fops = &USBD_DCD_INT_cb;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_CORE_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_Init
|
||||||
|
* Initailizes the device stack and load the class driver
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param core_address: USB OTG core ID
|
||||||
|
* @param class_cb: Class callback structure address
|
||||||
|
* @param usr_cb: User callback structure address
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
void USBD_Init(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_OTG_CORE_ID_TypeDef coreID,
|
||||||
|
USBD_DEVICE *pDevice,
|
||||||
|
USBD_Class_cb_TypeDef *class_cb,
|
||||||
|
USBD_Usr_cb_TypeDef *usr_cb)
|
||||||
|
{
|
||||||
|
/* Hardware Init */
|
||||||
|
USB_OTG_BSP_Init(pdev);
|
||||||
|
|
||||||
|
USBD_DeInit(pdev);
|
||||||
|
|
||||||
|
/*Register class and user callbacks */
|
||||||
|
pdev->dev.class_cb = class_cb;
|
||||||
|
pdev->dev.usr_cb = usr_cb;
|
||||||
|
pdev->dev.usr_device = pDevice;
|
||||||
|
|
||||||
|
/* set USB OTG core params */
|
||||||
|
DCD_Init(pdev , coreID);
|
||||||
|
|
||||||
|
/* Upon Init call usr callback */
|
||||||
|
pdev->dev.usr_cb->Init();
|
||||||
|
|
||||||
|
/* Enable Interrupts */
|
||||||
|
USB_OTG_BSP_EnableInterrupt(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_DeInit
|
||||||
|
* Re-Initialize th deviuce library
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status: status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_DeInit(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
/* Software Init */
|
||||||
|
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_SetupStage
|
||||||
|
* Handle the setup stage
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint8_t USBD_SetupStage(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_SETUP_REQ req;
|
||||||
|
|
||||||
|
USBD_ParseSetupRequest(pdev , &req);
|
||||||
|
|
||||||
|
switch (req.bmRequest & 0x1F)
|
||||||
|
{
|
||||||
|
case USB_REQ_RECIPIENT_DEVICE:
|
||||||
|
USBD_StdDevReq (pdev, &req);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_REQ_RECIPIENT_INTERFACE:
|
||||||
|
USBD_StdItfReq(pdev, &req);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_REQ_RECIPIENT_ENDPOINT:
|
||||||
|
USBD_StdEPReq(pdev, &req);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
DCD_EP_Stall(pdev , req.bmRequest & 0x80);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_DataOutStage
|
||||||
|
* Handle data out stage
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param epnum: endpoint index
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint8_t USBD_DataOutStage(USB_OTG_CORE_HANDLE *pdev , uint8_t epnum)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
|
||||||
|
if(epnum == 0)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.out_ep[0];
|
||||||
|
if ( pdev->dev.device_state == USB_OTG_EP0_DATA_OUT)
|
||||||
|
{
|
||||||
|
if(ep->rem_data_len > ep->maxpacket)
|
||||||
|
{
|
||||||
|
ep->rem_data_len -= ep->maxpacket;
|
||||||
|
|
||||||
|
if(pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
/* in slave mode this, is handled by the RxSTSQLvl ISR */
|
||||||
|
ep->xfer_buff += ep->maxpacket;
|
||||||
|
}
|
||||||
|
USBD_CtlContinueRx (pdev,
|
||||||
|
ep->xfer_buff,
|
||||||
|
MIN(ep->rem_data_len ,ep->maxpacket));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if((pdev->dev.class_cb->EP0_RxReady != NULL)&&
|
||||||
|
(pdev->dev.device_status == USB_OTG_CONFIGURED))
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->EP0_RxReady(pdev);
|
||||||
|
}
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if((pdev->dev.class_cb->DataOut != NULL)&&
|
||||||
|
(pdev->dev.device_status == USB_OTG_CONFIGURED))
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->DataOut(pdev, epnum);
|
||||||
|
}
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_DataInStage
|
||||||
|
* Handle data in stage
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param epnum: endpoint index
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint8_t USBD_DataInStage(USB_OTG_CORE_HANDLE *pdev , uint8_t epnum)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
|
||||||
|
if(epnum == 0)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.in_ep[0];
|
||||||
|
if ( pdev->dev.device_state == USB_OTG_EP0_DATA_IN)
|
||||||
|
{
|
||||||
|
if(ep->rem_data_len > ep->maxpacket)
|
||||||
|
{
|
||||||
|
ep->rem_data_len -= ep->maxpacket;
|
||||||
|
if(pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
/* in slave mode this, is handled by the TxFifoEmpty ISR */
|
||||||
|
ep->xfer_buff += ep->maxpacket;
|
||||||
|
}
|
||||||
|
USBD_CtlContinueSendData (pdev,
|
||||||
|
ep->xfer_buff,
|
||||||
|
ep->rem_data_len);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{ /* last packet is MPS multiple, so send ZLP packet */
|
||||||
|
if((ep->total_data_len % ep->maxpacket == 0) &&
|
||||||
|
(ep->total_data_len >= ep->maxpacket) &&
|
||||||
|
(ep->total_data_len < ep->ctl_data_len ))
|
||||||
|
{
|
||||||
|
|
||||||
|
USBD_CtlContinueSendData(pdev , NULL, 0);
|
||||||
|
ep->ctl_data_len = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if((pdev->dev.class_cb->EP0_TxSent != NULL)&&
|
||||||
|
(pdev->dev.device_status == USB_OTG_CONFIGURED))
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->EP0_TxSent(pdev);
|
||||||
|
}
|
||||||
|
USBD_CtlReceiveStatus(pdev);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if((pdev->dev.class_cb->DataIn != NULL)&&
|
||||||
|
(pdev->dev.device_status == USB_OTG_CONFIGURED))
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->DataIn(pdev, epnum);
|
||||||
|
}
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_Reset
|
||||||
|
* Handle Reset event
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
|
||||||
|
static uint8_t USBD_Reset(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
/* Open EP0 OUT */
|
||||||
|
DCD_EP_Open(pdev,
|
||||||
|
0x00,
|
||||||
|
USB_OTG_MAX_EP0_SIZE,
|
||||||
|
EP_TYPE_CTRL);
|
||||||
|
|
||||||
|
/* Open EP0 IN */
|
||||||
|
DCD_EP_Open(pdev,
|
||||||
|
0x80,
|
||||||
|
USB_OTG_MAX_EP0_SIZE,
|
||||||
|
EP_TYPE_CTRL);
|
||||||
|
|
||||||
|
/* Upon Reset call usr call back */
|
||||||
|
pdev->dev.device_status = USB_OTG_DEFAULT;
|
||||||
|
pdev->dev.usr_cb->DeviceReset(pdev->cfg.speed);
|
||||||
|
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_Resume
|
||||||
|
* Handle Resume event
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
|
||||||
|
static uint8_t USBD_Resume(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
/* Upon Resume call usr call back */
|
||||||
|
pdev->dev.usr_cb->DeviceResumed();
|
||||||
|
pdev->dev.device_status = USB_OTG_CONFIGURED;
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_Suspend
|
||||||
|
* Handle Suspend event
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
|
||||||
|
static uint8_t USBD_Suspend(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
pdev->dev.device_status = USB_OTG_SUSPENDED;
|
||||||
|
/* Upon Resume call usr call back */
|
||||||
|
pdev->dev.usr_cb->DeviceSuspended();
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_SOF
|
||||||
|
* Handle SOF event
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
|
||||||
|
static uint8_t USBD_SOF(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
if(pdev->dev.class_cb->SOF)
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->SOF(pdev);
|
||||||
|
}
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief USBD_SetCfg
|
||||||
|
* Configure device and start the interface
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param cfgidx: configuration index
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
|
||||||
|
USBD_Status USBD_SetCfg(USB_OTG_CORE_HANDLE *pdev, uint8_t cfgidx)
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->Init(pdev, cfgidx);
|
||||||
|
|
||||||
|
/* Upon set config call usr call back */
|
||||||
|
pdev->dev.usr_cb->DeviceConfigured();
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_ClrCfg
|
||||||
|
* Clear current configuration
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param cfgidx: configuration index
|
||||||
|
* @retval status: USBD_Status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_ClrCfg(USB_OTG_CORE_HANDLE *pdev, uint8_t cfgidx)
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->DeInit(pdev, cfgidx);
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_IsoINIncomplete
|
||||||
|
* Handle iso in incomplete event
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint8_t USBD_IsoINIncomplete(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->IsoINIncomplete(pdev);
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_IsoOUTIncomplete
|
||||||
|
* Handle iso out incomplete event
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint8_t USBD_IsoOUTIncomplete(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->IsoOUTIncomplete(pdev);
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef VBUS_SENSING_ENABLED
|
||||||
|
/**
|
||||||
|
* @brief USBD_DevConnected
|
||||||
|
* Handle device connection event
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint8_t USBD_DevConnected(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
pdev->dev.usr_cb->DeviceConnected();
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_DevDisconnected
|
||||||
|
* Handle device disconnection event
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint8_t USBD_DevDisconnected(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
pdev->dev.usr_cb->DeviceDisconnected();
|
||||||
|
pdev->dev.class_cb->DeInit(pdev, 0);
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,237 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usbd_ioreq.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief This file provides the IO requests APIs for control endpoints.
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usbd_ioreq.h"
|
||||||
|
/** @addtogroup STM32_USB_OTG_DEVICE_LIBRARY
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ
|
||||||
|
* @brief control I/O requests module
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_IOREQ_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_CtlSendData
|
||||||
|
* send data on the ctl pipe
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param buff: pointer to data buffer
|
||||||
|
* @param len: length of data to be sent
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_CtlSendData (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
const uint8_t *pbuf,
|
||||||
|
uint16_t len)
|
||||||
|
{
|
||||||
|
USBD_Status ret = USBD_OK;
|
||||||
|
|
||||||
|
pdev->dev.in_ep[0].total_data_len = len;
|
||||||
|
pdev->dev.in_ep[0].rem_data_len = len;
|
||||||
|
pdev->dev.device_state = USB_OTG_EP0_DATA_IN;
|
||||||
|
|
||||||
|
DCD_EP_Tx (pdev, 0, pbuf, len);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_CtlContinueSendData
|
||||||
|
* continue sending data on the ctl pipe
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param buff: pointer to data buffer
|
||||||
|
* @param len: length of data to be sent
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_CtlContinueSendData (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t *pbuf,
|
||||||
|
uint16_t len)
|
||||||
|
{
|
||||||
|
USBD_Status ret = USBD_OK;
|
||||||
|
|
||||||
|
DCD_EP_Tx (pdev, 0, pbuf, len);
|
||||||
|
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_CtlPrepareRx
|
||||||
|
* receive data on the ctl pipe
|
||||||
|
* @param pdev: USB OTG device instance
|
||||||
|
* @param buff: pointer to data buffer
|
||||||
|
* @param len: length of data to be received
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_CtlPrepareRx (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t *pbuf,
|
||||||
|
uint16_t len)
|
||||||
|
{
|
||||||
|
USBD_Status ret = USBD_OK;
|
||||||
|
|
||||||
|
pdev->dev.out_ep[0].total_data_len = len;
|
||||||
|
pdev->dev.out_ep[0].rem_data_len = len;
|
||||||
|
pdev->dev.device_state = USB_OTG_EP0_DATA_OUT;
|
||||||
|
|
||||||
|
DCD_EP_PrepareRx (pdev,
|
||||||
|
0,
|
||||||
|
pbuf,
|
||||||
|
len);
|
||||||
|
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_CtlContinueRx
|
||||||
|
* continue receive data on the ctl pipe
|
||||||
|
* @param pdev: USB OTG device instance
|
||||||
|
* @param buff: pointer to data buffer
|
||||||
|
* @param len: length of data to be received
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_CtlContinueRx (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t *pbuf,
|
||||||
|
uint16_t len)
|
||||||
|
{
|
||||||
|
USBD_Status ret = USBD_OK;
|
||||||
|
|
||||||
|
DCD_EP_PrepareRx (pdev,
|
||||||
|
0,
|
||||||
|
pbuf,
|
||||||
|
len);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief USBD_CtlSendStatus
|
||||||
|
* send zero lzngth packet on the ctl pipe
|
||||||
|
* @param pdev: USB OTG device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_CtlSendStatus (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USBD_Status ret = USBD_OK;
|
||||||
|
pdev->dev.device_state = USB_OTG_EP0_STATUS_IN;
|
||||||
|
DCD_EP_Tx (pdev,
|
||||||
|
0,
|
||||||
|
NULL,
|
||||||
|
0);
|
||||||
|
|
||||||
|
USB_OTG_EP0_OutStart(pdev);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_CtlReceiveStatus
|
||||||
|
* receive zero lzngth packet on the ctl pipe
|
||||||
|
* @param pdev: USB OTG device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_CtlReceiveStatus (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USBD_Status ret = USBD_OK;
|
||||||
|
pdev->dev.device_state = USB_OTG_EP0_STATUS_OUT;
|
||||||
|
DCD_EP_PrepareRx ( pdev,
|
||||||
|
0,
|
||||||
|
NULL,
|
||||||
|
0);
|
||||||
|
|
||||||
|
USB_OTG_EP0_OutStart(pdev);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_GetRxCount
|
||||||
|
* returns the received data length
|
||||||
|
* @param pdev: USB OTG device instance
|
||||||
|
* epnum: endpoint index
|
||||||
|
* @retval Rx Data blength
|
||||||
|
*/
|
||||||
|
uint16_t USBD_GetRxCount (USB_OTG_CORE_HANDLE *pdev , uint8_t epnum)
|
||||||
|
{
|
||||||
|
return pdev->dev.out_ep[epnum].xfer_count;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -0,0 +1,867 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usbd_req.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief This file provides the standard USB requests following chapter 9.
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usbd_req.h"
|
||||||
|
#include "usbd_ioreq.h"
|
||||||
|
#include "usbd_desc.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup STM32_USB_OTG_DEVICE_LIBRARY
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ
|
||||||
|
* @brief USB standard requests module
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_INTERNAL_DMA_ENABLED
|
||||||
|
#if defined ( __ICCARM__ ) /*!< IAR Compiler */
|
||||||
|
#pragma data_alignment=4
|
||||||
|
#endif
|
||||||
|
#endif /* USB_OTG_HS_INTERNAL_DMA_ENABLED */
|
||||||
|
__ALIGN_BEGIN uint32_t USBD_ep_status __ALIGN_END = 0;
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_INTERNAL_DMA_ENABLED
|
||||||
|
#if defined ( __ICCARM__ ) /*!< IAR Compiler */
|
||||||
|
#pragma data_alignment=4
|
||||||
|
#endif
|
||||||
|
#endif /* USB_OTG_HS_INTERNAL_DMA_ENABLED */
|
||||||
|
__ALIGN_BEGIN uint32_t USBD_default_cfg __ALIGN_END = 0;
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_INTERNAL_DMA_ENABLED
|
||||||
|
#if defined ( __ICCARM__ ) /*!< IAR Compiler */
|
||||||
|
#pragma data_alignment=4
|
||||||
|
#endif
|
||||||
|
#endif /* USB_OTG_HS_INTERNAL_DMA_ENABLED */
|
||||||
|
__ALIGN_BEGIN uint32_t USBD_cfg_status __ALIGN_END = 0;
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_INTERNAL_DMA_ENABLED
|
||||||
|
#if defined ( __ICCARM__ ) /*!< IAR Compiler */
|
||||||
|
#pragma data_alignment=4
|
||||||
|
#endif
|
||||||
|
#endif /* USB_OTG_HS_INTERNAL_DMA_ENABLED */
|
||||||
|
__ALIGN_BEGIN uint8_t USBD_StrDesc[USB_MAX_STR_DESC_SIZ] __ALIGN_END ;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
static void USBD_GetDescriptor(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req);
|
||||||
|
|
||||||
|
static void USBD_SetAddress(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req);
|
||||||
|
|
||||||
|
static void USBD_SetConfig(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req);
|
||||||
|
|
||||||
|
static void USBD_GetConfig(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req);
|
||||||
|
|
||||||
|
static void USBD_GetStatus(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req);
|
||||||
|
|
||||||
|
static void USBD_SetFeature(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req);
|
||||||
|
|
||||||
|
static void USBD_ClrFeature(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req);
|
||||||
|
|
||||||
|
static uint8_t USBD_GetLen(uint8_t *buf);
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USBD_REQ_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_StdDevReq
|
||||||
|
* Handle standard usb device requests
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_StdDevReq (USB_OTG_CORE_HANDLE *pdev, USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
USBD_Status ret = USBD_OK;
|
||||||
|
|
||||||
|
switch (req->bRequest)
|
||||||
|
{
|
||||||
|
case USB_REQ_GET_DESCRIPTOR:
|
||||||
|
|
||||||
|
USBD_GetDescriptor (pdev, req) ;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_REQ_SET_ADDRESS:
|
||||||
|
USBD_SetAddress(pdev, req);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_REQ_SET_CONFIGURATION:
|
||||||
|
USBD_SetConfig (pdev , req);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_REQ_GET_CONFIGURATION:
|
||||||
|
USBD_GetConfig (pdev , req);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_REQ_GET_STATUS:
|
||||||
|
USBD_GetStatus (pdev , req);
|
||||||
|
break;
|
||||||
|
|
||||||
|
|
||||||
|
case USB_REQ_SET_FEATURE:
|
||||||
|
USBD_SetFeature (pdev , req);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_REQ_CLEAR_FEATURE:
|
||||||
|
USBD_ClrFeature (pdev , req);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_StdItfReq
|
||||||
|
* Handle standard usb interface requests
|
||||||
|
* @param pdev: USB OTG device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_StdItfReq (USB_OTG_CORE_HANDLE *pdev, USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
USBD_Status ret = USBD_OK;
|
||||||
|
|
||||||
|
switch (pdev->dev.device_status)
|
||||||
|
{
|
||||||
|
case USB_OTG_CONFIGURED:
|
||||||
|
|
||||||
|
if (LOBYTE(req->wIndex) <= USBD_ITF_MAX_NUM)
|
||||||
|
{
|
||||||
|
pdev->dev.class_cb->Setup (pdev, req);
|
||||||
|
|
||||||
|
if((req->wLength == 0)&& (ret == USBD_OK))
|
||||||
|
{
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_StdEPReq
|
||||||
|
* Handle standard usb endpoint requests
|
||||||
|
* @param pdev: USB OTG device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USBD_Status USBD_StdEPReq (USB_OTG_CORE_HANDLE *pdev, USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
|
||||||
|
uint8_t ep_addr;
|
||||||
|
USBD_Status ret = USBD_OK;
|
||||||
|
|
||||||
|
ep_addr = LOBYTE(req->wIndex);
|
||||||
|
|
||||||
|
switch (req->bRequest)
|
||||||
|
{
|
||||||
|
|
||||||
|
case USB_REQ_SET_FEATURE :
|
||||||
|
|
||||||
|
switch (pdev->dev.device_status)
|
||||||
|
{
|
||||||
|
case USB_OTG_ADDRESSED:
|
||||||
|
if ((ep_addr != 0x00) && (ep_addr != 0x80))
|
||||||
|
{
|
||||||
|
DCD_EP_Stall(pdev , ep_addr);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_OTG_CONFIGURED:
|
||||||
|
if (req->wValue == USB_FEATURE_EP_HALT)
|
||||||
|
{
|
||||||
|
if ((ep_addr != 0x00) && (ep_addr != 0x80))
|
||||||
|
{
|
||||||
|
DCD_EP_Stall(pdev , ep_addr);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pdev->dev.class_cb->Setup (pdev, req);
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_REQ_CLEAR_FEATURE :
|
||||||
|
|
||||||
|
switch (pdev->dev.device_status)
|
||||||
|
{
|
||||||
|
case USB_OTG_ADDRESSED:
|
||||||
|
if ((ep_addr != 0x00) && (ep_addr != 0x80))
|
||||||
|
{
|
||||||
|
DCD_EP_Stall(pdev , ep_addr);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_OTG_CONFIGURED:
|
||||||
|
if (req->wValue == USB_FEATURE_EP_HALT)
|
||||||
|
{
|
||||||
|
if ((ep_addr != 0x00) && (ep_addr != 0x80))
|
||||||
|
{
|
||||||
|
DCD_EP_ClrStall(pdev , ep_addr);
|
||||||
|
pdev->dev.class_cb->Setup (pdev, req);
|
||||||
|
}
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_REQ_GET_STATUS:
|
||||||
|
switch (pdev->dev.device_status)
|
||||||
|
{
|
||||||
|
case USB_OTG_ADDRESSED:
|
||||||
|
if ((ep_addr != 0x00) && (ep_addr != 0x80))
|
||||||
|
{
|
||||||
|
DCD_EP_Stall(pdev , ep_addr);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_OTG_CONFIGURED:
|
||||||
|
|
||||||
|
|
||||||
|
if ((ep_addr & 0x80)== 0x80)
|
||||||
|
{
|
||||||
|
if(pdev->dev.in_ep[ep_addr & 0x7F].is_stall)
|
||||||
|
{
|
||||||
|
USBD_ep_status = 0x0001;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USBD_ep_status = 0x0000;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if ((ep_addr & 0x80)== 0x00)
|
||||||
|
{
|
||||||
|
if(pdev->dev.out_ep[ep_addr].is_stall)
|
||||||
|
{
|
||||||
|
USBD_ep_status = 0x0001;
|
||||||
|
}
|
||||||
|
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USBD_ep_status = 0x0000;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
USBD_CtlSendData (pdev,
|
||||||
|
(uint8_t *)&USBD_ep_status,
|
||||||
|
2);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief USBD_GetDescriptor
|
||||||
|
* Handle Get Descriptor requests
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static void USBD_GetDescriptor(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
uint16_t len;
|
||||||
|
const uint8_t * pbuf;
|
||||||
|
|
||||||
|
switch (req->wValue >> 8)
|
||||||
|
{
|
||||||
|
case USB_DESC_TYPE_DEVICE:
|
||||||
|
pbuf = pdev->dev.usr_device->GetDeviceDescriptor(pdev->cfg.speed, &len);
|
||||||
|
if ((req->wLength == 64) ||( pdev->dev.device_status == USB_OTG_DEFAULT))
|
||||||
|
{
|
||||||
|
len = 8;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_DESC_TYPE_CONFIGURATION:
|
||||||
|
pbuf = (uint8_t *)pdev->dev.class_cb->GetConfigDescriptor(pdev->cfg.speed, &len);
|
||||||
|
#ifdef USB_OTG_HS_CORE
|
||||||
|
if((pdev->cfg.speed == USB_OTG_SPEED_FULL )&&
|
||||||
|
(pdev->cfg.phy_itface == USB_OTG_ULPI_PHY))
|
||||||
|
{
|
||||||
|
pbuf = (uint8_t *)pdev->dev.class_cb->GetOtherConfigDescriptor(pdev->cfg.speed, &len);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
pdev->dev.pConfig_descriptor = pbuf;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_DESC_TYPE_STRING:
|
||||||
|
switch ((uint8_t)(req->wValue))
|
||||||
|
{
|
||||||
|
case USBD_IDX_LANGID_STR:
|
||||||
|
pbuf = pdev->dev.usr_device->GetLangIDStrDescriptor(pdev->cfg.speed, &len);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USBD_IDX_MFC_STR:
|
||||||
|
pbuf = pdev->dev.usr_device->GetManufacturerStrDescriptor(pdev->cfg.speed, &len);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USBD_IDX_PRODUCT_STR:
|
||||||
|
pbuf = pdev->dev.usr_device->GetProductStrDescriptor(pdev->cfg.speed, &len);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USBD_IDX_SERIAL_STR:
|
||||||
|
pbuf = pdev->dev.usr_device->GetSerialStrDescriptor(pdev->cfg.speed, &len);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USBD_IDX_CONFIG_STR:
|
||||||
|
pbuf = pdev->dev.usr_device->GetConfigurationStrDescriptor(pdev->cfg.speed, &len);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USBD_IDX_INTERFACE_STR:
|
||||||
|
pbuf = pdev->dev.usr_device->GetInterfaceStrDescriptor(pdev->cfg.speed, &len);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
#ifdef USB_SUPPORT_USER_STRING_DESC
|
||||||
|
pbuf = pdev->dev.class_cb->GetUsrStrDescriptor(pdev->cfg.speed, (req->wValue) , &len);
|
||||||
|
break;
|
||||||
|
#else
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
return;
|
||||||
|
#endif /* USBD_CtlError(pdev , req); */
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case USB_DESC_TYPE_DEVICE_QUALIFIER:
|
||||||
|
#ifdef USB_OTG_HS_CORE
|
||||||
|
if(pdev->cfg.speed == USB_OTG_SPEED_HIGH )
|
||||||
|
{
|
||||||
|
|
||||||
|
pbuf = (uint8_t *)pdev->dev.class_cb->GetConfigDescriptor(pdev->cfg.speed, &len);
|
||||||
|
|
||||||
|
USBD_DeviceQualifierDesc[4]= pbuf[14];
|
||||||
|
USBD_DeviceQualifierDesc[5]= pbuf[15];
|
||||||
|
USBD_DeviceQualifierDesc[6]= pbuf[16];
|
||||||
|
|
||||||
|
pbuf = USBD_DeviceQualifierDesc;
|
||||||
|
len = USB_LEN_DEV_QUALIFIER_DESC;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
return;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
case USB_DESC_TYPE_OTHER_SPEED_CONFIGURATION:
|
||||||
|
#ifdef USB_OTG_HS_CORE
|
||||||
|
|
||||||
|
if(pdev->cfg.speed == USB_OTG_SPEED_HIGH )
|
||||||
|
{
|
||||||
|
pbuf = (uint8_t *)pdev->dev.class_cb->GetOtherConfigDescriptor(pdev->cfg.speed, &len);
|
||||||
|
pbuf[1] = USB_DESC_TYPE_OTHER_SPEED_CONFIGURATION;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
return;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
default:
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if((len != 0)&& (req->wLength != 0))
|
||||||
|
{
|
||||||
|
|
||||||
|
len = MIN(len , req->wLength);
|
||||||
|
|
||||||
|
USBD_CtlSendData (pdev,
|
||||||
|
pbuf,
|
||||||
|
len);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_SetAddress
|
||||||
|
* Set device address
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static void USBD_SetAddress(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
uint8_t dev_addr;
|
||||||
|
|
||||||
|
if ((req->wIndex == 0) && (req->wLength == 0))
|
||||||
|
{
|
||||||
|
dev_addr = (uint8_t)(req->wValue) & 0x7F;
|
||||||
|
|
||||||
|
if (pdev->dev.device_status == USB_OTG_CONFIGURED)
|
||||||
|
{
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pdev->dev.device_address = dev_addr;
|
||||||
|
DCD_EP_SetAddress(pdev, dev_addr);
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
|
||||||
|
if (dev_addr != 0)
|
||||||
|
{
|
||||||
|
pdev->dev.device_status = USB_OTG_ADDRESSED;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pdev->dev.device_status = USB_OTG_DEFAULT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_SetConfig
|
||||||
|
* Handle Set device configuration request
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static void USBD_SetConfig(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
|
||||||
|
static uint8_t cfgidx;
|
||||||
|
|
||||||
|
cfgidx = (uint8_t)(req->wValue);
|
||||||
|
|
||||||
|
if (cfgidx > USBD_CFG_MAX_NUM )
|
||||||
|
{
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch (pdev->dev.device_status)
|
||||||
|
{
|
||||||
|
case USB_OTG_ADDRESSED:
|
||||||
|
if (cfgidx)
|
||||||
|
{
|
||||||
|
pdev->dev.device_config = cfgidx;
|
||||||
|
pdev->dev.device_status = USB_OTG_CONFIGURED;
|
||||||
|
USBD_SetCfg(pdev , cfgidx);
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_OTG_CONFIGURED:
|
||||||
|
if (cfgidx == 0)
|
||||||
|
{
|
||||||
|
pdev->dev.device_status = USB_OTG_ADDRESSED;
|
||||||
|
pdev->dev.device_config = cfgidx;
|
||||||
|
USBD_ClrCfg(pdev , cfgidx);
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
|
||||||
|
}
|
||||||
|
else if (cfgidx != pdev->dev.device_config)
|
||||||
|
{
|
||||||
|
/* Clear old configuration */
|
||||||
|
USBD_ClrCfg(pdev , pdev->dev.device_config);
|
||||||
|
|
||||||
|
/* set new configuration */
|
||||||
|
pdev->dev.device_config = cfgidx;
|
||||||
|
USBD_SetCfg(pdev , cfgidx);
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_GetConfig
|
||||||
|
* Handle Get device configuration request
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static void USBD_GetConfig(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (req->wLength != 1)
|
||||||
|
{
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch (pdev->dev.device_status )
|
||||||
|
{
|
||||||
|
case USB_OTG_ADDRESSED:
|
||||||
|
|
||||||
|
USBD_CtlSendData (pdev,
|
||||||
|
(uint8_t *)&USBD_default_cfg,
|
||||||
|
1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case USB_OTG_CONFIGURED:
|
||||||
|
|
||||||
|
USBD_CtlSendData (pdev,
|
||||||
|
&pdev->dev.device_config,
|
||||||
|
1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_GetStatus
|
||||||
|
* Handle Get Status request
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static void USBD_GetStatus(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
|
||||||
|
switch (pdev->dev.device_status)
|
||||||
|
{
|
||||||
|
case USB_OTG_ADDRESSED:
|
||||||
|
case USB_OTG_CONFIGURED:
|
||||||
|
|
||||||
|
if (pdev->dev.DevRemoteWakeup)
|
||||||
|
{
|
||||||
|
USBD_cfg_status = USB_CONFIG_SELF_POWERED | USB_CONFIG_REMOTE_WAKEUP;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USBD_cfg_status = USB_CONFIG_SELF_POWERED;
|
||||||
|
}
|
||||||
|
|
||||||
|
USBD_CtlSendData (pdev,
|
||||||
|
(uint8_t *)&USBD_cfg_status,
|
||||||
|
1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default :
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_SetFeature
|
||||||
|
* Handle Set device feature request
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static void USBD_SetFeature(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_DCTL_TypeDef dctl;
|
||||||
|
uint8_t test_mode = 0;
|
||||||
|
|
||||||
|
if (req->wValue == USB_FEATURE_REMOTE_WAKEUP)
|
||||||
|
{
|
||||||
|
pdev->dev.DevRemoteWakeup = 1;
|
||||||
|
pdev->dev.class_cb->Setup (pdev, req);
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
else if ((req->wValue == USB_FEATURE_TEST_MODE) &&
|
||||||
|
((req->wIndex & 0xFF) == 0))
|
||||||
|
{
|
||||||
|
dctl.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DCTL);
|
||||||
|
|
||||||
|
test_mode = req->wIndex >> 8;
|
||||||
|
switch (test_mode)
|
||||||
|
{
|
||||||
|
case 1: // TEST_J
|
||||||
|
dctl.b.tstctl = 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2: // TEST_K
|
||||||
|
dctl.b.tstctl = 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 3: // TEST_SE0_NAK
|
||||||
|
dctl.b.tstctl = 3;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 4: // TEST_PACKET
|
||||||
|
dctl.b.tstctl = 4;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 5: // TEST_FORCE_ENABLE
|
||||||
|
dctl.b.tstctl = 5;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.DREGS->DCTL, dctl.d32);
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_ClrFeature
|
||||||
|
* Handle clear device feature request
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static void USBD_ClrFeature(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
switch (pdev->dev.device_status)
|
||||||
|
{
|
||||||
|
case USB_OTG_ADDRESSED:
|
||||||
|
case USB_OTG_CONFIGURED:
|
||||||
|
if (req->wValue == USB_FEATURE_REMOTE_WAKEUP)
|
||||||
|
{
|
||||||
|
pdev->dev.DevRemoteWakeup = 0;
|
||||||
|
pdev->dev.class_cb->Setup (pdev, req);
|
||||||
|
USBD_CtlSendStatus(pdev);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default :
|
||||||
|
USBD_CtlError(pdev , req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_ParseSetupRequest
|
||||||
|
* Copy buffer into setup structure
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
|
||||||
|
void USBD_ParseSetupRequest( USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
req->bmRequest = *(uint8_t *) (pdev->dev.setup_packet);
|
||||||
|
req->bRequest = *(uint8_t *) (pdev->dev.setup_packet + 1);
|
||||||
|
req->wValue = SWAPBYTE (pdev->dev.setup_packet + 2);
|
||||||
|
req->wIndex = SWAPBYTE (pdev->dev.setup_packet + 4);
|
||||||
|
req->wLength = SWAPBYTE (pdev->dev.setup_packet + 6);
|
||||||
|
|
||||||
|
pdev->dev.in_ep[0].ctl_data_len = req->wLength ;
|
||||||
|
pdev->dev.device_state = USB_OTG_EP0_SETUP;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_CtlError
|
||||||
|
* Handle USB low level Error
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param req: usb request
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
|
||||||
|
void USBD_CtlError( USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
if((req->bmRequest & 0x80) == 0x80)
|
||||||
|
{
|
||||||
|
DCD_EP_Stall(pdev , 0x80);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(req->wLength == 0)
|
||||||
|
{
|
||||||
|
DCD_EP_Stall(pdev , 0x80);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
DCD_EP_Stall(pdev , 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
USB_OTG_EP0_OutStart(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_GetString
|
||||||
|
* Convert Ascii string into unicode one
|
||||||
|
* @param desc : descriptor buffer
|
||||||
|
* @param unicode : Formatted string buffer (unicode)
|
||||||
|
* @param len : descriptor length
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
void USBD_GetString(uint8_t *desc, uint8_t *unicode, uint16_t *len)
|
||||||
|
{
|
||||||
|
uint8_t idx = 0;
|
||||||
|
|
||||||
|
if (desc != NULL)
|
||||||
|
{
|
||||||
|
*len = USBD_GetLen(desc) * 2 + 2;
|
||||||
|
unicode[idx++] = *len;
|
||||||
|
unicode[idx++] = USB_DESC_TYPE_STRING;
|
||||||
|
|
||||||
|
while (*desc != NULL)
|
||||||
|
{
|
||||||
|
unicode[idx++] = *desc++;
|
||||||
|
unicode[idx++] = 0x00;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_GetLen
|
||||||
|
* return the string length
|
||||||
|
* @param buf : pointer to the ascii string buffer
|
||||||
|
* @retval string length
|
||||||
|
*/
|
||||||
|
static uint8_t USBD_GetLen(uint8_t *buf)
|
||||||
|
{
|
||||||
|
uint8_t len = 0;
|
||||||
|
|
||||||
|
while (*buf != NULL)
|
||||||
|
{
|
||||||
|
len++;
|
||||||
|
buf++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -0,0 +1,941 @@
|
|||||||
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
||||||
|
<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head>
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=windows-1252">
|
||||||
|
<link rel="File-List" href="Release_Notes_for_STM32F2xx_StdPeriph_Driver_files/filelist.xml">
|
||||||
|
<link rel="Edit-Time-Data" href="Release_Notes_for_STM32F2xx_StdPeriph_Driver_files/editdata.mso"><!--[if !mso]>
|
||||||
|
<style>
|
||||||
|
v\:* {behavior:url(#default#VML);}
|
||||||
|
o\:* {behavior:url(#default#VML);}
|
||||||
|
w\:* {behavior:url(#default#VML);}
|
||||||
|
.shape {behavior:url(#default#VML);}
|
||||||
|
</style>
|
||||||
|
<![endif]-->
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<title>Release Notes for STM32F105/7xx and STM32F2xx USB Device Library</title><!--[if gte mso 9]><xml>
|
||||||
|
<o:DocumentProperties>
|
||||||
|
<o:Author>STMicroelectronics</o:Author>
|
||||||
|
<o:LastAuthor>Raouf Hosni</o:LastAuthor>
|
||||||
|
<o:Revision>39</o:Revision>
|
||||||
|
<o:TotalTime>137</o:TotalTime>
|
||||||
|
<o:Created>2009-02-27T19:26:00Z</o:Created>
|
||||||
|
<o:LastSaved>2010-10-15T11:07:00Z</o:LastSaved>
|
||||||
|
<o:Pages>3</o:Pages>
|
||||||
|
<o:Words>973</o:Words>
|
||||||
|
<o:Characters>5548</o:Characters>
|
||||||
|
<o:Company>STMicroelectronics</o:Company>
|
||||||
|
<o:Lines>46</o:Lines>
|
||||||
|
<o:Paragraphs>13</o:Paragraphs>
|
||||||
|
<o:CharactersWithSpaces>6508</o:CharactersWithSpaces>
|
||||||
|
<o:Version>12.00</o:Version>
|
||||||
|
</o:DocumentProperties>
|
||||||
|
</xml><![endif]--><link rel="themeData" href="Release_Notes_for_STM32F2xx_StdPeriph_Driver_files/themedata.thmx">
|
||||||
|
<link rel="colorSchemeMapping" href="Release_Notes_for_STM32F2xx_StdPeriph_Driver_files/colorschememapping.xml"><!--[if gte mso 9]><xml>
|
||||||
|
<w:WordDocument>
|
||||||
|
<w:Zoom>110</w:Zoom>
|
||||||
|
<w:TrackMoves>false</w:TrackMoves>
|
||||||
|
<w:TrackFormatting/>
|
||||||
|
<w:ValidateAgainstSchemas/>
|
||||||
|
<w:SaveIfXMLInvalid>false</w:SaveIfXMLInvalid>
|
||||||
|
<w:IgnoreMixedContent>false</w:IgnoreMixedContent>
|
||||||
|
<w:AlwaysShowPlaceholderText>false</w:AlwaysShowPlaceholderText>
|
||||||
|
<w:DoNotPromoteQF/>
|
||||||
|
<w:LidThemeOther>EN-US</w:LidThemeOther>
|
||||||
|
<w:LidThemeAsian>X-NONE</w:LidThemeAsian>
|
||||||
|
<w:LidThemeComplexScript>X-NONE</w:LidThemeComplexScript>
|
||||||
|
<w:Compatibility>
|
||||||
|
<w:BreakWrappedTables/>
|
||||||
|
<w:SnapToGridInCell/>
|
||||||
|
<w:WrapTextWithPunct/>
|
||||||
|
<w:UseAsianBreakRules/>
|
||||||
|
<w:DontGrowAutofit/>
|
||||||
|
<w:SplitPgBreakAndParaMark/>
|
||||||
|
<w:DontVertAlignCellWithSp/>
|
||||||
|
<w:DontBreakConstrainedForcedTables/>
|
||||||
|
<w:DontVertAlignInTxbx/>
|
||||||
|
<w:Word11KerningPairs/>
|
||||||
|
<w:CachedColBalance/>
|
||||||
|
</w:Compatibility>
|
||||||
|
<w:BrowserLevel>MicrosoftInternetExplorer4</w:BrowserLevel>
|
||||||
|
<m:mathPr>
|
||||||
|
<m:mathFont m:val="Cambria Math"/>
|
||||||
|
<m:brkBin m:val="before"/>
|
||||||
|
<m:brkBinSub m:val="--"/>
|
||||||
|
<m:smallFrac m:val="off"/>
|
||||||
|
<m:dispDef/>
|
||||||
|
<m:lMargin m:val="0"/>
|
||||||
|
<m:rMargin m:val="0"/>
|
||||||
|
<m:defJc m:val="centerGroup"/>
|
||||||
|
<m:wrapIndent m:val="1440"/>
|
||||||
|
<m:intLim m:val="subSup"/>
|
||||||
|
<m:naryLim m:val="undOvr"/>
|
||||||
|
</m:mathPr></w:WordDocument>
|
||||||
|
</xml><![endif]--><!--[if gte mso 9]><xml>
|
||||||
|
<w:LatentStyles DefLockedState="false" DefUnhideWhenUsed="false"
|
||||||
|
DefSemiHidden="false" DefQFormat="false" LatentStyleCount="267">
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Normal"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="heading 1"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="heading 2"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="heading 3"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 4"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 5"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 6"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 7"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 8"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 9"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="caption"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Title"/>
|
||||||
|
<w:LsdException Locked="false" Priority="1" Name="Default Paragraph Font"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Subtitle"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Strong"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Emphasis"/>
|
||||||
|
<w:LsdException Locked="false" Priority="99" Name="No List"/>
|
||||||
|
<w:LsdException Locked="false" Priority="99" SemiHidden="true"
|
||||||
|
Name="Placeholder Text"/>
|
||||||
|
<w:LsdException Locked="false" Priority="1" QFormat="true" Name="No Spacing"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="99" SemiHidden="true" Name="Revision"/>
|
||||||
|
<w:LsdException Locked="false" Priority="34" QFormat="true"
|
||||||
|
Name="List Paragraph"/>
|
||||||
|
<w:LsdException Locked="false" Priority="29" QFormat="true" Name="Quote"/>
|
||||||
|
<w:LsdException Locked="false" Priority="30" QFormat="true"
|
||||||
|
Name="Intense Quote"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="19" QFormat="true"
|
||||||
|
Name="Subtle Emphasis"/>
|
||||||
|
<w:LsdException Locked="false" Priority="21" QFormat="true"
|
||||||
|
Name="Intense Emphasis"/>
|
||||||
|
<w:LsdException Locked="false" Priority="31" QFormat="true"
|
||||||
|
Name="Subtle Reference"/>
|
||||||
|
<w:LsdException Locked="false" Priority="32" QFormat="true"
|
||||||
|
Name="Intense Reference"/>
|
||||||
|
<w:LsdException Locked="false" Priority="33" QFormat="true" Name="Book Title"/>
|
||||||
|
<w:LsdException Locked="false" Priority="37" SemiHidden="true"
|
||||||
|
UnhideWhenUsed="true" Name="Bibliography"/>
|
||||||
|
<w:LsdException Locked="false" Priority="39" SemiHidden="true"
|
||||||
|
UnhideWhenUsed="true" QFormat="true" Name="TOC Heading"/>
|
||||||
|
</w:LatentStyles>
|
||||||
|
</xml><![endif]-->
|
||||||
|
|
||||||
|
<style>
|
||||||
|
<!--
|
||||||
|
/* Font Definitions */
|
||||||
|
@font-face
|
||||||
|
{font-family:"Cambria Math";
|
||||||
|
panose-1:2 4 5 3 5 4 6 3 2 4;
|
||||||
|
mso-font-charset:1;
|
||||||
|
mso-generic-font-family:roman;
|
||||||
|
mso-font-format:other;
|
||||||
|
mso-font-pitch:variable;
|
||||||
|
mso-font-signature:0 0 0 0 0 0;}
|
||||||
|
@font-face
|
||||||
|
{font-family:Calibri;
|
||||||
|
panose-1:2 15 5 2 2 2 4 3 2 4;
|
||||||
|
mso-font-charset:0;
|
||||||
|
mso-generic-font-family:swiss;
|
||||||
|
mso-font-pitch:variable;
|
||||||
|
mso-font-signature:-1610611985 1073750139 0 0 159 0;}
|
||||||
|
@font-face
|
||||||
|
{font-family:Tahoma;
|
||||||
|
panose-1:2 11 6 4 3 5 4 4 2 4;
|
||||||
|
mso-font-charset:0;
|
||||||
|
mso-generic-font-family:swiss;
|
||||||
|
mso-font-pitch:variable;
|
||||||
|
mso-font-signature:1627400839 -2147483648 8 0 66047 0;}
|
||||||
|
@font-face
|
||||||
|
{font-family:Verdana;
|
||||||
|
panose-1:2 11 6 4 3 5 4 4 2 4;
|
||||||
|
mso-font-charset:0;
|
||||||
|
mso-generic-font-family:swiss;
|
||||||
|
mso-font-pitch:variable;
|
||||||
|
mso-font-signature:536871559 0 0 0 415 0;}
|
||||||
|
/* Style Definitions */
|
||||||
|
p.MsoNormal, li.MsoNormal, div.MsoNormal
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-parent:"";
|
||||||
|
margin:0in;
|
||||||
|
margin-bottom:.0001pt;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
font-size:12.0pt;
|
||||||
|
font-family:"Times New Roman","serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";}
|
||||||
|
h1
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-link:"Heading 1 Char";
|
||||||
|
mso-margin-top-alt:auto;
|
||||||
|
margin-right:0in;
|
||||||
|
mso-margin-bottom-alt:auto;
|
||||||
|
margin-left:0in;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
mso-outline-level:1;
|
||||||
|
font-size:24.0pt;
|
||||||
|
font-family:"Times New Roman","serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:minor-fareast;
|
||||||
|
font-weight:bold;}
|
||||||
|
h2
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-link:"Heading 2 Char";
|
||||||
|
mso-style-next:Normal;
|
||||||
|
margin-top:12.0pt;
|
||||||
|
margin-right:0in;
|
||||||
|
margin-bottom:3.0pt;
|
||||||
|
margin-left:0in;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
page-break-after:avoid;
|
||||||
|
mso-outline-level:2;
|
||||||
|
font-size:14.0pt;
|
||||||
|
font-family:"Arial","sans-serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:minor-fareast;
|
||||||
|
font-weight:bold;
|
||||||
|
font-style:italic;}
|
||||||
|
h3
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-link:"Heading 3 Char";
|
||||||
|
mso-margin-top-alt:auto;
|
||||||
|
margin-right:0in;
|
||||||
|
mso-margin-bottom-alt:auto;
|
||||||
|
margin-left:0in;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
mso-outline-level:3;
|
||||||
|
font-size:13.5pt;
|
||||||
|
font-family:"Times New Roman","serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:minor-fareast;
|
||||||
|
font-weight:bold;}
|
||||||
|
a:link, span.MsoHyperlink
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
color:blue;
|
||||||
|
text-decoration:underline;
|
||||||
|
text-underline:single;}
|
||||||
|
a:visited, span.MsoHyperlinkFollowed
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
color:blue;
|
||||||
|
text-decoration:underline;
|
||||||
|
text-underline:single;}
|
||||||
|
p
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-margin-top-alt:auto;
|
||||||
|
margin-right:0in;
|
||||||
|
mso-margin-bottom-alt:auto;
|
||||||
|
margin-left:0in;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
font-size:12.0pt;
|
||||||
|
font-family:"Times New Roman","serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";}
|
||||||
|
p.MsoAcetate, li.MsoAcetate, div.MsoAcetate
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-link:"Balloon Text Char";
|
||||||
|
margin:0in;
|
||||||
|
margin-bottom:.0001pt;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
font-size:8.0pt;
|
||||||
|
font-family:"Tahoma","sans-serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";}
|
||||||
|
span.Heading1Char
|
||||||
|
{mso-style-name:"Heading 1 Char";
|
||||||
|
mso-style-unhide:no;
|
||||||
|
mso-style-locked:yes;
|
||||||
|
mso-style-link:"Heading 1";
|
||||||
|
mso-ansi-font-size:14.0pt;
|
||||||
|
mso-bidi-font-size:14.0pt;
|
||||||
|
font-family:"Cambria","serif";
|
||||||
|
mso-ascii-font-family:Cambria;
|
||||||
|
mso-ascii-theme-font:major-latin;
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:major-fareast;
|
||||||
|
mso-hansi-font-family:Cambria;
|
||||||
|
mso-hansi-theme-font:major-latin;
|
||||||
|
mso-bidi-font-family:"Times New Roman";
|
||||||
|
mso-bidi-theme-font:major-bidi;
|
||||||
|
color:#365F91;
|
||||||
|
mso-themecolor:accent1;
|
||||||
|
mso-themeshade:191;
|
||||||
|
font-weight:bold;}
|
||||||
|
span.Heading2Char
|
||||||
|
{mso-style-name:"Heading 2 Char";
|
||||||
|
mso-style-unhide:no;
|
||||||
|
mso-style-locked:yes;
|
||||||
|
mso-style-link:"Heading 2";
|
||||||
|
mso-ansi-font-size:13.0pt;
|
||||||
|
mso-bidi-font-size:13.0pt;
|
||||||
|
font-family:"Cambria","serif";
|
||||||
|
mso-ascii-font-family:Cambria;
|
||||||
|
mso-ascii-theme-font:major-latin;
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:major-fareast;
|
||||||
|
mso-hansi-font-family:Cambria;
|
||||||
|
mso-hansi-theme-font:major-latin;
|
||||||
|
mso-bidi-font-family:"Times New Roman";
|
||||||
|
mso-bidi-theme-font:major-bidi;
|
||||||
|
color:#4F81BD;
|
||||||
|
mso-themecolor:accent1;
|
||||||
|
font-weight:bold;}
|
||||||
|
span.Heading3Char
|
||||||
|
{mso-style-name:"Heading 3 Char";
|
||||||
|
mso-style-unhide:no;
|
||||||
|
mso-style-locked:yes;
|
||||||
|
mso-style-link:"Heading 3";
|
||||||
|
mso-ansi-font-size:12.0pt;
|
||||||
|
mso-bidi-font-size:12.0pt;
|
||||||
|
font-family:"Cambria","serif";
|
||||||
|
mso-ascii-font-family:Cambria;
|
||||||
|
mso-ascii-theme-font:major-latin;
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:major-fareast;
|
||||||
|
mso-hansi-font-family:Cambria;
|
||||||
|
mso-hansi-theme-font:major-latin;
|
||||||
|
mso-bidi-font-family:"Times New Roman";
|
||||||
|
mso-bidi-theme-font:major-bidi;
|
||||||
|
color:#4F81BD;
|
||||||
|
mso-themecolor:accent1;
|
||||||
|
font-weight:bold;}
|
||||||
|
span.BalloonTextChar
|
||||||
|
{mso-style-name:"Balloon Text Char";
|
||||||
|
mso-style-unhide:no;
|
||||||
|
mso-style-locked:yes;
|
||||||
|
mso-style-link:"Balloon Text";
|
||||||
|
mso-ansi-font-size:8.0pt;
|
||||||
|
mso-bidi-font-size:8.0pt;
|
||||||
|
font-family:"Tahoma","sans-serif";
|
||||||
|
mso-ascii-font-family:Tahoma;
|
||||||
|
mso-hansi-font-family:Tahoma;
|
||||||
|
mso-bidi-font-family:Tahoma;}
|
||||||
|
.MsoChpDefault
|
||||||
|
{mso-style-type:export-only;
|
||||||
|
mso-default-props:yes;
|
||||||
|
font-size:10.0pt;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
mso-bidi-font-size:10.0pt;}
|
||||||
|
@page WordSection1
|
||||||
|
{size:8.5in 11.0in;
|
||||||
|
margin:1.0in 1.25in 1.0in 1.25in;
|
||||||
|
mso-header-margin:.5in;
|
||||||
|
mso-footer-margin:.5in;
|
||||||
|
mso-paper-source:0;}
|
||||||
|
div.WordSection1
|
||||||
|
{page:WordSection1;}
|
||||||
|
/* List Definitions */
|
||||||
|
@list l0
|
||||||
|
{mso-list-id:62067358;
|
||||||
|
mso-list-template-ids:-174943062;}
|
||||||
|
@list l0:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l0:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1
|
||||||
|
{mso-list-id:128015942;
|
||||||
|
mso-list-template-ids:-90681214;}
|
||||||
|
@list l1:level1
|
||||||
|
{mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2
|
||||||
|
{mso-list-id:216556000;
|
||||||
|
mso-list-template-ids:925924412;}
|
||||||
|
@list l2:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l2:level2
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l2:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3
|
||||||
|
{mso-list-id:562446694;
|
||||||
|
mso-list-template-ids:913898366;}
|
||||||
|
@list l3:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l3:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4
|
||||||
|
{mso-list-id:797802132;
|
||||||
|
mso-list-template-ids:-1971191336;}
|
||||||
|
@list l4:level1
|
||||||
|
{mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5
|
||||||
|
{mso-list-id:907304066;
|
||||||
|
mso-list-template-ids:1969781532;}
|
||||||
|
@list l5:level1
|
||||||
|
{mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6
|
||||||
|
{mso-list-id:1050613616;
|
||||||
|
mso-list-template-ids:-1009886748;}
|
||||||
|
@list l6:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l6:level2
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l6:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7
|
||||||
|
{mso-list-id:1234970193;
|
||||||
|
mso-list-template-ids:2055904002;}
|
||||||
|
@list l7:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l7:level2
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l7:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8
|
||||||
|
{mso-list-id:1846092290;
|
||||||
|
mso-list-template-ids:-768590846;}
|
||||||
|
@list l8:level1
|
||||||
|
{mso-level-start-at:2;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9
|
||||||
|
{mso-list-id:1894656566;
|
||||||
|
mso-list-template-ids:1199983812;}
|
||||||
|
@list l9:level1
|
||||||
|
{mso-level-start-at:2;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
ol
|
||||||
|
{margin-bottom:0in;}
|
||||||
|
ul
|
||||||
|
{margin-bottom:0in;}
|
||||||
|
-->
|
||||||
|
</style><!--[if gte mso 10]>
|
||||||
|
<style>
|
||||||
|
/* Style Definitions */
|
||||||
|
table.MsoNormalTable
|
||||||
|
{mso-style-name:"Table Normal";
|
||||||
|
mso-tstyle-rowband-size:0;
|
||||||
|
mso-tstyle-colband-size:0;
|
||||||
|
mso-style-noshow:yes;
|
||||||
|
mso-style-priority:99;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-parent:"";
|
||||||
|
mso-padding-alt:0in 5.4pt 0in 5.4pt;
|
||||||
|
mso-para-margin:0in;
|
||||||
|
mso-para-margin-bottom:.0001pt;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
font-size:10.0pt;
|
||||||
|
font-family:"Times New Roman","serif";}
|
||||||
|
</style>
|
||||||
|
<![endif]--><!--[if gte mso 9]><xml>
|
||||||
|
<o:shapedefaults v:ext="edit" spidmax="7170"/>
|
||||||
|
</xml><![endif]--><!--[if gte mso 9]><xml>
|
||||||
|
<o:shapelayout v:ext="edit">
|
||||||
|
<o:idmap v:ext="edit" data="1"/>
|
||||||
|
</o:shapelayout></xml><![endif]--></head>
|
||||||
|
<body style="" lang="EN-US" link="blue" vlink="blue">
|
||||||
|
|
||||||
|
<div class="WordSection1">
|
||||||
|
|
||||||
|
<p class="MsoNormal"><span style="font-family: "Arial","sans-serif";"><o:p> </o:p></span></p>
|
||||||
|
|
||||||
|
<div align="center">
|
||||||
|
|
||||||
|
<table class="MsoNormalTable" style="width: 675pt;" border="0" cellpadding="0" cellspacing="0" width="900">
|
||||||
|
<tbody><tr style="">
|
||||||
|
<td style="padding: 0in;" valign="top">
|
||||||
|
<table class="MsoNormalTable" style="width: 675pt;" border="0" cellpadding="0" cellspacing="0" width="900">
|
||||||
|
<tbody><tr style="">
|
||||||
|
<td style="padding: 0in 5.4pt;" valign="top">
|
||||||
|
<p class="MsoNormal"><span style="font-size: 8pt; font-family: "Arial","sans-serif"; color: blue;"><a href="../../Release_Notes.html">Back to Release page</a></span><span style="font-size: 10pt;"><o:p></o:p></span></p>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr style="">
|
||||||
|
<td style="padding: 1.5pt;">
|
||||||
|
<h1 style="margin-bottom: 0.25in; text-align: center;" align="center"><span style="font-size: 20pt; font-family: "Verdana","sans-serif"; color: rgb(51, 102, 255);">Release Notes for STM32F105/7xx and STM32F2xx USB Device Library</span><span style="font-size: 20pt; font-family: "Verdana","sans-serif";"><o:p></o:p></span></h1>
|
||||||
|
<p class="MsoNormal" style="text-align: center;" align="center"><span style="font-size: 10pt; font-family: "Arial","sans-serif"; color: black;">Copyright
|
||||||
|
2011 STMicroelectronics</span><span style="color: black;"><u1:p></u1:p><o:p></o:p></span></p>
|
||||||
|
<p class="MsoNormal" style="text-align: center;" align="center"><span style="font-size: 10pt; font-family: "Arial","sans-serif"; color: black;"><img id="_x0000_i1026" src="../../_htmresc/logo.bmp" border="0" height="65" width="86"></span><span style="font-size: 10pt;"><o:p></o:p></span></p>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody></table>
|
||||||
|
<p class="MsoNormal"><span style="font-family: "Arial","sans-serif"; display: none;"><o:p> </o:p></span></p>
|
||||||
|
<table class="MsoNormalTable" style="width: 675pt;" border="0" cellpadding="0" width="900">
|
||||||
|
<tbody><tr style="">
|
||||||
|
<td style="padding: 0in;" valign="top">
|
||||||
|
<h2 style="background: rgb(51, 102, 255) none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial;"><span style="font-size: 12pt; color: white;">Contents<o:p></o:p></span></h2>
|
||||||
|
<ol style="margin-top: 0in;" start="1" type="1">
|
||||||
|
<li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: "Verdana","sans-serif";"><a href="#History">STM32F105/7xx and STM32F2xx USB Device Library update History</a><o:p></o:p></span></li>
|
||||||
|
<li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: "Verdana","sans-serif";"><a href="#License">License</a><o:p></o:p></span></li>
|
||||||
|
</ol>
|
||||||
|
<h2 style="background: rgb(51, 102, 255) none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial;"><a name="History"></a><span style="font-size: 12pt; color: white;">STM32F105/7xx and STM32F2xx USB Device Library update History</span></h2><h3 style="background: rgb(51, 102, 255) none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial; margin-right: 500pt; width: 171px;"><span style="font-size: 10pt; font-family: Arial; color: white;">V1.0.0 / 22-July-2011<o:p></o:p></span></h3><p class="MsoNormal" style="margin: 4.5pt 0cm 4.5pt 18pt;"><b style=""><u><span style="font-size: 10pt; font-family: Verdana; color: black;">Main
|
||||||
|
Changes<o:p></o:p></span></u></b></p>
|
||||||
|
<ul style="margin-top: 0cm;" type="square"><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">First official version for <span style="font-weight: bold; font-style: italic;">STM32F105/7xx</span> and <span style="font-weight: bold; font-style: italic;">STM32F2xx</span> devices</span></li></ul><span style="font-size: 10pt; font-family: Verdana;"></span><br><span style="font-size: 10pt; font-family: "Verdana","sans-serif";"></span>
|
||||||
|
<h2 style="background: rgb(51, 102, 255) none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial;"><a name="License"></a><span style="font-size: 12pt; color: white;">License<o:p></o:p></span></h2>
|
||||||
|
<p class="MsoNormal"><span style="font-size: 10pt; font-family: Verdana; color: black;">The use of this STM32 software is governed by the terms and conditions of the License Agreement </span><span style="font-size: 10pt; font-family: Verdana; color: black;"><span style="font-weight: bold; font-style: italic;">"MCD-ST Liberty SW License Agreement 20Jul2011 v0.1.pdf"</span> </span><span style="font-size: 10pt; font-family: Verdana; color: black;">available in the root of this package.</span><span style="color: black;"><o:p> </o:p></span></p>
|
||||||
|
<div class="MsoNormal" style="text-align: center;" align="center"><span style="color: black;">
|
||||||
|
<hr align="center" size="2" width="100%">
|
||||||
|
</span></div>
|
||||||
|
<p class="MsoNormal" style="margin: 4.5pt 0in 4.5pt 0.25in; text-align: center;" align="center"><span style="font-size: 10pt; font-family: "Verdana","sans-serif"; color: black;">For
|
||||||
|
complete documentation on </span><span style="font-size: 10pt; font-family: "Verdana","sans-serif";">STM32(<span style="color: black;">CORTEX M3) 32-Bit
|
||||||
|
Microcontrollers visit </span><u><span style="color: blue;"><a href="http://www.st.com/stm32" target="_blank">www.st.com/STM32</a></span></u></span><span style="color: black;"><o:p></o:p></span></p>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody></table>
|
||||||
|
<p class="MsoNormal"><span style="font-size: 10pt;"><o:p></o:p></span></p>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody></table>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<p class="MsoNormal"><o:p> </o:p></p>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</body></html>
|
@ -0,0 +1,941 @@
|
|||||||
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
||||||
|
<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head>
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=windows-1252">
|
||||||
|
<link rel="File-List" href="Release_Notes_for_STM32F2xx_StdPeriph_Driver_files/filelist.xml">
|
||||||
|
<link rel="Edit-Time-Data" href="Release_Notes_for_STM32F2xx_StdPeriph_Driver_files/editdata.mso"><!--[if !mso]>
|
||||||
|
<style>
|
||||||
|
v\:* {behavior:url(#default#VML);}
|
||||||
|
o\:* {behavior:url(#default#VML);}
|
||||||
|
w\:* {behavior:url(#default#VML);}
|
||||||
|
.shape {behavior:url(#default#VML);}
|
||||||
|
</style>
|
||||||
|
<![endif]-->
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<title>Release Notes for STM32F105/7xx and STM32F2xx USB OTG Driver</title><!--[if gte mso 9]><xml>
|
||||||
|
<o:DocumentProperties>
|
||||||
|
<o:Author>STMicroelectronics</o:Author>
|
||||||
|
<o:LastAuthor>Raouf Hosni</o:LastAuthor>
|
||||||
|
<o:Revision>39</o:Revision>
|
||||||
|
<o:TotalTime>137</o:TotalTime>
|
||||||
|
<o:Created>2009-02-27T19:26:00Z</o:Created>
|
||||||
|
<o:LastSaved>2010-10-15T11:07:00Z</o:LastSaved>
|
||||||
|
<o:Pages>3</o:Pages>
|
||||||
|
<o:Words>973</o:Words>
|
||||||
|
<o:Characters>5548</o:Characters>
|
||||||
|
<o:Company>STMicroelectronics</o:Company>
|
||||||
|
<o:Lines>46</o:Lines>
|
||||||
|
<o:Paragraphs>13</o:Paragraphs>
|
||||||
|
<o:CharactersWithSpaces>6508</o:CharactersWithSpaces>
|
||||||
|
<o:Version>12.00</o:Version>
|
||||||
|
</o:DocumentProperties>
|
||||||
|
</xml><![endif]--><link rel="themeData" href="Release_Notes_for_STM32F2xx_StdPeriph_Driver_files/themedata.thmx">
|
||||||
|
<link rel="colorSchemeMapping" href="Release_Notes_for_STM32F2xx_StdPeriph_Driver_files/colorschememapping.xml"><!--[if gte mso 9]><xml>
|
||||||
|
<w:WordDocument>
|
||||||
|
<w:Zoom>110</w:Zoom>
|
||||||
|
<w:TrackMoves>false</w:TrackMoves>
|
||||||
|
<w:TrackFormatting/>
|
||||||
|
<w:ValidateAgainstSchemas/>
|
||||||
|
<w:SaveIfXMLInvalid>false</w:SaveIfXMLInvalid>
|
||||||
|
<w:IgnoreMixedContent>false</w:IgnoreMixedContent>
|
||||||
|
<w:AlwaysShowPlaceholderText>false</w:AlwaysShowPlaceholderText>
|
||||||
|
<w:DoNotPromoteQF/>
|
||||||
|
<w:LidThemeOther>EN-US</w:LidThemeOther>
|
||||||
|
<w:LidThemeAsian>X-NONE</w:LidThemeAsian>
|
||||||
|
<w:LidThemeComplexScript>X-NONE</w:LidThemeComplexScript>
|
||||||
|
<w:Compatibility>
|
||||||
|
<w:BreakWrappedTables/>
|
||||||
|
<w:SnapToGridInCell/>
|
||||||
|
<w:WrapTextWithPunct/>
|
||||||
|
<w:UseAsianBreakRules/>
|
||||||
|
<w:DontGrowAutofit/>
|
||||||
|
<w:SplitPgBreakAndParaMark/>
|
||||||
|
<w:DontVertAlignCellWithSp/>
|
||||||
|
<w:DontBreakConstrainedForcedTables/>
|
||||||
|
<w:DontVertAlignInTxbx/>
|
||||||
|
<w:Word11KerningPairs/>
|
||||||
|
<w:CachedColBalance/>
|
||||||
|
</w:Compatibility>
|
||||||
|
<w:BrowserLevel>MicrosoftInternetExplorer4</w:BrowserLevel>
|
||||||
|
<m:mathPr>
|
||||||
|
<m:mathFont m:val="Cambria Math"/>
|
||||||
|
<m:brkBin m:val="before"/>
|
||||||
|
<m:brkBinSub m:val="--"/>
|
||||||
|
<m:smallFrac m:val="off"/>
|
||||||
|
<m:dispDef/>
|
||||||
|
<m:lMargin m:val="0"/>
|
||||||
|
<m:rMargin m:val="0"/>
|
||||||
|
<m:defJc m:val="centerGroup"/>
|
||||||
|
<m:wrapIndent m:val="1440"/>
|
||||||
|
<m:intLim m:val="subSup"/>
|
||||||
|
<m:naryLim m:val="undOvr"/>
|
||||||
|
</m:mathPr></w:WordDocument>
|
||||||
|
</xml><![endif]--><!--[if gte mso 9]><xml>
|
||||||
|
<w:LatentStyles DefLockedState="false" DefUnhideWhenUsed="false"
|
||||||
|
DefSemiHidden="false" DefQFormat="false" LatentStyleCount="267">
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Normal"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="heading 1"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="heading 2"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="heading 3"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 4"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 5"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 6"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 7"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 8"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="heading 9"/>
|
||||||
|
<w:LsdException Locked="false" SemiHidden="true" UnhideWhenUsed="true"
|
||||||
|
QFormat="true" Name="caption"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Title"/>
|
||||||
|
<w:LsdException Locked="false" Priority="1" Name="Default Paragraph Font"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Subtitle"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Strong"/>
|
||||||
|
<w:LsdException Locked="false" QFormat="true" Name="Emphasis"/>
|
||||||
|
<w:LsdException Locked="false" Priority="99" Name="No List"/>
|
||||||
|
<w:LsdException Locked="false" Priority="99" SemiHidden="true"
|
||||||
|
Name="Placeholder Text"/>
|
||||||
|
<w:LsdException Locked="false" Priority="1" QFormat="true" Name="No Spacing"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="99" SemiHidden="true" Name="Revision"/>
|
||||||
|
<w:LsdException Locked="false" Priority="34" QFormat="true"
|
||||||
|
Name="List Paragraph"/>
|
||||||
|
<w:LsdException Locked="false" Priority="29" QFormat="true" Name="Quote"/>
|
||||||
|
<w:LsdException Locked="false" Priority="30" QFormat="true"
|
||||||
|
Name="Intense Quote"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 1"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 2"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 3"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 4"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 5"/>
|
||||||
|
<w:LsdException Locked="false" Priority="60" Name="Light Shading Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="61" Name="Light List Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="62" Name="Light Grid Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="63" Name="Medium Shading 1 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="64" Name="Medium Shading 2 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="65" Name="Medium List 1 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="66" Name="Medium List 2 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="67" Name="Medium Grid 1 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="68" Name="Medium Grid 2 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="69" Name="Medium Grid 3 Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="70" Name="Dark List Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="71" Name="Colorful Shading Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="72" Name="Colorful List Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="73" Name="Colorful Grid Accent 6"/>
|
||||||
|
<w:LsdException Locked="false" Priority="19" QFormat="true"
|
||||||
|
Name="Subtle Emphasis"/>
|
||||||
|
<w:LsdException Locked="false" Priority="21" QFormat="true"
|
||||||
|
Name="Intense Emphasis"/>
|
||||||
|
<w:LsdException Locked="false" Priority="31" QFormat="true"
|
||||||
|
Name="Subtle Reference"/>
|
||||||
|
<w:LsdException Locked="false" Priority="32" QFormat="true"
|
||||||
|
Name="Intense Reference"/>
|
||||||
|
<w:LsdException Locked="false" Priority="33" QFormat="true" Name="Book Title"/>
|
||||||
|
<w:LsdException Locked="false" Priority="37" SemiHidden="true"
|
||||||
|
UnhideWhenUsed="true" Name="Bibliography"/>
|
||||||
|
<w:LsdException Locked="false" Priority="39" SemiHidden="true"
|
||||||
|
UnhideWhenUsed="true" QFormat="true" Name="TOC Heading"/>
|
||||||
|
</w:LatentStyles>
|
||||||
|
</xml><![endif]-->
|
||||||
|
|
||||||
|
<style>
|
||||||
|
<!--
|
||||||
|
/* Font Definitions */
|
||||||
|
@font-face
|
||||||
|
{font-family:"Cambria Math";
|
||||||
|
panose-1:2 4 5 3 5 4 6 3 2 4;
|
||||||
|
mso-font-charset:1;
|
||||||
|
mso-generic-font-family:roman;
|
||||||
|
mso-font-format:other;
|
||||||
|
mso-font-pitch:variable;
|
||||||
|
mso-font-signature:0 0 0 0 0 0;}
|
||||||
|
@font-face
|
||||||
|
{font-family:Calibri;
|
||||||
|
panose-1:2 15 5 2 2 2 4 3 2 4;
|
||||||
|
mso-font-charset:0;
|
||||||
|
mso-generic-font-family:swiss;
|
||||||
|
mso-font-pitch:variable;
|
||||||
|
mso-font-signature:-1610611985 1073750139 0 0 159 0;}
|
||||||
|
@font-face
|
||||||
|
{font-family:Tahoma;
|
||||||
|
panose-1:2 11 6 4 3 5 4 4 2 4;
|
||||||
|
mso-font-charset:0;
|
||||||
|
mso-generic-font-family:swiss;
|
||||||
|
mso-font-pitch:variable;
|
||||||
|
mso-font-signature:1627400839 -2147483648 8 0 66047 0;}
|
||||||
|
@font-face
|
||||||
|
{font-family:Verdana;
|
||||||
|
panose-1:2 11 6 4 3 5 4 4 2 4;
|
||||||
|
mso-font-charset:0;
|
||||||
|
mso-generic-font-family:swiss;
|
||||||
|
mso-font-pitch:variable;
|
||||||
|
mso-font-signature:536871559 0 0 0 415 0;}
|
||||||
|
/* Style Definitions */
|
||||||
|
p.MsoNormal, li.MsoNormal, div.MsoNormal
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-parent:"";
|
||||||
|
margin:0in;
|
||||||
|
margin-bottom:.0001pt;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
font-size:12.0pt;
|
||||||
|
font-family:"Times New Roman","serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";}
|
||||||
|
h1
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-link:"Heading 1 Char";
|
||||||
|
mso-margin-top-alt:auto;
|
||||||
|
margin-right:0in;
|
||||||
|
mso-margin-bottom-alt:auto;
|
||||||
|
margin-left:0in;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
mso-outline-level:1;
|
||||||
|
font-size:24.0pt;
|
||||||
|
font-family:"Times New Roman","serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:minor-fareast;
|
||||||
|
font-weight:bold;}
|
||||||
|
h2
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-link:"Heading 2 Char";
|
||||||
|
mso-style-next:Normal;
|
||||||
|
margin-top:12.0pt;
|
||||||
|
margin-right:0in;
|
||||||
|
margin-bottom:3.0pt;
|
||||||
|
margin-left:0in;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
page-break-after:avoid;
|
||||||
|
mso-outline-level:2;
|
||||||
|
font-size:14.0pt;
|
||||||
|
font-family:"Arial","sans-serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:minor-fareast;
|
||||||
|
font-weight:bold;
|
||||||
|
font-style:italic;}
|
||||||
|
h3
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-link:"Heading 3 Char";
|
||||||
|
mso-margin-top-alt:auto;
|
||||||
|
margin-right:0in;
|
||||||
|
mso-margin-bottom-alt:auto;
|
||||||
|
margin-left:0in;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
mso-outline-level:3;
|
||||||
|
font-size:13.5pt;
|
||||||
|
font-family:"Times New Roman","serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:minor-fareast;
|
||||||
|
font-weight:bold;}
|
||||||
|
a:link, span.MsoHyperlink
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
color:blue;
|
||||||
|
text-decoration:underline;
|
||||||
|
text-underline:single;}
|
||||||
|
a:visited, span.MsoHyperlinkFollowed
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
color:blue;
|
||||||
|
text-decoration:underline;
|
||||||
|
text-underline:single;}
|
||||||
|
p
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-margin-top-alt:auto;
|
||||||
|
margin-right:0in;
|
||||||
|
mso-margin-bottom-alt:auto;
|
||||||
|
margin-left:0in;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
font-size:12.0pt;
|
||||||
|
font-family:"Times New Roman","serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";}
|
||||||
|
p.MsoAcetate, li.MsoAcetate, div.MsoAcetate
|
||||||
|
{mso-style-unhide:no;
|
||||||
|
mso-style-link:"Balloon Text Char";
|
||||||
|
margin:0in;
|
||||||
|
margin-bottom:.0001pt;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
font-size:8.0pt;
|
||||||
|
font-family:"Tahoma","sans-serif";
|
||||||
|
mso-fareast-font-family:"Times New Roman";}
|
||||||
|
span.Heading1Char
|
||||||
|
{mso-style-name:"Heading 1 Char";
|
||||||
|
mso-style-unhide:no;
|
||||||
|
mso-style-locked:yes;
|
||||||
|
mso-style-link:"Heading 1";
|
||||||
|
mso-ansi-font-size:14.0pt;
|
||||||
|
mso-bidi-font-size:14.0pt;
|
||||||
|
font-family:"Cambria","serif";
|
||||||
|
mso-ascii-font-family:Cambria;
|
||||||
|
mso-ascii-theme-font:major-latin;
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:major-fareast;
|
||||||
|
mso-hansi-font-family:Cambria;
|
||||||
|
mso-hansi-theme-font:major-latin;
|
||||||
|
mso-bidi-font-family:"Times New Roman";
|
||||||
|
mso-bidi-theme-font:major-bidi;
|
||||||
|
color:#365F91;
|
||||||
|
mso-themecolor:accent1;
|
||||||
|
mso-themeshade:191;
|
||||||
|
font-weight:bold;}
|
||||||
|
span.Heading2Char
|
||||||
|
{mso-style-name:"Heading 2 Char";
|
||||||
|
mso-style-unhide:no;
|
||||||
|
mso-style-locked:yes;
|
||||||
|
mso-style-link:"Heading 2";
|
||||||
|
mso-ansi-font-size:13.0pt;
|
||||||
|
mso-bidi-font-size:13.0pt;
|
||||||
|
font-family:"Cambria","serif";
|
||||||
|
mso-ascii-font-family:Cambria;
|
||||||
|
mso-ascii-theme-font:major-latin;
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:major-fareast;
|
||||||
|
mso-hansi-font-family:Cambria;
|
||||||
|
mso-hansi-theme-font:major-latin;
|
||||||
|
mso-bidi-font-family:"Times New Roman";
|
||||||
|
mso-bidi-theme-font:major-bidi;
|
||||||
|
color:#4F81BD;
|
||||||
|
mso-themecolor:accent1;
|
||||||
|
font-weight:bold;}
|
||||||
|
span.Heading3Char
|
||||||
|
{mso-style-name:"Heading 3 Char";
|
||||||
|
mso-style-unhide:no;
|
||||||
|
mso-style-locked:yes;
|
||||||
|
mso-style-link:"Heading 3";
|
||||||
|
mso-ansi-font-size:12.0pt;
|
||||||
|
mso-bidi-font-size:12.0pt;
|
||||||
|
font-family:"Cambria","serif";
|
||||||
|
mso-ascii-font-family:Cambria;
|
||||||
|
mso-ascii-theme-font:major-latin;
|
||||||
|
mso-fareast-font-family:"Times New Roman";
|
||||||
|
mso-fareast-theme-font:major-fareast;
|
||||||
|
mso-hansi-font-family:Cambria;
|
||||||
|
mso-hansi-theme-font:major-latin;
|
||||||
|
mso-bidi-font-family:"Times New Roman";
|
||||||
|
mso-bidi-theme-font:major-bidi;
|
||||||
|
color:#4F81BD;
|
||||||
|
mso-themecolor:accent1;
|
||||||
|
font-weight:bold;}
|
||||||
|
span.BalloonTextChar
|
||||||
|
{mso-style-name:"Balloon Text Char";
|
||||||
|
mso-style-unhide:no;
|
||||||
|
mso-style-locked:yes;
|
||||||
|
mso-style-link:"Balloon Text";
|
||||||
|
mso-ansi-font-size:8.0pt;
|
||||||
|
mso-bidi-font-size:8.0pt;
|
||||||
|
font-family:"Tahoma","sans-serif";
|
||||||
|
mso-ascii-font-family:Tahoma;
|
||||||
|
mso-hansi-font-family:Tahoma;
|
||||||
|
mso-bidi-font-family:Tahoma;}
|
||||||
|
.MsoChpDefault
|
||||||
|
{mso-style-type:export-only;
|
||||||
|
mso-default-props:yes;
|
||||||
|
font-size:10.0pt;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
mso-bidi-font-size:10.0pt;}
|
||||||
|
@page WordSection1
|
||||||
|
{size:8.5in 11.0in;
|
||||||
|
margin:1.0in 1.25in 1.0in 1.25in;
|
||||||
|
mso-header-margin:.5in;
|
||||||
|
mso-footer-margin:.5in;
|
||||||
|
mso-paper-source:0;}
|
||||||
|
div.WordSection1
|
||||||
|
{page:WordSection1;}
|
||||||
|
/* List Definitions */
|
||||||
|
@list l0
|
||||||
|
{mso-list-id:62067358;
|
||||||
|
mso-list-template-ids:-174943062;}
|
||||||
|
@list l0:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l0:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l0:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1
|
||||||
|
{mso-list-id:128015942;
|
||||||
|
mso-list-template-ids:-90681214;}
|
||||||
|
@list l1:level1
|
||||||
|
{mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l1:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2
|
||||||
|
{mso-list-id:216556000;
|
||||||
|
mso-list-template-ids:925924412;}
|
||||||
|
@list l2:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l2:level2
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l2:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l2:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3
|
||||||
|
{mso-list-id:562446694;
|
||||||
|
mso-list-template-ids:913898366;}
|
||||||
|
@list l3:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l3:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l3:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4
|
||||||
|
{mso-list-id:797802132;
|
||||||
|
mso-list-template-ids:-1971191336;}
|
||||||
|
@list l4:level1
|
||||||
|
{mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l4:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5
|
||||||
|
{mso-list-id:907304066;
|
||||||
|
mso-list-template-ids:1969781532;}
|
||||||
|
@list l5:level1
|
||||||
|
{mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l5:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6
|
||||||
|
{mso-list-id:1050613616;
|
||||||
|
mso-list-template-ids:-1009886748;}
|
||||||
|
@list l6:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l6:level2
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l6:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l6:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7
|
||||||
|
{mso-list-id:1234970193;
|
||||||
|
mso-list-template-ids:2055904002;}
|
||||||
|
@list l7:level1
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l7:level2
|
||||||
|
{mso-level-number-format:bullet;
|
||||||
|
mso-level-text:\F0B7;
|
||||||
|
mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;
|
||||||
|
mso-ansi-font-size:10.0pt;
|
||||||
|
font-family:Symbol;}
|
||||||
|
@list l7:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l7:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8
|
||||||
|
{mso-list-id:1846092290;
|
||||||
|
mso-list-template-ids:-768590846;}
|
||||||
|
@list l8:level1
|
||||||
|
{mso-level-start-at:2;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l8:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9
|
||||||
|
{mso-list-id:1894656566;
|
||||||
|
mso-list-template-ids:1199983812;}
|
||||||
|
@list l9:level1
|
||||||
|
{mso-level-start-at:2;
|
||||||
|
mso-level-tab-stop:.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level2
|
||||||
|
{mso-level-tab-stop:1.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level3
|
||||||
|
{mso-level-tab-stop:1.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level4
|
||||||
|
{mso-level-tab-stop:2.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level5
|
||||||
|
{mso-level-tab-stop:2.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level6
|
||||||
|
{mso-level-tab-stop:3.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level7
|
||||||
|
{mso-level-tab-stop:3.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level8
|
||||||
|
{mso-level-tab-stop:4.0in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
@list l9:level9
|
||||||
|
{mso-level-tab-stop:4.5in;
|
||||||
|
mso-level-number-position:left;
|
||||||
|
text-indent:-.25in;}
|
||||||
|
ol
|
||||||
|
{margin-bottom:0in;}
|
||||||
|
ul
|
||||||
|
{margin-bottom:0in;}
|
||||||
|
-->
|
||||||
|
</style><!--[if gte mso 10]>
|
||||||
|
<style>
|
||||||
|
/* Style Definitions */
|
||||||
|
table.MsoNormalTable
|
||||||
|
{mso-style-name:"Table Normal";
|
||||||
|
mso-tstyle-rowband-size:0;
|
||||||
|
mso-tstyle-colband-size:0;
|
||||||
|
mso-style-noshow:yes;
|
||||||
|
mso-style-priority:99;
|
||||||
|
mso-style-qformat:yes;
|
||||||
|
mso-style-parent:"";
|
||||||
|
mso-padding-alt:0in 5.4pt 0in 5.4pt;
|
||||||
|
mso-para-margin:0in;
|
||||||
|
mso-para-margin-bottom:.0001pt;
|
||||||
|
mso-pagination:widow-orphan;
|
||||||
|
font-size:10.0pt;
|
||||||
|
font-family:"Times New Roman","serif";}
|
||||||
|
</style>
|
||||||
|
<![endif]--><!--[if gte mso 9]><xml>
|
||||||
|
<o:shapedefaults v:ext="edit" spidmax="7170"/>
|
||||||
|
</xml><![endif]--><!--[if gte mso 9]><xml>
|
||||||
|
<o:shapelayout v:ext="edit">
|
||||||
|
<o:idmap v:ext="edit" data="1"/>
|
||||||
|
</o:shapelayout></xml><![endif]--></head>
|
||||||
|
<body style="" lang="EN-US" link="blue" vlink="blue">
|
||||||
|
|
||||||
|
<div class="WordSection1">
|
||||||
|
|
||||||
|
<p class="MsoNormal"><span style="font-family: "Arial","sans-serif";"><o:p> </o:p></span></p>
|
||||||
|
|
||||||
|
<div align="center">
|
||||||
|
|
||||||
|
<table class="MsoNormalTable" style="width: 675pt;" border="0" cellpadding="0" cellspacing="0" width="900">
|
||||||
|
<tbody><tr style="">
|
||||||
|
<td style="padding: 0in;" valign="top">
|
||||||
|
<table class="MsoNormalTable" style="width: 675pt;" border="0" cellpadding="0" cellspacing="0" width="900">
|
||||||
|
<tbody><tr style="">
|
||||||
|
<td style="padding: 0in 5.4pt;" valign="top">
|
||||||
|
<p class="MsoNormal"><span style="font-size: 8pt; font-family: "Arial","sans-serif"; color: blue;"><a href="../../Release_Notes.html">Back to Release page</a></span><span style="font-size: 10pt;"><o:p></o:p></span></p>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr style="">
|
||||||
|
<td style="padding: 1.5pt;">
|
||||||
|
<h1 style="margin-bottom: 0.25in; text-align: center;" align="center"><span style="font-size: 20pt; font-family: "Verdana","sans-serif"; color: rgb(51, 102, 255);">Release Notes for STM32F105/7xx and STM32F2xx USB OTG Driver</span><span style="font-size: 20pt; font-family: "Verdana","sans-serif";"><o:p></o:p></span></h1>
|
||||||
|
<p class="MsoNormal" style="text-align: center;" align="center"><span style="font-size: 10pt; font-family: "Arial","sans-serif"; color: black;">Copyright
|
||||||
|
2011 STMicroelectronics</span><span style="color: black;"><u1:p></u1:p><o:p></o:p></span></p>
|
||||||
|
<p class="MsoNormal" style="text-align: center;" align="center"><span style="font-size: 10pt; font-family: "Arial","sans-serif"; color: black;"><img id="_x0000_i1026" src="../../_htmresc/logo.bmp" border="0" height="65" width="86"></span><span style="font-size: 10pt;"><o:p></o:p></span></p>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody></table>
|
||||||
|
<p class="MsoNormal"><span style="font-family: "Arial","sans-serif"; display: none;"><o:p> </o:p></span></p>
|
||||||
|
<table class="MsoNormalTable" style="width: 675pt;" border="0" cellpadding="0" width="900">
|
||||||
|
<tbody><tr style="">
|
||||||
|
<td style="padding: 0in;" valign="top">
|
||||||
|
<h2 style="background: rgb(51, 102, 255) none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial;"><span style="font-size: 12pt; color: white;">Contents<o:p></o:p></span></h2>
|
||||||
|
<ol style="margin-top: 0in;" start="1" type="1">
|
||||||
|
<li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: "Verdana","sans-serif";"><a href="#History">STM32F105/7xx and STM32F2xx USB OTG Driver update History</a><o:p></o:p></span></li>
|
||||||
|
<li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: "Verdana","sans-serif";"><a href="#License">License</a><o:p></o:p></span></li>
|
||||||
|
</ol>
|
||||||
|
<h2 style="background: rgb(51, 102, 255) none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial;"><a name="History"></a><span style="font-size: 12pt; color: white;">STM32F105/7xx and STM32F2xx USB OTG Driver update History</span></h2><h3 style="background: rgb(51, 102, 255) none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial; margin-right: 500pt; width: 171px;"><span style="font-size: 10pt; font-family: Arial; color: white;">V2.0.0 / 22-July-2011 <o:p></o:p></span></h3><p class="MsoNormal" style="margin: 4.5pt 0cm 4.5pt 18pt;"><b style=""><u><span style="font-size: 10pt; font-family: Verdana; color: black;">Main
|
||||||
|
Changes<o:p></o:p></span></u></b></p>
|
||||||
|
<ul style="margin-top: 0cm;" type="square"><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">Second official version supporting <span style="font-weight: bold; font-style: italic;">STM32F105/7</span> and <span style="font-weight: bold; font-style: italic;">STM32F2xx</span> devices</span></li><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">Rename the Library from "<span style="font-style: italic;">STM32_USB_HOST_Driver</span>" to "<span style="font-style: italic;">STM32_USB_OTG_Driver</span>"</span></li><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">Add support for <span style="font-weight: bold; font-style: italic;">STM32F2xx</span> devices</span><span style="font-size: 10pt; font-family: Verdana;"></span></li><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">Add support for Device and OTG modes</span></li><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">Change HCD layer to support High speed core</span></li><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">Change the Low level driver to support multi core support for Host mode</span></li><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">Add Stop mechanism for Host and Device modes</span></li><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">Change VBUS enabling method, to use the external or the internal VBUS when using the ULPI</span></li></ul><span style="font-size: 10pt; font-family: Verdana;"><br></span><h3 style="background: rgb(51, 102, 255) none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial; margin-right: 500pt; width: 171px;"><span style="font-size: 10pt; font-family: Arial; color: white;">V1.0.0 - 11/29/2010<o:p></o:p></span></h3>
|
||||||
|
<ul style="margin-top: 0cm;" type="square"><li class="MsoNormal" style="color: black; margin-top: 4.5pt; margin-bottom: 4.5pt;"><span style="font-size: 10pt; font-family: Verdana;">Created </span></li></ul><h2 style="background: rgb(51, 102, 255) none repeat scroll 0% 50%; -moz-background-clip: initial; -moz-background-origin: initial; -moz-background-inline-policy: initial;"><a name="License"></a><span style="font-size: 12pt; color: white;">License<o:p></o:p></span></h2>
|
||||||
|
<p class="MsoNormal"><span style="font-size: 10pt; font-family: Verdana; color: black;">The use of this STM32 software is governed by the terms and conditions of the License Agreement </span><span style="font-size: 10pt; font-family: Verdana; color: black;"><span style="font-weight: bold; font-style: italic;">"MCD-ST Liberty SW License Agreement 20Jul2011 v0.1.pdf"</span> </span><span style="font-size: 10pt; font-family: Verdana; color: black;">available in the root of this package.</span><span style="color: black;"><o:p> </o:p></span></p>
|
||||||
|
<div class="MsoNormal" style="text-align: center;" align="center"><span style="color: black;">
|
||||||
|
<hr align="center" size="2" width="100%">
|
||||||
|
</span></div>
|
||||||
|
<p class="MsoNormal" style="margin: 4.5pt 0in 4.5pt 0.25in; text-align: center;" align="center"><span style="font-size: 10pt; font-family: "Verdana","sans-serif"; color: black;">For
|
||||||
|
complete documentation on </span><span style="font-size: 10pt; font-family: "Verdana","sans-serif";">STM32(<span style="color: black;">CORTEX M3) 32-Bit
|
||||||
|
Microcontrollers visit </span><u><span style="color: blue;"><a href="http://www.st.com/stm32" target="_blank">www.st.com/STM32</a></span></u></span><span style="color: black;"><o:p></o:p></span></p>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody></table>
|
||||||
|
<p class="MsoNormal"><span style="font-size: 10pt;"><o:p></o:p></span></p>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody></table>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<p class="MsoNormal"><o:p> </o:p></p>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</body></html>
|
@ -0,0 +1,96 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_bsp.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Specific api's relative to the used hardware platform
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USB_BSP__H__
|
||||||
|
#define __USB_BSP__H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_core.h"
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP
|
||||||
|
* @brief This file is the
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
void BSP_Init(void);
|
||||||
|
|
||||||
|
void USB_OTG_BSP_Init (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void USB_OTG_BSP_uDelay (const uint32_t usec);
|
||||||
|
void USB_OTG_BSP_mDelay (const uint32_t msec);
|
||||||
|
void USB_OTG_BSP_EnableInterrupt (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
#ifdef USE_HOST_MODE
|
||||||
|
void USB_OTG_BSP_ConfigVBUS(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void USB_OTG_BSP_DriveVBUS(USB_OTG_CORE_HANDLE *pdev,uint8_t state);
|
||||||
|
#endif
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#endif //__USB_BSP__H__
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,287 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_conf.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief general low level driver configuration
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USB_CONF__H__
|
||||||
|
#define __USB_CONF__H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "stm32f4xx.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF
|
||||||
|
* @brief USB low level driver configuration file
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* USB Core and PHY interface configuration.
|
||||||
|
Tip: To avoid modifying these defines each time you need to change the USB
|
||||||
|
configuration, you can declare the needed define in your toolchain
|
||||||
|
compiler preprocessor.
|
||||||
|
*/
|
||||||
|
#ifndef USE_USB_OTG_FS
|
||||||
|
#define USE_USB_OTG_FS
|
||||||
|
#endif /* USE_USB_OTG_FS */
|
||||||
|
|
||||||
|
#ifndef USE_USB_OTG_HS
|
||||||
|
//#define USE_USB_OTG_HS
|
||||||
|
#endif /* USE_USB_OTG_HS */
|
||||||
|
|
||||||
|
#ifndef USE_ULPI_PHY
|
||||||
|
//#define USE_ULPI_PHY
|
||||||
|
#endif /* USE_ULPI_PHY */
|
||||||
|
|
||||||
|
#ifndef USE_EMBEDDED_PHY
|
||||||
|
#define USE_EMBEDDED_PHY
|
||||||
|
#endif /* USE_EMBEDDED_PHY */
|
||||||
|
|
||||||
|
#ifndef USE_I2C_PHY
|
||||||
|
//#define USE_I2C_PHY
|
||||||
|
#endif /* USE_I2C_PHY */
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef USE_USB_OTG_FS
|
||||||
|
#define USB_OTG_FS_CORE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef USE_USB_OTG_HS
|
||||||
|
#define USB_OTG_HS_CORE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* FIFO Size Configuration in Device mode
|
||||||
|
*
|
||||||
|
* (i) Receive data FIFO size = RAM for setup packets +
|
||||||
|
* OUT endpoint control information +
|
||||||
|
* data OUT packets + miscellaneous
|
||||||
|
* Space = ONE 32-bits words
|
||||||
|
* --> RAM for setup packets = 10 spaces
|
||||||
|
* (n is the nbr of CTRL EPs the device core supports)
|
||||||
|
* --> OUT EP CTRL info = 1 space
|
||||||
|
* (one space for status information written to the FIFO along with each
|
||||||
|
* received packet)
|
||||||
|
* --> data OUT packets = (Largest Packet Size / 4) + 1 spaces
|
||||||
|
* (MINIMUM to receive packets)
|
||||||
|
* --> OR data OUT packets = at least 2*(Largest Packet Size / 4) + 1 spaces
|
||||||
|
* (if high-bandwidth EP is enabled or multiple isochronous EPs)
|
||||||
|
* --> miscellaneous = 1 space per OUT EP
|
||||||
|
* (one space for transfer complete status information also pushed to the
|
||||||
|
* FIFO with each endpoint's last packet)
|
||||||
|
*
|
||||||
|
* (ii)MINIMUM RAM space required for each IN EP Tx FIFO = MAX packet size for
|
||||||
|
* that particular IN EP. More space allocated in the IN EP Tx FIFO results
|
||||||
|
* in a better performance on the USB and can hide latencies on the AHB.
|
||||||
|
*
|
||||||
|
* (iii) TXn min size = 16 words. (n : Transmit FIFO index)
|
||||||
|
* (iv) When a TxFIFO is not used, the Configuration should be as follows:
|
||||||
|
* case 1 : n > m and Txn is not used (n,m : Transmit FIFO indexes)
|
||||||
|
* --> Txm can use the space allocated for Txn.
|
||||||
|
* case2 : n < m and Txn is not used (n,m : Transmit FIFO indexes)
|
||||||
|
* --> Txn should be configured with the minimum space of 16 words
|
||||||
|
* (v) The FIFO is used optimally when used TxFIFOs are allocated in the top
|
||||||
|
* of the FIFO.Ex: use EP1 and EP2 as IN instead of EP1 and EP3 as IN ones.
|
||||||
|
*******************************************************************************/
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* FIFO Size Configuration in Host mode
|
||||||
|
*
|
||||||
|
* (i) Receive data FIFO size = (Largest Packet Size / 4) + 1 or
|
||||||
|
* 2x (Largest Packet Size / 4) + 1, If a
|
||||||
|
* high-bandwidth channel or multiple isochronous
|
||||||
|
* channels are enabled
|
||||||
|
*
|
||||||
|
* (ii) For the host nonperiodic Transmit FIFO is the largest maximum packet size
|
||||||
|
* for all supported nonperiodic OUT channels. Typically, a space
|
||||||
|
* corresponding to two Largest Packet Size is recommended.
|
||||||
|
*
|
||||||
|
* (iii) The minimum amount of RAM required for Host periodic Transmit FIFO is
|
||||||
|
* the largest maximum packet size for all supported periodic OUT channels.
|
||||||
|
* If there is at least one High Bandwidth Isochronous OUT endpoint,
|
||||||
|
* then the space must be at least two times the maximum packet size for
|
||||||
|
* that channel.
|
||||||
|
*******************************************************************************/
|
||||||
|
|
||||||
|
/****************** USB OTG HS CONFIGURATION **********************************/
|
||||||
|
#ifdef USB_OTG_HS_CORE
|
||||||
|
#define RX_FIFO_HS_SIZE 512
|
||||||
|
#define TX0_FIFO_HS_SIZE 512
|
||||||
|
#define TX1_FIFO_HS_SIZE 512
|
||||||
|
#define TX2_FIFO_HS_SIZE 0
|
||||||
|
#define TX3_FIFO_HS_SIZE 0
|
||||||
|
#define TX4_FIFO_HS_SIZE 0
|
||||||
|
#define TX5_FIFO_HS_SIZE 0
|
||||||
|
#define TXH_NP_HS_FIFOSIZ 96
|
||||||
|
#define TXH_P_HS_FIFOSIZ 96
|
||||||
|
|
||||||
|
//#define USB_OTG_HS_LOW_PWR_MGMT_SUPPORT
|
||||||
|
//#define USB_OTG_HS_SOF_OUTPUT_ENABLED
|
||||||
|
|
||||||
|
//#define USB_OTG_INTERNAL_VBUS_ENABLED
|
||||||
|
#define USB_OTG_EXTERNAL_VBUS_ENABLED
|
||||||
|
|
||||||
|
#ifdef USE_ULPI_PHY
|
||||||
|
#define USB_OTG_ULPI_PHY_ENABLED
|
||||||
|
#endif
|
||||||
|
#ifdef USE_EMBEDDED_PHY
|
||||||
|
#define USB_OTG_EMBEDDED_PHY_ENABLED
|
||||||
|
#endif
|
||||||
|
#ifdef USE_I2C_PHY
|
||||||
|
#define USB_OTG_I2C_PHY_ENABLED
|
||||||
|
#endif
|
||||||
|
#define USB_OTG_HS_INTERNAL_DMA_ENABLED
|
||||||
|
#define USB_OTG_HS_DEDICATED_EP1_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************** USB OTG FS CONFIGURATION **********************************/
|
||||||
|
#ifdef USB_OTG_FS_CORE
|
||||||
|
#define RX_FIFO_FS_SIZE 128
|
||||||
|
#define TX0_FIFO_FS_SIZE 64
|
||||||
|
#define TX1_FIFO_FS_SIZE 128
|
||||||
|
#define TX2_FIFO_FS_SIZE 0
|
||||||
|
#define TX3_FIFO_FS_SIZE 0
|
||||||
|
#define TXH_NP_HS_FIFOSIZ 96
|
||||||
|
#define TXH_P_HS_FIFOSIZ 96
|
||||||
|
|
||||||
|
//#define USB_OTG_FS_LOW_PWR_MGMT_SUPPORT
|
||||||
|
//#define USB_OTG_FS_SOF_OUTPUT_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************** USB OTG MODE CONFIGURATION ********************************/
|
||||||
|
//#define USE_HOST_MODE
|
||||||
|
#define USE_DEVICE_MODE
|
||||||
|
//#define USE_OTG_MODE
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef USB_OTG_FS_CORE
|
||||||
|
#ifndef USB_OTG_HS_CORE
|
||||||
|
#error "USB_OTG_HS_CORE or USB_OTG_FS_CORE should be defined"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef USE_DEVICE_MODE
|
||||||
|
#ifndef USE_HOST_MODE
|
||||||
|
#error "USE_DEVICE_MODE or USE_HOST_MODE should be defined"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef USE_USB_OTG_HS
|
||||||
|
#ifndef USE_USB_OTG_FS
|
||||||
|
#error "USE_USB_OTG_HS or USE_USB_OTG_FS should be defined"
|
||||||
|
#endif
|
||||||
|
#else //USE_USB_OTG_HS
|
||||||
|
#ifndef USE_ULPI_PHY
|
||||||
|
#ifndef USE_EMBEDDED_PHY
|
||||||
|
#ifndef USE_I2C_PHY
|
||||||
|
#error "USE_ULPI_PHY or USE_EMBEDDED_PHY or USE_I2C_PHY should be defined"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************** C Compilers dependant keywords ****************************/
|
||||||
|
/* In HS mode and when the DMA is used, all variables and data structures dealing
|
||||||
|
with the DMA during the transaction process should be 4-bytes aligned */
|
||||||
|
#ifdef USB_OTG_HS_INTERNAL_DMA_ENABLED
|
||||||
|
#if defined (__GNUC__) /* GNU Compiler */
|
||||||
|
#define __ALIGN_END __attribute__ ((aligned (4)))
|
||||||
|
#define __ALIGN_BEGIN
|
||||||
|
#else
|
||||||
|
#define __ALIGN_END
|
||||||
|
#if defined (__CC_ARM) /* ARM Compiler */
|
||||||
|
#define __ALIGN_BEGIN __align(4)
|
||||||
|
#elif defined (__ICCARM__) /* IAR Compiler */
|
||||||
|
#define __ALIGN_BEGIN
|
||||||
|
#elif defined (__TASKING__) /* TASKING Compiler */
|
||||||
|
#define __ALIGN_BEGIN __align(4)
|
||||||
|
#endif /* __CC_ARM */
|
||||||
|
#endif /* __GNUC__ */
|
||||||
|
#else
|
||||||
|
#define __ALIGN_BEGIN
|
||||||
|
#define __ALIGN_END
|
||||||
|
#endif /* USB_OTG_HS_INTERNAL_DMA_ENABLED */
|
||||||
|
|
||||||
|
/* __packed keyword used to decrease the data type alignment to 1-byte */
|
||||||
|
#if defined (__CC_ARM) /* ARM Compiler */
|
||||||
|
#define __packed __packed
|
||||||
|
#elif defined (__ICCARM__) /* IAR Compiler */
|
||||||
|
#define __packed __packed
|
||||||
|
#elif defined ( __GNUC__ ) /* GNU Compiler */
|
||||||
|
#define __packed __attribute__ ((__packed__))
|
||||||
|
#elif defined (__TASKING__) /* TASKING Compiler */
|
||||||
|
#define __packed __unaligned
|
||||||
|
#endif /* __CC_ARM */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CONF_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#endif //__USB_CONF__H__
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,408 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_core.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Header of the Core Layer
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USB_CORE_H__
|
||||||
|
#define __USB_CORE_H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_conf.h"
|
||||||
|
#include "usb_regs.h"
|
||||||
|
#include "usb_defines.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE
|
||||||
|
* @brief usb otg driver core layer
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define USB_OTG_EP0_IDLE 0
|
||||||
|
#define USB_OTG_EP0_SETUP 1
|
||||||
|
#define USB_OTG_EP0_DATA_IN 2
|
||||||
|
#define USB_OTG_EP0_DATA_OUT 3
|
||||||
|
#define USB_OTG_EP0_STATUS_IN 4
|
||||||
|
#define USB_OTG_EP0_STATUS_OUT 5
|
||||||
|
#define USB_OTG_EP0_STALL 6
|
||||||
|
|
||||||
|
#define USB_OTG_EP_TX_DIS 0x0000
|
||||||
|
#define USB_OTG_EP_TX_STALL 0x0010
|
||||||
|
#define USB_OTG_EP_TX_NAK 0x0020
|
||||||
|
#define USB_OTG_EP_TX_VALID 0x0030
|
||||||
|
|
||||||
|
#define USB_OTG_EP_RX_DIS 0x0000
|
||||||
|
#define USB_OTG_EP_RX_STALL 0x1000
|
||||||
|
#define USB_OTG_EP_RX_NAK 0x2000
|
||||||
|
#define USB_OTG_EP_RX_VALID 0x3000
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
#define MAX_DATA_LENGTH 0xFF
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
USB_OTG_OK = 0,
|
||||||
|
USB_OTG_FAIL
|
||||||
|
}USB_OTG_STS;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
HC_IDLE = 0,
|
||||||
|
HC_XFRC,
|
||||||
|
HC_HALTED,
|
||||||
|
HC_NAK,
|
||||||
|
HC_NYET,
|
||||||
|
HC_STALL,
|
||||||
|
HC_XACTERR,
|
||||||
|
HC_BBLERR,
|
||||||
|
HC_DATATGLERR,
|
||||||
|
}HC_STATUS;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
URB_IDLE = 0,
|
||||||
|
URB_DONE,
|
||||||
|
URB_NOTREADY,
|
||||||
|
URB_ERROR,
|
||||||
|
URB_STALL
|
||||||
|
}URB_STATE;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CTRL_START = 0,
|
||||||
|
CTRL_XFRC,
|
||||||
|
CTRL_HALTED,
|
||||||
|
CTRL_NAK,
|
||||||
|
CTRL_STALL,
|
||||||
|
CTRL_XACTERR,
|
||||||
|
CTRL_BBLERR,
|
||||||
|
CTRL_DATATGLERR,
|
||||||
|
CTRL_FAIL
|
||||||
|
}CTRL_STATUS;
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct USB_OTG_hc
|
||||||
|
{
|
||||||
|
uint8_t dev_addr ;
|
||||||
|
uint8_t ep_num;
|
||||||
|
uint8_t ep_is_in;
|
||||||
|
uint8_t speed;
|
||||||
|
uint8_t do_ping;
|
||||||
|
uint8_t ep_type;
|
||||||
|
uint16_t max_packet;
|
||||||
|
uint8_t data_pid;
|
||||||
|
uint8_t *xfer_buff;
|
||||||
|
uint32_t xfer_len;
|
||||||
|
uint32_t xfer_count;
|
||||||
|
uint8_t toggle_in;
|
||||||
|
uint8_t toggle_out;
|
||||||
|
uint32_t dma_addr;
|
||||||
|
}
|
||||||
|
USB_OTG_HC , *PUSB_OTG_HC;
|
||||||
|
|
||||||
|
typedef struct USB_OTG_ep
|
||||||
|
{
|
||||||
|
uint8_t num;
|
||||||
|
uint8_t is_in;
|
||||||
|
uint8_t is_stall;
|
||||||
|
uint8_t type;
|
||||||
|
uint8_t data_pid_start;
|
||||||
|
uint8_t even_odd_frame;
|
||||||
|
uint16_t tx_fifo_num;
|
||||||
|
uint32_t maxpacket;
|
||||||
|
/* transaction level variables*/
|
||||||
|
uint8_t *xfer_buff;
|
||||||
|
uint32_t dma_addr;
|
||||||
|
uint32_t xfer_len;
|
||||||
|
uint32_t xfer_count;
|
||||||
|
/* Transfer level variables*/
|
||||||
|
uint32_t rem_data_len;
|
||||||
|
uint32_t total_data_len;
|
||||||
|
uint32_t ctl_data_len;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_EP , *PUSB_OTG_EP;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct USB_OTG_core_cfg
|
||||||
|
{
|
||||||
|
uint8_t host_channels;
|
||||||
|
uint8_t dev_endpoints;
|
||||||
|
uint8_t speed;
|
||||||
|
uint8_t dma_enable;
|
||||||
|
uint16_t mps;
|
||||||
|
uint16_t TotalFifoSize;
|
||||||
|
uint8_t phy_itface;
|
||||||
|
uint8_t Sof_output;
|
||||||
|
uint8_t low_power;
|
||||||
|
uint8_t coreID;
|
||||||
|
|
||||||
|
}
|
||||||
|
USB_OTG_CORE_CFGS, *PUSB_OTG_CORE_CFGS;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct usb_setup_req {
|
||||||
|
|
||||||
|
uint8_t bmRequest;
|
||||||
|
uint8_t bRequest;
|
||||||
|
uint16_t wValue;
|
||||||
|
uint16_t wIndex;
|
||||||
|
uint16_t wLength;
|
||||||
|
} USB_SETUP_REQ;
|
||||||
|
|
||||||
|
typedef struct _Device_TypeDef
|
||||||
|
{
|
||||||
|
const uint8_t *(*GetDeviceDescriptor)( uint8_t speed , uint16_t *length);
|
||||||
|
const uint8_t *(*GetLangIDStrDescriptor)( uint8_t speed , uint16_t *length);
|
||||||
|
const uint8_t *(*GetManufacturerStrDescriptor)( uint8_t speed , uint16_t *length);
|
||||||
|
const uint8_t *(*GetProductStrDescriptor)( uint8_t speed , uint16_t *length);
|
||||||
|
const uint8_t *(*GetSerialStrDescriptor)( uint8_t speed , uint16_t *length);
|
||||||
|
const uint8_t *(*GetConfigurationStrDescriptor)( uint8_t speed , uint16_t *length);
|
||||||
|
const uint8_t *(*GetInterfaceStrDescriptor)( uint8_t speed , uint16_t *length);
|
||||||
|
} USBD_DEVICE, *pUSBD_DEVICE;
|
||||||
|
|
||||||
|
typedef struct USB_OTG_hPort
|
||||||
|
{
|
||||||
|
void (*Disconnect) (void *phost);
|
||||||
|
void (*Connect) (void *phost);
|
||||||
|
uint8_t ConnStatus;
|
||||||
|
uint8_t DisconnStatus;
|
||||||
|
uint8_t ConnHandled;
|
||||||
|
uint8_t DisconnHandled;
|
||||||
|
} USB_OTG_hPort_TypeDef;
|
||||||
|
|
||||||
|
typedef struct _Device_cb
|
||||||
|
{
|
||||||
|
uint8_t (*Init) (void *pdev , uint8_t cfgidx);
|
||||||
|
uint8_t (*DeInit) (void *pdev , uint8_t cfgidx);
|
||||||
|
/* Control Endpoints*/
|
||||||
|
uint8_t (*Setup) (void *pdev , USB_SETUP_REQ *req);
|
||||||
|
uint8_t (*EP0_TxSent) (void *pdev );
|
||||||
|
uint8_t (*EP0_RxReady) (void *pdev );
|
||||||
|
/* Class Specific Endpoints*/
|
||||||
|
uint8_t (*DataIn) (void *pdev , uint8_t epnum);
|
||||||
|
uint8_t (*DataOut) (void *pdev , uint8_t epnum);
|
||||||
|
uint8_t (*SOF) (void *pdev);
|
||||||
|
uint8_t (*IsoINIncomplete) (void *pdev);
|
||||||
|
uint8_t (*IsoOUTIncomplete) (void *pdev);
|
||||||
|
|
||||||
|
const uint8_t *(*GetConfigDescriptor)( uint8_t speed , uint16_t *length);
|
||||||
|
#ifdef USB_OTG_HS_CORE
|
||||||
|
const uint8_t *(*GetOtherConfigDescriptor)( uint8_t speed , uint16_t *length);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef USB_SUPPORT_USER_STRING_DESC
|
||||||
|
const uint8_t *(*GetUsrStrDescriptor)( uint8_t speed ,uint8_t index, uint16_t *length);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
} USBD_Class_cb_TypeDef;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct _USBD_USR_PROP
|
||||||
|
{
|
||||||
|
void (*Init)(void);
|
||||||
|
void (*DeviceReset)(uint8_t speed);
|
||||||
|
void (*DeviceConfigured)(void);
|
||||||
|
void (*DeviceSuspended)(void);
|
||||||
|
void (*DeviceResumed)(void);
|
||||||
|
|
||||||
|
void (*DeviceConnected)(void);
|
||||||
|
void (*DeviceDisconnected)(void);
|
||||||
|
|
||||||
|
}
|
||||||
|
USBD_Usr_cb_TypeDef;
|
||||||
|
|
||||||
|
typedef struct _DCD
|
||||||
|
{
|
||||||
|
uint8_t device_config;
|
||||||
|
uint8_t device_state;
|
||||||
|
uint8_t device_status;
|
||||||
|
uint8_t device_address;
|
||||||
|
uint32_t DevRemoteWakeup;
|
||||||
|
USB_OTG_EP in_ep [USB_OTG_MAX_TX_FIFOS];
|
||||||
|
USB_OTG_EP out_ep [USB_OTG_MAX_TX_FIFOS];
|
||||||
|
uint8_t setup_packet [8*3];
|
||||||
|
USBD_Class_cb_TypeDef *class_cb;
|
||||||
|
USBD_Usr_cb_TypeDef *usr_cb;
|
||||||
|
USBD_DEVICE *usr_device;
|
||||||
|
const uint8_t *pConfig_descriptor;
|
||||||
|
}
|
||||||
|
DCD_DEV , *DCD_PDEV;
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct _HCD
|
||||||
|
{
|
||||||
|
uint8_t Rx_Buffer [MAX_DATA_LENGTH];
|
||||||
|
__IO uint32_t ConnSts;
|
||||||
|
__IO uint32_t ErrCnt[USB_OTG_MAX_TX_FIFOS];
|
||||||
|
__IO uint32_t XferCnt[USB_OTG_MAX_TX_FIFOS];
|
||||||
|
__IO HC_STATUS HC_Status[USB_OTG_MAX_TX_FIFOS];
|
||||||
|
__IO URB_STATE URB_State[USB_OTG_MAX_TX_FIFOS];
|
||||||
|
USB_OTG_HC hc [USB_OTG_MAX_TX_FIFOS];
|
||||||
|
uint16_t channel [USB_OTG_MAX_TX_FIFOS];
|
||||||
|
USB_OTG_hPort_TypeDef *port_cb;
|
||||||
|
}
|
||||||
|
HCD_DEV , *USB_OTG_USBH_PDEV;
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct _OTG
|
||||||
|
{
|
||||||
|
uint8_t OTG_State;
|
||||||
|
uint8_t OTG_PrevState;
|
||||||
|
uint8_t OTG_Mode;
|
||||||
|
}
|
||||||
|
OTG_DEV , *USB_OTG_USBO_PDEV;
|
||||||
|
|
||||||
|
typedef struct USB_OTG_handle
|
||||||
|
{
|
||||||
|
USB_OTG_CORE_CFGS cfg;
|
||||||
|
USB_OTG_CORE_REGS regs;
|
||||||
|
#ifdef USE_DEVICE_MODE
|
||||||
|
DCD_DEV dev;
|
||||||
|
#endif
|
||||||
|
#ifdef USE_HOST_MODE
|
||||||
|
HCD_DEV host;
|
||||||
|
#endif
|
||||||
|
#ifdef USE_OTG_MODE
|
||||||
|
OTG_DEV otg;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
USB_OTG_CORE_HANDLE , *PUSB_OTG_CORE_HANDLE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
USB_OTG_STS USB_OTG_CoreInit (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
USB_OTG_STS USB_OTG_SelectCore (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_OTG_CORE_ID_TypeDef coreID);
|
||||||
|
USB_OTG_STS USB_OTG_EnableGlobalInt (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
USB_OTG_STS USB_OTG_DisableGlobalInt(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void* USB_OTG_ReadPacket (USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint8_t *dest,
|
||||||
|
uint16_t len);
|
||||||
|
USB_OTG_STS USB_OTG_WritePacket (USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint8_t *src,
|
||||||
|
uint8_t ch_ep_num,
|
||||||
|
uint16_t len);
|
||||||
|
USB_OTG_STS USB_OTG_FlushTxFifo (USB_OTG_CORE_HANDLE *pdev , uint32_t num);
|
||||||
|
USB_OTG_STS USB_OTG_FlushRxFifo (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
uint32_t USB_OTG_ReadCoreItr (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t USB_OTG_ReadOtgItr (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint8_t USB_OTG_IsHostMode (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint8_t USB_OTG_IsDeviceMode (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t USB_OTG_GetMode (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
USB_OTG_STS USB_OTG_PhyInit (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
USB_OTG_STS USB_OTG_SetCurrentMode (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t mode);
|
||||||
|
|
||||||
|
/*********************** HOST APIs ********************************************/
|
||||||
|
#ifdef USE_HOST_MODE
|
||||||
|
USB_OTG_STS USB_OTG_CoreInitHost (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
USB_OTG_STS USB_OTG_EnableHostInt (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
USB_OTG_STS USB_OTG_HC_Init (USB_OTG_CORE_HANDLE *pdev, uint8_t hc_num);
|
||||||
|
USB_OTG_STS USB_OTG_HC_Halt (USB_OTG_CORE_HANDLE *pdev, uint8_t hc_num);
|
||||||
|
USB_OTG_STS USB_OTG_HC_StartXfer (USB_OTG_CORE_HANDLE *pdev, uint8_t hc_num);
|
||||||
|
USB_OTG_STS USB_OTG_HC_DoPing (USB_OTG_CORE_HANDLE *pdev , uint8_t hc_num);
|
||||||
|
uint32_t USB_OTG_ReadHostAllChannels_intr (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t USB_OTG_ResetPort (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t USB_OTG_ReadHPRT0 (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void USB_OTG_DriveVbus (USB_OTG_CORE_HANDLE *pdev, uint8_t state);
|
||||||
|
void USB_OTG_InitFSLSPClkSel (USB_OTG_CORE_HANDLE *pdev ,uint8_t freq);
|
||||||
|
uint8_t USB_OTG_IsEvenFrame (USB_OTG_CORE_HANDLE *pdev) ;
|
||||||
|
void USB_OTG_StopHost (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
#endif
|
||||||
|
/********************* DEVICE APIs ********************************************/
|
||||||
|
#ifdef USE_DEVICE_MODE
|
||||||
|
USB_OTG_STS USB_OTG_CoreInitDev (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
USB_OTG_STS USB_OTG_EnableDevInt (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t USB_OTG_ReadDevAllInEPItr (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
enum USB_OTG_SPEED USB_OTG_GetDeviceSpeed (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
USB_OTG_STS USB_OTG_EP0Activate (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
USB_OTG_STS USB_OTG_EPActivate (USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep);
|
||||||
|
USB_OTG_STS USB_OTG_EPDeactivate(USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep);
|
||||||
|
USB_OTG_STS USB_OTG_EPStartXfer (USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep);
|
||||||
|
USB_OTG_STS USB_OTG_EP0StartXfer(USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep);
|
||||||
|
USB_OTG_STS USB_OTG_EPSetStall (USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep);
|
||||||
|
USB_OTG_STS USB_OTG_EPClearStall (USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep);
|
||||||
|
uint32_t USB_OTG_ReadDevAllOutEp_itr (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t USB_OTG_ReadDevOutEP_itr (USB_OTG_CORE_HANDLE *pdev , uint8_t epnum);
|
||||||
|
uint32_t USB_OTG_ReadDevAllInEPItr (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void USB_OTG_InitDevSpeed (USB_OTG_CORE_HANDLE *pdev , uint8_t speed);
|
||||||
|
uint8_t USBH_IsEvenFrame (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void USB_OTG_EP0_OutStart(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void USB_OTG_ActiveRemoteWakeup(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void USB_OTG_UngateClock(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void USB_OTG_StopDevice(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void USB_OTG_SetEPStatus (USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep , uint32_t Status);
|
||||||
|
uint32_t USB_OTG_GetEPStatus(USB_OTG_CORE_HANDLE *pdev ,USB_OTG_EP *ep);
|
||||||
|
#endif
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#endif /* __USB_CORE_H__ */
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,158 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_dcd.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Peripheral Driver Header file
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __DCD_H__
|
||||||
|
#define __DCD_H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_core.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD
|
||||||
|
* @brief This file is the
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
#define USB_OTG_EP_CONTROL 0
|
||||||
|
#define USB_OTG_EP_ISOC 1
|
||||||
|
#define USB_OTG_EP_BULK 2
|
||||||
|
#define USB_OTG_EP_INT 3
|
||||||
|
#define USB_OTG_EP_MASK 3
|
||||||
|
|
||||||
|
/* Device Status */
|
||||||
|
#define USB_OTG_DEFAULT 1
|
||||||
|
#define USB_OTG_ADDRESSED 2
|
||||||
|
#define USB_OTG_CONFIGURED 3
|
||||||
|
#define USB_OTG_SUSPENDED 4
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/********************************************************************************
|
||||||
|
Data structure type
|
||||||
|
********************************************************************************/
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
uint8_t bLength;
|
||||||
|
uint8_t bDescriptorType;
|
||||||
|
uint8_t bEndpointAddress;
|
||||||
|
uint8_t bmAttributes;
|
||||||
|
uint16_t wMaxPacketSize;
|
||||||
|
uint8_t bInterval;
|
||||||
|
}
|
||||||
|
EP_DESCRIPTOR , *PEP_DESCRIPTOR;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/********************************************************************************
|
||||||
|
EXPORTED FUNCTION FROM THE USB-OTG LAYER
|
||||||
|
********************************************************************************/
|
||||||
|
void DCD_Init(USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
USB_OTG_CORE_ID_TypeDef coreID);
|
||||||
|
|
||||||
|
void DCD_DevConnect (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void DCD_DevDisconnect (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void DCD_EP_SetAddress (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t address);
|
||||||
|
uint32_t DCD_EP_Open(USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint8_t ep_addr,
|
||||||
|
uint16_t ep_mps,
|
||||||
|
uint8_t ep_type);
|
||||||
|
|
||||||
|
uint32_t DCD_EP_Close (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t ep_addr);
|
||||||
|
|
||||||
|
|
||||||
|
uint32_t DCD_EP_PrepareRx ( USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t ep_addr,
|
||||||
|
uint8_t *pbuf,
|
||||||
|
uint16_t buf_len);
|
||||||
|
|
||||||
|
uint32_t DCD_EP_Tx (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t ep_addr,
|
||||||
|
const uint8_t *pbuf,
|
||||||
|
uint32_t buf_len);
|
||||||
|
uint32_t DCD_EP_Stall (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t epnum);
|
||||||
|
uint32_t DCD_EP_ClrStall (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t epnum);
|
||||||
|
uint32_t DCD_EP_Flush (USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t epnum);
|
||||||
|
uint32_t DCD_Handle_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
uint32_t DCD_GetEPStatus(USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint8_t epnum);
|
||||||
|
|
||||||
|
void DCD_SetEPStatus (USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint8_t epnum ,
|
||||||
|
uint32_t Status);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#endif //__DCD_H__
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,121 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_dcd_int.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Peripheral Device Interface Layer
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef USB_DCD_INT_H__
|
||||||
|
#define USB_DCD_INT_H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_dcd.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT
|
||||||
|
* @brief This file is the
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _USBD_DCD_INT
|
||||||
|
{
|
||||||
|
uint8_t (* DataOutStage) (USB_OTG_CORE_HANDLE *pdev , uint8_t epnum);
|
||||||
|
uint8_t (* DataInStage) (USB_OTG_CORE_HANDLE *pdev , uint8_t epnum);
|
||||||
|
uint8_t (* SetupStage) (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint8_t (* SOF) (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint8_t (* Reset) (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint8_t (* Suspend) (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint8_t (* Resume) (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint8_t (* IsoINIncomplete) (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint8_t (* IsoOUTIncomplete) (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
uint8_t (* DevConnected) (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint8_t (* DevDisconnected) (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
}USBD_DCD_INT_cb_TypeDef;
|
||||||
|
|
||||||
|
extern USBD_DCD_INT_cb_TypeDef *USBD_DCD_INT_fops;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CLEAR_IN_EP_INTR(epnum,intr) \
|
||||||
|
diepint.d32=0; \
|
||||||
|
diepint.b.intr = 1; \
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.INEP_REGS[epnum]->DIEPINT,diepint.d32);
|
||||||
|
|
||||||
|
#define CLEAR_OUT_EP_INTR(epnum,intr) \
|
||||||
|
doepint.d32=0; \
|
||||||
|
doepint.b.intr = 1; \
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.OUTEP_REGS[epnum]->DOEPINT,doepint.d32);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
uint32_t USBD_OTG_ISR_Handler (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#endif // USB_DCD_INT_H__
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,244 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_defines.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Header of the Core Layer
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USB_DEF_H__
|
||||||
|
#define __USB_DEF_H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_conf.h"
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DEFINES
|
||||||
|
* @brief This file is the
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DEFINES_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup _CORE_DEFINES_
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define USB_OTG_SPEED_PARAM_HIGH 0
|
||||||
|
#define USB_OTG_SPEED_PARAM_HIGH_IN_FULL 1
|
||||||
|
#define USB_OTG_SPEED_PARAM_FULL 3
|
||||||
|
|
||||||
|
#define USB_OTG_SPEED_HIGH 0
|
||||||
|
#define USB_OTG_SPEED_FULL 1
|
||||||
|
|
||||||
|
#define USB_OTG_ULPI_PHY 1
|
||||||
|
#define USB_OTG_EMBEDDED_PHY 2
|
||||||
|
#define USB_OTG_I2C_PHY 3
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup _GLOBAL_DEFINES_
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
#define GAHBCFG_TXFEMPTYLVL_EMPTY 1
|
||||||
|
#define GAHBCFG_TXFEMPTYLVL_HALFEMPTY 0
|
||||||
|
#define GAHBCFG_GLBINT_ENABLE 1
|
||||||
|
#define GAHBCFG_INT_DMA_BURST_SINGLE 0
|
||||||
|
#define GAHBCFG_INT_DMA_BURST_INCR 1
|
||||||
|
#define GAHBCFG_INT_DMA_BURST_INCR4 3
|
||||||
|
#define GAHBCFG_INT_DMA_BURST_INCR8 5
|
||||||
|
#define GAHBCFG_INT_DMA_BURST_INCR16 7
|
||||||
|
#define GAHBCFG_DMAENABLE 1
|
||||||
|
#define GAHBCFG_TXFEMPTYLVL_EMPTY 1
|
||||||
|
#define GAHBCFG_TXFEMPTYLVL_HALFEMPTY 0
|
||||||
|
#define GRXSTS_PKTSTS_IN 2
|
||||||
|
#define GRXSTS_PKTSTS_IN_XFER_COMP 3
|
||||||
|
#define GRXSTS_PKTSTS_DATA_TOGGLE_ERR 5
|
||||||
|
#define GRXSTS_PKTSTS_CH_HALTED 7
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup _OnTheGo_DEFINES_
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
#define MODE_HNP_SRP_CAPABLE 0
|
||||||
|
#define MODE_SRP_ONLY_CAPABLE 1
|
||||||
|
#define MODE_NO_HNP_SRP_CAPABLE 2
|
||||||
|
#define MODE_SRP_CAPABLE_DEVICE 3
|
||||||
|
#define MODE_NO_SRP_CAPABLE_DEVICE 4
|
||||||
|
#define MODE_SRP_CAPABLE_HOST 5
|
||||||
|
#define MODE_NO_SRP_CAPABLE_HOST 6
|
||||||
|
#define A_HOST 1
|
||||||
|
#define A_SUSPEND 2
|
||||||
|
#define A_PERIPHERAL 3
|
||||||
|
#define B_PERIPHERAL 4
|
||||||
|
#define B_HOST 5
|
||||||
|
#define DEVICE_MODE 0
|
||||||
|
#define HOST_MODE 1
|
||||||
|
#define OTG_MODE 2
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup __DEVICE_DEFINES_
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
#define DSTS_ENUMSPD_HS_PHY_30MHZ_OR_60MHZ 0
|
||||||
|
#define DSTS_ENUMSPD_FS_PHY_30MHZ_OR_60MHZ 1
|
||||||
|
#define DSTS_ENUMSPD_LS_PHY_6MHZ 2
|
||||||
|
#define DSTS_ENUMSPD_FS_PHY_48MHZ 3
|
||||||
|
|
||||||
|
#define DCFG_FRAME_INTERVAL_80 0
|
||||||
|
#define DCFG_FRAME_INTERVAL_85 1
|
||||||
|
#define DCFG_FRAME_INTERVAL_90 2
|
||||||
|
#define DCFG_FRAME_INTERVAL_95 3
|
||||||
|
|
||||||
|
#define DEP0CTL_MPS_64 0
|
||||||
|
#define DEP0CTL_MPS_32 1
|
||||||
|
#define DEP0CTL_MPS_16 2
|
||||||
|
#define DEP0CTL_MPS_8 3
|
||||||
|
|
||||||
|
#define EP_SPEED_LOW 0
|
||||||
|
#define EP_SPEED_FULL 1
|
||||||
|
#define EP_SPEED_HIGH 2
|
||||||
|
|
||||||
|
#define EP_TYPE_CTRL 0
|
||||||
|
#define EP_TYPE_ISOC 1
|
||||||
|
#define EP_TYPE_BULK 2
|
||||||
|
#define EP_TYPE_INTR 3
|
||||||
|
#define EP_TYPE_MSK 3
|
||||||
|
|
||||||
|
#define STS_GOUT_NAK 1
|
||||||
|
#define STS_DATA_UPDT 2
|
||||||
|
#define STS_XFER_COMP 3
|
||||||
|
#define STS_SETUP_COMP 4
|
||||||
|
#define STS_SETUP_UPDT 6
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup __HOST_DEFINES_
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
#define HC_PID_DATA0 0
|
||||||
|
#define HC_PID_DATA2 1
|
||||||
|
#define HC_PID_DATA1 2
|
||||||
|
#define HC_PID_SETUP 3
|
||||||
|
|
||||||
|
#define HPRT0_PRTSPD_HIGH_SPEED 0
|
||||||
|
#define HPRT0_PRTSPD_FULL_SPEED 1
|
||||||
|
#define HPRT0_PRTSPD_LOW_SPEED 2
|
||||||
|
|
||||||
|
#define HCFG_30_60_MHZ 0
|
||||||
|
#define HCFG_48_MHZ 1
|
||||||
|
#define HCFG_6_MHZ 2
|
||||||
|
|
||||||
|
#define HCCHAR_CTRL 0
|
||||||
|
#define HCCHAR_ISOC 1
|
||||||
|
#define HCCHAR_BULK 2
|
||||||
|
#define HCCHAR_INTR 3
|
||||||
|
|
||||||
|
#define MIN(a, b) (((a) < (b)) ? (a) : (b))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DEFINES_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
USB_OTG_HS_CORE_ID = 0,
|
||||||
|
USB_OTG_FS_CORE_ID = 1
|
||||||
|
}USB_OTG_CORE_ID_TypeDef;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DEFINES_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DEFINES_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DEFINES_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup Internal_Macro's
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
#define USB_OTG_READ_REG32(reg) (*(__IO uint32_t *)reg)
|
||||||
|
#define USB_OTG_WRITE_REG32(reg,value) (*(__IO uint32_t *)reg = value)
|
||||||
|
#define USB_OTG_MODIFY_REG32(reg,clear_mask,set_mask) \
|
||||||
|
USB_OTG_WRITE_REG32(reg, (((USB_OTG_READ_REG32(reg)) & ~clear_mask) | set_mask ) )
|
||||||
|
|
||||||
|
/********************************************************************************
|
||||||
|
ENUMERATION TYPE
|
||||||
|
********************************************************************************/
|
||||||
|
enum USB_OTG_SPEED {
|
||||||
|
USB_SPEED_UNKNOWN = 0,
|
||||||
|
USB_SPEED_LOW,
|
||||||
|
USB_SPEED_FULL,
|
||||||
|
USB_SPEED_HIGH
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif //__USB_DEFINES__H__
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,102 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_hcd.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Host layer Header file
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USB_HCD_H__
|
||||||
|
#define __USB_HCD_H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_regs.h"
|
||||||
|
#include "usb_core.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD
|
||||||
|
* @brief This file is the
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
uint32_t HCD_Init (USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
USB_OTG_CORE_ID_TypeDef coreID);
|
||||||
|
uint32_t HCD_HC_Init (USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint8_t hc_num);
|
||||||
|
uint32_t HCD_SubmitRequest (USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint8_t hc_num) ;
|
||||||
|
uint32_t HCD_GetCurrentSpeed (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t HCD_ResetPort (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t HCD_IsDeviceConnected (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t HCD_GetCurrentFrame (USB_OTG_CORE_HANDLE *pdev) ;
|
||||||
|
URB_STATE HCD_GetURB_State (USB_OTG_CORE_HANDLE *pdev, uint8_t ch_num);
|
||||||
|
uint32_t HCD_GetXferCnt (USB_OTG_CORE_HANDLE *pdev, uint8_t ch_num);
|
||||||
|
HC_STATUS HCD_GetHCState (USB_OTG_CORE_HANDLE *pdev, uint8_t ch_num) ;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#endif //__USB_HCD_H__
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,126 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_hcd_int.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Peripheral Device Interface Layer
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __HCD_INT_H__
|
||||||
|
#define __HCD_INT_H__
|
||||||
|
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_hcd.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT
|
||||||
|
* @brief This file is the
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CLEAR_HC_INT(HC_REGS, intr) \
|
||||||
|
{\
|
||||||
|
USB_OTG_HCINTn_TypeDef hcint_clear; \
|
||||||
|
hcint_clear.d32 = 0; \
|
||||||
|
hcint_clear.b.intr = 1; \
|
||||||
|
USB_OTG_WRITE_REG32(&((HC_REGS)->HCINT), hcint_clear.d32);\
|
||||||
|
}\
|
||||||
|
|
||||||
|
#define MASK_HOST_INT_CHH(hc_num) { USB_OTG_HCGINTMSK_TypeDef GINTMSK; \
|
||||||
|
GINTMSK.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[hc_num]->HCGINTMSK); \
|
||||||
|
GINTMSK.b.chhltd = 0; \
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCGINTMSK, GINTMSK.d32);}
|
||||||
|
|
||||||
|
#define UNMASK_HOST_INT_CHH(hc_num) { USB_OTG_HCGINTMSK_TypeDef GINTMSK; \
|
||||||
|
GINTMSK.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[hc_num]->HCGINTMSK); \
|
||||||
|
GINTMSK.b.chhltd = 1; \
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCGINTMSK, GINTMSK.d32);}
|
||||||
|
|
||||||
|
#define MASK_HOST_INT_ACK(hc_num) { USB_OTG_HCGINTMSK_TypeDef GINTMSK; \
|
||||||
|
GINTMSK.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[hc_num]->HCGINTMSK); \
|
||||||
|
GINTMSK.b.ack = 0; \
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCGINTMSK, GINTMSK.d32);}
|
||||||
|
|
||||||
|
#define UNMASK_HOST_INT_ACK(hc_num) { USB_OTG_HCGINTMSK_TypeDef GINTMSK; \
|
||||||
|
GINTMSK.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[hc_num]->HCGINTMSK); \
|
||||||
|
GINTMSK.b.ack = 1; \
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCGINTMSK, GINTMSK.d32);}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/* Callbacks handler */
|
||||||
|
void ConnectCallback_Handler(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void Disconnect_Callback_Handler(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
void Overcurrent_Callback_Handler(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t USBH_OTG_ISR_Handler (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif //__HCD_INT_H__
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,94 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_otg.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief OTG Core Header
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USB_OTG__
|
||||||
|
#define __USB_OTG__
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG
|
||||||
|
* @brief This file is the
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
void USB_OTG_InitiateSRP(void);
|
||||||
|
void USB_OTG_InitiateHNP(uint8_t state , uint8_t mode);
|
||||||
|
void USB_OTG_Switchback (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
uint32_t USB_OTG_GetCurrentState (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
uint32_t STM32_USBO_OTG_ISR_Handler(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#endif //__USB_OTG__
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
1206
flight/PiOS/STM32F4xx/Libraries/STM32_USB_OTG_Driver/inc/usb_regs.h
Normal file
1206
flight/PiOS/STM32F4xx/Libraries/STM32_USB_OTG_Driver/inc/usb_regs.h
Normal file
@ -0,0 +1,1206 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_regs.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief hardware registers
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __USB_OTG_REGS_H__
|
||||||
|
#define __USB_OTG_REGS_H__
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_conf.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_REGS
|
||||||
|
* @brief This file is the
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_REGS_Exported_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define USB_OTG_HS_BASE_ADDR 0x40040000
|
||||||
|
#define USB_OTG_FS_BASE_ADDR 0x50000000
|
||||||
|
|
||||||
|
#define USB_OTG_CORE_GLOBAL_REGS_OFFSET 0x000
|
||||||
|
#define USB_OTG_DEV_GLOBAL_REG_OFFSET 0x800
|
||||||
|
#define USB_OTG_DEV_IN_EP_REG_OFFSET 0x900
|
||||||
|
#define USB_OTG_EP_REG_OFFSET 0x20
|
||||||
|
#define USB_OTG_DEV_OUT_EP_REG_OFFSET 0xB00
|
||||||
|
#define USB_OTG_HOST_GLOBAL_REG_OFFSET 0x400
|
||||||
|
#define USB_OTG_HOST_PORT_REGS_OFFSET 0x440
|
||||||
|
#define USB_OTG_HOST_CHAN_REGS_OFFSET 0x500
|
||||||
|
#define USB_OTG_CHAN_REGS_OFFSET 0x20
|
||||||
|
#define USB_OTG_PCGCCTL_OFFSET 0xE00
|
||||||
|
#define USB_OTG_DATA_FIFO_OFFSET 0x1000
|
||||||
|
#define USB_OTG_DATA_FIFO_SIZE 0x1000
|
||||||
|
|
||||||
|
|
||||||
|
#define USB_OTG_MAX_TX_FIFOS 15
|
||||||
|
|
||||||
|
#define USB_OTG_HS_MAX_PACKET_SIZE 512
|
||||||
|
#define USB_OTG_FS_MAX_PACKET_SIZE 64
|
||||||
|
#define USB_OTG_MAX_EP0_SIZE 64
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_REGS_Exported_Types
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup __USB_OTG_Core_register
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
typedef struct _USB_OTG_GREGS //000h
|
||||||
|
{
|
||||||
|
__IO uint32_t GOTGCTL; /* USB_OTG Control and Status Register 000h*/
|
||||||
|
__IO uint32_t GOTGINT; /* USB_OTG Interrupt Register 004h*/
|
||||||
|
__IO uint32_t GAHBCFG; /* Core AHB Configuration Register 008h*/
|
||||||
|
__IO uint32_t GUSBCFG; /* Core USB Configuration Register 00Ch*/
|
||||||
|
__IO uint32_t GRSTCTL; /* Core Reset Register 010h*/
|
||||||
|
__IO uint32_t GINTSTS; /* Core Interrupt Register 014h*/
|
||||||
|
__IO uint32_t GINTMSK; /* Core Interrupt Mask Register 018h*/
|
||||||
|
__IO uint32_t GRXSTSR; /* Receive Sts Q Read Register 01Ch*/
|
||||||
|
__IO uint32_t GRXSTSP; /* Receive Sts Q Read & POP Register 020h*/
|
||||||
|
__IO uint32_t GRXFSIZ; /* Receive FIFO Size Register 024h*/
|
||||||
|
__IO uint32_t DIEPTXF0_HNPTXFSIZ; /* EP0 / Non Periodic Tx FIFO Size Register 028h*/
|
||||||
|
__IO uint32_t HNPTXSTS; /* Non Periodic Tx FIFO/Queue Sts reg 02Ch*/
|
||||||
|
__IO uint32_t GI2CCTL; /* I2C Access Register 030h*/
|
||||||
|
uint32_t Reserved34; /* PHY Vendor Control Register 034h*/
|
||||||
|
__IO uint32_t GCCFG; /* General Purpose IO Register 038h*/
|
||||||
|
__IO uint32_t CID; /* User ID Register 03Ch*/
|
||||||
|
uint32_t Reserved40[48]; /* Reserved 040h-0FFh*/
|
||||||
|
__IO uint32_t HPTXFSIZ; /* Host Periodic Tx FIFO Size Reg 100h*/
|
||||||
|
__IO uint32_t DIEPTXF[USB_OTG_MAX_TX_FIFOS];/* dev Periodic Transmit FIFO */
|
||||||
|
}
|
||||||
|
USB_OTG_GREGS;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup __device_Registers
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
typedef struct _USB_OTG_DREGS // 800h
|
||||||
|
{
|
||||||
|
__IO uint32_t DCFG; /* dev Configuration Register 800h*/
|
||||||
|
__IO uint32_t DCTL; /* dev Control Register 804h*/
|
||||||
|
__IO uint32_t DSTS; /* dev Status Register (RO) 808h*/
|
||||||
|
uint32_t Reserved0C; /* Reserved 80Ch*/
|
||||||
|
__IO uint32_t DIEPMSK; /* dev IN Endpoint Mask 810h*/
|
||||||
|
__IO uint32_t DOEPMSK; /* dev OUT Endpoint Mask 814h*/
|
||||||
|
__IO uint32_t DAINT; /* dev All Endpoints Itr Reg 818h*/
|
||||||
|
__IO uint32_t DAINTMSK; /* dev All Endpoints Itr Mask 81Ch*/
|
||||||
|
uint32_t Reserved20; /* Reserved 820h*/
|
||||||
|
uint32_t Reserved9; /* Reserved 824h*/
|
||||||
|
__IO uint32_t DVBUSDIS; /* dev VBUS discharge Register 828h*/
|
||||||
|
__IO uint32_t DVBUSPULSE; /* dev VBUS Pulse Register 82Ch*/
|
||||||
|
__IO uint32_t DTHRCTL; /* dev thr 830h*/
|
||||||
|
__IO uint32_t DIEPEMPMSK; /* dev empty msk 834h*/
|
||||||
|
__IO uint32_t DEACHINT; /* dedicated EP interrupt 838h*/
|
||||||
|
__IO uint32_t DEACHMSK; /* dedicated EP msk 83Ch*/
|
||||||
|
uint32_t Reserved40; /* dedicated EP mask 840h*/
|
||||||
|
__IO uint32_t DINEP1MSK; /* dedicated EP mask 844h*/
|
||||||
|
uint32_t Reserved44[15]; /* Reserved 844-87Ch*/
|
||||||
|
__IO uint32_t DOUTEP1MSK; /* dedicated EP msk 884h*/
|
||||||
|
}
|
||||||
|
USB_OTG_DREGS;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup __IN_Endpoint-Specific_Register
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
typedef struct _USB_OTG_INEPREGS
|
||||||
|
{
|
||||||
|
__IO uint32_t DIEPCTL; /* dev IN Endpoint Control Reg 900h + (ep_num * 20h) + 00h*/
|
||||||
|
uint32_t Reserved04; /* Reserved 900h + (ep_num * 20h) + 04h*/
|
||||||
|
__IO uint32_t DIEPINT; /* dev IN Endpoint Itr Reg 900h + (ep_num * 20h) + 08h*/
|
||||||
|
uint32_t Reserved0C; /* Reserved 900h + (ep_num * 20h) + 0Ch*/
|
||||||
|
__IO uint32_t DIEPTSIZ; /* IN Endpoint Txfer Size 900h + (ep_num * 20h) + 10h*/
|
||||||
|
__IO uint32_t DIEPDMA; /* IN Endpoint DMA Address Reg 900h + (ep_num * 20h) + 14h*/
|
||||||
|
__IO uint32_t DTXFSTS;/*IN Endpoint Tx FIFO Status Reg 900h + (ep_num * 20h) + 18h*/
|
||||||
|
uint32_t Reserved18; /* Reserved 900h+(ep_num*20h)+1Ch-900h+ (ep_num * 20h) + 1Ch*/
|
||||||
|
}
|
||||||
|
USB_OTG_INEPREGS;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup __OUT_Endpoint-Specific_Registers
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
typedef struct _USB_OTG_OUTEPREGS
|
||||||
|
{
|
||||||
|
__IO uint32_t DOEPCTL; /* dev OUT Endpoint Control Reg B00h + (ep_num * 20h) + 00h*/
|
||||||
|
__IO uint32_t DOUTEPFRM; /* dev OUT Endpoint Frame number B00h + (ep_num * 20h) + 04h*/
|
||||||
|
__IO uint32_t DOEPINT; /* dev OUT Endpoint Itr Reg B00h + (ep_num * 20h) + 08h*/
|
||||||
|
uint32_t Reserved0C; /* Reserved B00h + (ep_num * 20h) + 0Ch*/
|
||||||
|
__IO uint32_t DOEPTSIZ; /* dev OUT Endpoint Txfer Size B00h + (ep_num * 20h) + 10h*/
|
||||||
|
__IO uint32_t DOEPDMA; /* dev OUT Endpoint DMA Address B00h + (ep_num * 20h) + 14h*/
|
||||||
|
uint32_t Reserved18[2]; /* Reserved B00h + (ep_num * 20h) + 18h - B00h + (ep_num * 20h) + 1Ch*/
|
||||||
|
}
|
||||||
|
USB_OTG_OUTEPREGS;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup __Host_Mode_Register_Structures
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
typedef struct _USB_OTG_HREGS
|
||||||
|
{
|
||||||
|
__IO uint32_t HCFG; /* Host Configuration Register 400h*/
|
||||||
|
__IO uint32_t HFIR; /* Host Frame Interval Register 404h*/
|
||||||
|
__IO uint32_t HFNUM; /* Host Frame Nbr/Frame Remaining 408h*/
|
||||||
|
uint32_t Reserved40C; /* Reserved 40Ch*/
|
||||||
|
__IO uint32_t HPTXSTS; /* Host Periodic Tx FIFO/ Queue Status 410h*/
|
||||||
|
__IO uint32_t HAINT; /* Host All Channels Interrupt Register 414h*/
|
||||||
|
__IO uint32_t HAINTMSK; /* Host All Channels Interrupt Mask 418h*/
|
||||||
|
}
|
||||||
|
USB_OTG_HREGS;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup __Host_Channel_Specific_Registers
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
typedef struct _USB_OTG_HC_REGS
|
||||||
|
{
|
||||||
|
__IO uint32_t HCCHAR;
|
||||||
|
__IO uint32_t HCSPLT;
|
||||||
|
__IO uint32_t HCINT;
|
||||||
|
__IO uint32_t HCGINTMSK;
|
||||||
|
__IO uint32_t HCTSIZ;
|
||||||
|
__IO uint32_t HCDMA;
|
||||||
|
uint32_t Reserved[2];
|
||||||
|
}
|
||||||
|
USB_OTG_HC_REGS;
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup __otg_Core_registers
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
typedef struct USB_OTG_core_regs //000h
|
||||||
|
{
|
||||||
|
USB_OTG_GREGS *GREGS;
|
||||||
|
USB_OTG_DREGS *DREGS;
|
||||||
|
USB_OTG_HREGS *HREGS;
|
||||||
|
USB_OTG_INEPREGS *INEP_REGS[USB_OTG_MAX_TX_FIFOS];
|
||||||
|
USB_OTG_OUTEPREGS *OUTEP_REGS[USB_OTG_MAX_TX_FIFOS];
|
||||||
|
USB_OTG_HC_REGS *HC_REGS[USB_OTG_MAX_TX_FIFOS];
|
||||||
|
__IO uint32_t *HPRT0;
|
||||||
|
__IO uint32_t *DFIFO[USB_OTG_MAX_TX_FIFOS];
|
||||||
|
__IO uint32_t *PCGCCTL;
|
||||||
|
}
|
||||||
|
USB_OTG_CORE_REGS , *PUSB_OTG_CORE_REGS;
|
||||||
|
typedef union _USB_OTG_OTGCTL_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t sesreqscs :
|
||||||
|
1;
|
||||||
|
uint32_t sesreq :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved2_7 :
|
||||||
|
6;
|
||||||
|
uint32_t hstnegscs :
|
||||||
|
1;
|
||||||
|
uint32_t hnpreq :
|
||||||
|
1;
|
||||||
|
uint32_t hstsethnpen :
|
||||||
|
1;
|
||||||
|
uint32_t devhnpen :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved12_15 :
|
||||||
|
4;
|
||||||
|
uint32_t conidsts :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved17 :
|
||||||
|
1;
|
||||||
|
uint32_t asesvld :
|
||||||
|
1;
|
||||||
|
uint32_t bsesvld :
|
||||||
|
1;
|
||||||
|
uint32_t currmod :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved21_31 :
|
||||||
|
11;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_OTGCTL_TypeDef ;
|
||||||
|
typedef union _USB_OTG_GOTGINT_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t Reserved0_1 :
|
||||||
|
2;
|
||||||
|
uint32_t sesenddet :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved3_7 :
|
||||||
|
5;
|
||||||
|
uint32_t sesreqsucstschng :
|
||||||
|
1;
|
||||||
|
uint32_t hstnegsucstschng :
|
||||||
|
1;
|
||||||
|
uint32_t reserver10_16 :
|
||||||
|
7;
|
||||||
|
uint32_t hstnegdet :
|
||||||
|
1;
|
||||||
|
uint32_t adevtoutchng :
|
||||||
|
1;
|
||||||
|
uint32_t debdone :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved31_20 :
|
||||||
|
12;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_GOTGINT_TypeDef ;
|
||||||
|
typedef union _USB_OTG_GAHBCFG_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t glblintrmsk :
|
||||||
|
1;
|
||||||
|
uint32_t hburstlen :
|
||||||
|
4;
|
||||||
|
uint32_t dmaenable :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved :
|
||||||
|
1;
|
||||||
|
uint32_t nptxfemplvl_txfemplvl :
|
||||||
|
1;
|
||||||
|
uint32_t ptxfemplvl :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved9_31 :
|
||||||
|
23;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_GAHBCFG_TypeDef ;
|
||||||
|
typedef union _USB_OTG_GUSBCFG_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t toutcal :
|
||||||
|
3;
|
||||||
|
uint32_t phyif :
|
||||||
|
1;
|
||||||
|
uint32_t ulpi_utmi_sel :
|
||||||
|
1;
|
||||||
|
uint32_t fsintf :
|
||||||
|
1;
|
||||||
|
uint32_t physel :
|
||||||
|
1;
|
||||||
|
uint32_t ddrsel :
|
||||||
|
1;
|
||||||
|
uint32_t srpcap :
|
||||||
|
1;
|
||||||
|
uint32_t hnpcap :
|
||||||
|
1;
|
||||||
|
uint32_t usbtrdtim :
|
||||||
|
4;
|
||||||
|
uint32_t nptxfrwnden :
|
||||||
|
1;
|
||||||
|
uint32_t phylpwrclksel :
|
||||||
|
1;
|
||||||
|
uint32_t otgutmifssel :
|
||||||
|
1;
|
||||||
|
uint32_t ulpi_fsls :
|
||||||
|
1;
|
||||||
|
uint32_t ulpi_auto_res :
|
||||||
|
1;
|
||||||
|
uint32_t ulpi_clk_sus_m :
|
||||||
|
1;
|
||||||
|
uint32_t ulpi_ext_vbus_drv :
|
||||||
|
1;
|
||||||
|
uint32_t ulpi_int_vbus_indicator :
|
||||||
|
1;
|
||||||
|
uint32_t term_sel_dl_pulse :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved :
|
||||||
|
6;
|
||||||
|
uint32_t force_host :
|
||||||
|
1;
|
||||||
|
uint32_t force_dev :
|
||||||
|
1;
|
||||||
|
uint32_t corrupt_tx :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_GUSBCFG_TypeDef ;
|
||||||
|
typedef union _USB_OTG_GRSTCTL_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t csftrst :
|
||||||
|
1;
|
||||||
|
uint32_t hsftrst :
|
||||||
|
1;
|
||||||
|
uint32_t hstfrm :
|
||||||
|
1;
|
||||||
|
uint32_t intknqflsh :
|
||||||
|
1;
|
||||||
|
uint32_t rxfflsh :
|
||||||
|
1;
|
||||||
|
uint32_t txfflsh :
|
||||||
|
1;
|
||||||
|
uint32_t txfnum :
|
||||||
|
5;
|
||||||
|
uint32_t Reserved11_29 :
|
||||||
|
19;
|
||||||
|
uint32_t dmareq :
|
||||||
|
1;
|
||||||
|
uint32_t ahbidle :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_GRSTCTL_TypeDef ;
|
||||||
|
typedef union _USB_OTG_GINTMSK_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t Reserved0 :
|
||||||
|
1;
|
||||||
|
uint32_t modemismatch :
|
||||||
|
1;
|
||||||
|
uint32_t otgintr :
|
||||||
|
1;
|
||||||
|
uint32_t sofintr :
|
||||||
|
1;
|
||||||
|
uint32_t rxstsqlvl :
|
||||||
|
1;
|
||||||
|
uint32_t nptxfempty :
|
||||||
|
1;
|
||||||
|
uint32_t ginnakeff :
|
||||||
|
1;
|
||||||
|
uint32_t goutnakeff :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved8 :
|
||||||
|
1;
|
||||||
|
uint32_t i2cintr :
|
||||||
|
1;
|
||||||
|
uint32_t erlysuspend :
|
||||||
|
1;
|
||||||
|
uint32_t usbsuspend :
|
||||||
|
1;
|
||||||
|
uint32_t usbreset :
|
||||||
|
1;
|
||||||
|
uint32_t enumdone :
|
||||||
|
1;
|
||||||
|
uint32_t isooutdrop :
|
||||||
|
1;
|
||||||
|
uint32_t eopframe :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved16 :
|
||||||
|
1;
|
||||||
|
uint32_t epmismatch :
|
||||||
|
1;
|
||||||
|
uint32_t inepintr :
|
||||||
|
1;
|
||||||
|
uint32_t outepintr :
|
||||||
|
1;
|
||||||
|
uint32_t incomplisoin :
|
||||||
|
1;
|
||||||
|
uint32_t incomplisoout :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved22_23 :
|
||||||
|
2;
|
||||||
|
uint32_t portintr :
|
||||||
|
1;
|
||||||
|
uint32_t hcintr :
|
||||||
|
1;
|
||||||
|
uint32_t ptxfempty :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved27 :
|
||||||
|
1;
|
||||||
|
uint32_t conidstschng :
|
||||||
|
1;
|
||||||
|
uint32_t disconnect :
|
||||||
|
1;
|
||||||
|
uint32_t sessreqintr :
|
||||||
|
1;
|
||||||
|
uint32_t wkupintr :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_GINTMSK_TypeDef ;
|
||||||
|
typedef union _USB_OTG_GINTSTS_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t curmode :
|
||||||
|
1;
|
||||||
|
uint32_t modemismatch :
|
||||||
|
1;
|
||||||
|
uint32_t otgintr :
|
||||||
|
1;
|
||||||
|
uint32_t sofintr :
|
||||||
|
1;
|
||||||
|
uint32_t rxstsqlvl :
|
||||||
|
1;
|
||||||
|
uint32_t nptxfempty :
|
||||||
|
1;
|
||||||
|
uint32_t ginnakeff :
|
||||||
|
1;
|
||||||
|
uint32_t goutnakeff :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved8 :
|
||||||
|
1;
|
||||||
|
uint32_t i2cintr :
|
||||||
|
1;
|
||||||
|
uint32_t erlysuspend :
|
||||||
|
1;
|
||||||
|
uint32_t usbsuspend :
|
||||||
|
1;
|
||||||
|
uint32_t usbreset :
|
||||||
|
1;
|
||||||
|
uint32_t enumdone :
|
||||||
|
1;
|
||||||
|
uint32_t isooutdrop :
|
||||||
|
1;
|
||||||
|
uint32_t eopframe :
|
||||||
|
1;
|
||||||
|
uint32_t intimerrx :
|
||||||
|
1;
|
||||||
|
uint32_t epmismatch :
|
||||||
|
1;
|
||||||
|
uint32_t inepint:
|
||||||
|
1;
|
||||||
|
uint32_t outepintr :
|
||||||
|
1;
|
||||||
|
uint32_t incomplisoin :
|
||||||
|
1;
|
||||||
|
uint32_t incomplisoout :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved22_23 :
|
||||||
|
2;
|
||||||
|
uint32_t portintr :
|
||||||
|
1;
|
||||||
|
uint32_t hcintr :
|
||||||
|
1;
|
||||||
|
uint32_t ptxfempty :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved27 :
|
||||||
|
1;
|
||||||
|
uint32_t conidstschng :
|
||||||
|
1;
|
||||||
|
uint32_t disconnect :
|
||||||
|
1;
|
||||||
|
uint32_t sessreqintr :
|
||||||
|
1;
|
||||||
|
uint32_t wkupintr :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_GINTSTS_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DRXSTS_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t epnum :
|
||||||
|
4;
|
||||||
|
uint32_t bcnt :
|
||||||
|
11;
|
||||||
|
uint32_t dpid :
|
||||||
|
2;
|
||||||
|
uint32_t pktsts :
|
||||||
|
4;
|
||||||
|
uint32_t fn :
|
||||||
|
4;
|
||||||
|
uint32_t Reserved :
|
||||||
|
7;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DRXSTS_TypeDef ;
|
||||||
|
typedef union _USB_OTG_GRXSTS_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t chnum :
|
||||||
|
4;
|
||||||
|
uint32_t bcnt :
|
||||||
|
11;
|
||||||
|
uint32_t dpid :
|
||||||
|
2;
|
||||||
|
uint32_t pktsts :
|
||||||
|
4;
|
||||||
|
uint32_t Reserved :
|
||||||
|
11;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_GRXFSTS_TypeDef ;
|
||||||
|
typedef union _USB_OTG_FSIZ_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t startaddr :
|
||||||
|
16;
|
||||||
|
uint32_t depth :
|
||||||
|
16;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_FSIZ_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HNPTXSTS_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t nptxfspcavail :
|
||||||
|
16;
|
||||||
|
uint32_t nptxqspcavail :
|
||||||
|
8;
|
||||||
|
uint32_t nptxqtop_terminate :
|
||||||
|
1;
|
||||||
|
uint32_t nptxqtop_timer :
|
||||||
|
2;
|
||||||
|
uint32_t nptxqtop :
|
||||||
|
2;
|
||||||
|
uint32_t chnum :
|
||||||
|
2;
|
||||||
|
uint32_t Reserved :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HNPTXSTS_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DTXFSTSn_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t txfspcavail :
|
||||||
|
16;
|
||||||
|
uint32_t Reserved :
|
||||||
|
16;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DTXFSTSn_TypeDef ;
|
||||||
|
typedef union _USB_OTG_GI2CCTL_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t rwdata :
|
||||||
|
8;
|
||||||
|
uint32_t regaddr :
|
||||||
|
8;
|
||||||
|
uint32_t addr :
|
||||||
|
7;
|
||||||
|
uint32_t i2cen :
|
||||||
|
1;
|
||||||
|
uint32_t ack :
|
||||||
|
1;
|
||||||
|
uint32_t i2csuspctl :
|
||||||
|
1;
|
||||||
|
uint32_t i2cdevaddr :
|
||||||
|
2;
|
||||||
|
uint32_t dat_se0:
|
||||||
|
1;
|
||||||
|
uint32_t Reserved :
|
||||||
|
1;
|
||||||
|
uint32_t rw :
|
||||||
|
1;
|
||||||
|
uint32_t bsydne :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_GI2CCTL_TypeDef ;
|
||||||
|
typedef union _USB_OTG_GCCFG_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t Reserved_in :
|
||||||
|
16;
|
||||||
|
uint32_t pwdn :
|
||||||
|
1;
|
||||||
|
uint32_t i2cifen :
|
||||||
|
1;
|
||||||
|
uint32_t vbussensingA :
|
||||||
|
1;
|
||||||
|
uint32_t vbussensingB :
|
||||||
|
1;
|
||||||
|
uint32_t sofouten :
|
||||||
|
1;
|
||||||
|
uint32_t disablevbussensing :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved_out :
|
||||||
|
10;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_GCCFG_TypeDef ;
|
||||||
|
|
||||||
|
typedef union _USB_OTG_DCFG_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t devspd :
|
||||||
|
2;
|
||||||
|
uint32_t nzstsouthshk :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved3 :
|
||||||
|
1;
|
||||||
|
uint32_t devaddr :
|
||||||
|
7;
|
||||||
|
uint32_t perfrint :
|
||||||
|
2;
|
||||||
|
uint32_t Reserved13_17 :
|
||||||
|
5;
|
||||||
|
uint32_t epmscnt :
|
||||||
|
4;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DCFG_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DCTL_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t rmtwkupsig :
|
||||||
|
1;
|
||||||
|
uint32_t sftdiscon :
|
||||||
|
1;
|
||||||
|
uint32_t gnpinnaksts :
|
||||||
|
1;
|
||||||
|
uint32_t goutnaksts :
|
||||||
|
1;
|
||||||
|
uint32_t tstctl :
|
||||||
|
3;
|
||||||
|
uint32_t sgnpinnak :
|
||||||
|
1;
|
||||||
|
uint32_t cgnpinnak :
|
||||||
|
1;
|
||||||
|
uint32_t sgoutnak :
|
||||||
|
1;
|
||||||
|
uint32_t cgoutnak :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved :
|
||||||
|
21;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DCTL_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DSTS_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t suspsts :
|
||||||
|
1;
|
||||||
|
uint32_t enumspd :
|
||||||
|
2;
|
||||||
|
uint32_t errticerr :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved4_7:
|
||||||
|
4;
|
||||||
|
uint32_t soffn :
|
||||||
|
14;
|
||||||
|
uint32_t Reserved22_31 :
|
||||||
|
10;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DSTS_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DIEPINTn_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t xfercompl :
|
||||||
|
1;
|
||||||
|
uint32_t epdisabled :
|
||||||
|
1;
|
||||||
|
uint32_t ahberr :
|
||||||
|
1;
|
||||||
|
uint32_t timeout :
|
||||||
|
1;
|
||||||
|
uint32_t intktxfemp :
|
||||||
|
1;
|
||||||
|
uint32_t intknepmis :
|
||||||
|
1;
|
||||||
|
uint32_t inepnakeff :
|
||||||
|
1;
|
||||||
|
uint32_t emptyintr :
|
||||||
|
1;
|
||||||
|
uint32_t txfifoundrn :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved08_31 :
|
||||||
|
23;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DIEPINTn_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DIEPINTn_TypeDef USB_OTG_DIEPMSK_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DOEPINTn_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t xfercompl :
|
||||||
|
1;
|
||||||
|
uint32_t epdisabled :
|
||||||
|
1;
|
||||||
|
uint32_t ahberr :
|
||||||
|
1;
|
||||||
|
uint32_t setup :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved04_31 :
|
||||||
|
28;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DOEPINTn_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DOEPINTn_TypeDef USB_OTG_DOEPMSK_TypeDef ;
|
||||||
|
|
||||||
|
typedef union _USB_OTG_DAINT_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t in :
|
||||||
|
16;
|
||||||
|
uint32_t out :
|
||||||
|
16;
|
||||||
|
}
|
||||||
|
ep;
|
||||||
|
} USB_OTG_DAINT_TypeDef ;
|
||||||
|
|
||||||
|
typedef union _USB_OTG_DTHRCTL_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t non_iso_thr_en :
|
||||||
|
1;
|
||||||
|
uint32_t iso_thr_en :
|
||||||
|
1;
|
||||||
|
uint32_t tx_thr_len :
|
||||||
|
9;
|
||||||
|
uint32_t Reserved11_15 :
|
||||||
|
5;
|
||||||
|
uint32_t rx_thr_en :
|
||||||
|
1;
|
||||||
|
uint32_t rx_thr_len :
|
||||||
|
9;
|
||||||
|
uint32_t Reserved26_31 :
|
||||||
|
6;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DTHRCTL_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DEPCTL_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t mps :
|
||||||
|
11;
|
||||||
|
uint32_t reserved :
|
||||||
|
4;
|
||||||
|
uint32_t usbactep :
|
||||||
|
1;
|
||||||
|
uint32_t dpid :
|
||||||
|
1;
|
||||||
|
uint32_t naksts :
|
||||||
|
1;
|
||||||
|
uint32_t eptype :
|
||||||
|
2;
|
||||||
|
uint32_t snp :
|
||||||
|
1;
|
||||||
|
uint32_t stall :
|
||||||
|
1;
|
||||||
|
uint32_t txfnum :
|
||||||
|
4;
|
||||||
|
uint32_t cnak :
|
||||||
|
1;
|
||||||
|
uint32_t snak :
|
||||||
|
1;
|
||||||
|
uint32_t setd0pid :
|
||||||
|
1;
|
||||||
|
uint32_t setd1pid :
|
||||||
|
1;
|
||||||
|
uint32_t epdis :
|
||||||
|
1;
|
||||||
|
uint32_t epena :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DEPCTL_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DEPXFRSIZ_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t xfersize :
|
||||||
|
19;
|
||||||
|
uint32_t pktcnt :
|
||||||
|
10;
|
||||||
|
uint32_t mc :
|
||||||
|
2;
|
||||||
|
uint32_t Reserved :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DEPXFRSIZ_TypeDef ;
|
||||||
|
typedef union _USB_OTG_DEP0XFRSIZ_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t xfersize :
|
||||||
|
7;
|
||||||
|
uint32_t Reserved7_18 :
|
||||||
|
12;
|
||||||
|
uint32_t pktcnt :
|
||||||
|
2;
|
||||||
|
uint32_t Reserved20_28 :
|
||||||
|
9;
|
||||||
|
uint32_t supcnt :
|
||||||
|
2;
|
||||||
|
uint32_t Reserved31;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_DEP0XFRSIZ_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HCFG_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t fslspclksel :
|
||||||
|
2;
|
||||||
|
uint32_t fslssupp :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HCFG_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HFRMINTRVL_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t frint :
|
||||||
|
16;
|
||||||
|
uint32_t Reserved :
|
||||||
|
16;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HFRMINTRVL_TypeDef ;
|
||||||
|
|
||||||
|
typedef union _USB_OTG_HFNUM_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t frnum :
|
||||||
|
16;
|
||||||
|
uint32_t frrem :
|
||||||
|
16;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HFNUM_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HPTXSTS_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t ptxfspcavail :
|
||||||
|
16;
|
||||||
|
uint32_t ptxqspcavail :
|
||||||
|
8;
|
||||||
|
uint32_t ptxqtop_terminate :
|
||||||
|
1;
|
||||||
|
uint32_t ptxqtop_timer :
|
||||||
|
2;
|
||||||
|
uint32_t ptxqtop :
|
||||||
|
2;
|
||||||
|
uint32_t chnum :
|
||||||
|
2;
|
||||||
|
uint32_t ptxqtop_odd :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HPTXSTS_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HPRT0_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t prtconnsts :
|
||||||
|
1;
|
||||||
|
uint32_t prtconndet :
|
||||||
|
1;
|
||||||
|
uint32_t prtena :
|
||||||
|
1;
|
||||||
|
uint32_t prtenchng :
|
||||||
|
1;
|
||||||
|
uint32_t prtovrcurract :
|
||||||
|
1;
|
||||||
|
uint32_t prtovrcurrchng :
|
||||||
|
1;
|
||||||
|
uint32_t prtres :
|
||||||
|
1;
|
||||||
|
uint32_t prtsusp :
|
||||||
|
1;
|
||||||
|
uint32_t prtrst :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved9 :
|
||||||
|
1;
|
||||||
|
uint32_t prtlnsts :
|
||||||
|
2;
|
||||||
|
uint32_t prtpwr :
|
||||||
|
1;
|
||||||
|
uint32_t prttstctl :
|
||||||
|
4;
|
||||||
|
uint32_t prtspd :
|
||||||
|
2;
|
||||||
|
uint32_t Reserved19_31 :
|
||||||
|
13;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HPRT0_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HAINT_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t chint :
|
||||||
|
16;
|
||||||
|
uint32_t Reserved :
|
||||||
|
16;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HAINT_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HAINTMSK_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t chint :
|
||||||
|
16;
|
||||||
|
uint32_t Reserved :
|
||||||
|
16;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HAINTMSK_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HCCHAR_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t mps :
|
||||||
|
11;
|
||||||
|
uint32_t epnum :
|
||||||
|
4;
|
||||||
|
uint32_t epdir :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved :
|
||||||
|
1;
|
||||||
|
uint32_t lspddev :
|
||||||
|
1;
|
||||||
|
uint32_t eptype :
|
||||||
|
2;
|
||||||
|
uint32_t multicnt :
|
||||||
|
2;
|
||||||
|
uint32_t devaddr :
|
||||||
|
7;
|
||||||
|
uint32_t oddfrm :
|
||||||
|
1;
|
||||||
|
uint32_t chdis :
|
||||||
|
1;
|
||||||
|
uint32_t chen :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HCCHAR_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HCSPLT_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t prtaddr :
|
||||||
|
7;
|
||||||
|
uint32_t hubaddr :
|
||||||
|
7;
|
||||||
|
uint32_t xactpos :
|
||||||
|
2;
|
||||||
|
uint32_t compsplt :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved :
|
||||||
|
14;
|
||||||
|
uint32_t spltena :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HCSPLT_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HCINTn_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t xfercompl :
|
||||||
|
1;
|
||||||
|
uint32_t chhltd :
|
||||||
|
1;
|
||||||
|
uint32_t ahberr :
|
||||||
|
1;
|
||||||
|
uint32_t stall :
|
||||||
|
1;
|
||||||
|
uint32_t nak :
|
||||||
|
1;
|
||||||
|
uint32_t ack :
|
||||||
|
1;
|
||||||
|
uint32_t nyet :
|
||||||
|
1;
|
||||||
|
uint32_t xacterr :
|
||||||
|
1;
|
||||||
|
uint32_t bblerr :
|
||||||
|
1;
|
||||||
|
uint32_t frmovrun :
|
||||||
|
1;
|
||||||
|
uint32_t datatglerr :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved :
|
||||||
|
21;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HCINTn_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HCTSIZn_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t xfersize :
|
||||||
|
19;
|
||||||
|
uint32_t pktcnt :
|
||||||
|
10;
|
||||||
|
uint32_t pid :
|
||||||
|
2;
|
||||||
|
uint32_t dopng :
|
||||||
|
1;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HCTSIZn_TypeDef ;
|
||||||
|
typedef union _USB_OTG_HCGINTMSK_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t xfercompl :
|
||||||
|
1;
|
||||||
|
uint32_t chhltd :
|
||||||
|
1;
|
||||||
|
uint32_t ahberr :
|
||||||
|
1;
|
||||||
|
uint32_t stall :
|
||||||
|
1;
|
||||||
|
uint32_t nak :
|
||||||
|
1;
|
||||||
|
uint32_t ack :
|
||||||
|
1;
|
||||||
|
uint32_t nyet :
|
||||||
|
1;
|
||||||
|
uint32_t xacterr :
|
||||||
|
1;
|
||||||
|
uint32_t bblerr :
|
||||||
|
1;
|
||||||
|
uint32_t frmovrun :
|
||||||
|
1;
|
||||||
|
uint32_t datatglerr :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved :
|
||||||
|
21;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_HCGINTMSK_TypeDef ;
|
||||||
|
typedef union _USB_OTG_PCGCCTL_TypeDef
|
||||||
|
{
|
||||||
|
uint32_t d32;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
uint32_t stoppclk :
|
||||||
|
1;
|
||||||
|
uint32_t gatehclk :
|
||||||
|
1;
|
||||||
|
uint32_t Reserved :
|
||||||
|
30;
|
||||||
|
}
|
||||||
|
b;
|
||||||
|
} USB_OTG_PCGCCTL_TypeDef ;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_REGS_Exported_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_REGS_Exported_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_REGS_Exported_FunctionsPrototype
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#endif //__USB_OTG_REGS_H__
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,200 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_bsp.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief This file is responsible to offer board support package and is
|
||||||
|
* configurable by user.
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_bsp.h"
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP
|
||||||
|
* @brief This file is responsible to offer board support package
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBH_BSP_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USBH_BSP_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_BSP_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_BSP_Init
|
||||||
|
* Initilizes BSP configurations
|
||||||
|
* @param None
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
|
||||||
|
void USB_OTG_BSP_Init(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_BSP_EnableInterrupt
|
||||||
|
* Enabele USB Global interrupt
|
||||||
|
* @param None
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
void USB_OTG_BSP_EnableInterrupt(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief BSP_Drive_VBUS
|
||||||
|
* Drives the Vbus signal through IO
|
||||||
|
* @param speed : Full, Low
|
||||||
|
* @param state : VBUS states
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
|
||||||
|
void USB_OTG_BSP_DriveVBUS(USB_OTG_CORE_HANDLE *pdev, uint8_t state)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_BSP_ConfigVBUS
|
||||||
|
* Configures the IO for the Vbus and OverCurrent
|
||||||
|
* @param Speed : Full, Low
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
|
||||||
|
void USB_OTG_BSP_ConfigVBUS(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_BSP_TimeInit
|
||||||
|
* Initialises delay unit Systick timer /Timer2
|
||||||
|
* @param None
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
void USB_OTG_BSP_TimeInit ( void )
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_BSP_uDelay
|
||||||
|
* This function provides delay time in micro sec
|
||||||
|
* @param usec : Value of delay required in micro sec
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
void USB_OTG_BSP_uDelay (const uint32_t usec)
|
||||||
|
{
|
||||||
|
|
||||||
|
uint32_t count = 0;
|
||||||
|
const uint32_t utime = (120 * usec / 7);
|
||||||
|
do
|
||||||
|
{
|
||||||
|
if ( ++count > utime )
|
||||||
|
{
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (1);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_BSP_mDelay
|
||||||
|
* This function provides delay time in milli sec
|
||||||
|
* @param msec : Value of delay required in milli sec
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
void USB_OTG_BSP_mDelay (const uint32_t msec)
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_BSP_uDelay(msec * 1000);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_BSP_TimerIRQ
|
||||||
|
* Time base IRQ
|
||||||
|
* @param None
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
|
||||||
|
void USB_OTG_BSP_TimerIRQ (void)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
2187
flight/PiOS/STM32F4xx/Libraries/STM32_USB_OTG_Driver/src/usb_core.c
Normal file
2187
flight/PiOS/STM32F4xx/Libraries/STM32_USB_OTG_Driver/src/usb_core.c
Normal file
@ -0,0 +1,2187 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_core.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief USB-OTG Core Layer
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_core.h"
|
||||||
|
#include "usb_bsp.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE
|
||||||
|
* @brief This file includes the USB-OTG Core Layer
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_CORE_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_EnableCommonInt
|
||||||
|
* Initializes the commmon interrupts, used in both device and modes
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
static void USB_OTG_EnableCommonInt(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTMSK_TypeDef int_mask;
|
||||||
|
|
||||||
|
int_mask.d32 = 0;
|
||||||
|
/* Clear any pending USB_OTG Interrupts */
|
||||||
|
#ifndef USE_OTG_MODE
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->GOTGINT, 0xFFFFFFFF);
|
||||||
|
#endif
|
||||||
|
/* Clear any pending interrupts */
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->GINTSTS, 0xFFFFFFFF);
|
||||||
|
/* Enable the interrupts in the INTMSK */
|
||||||
|
int_mask.b.wkupintr = 1;
|
||||||
|
int_mask.b.usbsuspend = 1;
|
||||||
|
|
||||||
|
#ifdef USE_OTG_MODE
|
||||||
|
int_mask.b.otgintr = 1;
|
||||||
|
int_mask.b.sessreqintr = 1;
|
||||||
|
int_mask.b.conidstschng = 1;
|
||||||
|
#endif
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->GINTMSK, int_mask.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_CoreReset : Soft reset of the core
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
static USB_OTG_STS USB_OTG_CoreReset(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
__IO USB_OTG_GRSTCTL_TypeDef greset;
|
||||||
|
uint32_t count = 0;
|
||||||
|
|
||||||
|
greset.d32 = 0;
|
||||||
|
/* Wait for AHB master IDLE state. */
|
||||||
|
do
|
||||||
|
{
|
||||||
|
USB_OTG_BSP_uDelay(3);
|
||||||
|
greset.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GRSTCTL);
|
||||||
|
if (++count > 200000)
|
||||||
|
{
|
||||||
|
return USB_OTG_OK;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (greset.b.ahbidle == 0);
|
||||||
|
/* Core Soft Reset */
|
||||||
|
count = 0;
|
||||||
|
greset.b.csftrst = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GRSTCTL, greset.d32 );
|
||||||
|
do
|
||||||
|
{
|
||||||
|
greset.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GRSTCTL);
|
||||||
|
if (++count > 200000)
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (greset.b.csftrst == 1);
|
||||||
|
/* Wait for 3 PHY Clocks*/
|
||||||
|
USB_OTG_BSP_uDelay(3);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_WritePacket : Writes a packet into the Tx FIFO associated
|
||||||
|
* with the EP
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param src : source pointer
|
||||||
|
* @param ch_ep_num : end point number
|
||||||
|
* @param bytes : No. of bytes
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_WritePacket(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t *src,
|
||||||
|
uint8_t ch_ep_num,
|
||||||
|
uint16_t len)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
if (pdev->cfg.dma_enable == 0)
|
||||||
|
{
|
||||||
|
uint32_t count32b= 0 , i= 0;
|
||||||
|
__IO uint32_t *fifo;
|
||||||
|
|
||||||
|
count32b = (len + 3) / 4;
|
||||||
|
fifo = pdev->regs.DFIFO[ch_ep_num];
|
||||||
|
for (i = 0; i < count32b; i++, src+=4)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32( fifo, *((__packed uint32_t *)src) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_ReadPacket : Reads a packet from the Rx FIFO
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param dest : Destination Pointer
|
||||||
|
* @param bytes : No. of bytes
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
void *USB_OTG_ReadPacket(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t *dest,
|
||||||
|
uint16_t len)
|
||||||
|
{
|
||||||
|
uint32_t i=0;
|
||||||
|
uint32_t count32b = (len + 3) / 4;
|
||||||
|
|
||||||
|
__IO uint32_t *fifo = pdev->regs.DFIFO[0];
|
||||||
|
|
||||||
|
for ( i = 0; i < count32b; i++, dest += 4 )
|
||||||
|
{
|
||||||
|
*(__packed uint32_t *)dest = USB_OTG_READ_REG32(fifo);
|
||||||
|
|
||||||
|
}
|
||||||
|
return ((void *)dest);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_SelectCore
|
||||||
|
* Initialize core registers address.
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param coreID : USB OTG Core ID
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_SelectCore(USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
USB_OTG_CORE_ID_TypeDef coreID)
|
||||||
|
{
|
||||||
|
uint32_t i , baseAddress = 0;
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
|
||||||
|
pdev->cfg.dma_enable = 0;
|
||||||
|
|
||||||
|
/* at startup the core is in FS mode */
|
||||||
|
pdev->cfg.speed = USB_OTG_SPEED_FULL;
|
||||||
|
pdev->cfg.mps = USB_OTG_FS_MAX_PACKET_SIZE ;
|
||||||
|
|
||||||
|
/* initialize device cfg following its address */
|
||||||
|
if (coreID == USB_OTG_FS_CORE_ID)
|
||||||
|
{
|
||||||
|
baseAddress = USB_OTG_FS_BASE_ADDR;
|
||||||
|
pdev->cfg.coreID = USB_OTG_FS_CORE_ID;
|
||||||
|
pdev->cfg.host_channels = 8 ;
|
||||||
|
pdev->cfg.dev_endpoints = 4 ;
|
||||||
|
pdev->cfg.TotalFifoSize = 320; /* in 32-bits */
|
||||||
|
pdev->cfg.phy_itface = USB_OTG_EMBEDDED_PHY;
|
||||||
|
|
||||||
|
#ifdef USB_OTG_FS_SOF_OUTPUT_ENABLED
|
||||||
|
pdev->cfg.Sof_output = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef USB_OTG_FS_LOW_PWR_MGMT_SUPPORT
|
||||||
|
pdev->cfg.low_power = 1;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
else if (coreID == USB_OTG_HS_CORE_ID)
|
||||||
|
{
|
||||||
|
baseAddress = USB_OTG_HS_BASE_ADDR;
|
||||||
|
pdev->cfg.coreID = USB_OTG_HS_CORE_ID;
|
||||||
|
pdev->cfg.host_channels = 12 ;
|
||||||
|
pdev->cfg.dev_endpoints = 6 ;
|
||||||
|
pdev->cfg.TotalFifoSize = 1280;/* in 32-bits */
|
||||||
|
|
||||||
|
#ifdef USB_OTG_ULPI_PHY_ENABLED
|
||||||
|
pdev->cfg.phy_itface = USB_OTG_ULPI_PHY;
|
||||||
|
#else
|
||||||
|
#ifdef USB_OTG_EMBEDDED_PHY_ENABLED
|
||||||
|
pdev->cfg.phy_itface = USB_OTG_EMBEDDED_PHY;
|
||||||
|
#else
|
||||||
|
#ifdef USB_OTG_I2C_PHY_ENABLED
|
||||||
|
pdev->cfg.phy_itface = USB_OTG_I2C_PHY;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_INTERNAL_DMA_ENABLED
|
||||||
|
pdev->cfg.dma_enable = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_SOF_OUTPUT_ENABLED
|
||||||
|
pdev->cfg.Sof_output = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_LOW_PWR_MGMT_SUPPORT
|
||||||
|
pdev->cfg.low_power = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
pdev->regs.GREGS = (USB_OTG_GREGS *)(baseAddress + \
|
||||||
|
USB_OTG_CORE_GLOBAL_REGS_OFFSET);
|
||||||
|
pdev->regs.DREGS = (USB_OTG_DREGS *) (baseAddress + \
|
||||||
|
USB_OTG_DEV_GLOBAL_REG_OFFSET);
|
||||||
|
|
||||||
|
for (i = 0; i < pdev->cfg.dev_endpoints; i++)
|
||||||
|
{
|
||||||
|
pdev->regs.INEP_REGS[i] = (USB_OTG_INEPREGS *) \
|
||||||
|
(baseAddress + USB_OTG_DEV_IN_EP_REG_OFFSET + \
|
||||||
|
(i * USB_OTG_EP_REG_OFFSET));
|
||||||
|
pdev->regs.OUTEP_REGS[i] = (USB_OTG_OUTEPREGS *) \
|
||||||
|
(baseAddress + USB_OTG_DEV_OUT_EP_REG_OFFSET + \
|
||||||
|
(i * USB_OTG_EP_REG_OFFSET));
|
||||||
|
}
|
||||||
|
pdev->regs.HREGS = (USB_OTG_HREGS *)(baseAddress + \
|
||||||
|
USB_OTG_HOST_GLOBAL_REG_OFFSET);
|
||||||
|
pdev->regs.HPRT0 = (uint32_t *)(baseAddress + USB_OTG_HOST_PORT_REGS_OFFSET);
|
||||||
|
|
||||||
|
for (i = 0; i < pdev->cfg.host_channels; i++)
|
||||||
|
{
|
||||||
|
pdev->regs.HC_REGS[i] = (USB_OTG_HC_REGS *)(baseAddress + \
|
||||||
|
USB_OTG_HOST_CHAN_REGS_OFFSET + \
|
||||||
|
(i * USB_OTG_CHAN_REGS_OFFSET));
|
||||||
|
}
|
||||||
|
for (i = 0; i < pdev->cfg.host_channels; i++)
|
||||||
|
{
|
||||||
|
pdev->regs.DFIFO[i] = (uint32_t *)(baseAddress + USB_OTG_DATA_FIFO_OFFSET +\
|
||||||
|
(i * USB_OTG_DATA_FIFO_SIZE));
|
||||||
|
}
|
||||||
|
pdev->regs.PCGCCTL = (uint32_t *)(baseAddress + USB_OTG_PCGCCTL_OFFSET);
|
||||||
|
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_CoreInit
|
||||||
|
* Initializes the USB_OTG controller registers and prepares the core
|
||||||
|
* device mode or host mode operation.
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_CoreInit(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_GUSBCFG_TypeDef usbcfg;
|
||||||
|
USB_OTG_GCCFG_TypeDef gccfg;
|
||||||
|
USB_OTG_GI2CCTL_TypeDef i2cctl;
|
||||||
|
USB_OTG_GAHBCFG_TypeDef ahbcfg;
|
||||||
|
|
||||||
|
usbcfg.d32 = 0;
|
||||||
|
gccfg.d32 = 0;
|
||||||
|
ahbcfg.d32 = 0;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if (pdev->cfg.phy_itface == USB_OTG_ULPI_PHY)
|
||||||
|
{
|
||||||
|
gccfg.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GCCFG);
|
||||||
|
gccfg.b.pwdn = 0;
|
||||||
|
|
||||||
|
if (pdev->cfg.Sof_output)
|
||||||
|
{
|
||||||
|
gccfg.b.sofouten = 1;
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GCCFG, gccfg.d32);
|
||||||
|
|
||||||
|
/* Init The ULPI Interface */
|
||||||
|
usbcfg.d32 = 0;
|
||||||
|
usbcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GUSBCFG);
|
||||||
|
|
||||||
|
usbcfg.b.physel = 0; /* HS Interface */
|
||||||
|
#ifdef USB_OTG_INTERNAL_VBUS_ENABLED
|
||||||
|
usbcfg.b.ulpi_ext_vbus_drv = 0; /* Use internal VBUS */
|
||||||
|
#else
|
||||||
|
#ifdef USB_OTG_EXTERNAL_VBUS_ENABLED
|
||||||
|
usbcfg.b.ulpi_ext_vbus_drv = 1; /* Use external VBUS */
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
usbcfg.b.term_sel_dl_pulse = 0; /* Data line pulsing using utmi_txvalid */
|
||||||
|
usbcfg.b.ulpi_utmi_sel = 1; /* ULPI seleInterfacect */
|
||||||
|
|
||||||
|
usbcfg.b.phyif = 0; /* 8 bits */
|
||||||
|
usbcfg.b.ddrsel = 0; /* single data rate */
|
||||||
|
|
||||||
|
usbcfg.b.ulpi_fsls = 0;
|
||||||
|
usbcfg.b.ulpi_clk_sus_m = 0;
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GUSBCFG, usbcfg.d32);
|
||||||
|
|
||||||
|
/* Reset after a PHY select */
|
||||||
|
USB_OTG_CoreReset(pdev);
|
||||||
|
|
||||||
|
if(pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
|
||||||
|
ahbcfg.b.hburstlen = 5; /* 64 x 32-bits*/
|
||||||
|
ahbcfg.b.dmaenable = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GAHBCFG, ahbcfg.d32);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else /* FS interface (embedded Phy or I2C Phy) */
|
||||||
|
{
|
||||||
|
|
||||||
|
usbcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GUSBCFG);;
|
||||||
|
usbcfg.b.physel = 1; /* FS Interface */
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GUSBCFG, usbcfg.d32);
|
||||||
|
/* Reset after a PHY select and set Host mode */
|
||||||
|
USB_OTG_CoreReset(pdev);
|
||||||
|
/* Enable the I2C interface and deactivate the power down*/
|
||||||
|
gccfg.d32 = 0;
|
||||||
|
gccfg.b.pwdn = 1;
|
||||||
|
|
||||||
|
if(pdev->cfg.phy_itface == USB_OTG_I2C_PHY)
|
||||||
|
{
|
||||||
|
gccfg.b.i2cifen = 1;
|
||||||
|
}
|
||||||
|
gccfg.b.vbussensingA = 1 ;
|
||||||
|
gccfg.b.vbussensingB = 1 ;
|
||||||
|
#ifndef VBUS_SENSING_ENABLED
|
||||||
|
gccfg.b.disablevbussensing = 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if(pdev->cfg.Sof_output)
|
||||||
|
{
|
||||||
|
gccfg.b.sofouten = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GCCFG, gccfg.d32);
|
||||||
|
USB_OTG_BSP_mDelay(20);
|
||||||
|
/* Program GUSBCFG.OtgUtmifsSel to I2C*/
|
||||||
|
usbcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GUSBCFG);
|
||||||
|
|
||||||
|
if(pdev->cfg.phy_itface == USB_OTG_I2C_PHY)
|
||||||
|
{
|
||||||
|
usbcfg.b.otgutmifssel = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GUSBCFG, usbcfg.d32);
|
||||||
|
|
||||||
|
if(pdev->cfg.phy_itface == USB_OTG_I2C_PHY)
|
||||||
|
{
|
||||||
|
/*Program GI2CCTL.I2CEn*/
|
||||||
|
i2cctl.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GI2CCTL);
|
||||||
|
i2cctl.b.i2cdevaddr = 1;
|
||||||
|
i2cctl.b.i2cen = 0;
|
||||||
|
i2cctl.b.dat_se0 = 1;
|
||||||
|
i2cctl.b.addr = 0x2D;
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GI2CCTL, i2cctl.d32);
|
||||||
|
|
||||||
|
USB_OTG_BSP_mDelay(200);
|
||||||
|
|
||||||
|
i2cctl.b.i2cen = 1;
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GI2CCTL, i2cctl.d32);
|
||||||
|
USB_OTG_BSP_mDelay(200);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* case the HS core is working in FS mode */
|
||||||
|
if(pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
|
||||||
|
ahbcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GAHBCFG);
|
||||||
|
ahbcfg.b.hburstlen = 5; /* 64 x 32-bits*/
|
||||||
|
ahbcfg.b.dmaenable = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GAHBCFG, ahbcfg.d32);
|
||||||
|
|
||||||
|
}
|
||||||
|
/* initialize OTG features */
|
||||||
|
#ifdef USE_OTG_MODE
|
||||||
|
usbcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GUSBCFG);
|
||||||
|
usbcfg.b.hnpcap = 1;
|
||||||
|
usbcfg.b.srpcap = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GUSBCFG, usbcfg.d32);
|
||||||
|
USB_OTG_EnableCommonInt(pdev);
|
||||||
|
#endif
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_EnableGlobalInt
|
||||||
|
* Enables the controller's Global Int in the AHB Config reg
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EnableGlobalInt(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_GAHBCFG_TypeDef ahbcfg;
|
||||||
|
|
||||||
|
ahbcfg.d32 = 0;
|
||||||
|
ahbcfg.b.glblintrmsk = 1; /* Enable interrupts */
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.GREGS->GAHBCFG, 0, ahbcfg.d32);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_DisableGlobalInt
|
||||||
|
* Enables the controller's Global Int in the AHB Config reg
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_DisableGlobalInt(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_GAHBCFG_TypeDef ahbcfg;
|
||||||
|
ahbcfg.d32 = 0;
|
||||||
|
ahbcfg.b.glblintrmsk = 1; /* Enable interrupts */
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.GREGS->GAHBCFG, ahbcfg.d32, 0);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_FlushTxFifo : Flush a Tx FIFO
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param num : FO num
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_FlushTxFifo (USB_OTG_CORE_HANDLE *pdev , uint32_t num )
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
__IO USB_OTG_GRSTCTL_TypeDef greset;
|
||||||
|
|
||||||
|
uint32_t count = 0;
|
||||||
|
greset.d32 = 0;
|
||||||
|
greset.b.txfflsh = 1;
|
||||||
|
greset.b.txfnum = num;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->GRSTCTL, greset.d32 );
|
||||||
|
do
|
||||||
|
{
|
||||||
|
greset.d32 = USB_OTG_READ_REG32( &pdev->regs.GREGS->GRSTCTL);
|
||||||
|
if (++count > 200000)
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (greset.b.txfflsh == 1);
|
||||||
|
/* Wait for 3 PHY Clocks*/
|
||||||
|
USB_OTG_BSP_uDelay(3);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_FlushRxFifo : Flush a Rx FIFO
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_FlushRxFifo( USB_OTG_CORE_HANDLE *pdev )
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
__IO USB_OTG_GRSTCTL_TypeDef greset;
|
||||||
|
uint32_t count = 0;
|
||||||
|
|
||||||
|
greset.d32 = 0;
|
||||||
|
greset.b.rxfflsh = 1;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->GRSTCTL, greset.d32 );
|
||||||
|
do
|
||||||
|
{
|
||||||
|
greset.d32 = USB_OTG_READ_REG32( &pdev->regs.GREGS->GRSTCTL);
|
||||||
|
if (++count > 200000)
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (greset.b.rxfflsh == 1);
|
||||||
|
/* Wait for 3 PHY Clocks*/
|
||||||
|
USB_OTG_BSP_uDelay(3);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_SetCurrentMode : Set ID line
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param mode : (Host/device)
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_SetCurrentMode(USB_OTG_CORE_HANDLE *pdev , uint8_t mode)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_GUSBCFG_TypeDef usbcfg;
|
||||||
|
|
||||||
|
usbcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GUSBCFG);
|
||||||
|
|
||||||
|
usbcfg.b.force_host = 0;
|
||||||
|
usbcfg.b.force_dev = 0;
|
||||||
|
|
||||||
|
if ( mode == HOST_MODE)
|
||||||
|
{
|
||||||
|
usbcfg.b.force_host = 1;
|
||||||
|
}
|
||||||
|
else if ( mode == DEVICE_MODE)
|
||||||
|
{
|
||||||
|
usbcfg.b.force_dev = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GUSBCFG, usbcfg.d32);
|
||||||
|
USB_OTG_BSP_mDelay(50);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_GetMode : Get current mode
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval current mode
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_GetMode(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
return (USB_OTG_READ_REG32(&pdev->regs.GREGS->GINTSTS ) & 0x1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_IsDeviceMode : Check if it is device mode
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval num_in_ep
|
||||||
|
*/
|
||||||
|
uint8_t USB_OTG_IsDeviceMode(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
return (USB_OTG_GetMode(pdev) != HOST_MODE);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_IsHostMode : Check if it is host mode
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval num_in_ep
|
||||||
|
*/
|
||||||
|
uint8_t USB_OTG_IsHostMode(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
return (USB_OTG_GetMode(pdev) == HOST_MODE);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_ReadCoreItr : returns the Core Interrupt register
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval Status
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_ReadCoreItr(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
uint32_t v = 0;
|
||||||
|
v = USB_OTG_READ_REG32(&pdev->regs.GREGS->GINTSTS);
|
||||||
|
v &= USB_OTG_READ_REG32(&pdev->regs.GREGS->GINTMSK);
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_ReadOtgItr : returns the USB_OTG Interrupt register
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval Status
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_ReadOtgItr (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
return (USB_OTG_READ_REG32 (&pdev->regs.GREGS->GOTGINT));
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef USE_HOST_MODE
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_CoreInitHost : Initializes USB_OTG controller for host mode
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_CoreInitHost(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_FSIZ_TypeDef nptxfifosize;
|
||||||
|
USB_OTG_FSIZ_TypeDef ptxfifosize;
|
||||||
|
USB_OTG_HCFG_TypeDef hcfg;
|
||||||
|
|
||||||
|
#ifdef USE_OTG_MODE
|
||||||
|
USB_OTG_OTGCTL_TypeDef gotgctl;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
uint32_t i = 0;
|
||||||
|
|
||||||
|
nptxfifosize.d32 = 0;
|
||||||
|
ptxfifosize.d32 = 0;
|
||||||
|
#ifdef USE_OTG_MODE
|
||||||
|
gotgctl.d32 = 0;
|
||||||
|
#endif
|
||||||
|
hcfg.d32 = 0;
|
||||||
|
|
||||||
|
|
||||||
|
/* configure charge pump IO */
|
||||||
|
USB_OTG_BSP_ConfigVBUS(pdev);
|
||||||
|
|
||||||
|
/* Restart the Phy Clock */
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.PCGCCTL, 0);
|
||||||
|
|
||||||
|
/* Initialize Host Configuration Register */
|
||||||
|
USB_OTG_InitFSLSPClkSel(pdev , HCFG_48_MHZ); /* in init phase */
|
||||||
|
|
||||||
|
hcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.HREGS->HCFG);
|
||||||
|
hcfg.b.fslssupp = 0;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HREGS->HCFG, hcfg.d32);
|
||||||
|
|
||||||
|
/* Configure data FIFO sizes */
|
||||||
|
/* Rx FIFO */
|
||||||
|
#ifdef USB_OTG_FS_CORE
|
||||||
|
if(pdev->cfg.coreID == USB_OTG_FS_CORE_ID)
|
||||||
|
{
|
||||||
|
/* set Rx FIFO size */
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GRXFSIZ, RX_FIFO_FS_SIZE);
|
||||||
|
nptxfifosize.b.startaddr = RX_FIFO_FS_SIZE;
|
||||||
|
nptxfifosize.b.depth = TXH_NP_FS_FIFOSIZ;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->DIEPTXF0_HNPTXFSIZ, nptxfifosize.d32);
|
||||||
|
|
||||||
|
ptxfifosize.b.startaddr = RX_FIFO_FS_SIZE + TXH_NP_FS_FIFOSIZ;
|
||||||
|
ptxfifosize.b.depth = TXH_P_FS_FIFOSIZ;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->HPTXFSIZ, ptxfifosize.d32);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef USB_OTG_HS_CORE
|
||||||
|
if (pdev->cfg.coreID == USB_OTG_HS_CORE_ID)
|
||||||
|
{
|
||||||
|
/* set Rx FIFO size */
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GRXFSIZ, RX_FIFO_HS_SIZE);
|
||||||
|
nptxfifosize.b.startaddr = RX_FIFO_HS_SIZE;
|
||||||
|
nptxfifosize.b.depth = TXH_NP_HS_FIFOSIZ;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->DIEPTXF0_HNPTXFSIZ, nptxfifosize.d32);
|
||||||
|
|
||||||
|
ptxfifosize.b.startaddr = RX_FIFO_HS_SIZE + TXH_NP_HS_FIFOSIZ;
|
||||||
|
ptxfifosize.b.depth = TXH_P_HS_FIFOSIZ;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->HPTXFSIZ, ptxfifosize.d32);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef USE_OTG_MODE
|
||||||
|
/* Clear Host Set HNP Enable in the USB_OTG Control Register */
|
||||||
|
gotgctl.b.hstsethnpen = 1;
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.GREGS->GOTGCTL, gotgctl.d32, 0);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Make sure the FIFOs are flushed. */
|
||||||
|
USB_OTG_FlushTxFifo(pdev, 0x10 ); /* all Tx FIFOs */
|
||||||
|
USB_OTG_FlushRxFifo(pdev);
|
||||||
|
|
||||||
|
|
||||||
|
/* Clear all pending HC Interrupts */
|
||||||
|
for (i = 0; i < pdev->cfg.host_channels; i++)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.HC_REGS[i]->HCINT, 0xFFFFFFFF );
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.HC_REGS[i]->HCGINTMSK, 0 );
|
||||||
|
}
|
||||||
|
#ifndef USE_OTG_MODE
|
||||||
|
USB_OTG_DriveVbus(pdev, 1);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
USB_OTG_EnableHostInt(pdev);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_IsEvenFrame
|
||||||
|
* This function returns the frame number for sof packet
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval Frame number
|
||||||
|
*/
|
||||||
|
uint8_t USB_OTG_IsEvenFrame (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
return !(USB_OTG_READ_REG32(&pdev->regs.HREGS->HFNUM) & 0x1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_DriveVbus : set/reset vbus
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param state : VBUS state
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
void USB_OTG_DriveVbus (USB_OTG_CORE_HANDLE *pdev, uint8_t state)
|
||||||
|
{
|
||||||
|
USB_OTG_HPRT0_TypeDef hprt0;
|
||||||
|
|
||||||
|
hprt0.d32 = 0;
|
||||||
|
|
||||||
|
/* enable disable the external charge pump */
|
||||||
|
USB_OTG_BSP_DriveVBUS(pdev, state);
|
||||||
|
|
||||||
|
/* Turn on the Host port power. */
|
||||||
|
hprt0.d32 = USB_OTG_ReadHPRT0(pdev);
|
||||||
|
if ((hprt0.b.prtpwr == 0 ) && (state == 1 ))
|
||||||
|
{
|
||||||
|
hprt0.b.prtpwr = 1;
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.HPRT0, hprt0.d32);
|
||||||
|
}
|
||||||
|
if ((hprt0.b.prtpwr == 1 ) && (state == 0 ))
|
||||||
|
{
|
||||||
|
hprt0.b.prtpwr = 0;
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.HPRT0, hprt0.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_BSP_mDelay(200);
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_EnableHostInt: Enables the Host mode interrupts
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EnableHostInt(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_GINTMSK_TypeDef intmsk;
|
||||||
|
intmsk.d32 = 0;
|
||||||
|
/* Disable all interrupts. */
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GINTMSK, 0);
|
||||||
|
|
||||||
|
/* Clear any pending interrupts. */
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GINTSTS, 0xFFFFFFFF);
|
||||||
|
|
||||||
|
/* Enable the common interrupts */
|
||||||
|
USB_OTG_EnableCommonInt(pdev);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 0)
|
||||||
|
{
|
||||||
|
intmsk.b.rxstsqlvl = 1;
|
||||||
|
}
|
||||||
|
intmsk.b.portintr = 1;
|
||||||
|
intmsk.b.hcintr = 1;
|
||||||
|
intmsk.b.disconnect = 1;
|
||||||
|
intmsk.b.sofintr = 1;
|
||||||
|
intmsk.b.incomplisoout = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.GREGS->GINTMSK, intmsk.d32, intmsk.d32);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_InitFSLSPClkSel : Initializes the FSLSPClkSel field of the
|
||||||
|
* HCFG register on the PHY type
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param freq : clock frequency
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
void USB_OTG_InitFSLSPClkSel(USB_OTG_CORE_HANDLE *pdev , uint8_t freq)
|
||||||
|
{
|
||||||
|
USB_OTG_HCFG_TypeDef hcfg;
|
||||||
|
|
||||||
|
hcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.HREGS->HCFG);
|
||||||
|
hcfg.b.fslspclksel = freq;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HREGS->HCFG, hcfg.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_ReadHPRT0 : Reads HPRT0 to modify later
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval HPRT0 value
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_ReadHPRT0(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_HPRT0_TypeDef hprt0;
|
||||||
|
|
||||||
|
hprt0.d32 = USB_OTG_READ_REG32(pdev->regs.HPRT0);
|
||||||
|
hprt0.b.prtena = 0;
|
||||||
|
hprt0.b.prtconndet = 0;
|
||||||
|
hprt0.b.prtenchng = 0;
|
||||||
|
hprt0.b.prtovrcurrchng = 0;
|
||||||
|
return hprt0.d32;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_ReadHostAllChannels_intr : Register PCD Callbacks
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval Status
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_ReadHostAllChannels_intr (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
return (USB_OTG_READ_REG32 (&pdev->regs.HREGS->HAINT));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_ResetPort : Reset Host Port
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval status
|
||||||
|
* @note : (1)The application must wait at least 10 ms (+ 10 ms security)
|
||||||
|
* before clearing the reset bit.
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_ResetPort(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_HPRT0_TypeDef hprt0;
|
||||||
|
|
||||||
|
hprt0.d32 = USB_OTG_ReadHPRT0(pdev);
|
||||||
|
hprt0.b.prtrst = 1;
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.HPRT0, hprt0.d32);
|
||||||
|
USB_OTG_BSP_mDelay (10); /* See Note #1 */
|
||||||
|
hprt0.b.prtrst = 0;
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.HPRT0, hprt0.d32);
|
||||||
|
USB_OTG_BSP_mDelay (20);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_HC_Init : Prepares a host channel for transferring packets
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param hc_num : channel number
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_HC_Init(USB_OTG_CORE_HANDLE *pdev , uint8_t hc_num)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
uint32_t intr_enable = 0;
|
||||||
|
USB_OTG_HCGINTMSK_TypeDef hcintmsk;
|
||||||
|
USB_OTG_GINTMSK_TypeDef gintmsk;
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
USB_OTG_HCINTn_TypeDef hcint;
|
||||||
|
|
||||||
|
|
||||||
|
gintmsk.d32 = 0;
|
||||||
|
hcintmsk.d32 = 0;
|
||||||
|
hcchar.d32 = 0;
|
||||||
|
|
||||||
|
/* Clear old interrupt conditions for this host channel. */
|
||||||
|
hcint.d32 = 0xFFFFFFFF;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCINT, hcint.d32);
|
||||||
|
|
||||||
|
/* Enable channel interrupts required for this transfer. */
|
||||||
|
hcintmsk.d32 = 0;
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
hcintmsk.b.ahberr = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (pdev->host.hc[hc_num].ep_type)
|
||||||
|
{
|
||||||
|
case EP_TYPE_CTRL:
|
||||||
|
case EP_TYPE_BULK:
|
||||||
|
hcintmsk.b.xfercompl = 1;
|
||||||
|
hcintmsk.b.stall = 1;
|
||||||
|
hcintmsk.b.xacterr = 1;
|
||||||
|
hcintmsk.b.datatglerr = 1;
|
||||||
|
hcintmsk.b.nak = 1;
|
||||||
|
if (pdev->host.hc[hc_num].ep_is_in)
|
||||||
|
{
|
||||||
|
hcintmsk.b.bblerr = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hcintmsk.b.nyet = 1;
|
||||||
|
if (pdev->host.hc[hc_num].do_ping)
|
||||||
|
{
|
||||||
|
hcintmsk.b.ack = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case EP_TYPE_INTR:
|
||||||
|
hcintmsk.b.xfercompl = 1;
|
||||||
|
hcintmsk.b.nak = 1;
|
||||||
|
hcintmsk.b.stall = 1;
|
||||||
|
hcintmsk.b.xacterr = 1;
|
||||||
|
hcintmsk.b.datatglerr = 1;
|
||||||
|
hcintmsk.b.frmovrun = 1;
|
||||||
|
|
||||||
|
if (pdev->host.hc[hc_num].ep_is_in)
|
||||||
|
{
|
||||||
|
hcintmsk.b.bblerr = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
case EP_TYPE_ISOC:
|
||||||
|
hcintmsk.b.xfercompl = 1;
|
||||||
|
hcintmsk.b.frmovrun = 1;
|
||||||
|
hcintmsk.b.ack = 1;
|
||||||
|
|
||||||
|
if (pdev->host.hc[hc_num].ep_is_in)
|
||||||
|
{
|
||||||
|
hcintmsk.b.xacterr = 1;
|
||||||
|
hcintmsk.b.bblerr = 1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCGINTMSK, hcintmsk.d32);
|
||||||
|
|
||||||
|
|
||||||
|
/* Enable the top level host channel interrupt. */
|
||||||
|
intr_enable = (1 << hc_num);
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.HREGS->HAINTMSK, 0, intr_enable);
|
||||||
|
|
||||||
|
/* Make sure host channel interrupts are enabled. */
|
||||||
|
gintmsk.b.hcintr = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.GREGS->GINTMSK, 0, gintmsk.d32);
|
||||||
|
|
||||||
|
/* Program the HCCHAR register */
|
||||||
|
hcchar.d32 = 0;
|
||||||
|
hcchar.b.devaddr = pdev->host.hc[hc_num].dev_addr;
|
||||||
|
hcchar.b.epnum = pdev->host.hc[hc_num].ep_num;
|
||||||
|
hcchar.b.epdir = pdev->host.hc[hc_num].ep_is_in;
|
||||||
|
hcchar.b.lspddev = (pdev->host.hc[hc_num].speed == HPRT0_PRTSPD_LOW_SPEED);
|
||||||
|
hcchar.b.eptype = pdev->host.hc[hc_num].ep_type;
|
||||||
|
hcchar.b.mps = pdev->host.hc[hc_num].max_packet;
|
||||||
|
if (pdev->host.hc[hc_num].ep_type == HCCHAR_INTR)
|
||||||
|
{
|
||||||
|
hcchar.b.oddfrm = 1;
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCCHAR, hcchar.d32);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_HC_StartXfer : Start transfer
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param hc_num : channel number
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_HC_StartXfer(USB_OTG_CORE_HANDLE *pdev , uint8_t hc_num)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
USB_OTG_HCTSIZn_TypeDef hctsiz;
|
||||||
|
USB_OTG_HNPTXSTS_TypeDef hnptxsts;
|
||||||
|
USB_OTG_HPTXSTS_TypeDef hptxsts;
|
||||||
|
USB_OTG_GINTMSK_TypeDef intmsk;
|
||||||
|
uint16_t len_words = 0;
|
||||||
|
|
||||||
|
uint16_t num_packets;
|
||||||
|
uint16_t max_hc_pkt_count;
|
||||||
|
|
||||||
|
max_hc_pkt_count = 256;
|
||||||
|
hctsiz.d32 = 0;
|
||||||
|
hcchar.d32 = 0;
|
||||||
|
intmsk.d32 = 0;
|
||||||
|
|
||||||
|
/* Compute the expected number of packets associated to the transfer */
|
||||||
|
if (pdev->host.hc[hc_num].xfer_len > 0)
|
||||||
|
{
|
||||||
|
num_packets = (pdev->host.hc[hc_num].xfer_len + \
|
||||||
|
pdev->host.hc[hc_num].max_packet - 1) / pdev->host.hc[hc_num].max_packet;
|
||||||
|
|
||||||
|
if (num_packets > max_hc_pkt_count)
|
||||||
|
{
|
||||||
|
num_packets = max_hc_pkt_count;
|
||||||
|
pdev->host.hc[hc_num].xfer_len = num_packets * \
|
||||||
|
pdev->host.hc[hc_num].max_packet;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
num_packets = 1;
|
||||||
|
}
|
||||||
|
if (pdev->host.hc[hc_num].ep_is_in)
|
||||||
|
{
|
||||||
|
pdev->host.hc[hc_num].xfer_len = num_packets * \
|
||||||
|
pdev->host.hc[hc_num].max_packet;
|
||||||
|
}
|
||||||
|
/* Initialize the HCTSIZn register */
|
||||||
|
hctsiz.b.xfersize = pdev->host.hc[hc_num].xfer_len;
|
||||||
|
hctsiz.b.pktcnt = num_packets;
|
||||||
|
hctsiz.b.pid = pdev->host.hc[hc_num].data_pid;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCTSIZ, hctsiz.d32);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCDMA, (unsigned int)pdev->host.hc[hc_num].xfer_buff);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
hcchar.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[hc_num]->HCCHAR);
|
||||||
|
hcchar.b.oddfrm = USB_OTG_IsEvenFrame(pdev);
|
||||||
|
|
||||||
|
/* Set host channel enable */
|
||||||
|
hcchar.b.chen = 1;
|
||||||
|
hcchar.b.chdis = 0;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCCHAR, hcchar.d32);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 0) /* Slave mode */
|
||||||
|
{
|
||||||
|
if((pdev->host.hc[hc_num].ep_is_in == 0) &&
|
||||||
|
(pdev->host.hc[hc_num].xfer_len > 0))
|
||||||
|
{
|
||||||
|
switch(pdev->host.hc[hc_num].ep_type)
|
||||||
|
{
|
||||||
|
/* Non periodic transfer */
|
||||||
|
case EP_TYPE_CTRL:
|
||||||
|
case EP_TYPE_BULK:
|
||||||
|
|
||||||
|
hnptxsts.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->HNPTXSTS);
|
||||||
|
len_words = (pdev->host.hc[hc_num].xfer_len + 3) / 4;
|
||||||
|
|
||||||
|
/* check if there is enough space in FIFO space */
|
||||||
|
if(len_words > hnptxsts.b.nptxfspcavail)
|
||||||
|
{
|
||||||
|
/* need to process data in nptxfempty interrupt */
|
||||||
|
intmsk.b.nptxfempty = 1;
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.GREGS->GINTMSK, 0, intmsk.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
/* Periodic transfer */
|
||||||
|
case EP_TYPE_INTR:
|
||||||
|
case EP_TYPE_ISOC:
|
||||||
|
hptxsts.d32 = USB_OTG_READ_REG32(&pdev->regs.HREGS->HPTXSTS);
|
||||||
|
len_words = (pdev->host.hc[hc_num].xfer_len + 3) / 4;
|
||||||
|
/* check if there is enough space in FIFO space */
|
||||||
|
if(len_words > hptxsts.b.ptxfspcavail) /* split the transfer */
|
||||||
|
{
|
||||||
|
/* need to process data in ptxfempty interrupt */
|
||||||
|
intmsk.b.ptxfempty = 1;
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.GREGS->GINTMSK, 0, intmsk.d32);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Write packet into the Tx FIFO. */
|
||||||
|
USB_OTG_WritePacket(pdev,
|
||||||
|
pdev->host.hc[hc_num].xfer_buff ,
|
||||||
|
hc_num, pdev->host.hc[hc_num].xfer_len);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_HC_Halt : Halt channel
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param hc_num : channel number
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_HC_Halt(USB_OTG_CORE_HANDLE *pdev , uint8_t hc_num)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_HNPTXSTS_TypeDef nptxsts;
|
||||||
|
USB_OTG_HPTXSTS_TypeDef hptxsts;
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
|
||||||
|
nptxsts.d32 = 0;
|
||||||
|
hptxsts.d32 = 0;
|
||||||
|
hcchar.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[hc_num]->HCCHAR);
|
||||||
|
hcchar.b.chen = 1;
|
||||||
|
hcchar.b.chdis = 1;
|
||||||
|
|
||||||
|
/* Check for space in the request queue to issue the halt. */
|
||||||
|
if (hcchar.b.eptype == HCCHAR_CTRL || hcchar.b.eptype == HCCHAR_BULK)
|
||||||
|
{
|
||||||
|
nptxsts.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->HNPTXSTS);
|
||||||
|
if (nptxsts.b.nptxqspcavail == 0)
|
||||||
|
{
|
||||||
|
hcchar.b.chen = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hptxsts.d32 = USB_OTG_READ_REG32(&pdev->regs.HREGS->HPTXSTS);
|
||||||
|
if (hptxsts.b.ptxqspcavail == 0)
|
||||||
|
{
|
||||||
|
hcchar.b.chen = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCCHAR, hcchar.d32);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Issue a ping token
|
||||||
|
* @param None
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_HC_DoPing(USB_OTG_CORE_HANDLE *pdev , uint8_t hc_num)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
USB_OTG_HCTSIZn_TypeDef hctsiz;
|
||||||
|
|
||||||
|
hctsiz.d32 = 0;
|
||||||
|
hctsiz.b.dopng = 1;
|
||||||
|
hctsiz.b.pktcnt = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCTSIZ, hctsiz.d32);
|
||||||
|
|
||||||
|
hcchar.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[hc_num]->HCCHAR);
|
||||||
|
hcchar.b.chen = 1;
|
||||||
|
hcchar.b.chdis = 0;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[hc_num]->HCCHAR, hcchar.d32);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Stop the device and clean up fifo's
|
||||||
|
* @param None
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void USB_OTG_StopHost(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
uint32_t i;
|
||||||
|
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HREGS->HAINTMSK , 0);
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HREGS->HAINT, 0xFFFFFFFF);
|
||||||
|
/* Flush out any leftover queued requests. */
|
||||||
|
|
||||||
|
for (i = 0; i < pdev->cfg.host_channels; i++)
|
||||||
|
{
|
||||||
|
hcchar.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[i]->HCCHAR);
|
||||||
|
hcchar.b.chen = 0;
|
||||||
|
hcchar.b.chdis = 1;
|
||||||
|
hcchar.b.epdir = 0;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[i]->HCCHAR, hcchar.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Flush the FIFO */
|
||||||
|
USB_OTG_FlushRxFifo(pdev);
|
||||||
|
USB_OTG_FlushTxFifo(pdev , 0x10 );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef USE_DEVICE_MODE
|
||||||
|
/* PCD Core Layer */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_InitDevSpeed :Initializes the DevSpd field of DCFG register
|
||||||
|
* depending the PHY type and the enumeration speed of the device.
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void USB_OTG_InitDevSpeed(USB_OTG_CORE_HANDLE *pdev , uint8_t speed)
|
||||||
|
{
|
||||||
|
USB_OTG_DCFG_TypeDef dcfg;
|
||||||
|
|
||||||
|
dcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DCFG);
|
||||||
|
dcfg.b.devspd = speed;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.DREGS->DCFG, dcfg.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_CoreInitDev : Initializes the USB_OTG controller registers
|
||||||
|
* for device mode
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_CoreInitDev (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
uint32_t i;
|
||||||
|
USB_OTG_DCFG_TypeDef dcfg;
|
||||||
|
USB_OTG_FSIZ_TypeDef nptxfifosize;
|
||||||
|
USB_OTG_FSIZ_TypeDef txfifosize;
|
||||||
|
USB_OTG_DIEPMSK_TypeDef msk;
|
||||||
|
USB_OTG_DTHRCTL_TypeDef dthrctl;
|
||||||
|
|
||||||
|
depctl.d32 = 0;
|
||||||
|
dcfg.d32 = 0;
|
||||||
|
nptxfifosize.d32 = 0;
|
||||||
|
txfifosize.d32 = 0;
|
||||||
|
msk.d32 = 0;
|
||||||
|
|
||||||
|
/* Restart the Phy Clock */
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.PCGCCTL, 0);
|
||||||
|
/* Device configuration register */
|
||||||
|
dcfg.d32 = USB_OTG_READ_REG32( &pdev->regs.DREGS->DCFG);
|
||||||
|
dcfg.b.perfrint = DCFG_FRAME_INTERVAL_80;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DCFG, dcfg.d32 );
|
||||||
|
|
||||||
|
#ifdef USB_OTG_FS_CORE
|
||||||
|
if(pdev->cfg.coreID == USB_OTG_FS_CORE_ID )
|
||||||
|
{
|
||||||
|
|
||||||
|
/* Set Full speed phy */
|
||||||
|
USB_OTG_InitDevSpeed (pdev , USB_OTG_SPEED_PARAM_FULL);
|
||||||
|
|
||||||
|
/* set Rx FIFO size */
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GRXFSIZ, RX_FIFO_FS_SIZE);
|
||||||
|
|
||||||
|
/* EP0 TX*/
|
||||||
|
nptxfifosize.b.depth = TX0_FIFO_FS_SIZE;
|
||||||
|
nptxfifosize.b.startaddr = RX_FIFO_FS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF0_HNPTXFSIZ, nptxfifosize.d32 );
|
||||||
|
|
||||||
|
|
||||||
|
/* EP1 TX*/
|
||||||
|
txfifosize.b.startaddr = nptxfifosize.b.startaddr + nptxfifosize.b.depth;
|
||||||
|
txfifosize.b.depth = TX1_FIFO_FS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF[0], txfifosize.d32 );
|
||||||
|
|
||||||
|
|
||||||
|
/* EP2 TX*/
|
||||||
|
txfifosize.b.startaddr += txfifosize.b.depth;
|
||||||
|
txfifosize.b.depth = TX2_FIFO_FS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF[1], txfifosize.d32 );
|
||||||
|
|
||||||
|
|
||||||
|
/* EP3 TX*/
|
||||||
|
txfifosize.b.startaddr += txfifosize.b.depth;
|
||||||
|
txfifosize.b.depth = TX3_FIFO_FS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF[2], txfifosize.d32 );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef USB_OTG_HS_CORE
|
||||||
|
if(pdev->cfg.coreID == USB_OTG_HS_CORE_ID )
|
||||||
|
{
|
||||||
|
|
||||||
|
/* Set High speed phy */
|
||||||
|
|
||||||
|
if(pdev->cfg.phy_itface == USB_OTG_ULPI_PHY)
|
||||||
|
{
|
||||||
|
USB_OTG_InitDevSpeed (pdev , USB_OTG_SPEED_PARAM_HIGH);
|
||||||
|
}
|
||||||
|
else /* set High speed phy in Full speed mode */
|
||||||
|
{
|
||||||
|
USB_OTG_InitDevSpeed (pdev , USB_OTG_SPEED_PARAM_HIGH_IN_FULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set Rx FIFO size */
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GRXFSIZ, RX_FIFO_HS_SIZE);
|
||||||
|
|
||||||
|
/* EP0 TX*/
|
||||||
|
nptxfifosize.b.depth = TX0_FIFO_HS_SIZE;
|
||||||
|
nptxfifosize.b.startaddr = RX_FIFO_HS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF0_HNPTXFSIZ, nptxfifosize.d32 );
|
||||||
|
|
||||||
|
|
||||||
|
/* EP1 TX*/
|
||||||
|
txfifosize.b.startaddr = nptxfifosize.b.startaddr + nptxfifosize.b.depth;
|
||||||
|
txfifosize.b.depth = TX1_FIFO_HS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF[0], txfifosize.d32 );
|
||||||
|
|
||||||
|
|
||||||
|
/* EP2 TX*/
|
||||||
|
txfifosize.b.startaddr += txfifosize.b.depth;
|
||||||
|
txfifosize.b.depth = TX2_FIFO_HS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF[1], txfifosize.d32 );
|
||||||
|
|
||||||
|
|
||||||
|
/* EP3 TX*/
|
||||||
|
txfifosize.b.startaddr += txfifosize.b.depth;
|
||||||
|
txfifosize.b.depth = TX3_FIFO_HS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF[2], txfifosize.d32 );
|
||||||
|
|
||||||
|
/* EP4 TX*/
|
||||||
|
txfifosize.b.startaddr += txfifosize.b.depth;
|
||||||
|
txfifosize.b.depth = TX4_FIFO_HS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF[3], txfifosize.d32 );
|
||||||
|
|
||||||
|
|
||||||
|
/* EP5 TX*/
|
||||||
|
txfifosize.b.startaddr += txfifosize.b.depth;
|
||||||
|
txfifosize.b.depth = TX5_FIFO_HS_SIZE;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->DIEPTXF[4], txfifosize.d32 );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
/* Flush the FIFOs */
|
||||||
|
USB_OTG_FlushTxFifo(pdev , 0x10); /* all Tx FIFOs */
|
||||||
|
USB_OTG_FlushRxFifo(pdev);
|
||||||
|
/* Clear all pending Device Interrupts */
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DIEPMSK, 0 );
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DOEPMSK, 0 );
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DAINT, 0xFFFFFFFF );
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DAINTMSK, 0 );
|
||||||
|
|
||||||
|
for (i = 0; i < pdev->cfg.dev_endpoints; i++)
|
||||||
|
{
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(&pdev->regs.INEP_REGS[i]->DIEPCTL);
|
||||||
|
if (depctl.b.epena)
|
||||||
|
{
|
||||||
|
depctl.d32 = 0;
|
||||||
|
depctl.b.epdis = 1;
|
||||||
|
depctl.b.snak = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
depctl.d32 = 0;
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.INEP_REGS[i]->DIEPCTL, depctl.d32);
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.INEP_REGS[i]->DIEPTSIZ, 0);
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.INEP_REGS[i]->DIEPINT, 0xFF);
|
||||||
|
}
|
||||||
|
for (i = 0; i < pdev->cfg.dev_endpoints; i++)
|
||||||
|
{
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(&pdev->regs.OUTEP_REGS[i]->DOEPCTL);
|
||||||
|
if (depctl.b.epena)
|
||||||
|
{
|
||||||
|
depctl.d32 = 0;
|
||||||
|
depctl.b.epdis = 1;
|
||||||
|
depctl.b.snak = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
depctl.d32 = 0;
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.OUTEP_REGS[i]->DOEPCTL, depctl.d32);
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.OUTEP_REGS[i]->DOEPTSIZ, 0);
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.OUTEP_REGS[i]->DOEPINT, 0xFF);
|
||||||
|
}
|
||||||
|
msk.d32 = 0;
|
||||||
|
msk.b.txfifoundrn = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DIEPMSK, msk.d32, msk.d32);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
dthrctl.d32 = 0;
|
||||||
|
dthrctl.b.non_iso_thr_en = 1;
|
||||||
|
dthrctl.b.iso_thr_en = 1;
|
||||||
|
dthrctl.b.tx_thr_len = 64;
|
||||||
|
dthrctl.b.rx_thr_en = 1;
|
||||||
|
dthrctl.b.rx_thr_len = 64;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.DREGS->DTHRCTL, dthrctl.d32);
|
||||||
|
}
|
||||||
|
USB_OTG_EnableDevInt(pdev);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_EnableDevInt : Enables the Device mode interrupts
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EnableDevInt(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_GINTMSK_TypeDef intmsk;
|
||||||
|
|
||||||
|
intmsk.d32 = 0;
|
||||||
|
|
||||||
|
/* Disable all interrupts. */
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->GINTMSK, 0);
|
||||||
|
/* Clear any pending interrupts */
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->GINTSTS, 0xFFFFFFFF);
|
||||||
|
/* Enable the common interrupts */
|
||||||
|
USB_OTG_EnableCommonInt(pdev);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 0)
|
||||||
|
{
|
||||||
|
intmsk.b.rxstsqlvl = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Enable interrupts matching to the Device mode ONLY */
|
||||||
|
intmsk.b.usbsuspend = 1;
|
||||||
|
intmsk.b.usbreset = 1;
|
||||||
|
intmsk.b.enumdone = 1;
|
||||||
|
intmsk.b.inepintr = 1;
|
||||||
|
intmsk.b.outepintr = 1;
|
||||||
|
intmsk.b.sofintr = 1;
|
||||||
|
|
||||||
|
intmsk.b.incomplisoin = 1;
|
||||||
|
intmsk.b.incomplisoout = 1;
|
||||||
|
#ifdef VBUS_SENSING_ENABLED
|
||||||
|
intmsk.b.sessreqintr = 1;
|
||||||
|
intmsk.b.otgintr = 1;
|
||||||
|
#endif
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.GREGS->GINTMSK, intmsk.d32, intmsk.d32);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_GetDeviceSpeed
|
||||||
|
* Get the device speed from the device status register
|
||||||
|
* @param None
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
enum USB_OTG_SPEED USB_OTG_GetDeviceSpeed (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_DSTS_TypeDef dsts;
|
||||||
|
enum USB_OTG_SPEED speed = USB_SPEED_UNKNOWN;
|
||||||
|
|
||||||
|
|
||||||
|
dsts.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DSTS);
|
||||||
|
|
||||||
|
switch (dsts.b.enumspd)
|
||||||
|
{
|
||||||
|
case DSTS_ENUMSPD_HS_PHY_30MHZ_OR_60MHZ:
|
||||||
|
speed = USB_SPEED_HIGH;
|
||||||
|
break;
|
||||||
|
case DSTS_ENUMSPD_FS_PHY_30MHZ_OR_60MHZ:
|
||||||
|
case DSTS_ENUMSPD_FS_PHY_48MHZ:
|
||||||
|
speed = USB_SPEED_FULL;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case DSTS_ENUMSPD_LS_PHY_6MHZ:
|
||||||
|
speed = USB_SPEED_LOW;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return speed;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief enables EP0 OUT to receive SETUP packets and configures EP0
|
||||||
|
* for transmitting packets
|
||||||
|
* @param None
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EP0Activate(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_DSTS_TypeDef dsts;
|
||||||
|
USB_OTG_DEPCTL_TypeDef diepctl;
|
||||||
|
USB_OTG_DCTL_TypeDef dctl;
|
||||||
|
|
||||||
|
dctl.d32 = 0;
|
||||||
|
/* Read the Device Status and Endpoint 0 Control registers */
|
||||||
|
dsts.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DSTS);
|
||||||
|
diepctl.d32 = USB_OTG_READ_REG32(&pdev->regs.INEP_REGS[0]->DIEPCTL);
|
||||||
|
/* Set the MPS of the IN EP based on the enumeration speed */
|
||||||
|
switch (dsts.b.enumspd)
|
||||||
|
{
|
||||||
|
case DSTS_ENUMSPD_HS_PHY_30MHZ_OR_60MHZ:
|
||||||
|
case DSTS_ENUMSPD_FS_PHY_30MHZ_OR_60MHZ:
|
||||||
|
case DSTS_ENUMSPD_FS_PHY_48MHZ:
|
||||||
|
diepctl.b.mps = DEP0CTL_MPS_64;
|
||||||
|
break;
|
||||||
|
case DSTS_ENUMSPD_LS_PHY_6MHZ:
|
||||||
|
diepctl.b.mps = DEP0CTL_MPS_8;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.INEP_REGS[0]->DIEPCTL, diepctl.d32);
|
||||||
|
dctl.b.cgnpinnak = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DCTL, dctl.d32, dctl.d32);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_EPActivate : Activates an EP
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EPActivate(USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
USB_OTG_DAINT_TypeDef daintmsk;
|
||||||
|
__IO uint32_t *addr;
|
||||||
|
|
||||||
|
|
||||||
|
depctl.d32 = 0;
|
||||||
|
daintmsk.d32 = 0;
|
||||||
|
/* Read DEPCTLn register */
|
||||||
|
if (ep->is_in == 1)
|
||||||
|
{
|
||||||
|
addr = &pdev->regs.INEP_REGS[ep->num]->DIEPCTL;
|
||||||
|
daintmsk.ep.in = 1 << ep->num;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
addr = &pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL;
|
||||||
|
daintmsk.ep.out = 1 << ep->num;
|
||||||
|
}
|
||||||
|
/* If the EP is already active don't change the EP Control
|
||||||
|
* register. */
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(addr);
|
||||||
|
if (!depctl.b.usbactep)
|
||||||
|
{
|
||||||
|
depctl.b.mps = ep->maxpacket;
|
||||||
|
depctl.b.eptype = ep->type;
|
||||||
|
depctl.b.txfnum = ep->tx_fifo_num;
|
||||||
|
depctl.b.setd0pid = 1;
|
||||||
|
depctl.b.usbactep = 1;
|
||||||
|
USB_OTG_WRITE_REG32(addr, depctl.d32);
|
||||||
|
}
|
||||||
|
/* Enable the Interrupt for this EP */
|
||||||
|
#ifdef USB_OTG_HS_DEDICATED_EP1_ENABLED
|
||||||
|
if((ep->num == 1)&&(pdev->cfg.coreID == USB_OTG_HS_CORE_ID))
|
||||||
|
{
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DEACHMSK, 0, daintmsk.d32);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DAINTMSK, 0, daintmsk.d32);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_EPDeactivate : Deactivates an EP
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EPDeactivate(USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
USB_OTG_DAINT_TypeDef daintmsk;
|
||||||
|
__IO uint32_t *addr;
|
||||||
|
|
||||||
|
depctl.d32 = 0;
|
||||||
|
daintmsk.d32 = 0;
|
||||||
|
/* Read DEPCTLn register */
|
||||||
|
if (ep->is_in == 1)
|
||||||
|
{
|
||||||
|
addr = &pdev->regs.INEP_REGS[ep->num]->DIEPCTL;
|
||||||
|
daintmsk.ep.in = 1 << ep->num;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
addr = &pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL;
|
||||||
|
daintmsk.ep.out = 1 << ep->num;
|
||||||
|
}
|
||||||
|
depctl.b.usbactep = 0;
|
||||||
|
USB_OTG_WRITE_REG32(addr, depctl.d32);
|
||||||
|
/* Disable the Interrupt for this EP */
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_DEDICATED_EP1_ENABLED
|
||||||
|
if((ep->num == 1)&&(pdev->cfg.coreID == USB_OTG_HS_CORE_ID))
|
||||||
|
{
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DEACHMSK, daintmsk.d32, 0);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DAINTMSK, daintmsk.d32, 0);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_EPStartXfer : Handle the setup for data xfer for an EP and
|
||||||
|
* starts the xfer
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EPStartXfer(USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
USB_OTG_DEPXFRSIZ_TypeDef deptsiz;
|
||||||
|
USB_OTG_DSTS_TypeDef dsts;
|
||||||
|
uint32_t fifoemptymsk = 0;
|
||||||
|
|
||||||
|
depctl.d32 = 0;
|
||||||
|
deptsiz.d32 = 0;
|
||||||
|
/* IN endpoint */
|
||||||
|
if (ep->is_in == 1)
|
||||||
|
{
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(&(pdev->regs.INEP_REGS[ep->num]->DIEPCTL));
|
||||||
|
deptsiz.d32 = USB_OTG_READ_REG32(&(pdev->regs.INEP_REGS[ep->num]->DIEPTSIZ));
|
||||||
|
/* Zero Length Packet? */
|
||||||
|
if (ep->xfer_len == 0)
|
||||||
|
{
|
||||||
|
deptsiz.b.xfersize = 0;
|
||||||
|
deptsiz.b.pktcnt = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Program the transfer size and packet count
|
||||||
|
* as follows: xfersize = N * maxpacket +
|
||||||
|
* short_packet pktcnt = N + (short_packet
|
||||||
|
* exist ? 1 : 0)
|
||||||
|
*/
|
||||||
|
deptsiz.b.xfersize = ep->xfer_len;
|
||||||
|
deptsiz.b.pktcnt = (ep->xfer_len - 1 + ep->maxpacket) / ep->maxpacket;
|
||||||
|
|
||||||
|
if (ep->type == EP_TYPE_ISOC)
|
||||||
|
{
|
||||||
|
deptsiz.b.mc = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.INEP_REGS[ep->num]->DIEPTSIZ, deptsiz.d32);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.INEP_REGS[ep->num]->DIEPDMA, ep->dma_addr);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (ep->type != EP_TYPE_ISOC)
|
||||||
|
{
|
||||||
|
/* Enable the Tx FIFO Empty Interrupt for this EP */
|
||||||
|
if (ep->xfer_len > 0)
|
||||||
|
{
|
||||||
|
fifoemptymsk = 1 << ep->num;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DIEPEMPMSK, 0, fifoemptymsk);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (ep->type == EP_TYPE_ISOC)
|
||||||
|
{
|
||||||
|
dsts.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DSTS);
|
||||||
|
|
||||||
|
if (((dsts.b.soffn)&0x1) == 0)
|
||||||
|
{
|
||||||
|
depctl.b.setd1pid = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
depctl.b.setd0pid = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* EP enable, IN data in FIFO */
|
||||||
|
depctl.b.cnak = 1;
|
||||||
|
depctl.b.epena = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.INEP_REGS[ep->num]->DIEPCTL, depctl.d32);
|
||||||
|
|
||||||
|
if (ep->type == EP_TYPE_ISOC)
|
||||||
|
{
|
||||||
|
USB_OTG_WritePacket(pdev, ep->xfer_buff, ep->num, ep->xfer_len);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* OUT endpoint */
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(&(pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL));
|
||||||
|
deptsiz.d32 = USB_OTG_READ_REG32(&(pdev->regs.OUTEP_REGS[ep->num]->DOEPTSIZ));
|
||||||
|
/* Program the transfer size and packet count as follows:
|
||||||
|
* pktcnt = N
|
||||||
|
* xfersize = N * maxpacket
|
||||||
|
*/
|
||||||
|
if (ep->xfer_len == 0)
|
||||||
|
{
|
||||||
|
deptsiz.b.xfersize = ep->maxpacket;
|
||||||
|
deptsiz.b.pktcnt = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
deptsiz.b.pktcnt = (ep->xfer_len + (ep->maxpacket - 1)) / ep->maxpacket;
|
||||||
|
deptsiz.b.xfersize = deptsiz.b.pktcnt * ep->maxpacket;
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.OUTEP_REGS[ep->num]->DOEPTSIZ, deptsiz.d32);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.OUTEP_REGS[ep->num]->DOEPDMA, ep->dma_addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ep->type == EP_TYPE_ISOC)
|
||||||
|
{
|
||||||
|
if (ep->even_odd_frame)
|
||||||
|
{
|
||||||
|
depctl.b.setd1pid = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
depctl.b.setd0pid = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* EP enable */
|
||||||
|
depctl.b.cnak = 1;
|
||||||
|
depctl.b.epena = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL, depctl.d32);
|
||||||
|
}
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_EP0StartXfer : Handle the setup for a data xfer for EP0 and
|
||||||
|
* starts the xfer
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EP0StartXfer(USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
USB_OTG_DEP0XFRSIZ_TypeDef deptsiz;
|
||||||
|
USB_OTG_INEPREGS *in_regs;
|
||||||
|
uint32_t fifoemptymsk = 0;
|
||||||
|
|
||||||
|
depctl.d32 = 0;
|
||||||
|
deptsiz.d32 = 0;
|
||||||
|
/* IN endpoint */
|
||||||
|
if (ep->is_in == 1)
|
||||||
|
{
|
||||||
|
in_regs = pdev->regs.INEP_REGS[0];
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(&in_regs->DIEPCTL);
|
||||||
|
deptsiz.d32 = USB_OTG_READ_REG32(&in_regs->DIEPTSIZ);
|
||||||
|
/* Zero Length Packet? */
|
||||||
|
if (ep->xfer_len == 0)
|
||||||
|
{
|
||||||
|
deptsiz.b.xfersize = 0;
|
||||||
|
deptsiz.b.pktcnt = 1;
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (ep->xfer_len > ep->maxpacket)
|
||||||
|
{
|
||||||
|
ep->xfer_len = ep->maxpacket;
|
||||||
|
deptsiz.b.xfersize = ep->maxpacket;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
deptsiz.b.xfersize = ep->xfer_len;
|
||||||
|
}
|
||||||
|
deptsiz.b.pktcnt = 1;
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32(&in_regs->DIEPTSIZ, deptsiz.d32);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.INEP_REGS[ep->num]->DIEPDMA, ep->dma_addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* EP enable, IN data in FIFO */
|
||||||
|
depctl.b.cnak = 1;
|
||||||
|
depctl.b.epena = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&in_regs->DIEPCTL, depctl.d32);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 0)
|
||||||
|
{
|
||||||
|
/* Enable the Tx FIFO Empty Interrupt for this EP */
|
||||||
|
if (ep->xfer_len > 0)
|
||||||
|
{
|
||||||
|
{
|
||||||
|
fifoemptymsk |= 1 << ep->num;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DIEPEMPMSK, 0, fifoemptymsk);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* OUT endpoint */
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(&pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL);
|
||||||
|
deptsiz.d32 = USB_OTG_READ_REG32(&pdev->regs.OUTEP_REGS[ep->num]->DOEPTSIZ);
|
||||||
|
/* Program the transfer size and packet count as follows:
|
||||||
|
* xfersize = N * (maxpacket + 4 - (maxpacket % 4))
|
||||||
|
* pktcnt = N */
|
||||||
|
if (ep->xfer_len == 0)
|
||||||
|
{
|
||||||
|
deptsiz.b.xfersize = ep->maxpacket;
|
||||||
|
deptsiz.b.pktcnt = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ep->xfer_len = ep->maxpacket;
|
||||||
|
deptsiz.b.xfersize = ep->maxpacket;
|
||||||
|
deptsiz.b.pktcnt = 1;
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.OUTEP_REGS[ep->num]->DOEPTSIZ, deptsiz.d32);
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.OUTEP_REGS[ep->num]->DOEPDMA, ep->dma_addr);
|
||||||
|
}
|
||||||
|
/* EP enable */
|
||||||
|
depctl.b.cnak = 1;
|
||||||
|
depctl.b.epena = 1;
|
||||||
|
USB_OTG_WRITE_REG32 (&(pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL), depctl.d32);
|
||||||
|
|
||||||
|
}
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_EPSetStall : Set the EP STALL
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EPSetStall(USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
__IO uint32_t *depctl_addr;
|
||||||
|
|
||||||
|
depctl.d32 = 0;
|
||||||
|
if (ep->is_in == 1)
|
||||||
|
{
|
||||||
|
depctl_addr = &(pdev->regs.INEP_REGS[ep->num]->DIEPCTL);
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(depctl_addr);
|
||||||
|
/* set the disable and stall bits */
|
||||||
|
if (depctl.b.epena)
|
||||||
|
{
|
||||||
|
depctl.b.epdis = 1;
|
||||||
|
}
|
||||||
|
depctl.b.stall = 1;
|
||||||
|
USB_OTG_WRITE_REG32(depctl_addr, depctl.d32);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
depctl_addr = &(pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL);
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(depctl_addr);
|
||||||
|
/* set the stall bit */
|
||||||
|
depctl.b.stall = 1;
|
||||||
|
USB_OTG_WRITE_REG32(depctl_addr, depctl.d32);
|
||||||
|
}
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Clear the EP STALL
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval USB_OTG_STS : status
|
||||||
|
*/
|
||||||
|
USB_OTG_STS USB_OTG_EPClearStall(USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep)
|
||||||
|
{
|
||||||
|
USB_OTG_STS status = USB_OTG_OK;
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
__IO uint32_t *depctl_addr;
|
||||||
|
|
||||||
|
depctl.d32 = 0;
|
||||||
|
|
||||||
|
if (ep->is_in == 1)
|
||||||
|
{
|
||||||
|
depctl_addr = &(pdev->regs.INEP_REGS[ep->num]->DIEPCTL);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
depctl_addr = &(pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL);
|
||||||
|
}
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(depctl_addr);
|
||||||
|
/* clear the stall bits */
|
||||||
|
depctl.b.stall = 0;
|
||||||
|
if (ep->type == EP_TYPE_INTR || ep->type == EP_TYPE_BULK)
|
||||||
|
{
|
||||||
|
depctl.b.setd0pid = 1; /* DATA0 */
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32(depctl_addr, depctl.d32);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_ReadDevAllOutEp_itr : returns OUT endpoint interrupt bits
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval OUT endpoint interrupt bits
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_ReadDevAllOutEp_itr(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
uint32_t v;
|
||||||
|
v = USB_OTG_READ_REG32(&pdev->regs.DREGS->DAINT);
|
||||||
|
v &= USB_OTG_READ_REG32(&pdev->regs.DREGS->DAINTMSK);
|
||||||
|
return ((v & 0xffff0000) >> 16);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_ReadDevOutEP_itr : returns Device OUT EP Interrupt register
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @param ep : end point number
|
||||||
|
* @retval Device OUT EP Interrupt register
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_ReadDevOutEP_itr(USB_OTG_CORE_HANDLE *pdev , uint8_t epnum)
|
||||||
|
{
|
||||||
|
uint32_t v;
|
||||||
|
v = USB_OTG_READ_REG32(&pdev->regs.OUTEP_REGS[epnum]->DOEPINT);
|
||||||
|
v &= USB_OTG_READ_REG32(&pdev->regs.DREGS->DOEPMSK);
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_ReadDevAllInEPItr : Get int status register
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval int status register
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_ReadDevAllInEPItr(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
uint32_t v;
|
||||||
|
v = USB_OTG_READ_REG32(&pdev->regs.DREGS->DAINT);
|
||||||
|
v &= USB_OTG_READ_REG32(&pdev->regs.DREGS->DAINTMSK);
|
||||||
|
return (v & 0xffff);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief configures EPO to receive SETUP packets
|
||||||
|
* @param None
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void USB_OTG_EP0_OutStart(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_DEP0XFRSIZ_TypeDef doeptsize0;
|
||||||
|
doeptsize0.d32 = 0;
|
||||||
|
doeptsize0.b.supcnt = 3;
|
||||||
|
doeptsize0.b.pktcnt = 1;
|
||||||
|
doeptsize0.b.xfersize = 8 * 3;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.OUTEP_REGS[0]->DOEPTSIZ, doeptsize0.d32 );
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
USB_OTG_DEPCTL_TypeDef doepctl;
|
||||||
|
doepctl.d32 = 0;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.OUTEP_REGS[0]->DOEPDMA,
|
||||||
|
(uint32_t)&pdev->dev.setup_packet);
|
||||||
|
|
||||||
|
/* EP enable */
|
||||||
|
doepctl.d32 = USB_OTG_READ_REG32(&pdev->regs.OUTEP_REGS[0]->DOEPCTL);
|
||||||
|
doepctl.b.epena = 1;
|
||||||
|
doepctl.d32 = 0x80008000;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.OUTEP_REGS[0]->DOEPCTL, doepctl.d32);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_RemoteWakeup : active remote wakeup signalling
|
||||||
|
* @param None
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void USB_OTG_ActiveRemoteWakeup(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_DCTL_TypeDef dctl;
|
||||||
|
USB_OTG_DSTS_TypeDef dsts;
|
||||||
|
USB_OTG_PCGCCTL_TypeDef power;
|
||||||
|
|
||||||
|
if (pdev->dev.DevRemoteWakeup)
|
||||||
|
{
|
||||||
|
dsts.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DSTS);
|
||||||
|
if(dsts.b.suspsts == 1)
|
||||||
|
{
|
||||||
|
if(pdev->cfg.low_power)
|
||||||
|
{
|
||||||
|
/* un-gate USB Core clock */
|
||||||
|
power.d32 = USB_OTG_READ_REG32(&pdev->regs.PCGCCTL);
|
||||||
|
power.b.gatehclk = 0;
|
||||||
|
power.b.stoppclk = 0;
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.PCGCCTL, power.d32);
|
||||||
|
}
|
||||||
|
/* active Remote wakeup signaling */
|
||||||
|
dctl.d32 = 0;
|
||||||
|
dctl.b.rmtwkupsig = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DCTL, 0, dctl.d32);
|
||||||
|
USB_OTG_BSP_mDelay(5);
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DCTL, dctl.d32, 0 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_UngateClock : active USB Core clock
|
||||||
|
* @param None
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void USB_OTG_UngateClock(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
if(pdev->cfg.low_power)
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_DSTS_TypeDef dsts;
|
||||||
|
USB_OTG_PCGCCTL_TypeDef power;
|
||||||
|
|
||||||
|
dsts.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DSTS);
|
||||||
|
|
||||||
|
if(dsts.b.suspsts == 1)
|
||||||
|
{
|
||||||
|
/* un-gate USB Core clock */
|
||||||
|
power.d32 = USB_OTG_READ_REG32(&pdev->regs.PCGCCTL);
|
||||||
|
power.b.gatehclk = 0;
|
||||||
|
power.b.stoppclk = 0;
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.PCGCCTL, power.d32);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Stop the device and clean up fifo's
|
||||||
|
* @param None
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void USB_OTG_StopDevice(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
uint32_t i;
|
||||||
|
|
||||||
|
pdev->dev.device_status = 1;
|
||||||
|
|
||||||
|
for (i = 0; i < pdev->cfg.dev_endpoints ; i++)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.INEP_REGS[i]->DIEPINT, 0xFF);
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.OUTEP_REGS[i]->DOEPINT, 0xFF);
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DIEPMSK, 0 );
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DOEPMSK, 0 );
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DAINTMSK, 0 );
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DAINT, 0xFFFFFFFF );
|
||||||
|
|
||||||
|
/* Flush the FIFO */
|
||||||
|
USB_OTG_FlushRxFifo(pdev);
|
||||||
|
USB_OTG_FlushTxFifo(pdev , 0x10 );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief returns the EP Status
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* ep : endpoint structure
|
||||||
|
* @retval : EP status
|
||||||
|
*/
|
||||||
|
|
||||||
|
uint32_t USB_OTG_GetEPStatus(USB_OTG_CORE_HANDLE *pdev ,USB_OTG_EP *ep)
|
||||||
|
{
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
__IO uint32_t *depctl_addr;
|
||||||
|
uint32_t Status = 0;
|
||||||
|
|
||||||
|
depctl.d32 = 0;
|
||||||
|
if (ep->is_in == 1)
|
||||||
|
{
|
||||||
|
depctl_addr = &(pdev->regs.INEP_REGS[ep->num]->DIEPCTL);
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(depctl_addr);
|
||||||
|
|
||||||
|
if (depctl.b.stall == 1)
|
||||||
|
Status = USB_OTG_EP_TX_STALL;
|
||||||
|
else if (depctl.b.naksts == 1)
|
||||||
|
Status = USB_OTG_EP_TX_NAK;
|
||||||
|
else
|
||||||
|
Status = USB_OTG_EP_TX_VALID;
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
depctl_addr = &(pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL);
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(depctl_addr);
|
||||||
|
if (depctl.b.stall == 1)
|
||||||
|
Status = USB_OTG_EP_RX_STALL;
|
||||||
|
else if (depctl.b.naksts == 1)
|
||||||
|
Status = USB_OTG_EP_RX_NAK;
|
||||||
|
else
|
||||||
|
Status = USB_OTG_EP_RX_VALID;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Return the current status */
|
||||||
|
return Status;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set the EP Status
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* Status : new Status
|
||||||
|
* ep : EP structure
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void USB_OTG_SetEPStatus (USB_OTG_CORE_HANDLE *pdev , USB_OTG_EP *ep , uint32_t Status)
|
||||||
|
{
|
||||||
|
USB_OTG_DEPCTL_TypeDef depctl;
|
||||||
|
__IO uint32_t *depctl_addr;
|
||||||
|
|
||||||
|
depctl.d32 = 0;
|
||||||
|
|
||||||
|
/* Process for IN endpoint */
|
||||||
|
if (ep->is_in == 1)
|
||||||
|
{
|
||||||
|
depctl_addr = &(pdev->regs.INEP_REGS[ep->num]->DIEPCTL);
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(depctl_addr);
|
||||||
|
|
||||||
|
if (Status == USB_OTG_EP_TX_STALL)
|
||||||
|
{
|
||||||
|
USB_OTG_EPSetStall(pdev, ep); return;
|
||||||
|
}
|
||||||
|
else if (Status == USB_OTG_EP_TX_NAK)
|
||||||
|
depctl.b.snak = 1;
|
||||||
|
else if (Status == USB_OTG_EP_TX_VALID)
|
||||||
|
{
|
||||||
|
if (depctl.b.stall == 1)
|
||||||
|
{
|
||||||
|
ep->even_odd_frame = 0;
|
||||||
|
USB_OTG_EPClearStall(pdev, ep);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
depctl.b.cnak = 1;
|
||||||
|
depctl.b.usbactep = 1;
|
||||||
|
depctl.b.epena = 1;
|
||||||
|
}
|
||||||
|
else if (Status == USB_OTG_EP_TX_DIS)
|
||||||
|
depctl.b.usbactep = 0;
|
||||||
|
}
|
||||||
|
else /* Process for OUT endpoint */
|
||||||
|
{
|
||||||
|
depctl_addr = &(pdev->regs.OUTEP_REGS[ep->num]->DOEPCTL);
|
||||||
|
depctl.d32 = USB_OTG_READ_REG32(depctl_addr);
|
||||||
|
|
||||||
|
if (Status == USB_OTG_EP_RX_STALL) {
|
||||||
|
depctl.b.stall = 1;
|
||||||
|
}
|
||||||
|
else if (Status == USB_OTG_EP_RX_NAK)
|
||||||
|
depctl.b.snak = 1;
|
||||||
|
else if (Status == USB_OTG_EP_RX_VALID)
|
||||||
|
{
|
||||||
|
if (depctl.b.stall == 1)
|
||||||
|
{
|
||||||
|
ep->even_odd_frame = 0;
|
||||||
|
USB_OTG_EPClearStall(pdev, ep);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
depctl.b.cnak = 1;
|
||||||
|
depctl.b.usbactep = 1;
|
||||||
|
depctl.b.epena = 1;
|
||||||
|
}
|
||||||
|
else if (Status == USB_OTG_EP_RX_DIS)
|
||||||
|
{
|
||||||
|
depctl.b.usbactep = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_WRITE_REG32(depctl_addr, depctl.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -0,0 +1,472 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_dcd.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Peripheral Device Interface Layer
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_dcd.h"
|
||||||
|
#include "usb_bsp.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD
|
||||||
|
* @brief This file is the interface between EFSL ans Host mass-storage class
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void DCD_Init(USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
USB_OTG_CORE_ID_TypeDef coreID)
|
||||||
|
{
|
||||||
|
uint32_t i;
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
|
||||||
|
USB_OTG_SelectCore (pdev , coreID);
|
||||||
|
|
||||||
|
pdev->dev.device_status = USB_OTG_DEFAULT;
|
||||||
|
pdev->dev.device_address = 0;
|
||||||
|
|
||||||
|
/* Init ep structure */
|
||||||
|
for (i = 0; i < pdev->cfg.dev_endpoints ; i++)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.in_ep[i];
|
||||||
|
/* Init ep structure */
|
||||||
|
ep->is_in = 1;
|
||||||
|
ep->num = i;
|
||||||
|
ep->tx_fifo_num = i;
|
||||||
|
/* Control until ep is actvated */
|
||||||
|
ep->type = EP_TYPE_CTRL;
|
||||||
|
ep->maxpacket = USB_OTG_MAX_EP0_SIZE;
|
||||||
|
ep->xfer_buff = 0;
|
||||||
|
ep->xfer_len = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < pdev->cfg.dev_endpoints; i++)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.out_ep[i];
|
||||||
|
/* Init ep structure */
|
||||||
|
ep->is_in = 0;
|
||||||
|
ep->num = i;
|
||||||
|
ep->tx_fifo_num = i;
|
||||||
|
/* Control until ep is activated */
|
||||||
|
ep->type = EP_TYPE_CTRL;
|
||||||
|
ep->maxpacket = USB_OTG_MAX_EP0_SIZE;
|
||||||
|
ep->xfer_buff = 0;
|
||||||
|
ep->xfer_len = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_DisableGlobalInt(pdev);
|
||||||
|
|
||||||
|
/*Init the Core (common init.) */
|
||||||
|
USB_OTG_CoreInit(pdev);
|
||||||
|
|
||||||
|
|
||||||
|
/* Force Device Mode*/
|
||||||
|
USB_OTG_SetCurrentMode(pdev, DEVICE_MODE);
|
||||||
|
|
||||||
|
/* Init Device */
|
||||||
|
USB_OTG_CoreInitDev(pdev);
|
||||||
|
|
||||||
|
|
||||||
|
/* Enable USB Global interrupt */
|
||||||
|
USB_OTG_EnableGlobalInt(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Configure an EP
|
||||||
|
* @param pdev : Device instance
|
||||||
|
* @param epdesc : Endpoint Descriptor
|
||||||
|
* @retval : status
|
||||||
|
*/
|
||||||
|
uint32_t DCD_EP_Open(USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint8_t ep_addr,
|
||||||
|
uint16_t ep_mps,
|
||||||
|
uint8_t ep_type)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
|
||||||
|
if ((ep_addr & 0x80) == 0x80)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.in_ep[ep_addr & 0x7F];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.out_ep[ep_addr & 0x7F];
|
||||||
|
}
|
||||||
|
ep->num = ep_addr & 0x7F;
|
||||||
|
|
||||||
|
ep->is_in = (0x80 & ep_addr) != 0;
|
||||||
|
ep->maxpacket = ep_mps;
|
||||||
|
ep->type = ep_type;
|
||||||
|
if (ep->is_in)
|
||||||
|
{
|
||||||
|
/* Assign a Tx FIFO */
|
||||||
|
ep->tx_fifo_num = ep->num;
|
||||||
|
}
|
||||||
|
/* Set initial data PID. */
|
||||||
|
if (ep_type == USB_OTG_EP_BULK )
|
||||||
|
{
|
||||||
|
ep->data_pid_start = 0;
|
||||||
|
}
|
||||||
|
USB_OTG_EPActivate(pdev , ep );
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief called when an EP is disabled
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param ep_addr: endpoint address
|
||||||
|
* @retval : status
|
||||||
|
*/
|
||||||
|
uint32_t DCD_EP_Close(USB_OTG_CORE_HANDLE *pdev , uint8_t ep_addr)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
|
||||||
|
if ((ep_addr&0x80) == 0x80)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.in_ep[ep_addr & 0x7F];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.out_ep[ep_addr & 0x7F];
|
||||||
|
}
|
||||||
|
ep->num = ep_addr & 0x7F;
|
||||||
|
ep->is_in = (0x80 & ep_addr) != 0;
|
||||||
|
USB_OTG_EPDeactivate(pdev , ep );
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_EP_PrepareRx
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param ep_addr: endpoint address
|
||||||
|
* @param pbuf: pointer to Rx buffer
|
||||||
|
* @param buf_len: data length
|
||||||
|
* @retval : status
|
||||||
|
*/
|
||||||
|
uint32_t DCD_EP_PrepareRx( USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t ep_addr,
|
||||||
|
uint8_t *pbuf,
|
||||||
|
uint16_t buf_len)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
|
||||||
|
ep = &pdev->dev.out_ep[ep_addr & 0x7F];
|
||||||
|
|
||||||
|
/*setup and start the Xfer */
|
||||||
|
ep->xfer_buff = pbuf;
|
||||||
|
ep->xfer_len = buf_len;
|
||||||
|
ep->xfer_count = 0;
|
||||||
|
ep->is_in = 0;
|
||||||
|
ep->num = ep_addr & 0x7F;
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
ep->dma_addr = (uint32_t)pbuf;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ep->num == 0 )
|
||||||
|
{
|
||||||
|
USB_OTG_EP0StartXfer(pdev , ep);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USB_OTG_EPStartXfer(pdev, ep );
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Transmit data over USB
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param ep_addr: endpoint address
|
||||||
|
* @param pbuf: pointer to Tx buffer
|
||||||
|
* @param buf_len: data length
|
||||||
|
* @retval : status
|
||||||
|
*/
|
||||||
|
uint32_t DCD_EP_Tx ( USB_OTG_CORE_HANDLE *pdev,
|
||||||
|
uint8_t ep_addr,
|
||||||
|
const uint8_t *pbuf,
|
||||||
|
uint32_t buf_len)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
|
||||||
|
ep = &pdev->dev.in_ep[ep_addr & 0x7F];
|
||||||
|
|
||||||
|
/* Setup and start the Transfer */
|
||||||
|
ep->is_in = 1;
|
||||||
|
ep->num = ep_addr & 0x7F;
|
||||||
|
ep->xfer_buff = pbuf;
|
||||||
|
ep->dma_addr = (uint32_t)pbuf;
|
||||||
|
ep->xfer_count = 0;
|
||||||
|
ep->xfer_len = buf_len;
|
||||||
|
|
||||||
|
if ( ep->num == 0 )
|
||||||
|
{
|
||||||
|
USB_OTG_EP0StartXfer(pdev , ep);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USB_OTG_EPStartXfer(pdev, ep );
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Stall an endpoint.
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param epnum: endpoint address
|
||||||
|
* @retval : status
|
||||||
|
*/
|
||||||
|
uint32_t DCD_EP_Stall (USB_OTG_CORE_HANDLE *pdev, uint8_t epnum)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
if ((0x80 & epnum) == 0x80)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.in_ep[epnum & 0x7F];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.out_ep[epnum];
|
||||||
|
}
|
||||||
|
|
||||||
|
ep->is_stall = 1;
|
||||||
|
ep->num = epnum & 0x7F;
|
||||||
|
ep->is_in = ((epnum & 0x80) == 0x80);
|
||||||
|
|
||||||
|
USB_OTG_EPSetStall(pdev , ep);
|
||||||
|
return (0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Clear stall condition on endpoints.
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param epnum: endpoint address
|
||||||
|
* @retval : status
|
||||||
|
*/
|
||||||
|
uint32_t DCD_EP_ClrStall (USB_OTG_CORE_HANDLE *pdev, uint8_t epnum)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
if ((0x80 & epnum) == 0x80)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.in_ep[epnum & 0x7F];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.out_ep[epnum];
|
||||||
|
}
|
||||||
|
|
||||||
|
ep->is_stall = 0;
|
||||||
|
ep->num = epnum & 0x7F;
|
||||||
|
ep->is_in = ((epnum & 0x80) == 0x80);
|
||||||
|
|
||||||
|
USB_OTG_EPClearStall(pdev , ep);
|
||||||
|
return (0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This Function flushes the FIFOs.
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param epnum: endpoint address
|
||||||
|
* @retval : status
|
||||||
|
*/
|
||||||
|
uint32_t DCD_EP_Flush (USB_OTG_CORE_HANDLE *pdev , uint8_t epnum)
|
||||||
|
{
|
||||||
|
|
||||||
|
if ((epnum & 0x80) == 0x80)
|
||||||
|
{
|
||||||
|
USB_OTG_FlushTxFifo(pdev, epnum & 0x7F);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
USB_OTG_FlushRxFifo(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
return (0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This Function set USB device address
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @param address: new device address
|
||||||
|
* @retval : status
|
||||||
|
*/
|
||||||
|
void DCD_EP_SetAddress (USB_OTG_CORE_HANDLE *pdev, uint8_t address)
|
||||||
|
{
|
||||||
|
USB_OTG_DCFG_TypeDef dcfg;
|
||||||
|
dcfg.d32 = 0;
|
||||||
|
dcfg.b.devaddr = address;
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.DREGS->DCFG, 0, dcfg.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Connect device (enable internal pull-up)
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void DCD_DevConnect (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
#ifndef USE_OTG_MODE
|
||||||
|
USB_OTG_DCTL_TypeDef dctl;
|
||||||
|
dctl.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DCTL);
|
||||||
|
/* Connect device */
|
||||||
|
dctl.b.sftdiscon = 0;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.DREGS->DCTL, dctl.d32);
|
||||||
|
USB_OTG_BSP_mDelay(3);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Disconnect device (disable internal pull-up)
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void DCD_DevDisconnect (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
#ifndef USE_OTG_MODE
|
||||||
|
USB_OTG_DCTL_TypeDef dctl;
|
||||||
|
dctl.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DCTL);
|
||||||
|
/* Disconnect device for 3ms */
|
||||||
|
dctl.b.sftdiscon = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.DREGS->DCTL, dctl.d32);
|
||||||
|
USB_OTG_BSP_mDelay(3);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief returns the EP Status
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* epnum : endpoint address
|
||||||
|
* @retval : EP status
|
||||||
|
*/
|
||||||
|
|
||||||
|
uint32_t DCD_GetEPStatus(USB_OTG_CORE_HANDLE *pdev ,uint8_t epnum)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
uint32_t Status = 0;
|
||||||
|
|
||||||
|
if ((0x80 & epnum) == 0x80)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.in_ep[epnum & 0x7F];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.out_ep[epnum];
|
||||||
|
}
|
||||||
|
|
||||||
|
Status = USB_OTG_GetEPStatus(pdev ,ep);
|
||||||
|
|
||||||
|
/* Return the current status */
|
||||||
|
return Status;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set the EP Status
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* Status : new Status
|
||||||
|
* epnum : EP address
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
void DCD_SetEPStatus (USB_OTG_CORE_HANDLE *pdev , uint8_t epnum , uint32_t Status)
|
||||||
|
{
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
|
||||||
|
if ((0x80 & epnum) == 0x80)
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.in_ep[epnum & 0x7F];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ep = &pdev->dev.out_ep[epnum];
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_SetEPStatus(pdev ,ep , Status);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -0,0 +1,886 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_dcd_int.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Peripheral Device interrupt subroutines
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_dcd_int.h"
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT
|
||||||
|
* @brief This file contains the interrupt subroutines for the Device mode.
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/* static functions */
|
||||||
|
static uint32_t DCD_ReadDevInEP (USB_OTG_CORE_HANDLE *pdev, uint8_t epnum);
|
||||||
|
|
||||||
|
/* Interrupt Handlers */
|
||||||
|
static uint32_t DCD_HandleInEP_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t DCD_HandleOutEP_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t DCD_HandleSof_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
static uint32_t DCD_HandleRxStatusQueueLevel_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t DCD_WriteEmptyTxFifo(USB_OTG_CORE_HANDLE *pdev , uint32_t epnum);
|
||||||
|
|
||||||
|
static uint32_t DCD_HandleUsbReset_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t DCD_HandleEnumDone_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t DCD_HandleResume_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t DCD_HandleUSBSuspend_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
static uint32_t DCD_IsoINIncomplete_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t DCD_IsoOUTIncomplete_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
#ifdef VBUS_SENSING_ENABLED
|
||||||
|
static uint32_t DCD_SessionRequest_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t DCD_OTG_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_DCD_INT_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_DEDICATED_EP1_ENABLED
|
||||||
|
/**
|
||||||
|
* @brief USBD_OTG_EP1OUT_ISR_Handler
|
||||||
|
* handles all USB Interrupts
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
uint32_t USBD_OTG_EP1OUT_ISR_Handler (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_DOEPINTn_TypeDef doepint;
|
||||||
|
USB_OTG_DEPXFRSIZ_TypeDef deptsiz;
|
||||||
|
|
||||||
|
doepint.d32 = USB_OTG_READ_REG32(&pdev->regs.OUTEP_REGS[1]->DOEPINT);
|
||||||
|
doepint.d32&= USB_OTG_READ_REG32(&pdev->regs.DREGS->DOUTEP1MSK);
|
||||||
|
|
||||||
|
/* Transfer complete */
|
||||||
|
if ( doepint.b.xfercompl )
|
||||||
|
{
|
||||||
|
/* Clear the bit in DOEPINTn for this interrupt */
|
||||||
|
CLEAR_OUT_EP_INTR(1, xfercompl);
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
deptsiz.d32 = USB_OTG_READ_REG32(&(pdev->regs.OUTEP_REGS[1]->DOEPTSIZ));
|
||||||
|
/*ToDo : handle more than one single MPS size packet */
|
||||||
|
pdev->dev.out_ep[1].xfer_count = pdev->dev.out_ep[1].maxpacket - \
|
||||||
|
deptsiz.b.xfersize;
|
||||||
|
}
|
||||||
|
/* Inform upper layer: data ready */
|
||||||
|
/* RX COMPLETE */
|
||||||
|
USBD_DCD_INT_fops->DataOutStage(pdev , 1);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Endpoint disable */
|
||||||
|
if ( doepint.b.epdisabled )
|
||||||
|
{
|
||||||
|
/* Clear the bit in DOEPINTn for this interrupt */
|
||||||
|
CLEAR_OUT_EP_INTR(1, epdisabled);
|
||||||
|
}
|
||||||
|
/* AHB Error */
|
||||||
|
if ( doepint.b.ahberr )
|
||||||
|
{
|
||||||
|
CLEAR_OUT_EP_INTR(1, ahberr);
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USBD_OTG_EP1IN_ISR_Handler
|
||||||
|
* handles all USB Interrupts
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
uint32_t USBD_OTG_EP1IN_ISR_Handler (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_DIEPINTn_TypeDef diepint;
|
||||||
|
uint32_t fifoemptymsk, msk, emp;
|
||||||
|
|
||||||
|
msk = USB_OTG_READ_REG32(&pdev->regs.DREGS->DINEP1MSK);
|
||||||
|
emp = USB_OTG_READ_REG32(&pdev->regs.DREGS->DIEPEMPMSK);
|
||||||
|
msk |= ((emp >> 1 ) & 0x1) << 7;
|
||||||
|
diepint.d32 = USB_OTG_READ_REG32(&pdev->regs.INEP_REGS[1]->DIEPINT) & msk;
|
||||||
|
|
||||||
|
if ( diepint.b.xfercompl )
|
||||||
|
{
|
||||||
|
fifoemptymsk = 0x1 << 1;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DIEPEMPMSK, fifoemptymsk, 0);
|
||||||
|
CLEAR_IN_EP_INTR(1, xfercompl);
|
||||||
|
/* TX COMPLETE */
|
||||||
|
USBD_DCD_INT_fops->DataInStage(pdev , 1);
|
||||||
|
}
|
||||||
|
if ( diepint.b.ahberr )
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(1, ahberr);
|
||||||
|
}
|
||||||
|
if ( diepint.b.epdisabled )
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(1, epdisabled);
|
||||||
|
}
|
||||||
|
if ( diepint.b.timeout )
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(1, timeout);
|
||||||
|
}
|
||||||
|
if (diepint.b.intktxfemp)
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(1, intktxfemp);
|
||||||
|
}
|
||||||
|
if (diepint.b.intknepmis)
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(1, intknepmis);
|
||||||
|
}
|
||||||
|
if (diepint.b.inepnakeff)
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(1, inepnakeff);
|
||||||
|
}
|
||||||
|
if (diepint.b.emptyintr)
|
||||||
|
{
|
||||||
|
DCD_WriteEmptyTxFifo(pdev , 1);
|
||||||
|
CLEAR_IN_EP_INTR(1, emptyintr);
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief STM32_USBF_OTG_ISR_Handler
|
||||||
|
* handles all USB Interrupts
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
uint32_t USBD_OTG_ISR_Handler (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintr_status;
|
||||||
|
uint32_t retval = 0;
|
||||||
|
|
||||||
|
if (USB_OTG_IsDeviceMode(pdev)) /* ensure that we are in device mode */
|
||||||
|
{
|
||||||
|
gintr_status.d32 = USB_OTG_ReadCoreItr(pdev);
|
||||||
|
if (!gintr_status.d32) /* avoid spurious interrupt */
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.outepintr)
|
||||||
|
{
|
||||||
|
retval |= DCD_HandleOutEP_ISR(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.inepint)
|
||||||
|
{
|
||||||
|
retval |= DCD_HandleInEP_ISR(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.modemismatch)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
gintsts.b.modemismatch = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.wkupintr)
|
||||||
|
{
|
||||||
|
retval |= DCD_HandleResume_ISR(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.usbsuspend)
|
||||||
|
{
|
||||||
|
retval |= DCD_HandleUSBSuspend_ISR(pdev);
|
||||||
|
}
|
||||||
|
if (gintr_status.b.sofintr)
|
||||||
|
{
|
||||||
|
retval |= DCD_HandleSof_ISR(pdev);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.rxstsqlvl)
|
||||||
|
{
|
||||||
|
retval |= DCD_HandleRxStatusQueueLevel_ISR(pdev);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.usbreset)
|
||||||
|
{
|
||||||
|
retval |= DCD_HandleUsbReset_ISR(pdev);
|
||||||
|
|
||||||
|
}
|
||||||
|
if (gintr_status.b.enumdone)
|
||||||
|
{
|
||||||
|
retval |= DCD_HandleEnumDone_ISR(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.incomplisoin)
|
||||||
|
{
|
||||||
|
retval |= DCD_IsoINIncomplete_ISR(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.incomplisoout)
|
||||||
|
{
|
||||||
|
retval |= DCD_IsoOUTIncomplete_ISR(pdev);
|
||||||
|
}
|
||||||
|
#ifdef VBUS_SENSING_ENABLED
|
||||||
|
if (gintr_status.b.sessreqintr)
|
||||||
|
{
|
||||||
|
retval |= DCD_SessionRequest_ISR(pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintr_status.b.otgintr)
|
||||||
|
{
|
||||||
|
retval |= DCD_OTG_ISR(pdev);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef VBUS_SENSING_ENABLED
|
||||||
|
/**
|
||||||
|
* @brief DCD_SessionRequest_ISR
|
||||||
|
* Indicates that the USB_OTG controller has detected a connection
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_SessionRequest_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
USBD_DCD_INT_fops->DevConnected (pdev);
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
gintsts.b.sessreqintr = 1;
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_OTG_ISR
|
||||||
|
* Indicates that the USB_OTG controller has detected an OTG event:
|
||||||
|
* used to detect the end of session i.e. disconnection
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_OTG_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_GOTGINT_TypeDef gotgint;
|
||||||
|
|
||||||
|
gotgint.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GOTGINT);
|
||||||
|
|
||||||
|
if (gotgint.b.sesenddet)
|
||||||
|
{
|
||||||
|
USBD_DCD_INT_fops->DevDisconnected (pdev);
|
||||||
|
}
|
||||||
|
/* Clear OTG interrupt */
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GOTGINT, gotgint.d32);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
/**
|
||||||
|
* @brief DCD_HandleResume_ISR
|
||||||
|
* Indicates that the USB_OTG controller has detected a resume or
|
||||||
|
* remote Wake-up sequence
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_HandleResume_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
USB_OTG_DCTL_TypeDef devctl;
|
||||||
|
USB_OTG_PCGCCTL_TypeDef power;
|
||||||
|
|
||||||
|
if(pdev->cfg.low_power)
|
||||||
|
{
|
||||||
|
/* un-gate USB Core clock */
|
||||||
|
power.d32 = USB_OTG_READ_REG32(&pdev->regs.PCGCCTL);
|
||||||
|
power.b.gatehclk = 0;
|
||||||
|
power.b.stoppclk = 0;
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.PCGCCTL, power.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Clear the Remote Wake-up Signaling */
|
||||||
|
devctl.d32 = 0;
|
||||||
|
devctl.b.rmtwkupsig = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DCTL, devctl.d32, 0);
|
||||||
|
|
||||||
|
/* Inform upper layer by the Resume Event */
|
||||||
|
USBD_DCD_INT_fops->Resume (pdev);
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
gintsts.b.wkupintr = 1;
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_HandleUSBSuspend_ISR
|
||||||
|
* Indicates that SUSPEND state has been detected on the USB
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_HandleUSBSuspend_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
USB_OTG_PCGCCTL_TypeDef power;
|
||||||
|
USB_OTG_DSTS_TypeDef dsts;
|
||||||
|
|
||||||
|
USBD_DCD_INT_fops->Suspend (pdev);
|
||||||
|
|
||||||
|
dsts.d32 = USB_OTG_READ_REG32(&pdev->regs.DREGS->DSTS);
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
gintsts.b.usbsuspend = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
|
||||||
|
if((pdev->cfg.low_power) && (dsts.b.suspsts == 1))
|
||||||
|
{
|
||||||
|
/* switch-off the clocks */
|
||||||
|
power.d32 = 0;
|
||||||
|
power.b.stoppclk = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(pdev->regs.PCGCCTL, 0, power.d32);
|
||||||
|
|
||||||
|
power.b.gatehclk = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(pdev->regs.PCGCCTL, 0, power.d32);
|
||||||
|
|
||||||
|
/* Request to enter Sleep mode after exit from current ISR */
|
||||||
|
SCB->SCR |= (SCB_SCR_SLEEPDEEP_Msk | SCB_SCR_SLEEPONEXIT_Msk);
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_HandleInEP_ISR
|
||||||
|
* Indicates that an IN EP has a pending Interrupt
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_HandleInEP_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_DIEPINTn_TypeDef diepint;
|
||||||
|
|
||||||
|
uint32_t ep_intr;
|
||||||
|
uint32_t epnum = 0;
|
||||||
|
uint32_t fifoemptymsk;
|
||||||
|
diepint.d32 = 0;
|
||||||
|
ep_intr = USB_OTG_ReadDevAllInEPItr(pdev);
|
||||||
|
|
||||||
|
while ( ep_intr )
|
||||||
|
{
|
||||||
|
if (ep_intr&0x1) /* In ITR */
|
||||||
|
{
|
||||||
|
diepint.d32 = DCD_ReadDevInEP(pdev , epnum); /* Get In ITR status */
|
||||||
|
if ( diepint.b.xfercompl )
|
||||||
|
{
|
||||||
|
fifoemptymsk = 0x1 << epnum;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DIEPEMPMSK, fifoemptymsk, 0);
|
||||||
|
CLEAR_IN_EP_INTR(epnum, xfercompl);
|
||||||
|
/* TX COMPLETE */
|
||||||
|
USBD_DCD_INT_fops->DataInStage(pdev , epnum);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
if((epnum == 0) && (pdev->dev.device_state == USB_OTG_EP0_STATUS_IN))
|
||||||
|
{
|
||||||
|
/* prepare to rx more setup packets */
|
||||||
|
USB_OTG_EP0_OutStart(pdev);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ( diepint.b.ahberr )
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(epnum, ahberr);
|
||||||
|
}
|
||||||
|
if ( diepint.b.timeout )
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(epnum, timeout);
|
||||||
|
}
|
||||||
|
if (diepint.b.intktxfemp)
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(epnum, intktxfemp);
|
||||||
|
}
|
||||||
|
if (diepint.b.intknepmis)
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(epnum, intknepmis);
|
||||||
|
}
|
||||||
|
if (diepint.b.inepnakeff)
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(epnum, inepnakeff);
|
||||||
|
}
|
||||||
|
if ( diepint.b.epdisabled )
|
||||||
|
{
|
||||||
|
CLEAR_IN_EP_INTR(epnum, epdisabled);
|
||||||
|
}
|
||||||
|
if (diepint.b.emptyintr)
|
||||||
|
{
|
||||||
|
|
||||||
|
DCD_WriteEmptyTxFifo(pdev , epnum);
|
||||||
|
|
||||||
|
CLEAR_IN_EP_INTR(epnum, emptyintr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
epnum++;
|
||||||
|
ep_intr >>= 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_HandleOutEP_ISR
|
||||||
|
* Indicates that an OUT EP has a pending Interrupt
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_HandleOutEP_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
uint32_t ep_intr;
|
||||||
|
USB_OTG_DOEPINTn_TypeDef doepint;
|
||||||
|
USB_OTG_DEPXFRSIZ_TypeDef deptsiz;
|
||||||
|
uint32_t epnum = 0;
|
||||||
|
|
||||||
|
doepint.d32 = 0;
|
||||||
|
|
||||||
|
/* Read in the device interrupt bits */
|
||||||
|
ep_intr = USB_OTG_ReadDevAllOutEp_itr(pdev);
|
||||||
|
|
||||||
|
while ( ep_intr )
|
||||||
|
{
|
||||||
|
if (ep_intr&0x1)
|
||||||
|
{
|
||||||
|
|
||||||
|
doepint.d32 = USB_OTG_ReadDevOutEP_itr(pdev, epnum);
|
||||||
|
|
||||||
|
/* Transfer complete */
|
||||||
|
if ( doepint.b.xfercompl )
|
||||||
|
{
|
||||||
|
/* Clear the bit in DOEPINTn for this interrupt */
|
||||||
|
CLEAR_OUT_EP_INTR(epnum, xfercompl);
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
deptsiz.d32 = USB_OTG_READ_REG32(&(pdev->regs.OUTEP_REGS[epnum]->DOEPTSIZ));
|
||||||
|
/*ToDo : handle more than one single MPS size packet */
|
||||||
|
pdev->dev.out_ep[epnum].xfer_count = pdev->dev.out_ep[epnum].maxpacket - \
|
||||||
|
deptsiz.b.xfersize;
|
||||||
|
}
|
||||||
|
/* Inform upper layer: data ready */
|
||||||
|
/* RX COMPLETE */
|
||||||
|
USBD_DCD_INT_fops->DataOutStage(pdev , epnum);
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
if((epnum == 0) && (pdev->dev.device_state == USB_OTG_EP0_STATUS_OUT))
|
||||||
|
{
|
||||||
|
/* prepare to rx more setup packets */
|
||||||
|
USB_OTG_EP0_OutStart(pdev);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Endpoint disable */
|
||||||
|
if ( doepint.b.epdisabled )
|
||||||
|
{
|
||||||
|
/* Clear the bit in DOEPINTn for this interrupt */
|
||||||
|
CLEAR_OUT_EP_INTR(epnum, epdisabled);
|
||||||
|
}
|
||||||
|
/* AHB Error */
|
||||||
|
if ( doepint.b.ahberr )
|
||||||
|
{
|
||||||
|
CLEAR_OUT_EP_INTR(epnum, ahberr);
|
||||||
|
}
|
||||||
|
/* Setup Phase Done (control EPs) */
|
||||||
|
if ( doepint.b.setup )
|
||||||
|
{
|
||||||
|
|
||||||
|
/* inform the upper layer that a setup packet is available */
|
||||||
|
/* SETUP COMPLETE */
|
||||||
|
USBD_DCD_INT_fops->SetupStage(pdev);
|
||||||
|
CLEAR_OUT_EP_INTR(epnum, setup);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
epnum++;
|
||||||
|
ep_intr >>= 1;
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_HandleSof_ISR
|
||||||
|
* Handles the SOF Interrupts
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_HandleSof_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef GINTSTS;
|
||||||
|
|
||||||
|
|
||||||
|
USBD_DCD_INT_fops->SOF(pdev);
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
GINTSTS.d32 = 0;
|
||||||
|
GINTSTS.b.sofintr = 1;
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GINTSTS, GINTSTS.d32);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_HandleRxStatusQueueLevel_ISR
|
||||||
|
* Handles the Rx Status Queue Level Interrupt
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_HandleRxStatusQueueLevel_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTMSK_TypeDef int_mask;
|
||||||
|
USB_OTG_DRXSTS_TypeDef status;
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
|
||||||
|
/* Disable the Rx Status Queue Level interrupt */
|
||||||
|
int_mask.d32 = 0;
|
||||||
|
int_mask.b.rxstsqlvl = 1;
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.GREGS->GINTMSK, int_mask.d32, 0);
|
||||||
|
|
||||||
|
/* Get the Status from the top of the FIFO */
|
||||||
|
status.d32 = USB_OTG_READ_REG32( &pdev->regs.GREGS->GRXSTSP );
|
||||||
|
|
||||||
|
ep = &pdev->dev.out_ep[status.b.epnum];
|
||||||
|
|
||||||
|
switch (status.b.pktsts)
|
||||||
|
{
|
||||||
|
case STS_GOUT_NAK:
|
||||||
|
break;
|
||||||
|
case STS_DATA_UPDT:
|
||||||
|
if (status.b.bcnt)
|
||||||
|
{
|
||||||
|
USB_OTG_ReadPacket(pdev,ep->xfer_buff, status.b.bcnt);
|
||||||
|
ep->xfer_buff += status.b.bcnt;
|
||||||
|
ep->xfer_count += status.b.bcnt;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case STS_XFER_COMP:
|
||||||
|
break;
|
||||||
|
case STS_SETUP_COMP:
|
||||||
|
break;
|
||||||
|
case STS_SETUP_UPDT:
|
||||||
|
/* Copy the setup packet received in FIFO into the setup buffer in RAM */
|
||||||
|
USB_OTG_ReadPacket(pdev , pdev->dev.setup_packet, 8);
|
||||||
|
ep->xfer_count += status.b.bcnt;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Enable the Rx Status Queue Level interrupt */
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.GREGS->GINTMSK, 0, int_mask.d32);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_WriteEmptyTxFifo
|
||||||
|
* check FIFO for the next packet to be loaded
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_WriteEmptyTxFifo(USB_OTG_CORE_HANDLE *pdev, uint32_t epnum)
|
||||||
|
{
|
||||||
|
USB_OTG_DTXFSTSn_TypeDef txstatus;
|
||||||
|
USB_OTG_EP *ep;
|
||||||
|
uint32_t len = 0;
|
||||||
|
uint32_t len32b;
|
||||||
|
txstatus.d32 = 0;
|
||||||
|
|
||||||
|
ep = &pdev->dev.in_ep[epnum];
|
||||||
|
|
||||||
|
len = ep->xfer_len - ep->xfer_count;
|
||||||
|
|
||||||
|
if (len > ep->maxpacket)
|
||||||
|
{
|
||||||
|
len = ep->maxpacket;
|
||||||
|
}
|
||||||
|
|
||||||
|
len32b = (len + 3) / 4;
|
||||||
|
txstatus.d32 = USB_OTG_READ_REG32( &pdev->regs.INEP_REGS[epnum]->DTXFSTS);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
while (txstatus.b.txfspcavail > len32b &&
|
||||||
|
ep->xfer_count < ep->xfer_len &&
|
||||||
|
ep->xfer_len != 0)
|
||||||
|
{
|
||||||
|
/* Write the FIFO */
|
||||||
|
len = ep->xfer_len - ep->xfer_count;
|
||||||
|
|
||||||
|
if (len > ep->maxpacket)
|
||||||
|
{
|
||||||
|
len = ep->maxpacket;
|
||||||
|
}
|
||||||
|
len32b = (len + 3) / 4;
|
||||||
|
|
||||||
|
USB_OTG_WritePacket (pdev , ep->xfer_buff, epnum, len);
|
||||||
|
|
||||||
|
ep->xfer_buff += len;
|
||||||
|
ep->xfer_count += len;
|
||||||
|
|
||||||
|
txstatus.d32 = USB_OTG_READ_REG32(&pdev->regs.INEP_REGS[epnum]->DTXFSTS);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_HandleUsbReset_ISR
|
||||||
|
* This interrupt occurs when a USB Reset is detected
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_HandleUsbReset_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_DAINT_TypeDef daintmsk;
|
||||||
|
USB_OTG_DOEPMSK_TypeDef doepmsk;
|
||||||
|
USB_OTG_DIEPMSK_TypeDef diepmsk;
|
||||||
|
USB_OTG_DCFG_TypeDef dcfg;
|
||||||
|
USB_OTG_DCTL_TypeDef dctl;
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
uint32_t i;
|
||||||
|
|
||||||
|
dctl.d32 = 0;
|
||||||
|
daintmsk.d32 = 0;
|
||||||
|
doepmsk.d32 = 0;
|
||||||
|
diepmsk.d32 = 0;
|
||||||
|
dcfg.d32 = 0;
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
|
||||||
|
/* Clear the Remote Wake-up Signaling */
|
||||||
|
dctl.b.rmtwkupsig = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.DREGS->DCTL, dctl.d32, 0 );
|
||||||
|
|
||||||
|
/* Flush the Tx FIFO */
|
||||||
|
USB_OTG_FlushTxFifo(pdev , 0 );
|
||||||
|
|
||||||
|
for (i = 0; i < pdev->cfg.dev_endpoints ; i++)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.INEP_REGS[i]->DIEPINT, 0xFF);
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.OUTEP_REGS[i]->DOEPINT, 0xFF);
|
||||||
|
}
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DAINT, 0xFFFFFFFF );
|
||||||
|
|
||||||
|
daintmsk.ep.in = 1;
|
||||||
|
daintmsk.ep.out = 1;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DAINTMSK, daintmsk.d32 );
|
||||||
|
|
||||||
|
doepmsk.b.setup = 1;
|
||||||
|
doepmsk.b.xfercompl = 1;
|
||||||
|
doepmsk.b.ahberr = 1;
|
||||||
|
doepmsk.b.epdisabled = 1;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DOEPMSK, doepmsk.d32 );
|
||||||
|
#ifdef USB_OTG_HS_DEDICATED_EP1_ENABLED
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DOUTEP1MSK, doepmsk.d32 );
|
||||||
|
#endif
|
||||||
|
diepmsk.b.xfercompl = 1;
|
||||||
|
diepmsk.b.timeout = 1;
|
||||||
|
diepmsk.b.epdisabled = 1;
|
||||||
|
diepmsk.b.ahberr = 1;
|
||||||
|
diepmsk.b.intknepmis = 1;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DIEPMSK, diepmsk.d32 );
|
||||||
|
#ifdef USB_OTG_HS_DEDICATED_EP1_ENABLED
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DINEP1MSK, diepmsk.d32 );
|
||||||
|
#endif
|
||||||
|
/* Reset Device Address */
|
||||||
|
dcfg.d32 = USB_OTG_READ_REG32( &pdev->regs.DREGS->DCFG);
|
||||||
|
dcfg.b.devaddr = 0;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.DREGS->DCFG, dcfg.d32);
|
||||||
|
|
||||||
|
|
||||||
|
/* setup EP0 to receive SETUP packets */
|
||||||
|
USB_OTG_EP0_OutStart(pdev);
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
gintsts.b.usbreset = 1;
|
||||||
|
USB_OTG_WRITE_REG32 (&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
|
||||||
|
/*Reset internal state machine */
|
||||||
|
USBD_DCD_INT_fops->Reset(pdev);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_HandleEnumDone_ISR
|
||||||
|
* Read the device status register and set the device speed
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_HandleEnumDone_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
USB_OTG_GUSBCFG_TypeDef gusbcfg;
|
||||||
|
|
||||||
|
USB_OTG_EP0Activate(pdev);
|
||||||
|
|
||||||
|
/* Set USB turn-around time based on device speed and PHY interface. */
|
||||||
|
gusbcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GUSBCFG);
|
||||||
|
|
||||||
|
/* Full or High speed */
|
||||||
|
if ( USB_OTG_GetDeviceSpeed(pdev) == USB_SPEED_HIGH)
|
||||||
|
{
|
||||||
|
pdev->cfg.speed = USB_OTG_SPEED_HIGH;
|
||||||
|
pdev->cfg.mps = USB_OTG_HS_MAX_PACKET_SIZE ;
|
||||||
|
gusbcfg.b.usbtrdtim = 9;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pdev->cfg.speed = USB_OTG_SPEED_FULL;
|
||||||
|
pdev->cfg.mps = USB_OTG_FS_MAX_PACKET_SIZE ;
|
||||||
|
gusbcfg.b.usbtrdtim = 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GUSBCFG, gusbcfg.d32);
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
gintsts.b.enumdone = 1;
|
||||||
|
USB_OTG_WRITE_REG32( &pdev->regs.GREGS->GINTSTS, gintsts.d32 );
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_IsoINIncomplete_ISR
|
||||||
|
* handle the ISO IN incomplete interrupt
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_IsoINIncomplete_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
|
||||||
|
USBD_DCD_INT_fops->IsoINIncomplete (pdev);
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.b.incomplisoin = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief DCD_IsoOUTIncomplete_ISR
|
||||||
|
* handle the ISO OUT incomplete interrupt
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_IsoOUTIncomplete_ISR(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
|
||||||
|
USBD_DCD_INT_fops->IsoOUTIncomplete (pdev);
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.b.incomplisoout = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* @brief DCD_ReadDevInEP
|
||||||
|
* Reads ep flags
|
||||||
|
* @param pdev: device instance
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t DCD_ReadDevInEP (USB_OTG_CORE_HANDLE *pdev, uint8_t epnum)
|
||||||
|
{
|
||||||
|
uint32_t v, msk, emp;
|
||||||
|
msk = USB_OTG_READ_REG32(&pdev->regs.DREGS->DIEPMSK);
|
||||||
|
emp = USB_OTG_READ_REG32(&pdev->regs.DREGS->DIEPEMPMSK);
|
||||||
|
msk |= ((emp >> epnum) & 0x1) << 7;
|
||||||
|
v = USB_OTG_READ_REG32(&pdev->regs.INEP_REGS[epnum]->DIEPINT) & msk;
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -0,0 +1,256 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_hcd.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Host Interface Layer
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_core.h"
|
||||||
|
#include "usb_hcd.h"
|
||||||
|
#include "usb_conf.h"
|
||||||
|
#include "usb_bsp.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD
|
||||||
|
* @brief This file is the interface between EFSL ans Host mass-storage class
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_Init
|
||||||
|
* Initialize the HOST portion of the driver.
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @param base_address: OTG base address
|
||||||
|
* @retval Status
|
||||||
|
*/
|
||||||
|
uint32_t HCD_Init(USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
USB_OTG_CORE_ID_TypeDef coreID)
|
||||||
|
{
|
||||||
|
uint8_t i = 0;
|
||||||
|
pdev->host.ConnSts = 0;
|
||||||
|
|
||||||
|
for (i= 0; i< USB_OTG_MAX_TX_FIFOS; i++)
|
||||||
|
{
|
||||||
|
pdev->host.ErrCnt[i] = 0;
|
||||||
|
pdev->host.XferCnt[i] = 0;
|
||||||
|
pdev->host.HC_Status[i] = HC_IDLE;
|
||||||
|
}
|
||||||
|
pdev->host.hc[0].max_packet = 8;
|
||||||
|
|
||||||
|
USB_OTG_SelectCore(pdev, coreID);
|
||||||
|
#ifndef DUAL_ROLE_MODE_ENABLED
|
||||||
|
USB_OTG_DisableGlobalInt(pdev);
|
||||||
|
USB_OTG_CoreInit(pdev);
|
||||||
|
|
||||||
|
/* Force Host Mode*/
|
||||||
|
USB_OTG_SetCurrentMode(pdev , HOST_MODE);
|
||||||
|
USB_OTG_CoreInitHost(pdev);
|
||||||
|
USB_OTG_EnableGlobalInt(pdev);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_GetCurrentSpeed
|
||||||
|
* Get Current device Speed.
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval Status
|
||||||
|
*/
|
||||||
|
|
||||||
|
uint32_t HCD_GetCurrentSpeed (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_HPRT0_TypeDef HPRT0;
|
||||||
|
HPRT0.d32 = USB_OTG_READ_REG32(pdev->regs.HPRT0);
|
||||||
|
|
||||||
|
return HPRT0.b.prtspd;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_ResetPort
|
||||||
|
* Issues the reset command to device
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval Status
|
||||||
|
*/
|
||||||
|
uint32_t HCD_ResetPort(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
Before starting to drive a USB reset, the application waits for the OTG
|
||||||
|
interrupt triggered by the debounce done bit (DBCDNE bit in OTG_FS_GOTGINT),
|
||||||
|
which indicates that the bus is stable again after the electrical debounce
|
||||||
|
caused by the attachment of a pull-up resistor on DP (FS) or DM (LS).
|
||||||
|
*/
|
||||||
|
|
||||||
|
USB_OTG_ResetPort(pdev);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_IsDeviceConnected
|
||||||
|
* Check if the device is connected.
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval Device connection status. 1 -> connected and 0 -> disconnected
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
uint32_t HCD_IsDeviceConnected(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
return (pdev->host.ConnSts);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_GetCurrentFrame
|
||||||
|
* This function returns the frame number for sof packet
|
||||||
|
* @param pdev : Selected device
|
||||||
|
* @retval Frame number
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
uint32_t HCD_GetCurrentFrame (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
return (USB_OTG_READ_REG32(&pdev->regs.HREGS->HFNUM) & 0xFFFF) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_GetURB_State
|
||||||
|
* This function returns the last URBstate
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval URB_STATE
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
URB_STATE HCD_GetURB_State (USB_OTG_CORE_HANDLE *pdev , uint8_t ch_num)
|
||||||
|
{
|
||||||
|
return pdev->host.URB_State[ch_num] ;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_GetXferCnt
|
||||||
|
* This function returns the last URBstate
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval No. of data bytes transferred
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
uint32_t HCD_GetXferCnt (USB_OTG_CORE_HANDLE *pdev, uint8_t ch_num)
|
||||||
|
{
|
||||||
|
return pdev->host.XferCnt[ch_num] ;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_GetHCState
|
||||||
|
* This function returns the HC Status
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval HC_STATUS
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
HC_STATUS HCD_GetHCState (USB_OTG_CORE_HANDLE *pdev , uint8_t ch_num)
|
||||||
|
{
|
||||||
|
return pdev->host.HC_Status[ch_num] ;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_HC_Init
|
||||||
|
* This function prepare a HC and start a transfer
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @param hc_num: Channel number
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
uint32_t HCD_HC_Init (USB_OTG_CORE_HANDLE *pdev , uint8_t hc_num)
|
||||||
|
{
|
||||||
|
return USB_OTG_HC_Init(pdev, hc_num);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HCD_SubmitRequest
|
||||||
|
* This function prepare a HC and start a transfer
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @param hc_num: Channel number
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
uint32_t HCD_SubmitRequest (USB_OTG_CORE_HANDLE *pdev , uint8_t hc_num)
|
||||||
|
{
|
||||||
|
|
||||||
|
pdev->host.URB_State[hc_num] = URB_IDLE;
|
||||||
|
pdev->host.hc[hc_num].xfer_count = 0 ;
|
||||||
|
return USB_OTG_HC_StartXfer(pdev, hc_num);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -0,0 +1,832 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_hcd_int.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief Host driver interrupt subroutines
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_core.h"
|
||||||
|
#include "usb_defines.h"
|
||||||
|
#include "usb_hcd_int.h"
|
||||||
|
|
||||||
|
#if defined (__CC_ARM) /*!< ARM Compiler */
|
||||||
|
#pragma O0
|
||||||
|
#elif defined ( __ICCARM__ ) /*!< IAR Compiler */
|
||||||
|
#pragma O0
|
||||||
|
#elif defined (__GNUC__) /*!< GNU Compiler */
|
||||||
|
#pragma GCC optimize ("O0")
|
||||||
|
#elif defined (__TASKING__) /*!< TASKING Compiler */
|
||||||
|
#pragma optimize=0
|
||||||
|
|
||||||
|
#endif /* __CC_ARM */
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT
|
||||||
|
* @brief This file contains the interrupt subroutines for the Host mode.
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
static uint32_t USB_OTG_USBH_handle_sof_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t USB_OTG_USBH_handle_port_ISR(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t USB_OTG_USBH_handle_hc_ISR (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t USB_OTG_USBH_handle_hc_n_In_ISR (USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint32_t num);
|
||||||
|
static uint32_t USB_OTG_USBH_handle_hc_n_Out_ISR (USB_OTG_CORE_HANDLE *pdev ,
|
||||||
|
uint32_t num);
|
||||||
|
static uint32_t USB_OTG_USBH_handle_rx_qlvl_ISR (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t USB_OTG_USBH_handle_nptxfempty_ISR (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t USB_OTG_USBH_handle_ptxfempty_ISR (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t USB_OTG_USBH_handle_Disconnect_ISR (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
static uint32_t USB_OTG_USBH_handle_IncompletePeriodicXfer_ISR (USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_HCD_INT_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief HOST_Handle_ISR
|
||||||
|
* This function handles all USB Host Interrupts
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
|
||||||
|
uint32_t USBH_OTG_ISR_Handler (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
uint32_t retval = 0;
|
||||||
|
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
|
||||||
|
/* Check if HOST Mode */
|
||||||
|
if (USB_OTG_IsHostMode(pdev))
|
||||||
|
{
|
||||||
|
gintsts.d32 = USB_OTG_ReadCoreItr(pdev);
|
||||||
|
if (!gintsts.d32)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintsts.b.sofintr)
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_sof_ISR (pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintsts.b.rxstsqlvl)
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_rx_qlvl_ISR (pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintsts.b.nptxfempty)
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_nptxfempty_ISR (pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintsts.b.ptxfempty)
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_ptxfempty_ISR (pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintsts.b.hcintr)
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_hc_ISR (pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintsts.b.portintr)
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_port_ISR (pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintsts.b.disconnect)
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_Disconnect_ISR (pdev);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gintsts.b.incomplisoout)
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_IncompletePeriodicXfer_ISR (pdev);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_USBH_handle_hc_ISR
|
||||||
|
* This function indicates that one or more host channels has a pending
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t USB_OTG_USBH_handle_hc_ISR (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_HAINT_TypeDef haint;
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
uint32_t i = 0;
|
||||||
|
uint32_t retval = 0;
|
||||||
|
|
||||||
|
/* Clear appropriate bits in HCINTn to clear the interrupt bit in
|
||||||
|
* GINTSTS */
|
||||||
|
|
||||||
|
haint.d32 = USB_OTG_ReadHostAllChannels_intr(pdev);
|
||||||
|
|
||||||
|
for (i = 0; i < pdev->cfg.host_channels ; i++)
|
||||||
|
{
|
||||||
|
if (haint.b.chint & (1 << i))
|
||||||
|
{
|
||||||
|
hcchar.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[i]->HCCHAR);
|
||||||
|
|
||||||
|
if (hcchar.b.epdir)
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_hc_n_In_ISR (pdev, i);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
retval |= USB_OTG_USBH_handle_hc_n_Out_ISR (pdev, i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_otg_hcd_handle_sof_intr
|
||||||
|
* Handles the start-of-frame interrupt in host mode.
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t USB_OTG_USBH_handle_sof_ISR (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
|
||||||
|
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.b.sofintr = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_USBH_handle_Disconnect_ISR
|
||||||
|
* Handles disconnect event.
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t USB_OTG_USBH_handle_Disconnect_ISR (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
|
||||||
|
pdev->host.ConnSts = 0;
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
|
||||||
|
pdev->host.port_cb->Disconnect(pdev);
|
||||||
|
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.b.disconnect = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_USBH_handle_nptxfempty_ISR
|
||||||
|
* Handles non periodic tx fifo empty.
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t USB_OTG_USBH_handle_nptxfempty_ISR (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTMSK_TypeDef intmsk;
|
||||||
|
USB_OTG_HNPTXSTS_TypeDef hnptxsts;
|
||||||
|
uint16_t len_words , len;
|
||||||
|
|
||||||
|
hnptxsts.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->HNPTXSTS);
|
||||||
|
|
||||||
|
len_words = (pdev->host.hc[hnptxsts.b.chnum].xfer_len + 3) / 4;
|
||||||
|
|
||||||
|
while ((hnptxsts.b.nptxfspcavail > len_words)&&
|
||||||
|
(pdev->host.hc[hnptxsts.b.chnum].xfer_len != 0))
|
||||||
|
{
|
||||||
|
|
||||||
|
len = hnptxsts.b.nptxfspcavail * 4;
|
||||||
|
|
||||||
|
if (len > pdev->host.hc[hnptxsts.b.chnum].xfer_len)
|
||||||
|
{
|
||||||
|
/* Last packet */
|
||||||
|
len = pdev->host.hc[hnptxsts.b.chnum].xfer_len;
|
||||||
|
|
||||||
|
intmsk.d32 = 0;
|
||||||
|
intmsk.b.nptxfempty = 1;
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.GREGS->GINTMSK, intmsk.d32, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
len_words = (pdev->host.hc[hnptxsts.b.chnum].xfer_len + 3) / 4;
|
||||||
|
|
||||||
|
USB_OTG_WritePacket (pdev , pdev->host.hc[hnptxsts.b.chnum].xfer_buff, hnptxsts.b.chnum, len);
|
||||||
|
|
||||||
|
pdev->host.hc[hnptxsts.b.chnum].xfer_buff += len;
|
||||||
|
pdev->host.hc[hnptxsts.b.chnum].xfer_len -= len;
|
||||||
|
pdev->host.hc[hnptxsts.b.chnum].xfer_count += len;
|
||||||
|
|
||||||
|
hnptxsts.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->HNPTXSTS);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_USBH_handle_ptxfempty_ISR
|
||||||
|
* Handles periodic tx fifo empty
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t USB_OTG_USBH_handle_ptxfempty_ISR (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTMSK_TypeDef intmsk;
|
||||||
|
USB_OTG_HPTXSTS_TypeDef hptxsts;
|
||||||
|
uint16_t len_words , len;
|
||||||
|
|
||||||
|
hptxsts.d32 = USB_OTG_READ_REG32(&pdev->regs.HREGS->HPTXSTS);
|
||||||
|
|
||||||
|
len_words = (pdev->host.hc[hptxsts.b.chnum].xfer_len + 3) / 4;
|
||||||
|
|
||||||
|
while ((hptxsts.b.ptxfspcavail > len_words)&&
|
||||||
|
(pdev->host.hc[hptxsts.b.chnum].xfer_len != 0))
|
||||||
|
{
|
||||||
|
|
||||||
|
len = hptxsts.b.ptxfspcavail * 4;
|
||||||
|
|
||||||
|
if (len > pdev->host.hc[hptxsts.b.chnum].xfer_len)
|
||||||
|
{
|
||||||
|
len = pdev->host.hc[hptxsts.b.chnum].xfer_len;
|
||||||
|
/* Last packet */
|
||||||
|
intmsk.d32 = 0;
|
||||||
|
intmsk.b.ptxfempty = 1;
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.GREGS->GINTMSK, intmsk.d32, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
len_words = (pdev->host.hc[hptxsts.b.chnum].xfer_len + 3) / 4;
|
||||||
|
|
||||||
|
USB_OTG_WritePacket (pdev , pdev->host.hc[hptxsts.b.chnum].xfer_buff, hptxsts.b.chnum, len);
|
||||||
|
|
||||||
|
pdev->host.hc[hptxsts.b.chnum].xfer_buff += len;
|
||||||
|
pdev->host.hc[hptxsts.b.chnum].xfer_len -= len;
|
||||||
|
pdev->host.hc[hptxsts.b.chnum].xfer_count += len;
|
||||||
|
|
||||||
|
hptxsts.d32 = USB_OTG_READ_REG32(&pdev->regs.HREGS->HPTXSTS);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_USBH_handle_port_ISR
|
||||||
|
* This function determines which interrupt conditions have occurred
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t USB_OTG_USBH_handle_port_ISR (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_HPRT0_TypeDef hprt0;
|
||||||
|
USB_OTG_HPRT0_TypeDef hprt0_dup;
|
||||||
|
USB_OTG_HCFG_TypeDef hcfg;
|
||||||
|
uint32_t do_reset = 0;
|
||||||
|
uint32_t retval = 0;
|
||||||
|
|
||||||
|
hcfg.d32 = 0;
|
||||||
|
hprt0.d32 = 0;
|
||||||
|
hprt0_dup.d32 = 0;
|
||||||
|
|
||||||
|
hprt0.d32 = USB_OTG_READ_REG32(pdev->regs.HPRT0);
|
||||||
|
hprt0_dup.d32 = USB_OTG_READ_REG32(pdev->regs.HPRT0);
|
||||||
|
|
||||||
|
/* Clear the interrupt bits in GINTSTS */
|
||||||
|
|
||||||
|
hprt0_dup.b.prtena = 0;
|
||||||
|
hprt0_dup.b.prtconndet = 0;
|
||||||
|
hprt0_dup.b.prtenchng = 0;
|
||||||
|
hprt0_dup.b.prtovrcurrchng = 0;
|
||||||
|
|
||||||
|
/* Port Connect Detected */
|
||||||
|
if (hprt0.b.prtconndet)
|
||||||
|
{
|
||||||
|
pdev->host.port_cb->Connect(pdev);
|
||||||
|
hprt0_dup.b.prtconndet = 1;
|
||||||
|
do_reset = 1;
|
||||||
|
retval |= 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Port Enable Changed */
|
||||||
|
if (hprt0.b.prtenchng)
|
||||||
|
{
|
||||||
|
hprt0_dup.b.prtenchng = 1;
|
||||||
|
if (hprt0.b.prtena == 1)
|
||||||
|
{
|
||||||
|
pdev->host.ConnSts = 1;
|
||||||
|
|
||||||
|
if ((hprt0.b.prtspd == HPRT0_PRTSPD_LOW_SPEED) ||
|
||||||
|
(hprt0.b.prtspd == HPRT0_PRTSPD_FULL_SPEED))
|
||||||
|
{
|
||||||
|
|
||||||
|
hcfg.d32 = USB_OTG_READ_REG32(&pdev->regs.HREGS->HCFG);
|
||||||
|
|
||||||
|
if (hprt0.b.prtspd == HPRT0_PRTSPD_LOW_SPEED)
|
||||||
|
{
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HREGS->HFIR, 6000 );
|
||||||
|
if (hcfg.b.fslspclksel != HCFG_6_MHZ)
|
||||||
|
{
|
||||||
|
if(pdev->cfg.coreID == USB_OTG_FS_CORE_ID)
|
||||||
|
{
|
||||||
|
USB_OTG_InitFSLSPClkSel(pdev ,HCFG_6_MHZ );
|
||||||
|
}
|
||||||
|
do_reset = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HREGS->HFIR, 48000 );
|
||||||
|
if (hcfg.b.fslspclksel != HCFG_48_MHZ)
|
||||||
|
{
|
||||||
|
USB_OTG_InitFSLSPClkSel(pdev ,HCFG_48_MHZ );
|
||||||
|
do_reset = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
do_reset = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Overcurrent Change Interrupt */
|
||||||
|
if (hprt0.b.prtovrcurrchng)
|
||||||
|
{
|
||||||
|
hprt0_dup.b.prtovrcurrchng = 1;
|
||||||
|
retval |= 1;
|
||||||
|
}
|
||||||
|
if (do_reset)
|
||||||
|
{
|
||||||
|
USB_OTG_ResetPort(pdev);
|
||||||
|
|
||||||
|
}
|
||||||
|
/* Clear Port Interrupts */
|
||||||
|
USB_OTG_WRITE_REG32(pdev->regs.HPRT0, hprt0_dup.d32);
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_USBH_handle_hc_n_Out_ISR
|
||||||
|
* Handles interrupt for a specific Host Channel
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @param hc_num: Channel number
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_USBH_handle_hc_n_Out_ISR (USB_OTG_CORE_HANDLE *pdev , uint32_t num)
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_HCINTn_TypeDef hcint;
|
||||||
|
USB_OTG_HCGINTMSK_TypeDef hcintmsk;
|
||||||
|
USB_OTG_HC_REGS *hcreg;
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
|
||||||
|
hcreg = pdev->regs.HC_REGS[num];
|
||||||
|
hcint.d32 = USB_OTG_READ_REG32(&hcreg->HCINT);
|
||||||
|
hcintmsk.d32 = USB_OTG_READ_REG32(&hcreg->HCGINTMSK);
|
||||||
|
hcint.d32 = hcint.d32 & hcintmsk.d32;
|
||||||
|
|
||||||
|
hcchar.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[num]->HCCHAR);
|
||||||
|
|
||||||
|
if (hcint.b.ahberr)
|
||||||
|
{
|
||||||
|
CLEAR_HC_INT(hcreg ,ahberr);
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
}
|
||||||
|
else if (hcint.b.ack)
|
||||||
|
{
|
||||||
|
CLEAR_HC_INT(hcreg , ack);
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (hcint.b.xfercompl)
|
||||||
|
{
|
||||||
|
pdev->host.ErrCnt[num] = 0;
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
CLEAR_HC_INT(hcreg , xfercompl);
|
||||||
|
pdev->host.HC_Status[num] = HC_XFRC;
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (hcint.b.stall)
|
||||||
|
{
|
||||||
|
CLEAR_HC_INT(hcreg , stall);
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
pdev->host.HC_Status[num] = HC_STALL;
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (hcint.b.nak)
|
||||||
|
{
|
||||||
|
pdev->host.ErrCnt[num] = 0;
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
CLEAR_HC_INT(hcreg , nak);
|
||||||
|
pdev->host.HC_Status[num] = HC_NAK;
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (hcint.b.xacterr)
|
||||||
|
{
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
pdev->host.ErrCnt[num] ++;
|
||||||
|
pdev->host.HC_Status[num] = HC_XACTERR;
|
||||||
|
CLEAR_HC_INT(hcreg , xacterr);
|
||||||
|
}
|
||||||
|
else if (hcint.b.nyet)
|
||||||
|
{
|
||||||
|
pdev->host.ErrCnt[num] = 0;
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
CLEAR_HC_INT(hcreg , nyet);
|
||||||
|
pdev->host.HC_Status[num] = HC_NYET;
|
||||||
|
}
|
||||||
|
else if (hcint.b.datatglerr)
|
||||||
|
{
|
||||||
|
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
CLEAR_HC_INT(hcreg , nak);
|
||||||
|
pdev->host.HC_Status[num] = HC_DATATGLERR;
|
||||||
|
|
||||||
|
CLEAR_HC_INT(hcreg , datatglerr);
|
||||||
|
}
|
||||||
|
else if (hcint.b.chhltd)
|
||||||
|
{
|
||||||
|
MASK_HOST_INT_CHH (num);
|
||||||
|
|
||||||
|
if(pdev->host.HC_Status[num] == HC_XFRC)
|
||||||
|
{
|
||||||
|
pdev->host.URB_State[num] = URB_DONE;
|
||||||
|
|
||||||
|
if (hcchar.b.eptype == EP_TYPE_BULK)
|
||||||
|
{
|
||||||
|
pdev->host.hc[num].toggle_out ^= 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(pdev->host.HC_Status[num] == HC_NAK)
|
||||||
|
{
|
||||||
|
pdev->host.URB_State[num] = URB_NOTREADY;
|
||||||
|
}
|
||||||
|
else if(pdev->host.HC_Status[num] == HC_NYET)
|
||||||
|
{
|
||||||
|
if(pdev->host.hc[num].do_ping == 1)
|
||||||
|
{
|
||||||
|
USB_OTG_HC_DoPing(pdev, num);
|
||||||
|
}
|
||||||
|
pdev->host.URB_State[num] = URB_NOTREADY;
|
||||||
|
}
|
||||||
|
else if(pdev->host.HC_Status[num] == HC_STALL)
|
||||||
|
{
|
||||||
|
pdev->host.URB_State[num] = URB_STALL;
|
||||||
|
}
|
||||||
|
else if(pdev->host.HC_Status[num] == HC_XACTERR)
|
||||||
|
{
|
||||||
|
if (pdev->host.ErrCnt[num] == 3)
|
||||||
|
{
|
||||||
|
pdev->host.URB_State[num] = URB_ERROR;
|
||||||
|
pdev->host.ErrCnt[num] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
CLEAR_HC_INT(hcreg , chhltd);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_USBH_handle_hc_n_In_ISR
|
||||||
|
* Handles interrupt for a specific Host Channel
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @param hc_num: Channel number
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_USBH_handle_hc_n_In_ISR (USB_OTG_CORE_HANDLE *pdev , uint32_t num)
|
||||||
|
{
|
||||||
|
USB_OTG_HCINTn_TypeDef hcint;
|
||||||
|
USB_OTG_HCGINTMSK_TypeDef hcintmsk;
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
USB_OTG_HCTSIZn_TypeDef hctsiz;
|
||||||
|
USB_OTG_HC_REGS *hcreg;
|
||||||
|
|
||||||
|
|
||||||
|
hcreg = pdev->regs.HC_REGS[num];
|
||||||
|
hcint.d32 = USB_OTG_READ_REG32(&hcreg->HCINT);
|
||||||
|
hcintmsk.d32 = USB_OTG_READ_REG32(&hcreg->HCGINTMSK);
|
||||||
|
hcint.d32 = hcint.d32 & hcintmsk.d32;
|
||||||
|
hcchar.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[num]->HCCHAR);
|
||||||
|
hcintmsk.d32 = 0;
|
||||||
|
|
||||||
|
|
||||||
|
if (hcint.b.ahberr)
|
||||||
|
{
|
||||||
|
CLEAR_HC_INT(hcreg ,ahberr);
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
}
|
||||||
|
else if (hcint.b.ack)
|
||||||
|
{
|
||||||
|
CLEAR_HC_INT(hcreg ,ack);
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (hcint.b.stall)
|
||||||
|
{
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
pdev->host.HC_Status[num] = HC_STALL;
|
||||||
|
CLEAR_HC_INT(hcreg , nak); /* Clear the NAK Condition */
|
||||||
|
CLEAR_HC_INT(hcreg , stall); /* Clear the STALL Condition */
|
||||||
|
hcint.b.nak = 0; /* NOTE: When there is a 'stall', reset also nak,
|
||||||
|
else, the pdev->host.HC_Status = HC_STALL
|
||||||
|
will be overwritten by 'nak' in code below */
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
}
|
||||||
|
else if (hcint.b.datatglerr)
|
||||||
|
{
|
||||||
|
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
CLEAR_HC_INT(hcreg , nak);
|
||||||
|
pdev->host.HC_Status[num] = HC_DATATGLERR;
|
||||||
|
CLEAR_HC_INT(hcreg , datatglerr);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hcint.b.frmovrun)
|
||||||
|
{
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
CLEAR_HC_INT(hcreg ,frmovrun);
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (hcint.b.xfercompl)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (pdev->cfg.dma_enable == 1)
|
||||||
|
{
|
||||||
|
hctsiz.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[num]->HCTSIZ);
|
||||||
|
pdev->host.XferCnt[num] = pdev->host.hc[num].xfer_len - hctsiz.b.xfersize;
|
||||||
|
}
|
||||||
|
|
||||||
|
pdev->host.HC_Status[num] = HC_XFRC;
|
||||||
|
pdev->host.ErrCnt [num]= 0;
|
||||||
|
CLEAR_HC_INT(hcreg , xfercompl);
|
||||||
|
|
||||||
|
if ((hcchar.b.eptype == EP_TYPE_CTRL)||
|
||||||
|
(hcchar.b.eptype == EP_TYPE_BULK))
|
||||||
|
{
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
CLEAR_HC_INT(hcreg , nak);
|
||||||
|
pdev->host.hc[num].toggle_in ^= 1;
|
||||||
|
|
||||||
|
}
|
||||||
|
else if(hcchar.b.eptype == EP_TYPE_INTR)
|
||||||
|
{
|
||||||
|
hcchar.b.oddfrm = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[num]->HCCHAR, hcchar.d32);
|
||||||
|
pdev->host.URB_State[num] = URB_DONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else if (hcint.b.chhltd)
|
||||||
|
{
|
||||||
|
MASK_HOST_INT_CHH (num);
|
||||||
|
|
||||||
|
if(pdev->host.HC_Status[num] == HC_XFRC)
|
||||||
|
{
|
||||||
|
pdev->host.URB_State[num] = URB_DONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (pdev->host.HC_Status[num] == HC_STALL)
|
||||||
|
{
|
||||||
|
pdev->host.URB_State[num] = URB_STALL;
|
||||||
|
}
|
||||||
|
|
||||||
|
else if((pdev->host.HC_Status[num] == HC_XACTERR) ||
|
||||||
|
(pdev->host.HC_Status[num] == HC_DATATGLERR))
|
||||||
|
{
|
||||||
|
pdev->host.ErrCnt[num] = 0;
|
||||||
|
pdev->host.URB_State[num] = URB_ERROR;
|
||||||
|
|
||||||
|
}
|
||||||
|
else if(hcchar.b.eptype == EP_TYPE_INTR)
|
||||||
|
{
|
||||||
|
pdev->host.hc[num].toggle_in ^= 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
CLEAR_HC_INT(hcreg , chhltd);
|
||||||
|
|
||||||
|
}
|
||||||
|
else if (hcint.b.xacterr)
|
||||||
|
{
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
pdev->host.ErrCnt[num] ++;
|
||||||
|
pdev->host.HC_Status[num] = HC_XACTERR;
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
CLEAR_HC_INT(hcreg , xacterr);
|
||||||
|
|
||||||
|
}
|
||||||
|
else if (hcint.b.nak)
|
||||||
|
{
|
||||||
|
if(hcchar.b.eptype == EP_TYPE_INTR)
|
||||||
|
{
|
||||||
|
UNMASK_HOST_INT_CHH (num);
|
||||||
|
USB_OTG_HC_Halt(pdev, num);
|
||||||
|
CLEAR_HC_INT(hcreg , nak);
|
||||||
|
}
|
||||||
|
else if ((hcchar.b.eptype == EP_TYPE_CTRL)||
|
||||||
|
(hcchar.b.eptype == EP_TYPE_BULK))
|
||||||
|
{
|
||||||
|
/* re-activate the channel */
|
||||||
|
hcchar.b.chen = 1;
|
||||||
|
hcchar.b.chdis = 0;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[num]->HCCHAR, hcchar.d32);
|
||||||
|
}
|
||||||
|
pdev->host.HC_Status[num] = HC_NAK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_USBH_handle_rx_qlvl_ISR
|
||||||
|
* Handles the Rx Status Queue Level Interrupt
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
|
||||||
|
static uint32_t USB_OTG_USBH_handle_rx_qlvl_ISR (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GRXFSTS_TypeDef grxsts;
|
||||||
|
USB_OTG_GINTMSK_TypeDef intmsk;
|
||||||
|
USB_OTG_HCTSIZn_TypeDef hctsiz;
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
__IO uint8_t channelnum =0;
|
||||||
|
uint32_t count;
|
||||||
|
|
||||||
|
/* Disable the Rx Status Queue Level interrupt */
|
||||||
|
intmsk.d32 = 0;
|
||||||
|
intmsk.b.rxstsqlvl = 1;
|
||||||
|
USB_OTG_MODIFY_REG32( &pdev->regs.GREGS->GINTMSK, intmsk.d32, 0);
|
||||||
|
|
||||||
|
grxsts.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GRXSTSP);
|
||||||
|
channelnum = grxsts.b.chnum;
|
||||||
|
hcchar.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[channelnum]->HCCHAR);
|
||||||
|
|
||||||
|
switch (grxsts.b.pktsts)
|
||||||
|
{
|
||||||
|
case GRXSTS_PKTSTS_IN:
|
||||||
|
/* Read the data into the host buffer. */
|
||||||
|
if ((grxsts.b.bcnt > 0) && (pdev->host.hc[channelnum].xfer_buff != (void *)0))
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_ReadPacket(pdev, pdev->host.hc[channelnum].xfer_buff, grxsts.b.bcnt);
|
||||||
|
/*manage multiple Xfer */
|
||||||
|
pdev->host.hc[grxsts.b.chnum].xfer_buff += grxsts.b.bcnt;
|
||||||
|
pdev->host.hc[grxsts.b.chnum].xfer_count += grxsts.b.bcnt;
|
||||||
|
|
||||||
|
|
||||||
|
count = pdev->host.hc[channelnum].xfer_count;
|
||||||
|
pdev->host.XferCnt[channelnum] = count;
|
||||||
|
|
||||||
|
hctsiz.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[channelnum]->HCTSIZ);
|
||||||
|
if(hctsiz.b.pktcnt > 0)
|
||||||
|
{
|
||||||
|
/* re-activate the channel when more packets are expected */
|
||||||
|
hcchar.b.chen = 1;
|
||||||
|
hcchar.b.chdis = 0;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[channelnum]->HCCHAR, hcchar.d32);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GRXSTS_PKTSTS_IN_XFER_COMP:
|
||||||
|
|
||||||
|
case GRXSTS_PKTSTS_DATA_TOGGLE_ERR:
|
||||||
|
case GRXSTS_PKTSTS_CH_HALTED:
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Enable the Rx Status Queue Level interrupt */
|
||||||
|
intmsk.b.rxstsqlvl = 1;
|
||||||
|
USB_OTG_MODIFY_REG32(&pdev->regs.GREGS->GINTMSK, 0, intmsk.d32);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_USBH_handle_IncompletePeriodicXfer_ISR
|
||||||
|
* Handles the incomplete Periodic transfer Interrupt
|
||||||
|
* @param pdev: Selected device
|
||||||
|
* @retval status
|
||||||
|
*/
|
||||||
|
static uint32_t USB_OTG_USBH_handle_IncompletePeriodicXfer_ISR (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
USB_OTG_HCCHAR_TypeDef hcchar;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
hcchar.d32 = USB_OTG_READ_REG32(&pdev->regs.HC_REGS[0]->HCCHAR);
|
||||||
|
hcchar.b.chen = 1;
|
||||||
|
hcchar.b.chdis = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.HC_REGS[0]->HCCHAR, hcchar.d32);
|
||||||
|
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
/* Clear interrupt */
|
||||||
|
gintsts.b.incomplisoout = 1;
|
||||||
|
USB_OTG_WRITE_REG32(&pdev->regs.GREGS->GINTSTS, gintsts.d32);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
||||||
|
|
@ -0,0 +1,175 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file usb_otg.c
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V2.0.0
|
||||||
|
* @date 22-July-2011
|
||||||
|
* @brief OTG Core Layer
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "usb_defines.h"
|
||||||
|
#include "usb_regs.h"
|
||||||
|
#include "usb_core.h"
|
||||||
|
#include "usb_otg.h"
|
||||||
|
|
||||||
|
/** @addtogroup USB_OTG_DRIVER
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG
|
||||||
|
* @brief This file is the interface between EFSL ans Host mass-storage class
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Private_Defines
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Private_TypesDefinitions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Private_Macros
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Private_Variables
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Private_FunctionPrototypes
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
static uint32_t USB_OTG_Read_itr(USB_OTG_CORE_HANDLE *pdev);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/** @defgroup USB_OTG_Private_Functions
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* OTG Interrupt Handler */
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief STM32_USBO_OTG_ISR_Handler
|
||||||
|
*
|
||||||
|
* @param None
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
uint32_t STM32_USBO_OTG_ISR_Handler(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
uint32_t retval = 0;
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts ;
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
|
||||||
|
gintsts.d32 = USB_OTG_Read_itr(pdev);
|
||||||
|
if (gintsts.d32 == 0)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (gintsts.b.otgintr)
|
||||||
|
{
|
||||||
|
retval |= 1;//USB_OTG_HandleOTG_ISR(pdev);
|
||||||
|
}
|
||||||
|
if (gintsts.b.conidstschng)
|
||||||
|
{
|
||||||
|
retval |= 2;//USB_OTG_HandleConnectorIDStatusChange_ISR(pdev);
|
||||||
|
}
|
||||||
|
if (gintsts.b.sessreqintr)
|
||||||
|
{
|
||||||
|
retval |= 3;//USB_OTG_HandleSessionRequest_ISR(pdev);
|
||||||
|
}
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_Read_itr
|
||||||
|
* returns the Core Interrupt register
|
||||||
|
* @param None
|
||||||
|
* @retval : status
|
||||||
|
*/
|
||||||
|
static uint32_t USB_OTG_Read_itr(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
USB_OTG_GINTSTS_TypeDef gintsts;
|
||||||
|
USB_OTG_GINTMSK_TypeDef gintmsk;
|
||||||
|
USB_OTG_GINTMSK_TypeDef gintmsk_common;
|
||||||
|
|
||||||
|
|
||||||
|
gintsts.d32 = 0;
|
||||||
|
gintmsk.d32 = 0;
|
||||||
|
gintmsk_common.d32 = 0;
|
||||||
|
|
||||||
|
/* OTG interrupts */
|
||||||
|
gintmsk_common.b.sessreqintr = 1;
|
||||||
|
gintmsk_common.b.conidstschng = 1;
|
||||||
|
gintmsk_common.b.otgintr = 1;
|
||||||
|
|
||||||
|
gintsts.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GINTSTS);
|
||||||
|
gintmsk.d32 = USB_OTG_READ_REG32(&pdev->regs.GREGS->GINTMSK);
|
||||||
|
return ((gintsts.d32 & gintmsk.d32 ) & gintmsk_common.d32);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief USB_OTG_GetCurrentState
|
||||||
|
* Return current OTG State
|
||||||
|
* @param None
|
||||||
|
* @retval : None
|
||||||
|
*/
|
||||||
|
uint32_t USB_OTG_GetCurrentState (USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
return pdev->otg.OTG_State;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
@ -45,6 +45,21 @@ PERIPHLIB = $(PIOS_DEVLIB)/Libraries/STM32F4xx_StdPeriph_Driver
|
|||||||
SRC += $(wildcard $(PERIPHLIB)/src/*.c)
|
SRC += $(wildcard $(PERIPHLIB)/src/*.c)
|
||||||
EXTRAINCDIRS += $(PERIPHLIB)/inc
|
EXTRAINCDIRS += $(PERIPHLIB)/inc
|
||||||
|
|
||||||
|
#
|
||||||
|
# ST USB OTG library
|
||||||
|
#
|
||||||
|
USBOTGLIB = $(PIOS_DEVLIB)/Libraries/STM32_USB_OTG_Driver
|
||||||
|
USBOTGLIB_SRC = usb_core.c usb_dcd.c usb_dcd_int.c
|
||||||
|
SRC += $(addprefix $(USBOTGLIB)/src/,$(USBOTGLIB_SRC))
|
||||||
|
EXTRAINCDIRS += $(USBOTGLIB)/inc
|
||||||
|
|
||||||
|
#
|
||||||
|
# ST USB Device library
|
||||||
|
#
|
||||||
|
USBDEVLIB = $(PIOS_DEVLIB)/Libraries/STM32_USB_Device_Library
|
||||||
|
SRC += $(wildcard $(USBDEVLIB)/Core/src/*.c)
|
||||||
|
EXTRAINCDIRS += $(USBDEVLIB)/Core/inc
|
||||||
|
|
||||||
#
|
#
|
||||||
# FreeRTOS
|
# FreeRTOS
|
||||||
#
|
#
|
||||||
|
@ -94,7 +94,7 @@ void PIOS_SYS_Init(void)
|
|||||||
//RCC_AHB2Periph_CRYP | No crypto
|
//RCC_AHB2Periph_CRYP | No crypto
|
||||||
//RCC_AHB2Periph_HASH | No hash generator
|
//RCC_AHB2Periph_HASH | No hash generator
|
||||||
//RCC_AHB2Periph_RNG | No random numbers @todo might be good to have later if entropy is desired
|
//RCC_AHB2Periph_RNG | No random numbers @todo might be good to have later if entropy is desired
|
||||||
RCC_AHB2Periph_OTG_FS |
|
//RCC_AHB2Periph_OTG_FS |
|
||||||
0, ENABLE);
|
0, ENABLE);
|
||||||
RCC_AHB3PeriphClockCmd(
|
RCC_AHB3PeriphClockCmd(
|
||||||
//RCC_AHB3Periph_FSMC | No external static memory
|
//RCC_AHB3Periph_FSMC | No external static memory
|
||||||
|
290
flight/PiOS/STM32F4xx/pios_usb.c
Normal file
290
flight/PiOS/STM32F4xx/pios_usb.c
Normal file
@ -0,0 +1,290 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @addtogroup PIOS PIOS Core hardware abstraction layer
|
||||||
|
* @{
|
||||||
|
* @addtogroup PIOS_USB USB Setup Functions
|
||||||
|
* @brief PIOS USB device implementation
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file pios_usb.c
|
||||||
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||||
|
* @brief USB device functions (STM32 dependent code)
|
||||||
|
* @see The GNU Public License (GPL) Version 3
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
/*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Project Includes */
|
||||||
|
#include "pios.h"
|
||||||
|
#include "usb_core.h"
|
||||||
|
#include "pios_usb_board_data.h"
|
||||||
|
#include "pios_usb.h"
|
||||||
|
#include "pios_usb_priv.h"
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB)
|
||||||
|
|
||||||
|
/* Rx/Tx status */
|
||||||
|
static uint8_t transfer_possible = 0;
|
||||||
|
|
||||||
|
enum pios_usb_dev_magic {
|
||||||
|
PIOS_USB_DEV_MAGIC = 0x17365904,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct pios_usb_dev {
|
||||||
|
enum pios_usb_dev_magic magic;
|
||||||
|
const struct pios_usb_cfg * cfg;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Validate the usb device structure
|
||||||
|
* @returns true if valid device or false otherwise
|
||||||
|
*/
|
||||||
|
static bool PIOS_USB_validate(struct pios_usb_dev * usb_dev)
|
||||||
|
{
|
||||||
|
return (usb_dev && (usb_dev->magic == PIOS_USB_DEV_MAGIC));
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_FREERTOS)
|
||||||
|
static struct pios_usb_dev * PIOS_USB_alloc(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_dev * usb_dev;
|
||||||
|
|
||||||
|
usb_dev = (struct pios_usb_dev *)pvPortMalloc(sizeof(*usb_dev));
|
||||||
|
if (!usb_dev) return(NULL);
|
||||||
|
|
||||||
|
usb_dev->magic = PIOS_USB_DEV_MAGIC;
|
||||||
|
return(usb_dev);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static struct pios_usb_dev pios_usb_devs[PIOS_USB_MAX_DEVS];
|
||||||
|
static uint8_t pios_usb_num_devs;
|
||||||
|
static struct pios_usb_dev * PIOS_USB_alloc(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_dev * usb_dev;
|
||||||
|
|
||||||
|
if (pios_usb_num_devs >= PIOS_USB_MAX_DEVS) {
|
||||||
|
return (NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
usb_dev = &pios_usb_devs[pios_usb_num_devs++];
|
||||||
|
usb_dev->magic = PIOS_USB_DEV_MAGIC;
|
||||||
|
|
||||||
|
return (usb_dev);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Bind configuration to USB BSP layer
|
||||||
|
* \return < 0 if initialisation failed
|
||||||
|
*/
|
||||||
|
static uint32_t pios_usb_id;
|
||||||
|
int32_t PIOS_USB_Init(uint32_t * usb_id, const struct pios_usb_cfg * cfg)
|
||||||
|
{
|
||||||
|
PIOS_Assert(usb_id);
|
||||||
|
PIOS_Assert(cfg);
|
||||||
|
|
||||||
|
struct pios_usb_dev * usb_dev;
|
||||||
|
|
||||||
|
usb_dev = (struct pios_usb_dev *) PIOS_USB_alloc();
|
||||||
|
if (!usb_dev) goto out_fail;
|
||||||
|
|
||||||
|
/* Bind the configuration to the device instance */
|
||||||
|
usb_dev->cfg = cfg;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This is a horrible hack to make this available to
|
||||||
|
* the interrupt callbacks. This should go away ASAP.
|
||||||
|
*/
|
||||||
|
pios_usb_id = (uint32_t) usb_dev;
|
||||||
|
|
||||||
|
*usb_id = (uint32_t) usb_dev;
|
||||||
|
|
||||||
|
return 0; /* No error */
|
||||||
|
|
||||||
|
out_fail:
|
||||||
|
return(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is called by the USB driver on cable connection/disconnection
|
||||||
|
* \param[in] connected connection status (1 if connected)
|
||||||
|
* \return < 0 on errors
|
||||||
|
* \note Applications shouldn't call this function directly, instead please use \ref PIOS_COM layer functions
|
||||||
|
*/
|
||||||
|
int32_t PIOS_USB_ChangeConnectionState(bool connected)
|
||||||
|
{
|
||||||
|
// In all cases: re-initialise USB HID driver
|
||||||
|
if (connected) {
|
||||||
|
transfer_possible = 1;
|
||||||
|
|
||||||
|
//TODO: Check SetEPRxValid(ENDP1);
|
||||||
|
|
||||||
|
#if defined(USB_LED_ON)
|
||||||
|
USB_LED_ON; // turn the USB led on
|
||||||
|
#endif
|
||||||
|
} else {
|
||||||
|
// Cable disconnected: disable transfers
|
||||||
|
transfer_possible = 0;
|
||||||
|
|
||||||
|
#if defined(USB_LED_OFF)
|
||||||
|
USB_LED_OFF; // turn the USB led off
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function returns the connection status of the USB interface
|
||||||
|
* \return 1: interface available
|
||||||
|
* \return 0: interface not available
|
||||||
|
*/
|
||||||
|
uint32_t usb_found;
|
||||||
|
bool PIOS_USB_CheckAvailable(uint8_t id)
|
||||||
|
{
|
||||||
|
struct pios_usb_dev * usb_dev = (struct pios_usb_dev *) pios_usb_id;
|
||||||
|
|
||||||
|
if(!PIOS_USB_validate(usb_dev))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
usb_found = (usb_dev->cfg->vsense.gpio->IDR & usb_dev->cfg->vsense.init.GPIO_Pin);
|
||||||
|
return usb_found;
|
||||||
|
return usb_found != 0 && transfer_possible ? 1 : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* Provide STM32 USB OTG BSP layer API
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "usb_bsp.h"
|
||||||
|
|
||||||
|
void USB_OTG_BSP_Init(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
struct pios_usb_dev * usb_dev = (struct pios_usb_dev *) pios_usb_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_validate(usb_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
#define FORCE_DISABLE_USB_IRQ 1
|
||||||
|
#if FORCE_DISABLE_USB_IRQ
|
||||||
|
/* Make sure we disable the USB interrupt since it may be left on by bootloader */
|
||||||
|
NVIC_InitTypeDef NVIC_InitStructure;
|
||||||
|
NVIC_InitStructure = usb_dev->cfg->irq.init;
|
||||||
|
NVIC_InitStructure.NVIC_IRQChannelCmd = DISABLE;
|
||||||
|
NVIC_Init(&NVIC_InitStructure);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Configure USB D-/D+ (DM/DP) pins */
|
||||||
|
GPIO_InitTypeDef GPIO_InitStructure;
|
||||||
|
|
||||||
|
#define FORCE_USB_DP_DM_LOW 1
|
||||||
|
#if FORCE_USB_DP_DM_LOW
|
||||||
|
/* Force D-/D+ low for 50ms to trigger a disconnect */
|
||||||
|
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11 | GPIO_Pin_12;
|
||||||
|
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
|
||||||
|
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
|
||||||
|
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
|
||||||
|
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
|
||||||
|
GPIO_Init(GPIOA, &GPIO_InitStructure);
|
||||||
|
|
||||||
|
GPIO_PinAFConfig(GPIOA, GPIO_PinSource11, 0);
|
||||||
|
GPIO_PinAFConfig(GPIOA, GPIO_PinSource12, 0);
|
||||||
|
|
||||||
|
GPIO_ResetBits(GPIOA, GPIO_Pin_12);
|
||||||
|
GPIO_ResetBits(GPIOA, GPIO_Pin_11);
|
||||||
|
|
||||||
|
PIOS_DELAY_WaitmS(50);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Set up D-/D+ as USB function again */
|
||||||
|
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11 | GPIO_Pin_12;
|
||||||
|
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
|
||||||
|
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
|
||||||
|
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
|
||||||
|
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
|
||||||
|
GPIO_Init(GPIOA, &GPIO_InitStructure);
|
||||||
|
|
||||||
|
GPIO_PinAFConfig(GPIOA, GPIO_PinSource11, GPIO_AF_OTG1_FS);
|
||||||
|
GPIO_PinAFConfig(GPIOA, GPIO_PinSource12, GPIO_AF_OTG1_FS);
|
||||||
|
|
||||||
|
/* Configure VBUS sense pin */
|
||||||
|
GPIO_Init(usb_dev->cfg->vsense.gpio, &usb_dev->cfg->vsense.init);
|
||||||
|
|
||||||
|
/* Enable USB OTG Clock */
|
||||||
|
RCC_AHB2PeriphClockCmd(RCC_AHB2Periph_OTG_FS, ENABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
void USB_OTG_BSP_EnableInterrupt(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
struct pios_usb_dev * usb_dev = (struct pios_usb_dev *) pios_usb_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_validate(usb_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
|
||||||
|
|
||||||
|
NVIC_Init(&usb_dev->cfg->irq.init);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef USE_HOST_MODE
|
||||||
|
void USB_OTG_BSP_DriveVBUS(USB_OTG_CORE_HANDLE *pdev, uint8_t state)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void USB_OTG_BSP_ConfigVBUS(USB_OTG_CORE_HANDLE *pdev)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
#endif /* USE_HOST_MODE */
|
||||||
|
|
||||||
|
void USB_OTG_BSP_TimeInit ( void )
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void USB_OTG_BSP_uDelay (const uint32_t usec)
|
||||||
|
{
|
||||||
|
uint32_t count = 0;
|
||||||
|
const uint32_t utime = (120 * usec / 7);
|
||||||
|
do {
|
||||||
|
if (++count > utime) {
|
||||||
|
return ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void USB_OTG_BSP_mDelay (const uint32_t msec)
|
||||||
|
{
|
||||||
|
USB_OTG_BSP_uDelay(msec * 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
void USB_OTG_BSP_TimerIRQ (void)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* PIOS_INCLUDE_USB */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @}
|
||||||
|
* @}
|
||||||
|
*/
|
400
flight/PiOS/STM32F4xx/pios_usb_cdc.c
Normal file
400
flight/PiOS/STM32F4xx/pios_usb_cdc.c
Normal file
@ -0,0 +1,400 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @addtogroup PIOS PIOS Core hardware abstraction layer
|
||||||
|
* @{
|
||||||
|
* @addtogroup PIOS_USB_COM USB COM Functions
|
||||||
|
* @brief PIOS USB COM implementation for CDC interfaces
|
||||||
|
* @notes This implements a CDC Serial Port
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file pios_usb_com_cdc.c
|
||||||
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||||
|
* @brief USB COM functions (STM32 dependent code)
|
||||||
|
* @see The GNU Public License (GPL) Version 3
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
/*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Project Includes */
|
||||||
|
#include "pios.h"
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
||||||
|
|
||||||
|
#include "pios_usb.h"
|
||||||
|
#include "pios_usb_cdc_priv.h"
|
||||||
|
#include "pios_usb_board_data.h" /* PIOS_BOARD_*_DATA_LENGTH */
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_RegisterTxCallback(uint32_t usbcdc_id, pios_com_callback tx_out_cb, uint32_t context);
|
||||||
|
static void PIOS_USB_CDC_RegisterRxCallback(uint32_t usbcdc_id, pios_com_callback rx_in_cb, uint32_t context);
|
||||||
|
static void PIOS_USB_CDC_TxStart(uint32_t usbcdc_id, uint16_t tx_bytes_avail);
|
||||||
|
static void PIOS_USB_CDC_RxStart(uint32_t usbcdc_id, uint16_t rx_bytes_avail);
|
||||||
|
|
||||||
|
const struct pios_com_driver pios_usb_cdc_com_driver = {
|
||||||
|
.tx_start = PIOS_USB_CDC_TxStart,
|
||||||
|
.rx_start = PIOS_USB_CDC_RxStart,
|
||||||
|
.bind_tx_cb = PIOS_USB_CDC_RegisterTxCallback,
|
||||||
|
.bind_rx_cb = PIOS_USB_CDC_RegisterRxCallback,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum pios_usb_cdc_dev_magic {
|
||||||
|
PIOS_USB_CDC_DEV_MAGIC = 0xAABBCCDD,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct pios_usb_cdc_dev {
|
||||||
|
enum pios_usb_cdc_dev_magic magic;
|
||||||
|
const struct pios_usb_cdc_cfg * cfg;
|
||||||
|
|
||||||
|
uint32_t lower_id;
|
||||||
|
|
||||||
|
pios_com_callback rx_in_cb;
|
||||||
|
uint32_t rx_in_context;
|
||||||
|
pios_com_callback tx_out_cb;
|
||||||
|
uint32_t tx_out_context;
|
||||||
|
|
||||||
|
uint8_t rx_packet_buffer[PIOS_USB_BOARD_CDC_DATA_LENGTH];
|
||||||
|
uint8_t tx_packet_buffer[PIOS_USB_BOARD_CDC_DATA_LENGTH];
|
||||||
|
|
||||||
|
uint32_t rx_dropped;
|
||||||
|
uint32_t rx_oversize;
|
||||||
|
};
|
||||||
|
|
||||||
|
static bool PIOS_USB_CDC_validate(struct pios_usb_cdc_dev * usb_cdc_dev)
|
||||||
|
{
|
||||||
|
return (usb_cdc_dev && (usb_cdc_dev->magic == PIOS_USB_CDC_DEV_MAGIC));
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_FREERTOS)
|
||||||
|
static struct pios_usb_cdc_dev * PIOS_USB_CDC_alloc(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev;
|
||||||
|
|
||||||
|
usb_cdc_dev = (struct pios_usb_cdc_dev *)pvPortMalloc(sizeof(*usb_cdc_dev));
|
||||||
|
if (!usb_cdc_dev) return(NULL);
|
||||||
|
|
||||||
|
usb_cdc_dev->magic = PIOS_USB_CDC_DEV_MAGIC;
|
||||||
|
return(usb_cdc_dev);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static struct pios_usb_cdc_dev pios_usb_cdc_devs[PIOS_USB_CDC_MAX_DEVS];
|
||||||
|
static uint8_t pios_usb_cdc_num_devs;
|
||||||
|
static struct pios_usb_cdc_dev * PIOS_USB_CDC_alloc(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev;
|
||||||
|
|
||||||
|
if (pios_usb_cdc_num_devs >= PIOS_USB_CDC_MAX_DEVS) {
|
||||||
|
return (NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
usb_cdc_dev = &pios_usb_cdc_devs[pios_usb_cdc_num_devs++];
|
||||||
|
usb_cdc_dev->magic = PIOS_USB_CDC_DEV_MAGIC;
|
||||||
|
|
||||||
|
return (usb_cdc_dev);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_DATA_EP_IN_Callback(void);
|
||||||
|
static void PIOS_USB_CDC_DATA_EP_OUT_Callback(void);
|
||||||
|
static void PIOS_USB_CDC_CTRL_EP_IN_Callback(void);
|
||||||
|
|
||||||
|
static uint32_t pios_usb_cdc_id;
|
||||||
|
|
||||||
|
/* Need a better way to pull these in */
|
||||||
|
extern void (*pEpInt_IN[7])(void);
|
||||||
|
extern void (*pEpInt_OUT[7])(void);
|
||||||
|
|
||||||
|
int32_t PIOS_USB_CDC_Init(uint32_t * usbcdc_id, const struct pios_usb_cdc_cfg * cfg, uint32_t lower_id)
|
||||||
|
{
|
||||||
|
PIOS_Assert(usbcdc_id);
|
||||||
|
PIOS_Assert(cfg);
|
||||||
|
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev;
|
||||||
|
|
||||||
|
usb_cdc_dev = (struct pios_usb_cdc_dev *) PIOS_USB_CDC_alloc();
|
||||||
|
if (!usb_cdc_dev) goto out_fail;
|
||||||
|
|
||||||
|
/* Bind the configuration to the device instance */
|
||||||
|
usb_cdc_dev->cfg = cfg;
|
||||||
|
usb_cdc_dev->lower_id = lower_id;
|
||||||
|
|
||||||
|
pios_usb_cdc_id = (uint32_t) usb_cdc_dev;
|
||||||
|
|
||||||
|
/* Bind lower level callbacks into the USB infrastructure */
|
||||||
|
pEpInt_OUT[cfg->ctrl_tx_ep - 1] = PIOS_USB_CDC_CTRL_EP_IN_Callback;
|
||||||
|
pEpInt_IN[cfg->data_tx_ep - 1] = PIOS_USB_CDC_DATA_EP_IN_Callback;
|
||||||
|
pEpInt_OUT[cfg->data_rx_ep - 1] = PIOS_USB_CDC_DATA_EP_OUT_Callback;
|
||||||
|
|
||||||
|
*usbcdc_id = (uint32_t) usb_cdc_dev;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
out_fail:
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_RegisterRxCallback(uint32_t usbcdc_id, pios_com_callback rx_in_cb, uint32_t context)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)usbcdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Order is important in these assignments since ISR uses _cb
|
||||||
|
* field to determine if it's ok to dereference _cb and _context
|
||||||
|
*/
|
||||||
|
usb_cdc_dev->rx_in_context = context;
|
||||||
|
usb_cdc_dev->rx_in_cb = rx_in_cb;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_RegisterTxCallback(uint32_t usbcdc_id, pios_com_callback tx_out_cb, uint32_t context)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)usbcdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Order is important in these assignments since ISR uses _cb
|
||||||
|
* field to determine if it's ok to dereference _cb and _context
|
||||||
|
*/
|
||||||
|
usb_cdc_dev->tx_out_context = context;
|
||||||
|
usb_cdc_dev->tx_out_cb = tx_out_cb;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_RxStart(uint32_t usbcdc_id, uint16_t rx_bytes_avail) {
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)usbcdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
if (!PIOS_USB_CheckAvailable(usb_cdc_dev->lower_id)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If endpoint was stalled and there is now space make it valid
|
||||||
|
PIOS_IRQ_Disable();
|
||||||
|
if ((GetEPRxStatus(usb_cdc_dev->cfg->data_rx_ep) != EP_RX_VALID) &&
|
||||||
|
(rx_bytes_avail >= sizeof(usb_cdc_dev->rx_packet_buffer))) {
|
||||||
|
SetEPRxStatus(usb_cdc_dev->cfg->data_rx_ep, EP_RX_VALID);
|
||||||
|
}
|
||||||
|
PIOS_IRQ_Enable();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_SendData(struct pios_usb_cdc_dev * usb_cdc_dev)
|
||||||
|
{
|
||||||
|
uint16_t bytes_to_tx;
|
||||||
|
|
||||||
|
if (!usb_cdc_dev->tx_out_cb) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool need_yield = false;
|
||||||
|
bytes_to_tx = (usb_cdc_dev->tx_out_cb)(usb_cdc_dev->tx_out_context,
|
||||||
|
usb_cdc_dev->tx_packet_buffer,
|
||||||
|
sizeof(usb_cdc_dev->tx_packet_buffer),
|
||||||
|
NULL,
|
||||||
|
&need_yield);
|
||||||
|
if (bytes_to_tx == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
UserToPMABufferCopy(usb_cdc_dev->tx_packet_buffer,
|
||||||
|
GetEPTxAddr(usb_cdc_dev->cfg->data_tx_ep),
|
||||||
|
bytes_to_tx);
|
||||||
|
SetEPTxCount(usb_cdc_dev->cfg->data_tx_ep, bytes_to_tx);
|
||||||
|
SetEPTxValid(usb_cdc_dev->cfg->data_tx_ep);
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_FREERTOS)
|
||||||
|
if (need_yield) {
|
||||||
|
vPortYieldFromISR();
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_FREERTOS */
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_TxStart(uint32_t usbcdc_id, uint16_t tx_bytes_avail)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)usbcdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
if (!PIOS_USB_CheckAvailable(usb_cdc_dev->lower_id)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (GetEPTxStatus(usb_cdc_dev->cfg->data_tx_ep) == EP_TX_VALID) {
|
||||||
|
/* Endpoint is already transmitting */
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
PIOS_USB_CDC_SendData(usb_cdc_dev);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_DATA_EP_IN_Callback(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)pios_usb_cdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
PIOS_USB_CDC_SendData(usb_cdc_dev);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_DATA_EP_OUT_Callback(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)pios_usb_cdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
uint32_t DataLength;
|
||||||
|
|
||||||
|
/* Get the number of received data on the selected Endpoint */
|
||||||
|
DataLength = GetEPRxCount(usb_cdc_dev->cfg->data_rx_ep);
|
||||||
|
if (DataLength > sizeof(usb_cdc_dev->rx_packet_buffer)) {
|
||||||
|
usb_cdc_dev->rx_oversize++;
|
||||||
|
DataLength = sizeof(usb_cdc_dev->rx_packet_buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Use the memory interface function to read from the selected endpoint */
|
||||||
|
PMAToUserBufferCopy((uint8_t *) usb_cdc_dev->rx_packet_buffer,
|
||||||
|
GetEPRxAddr(usb_cdc_dev->cfg->data_rx_ep),
|
||||||
|
DataLength);
|
||||||
|
|
||||||
|
if (!usb_cdc_dev->rx_in_cb) {
|
||||||
|
/* No Rx call back registered, disable the receiver */
|
||||||
|
SetEPRxStatus(usb_cdc_dev->cfg->data_rx_ep, EP_RX_NAK);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16_t headroom;
|
||||||
|
bool need_yield = false;
|
||||||
|
uint16_t rc;
|
||||||
|
rc = (usb_cdc_dev->rx_in_cb)(usb_cdc_dev->rx_in_context,
|
||||||
|
usb_cdc_dev->rx_packet_buffer,
|
||||||
|
DataLength,
|
||||||
|
&headroom,
|
||||||
|
&need_yield);
|
||||||
|
|
||||||
|
if (rc < DataLength) {
|
||||||
|
/* Lost bytes on rx */
|
||||||
|
usb_cdc_dev->rx_dropped += (DataLength - rc);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (headroom >= sizeof(usb_cdc_dev->rx_packet_buffer)) {
|
||||||
|
/* We have room for a maximum length message */
|
||||||
|
SetEPRxStatus(usb_cdc_dev->cfg->data_rx_ep, EP_RX_VALID);
|
||||||
|
} else {
|
||||||
|
/* Not enough room left for a message, apply backpressure */
|
||||||
|
SetEPRxStatus(usb_cdc_dev->cfg->data_rx_ep, EP_RX_NAK);
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_FREERTOS)
|
||||||
|
if (need_yield) {
|
||||||
|
vPortYieldFromISR();
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_FREERTOS */
|
||||||
|
}
|
||||||
|
|
||||||
|
RESULT PIOS_USB_CDC_SetControlLineState(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)pios_usb_cdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
static uint16_t control_line_state;
|
||||||
|
|
||||||
|
uint8_t wValue0 = pInformation->USBwValue0;
|
||||||
|
uint8_t wValue1 = pInformation->USBwValue1;
|
||||||
|
|
||||||
|
control_line_state = wValue1 << 8 | wValue0;
|
||||||
|
|
||||||
|
return USB_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct usb_cdc_line_coding line_coding = {
|
||||||
|
.dwDTERate = htousbl(57600),
|
||||||
|
.bCharFormat = USB_CDC_LINE_CODING_STOP_1,
|
||||||
|
.bParityType = USB_CDC_LINE_CODING_PARITY_NONE,
|
||||||
|
.bDataBits = 8,
|
||||||
|
};
|
||||||
|
|
||||||
|
RESULT PIOS_USB_CDC_SetLineCoding(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)pios_usb_cdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
return USB_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
const uint8_t *PIOS_USB_CDC_GetLineCoding(uint16_t Length)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)pios_usb_cdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
if (Length == 0) {
|
||||||
|
pInformation->Ctrl_Info.Usb_wLength = sizeof(line_coding);
|
||||||
|
return NULL;
|
||||||
|
} else {
|
||||||
|
return ((uint8_t *) &line_coding);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct usb_cdc_serial_state_report uart_state = {
|
||||||
|
.bmRequestType = 0xA1,
|
||||||
|
.bNotification = USB_CDC_NOTIFICATION_SERIAL_STATE,
|
||||||
|
.wValue = 0,
|
||||||
|
.wIndex = htousbs(1),
|
||||||
|
.wLength = htousbs(2),
|
||||||
|
.bmUartState = htousbs(0),
|
||||||
|
};
|
||||||
|
|
||||||
|
static void PIOS_USB_CDC_CTRL_EP_IN_Callback(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_cdc_dev * usb_cdc_dev = (struct pios_usb_cdc_dev *)pios_usb_cdc_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_CDC_validate(usb_cdc_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
/* Give back UART State Bitmap */
|
||||||
|
/* UART State Bitmap
|
||||||
|
* 15-7: reserved
|
||||||
|
* 6: bOverRun overrun error
|
||||||
|
* 5: bParity parity error
|
||||||
|
* 4: bFraming framing error
|
||||||
|
* 3: bRingSignal RI
|
||||||
|
* 2: bBreak break reception
|
||||||
|
* 1: bTxCarrier DSR
|
||||||
|
* 0: bRxCarrier DCD
|
||||||
|
*/
|
||||||
|
uart_state.bmUartState = htousbs(0x0003);
|
||||||
|
|
||||||
|
UserToPMABufferCopy((uint8_t *) &uart_state,
|
||||||
|
GetEPTxAddr(usb_cdc_dev->cfg->data_tx_ep),
|
||||||
|
sizeof(uart_state));
|
||||||
|
SetEPTxCount(usb_cdc_dev->cfg->data_tx_ep, PIOS_USB_BOARD_CDC_MGMT_LENGTH);
|
||||||
|
SetEPTxValid(usb_cdc_dev->cfg->data_tx_ep);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* PIOS_INCLUDE_USB_CDC */
|
497
flight/PiOS/STM32F4xx/pios_usb_hid.c
Normal file
497
flight/PiOS/STM32F4xx/pios_usb_hid.c
Normal file
@ -0,0 +1,497 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @addtogroup PIOS PIOS Core hardware abstraction layer
|
||||||
|
* @{
|
||||||
|
* @addtogroup PIOS_USB_HID USB COM Functions
|
||||||
|
* @brief PIOS USB COM implementation for HID interfaces
|
||||||
|
* @notes This implements serial emulation over HID reports
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file pios_usb_hid.c
|
||||||
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||||
|
* @brief USB COM functions (STM32 dependent code)
|
||||||
|
* @see The GNU Public License (GPL) Version 3
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
/*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Project Includes */
|
||||||
|
#include "pios.h"
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_HID)
|
||||||
|
|
||||||
|
#include "pios_usb.h"
|
||||||
|
#include "pios_usb_hid_priv.h"
|
||||||
|
#include "pios_usb_board_data.h" /* PIOS_BOARD_*_DATA_LENGTH */
|
||||||
|
#include "pios_usbhook.h" /* PIOS_USBHOOK_* */
|
||||||
|
|
||||||
|
#define MIN(x,y) (((x) < (y)) ? (x) : (y))
|
||||||
|
|
||||||
|
static void PIOS_USB_HID_RegisterTxCallback(uint32_t usbhid_id, pios_com_callback tx_out_cb, uint32_t context);
|
||||||
|
static void PIOS_USB_HID_RegisterRxCallback(uint32_t usbhid_id, pios_com_callback rx_in_cb, uint32_t context);
|
||||||
|
static void PIOS_USB_HID_TxStart(uint32_t usbhid_id, uint16_t tx_bytes_avail);
|
||||||
|
static void PIOS_USB_HID_RxStart(uint32_t usbhid_id, uint16_t rx_bytes_avail);
|
||||||
|
|
||||||
|
const struct pios_com_driver pios_usb_hid_com_driver = {
|
||||||
|
.tx_start = PIOS_USB_HID_TxStart,
|
||||||
|
.rx_start = PIOS_USB_HID_RxStart,
|
||||||
|
.bind_tx_cb = PIOS_USB_HID_RegisterTxCallback,
|
||||||
|
.bind_rx_cb = PIOS_USB_HID_RegisterRxCallback,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum pios_usb_hid_dev_magic {
|
||||||
|
PIOS_USB_HID_DEV_MAGIC = 0xAA00BB00,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct pios_usb_hid_dev {
|
||||||
|
enum pios_usb_hid_dev_magic magic;
|
||||||
|
const struct pios_usb_hid_cfg * cfg;
|
||||||
|
|
||||||
|
uint32_t lower_id;
|
||||||
|
|
||||||
|
pios_com_callback rx_in_cb;
|
||||||
|
uint32_t rx_in_context;
|
||||||
|
pios_com_callback tx_out_cb;
|
||||||
|
uint32_t tx_out_context;
|
||||||
|
|
||||||
|
uint8_t rx_packet_buffer[PIOS_USB_BOARD_HID_DATA_LENGTH];
|
||||||
|
uint8_t tx_packet_buffer[PIOS_USB_BOARD_HID_DATA_LENGTH];
|
||||||
|
|
||||||
|
uint32_t rx_dropped;
|
||||||
|
uint32_t rx_oversize;
|
||||||
|
};
|
||||||
|
|
||||||
|
static bool PIOS_USB_HID_validate(struct pios_usb_hid_dev * usb_hid_dev)
|
||||||
|
{
|
||||||
|
return (usb_hid_dev && (usb_hid_dev->magic == PIOS_USB_HID_DEV_MAGIC));
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_FREERTOS)
|
||||||
|
static struct pios_usb_hid_dev * PIOS_USB_HID_alloc(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev;
|
||||||
|
|
||||||
|
usb_hid_dev = (struct pios_usb_hid_dev *)pvPortMalloc(sizeof(*usb_hid_dev));
|
||||||
|
if (!usb_hid_dev) return(NULL);
|
||||||
|
|
||||||
|
usb_hid_dev->magic = PIOS_USB_HID_DEV_MAGIC;
|
||||||
|
return(usb_hid_dev);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static struct pios_usb_hid_dev pios_usb_hid_devs[PIOS_USB_HID_MAX_DEVS];
|
||||||
|
static uint8_t pios_usb_hid_num_devs;
|
||||||
|
static struct pios_usb_hid_dev * PIOS_USB_HID_alloc(void)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev;
|
||||||
|
|
||||||
|
if (pios_usb_hid_num_devs >= PIOS_USB_HID_MAX_DEVS) {
|
||||||
|
return (NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
usb_hid_dev = &pios_usb_hid_devs[pios_usb_hid_num_devs++];
|
||||||
|
usb_hid_dev->magic = PIOS_USB_HID_DEV_MAGIC;
|
||||||
|
|
||||||
|
return (usb_hid_dev);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static void PIOS_USB_HID_IF_Init(uint32_t usb_hid_id);
|
||||||
|
static void PIOS_USB_HID_IF_DeInit(uint32_t usb_hid_id);
|
||||||
|
static bool PIOS_USB_HID_IF_Setup(uint32_t usb_hid_id, struct usb_setup_request *req);
|
||||||
|
static void PIOS_USB_HID_IF_CtrlDataOut(uint32_t usb_hid_id, struct usb_setup_request *req);
|
||||||
|
|
||||||
|
static struct pios_usb_ifops usb_hid_ifops = {
|
||||||
|
.init = PIOS_USB_HID_IF_Init,
|
||||||
|
.deinit = PIOS_USB_HID_IF_DeInit,
|
||||||
|
.setup = PIOS_USB_HID_IF_Setup,
|
||||||
|
.ctrl_data_out = PIOS_USB_HID_IF_CtrlDataOut,
|
||||||
|
};
|
||||||
|
|
||||||
|
static bool PIOS_USB_HID_EP_IN_Callback(uint32_t usb_hid_id, uint8_t epnum, uint16_t len);
|
||||||
|
static bool PIOS_USB_HID_EP_OUT_Callback(uint32_t usb_hid_id, uint8_t epnum, uint16_t len);
|
||||||
|
|
||||||
|
int32_t PIOS_USB_HID_Init(uint32_t * usbhid_id, const struct pios_usb_hid_cfg * cfg, uint32_t lower_id)
|
||||||
|
{
|
||||||
|
PIOS_Assert(usbhid_id);
|
||||||
|
PIOS_Assert(cfg);
|
||||||
|
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev;
|
||||||
|
|
||||||
|
usb_hid_dev = (struct pios_usb_hid_dev *) PIOS_USB_HID_alloc();
|
||||||
|
if (!usb_hid_dev) goto out_fail;
|
||||||
|
|
||||||
|
/* Bind the configuration to the device instance */
|
||||||
|
usb_hid_dev->cfg = cfg;
|
||||||
|
usb_hid_dev->lower_id = lower_id;
|
||||||
|
|
||||||
|
/* Register class specific interface callbacks with the USBHOOK layer */
|
||||||
|
PIOS_USBHOOK_RegisterIfOps(cfg->data_if, &usb_hid_ifops, (uint32_t) usb_hid_dev);
|
||||||
|
|
||||||
|
*usbhid_id = (uint32_t) usb_hid_dev;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
out_fail:
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static struct pios_usbhook_descriptor hid_if_desc;
|
||||||
|
|
||||||
|
void PIOS_USB_HID_RegisterHidInterface(const uint8_t * desc, uint16_t length)
|
||||||
|
{
|
||||||
|
hid_if_desc.descriptor = desc;
|
||||||
|
hid_if_desc.length = length;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct pios_usbhook_descriptor hid_report_desc;
|
||||||
|
|
||||||
|
void PIOS_USB_HID_RegisterHidReport(const uint8_t * desc, uint16_t length)
|
||||||
|
{
|
||||||
|
hid_report_desc.descriptor = desc;
|
||||||
|
hid_report_desc.length = length;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool PIOS_USB_HID_SendReport(struct pios_usb_hid_dev * usb_hid_dev)
|
||||||
|
{
|
||||||
|
uint16_t bytes_to_tx;
|
||||||
|
|
||||||
|
if (!usb_hid_dev->tx_out_cb) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool need_yield = false;
|
||||||
|
#ifdef PIOS_USB_BOARD_BL_HID_HAS_NO_LENGTH_BYTE
|
||||||
|
bytes_to_tx = (usb_hid_dev->tx_out_cb)(usb_hid_dev->tx_out_context,
|
||||||
|
&usb_hid_dev->tx_packet_buffer[1],
|
||||||
|
sizeof(usb_hid_dev->tx_packet_buffer)-1,
|
||||||
|
NULL,
|
||||||
|
&need_yield);
|
||||||
|
#else
|
||||||
|
bytes_to_tx = (usb_hid_dev->tx_out_cb)(usb_hid_dev->tx_out_context,
|
||||||
|
&usb_hid_dev->tx_packet_buffer[2],
|
||||||
|
sizeof(usb_hid_dev->tx_packet_buffer)-2,
|
||||||
|
NULL,
|
||||||
|
&need_yield);
|
||||||
|
#endif
|
||||||
|
if (bytes_to_tx == 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Always set type as report ID */
|
||||||
|
usb_hid_dev->tx_packet_buffer[0] = 1;
|
||||||
|
|
||||||
|
#ifdef PIOS_USB_BOARD_BL_HID_HAS_NO_LENGTH_BYTE
|
||||||
|
PIOS_USBHOOK_EndpointTx(usb_hid_dev->cfg->data_tx_ep,
|
||||||
|
usb_hid_dev->tx_packet_buffer,
|
||||||
|
sizeof(usb_hid_dev->tx_packet_buffer));
|
||||||
|
#else
|
||||||
|
usb_hid_dev->tx_packet_buffer[1] = bytes_to_tx;
|
||||||
|
PIOS_USBHOOK_EndpointTx(usb_hid_dev->cfg->data_tx_ep,
|
||||||
|
usb_hid_dev->tx_packet_buffer,
|
||||||
|
sizeof(usb_hid_dev->tx_packet_buffer));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_FREERTOS)
|
||||||
|
if (need_yield) {
|
||||||
|
vPortYieldFromISR();
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_FREERTOS */
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_HID_RxStart(uint32_t usbhid_id, uint16_t rx_bytes_avail) {
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev = (struct pios_usb_hid_dev *)usbhid_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_HID_validate(usb_hid_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
if (!PIOS_USB_CheckAvailable(usb_hid_dev->lower_id)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If endpoint was stalled and there is now space make it valid
|
||||||
|
#ifdef PIOS_USB_BOARD_BL_HID_HAS_NO_LENGTH_BYTE
|
||||||
|
uint16_t max_payload_length = PIOS_USB_BOARD_HID_DATA_LENGTH - 1;
|
||||||
|
#else
|
||||||
|
uint16_t max_payload_length = PIOS_USB_BOARD_HID_DATA_LENGTH - 2;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
PIOS_IRQ_Disable();
|
||||||
|
if (rx_bytes_avail >= max_payload_length) {
|
||||||
|
/*
|
||||||
|
* FIXME should make sure we do not already have a buffer queued
|
||||||
|
*/
|
||||||
|
PIOS_USBHOOK_EndpointRx(usb_hid_dev->cfg->data_rx_ep,
|
||||||
|
usb_hid_dev->rx_packet_buffer,
|
||||||
|
sizeof(usb_hid_dev->rx_packet_buffer));
|
||||||
|
}
|
||||||
|
PIOS_IRQ_Enable();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_HID_TxStart(uint32_t usbhid_id, uint16_t tx_bytes_avail)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev = (struct pios_usb_hid_dev *)usbhid_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_HID_validate(usb_hid_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
if (!PIOS_USB_CheckAvailable(usb_hid_dev->lower_id)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
if (GetEPTxStatus(usb_hid_dev->cfg->data_tx_ep) == EP_TX_VALID) {
|
||||||
|
/* Endpoint is already transmitting */
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
/*
|
||||||
|
* FIXME start transmitter
|
||||||
|
*/
|
||||||
|
#endif
|
||||||
|
|
||||||
|
PIOS_USB_HID_SendReport(usb_hid_dev);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_HID_RegisterRxCallback(uint32_t usbhid_id, pios_com_callback rx_in_cb, uint32_t context)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev = (struct pios_usb_hid_dev *)usbhid_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_HID_validate(usb_hid_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Order is important in these assignments since ISR uses _cb
|
||||||
|
* field to determine if it's ok to dereference _cb and _context
|
||||||
|
*/
|
||||||
|
usb_hid_dev->rx_in_context = context;
|
||||||
|
usb_hid_dev->rx_in_cb = rx_in_cb;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_HID_RegisterTxCallback(uint32_t usbhid_id, pios_com_callback tx_out_cb, uint32_t context)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev = (struct pios_usb_hid_dev *)usbhid_id;
|
||||||
|
|
||||||
|
bool valid = PIOS_USB_HID_validate(usb_hid_dev);
|
||||||
|
PIOS_Assert(valid);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Order is important in these assignments since ISR uses _cb
|
||||||
|
* field to determine if it's ok to dereference _cb and _context
|
||||||
|
*/
|
||||||
|
usb_hid_dev->tx_out_context = context;
|
||||||
|
usb_hid_dev->tx_out_cb = tx_out_cb;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_HID_IF_Init(uint32_t usb_hid_id)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev = (struct pios_usb_hid_dev *)usb_hid_id;
|
||||||
|
|
||||||
|
if (!PIOS_USB_HID_validate(usb_hid_dev)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Register endpoint specific callbacks with the USBHOOK layer */
|
||||||
|
PIOS_USBHOOK_RegisterEpInCallback(usb_hid_dev->cfg->data_tx_ep,
|
||||||
|
sizeof(usb_hid_dev->rx_packet_buffer),
|
||||||
|
PIOS_USB_HID_EP_IN_Callback,
|
||||||
|
(uint32_t) usb_hid_dev);
|
||||||
|
PIOS_USBHOOK_RegisterEpOutCallback(usb_hid_dev->cfg->data_rx_ep,
|
||||||
|
sizeof(usb_hid_dev->rx_packet_buffer),
|
||||||
|
PIOS_USB_HID_EP_OUT_Callback,
|
||||||
|
(uint32_t) usb_hid_dev);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_HID_IF_DeInit(uint32_t usb_hid_id)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev = (struct pios_usb_hid_dev *)usb_hid_id;
|
||||||
|
|
||||||
|
if (!PIOS_USB_HID_validate(usb_hid_dev)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* DeRegister endpoint specific callbacks with the USBHOOK layer */
|
||||||
|
PIOS_USBHOOK_DeRegisterEpInCallback(usb_hid_dev->cfg->data_tx_ep);
|
||||||
|
PIOS_USBHOOK_DeRegisterEpOutCallback(usb_hid_dev->cfg->data_rx_ep);
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t hid_protocol;
|
||||||
|
static uint8_t hid_altset;
|
||||||
|
|
||||||
|
static bool PIOS_USB_HID_IF_Setup(uint32_t usb_hid_id, struct usb_setup_request *req)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev = (struct pios_usb_hid_dev *)usb_hid_id;
|
||||||
|
|
||||||
|
if (!PIOS_USB_HID_validate(usb_hid_dev)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Make sure this is a request for an interface we know about */
|
||||||
|
uint8_t ifnum = req->wIndex & 0xFF;
|
||||||
|
if (ifnum != usb_hid_dev->cfg->data_if) {
|
||||||
|
return (false);
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (req->bmRequestType & (USB_REQ_TYPE_MASK | USB_REQ_RECIPIENT_MASK)) {
|
||||||
|
case (USB_REQ_TYPE_STANDARD | USB_REQ_RECIPIENT_INTERFACE):
|
||||||
|
switch (req->bRequest) {
|
||||||
|
case USB_REQ_GET_DESCRIPTOR:
|
||||||
|
switch (req->wValue >> 8) {
|
||||||
|
case USB_DESC_TYPE_REPORT:
|
||||||
|
PIOS_USBHOOK_CtrlTx(hid_report_desc.descriptor,
|
||||||
|
MIN(hid_report_desc.length, req->wLength));
|
||||||
|
break;
|
||||||
|
case USB_DESC_TYPE_HID:
|
||||||
|
PIOS_USBHOOK_CtrlTx(hid_if_desc.descriptor,
|
||||||
|
MIN(hid_if_desc.length, req->wLength));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/* Unhandled descriptor request */
|
||||||
|
return false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case USB_REQ_GET_INTERFACE:
|
||||||
|
PIOS_USBHOOK_CtrlTx(&hid_altset, 1);
|
||||||
|
break;
|
||||||
|
case USB_REQ_SET_INTERFACE:
|
||||||
|
hid_altset = (uint8_t)(req->wValue);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/* Unhandled standard request */
|
||||||
|
return false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case (USB_REQ_TYPE_CLASS | USB_REQ_RECIPIENT_INTERFACE):
|
||||||
|
switch (req->bRequest) {
|
||||||
|
case USB_HID_REQ_SET_PROTOCOL:
|
||||||
|
hid_protocol = (uint8_t)(req->wValue);
|
||||||
|
break;
|
||||||
|
case USB_HID_REQ_GET_PROTOCOL:
|
||||||
|
PIOS_USBHOOK_CtrlTx(&hid_protocol, 1);
|
||||||
|
break;
|
||||||
|
case USB_HID_REQ_GET_REPORT:
|
||||||
|
{
|
||||||
|
/* Give back a dummy input report */
|
||||||
|
uint8_t dummy_report[2] = {
|
||||||
|
[0] = req->wValue >> 8, /* Report ID */
|
||||||
|
[1] = 0x00,
|
||||||
|
};
|
||||||
|
PIOS_USBHOOK_CtrlTx(dummy_report, sizeof(dummy_report));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/* Unhandled class request */
|
||||||
|
return false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/* Unhandled request */
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USB_HID_IF_CtrlDataOut(uint32_t usb_hid_id, struct usb_setup_request *req)
|
||||||
|
{
|
||||||
|
/* HID devices don't have any OUT data stages on the control endpoint */
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Callback used to indicate a transmission from device INto host completed
|
||||||
|
* Checks if any data remains, pads it into HID packet and sends.
|
||||||
|
*/
|
||||||
|
static bool PIOS_USB_HID_EP_IN_Callback(uint32_t usb_hid_id, uint8_t epnum, uint16_t len)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev = (struct pios_usb_hid_dev *)usb_hid_id;
|
||||||
|
|
||||||
|
if (!PIOS_USB_HID_validate(usb_hid_dev)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!PIOS_USB_CheckAvailable(usb_hid_dev->lower_id)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (PIOS_USB_HID_SendReport(usb_hid_dev));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* EP1 OUT Callback Routine
|
||||||
|
*/
|
||||||
|
static bool PIOS_USB_HID_EP_OUT_Callback(uint32_t usb_hid_id, uint8_t epnum, uint16_t len)
|
||||||
|
{
|
||||||
|
struct pios_usb_hid_dev * usb_hid_dev = (struct pios_usb_hid_dev *)usb_hid_id;
|
||||||
|
|
||||||
|
if (!PIOS_USB_HID_validate(usb_hid_dev)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (len > sizeof(usb_hid_dev->rx_packet_buffer)) {
|
||||||
|
len = sizeof(usb_hid_dev->rx_packet_buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!usb_hid_dev->rx_in_cb) {
|
||||||
|
/* No Rx call back registered, disable the receiver */
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* The first byte is report ID (not checked), the second byte is the valid data length */
|
||||||
|
uint16_t headroom;
|
||||||
|
bool need_yield = false;
|
||||||
|
#ifdef PIOS_USB_BOARD_BL_HID_HAS_NO_LENGTH_BYTE
|
||||||
|
(usb_hid_dev->rx_in_cb)(usb_hid_dev->rx_in_context,
|
||||||
|
&usb_hid_dev->rx_packet_buffer[1],
|
||||||
|
len-1,
|
||||||
|
&headroom,
|
||||||
|
&need_yield);
|
||||||
|
#else
|
||||||
|
(usb_hid_dev->rx_in_cb)(usb_hid_dev->rx_in_context,
|
||||||
|
&usb_hid_dev->rx_packet_buffer[2],
|
||||||
|
usb_hid_dev->rx_packet_buffer[1],
|
||||||
|
&headroom,
|
||||||
|
&need_yield);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef PIOS_USB_BOARD_BL_HID_HAS_NO_LENGTH_BYTE
|
||||||
|
uint16_t max_payload_length = PIOS_USB_BOARD_HID_DATA_LENGTH - 1;
|
||||||
|
#else
|
||||||
|
uint16_t max_payload_length = PIOS_USB_BOARD_HID_DATA_LENGTH - 2;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (headroom >= max_payload_length) {
|
||||||
|
/* We have room for a maximum length message */
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
/* Not enough room left for a message, apply backpressure */
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_FREERTOS)
|
||||||
|
if (need_yield) {
|
||||||
|
vPortYieldFromISR();
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_FREERTOS */
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* PIOS_INCLUDE_USB_HID */
|
897
flight/PiOS/STM32F4xx/pios_usbhook.c
Normal file
897
flight/PiOS/STM32F4xx/pios_usbhook.c
Normal file
@ -0,0 +1,897 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @addtogroup PIOS PIOS Core hardware abstraction layer
|
||||||
|
* @{
|
||||||
|
* @addtogroup PIOS_USBHOOK USB glue code
|
||||||
|
* @brief Glue between PiOS and STM32 libs
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file pios_usbhook.c
|
||||||
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||||
|
* @brief Glue between PiOS and STM32 libs
|
||||||
|
* @see The GNU Public License (GPL) Version 3
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
/*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "pios.h"
|
||||||
|
#include "pios_usb.h" /* PIOS_USB_* */
|
||||||
|
#include "pios_usbhook.h"
|
||||||
|
#include "pios_usb_defs.h" /* struct usb_* */
|
||||||
|
#include "pios_usb_cdc_priv.h" /* PIOS_USB_CDC_* */
|
||||||
|
#include "pios_usb_board_data.h" /* PIOS_USB_BOARD_* */
|
||||||
|
|
||||||
|
|
||||||
|
/* STM32 USB Library Definitions */
|
||||||
|
#include "usb_core.h" /* USBD_Class_cb_TypeDef */
|
||||||
|
#include "usbd_core.h" /* USBD_Init USBD_OK*/
|
||||||
|
#include "usbd_ioreq.h" /* USBD_CtlPrepareRx, USBD_CtlSendData */
|
||||||
|
#include "usbd_req.h" /* USBD_CtlError */
|
||||||
|
#include "usb_dcd_int.h" /* USBD_OTG_ISR_Handler */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* External API
|
||||||
|
*/
|
||||||
|
static struct pios_usbhook_descriptor Device_Descriptor;
|
||||||
|
|
||||||
|
void PIOS_USBHOOK_RegisterDevice(const uint8_t * desc, uint16_t length)
|
||||||
|
{
|
||||||
|
Device_Descriptor.descriptor = desc;
|
||||||
|
Device_Descriptor.length = length;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct pios_usbhook_descriptor String_Descriptor[4];
|
||||||
|
|
||||||
|
void PIOS_USBHOOK_RegisterString(enum usb_string_desc string_id, const uint8_t * desc, uint16_t desc_size)
|
||||||
|
{
|
||||||
|
if (string_id < NELEMENTS(String_Descriptor)) {
|
||||||
|
String_Descriptor[string_id].descriptor = desc;
|
||||||
|
String_Descriptor[string_id].length = desc_size;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct pios_usbhook_descriptor Config_Descriptor;
|
||||||
|
|
||||||
|
void PIOS_USBHOOK_RegisterConfig(uint8_t config_id, const uint8_t * desc, uint16_t desc_size)
|
||||||
|
{
|
||||||
|
Config_Descriptor.descriptor = desc;
|
||||||
|
Config_Descriptor.length = desc_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
static USB_OTG_CORE_HANDLE pios_usb_otg_core_handle;
|
||||||
|
static USBD_Class_cb_TypeDef class_callbacks;
|
||||||
|
static USBD_DEVICE device_callbacks;
|
||||||
|
static USBD_Usr_cb_TypeDef user_callbacks;
|
||||||
|
|
||||||
|
void PIOS_USBHOOK_Activate(void)
|
||||||
|
{
|
||||||
|
USBD_Init(&pios_usb_otg_core_handle,
|
||||||
|
USB_OTG_FS_CORE_ID,
|
||||||
|
&device_callbacks,
|
||||||
|
&class_callbacks,
|
||||||
|
&user_callbacks);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OTG_FS_IRQHandler(void)
|
||||||
|
{
|
||||||
|
if(!USBD_OTG_ISR_Handler(&pios_usb_otg_core_handle)) {
|
||||||
|
/* spurious interrupt, disable IRQ */
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct usb_if_entry {
|
||||||
|
struct pios_usb_ifops *ifops;
|
||||||
|
uint32_t context;
|
||||||
|
};
|
||||||
|
static struct usb_if_entry usb_if_table[3];
|
||||||
|
void PIOS_USBHOOK_RegisterIfOps(uint8_t ifnum, struct pios_usb_ifops * ifops, uint32_t context)
|
||||||
|
{
|
||||||
|
PIOS_Assert(ifnum < NELEMENTS(usb_if_table));
|
||||||
|
PIOS_Assert(ifops);
|
||||||
|
|
||||||
|
usb_if_table[ifnum].ifops = ifops;
|
||||||
|
usb_if_table[ifnum].context = context;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct usb_ep_entry {
|
||||||
|
pios_usbhook_epcb cb;
|
||||||
|
uint32_t context;
|
||||||
|
uint16_t max_len;
|
||||||
|
};
|
||||||
|
static struct usb_ep_entry usb_epin_table[6];
|
||||||
|
void PIOS_USBHOOK_RegisterEpInCallback(uint8_t epnum, uint16_t max_len, pios_usbhook_epcb cb, uint32_t context)
|
||||||
|
{
|
||||||
|
PIOS_Assert(epnum < NELEMENTS(usb_epin_table));
|
||||||
|
PIOS_Assert(cb);
|
||||||
|
|
||||||
|
usb_epin_table[epnum].cb = cb;
|
||||||
|
usb_epin_table[epnum].context = context;
|
||||||
|
usb_epin_table[epnum].max_len = max_len;
|
||||||
|
|
||||||
|
DCD_EP_Open(&pios_usb_otg_core_handle,
|
||||||
|
epnum | 0x80,
|
||||||
|
max_len,
|
||||||
|
USB_OTG_EP_INT);
|
||||||
|
/*
|
||||||
|
* FIXME do not hardcode endpoint type
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
extern void PIOS_USBHOOK_DeRegisterEpInCallback(uint8_t epnum)
|
||||||
|
{
|
||||||
|
PIOS_Assert(epnum < NELEMENTS(usb_epin_table));
|
||||||
|
|
||||||
|
usb_epin_table[epnum].cb = NULL;
|
||||||
|
|
||||||
|
DCD_EP_Close(&pios_usb_otg_core_handle, epnum | 0x80);
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct usb_ep_entry usb_epout_table[6];
|
||||||
|
void PIOS_USBHOOK_RegisterEpOutCallback(uint8_t epnum, uint16_t max_len, pios_usbhook_epcb cb, uint32_t context)
|
||||||
|
{
|
||||||
|
PIOS_Assert(epnum < NELEMENTS(usb_epout_table));
|
||||||
|
PIOS_Assert(cb);
|
||||||
|
|
||||||
|
usb_epout_table[epnum].cb = cb;
|
||||||
|
usb_epout_table[epnum].context = context;
|
||||||
|
usb_epout_table[epnum].max_len = max_len;
|
||||||
|
|
||||||
|
DCD_EP_Open(&pios_usb_otg_core_handle,
|
||||||
|
epnum,
|
||||||
|
max_len,
|
||||||
|
USB_OTG_EP_INT);
|
||||||
|
/*
|
||||||
|
* FIXME do not hardcode endpoint type
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
extern void PIOS_USBHOOK_DeRegisterEpOutCallback(uint8_t epnum)
|
||||||
|
{
|
||||||
|
PIOS_Assert(epnum < NELEMENTS(usb_epout_table));
|
||||||
|
|
||||||
|
usb_epout_table[epnum].cb = NULL;
|
||||||
|
|
||||||
|
DCD_EP_Close(&pios_usb_otg_core_handle, epnum);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PIOS_USBHOOK_CtrlTx(const uint8_t *buf, uint16_t len)
|
||||||
|
{
|
||||||
|
USBD_CtlSendData(&pios_usb_otg_core_handle, buf, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PIOS_USBHOOK_CtrlRx(uint8_t *buf, uint16_t len)
|
||||||
|
{
|
||||||
|
USBD_CtlPrepareRx(&pios_usb_otg_core_handle, buf, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PIOS_USBHOOK_EndpointTx(uint8_t epnum, const uint8_t *buf, uint16_t len)
|
||||||
|
{
|
||||||
|
if (pios_usb_otg_core_handle.dev.device_status == USB_OTG_CONFIGURED) {
|
||||||
|
DCD_EP_Tx(&pios_usb_otg_core_handle, epnum, buf, len);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void PIOS_USBHOOK_EndpointRx(uint8_t epnum, uint8_t *buf, uint16_t len)
|
||||||
|
{
|
||||||
|
DCD_EP_PrepareRx(&pios_usb_otg_core_handle, epnum, buf, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Device level hooks into STM USB library
|
||||||
|
*/
|
||||||
|
|
||||||
|
static const uint8_t * PIOS_USBHOOK_DEV_GetDeviceDescriptor(uint8_t speed, uint16_t *length)
|
||||||
|
{
|
||||||
|
*length = Device_Descriptor.length;
|
||||||
|
return Device_Descriptor.descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const uint8_t * PIOS_USBHOOK_DEV_GetLangIDStrDescriptor(uint8_t speed, uint16_t *length)
|
||||||
|
{
|
||||||
|
*length = String_Descriptor[USB_STRING_DESC_LANG].length;
|
||||||
|
return String_Descriptor[USB_STRING_DESC_LANG].descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const uint8_t * PIOS_USBHOOK_DEV_GetManufacturerStrDescriptor(uint8_t speed, uint16_t *length)
|
||||||
|
{
|
||||||
|
*length = String_Descriptor[USB_STRING_DESC_VENDOR].length;
|
||||||
|
return String_Descriptor[USB_STRING_DESC_VENDOR].descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const uint8_t * PIOS_USBHOOK_DEV_GetProductStrDescriptor(uint8_t speed, uint16_t *length)
|
||||||
|
{
|
||||||
|
*length = String_Descriptor[USB_STRING_DESC_PRODUCT].length;
|
||||||
|
return String_Descriptor[USB_STRING_DESC_PRODUCT].descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const uint8_t * PIOS_USBHOOK_DEV_GetSerialStrDescriptor(uint8_t speed, uint16_t *length)
|
||||||
|
{
|
||||||
|
*length = String_Descriptor[USB_STRING_DESC_SERIAL].length;
|
||||||
|
return String_Descriptor[USB_STRING_DESC_SERIAL].descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const uint8_t * PIOS_USBHOOK_DEV_GetConfigurationStrDescriptor(uint8_t speed, uint16_t *length)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const uint8_t * PIOS_USBHOOK_DEV_GetInterfaceStrDescriptor(uint8_t speed, uint16_t *length)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static USBD_DEVICE device_callbacks = {
|
||||||
|
.GetDeviceDescriptor = PIOS_USBHOOK_DEV_GetDeviceDescriptor,
|
||||||
|
.GetLangIDStrDescriptor = PIOS_USBHOOK_DEV_GetLangIDStrDescriptor,
|
||||||
|
.GetManufacturerStrDescriptor = PIOS_USBHOOK_DEV_GetManufacturerStrDescriptor,
|
||||||
|
.GetProductStrDescriptor = PIOS_USBHOOK_DEV_GetProductStrDescriptor,
|
||||||
|
.GetSerialStrDescriptor = PIOS_USBHOOK_DEV_GetSerialStrDescriptor,
|
||||||
|
.GetConfigurationStrDescriptor = PIOS_USBHOOK_DEV_GetConfigurationStrDescriptor,
|
||||||
|
.GetInterfaceStrDescriptor = PIOS_USBHOOK_DEV_GetInterfaceStrDescriptor,
|
||||||
|
};
|
||||||
|
|
||||||
|
static void PIOS_USBHOOK_USR_Init(void)
|
||||||
|
{
|
||||||
|
PIOS_USB_ChangeConnectionState(false);
|
||||||
|
|
||||||
|
#if 1
|
||||||
|
/* Force a physical disconnect/reconnect */
|
||||||
|
DCD_DevDisconnect(&pios_usb_otg_core_handle);
|
||||||
|
DCD_DevConnect(&pios_usb_otg_core_handle);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USBHOOK_USR_DeviceReset(uint8_t speed)
|
||||||
|
{
|
||||||
|
PIOS_USB_ChangeConnectionState(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USBHOOK_USR_DeviceConfigured(void)
|
||||||
|
{
|
||||||
|
PIOS_USB_ChangeConnectionState(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USBHOOK_USR_DeviceSuspended(void)
|
||||||
|
{
|
||||||
|
/* Unhandled */
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USBHOOK_USR_DeviceResumed(void)
|
||||||
|
{
|
||||||
|
/* Unhandled */
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USBHOOK_USR_DeviceConnected(void)
|
||||||
|
{
|
||||||
|
/* NOP */
|
||||||
|
}
|
||||||
|
|
||||||
|
static void PIOS_USBHOOK_USR_DeviceDisconnected(void)
|
||||||
|
{
|
||||||
|
PIOS_USB_ChangeConnectionState(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
static USBD_Usr_cb_TypeDef user_callbacks = {
|
||||||
|
.Init = PIOS_USBHOOK_USR_Init,
|
||||||
|
.DeviceReset = PIOS_USBHOOK_USR_DeviceReset,
|
||||||
|
.DeviceConfigured = PIOS_USBHOOK_USR_DeviceConfigured,
|
||||||
|
.DeviceSuspended = PIOS_USBHOOK_USR_DeviceSuspended,
|
||||||
|
.DeviceResumed = PIOS_USBHOOK_USR_DeviceResumed,
|
||||||
|
.DeviceConnected = PIOS_USBHOOK_USR_DeviceConnected,
|
||||||
|
.DeviceDisconnected = PIOS_USBHOOK_USR_DeviceDisconnected,
|
||||||
|
};
|
||||||
|
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_Init(void *pdev, uint8_t cfgidx)
|
||||||
|
{
|
||||||
|
/* Call all of the registered init callbacks */
|
||||||
|
for (uint8_t i = 0; i < NELEMENTS(usb_if_table); i++) {
|
||||||
|
struct usb_if_entry * usb_if = &(usb_if_table[i]);
|
||||||
|
if (usb_if->ifops && usb_if->ifops->init) {
|
||||||
|
usb_if->ifops->init(usb_if->context);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_DeInit(void *pdev, uint8_t cfgidx)
|
||||||
|
{
|
||||||
|
/* Call all of the registered deinit callbacks */
|
||||||
|
for (uint8_t i = 0; i < NELEMENTS(usb_if_table); i++) {
|
||||||
|
struct usb_if_entry * usb_if = &(usb_if_table[i]);
|
||||||
|
if (usb_if->ifops && usb_if->ifops->deinit) {
|
||||||
|
usb_if->ifops->deinit(usb_if->context);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct usb_setup_request usb_ep0_active_req;
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_Setup(void *pdev, USB_SETUP_REQ *req)
|
||||||
|
{
|
||||||
|
switch (req->bmRequest & (USB_REQ_TYPE_MASK | USB_REQ_RECIPIENT_MASK)) {
|
||||||
|
case (USB_REQ_TYPE_STANDARD | USB_REQ_RECIPIENT_INTERFACE):
|
||||||
|
case (USB_REQ_TYPE_CLASS | USB_REQ_RECIPIENT_INTERFACE):
|
||||||
|
{
|
||||||
|
uint8_t ifnum = LOBYTE(req->wIndex);
|
||||||
|
if ((ifnum < NELEMENTS(usb_if_table)) &&
|
||||||
|
(usb_if_table[ifnum].ifops && usb_if_table[ifnum].ifops->setup)) {
|
||||||
|
usb_if_table[ifnum].ifops->setup(usb_if_table[ifnum].context,
|
||||||
|
(struct usb_setup_request *)req);
|
||||||
|
if (req->bmRequest & 0x80 && req->wLength > 0) {
|
||||||
|
/* Request is a host-to-device data setup packet, keep track of the request details for the EP0_RxRead call */
|
||||||
|
usb_ep0_active_req.bmRequestType = req->bmRequest;
|
||||||
|
usb_ep0_active_req.bRequest = req->bRequest;
|
||||||
|
usb_ep0_active_req.wValue = req->wValue;
|
||||||
|
usb_ep0_active_req.wIndex = req->wIndex;
|
||||||
|
usb_ep0_active_req.wLength = req->wLength;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* No Setup handler or Setup handler failed */
|
||||||
|
USBD_CtlError (&pios_usb_otg_core_handle, req);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
/* Unhandled Setup */
|
||||||
|
USBD_CtlError (&pios_usb_otg_core_handle, req);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_EP0_TxSent(void *pdev)
|
||||||
|
{
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_EP0_RxReady(void *pdev)
|
||||||
|
{
|
||||||
|
uint8_t ifnum = LOBYTE(usb_ep0_active_req.wIndex);
|
||||||
|
|
||||||
|
if ((ifnum < NELEMENTS(usb_if_table)) &&
|
||||||
|
(usb_if_table[ifnum].ifops && usb_if_table[ifnum].ifops->ctrl_data_out)) {
|
||||||
|
usb_if_table[ifnum].ifops->ctrl_data_out(usb_if_table[ifnum].context,
|
||||||
|
&usb_ep0_active_req);
|
||||||
|
}
|
||||||
|
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_DataIn(void *pdev, uint8_t epnum)
|
||||||
|
{
|
||||||
|
/* Make sure the previous transfer has completed before starting a new one */
|
||||||
|
DCD_EP_Flush(pdev, epnum); /* NOT SURE IF THIS IS REQUIRED */
|
||||||
|
|
||||||
|
/* Remove the direction bit so we can use this as an index */
|
||||||
|
epnum = epnum & 0xF;
|
||||||
|
|
||||||
|
if ((epnum < NELEMENTS(usb_epin_table)) && usb_epin_table[epnum].cb) {
|
||||||
|
struct usb_ep_entry *ep = &(usb_epin_table[epnum]);
|
||||||
|
ep->cb(ep->context, epnum, ep->max_len);
|
||||||
|
}
|
||||||
|
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_DataOut(void *pdev, uint8_t epnum)
|
||||||
|
{
|
||||||
|
/* Remove the direction bit so we can use this as an index */
|
||||||
|
epnum = epnum & 0xF;
|
||||||
|
|
||||||
|
if ((epnum < NELEMENTS(usb_epout_table)) && usb_epout_table[epnum].cb) {
|
||||||
|
struct usb_ep_entry *ep = &(usb_epout_table[epnum]);
|
||||||
|
ep->cb(ep->context, epnum, ep->max_len);
|
||||||
|
}
|
||||||
|
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_SOF(void *pdev)
|
||||||
|
{
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_IsoINIncomplete(void *pdev)
|
||||||
|
{
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t PIOS_USBHOOK_CLASS_IsoOUTIncomplete(void *pdev)
|
||||||
|
{
|
||||||
|
return USBD_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const uint8_t * PIOS_USBHOOK_CLASS_GetConfigDescriptor(uint8_t speed, uint16_t *length)
|
||||||
|
{
|
||||||
|
*length = Config_Descriptor.length;
|
||||||
|
return Config_Descriptor.descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef USB_OTG_HS_CORE
|
||||||
|
static const uint8_t * PIOS_USBHOOK_CLASS_GetOtherConfigDescriptor(uint8_t speed, uint16_t *length)
|
||||||
|
{
|
||||||
|
return PIOS_USBHOOK_CLASS_GetConfigDescriptor(speed, length);
|
||||||
|
}
|
||||||
|
#endif /* USB_OTG_HS_CORE */
|
||||||
|
|
||||||
|
#ifdef USB_SUPPORT_USER_STRING_DESC
|
||||||
|
static const uint8_t * PIOS_USBHOOK_CLASS_GetUsrStrDescriptor(uint8_t speed, uint8_t index, uint16_t *length)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
#endif /* USB_SUPPORT_USER_STRING_DESC */
|
||||||
|
|
||||||
|
static USBD_Class_cb_TypeDef class_callbacks = {
|
||||||
|
.Init = PIOS_USBHOOK_CLASS_Init,
|
||||||
|
.DeInit = PIOS_USBHOOK_CLASS_DeInit,
|
||||||
|
.Setup = PIOS_USBHOOK_CLASS_Setup,
|
||||||
|
.EP0_TxSent = PIOS_USBHOOK_CLASS_EP0_TxSent,
|
||||||
|
.EP0_RxReady = PIOS_USBHOOK_CLASS_EP0_RxReady,
|
||||||
|
.DataIn = PIOS_USBHOOK_CLASS_DataIn,
|
||||||
|
.DataOut = PIOS_USBHOOK_CLASS_DataOut,
|
||||||
|
.SOF = PIOS_USBHOOK_CLASS_SOF,
|
||||||
|
.IsoINIncomplete = PIOS_USBHOOK_CLASS_IsoINIncomplete,
|
||||||
|
.IsoOUTIncomplete = PIOS_USBHOOK_CLASS_IsoOUTIncomplete,
|
||||||
|
.GetConfigDescriptor = PIOS_USBHOOK_CLASS_GetConfigDescriptor,
|
||||||
|
#ifdef USB_OTG_HS_CORE
|
||||||
|
.GetOtherConfigDescriptor = PIOS_USBHOOK_CLASS_GetOtherConfigDescriptor,
|
||||||
|
#endif /* USB_OTG_HS_CORE */
|
||||||
|
#ifdef USB_SUPPORT_USER_STRING_DESC
|
||||||
|
.GetUsrStrDescriptor = PIOS_USBHOOK_CLASS_GetUsrStrDescriptor,
|
||||||
|
#endif /* USB_SUPPORT_USER_STRING_DESC */
|
||||||
|
};
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
#include "stm32f10x.h" /* __IO */
|
||||||
|
__IO uint8_t EXTI_Enable;
|
||||||
|
|
||||||
|
uint32_t ProtocolValue;
|
||||||
|
|
||||||
|
DEVICE Device_Table = {
|
||||||
|
PIOS_USB_BOARD_EP_NUM,
|
||||||
|
1
|
||||||
|
};
|
||||||
|
|
||||||
|
static void PIOS_USBHOOK_Init(void);
|
||||||
|
static void PIOS_USBHOOK_Reset(void);
|
||||||
|
static void PIOS_USBHOOK_Status_In(void);
|
||||||
|
static void PIOS_USBHOOK_Status_Out(void);
|
||||||
|
static RESULT PIOS_USBHOOK_Data_Setup(uint8_t RequestNo);
|
||||||
|
static RESULT PIOS_USBHOOK_NoData_Setup(uint8_t RequestNo);
|
||||||
|
static RESULT PIOS_USBHOOK_Get_Interface_Setting(uint8_t Interface, uint8_t AlternateSetting);
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetDeviceDescriptor(uint16_t Length);
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetConfigDescriptor(uint16_t Length);
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetStringDescriptor(uint16_t Length);
|
||||||
|
|
||||||
|
DEVICE_PROP Device_Property = {
|
||||||
|
.Init = PIOS_USBHOOK_Init,
|
||||||
|
.Reset = PIOS_USBHOOK_Reset,
|
||||||
|
.Process_Status_IN = PIOS_USBHOOK_Status_In,
|
||||||
|
.Process_Status_OUT = PIOS_USBHOOK_Status_Out,
|
||||||
|
.Class_Data_Setup = PIOS_USBHOOK_Data_Setup,
|
||||||
|
.Class_NoData_Setup = PIOS_USBHOOK_NoData_Setup,
|
||||||
|
.Class_Get_Interface_Setting = PIOS_USBHOOK_Get_Interface_Setting,
|
||||||
|
.GetDeviceDescriptor = PIOS_USBHOOK_GetDeviceDescriptor,
|
||||||
|
.GetConfigDescriptor = PIOS_USBHOOK_GetConfigDescriptor,
|
||||||
|
.GetStringDescriptor = PIOS_USBHOOK_GetStringDescriptor,
|
||||||
|
.RxEP_buffer = 0,
|
||||||
|
.MaxPacketSize = 0x40,
|
||||||
|
};
|
||||||
|
|
||||||
|
static void PIOS_USBHOOK_SetConfiguration(void);
|
||||||
|
static void PIOS_USBHOOK_SetDeviceAddress(void);
|
||||||
|
|
||||||
|
USER_STANDARD_REQUESTS User_Standard_Requests = {
|
||||||
|
.User_GetConfiguration = NOP_Process,
|
||||||
|
.User_SetConfiguration = PIOS_USBHOOK_SetConfiguration,
|
||||||
|
.User_GetInterface = NOP_Process,
|
||||||
|
.User_SetInterface = NOP_Process,
|
||||||
|
.User_GetStatus = NOP_Process,
|
||||||
|
.User_ClearFeature = NOP_Process,
|
||||||
|
.User_SetEndPointFeature = NOP_Process,
|
||||||
|
.User_SetDeviceFeature = NOP_Process,
|
||||||
|
.User_SetDeviceAddress = PIOS_USBHOOK_SetDeviceAddress
|
||||||
|
};
|
||||||
|
|
||||||
|
static RESULT PIOS_USBHOOK_SetProtocol(void);
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetProtocolValue(uint16_t Length);
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetReportDescriptor(uint16_t Length);
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetHIDDescriptor(uint16_t Length);
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_Init.
|
||||||
|
* Description : Custom HID init routine.
|
||||||
|
* Input : None.
|
||||||
|
* Output : None.
|
||||||
|
* Return : None.
|
||||||
|
*******************************************************************************/
|
||||||
|
static void PIOS_USBHOOK_Init(void)
|
||||||
|
{
|
||||||
|
pInformation->Current_Configuration = 0;
|
||||||
|
|
||||||
|
/* Connect the device */
|
||||||
|
PowerOn();
|
||||||
|
|
||||||
|
/* Perform basic device initialization operations */
|
||||||
|
USB_SIL_Init();
|
||||||
|
|
||||||
|
bDeviceState = UNCONNECTED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_Reset.
|
||||||
|
* Description : Custom HID reset routine.
|
||||||
|
* Input : None.
|
||||||
|
* Output : None.
|
||||||
|
* Return : None.
|
||||||
|
*******************************************************************************/
|
||||||
|
static void PIOS_USBHOOK_Reset(void)
|
||||||
|
{
|
||||||
|
/* Set DEVICE as not configured */
|
||||||
|
pInformation->Current_Configuration = 0;
|
||||||
|
pInformation->Current_Interface = 0; /*the default Interface */
|
||||||
|
|
||||||
|
/* Current Feature initialization */
|
||||||
|
pInformation->Current_Feature = 0;
|
||||||
|
|
||||||
|
#ifdef STM32F10X_CL
|
||||||
|
/* EP0 is already configured in DFU_Init() by USB_SIL_Init() function */
|
||||||
|
|
||||||
|
/* Init EP1 IN as Interrupt endpoint */
|
||||||
|
OTG_DEV_EP_Init(EP1_IN, OTG_DEV_EP_TYPE_INT, 2);
|
||||||
|
|
||||||
|
/* Init EP1 OUT as Interrupt endpoint */
|
||||||
|
OTG_DEV_EP_Init(EP1_OUT, OTG_DEV_EP_TYPE_INT, 2);
|
||||||
|
#else
|
||||||
|
SetBTABLE(BTABLE_ADDRESS);
|
||||||
|
|
||||||
|
/* Initialize Endpoint 0 (Control) */
|
||||||
|
SetEPType(ENDP0, EP_CONTROL);
|
||||||
|
SetEPTxAddr(ENDP0, ENDP0_TXADDR);
|
||||||
|
SetEPTxStatus(ENDP0, EP_TX_STALL);
|
||||||
|
Clear_Status_Out(ENDP0);
|
||||||
|
|
||||||
|
SetEPRxAddr(ENDP0, ENDP0_RXADDR);
|
||||||
|
SetEPRxCount(ENDP0, Device_Property.MaxPacketSize);
|
||||||
|
SetEPRxValid(ENDP0);
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_HID)
|
||||||
|
/* Initialize Endpoint 1 (HID) */
|
||||||
|
SetEPType(ENDP1, EP_INTERRUPT);
|
||||||
|
SetEPTxAddr(ENDP1, ENDP1_TXADDR);
|
||||||
|
SetEPTxCount(ENDP1, PIOS_USB_BOARD_HID_DATA_LENGTH);
|
||||||
|
SetEPTxStatus(ENDP1, EP_TX_NAK);
|
||||||
|
|
||||||
|
SetEPRxAddr(ENDP1, ENDP1_RXADDR);
|
||||||
|
SetEPRxCount(ENDP1, PIOS_USB_BOARD_HID_DATA_LENGTH);
|
||||||
|
SetEPRxStatus(ENDP1, EP_RX_VALID);
|
||||||
|
#endif /* PIOS_INCLUDE_USB_HID */
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
||||||
|
/* Initialize Endpoint 2 (CDC Call Control) */
|
||||||
|
SetEPType(ENDP2, EP_INTERRUPT);
|
||||||
|
SetEPTxAddr(ENDP2, ENDP2_TXADDR);
|
||||||
|
SetEPTxStatus(ENDP2, EP_TX_NAK);
|
||||||
|
|
||||||
|
SetEPRxAddr(ENDP2, ENDP2_RXADDR);
|
||||||
|
SetEPRxCount(ENDP2, PIOS_USB_BOARD_CDC_MGMT_LENGTH);
|
||||||
|
SetEPRxStatus(ENDP2, EP_RX_DIS);
|
||||||
|
|
||||||
|
/* Initialize Endpoint 3 (CDC Data) */
|
||||||
|
SetEPType(ENDP3, EP_BULK);
|
||||||
|
SetEPTxAddr(ENDP3, ENDP3_TXADDR);
|
||||||
|
SetEPTxStatus(ENDP3, EP_TX_NAK);
|
||||||
|
|
||||||
|
SetEPRxAddr(ENDP3, ENDP3_RXADDR);
|
||||||
|
SetEPRxCount(ENDP3, PIOS_USB_BOARD_CDC_DATA_LENGTH);
|
||||||
|
SetEPRxStatus(ENDP3, EP_RX_VALID);
|
||||||
|
|
||||||
|
#endif /* PIOS_INCLUDE_USB_CDC */
|
||||||
|
|
||||||
|
/* Set this device to response on default address */
|
||||||
|
SetDeviceAddress(0);
|
||||||
|
#endif /* STM32F10X_CL */
|
||||||
|
|
||||||
|
bDeviceState = ATTACHED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_SetConfiguration.
|
||||||
|
* Description : Update the device state to configured
|
||||||
|
* Input : None.
|
||||||
|
* Output : None.
|
||||||
|
* Return : None.
|
||||||
|
*******************************************************************************/
|
||||||
|
static void PIOS_USBHOOK_SetConfiguration(void)
|
||||||
|
{
|
||||||
|
if (pInformation->Current_Configuration != 0) {
|
||||||
|
/* Device configured */
|
||||||
|
bDeviceState = CONFIGURED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Enable transfers */
|
||||||
|
PIOS_USB_ChangeConnectionState(pInformation->Current_Configuration != 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_SetConfiguration.
|
||||||
|
* Description : Update the device state to addressed.
|
||||||
|
* Input : None.
|
||||||
|
* Output : None.
|
||||||
|
* Return : None.
|
||||||
|
*******************************************************************************/
|
||||||
|
static void PIOS_USBHOOK_SetDeviceAddress(void)
|
||||||
|
{
|
||||||
|
bDeviceState = ADDRESSED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_Status_In.
|
||||||
|
* Description : status IN routine.
|
||||||
|
* Input : None.
|
||||||
|
* Output : None.
|
||||||
|
* Return : None.
|
||||||
|
*******************************************************************************/
|
||||||
|
static void PIOS_USBHOOK_Status_In(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_Status_Out
|
||||||
|
* Description : status OUT routine.
|
||||||
|
* Input : None.
|
||||||
|
* Output : None.
|
||||||
|
* Return : None.
|
||||||
|
*******************************************************************************/
|
||||||
|
static void PIOS_USBHOOK_Status_Out(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_Data_Setup
|
||||||
|
* Description : Handle the data class specific requests.
|
||||||
|
* Input : Request Nb.
|
||||||
|
* Output : None.
|
||||||
|
* Return : USB_UNSUPPORT or USB_SUCCESS.
|
||||||
|
*******************************************************************************/
|
||||||
|
static RESULT PIOS_USBHOOK_Data_Setup(uint8_t RequestNo)
|
||||||
|
{
|
||||||
|
const uint8_t *(*CopyRoutine) (uint16_t);
|
||||||
|
|
||||||
|
CopyRoutine = NULL;
|
||||||
|
|
||||||
|
switch (Type_Recipient) {
|
||||||
|
case (STANDARD_REQUEST | INTERFACE_RECIPIENT):
|
||||||
|
switch (pInformation->USBwIndex0) {
|
||||||
|
case 0: /* HID Interface */
|
||||||
|
switch (RequestNo) {
|
||||||
|
case GET_DESCRIPTOR:
|
||||||
|
switch (pInformation->USBwValue1) {
|
||||||
|
case USB_DESC_TYPE_REPORT:
|
||||||
|
CopyRoutine = PIOS_USBHOOK_GetReportDescriptor;
|
||||||
|
break;
|
||||||
|
case USB_DESC_TYPE_HID:
|
||||||
|
CopyRoutine = PIOS_USBHOOK_GetHIDDescriptor;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case (CLASS_REQUEST | INTERFACE_RECIPIENT):
|
||||||
|
switch (pInformation->USBwIndex0) {
|
||||||
|
case 0: /* HID Interface */
|
||||||
|
switch (RequestNo) {
|
||||||
|
case GET_PROTOCOL:
|
||||||
|
CopyRoutine = PIOS_USBHOOK_GetProtocolValue;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
||||||
|
case 1: /* CDC Call Control Interface */
|
||||||
|
switch (RequestNo) {
|
||||||
|
case GET_LINE_CODING:
|
||||||
|
CopyRoutine = PIOS_USB_CDC_GetLineCoding;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2: /* CDC Data Interface */
|
||||||
|
switch (RequestNo) {
|
||||||
|
case 0:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
#endif /* PIOS_INCLUDE_USB_CDC */
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (CopyRoutine == NULL) {
|
||||||
|
return USB_UNSUPPORT;
|
||||||
|
}
|
||||||
|
|
||||||
|
pInformation->Ctrl_Info.CopyDataIn = CopyRoutine;
|
||||||
|
pInformation->Ctrl_Info.Usb_wOffset = 0;
|
||||||
|
(*CopyRoutine) (0);
|
||||||
|
return USB_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_NoData_Setup
|
||||||
|
* Description : handle the no data class specific requests
|
||||||
|
* Input : Request Nb.
|
||||||
|
* Output : None.
|
||||||
|
* Return : USB_UNSUPPORT or USB_SUCCESS.
|
||||||
|
*******************************************************************************/
|
||||||
|
static RESULT PIOS_USBHOOK_NoData_Setup(uint8_t RequestNo)
|
||||||
|
{
|
||||||
|
switch (Type_Recipient) {
|
||||||
|
case (CLASS_REQUEST | INTERFACE_RECIPIENT):
|
||||||
|
switch (pInformation->USBwIndex0) {
|
||||||
|
case 0: /* HID */
|
||||||
|
switch (RequestNo) {
|
||||||
|
case SET_PROTOCOL:
|
||||||
|
return PIOS_USBHOOK_SetProtocol();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
||||||
|
case 1: /* CDC Call Control Interface */
|
||||||
|
switch (RequestNo) {
|
||||||
|
case SET_LINE_CODING:
|
||||||
|
return PIOS_USB_CDC_SetLineCoding();
|
||||||
|
break;
|
||||||
|
case SET_CONTROL_LINE_STATE:
|
||||||
|
return PIOS_USB_CDC_SetControlLineState();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
#endif /* PIOS_INCLUDE_USB_CDC */
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return USB_UNSUPPORT;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_GetDeviceDescriptor.
|
||||||
|
* Description : Gets the device descriptor.
|
||||||
|
* Input : Length
|
||||||
|
* Output : None.
|
||||||
|
* Return : The address of the device descriptor.
|
||||||
|
*******************************************************************************/
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetDeviceDescriptor(uint16_t Length)
|
||||||
|
{
|
||||||
|
return Standard_GetDescriptorData(Length, &Device_Descriptor);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_GetConfigDescriptor.
|
||||||
|
* Description : Gets the configuration descriptor.
|
||||||
|
* Input : Length
|
||||||
|
* Output : None.
|
||||||
|
* Return : The address of the configuration descriptor.
|
||||||
|
*******************************************************************************/
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetConfigDescriptor(uint16_t Length)
|
||||||
|
{
|
||||||
|
return Standard_GetDescriptorData(Length, &Config_Descriptor);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_GetStringDescriptor
|
||||||
|
* Description : Gets the string descriptors according to the needed index
|
||||||
|
* Input : Length
|
||||||
|
* Output : None.
|
||||||
|
* Return : The address of the string descriptors.
|
||||||
|
*******************************************************************************/
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetStringDescriptor(uint16_t Length)
|
||||||
|
{
|
||||||
|
uint8_t wValue0 = pInformation->USBwValue0;
|
||||||
|
if (wValue0 > 4) {
|
||||||
|
return NULL;
|
||||||
|
} else {
|
||||||
|
return Standard_GetDescriptorData(Length, &String_Descriptor[wValue0]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_GetReportDescriptor.
|
||||||
|
* Description : Gets the HID report descriptor.
|
||||||
|
* Input : Length
|
||||||
|
* Output : None.
|
||||||
|
* Return : The address of the configuration descriptor.
|
||||||
|
*******************************************************************************/
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetReportDescriptor(uint16_t Length)
|
||||||
|
{
|
||||||
|
return Standard_GetDescriptorData(Length, &Hid_Report_Descriptor);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_GetHIDDescriptor.
|
||||||
|
* Description : Gets the HID descriptor.
|
||||||
|
* Input : Length
|
||||||
|
* Output : None.
|
||||||
|
* Return : The address of the configuration descriptor.
|
||||||
|
*******************************************************************************/
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetHIDDescriptor(uint16_t Length)
|
||||||
|
{
|
||||||
|
return Standard_GetDescriptorData(Length, &Hid_Interface_Descriptor);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_Get_Interface_Setting.
|
||||||
|
* Description : tests the interface and the alternate setting according to the
|
||||||
|
* supported one.
|
||||||
|
* Input : - Interface : interface number.
|
||||||
|
* - AlternateSetting : Alternate Setting number.
|
||||||
|
* Output : None.
|
||||||
|
* Return : USB_SUCCESS or USB_UNSUPPORT.
|
||||||
|
*******************************************************************************/
|
||||||
|
static RESULT PIOS_USBHOOK_Get_Interface_Setting(uint8_t Interface, uint8_t AlternateSetting)
|
||||||
|
{
|
||||||
|
if (AlternateSetting > 0) {
|
||||||
|
return USB_UNSUPPORT;
|
||||||
|
} else if (Interface > 0) {
|
||||||
|
return USB_UNSUPPORT;
|
||||||
|
}
|
||||||
|
return USB_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_SetProtocol
|
||||||
|
* Description : Set Protocol request routine.
|
||||||
|
* Input : None.
|
||||||
|
* Output : None.
|
||||||
|
* Return : USB SUCCESS.
|
||||||
|
*******************************************************************************/
|
||||||
|
static RESULT PIOS_USBHOOK_SetProtocol(void)
|
||||||
|
{
|
||||||
|
uint8_t wValue0 = pInformation->USBwValue0;
|
||||||
|
ProtocolValue = wValue0;
|
||||||
|
return USB_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Function Name : PIOS_USBHOOK_GetProtocolValue
|
||||||
|
* Description : get the protocol value
|
||||||
|
* Input : Length.
|
||||||
|
* Output : None.
|
||||||
|
* Return : address of the protcol value.
|
||||||
|
*******************************************************************************/
|
||||||
|
static const uint8_t *PIOS_USBHOOK_GetProtocolValue(uint16_t Length)
|
||||||
|
{
|
||||||
|
if (Length == 0) {
|
||||||
|
pInformation->Ctrl_Info.Usb_wLength = 1;
|
||||||
|
return NULL;
|
||||||
|
} else {
|
||||||
|
return (uint8_t *) (&ProtocolValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2010 STMicroelectronics *****END OF FILE****/
|
||||||
|
#endif
|
@ -30,9 +30,11 @@
|
|||||||
#ifndef PIOS_USB_H
|
#ifndef PIOS_USB_H
|
||||||
#define PIOS_USB_H
|
#define PIOS_USB_H
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
/* Global functions */
|
/* Global functions */
|
||||||
extern int32_t PIOS_USB_Reenumerate();
|
extern int32_t PIOS_USB_Reenumerate();
|
||||||
extern int32_t PIOS_USB_ChangeConnectionState(uint32_t Connected);
|
extern int32_t PIOS_USB_ChangeConnectionState(bool connected);
|
||||||
extern bool PIOS_USB_CheckAvailable(uint8_t id);
|
extern bool PIOS_USB_CheckAvailable(uint8_t id);
|
||||||
|
|
||||||
#endif /* PIOS_USB_H */
|
#endif /* PIOS_USB_H */
|
||||||
|
@ -31,8 +31,6 @@
|
|||||||
#ifndef PIOS_USB_CDC_PRIV_H
|
#ifndef PIOS_USB_CDC_PRIV_H
|
||||||
#define PIOS_USB_CDC_PRIV_H
|
#define PIOS_USB_CDC_PRIV_H
|
||||||
|
|
||||||
#include "usb_core.h" /* RESULT */
|
|
||||||
|
|
||||||
struct pios_usb_cdc_cfg {
|
struct pios_usb_cdc_cfg {
|
||||||
uint8_t ctrl_if;
|
uint8_t ctrl_if;
|
||||||
uint8_t ctrl_tx_ep;
|
uint8_t ctrl_tx_ep;
|
||||||
@ -46,10 +44,6 @@ extern const struct pios_com_driver pios_usb_cdc_com_driver;
|
|||||||
|
|
||||||
extern int32_t PIOS_USB_CDC_Init(uint32_t * usbcdc_id, const struct pios_usb_cdc_cfg * cfg, uint32_t lower_id);
|
extern int32_t PIOS_USB_CDC_Init(uint32_t * usbcdc_id, const struct pios_usb_cdc_cfg * cfg, uint32_t lower_id);
|
||||||
|
|
||||||
extern const uint8_t *PIOS_USB_CDC_GetLineCoding(uint16_t Length);
|
|
||||||
extern RESULT PIOS_USB_CDC_SetControlLineState(void);
|
|
||||||
extern RESULT PIOS_USB_CDC_SetLineCoding(void);
|
|
||||||
|
|
||||||
#endif /* PIOS_USB_CDC_PRIV_H */
|
#endif /* PIOS_USB_CDC_PRIV_H */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -219,6 +219,57 @@ struct usb_endpoint_desc {
|
|||||||
uint8_t bInterval;
|
uint8_t bInterval;
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
struct usb_setup_request {
|
||||||
|
uint8_t bmRequestType;
|
||||||
|
uint8_t bRequest;
|
||||||
|
uint16_t wValue;
|
||||||
|
uint16_t wIndex;
|
||||||
|
uint16_t wLength;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
#define USB_REQ_TYPE_STANDARD 0x00
|
||||||
|
#define USB_REQ_TYPE_CLASS 0x20
|
||||||
|
#define USB_REQ_TYPE_VENDOR 0x40
|
||||||
|
#define USB_REQ_TYPE_MASK 0x60
|
||||||
|
|
||||||
|
#define USB_REQ_RECIPIENT_DEVICE 0x00
|
||||||
|
#define USB_REQ_RECIPIENT_INTERFACE 0x01
|
||||||
|
#define USB_REQ_RECIPIENT_ENDPOINT 0x02
|
||||||
|
#define USB_REQ_RECIPIENT_MASK 0x03
|
||||||
|
|
||||||
|
enum usb_standard_requests {
|
||||||
|
USB_REQ_GET_STATUS = 0x00,
|
||||||
|
USB_REQ_CLEAR_FEATURE = 0x01,
|
||||||
|
/* what is 0x02? */
|
||||||
|
USB_REQ_SET_FEATURE = 0x03,
|
||||||
|
/* what is 0x04? */
|
||||||
|
USB_REQ_SET_ADDRESS = 0x05,
|
||||||
|
USB_REQ_GET_DESCRIPTOR = 0x06,
|
||||||
|
USB_REQ_SET_DESCRIPTOR = 0x07,
|
||||||
|
USB_REQ_GET_CONFIGURATION = 0x08,
|
||||||
|
USB_REQ_SET_CONFIGURATION = 0x09,
|
||||||
|
USB_REQ_GET_INTERFACE = 0x0A,
|
||||||
|
USB_REQ_SET_INTERFACE = 0x0B,
|
||||||
|
USB_REQ_SYNCH_FRAME = 0x0C,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum usb_hid_requests {
|
||||||
|
USB_HID_REQ_GET_REPORT = 0x01,
|
||||||
|
USB_HID_REQ_GET_IDLE = 0x02,
|
||||||
|
USB_HID_REQ_GET_PROTOCOL = 0x03,
|
||||||
|
/* 0x04-0x08 Reserved */
|
||||||
|
USB_HID_REQ_SET_REPORT = 0x09,
|
||||||
|
USB_HID_REQ_SET_IDLE = 0x0A,
|
||||||
|
USB_HID_REQ_SET_PROTOCOL = 0x0B,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum usb_cdc_requests {
|
||||||
|
USB_CDC_REQ_SET_LINE_CODING = 0x20,
|
||||||
|
USB_CDC_REQ_GET_LINE_CODING = 0x21,
|
||||||
|
|
||||||
|
USB_CDC_REQ_SET_CONTROL_LINE_STATE = 0x23,
|
||||||
|
};
|
||||||
|
|
||||||
struct usb_cdc_header_func_desc {
|
struct usb_cdc_header_func_desc {
|
||||||
uint8_t bLength;
|
uint8_t bLength;
|
||||||
uint8_t bDescriptorType;
|
uint8_t bDescriptorType;
|
||||||
@ -301,6 +352,10 @@ enum usb_product_ids {
|
|||||||
USB_PRODUCT_ID_OPENPILOT_MAIN = 0x415A,
|
USB_PRODUCT_ID_OPENPILOT_MAIN = 0x415A,
|
||||||
USB_PRODUCT_ID_COPTERCONTROL = 0x415B,
|
USB_PRODUCT_ID_COPTERCONTROL = 0x415B,
|
||||||
USB_PRODUCT_ID_PIPXTREME = 0x415C,
|
USB_PRODUCT_ID_PIPXTREME = 0x415C,
|
||||||
|
USB_PRODUCT_ID_CC3D = 0x415D,
|
||||||
|
USB_PRODUCT_ID_REVOLUTION = 0x415E,
|
||||||
|
USB_PRODUCT_ID_OSD = 0x4194,
|
||||||
|
USB_PRODUCT_ID_SPARE = 0x4195,
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
enum usb_op_board_ids {
|
enum usb_op_board_ids {
|
||||||
@ -308,6 +363,7 @@ enum usb_op_board_ids {
|
|||||||
/* Board ID 2 may be unused or AHRS */
|
/* Board ID 2 may be unused or AHRS */
|
||||||
USB_OP_BOARD_ID_PIPXTREME = 3,
|
USB_OP_BOARD_ID_PIPXTREME = 3,
|
||||||
USB_OP_BOARD_ID_COPTERCONTROL = 4,
|
USB_OP_BOARD_ID_COPTERCONTROL = 4,
|
||||||
|
USB_OP_BOARD_ID_REVOLUTION = 5,
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
enum usb_op_board_modes {
|
enum usb_op_board_modes {
|
||||||
|
@ -31,10 +31,13 @@
|
|||||||
#define PIOS_USB_HID_H
|
#define PIOS_USB_HID_H
|
||||||
|
|
||||||
/* Global functions */
|
/* Global functions */
|
||||||
extern int32_t PIOS_USB_HID_Reenumerate();
|
extern int32_t PIOS_USB_HID_Reenumerate(void);
|
||||||
extern int32_t PIOS_USB_HID_ChangeConnectionState(uint32_t Connected);
|
extern int32_t PIOS_USB_HID_ChangeConnectionState(uint32_t Connected);
|
||||||
extern bool PIOS_USB_HID_CheckAvailable(uint8_t id);
|
extern bool PIOS_USB_HID_CheckAvailable(uint8_t id);
|
||||||
|
|
||||||
|
extern void PIOS_USB_HID_RegisterHidInterface(const uint8_t * desc, uint16_t length);
|
||||||
|
extern void PIOS_USB_HID_RegisterHidReport(const uint8_t * desc, uint16_t length);
|
||||||
|
|
||||||
#endif /* PIOS_USB_HID_H */
|
#endif /* PIOS_USB_HID_H */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -31,8 +31,6 @@
|
|||||||
#ifndef PIOS_USB_HID_PRIV_H
|
#ifndef PIOS_USB_HID_PRIV_H
|
||||||
#define PIOS_USB_HID_PRIV_H
|
#define PIOS_USB_HID_PRIV_H
|
||||||
|
|
||||||
#include "usb_core.h" /* RESULT */
|
|
||||||
|
|
||||||
struct pios_usb_hid_cfg {
|
struct pios_usb_hid_cfg {
|
||||||
uint8_t data_if;
|
uint8_t data_if;
|
||||||
uint8_t data_rx_ep;
|
uint8_t data_rx_ep;
|
||||||
|
@ -17,6 +17,8 @@
|
|||||||
#ifndef __USB_PWR_H
|
#ifndef __USB_PWR_H
|
||||||
#define __USB_PWR_H
|
#define __USB_PWR_H
|
||||||
|
|
||||||
|
#include "usb_core.h"
|
||||||
|
|
||||||
/* Includes ------------------------------------------------------------------*/
|
/* Includes ------------------------------------------------------------------*/
|
||||||
/* Exported types ------------------------------------------------------------*/
|
/* Exported types ------------------------------------------------------------*/
|
||||||
typedef enum _RESUME_STATE {
|
typedef enum _RESUME_STATE {
|
||||||
|
@ -31,21 +31,14 @@
|
|||||||
#ifndef PIOS_USBHOOK_H
|
#ifndef PIOS_USBHOOK_H
|
||||||
#define PIOS_USBHOOK_H
|
#define PIOS_USBHOOK_H
|
||||||
|
|
||||||
typedef enum _HID_REQUESTS {
|
#include <stdbool.h>
|
||||||
GET_REPORT = 1,
|
#include <stdint.h>
|
||||||
GET_IDLE,
|
#include "pios_usb_defs.h" /* usb_setup_request */
|
||||||
GET_PROTOCOL,
|
|
||||||
|
|
||||||
SET_REPORT = 9,
|
struct pios_usbhook_descriptor {
|
||||||
SET_IDLE,
|
const uint8_t * descriptor;
|
||||||
SET_PROTOCOL
|
uint16_t length;
|
||||||
} HID_REQUESTS;
|
};
|
||||||
|
|
||||||
typedef enum CDC_REQUESTS {
|
|
||||||
SET_LINE_CODING = 0x20,
|
|
||||||
GET_LINE_CODING = 0x21,
|
|
||||||
SET_CONTROL_LINE_STATE = 0x23,
|
|
||||||
} CDC_REQUESTS;
|
|
||||||
|
|
||||||
enum usb_string_desc {
|
enum usb_string_desc {
|
||||||
USB_STRING_DESC_LANG = 0,
|
USB_STRING_DESC_LANG = 0,
|
||||||
@ -57,8 +50,28 @@ enum usb_string_desc {
|
|||||||
extern void PIOS_USBHOOK_RegisterDevice(const uint8_t * desc, uint16_t desc_size);
|
extern void PIOS_USBHOOK_RegisterDevice(const uint8_t * desc, uint16_t desc_size);
|
||||||
extern void PIOS_USBHOOK_RegisterConfig(uint8_t config_id, const uint8_t * desc, uint16_t desc_size);
|
extern void PIOS_USBHOOK_RegisterConfig(uint8_t config_id, const uint8_t * desc, uint16_t desc_size);
|
||||||
extern void PIOS_USBHOOK_RegisterString(enum usb_string_desc string_id, const uint8_t * desc, uint16_t desc_size);
|
extern void PIOS_USBHOOK_RegisterString(enum usb_string_desc string_id, const uint8_t * desc, uint16_t desc_size);
|
||||||
extern void PIOS_USBHOOK_RegisterHidInterface(const uint8_t * desc, uint16_t desc_size);
|
|
||||||
extern void PIOS_USBHOOK_RegisterHidReport(const uint8_t * desc, uint16_t desc_size);
|
struct pios_usb_ifops {
|
||||||
|
void (*init)(uint32_t context);
|
||||||
|
void (*deinit)(uint32_t context);
|
||||||
|
bool (*setup)(uint32_t context, struct usb_setup_request * req);
|
||||||
|
void (*ctrl_data_out)(uint32_t context, struct usb_setup_request * req);
|
||||||
|
};
|
||||||
|
|
||||||
|
extern void PIOS_USBHOOK_RegisterIfOps(uint8_t ifnum, struct pios_usb_ifops * ifops, uint32_t context);
|
||||||
|
|
||||||
|
typedef bool (*pios_usbhook_epcb)(uint32_t context, uint8_t epnum, uint16_t len);
|
||||||
|
|
||||||
|
extern void PIOS_USBHOOK_RegisterEpInCallback(uint8_t epnum, uint16_t max_len, pios_usbhook_epcb cb, uint32_t context);
|
||||||
|
extern void PIOS_USBHOOK_RegisterEpOutCallback(uint8_t epnum, uint16_t max_len, pios_usbhook_epcb cb, uint32_t context);
|
||||||
|
extern void PIOS_USBHOOK_DeRegisterEpInCallback(uint8_t epnum);
|
||||||
|
extern void PIOS_USBHOOK_DeRegisterEpOutCallback(uint8_t epnum);
|
||||||
|
|
||||||
|
extern void PIOS_USBHOOK_CtrlTx(const uint8_t *buf, uint16_t len);
|
||||||
|
extern void PIOS_USBHOOK_CtrlRx(uint8_t *buf, uint16_t len);
|
||||||
|
extern void PIOS_USBHOOK_EndpointTx(uint8_t epnum, const uint8_t *buf, uint16_t len);
|
||||||
|
extern void PIOS_USBHOOK_EndpointRx(uint8_t epnum, uint8_t *buf, uint16_t len);
|
||||||
|
extern void PIOS_USBHOOK_Activate(void);
|
||||||
|
|
||||||
#endif /* PIOS_USBHOOK_H */
|
#endif /* PIOS_USBHOOK_H */
|
||||||
|
|
||||||
|
@ -150,8 +150,6 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(PIOS_INCLUDE_USB)
|
#if defined(PIOS_INCLUDE_USB)
|
||||||
/* USB Libs */
|
|
||||||
#include <usb_lib.h>
|
|
||||||
#include <pios_usb.h>
|
#include <pios_usb.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -30,5 +30,5 @@ target create $_TARGETNAME stm32_stlink -chain-position $_TARGETNAME -rtos auto
|
|||||||
|
|
||||||
$_TARGETNAME configure -work-area-phys 0x20000000 -work-area-size $_WORKAREASIZE -work-area-backup 0
|
$_TARGETNAME configure -work-area-phys 0x20000000 -work-area-size $_WORKAREASIZE -work-area-backup 0
|
||||||
|
|
||||||
set _FLASHNAME $_CHIPNAME.flash
|
#set _FLASHNAME $_CHIPNAME.flash
|
||||||
flash bank $_FLASHNAME stm32f2x 0x08000000 0 0 0 $_TARGETNAME
|
#flash bank $_FLASHNAME stm32f2x 0x08000000 0 0 0 $_TARGETNAME
|
||||||
|
4
flight/Project/gdb/bl_revolution
Normal file
4
flight/Project/gdb/bl_revolution
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
define connect
|
||||||
|
target remote localhost:3333
|
||||||
|
file ./build/bl_revolution/bl_revolution.elf
|
||||||
|
end
|
@ -119,13 +119,14 @@ SRC += ${foreach MOD, ${MODULES}, ${wildcard ${OPMODULEDIR}/${MOD}/*.c}}
|
|||||||
SRC += ${OPMODULEDIR}/System/systemmod.c
|
SRC += ${OPMODULEDIR}/System/systemmod.c
|
||||||
SRC += $(OPSYSTEM)/revolution.c
|
SRC += $(OPSYSTEM)/revolution.c
|
||||||
SRC += $(OPSYSTEM)/pios_board.c
|
SRC += $(OPSYSTEM)/pios_board.c
|
||||||
|
SRC += $(OPSYSTEM)/pios_usb_board_data.c
|
||||||
SRC += $(OPSYSTEM)/alarms.c
|
SRC += $(OPSYSTEM)/alarms.c
|
||||||
SRC += $(OPUAVTALK)/uavtalk.c
|
SRC += $(OPUAVTALK)/uavtalk.c
|
||||||
SRC += $(OPUAVOBJ)/uavobjectmanager.c
|
SRC += $(OPUAVOBJ)/uavobjectmanager.c
|
||||||
SRC += $(OPUAVOBJ)/eventdispatcher.c
|
SRC += $(OPUAVOBJ)/eventdispatcher.c
|
||||||
|
|
||||||
#ifeq ($(DEBUG),YES)
|
#ifeq ($(DEBUG),YES)
|
||||||
SRC += $(OPSYSTEM)/dcc_stdio.c
|
SRC += $(OPSYSTEM)/dcc_stdio.c
|
||||||
SRC += $(OPSYSTEM)/cm3_fault_handlers.c
|
SRC += $(OPSYSTEM)/cm3_fault_handlers.c
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -150,6 +151,8 @@ SRC += $(PIOSCOMMON)/pios_rcvr.c
|
|||||||
SRC += $(PIOSCOMMON)/pios_flash_jedec.c
|
SRC += $(PIOSCOMMON)/pios_flash_jedec.c
|
||||||
SRC += $(PIOSCOMMON)/pios_flashfs_objlist.c
|
SRC += $(PIOSCOMMON)/pios_flashfs_objlist.c
|
||||||
SRC += $(PIOSCOMMON)/printf-stdarg.c
|
SRC += $(PIOSCOMMON)/printf-stdarg.c
|
||||||
|
SRC += $(PIOSCOMMON)/pios_usb_desc_hid_cdc.c
|
||||||
|
SRC += $(PIOSCOMMON)/pios_usb_desc_hid_only.c
|
||||||
|
|
||||||
include ./UAVObjects.inc
|
include ./UAVObjects.inc
|
||||||
SRC += $(UAVOBJSRC)
|
SRC += $(UAVOBJSRC)
|
||||||
@ -314,7 +317,7 @@ ifeq ($(CODE_SOURCERY), YES)
|
|||||||
CFLAGS += -fpromote-loop-indices
|
CFLAGS += -fpromote-loop-indices
|
||||||
endif
|
endif
|
||||||
|
|
||||||
#CFLAGS += -Wall
|
CFLAGS += -Wall
|
||||||
#CFLAGS += -Werror
|
#CFLAGS += -Werror
|
||||||
CFLAGS += -Wa,-adhlns=$(addprefix $(OUTDIR)/, $(notdir $(addsuffix .lst, $(basename $<))))
|
CFLAGS += -Wa,-adhlns=$(addprefix $(OUTDIR)/, $(notdir $(addsuffix .lst, $(basename $<))))
|
||||||
# Compiler flags to generate dependency files:
|
# Compiler flags to generate dependency files:
|
||||||
|
@ -49,7 +49,8 @@
|
|||||||
#define PIOS_INCLUDE_SPI
|
#define PIOS_INCLUDE_SPI
|
||||||
#define PIOS_INCLUDE_SYS
|
#define PIOS_INCLUDE_SYS
|
||||||
#define PIOS_INCLUDE_USART
|
#define PIOS_INCLUDE_USART
|
||||||
//#define PIOS_INCLUDE_USB_HID
|
#define PIOS_INCLUDE_USB
|
||||||
|
#define PIOS_INCLUDE_USB_HID
|
||||||
//#define PIOS_INCLUDE_GPIO
|
//#define PIOS_INCLUDE_GPIO
|
||||||
#define PIOS_INCLUDE_EXTI
|
#define PIOS_INCLUDE_EXTI
|
||||||
#define PIOS_INCLUDE_RTC
|
#define PIOS_INCLUDE_RTC
|
||||||
|
45
flight/Revolution/System/inc/pios_usb_board_data.h
Normal file
45
flight/Revolution/System/inc/pios_usb_board_data.h
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @addtogroup PIOS PIOS Core hardware abstraction layer
|
||||||
|
* @{
|
||||||
|
* @addtogroup PIOS_USB_BOARD Board specific USB definitions
|
||||||
|
* @brief Board specific USB definitions
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file pios_usb_board_data.h
|
||||||
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||||
|
* @brief Board specific USB definitions
|
||||||
|
* @see The GNU Public License (GPL) Version 3
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
/*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef PIOS_USB_BOARD_DATA_H
|
||||||
|
#define PIOS_USB_BOARD_DATA_H
|
||||||
|
|
||||||
|
#define PIOS_USB_BOARD_CDC_DATA_LENGTH 64
|
||||||
|
#define PIOS_USB_BOARD_CDC_MGMT_LENGTH 32
|
||||||
|
#define PIOS_USB_BOARD_HID_DATA_LENGTH 64
|
||||||
|
|
||||||
|
#define PIOS_USB_BOARD_EP_NUM 4
|
||||||
|
|
||||||
|
#include "pios_usb_defs.h" /* USB_* macros */
|
||||||
|
|
||||||
|
#define PIOS_USB_BOARD_PRODUCT_ID USB_PRODUCT_ID_REVOLUTION
|
||||||
|
#define PIOS_USB_BOARD_DEVICE_VER USB_OP_DEVICE_VER(USB_OP_BOARD_ID_REVOLUTION, USB_OP_BOARD_MODE_FW)
|
||||||
|
|
||||||
|
#endif /* PIOS_USB_BOARD_DATA_H */
|
@ -240,6 +240,27 @@ static const struct pios_flash_jedec_cfg flash_m25p_cfg = {
|
|||||||
.chip_erase = 0xC7
|
.chip_erase = 0xC7
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* One slot per selectable receiver group.
|
||||||
|
* eg. PWM, PPM, GCS, SPEKTRUM1, SPEKTRUM2, SBUS
|
||||||
|
* NOTE: No slot in this map for NONE.
|
||||||
|
*/
|
||||||
|
uint32_t pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_NONE];
|
||||||
|
|
||||||
|
#define PIOS_COM_TELEM_RF_RX_BUF_LEN 512
|
||||||
|
#define PIOS_COM_TELEM_RF_TX_BUF_LEN 512
|
||||||
|
|
||||||
|
#define PIOS_COM_GPS_RX_BUF_LEN 32
|
||||||
|
|
||||||
|
#define PIOS_COM_TELEM_USB_RX_BUF_LEN 65
|
||||||
|
#define PIOS_COM_TELEM_USB_TX_BUF_LEN 65
|
||||||
|
|
||||||
|
#define PIOS_COM_BRIDGE_RX_BUF_LEN 65
|
||||||
|
#define PIOS_COM_BRIDGE_TX_BUF_LEN 12
|
||||||
|
|
||||||
|
uint32_t pios_com_aux_id;
|
||||||
|
uint32_t pios_com_gps_id;
|
||||||
|
uint32_t pios_com_telem_usb_id;
|
||||||
|
uint32_t pios_com_telem_rf_id;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* PIOS_Board_Init()
|
* PIOS_Board_Init()
|
||||||
@ -324,6 +345,138 @@ void PIOS_Board_Init(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//PIOS_IAP_Init();
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB)
|
||||||
|
/* Initialize board specific USB data */
|
||||||
|
PIOS_USB_BOARD_DATA_Init();
|
||||||
|
|
||||||
|
/* Flags to determine if various USB interfaces are advertised */
|
||||||
|
bool usb_hid_present = false;
|
||||||
|
bool usb_cdc_present = false;
|
||||||
|
|
||||||
|
uint8_t hwsettings_usb_devicetype;
|
||||||
|
HwSettingsUSB_DeviceTypeGet(&hwsettings_usb_devicetype);
|
||||||
|
|
||||||
|
switch (hwsettings_usb_devicetype) {
|
||||||
|
case HWSETTINGS_USB_DEVICETYPE_HIDONLY:
|
||||||
|
if (PIOS_USB_DESC_HID_ONLY_Init()) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
usb_hid_present = true;
|
||||||
|
break;
|
||||||
|
case HWSETTINGS_USB_DEVICETYPE_HIDVCP:
|
||||||
|
if (PIOS_USB_DESC_HID_CDC_Init()) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
usb_hid_present = true;
|
||||||
|
usb_cdc_present = true;
|
||||||
|
break;
|
||||||
|
case HWSETTINGS_USB_DEVICETYPE_VCPONLY:
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t pios_usb_id;
|
||||||
|
PIOS_USB_Init(&pios_usb_id, &pios_usb_main_cfg);
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
||||||
|
|
||||||
|
uint8_t hwsettings_usb_vcpport;
|
||||||
|
/* Configure the USB VCP port */
|
||||||
|
HwSettingsUSB_VCPPortGet(&hwsettings_usb_vcpport);
|
||||||
|
|
||||||
|
if (!usb_cdc_present) {
|
||||||
|
/* Force VCP port function to disabled if we haven't advertised VCP in our USB descriptor */
|
||||||
|
hwsettings_usb_vcpport = HWSETTINGS_USB_VCPPORT_DISABLED;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (hwsettings_usb_vcpport) {
|
||||||
|
case HWSETTINGS_USB_VCPPORT_DISABLED:
|
||||||
|
break;
|
||||||
|
case HWSETTINGS_USB_VCPPORT_USBTELEMETRY:
|
||||||
|
#if defined(PIOS_INCLUDE_COM)
|
||||||
|
{
|
||||||
|
uint32_t pios_usb_cdc_id;
|
||||||
|
if (PIOS_USB_CDC_Init(&pios_usb_cdc_id, &pios_usb_cdc_cfg, pios_usb_id)) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
uint8_t * rx_buffer = (uint8_t *) pvPortMalloc(PIOS_COM_TELEM_USB_RX_BUF_LEN);
|
||||||
|
uint8_t * tx_buffer = (uint8_t *) pvPortMalloc(PIOS_COM_TELEM_USB_TX_BUF_LEN);
|
||||||
|
PIOS_Assert(rx_buffer);
|
||||||
|
PIOS_Assert(tx_buffer);
|
||||||
|
if (PIOS_COM_Init(&pios_com_telem_usb_id, &pios_usb_cdc_com_driver, pios_usb_cdc_id,
|
||||||
|
rx_buffer, PIOS_COM_TELEM_USB_RX_BUF_LEN,
|
||||||
|
tx_buffer, PIOS_COM_TELEM_USB_TX_BUF_LEN)) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_COM */
|
||||||
|
break;
|
||||||
|
case HWSETTINGS_USB_VCPPORT_COMBRIDGE:
|
||||||
|
#if defined(PIOS_INCLUDE_COM)
|
||||||
|
{
|
||||||
|
uint32_t pios_usb_cdc_id;
|
||||||
|
if (PIOS_USB_CDC_Init(&pios_usb_cdc_id, &pios_usb_cdc_cfg, pios_usb_id)) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
uint8_t * rx_buffer = (uint8_t *) pvPortMalloc(PIOS_COM_BRIDGE_RX_BUF_LEN);
|
||||||
|
uint8_t * tx_buffer = (uint8_t *) pvPortMalloc(PIOS_COM_BRIDGE_TX_BUF_LEN);
|
||||||
|
PIOS_Assert(rx_buffer);
|
||||||
|
PIOS_Assert(tx_buffer);
|
||||||
|
if (PIOS_COM_Init(&pios_com_vcp_id, &pios_usb_cdc_com_driver, pios_usb_cdc_id,
|
||||||
|
rx_buffer, PIOS_COM_BRIDGE_RX_BUF_LEN,
|
||||||
|
tx_buffer, PIOS_COM_BRIDGE_TX_BUF_LEN)) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_COM */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_USB_CDC */
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_HID)
|
||||||
|
/* Configure the usb HID port */
|
||||||
|
uint8_t hwsettings_usb_hidport;
|
||||||
|
HwSettingsUSB_HIDPortGet(&hwsettings_usb_hidport);
|
||||||
|
|
||||||
|
if (!usb_hid_present) {
|
||||||
|
/* Force HID port function to disabled if we haven't advertised HID in our USB descriptor */
|
||||||
|
hwsettings_usb_hidport = HWSETTINGS_USB_HIDPORT_DISABLED;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (hwsettings_usb_hidport) {
|
||||||
|
case HWSETTINGS_USB_HIDPORT_DISABLED:
|
||||||
|
break;
|
||||||
|
case HWSETTINGS_USB_HIDPORT_USBTELEMETRY:
|
||||||
|
#if defined(PIOS_INCLUDE_COM)
|
||||||
|
{
|
||||||
|
uint32_t pios_usb_hid_id;
|
||||||
|
if (PIOS_USB_HID_Init(&pios_usb_hid_id, &pios_usb_hid_cfg, pios_usb_id)) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
uint8_t * rx_buffer = (uint8_t *) pvPortMalloc(PIOS_COM_TELEM_USB_RX_BUF_LEN);
|
||||||
|
uint8_t * tx_buffer = (uint8_t *) pvPortMalloc(PIOS_COM_TELEM_USB_TX_BUF_LEN);
|
||||||
|
PIOS_Assert(rx_buffer);
|
||||||
|
PIOS_Assert(tx_buffer);
|
||||||
|
if (PIOS_COM_Init(&pios_com_telem_usb_id, &pios_usb_hid_com_driver, pios_usb_hid_id,
|
||||||
|
rx_buffer, PIOS_COM_TELEM_USB_RX_BUF_LEN,
|
||||||
|
tx_buffer, PIOS_COM_TELEM_USB_TX_BUF_LEN)) {
|
||||||
|
PIOS_Assert(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_COM */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* PIOS_INCLUDE_USB_HID */
|
||||||
|
|
||||||
|
if (usb_hid_present || usb_cdc_present) {
|
||||||
|
PIOS_USBHOOK_Activate();
|
||||||
|
}
|
||||||
|
#endif /* PIOS_INCLUDE_USB */
|
||||||
|
|
||||||
#if defined(PIOS_INCLUDE_COM)
|
#if defined(PIOS_INCLUDE_COM)
|
||||||
#if defined(PIOS_INCLUDE_GPS)
|
#if defined(PIOS_INCLUDE_GPS)
|
||||||
|
|
||||||
|
120
flight/Revolution/System/pios_usb_board_data.c
Normal file
120
flight/Revolution/System/pios_usb_board_data.c
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @addtogroup PIOS PIOS Core hardware abstraction layer
|
||||||
|
* @{
|
||||||
|
* @addtogroup PIOS_USB_BOARD Board specific USB definitions
|
||||||
|
* @brief Board specific USB definitions
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file pios_usb_board_data.c
|
||||||
|
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
||||||
|
* @brief Board specific USB definitions
|
||||||
|
* @see The GNU Public License (GPL) Version 3
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
/*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "pios_usb_board_data.h" /* struct usb_*, USB_* */
|
||||||
|
#include "pios_sys.h" /* PIOS_SYS_SerialNumberGet */
|
||||||
|
#include "pios_usbhook.h" /* PIOS_USBHOOK_* */
|
||||||
|
|
||||||
|
static const uint8_t usb_product_id[22] = {
|
||||||
|
sizeof(usb_product_id),
|
||||||
|
USB_DESC_TYPE_STRING,
|
||||||
|
'R', 0,
|
||||||
|
'e', 0,
|
||||||
|
'v', 0,
|
||||||
|
'o', 0,
|
||||||
|
'l', 0,
|
||||||
|
'u', 0,
|
||||||
|
't', 0,
|
||||||
|
'i', 0,
|
||||||
|
'o', 0,
|
||||||
|
'n', 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
static uint8_t usb_serial_number[52] = {
|
||||||
|
sizeof(usb_serial_number),
|
||||||
|
USB_DESC_TYPE_STRING,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0,
|
||||||
|
0, 0
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct usb_string_langid usb_lang_id = {
|
||||||
|
.bLength = sizeof(usb_lang_id),
|
||||||
|
.bDescriptorType = USB_DESC_TYPE_STRING,
|
||||||
|
.bLangID = htousbs(USB_LANGID_ENGLISH_UK),
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t usb_vendor_id[28] = {
|
||||||
|
sizeof(usb_vendor_id),
|
||||||
|
USB_DESC_TYPE_STRING,
|
||||||
|
'o', 0,
|
||||||
|
'p', 0,
|
||||||
|
'e', 0,
|
||||||
|
'n', 0,
|
||||||
|
'p', 0,
|
||||||
|
'i', 0,
|
||||||
|
'l', 0,
|
||||||
|
'o', 0,
|
||||||
|
't', 0,
|
||||||
|
'.', 0,
|
||||||
|
'o', 0,
|
||||||
|
'r', 0,
|
||||||
|
'g', 0
|
||||||
|
};
|
||||||
|
|
||||||
|
int32_t PIOS_USB_BOARD_DATA_Init(void)
|
||||||
|
{
|
||||||
|
/* Load device serial number into serial number string */
|
||||||
|
uint8_t sn[25];
|
||||||
|
PIOS_SYS_SerialNumberGet((char *)sn);
|
||||||
|
for (uint8_t i = 0; sn[i] != '\0' && (2 * i) < usb_serial_number[0]; i++) {
|
||||||
|
usb_serial_number[2 + 2 * i] = sn[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
PIOS_USBHOOK_RegisterString(USB_STRING_DESC_PRODUCT, (uint8_t *)&usb_product_id, sizeof(usb_product_id));
|
||||||
|
PIOS_USBHOOK_RegisterString(USB_STRING_DESC_SERIAL, (uint8_t *)&usb_serial_number, sizeof(usb_serial_number));
|
||||||
|
|
||||||
|
PIOS_USBHOOK_RegisterString(USB_STRING_DESC_LANG, (uint8_t *)&usb_lang_id, sizeof(usb_lang_id));
|
||||||
|
PIOS_USBHOOK_RegisterString(USB_STRING_DESC_VENDOR, (uint8_t *)&usb_vendor_id, sizeof(usb_vendor_id));
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@ -618,8 +618,6 @@ static const struct pios_usart_cfg pios_usart_gps_cfg = {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
#define PIOS_COM_GPS_RX_BUF_LEN 192
|
|
||||||
|
|
||||||
#endif /* PIOS_INCLUDE_GPS */
|
#endif /* PIOS_INCLUDE_GPS */
|
||||||
|
|
||||||
#ifdef PIOS_INCLUDE_COM_AUX
|
#ifdef PIOS_INCLUDE_COM_AUX
|
||||||
@ -716,9 +714,6 @@ static const struct pios_usart_cfg pios_usart_telem_main_cfg = {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
#define PIOS_COM_TELEM_RF_RX_BUF_LEN 512
|
|
||||||
#define PIOS_COM_TELEM_RF_TX_BUF_LEN 512
|
|
||||||
|
|
||||||
#endif /* PIOS_COM_TELEM */
|
#endif /* PIOS_COM_TELEM */
|
||||||
|
|
||||||
#if defined(PIOS_INCLUDE_DSM)
|
#if defined(PIOS_INCLUDE_DSM)
|
||||||
@ -1545,17 +1540,63 @@ static const struct pios_ppm_cfg pios_ppm_cfg = {
|
|||||||
#if defined(PIOS_INCLUDE_RCVR)
|
#if defined(PIOS_INCLUDE_RCVR)
|
||||||
#include "pios_rcvr_priv.h"
|
#include "pios_rcvr_priv.h"
|
||||||
|
|
||||||
/* One slot per selectable receiver group.
|
|
||||||
* eg. PWM, PPM, GCS, SPEKTRUM1, SPEKTRUM2, SBUS
|
|
||||||
* NOTE: No slot in this map for NONE.
|
|
||||||
*/
|
|
||||||
uint32_t pios_rcvr_group_map[MANUALCONTROLSETTINGS_CHANNELGROUPS_NONE];
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern const struct pios_com_driver pios_usart_com_driver;
|
#if defined(PIOS_INCLUDE_USB)
|
||||||
|
#include "pios_usb_priv.h"
|
||||||
|
|
||||||
uint32_t pios_com_aux_id;
|
static const struct pios_usb_cfg pios_usb_main_cfg = {
|
||||||
uint32_t pios_com_gps_id;
|
.irq = {
|
||||||
uint32_t pios_com_telem_usb_id;
|
.init = {
|
||||||
uint32_t pios_com_telem_rf_id;
|
.NVIC_IRQChannel = OTG_FS_IRQn,
|
||||||
|
.NVIC_IRQChannelPreemptionPriority = PIOS_IRQ_PRIO_LOW,
|
||||||
|
.NVIC_IRQChannelSubPriority = 3,
|
||||||
|
.NVIC_IRQChannelCmd = ENABLE,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
.vsense = {
|
||||||
|
.gpio = GPIOD,
|
||||||
|
.init = {
|
||||||
|
.GPIO_Pin = GPIO_Pin_11,
|
||||||
|
.GPIO_Speed = GPIO_Speed_25MHz,
|
||||||
|
.GPIO_Mode = GPIO_Mode_IN,
|
||||||
|
.GPIO_OType = GPIO_OType_OD,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
#include "pios_usb_board_data_priv.h"
|
||||||
|
#include "pios_usb_desc_hid_cdc_priv.h"
|
||||||
|
#include "pios_usb_desc_hid_only_priv.h"
|
||||||
|
#include "pios_usbhook.h"
|
||||||
|
|
||||||
|
#endif /* PIOS_INCLUDE_USB */
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_COM_MSG)
|
||||||
|
|
||||||
|
#include <pios_com_msg_priv.h>
|
||||||
|
|
||||||
|
#endif /* PIOS_INCLUDE_COM_MSG */
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_HID)
|
||||||
|
#include <pios_usb_hid_priv.h>
|
||||||
|
|
||||||
|
const struct pios_usb_hid_cfg pios_usb_hid_cfg = {
|
||||||
|
.data_if = 0,
|
||||||
|
.data_rx_ep = 1,
|
||||||
|
.data_tx_ep = 1,
|
||||||
|
};
|
||||||
|
#endif /* PIOS_INCLUDE_USB_HID */
|
||||||
|
|
||||||
|
#if defined(PIOS_INCLUDE_USB_CDC)
|
||||||
|
#include <pios_usb_cdc_priv.h>
|
||||||
|
|
||||||
|
const struct pios_usb_cdc_cfg pios_usb_cdc_cfg = {
|
||||||
|
.ctrl_if = 1,
|
||||||
|
.ctrl_tx_ep = 2,
|
||||||
|
|
||||||
|
.data_if = 2,
|
||||||
|
.data_rx_ep = 3,
|
||||||
|
.data_tx_ep = 3,
|
||||||
|
};
|
||||||
|
#endif /* PIOS_INCLUDE_USB_CDC */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user