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
73// Clock value in Hz provided externally.
74extern volatile uint32_t SystemCoreClock;
75
83static inline void usb_hw_init(void) {
84 // System Clock Configuration Clock enable.
85 RCC->APB2ENR |= RCC_APB2ENR_SYSCFGEN;
86 RCC->APB1ENR1 |= RCC_APB1ENR1_PWREN;
87 // Enable access to the backup domain.
88 PWR->CR1 |= PWR_CR1_DBP;
89 // Modify LSE drive capability. (lower driving capability)
90 RCC->BDCR &= ~RCC_BDCR_LSEDRV_Msk;
91 // Enable clock for PORT_A.
92 RCC->AHB2ENR |= RCC_AHB2ENR_GPIOAEN;
100 GPIOA->PUPDR = 0x64000000UL;
101 GPIOA->OSPEEDR = 0xFC00000UL;
102 GPIOA->OTYPER = 0UL;
103 GPIOA->AFR[1] = 0xAA000UL;
104 GPIOA->MODER = 0xAAB3FFFFUL;
105 // Enable VDDUSB.
106 if (!(RCC->APB1ENR1 & RCC_APB1ENR1_PWREN)) {
107 RCC->APB1ENR1 |= RCC_APB1ENR1_PWREN;
108 PWR->CR2 |= PWR_CR2_USV;
109 RCC->APB1ENR1 &= ~RCC_APB1ENR1_PWREN;
110 } else {
111 PWR->CR2 |= PWR_CR2_USV;
112 }
113 #ifdef RCC_CRRCR_HSI48ON
114 // Turn HSI48 on. Only for L496/L4A6 devices.
115 RCC->CRRCR |= RCC_CRRCR_HSI48ON;
116 // Wait for HSI48 to stabilize.
117 while(!(RCC->CRRCR & RCC_CRRCR_HSI48RDY));
118 // Select HSI48 as USB clock source.
119 RCC->CCIPR &= ~RCC_CCIPR_CLK48SEL;
120 #endif
121 // USB_OTG_FS Clock enable.
122 RCC->AHB2ENR |= RCC_AHB2ENR_OTGFSEN;
123}
124
125 // usb
126 // middleware
127
128#ifdef __cplusplus
129}
130#endif
131
132#endif // _USB_HW_H_
133// ------------------------------------------------------------------------- END
#define GPIOA
Definition MK60D10.h:6910
#define PWR_CR1_DBP
Definition stm32f745xx.h:9512