mikroSDK Reference Manual
usb_hw.h
Go to the documentation of this file.
1/****************************************************************************
2**
3** Copyright (C) 2024 MikroElektronika d.o.o.
4** Contact: https://www.mikroe.com/contact
5**
6** This file is part of the mikroSDK package
7**
8** Commercial License Usage
9**
10** Licensees holding valid commercial NECTO compilers AI licenses may use this
11** file in accordance with the commercial license agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and The MikroElektronika Company.
14** For licensing terms and conditions see
15** https://www.mikroe.com/legal/software-license-agreement.
16** For further information use the contact form at
17** https://www.mikroe.com/contact.
18**
19**
20** GNU Lesser General Public License Usage
21**
22** Alternatively, this file may be used for
23** non-commercial projects under the terms of the GNU Lesser
24** General Public License version 3 as published by the Free Software
25** Foundation: https://www.gnu.org/licenses/lgpl-3.0.html.
26**
27** The above copyright notice and this permission notice shall be
28** included in all copies or substantial portions of the Software.
29**
30** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
31** OF MERCHANTABILITY, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
32** TO THE WARRANTIES FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
33** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
34** DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT
35** OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
36** OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
37**
38****************************************************************************/
45#ifndef _USB_HW_H_
46#define _USB_HW_H_
47
48#ifdef __cplusplus
49extern "C"{
50#endif
51
52#include "mcu.h"
53#include "interrupts.h"
54// Note: Added for MikroE implementation.
55// MikroE interrupt source uses NVIC -> (IRQx + 16).
56#define NVIC_EnableIRQ(_x) interrupt_enable(_x + 16)
57#define NVIC_DisableIRQ(_x) interrupt_disable(_x + 16)
58#define power_set() ( USB_OTG_FS->GCCFG |= USB_OTG_GCCFG_PWRDWN )
59#ifdef USB_OTG_GCCFG_VBUSASEN
60#define vbus_enable() ( USB_OTG_FS->GCCFG |= USB_OTG_GCCFG_VBUSASEN )
61#else
62#define vbus_enable() ( USB_OTG_FS->GCCFG |= USB_OTG_GCCFG_VBDEN )
63#endif
64
65
87static inline void usb_hw_init(void) {
88 // Enable clock for PORT_A.
89 RCC->AHB1ENR |= RCC_AHB1ENR_GPIOAEN;
90 // Alternate function enable for pins PA12 and PA11.
93 // Pins speed selection.
96 // Setting alternate function for pins.
97 GPIOA->AFR[1] |= GPIO_AFRH_AFSEL11_1;
98 GPIOA->AFR[1] |= GPIO_AFRH_AFSEL11_3;
99 GPIOA->AFR[1] |= GPIO_AFRH_AFSEL12_1;
100 GPIOA->AFR[1] |= GPIO_AFRH_AFSEL12_3;
101
102 // Alternate function enable for pin PA10.
103 GPIOA->MODER |= GPIO_MODER_MODER10_1;
104 // Configure pin as Open drain.
105 #if CFG_TUSB_MCU == OPT_MCU_STM32F2
106 GPIOA->OTYPER |= GPIO_OTYPER_OT10;
107 #else
108 GPIOA->OTYPER |= GPIO_OTYPER_OT10_Msk;
109 #endif
110 // Configur pin Pull up.
111 GPIOA->PUPDR |= GPIO_PUPDR_PUPD10_0;
112 // Setting alternate function for pin.
113 GPIOA->AFR[1] |= GPIO_AFRH_AFSEL10_1;
114 GPIOA->AFR[1] |= GPIO_AFRH_AFSEL10_3;
115
116 // USB_OTG_FS Clock enable.
117 RCC->AHB2ENR |= RCC_AHB2ENR_OTGFSEN;
118 // System Clock Configuration Clock enable.
119 RCC->APB2ENR |= RCC_APB2ENR_SYSCFGEN;
120}
121
122 // usb
123 // middleware
124
125#ifdef __cplusplus
126}
127#endif
128
129#endif // _USB_HW_H_
130// ------------------------------------------------------------------------- END
#define GPIOA
Definition MK60D10.h:6910
#define GPIO_OTYPER_OT10_Msk
Definition stm32f407xx.h:8239
#define GPIO_MODER_MODER11_1
Definition stm32f207xx.h:8109
#define GPIO_OSPEEDR_OSPEED12_1
Definition stm32f207xx.h:8206
#define GPIO_AFRH_AFSEL11_3
Definition stm32f207xx.h:8664
#define GPIO_PUPDR_PUPD10_0
Definition stm32f207xx.h:8299
#define GPIO_MODER_MODER12_1
Definition stm32f207xx.h:8114
#define GPIO_AFRH_AFSEL11_1
Definition stm32f207xx.h:8662
#define GPIO_MODER_MODER10_1
Definition stm32f207xx.h:8104
#define GPIO_AFRH_AFSEL12_1
Definition stm32f207xx.h:8667
#define GPIO_AFRH_AFSEL12_3
Definition stm32f207xx.h:8669
#define GPIO_AFRH_AFSEL10_3
Definition stm32f207xx.h:8659
#define GPIO_OSPEEDR_OSPEED11_1
Definition stm32f207xx.h:8203
#define GPIO_AFRH_AFSEL10_1
Definition stm32f207xx.h:8657