201 lines
6.3 KiB
C
201 lines
6.3 KiB
C
|
|
/* -----------------------------------------------------------------------------
|
||
|
|
* Copyright (c) 2013-2017 ARM Ltd.
|
||
|
|
*
|
||
|
|
* This software is provided 'as-is', without any express or implied warranty.
|
||
|
|
* In no event will the authors be held liable for any damages arising from
|
||
|
|
* the use of this software. Permission is granted to anyone to use this
|
||
|
|
* software for any purpose, including commercial applications, and to alter
|
||
|
|
* it and redistribute it freely, subject to the following restrictions:
|
||
|
|
*
|
||
|
|
* 1. The origin of this software must not be misrepresented; you must not
|
||
|
|
* claim that you wrote the original software. If you use this software in
|
||
|
|
* a product, an acknowledgment in the product documentation would be
|
||
|
|
* appreciated but is not required.
|
||
|
|
*
|
||
|
|
* 2. Altered source versions must be plainly marked as such, and must not be
|
||
|
|
* misrepresented as being the original software.
|
||
|
|
*
|
||
|
|
* 3. This notice may not be removed or altered from any source distribution.
|
||
|
|
*
|
||
|
|
*
|
||
|
|
* $Date: 19. September 2017
|
||
|
|
* $Revision: V2.3
|
||
|
|
*
|
||
|
|
* Project: OTG Full/Low-Speed Common Driver for ST STM32F1xx
|
||
|
|
* -------------------------------------------------------------------------- */
|
||
|
|
|
||
|
|
/* History:
|
||
|
|
* Version 2.3
|
||
|
|
* Removed unnecessary include of cmsis_os.h
|
||
|
|
* Version 2.2
|
||
|
|
* Corrected over-current pin configuration
|
||
|
|
* Version 2.1
|
||
|
|
* Added configuration for USB Device VBUS pin so connection/disconnection of
|
||
|
|
* USB cable can be detected when device is self-powered
|
||
|
|
* Version 2.0
|
||
|
|
* Based on API V2.01
|
||
|
|
* Version 1.03
|
||
|
|
* Based on API V1.10 (namespace prefix ARM_ added)
|
||
|
|
* Version 1.00
|
||
|
|
* Initial release
|
||
|
|
*/
|
||
|
|
|
||
|
|
#include <stdint.h>
|
||
|
|
#include <string.h>
|
||
|
|
|
||
|
|
#include "stm32f10x.h"
|
||
|
|
|
||
|
|
#include "GPIO_STM32F10x.h"
|
||
|
|
#include "OTG_STM32F10x_cl.h"
|
||
|
|
|
||
|
|
#include "Driver_USBH.h"
|
||
|
|
#include "Driver_USBD.h"
|
||
|
|
|
||
|
|
|
||
|
|
extern void USBH_FS_IRQ (uint32_t gintsts);
|
||
|
|
extern void USBD_FS_IRQ (uint32_t gintsts);
|
||
|
|
|
||
|
|
uint8_t otg_fs_role = ARM_USB_ROLE_NONE;
|
||
|
|
|
||
|
|
|
||
|
|
|
||
|
|
|
||
|
|
// Common IRQ Routine **********************************************************
|
||
|
|
|
||
|
|
/**
|
||
|
|
\fn void OTG_FS_IRQHandler (void)
|
||
|
|
\brief USB Interrupt Routine (IRQ).
|
||
|
|
*/
|
||
|
|
void OTG_FS_IRQHandler (void) {
|
||
|
|
uint32_t gintsts;
|
||
|
|
|
||
|
|
gintsts = OTG_FS->GINTSTS & OTG_FS->GINTMSK;
|
||
|
|
|
||
|
|
#if (defined(MX_USB_OTG_FS_HOST) && defined(MX_USB_OTG_FS_DEVICE))
|
||
|
|
switch (otg_fs_role) {
|
||
|
|
#ifdef MX_USB_OTG_FS_HOST
|
||
|
|
case ARM_USB_ROLE_HOST:
|
||
|
|
USBH_FS_IRQ (gintsts);
|
||
|
|
break;
|
||
|
|
#endif
|
||
|
|
#ifdef MX_USB_OTG_FS_DEVICE
|
||
|
|
case ARM_USB_ROLE_DEVICE:
|
||
|
|
USBD_FS_IRQ (gintsts);
|
||
|
|
break;
|
||
|
|
#endif
|
||
|
|
default:
|
||
|
|
break;
|
||
|
|
}
|
||
|
|
#else
|
||
|
|
#ifdef MX_USB_OTG_FS_HOST
|
||
|
|
USBH_FS_IRQ (gintsts);
|
||
|
|
#else
|
||
|
|
USBD_FS_IRQ (gintsts);
|
||
|
|
#endif
|
||
|
|
#endif
|
||
|
|
}
|
||
|
|
|
||
|
|
|
||
|
|
// Public Functions ************************************************************
|
||
|
|
|
||
|
|
/**
|
||
|
|
\fn void OTG_FS_PinsConfigure (uint8_t pins_mask)
|
||
|
|
\brief Configure single or multiple USB Pin(s).
|
||
|
|
\param[in] Mask of pins to be configured (possible masking values:
|
||
|
|
USB_PIN_DP, USB_PIN_DM, USB_PIN_VBUS, USB_PIN_OC, USB_PIN_ID)
|
||
|
|
*/
|
||
|
|
void OTG_FS_PinsConfigure (uint8_t pins_mask) {
|
||
|
|
|
||
|
|
#ifdef MX_USB_OTG_FS_VBUS_Power_Pin // Host VBUS power driving pin (output)
|
||
|
|
if ((pins_mask & ARM_USB_PIN_VBUS) != 0U) {
|
||
|
|
if (otg_fs_role == ARM_USB_ROLE_DEVICE) {
|
||
|
|
GPIO_PortClock (GPIOA, true);
|
||
|
|
GPIO_PinConfigure(GPIOA, 9, GPIO_IN_FLOATING, GPIO_MODE_INPUT);
|
||
|
|
}
|
||
|
|
if (otg_fs_role == ARM_USB_ROLE_HOST) {
|
||
|
|
GPIO_PortClock (MX_USB_OTG_FS_VBUS_Power_GPIOx, true);
|
||
|
|
#if (USB_OTG_FS_VBUS_Power_Pin_Active == 0)
|
||
|
|
GPIO_PinWrite (MX_USB_OTG_FS_VBUS_Power_GPIOx, MX_USB_OTG_FS_VBUS_Power_GPIO_Pin, 1U);
|
||
|
|
#else
|
||
|
|
GPIO_PinWrite (MX_USB_OTG_FS_VBUS_Power_GPIOx, MX_USB_OTG_FS_VBUS_Power_GPIO_Pin, 0U);
|
||
|
|
#endif
|
||
|
|
GPIO_PinConfigure(MX_USB_OTG_FS_VBUS_Power_GPIOx, MX_USB_OTG_FS_VBUS_Power_GPIO_Pin, GPIO_OUT_PUSH_PULL, GPIO_MODE_OUT10MHZ);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
#endif
|
||
|
|
#ifdef MX_USB_OTG_FS_Overcurrent_Pin // Host overcurrent sensing pin (input)
|
||
|
|
if ((pins_mask & ARM_USB_PIN_OC) != 0U) {
|
||
|
|
if (otg_fs_role == ARM_USB_ROLE_HOST) {
|
||
|
|
GPIO_PortClock (MX_USB_OTG_FS_Overcurrent_GPIOx, true);
|
||
|
|
GPIO_PinConfigure(MX_USB_OTG_FS_Overcurrent_GPIOx, MX_USB_OTG_FS_Overcurrent_GPIO_Pin, GPIO_IN_FLOATING, GPIO_MODE_INPUT);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
#endif
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
\fn void OTG_FS_PinsUnconfigure (uint8_t pins_mask)
|
||
|
|
\brief Unconfigure to reset settings single or multiple USB Pin(s).
|
||
|
|
\param[in] Mask of pins to be unconfigured (possible masking values:
|
||
|
|
USB_PIN_DP, USB_PIN_DM, USB_PIN_VBUS, USB_PIN_OC, USB_PIN_ID)
|
||
|
|
*/
|
||
|
|
void OTG_FS_PinsUnconfigure (uint8_t pins_mask) {
|
||
|
|
|
||
|
|
#ifdef MX_USB_OTG_FS_VBUS_Power_Pin
|
||
|
|
if ((pins_mask & ARM_USB_PIN_VBUS) != 0U) {
|
||
|
|
if (otg_fs_role == ARM_USB_ROLE_HOST) {
|
||
|
|
GPIO_PortClock (MX_USB_OTG_FS_VBUS_Power_GPIOx, true);
|
||
|
|
GPIO_PinConfigure(MX_USB_OTG_FS_VBUS_Power_GPIOx, MX_USB_OTG_FS_VBUS_Power_GPIO_Pin, GPIO_IN_FLOATING, GPIO_MODE_INPUT);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
#endif
|
||
|
|
#ifdef MX_USB_OTG_FS_Overcurrent_Pin
|
||
|
|
if ((pins_mask & ARM_USB_PIN_OC) != 0U) {
|
||
|
|
if (otg_fs_role == ARM_USB_ROLE_HOST) {
|
||
|
|
GPIO_PortClock (MX_USB_OTG_FS_Overcurrent_GPIOx, true);
|
||
|
|
GPIO_PinConfigure(MX_USB_OTG_FS_Overcurrent_GPIOx, MX_USB_OTG_FS_Overcurrent_GPIO_Pin, GPIO_IN_FLOATING, GPIO_MODE_INPUT);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
#endif
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
\fn void OTG_FS_PinVbusOnOff (bool state)
|
||
|
|
\brief Drive VBUS Pin On/Off.
|
||
|
|
\param[in] state State On/Off (true = On, false = Off)
|
||
|
|
*/
|
||
|
|
|
||
|
|
void OTG_FS_PinVbusOnOff (bool state) {
|
||
|
|
|
||
|
|
#ifdef MX_USB_OTG_FS_VBUS_Power_Pin
|
||
|
|
if (otg_fs_role == ARM_USB_ROLE_HOST) {
|
||
|
|
#if (USB_OTG_FS_VBUS_Power_Pin_Active == 0)
|
||
|
|
GPIO_PinWrite (MX_USB_OTG_FS_VBUS_Power_GPIOx, MX_USB_OTG_FS_VBUS_Power_GPIO_Pin,((state == true) ? 0U : 1U));
|
||
|
|
#else
|
||
|
|
GPIO_PinWrite (MX_USB_OTG_FS_VBUS_Power_GPIOx, MX_USB_OTG_FS_VBUS_Power_GPIO_Pin,((state == true) ? 1U : 0U));
|
||
|
|
#endif
|
||
|
|
}
|
||
|
|
#endif
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
\fn bool OTG_FS_PinGetOC (void)
|
||
|
|
\brief Get state of Overcurrent Pin.
|
||
|
|
\return overcurrent state (true = Overcurrent active, false = No overcurrent)
|
||
|
|
*/
|
||
|
|
bool OTG_FS_PinGetOC (void) {
|
||
|
|
|
||
|
|
#ifdef MX_USB_OTG_FS_Overcurrent_Pin
|
||
|
|
if (otg_fs_role == ARM_USB_ROLE_HOST) {
|
||
|
|
#if (USB_OTG_FS_Overcurrent_Pin_Active == 0)
|
||
|
|
return ((GPIO_PinRead (MX_USB_OTG_FS_Overcurrent_GPIOx, MX_USB_OTG_FS_Overcurrent_GPIO_Pin) == 0U) ? true : false);
|
||
|
|
#else
|
||
|
|
return ((GPIO_PinRead (MX_USB_OTG_FS_Overcurrent_GPIOx, MX_USB_OTG_FS_Overcurrent_GPIO_Pin) == 1U) ? true : false);
|
||
|
|
#endif
|
||
|
|
}
|
||
|
|
return false;
|
||
|
|
#else
|
||
|
|
return false;
|
||
|
|
#endif
|
||
|
|
}
|