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 <stdint.h>
54
77#define analog_function_enable(_pin) (GPIO_PORTJ_AMSEL_R |= 1U << _pin)
78
82#define GPIO_PORTJ_PIN0 (0)
83#define GPIO_PORTJ_PIN1 (1)
84
92static inline void usb_hw_init(void) {
93 // Enable clock to J0 and J1 pins - DP/DM pins.
94 SYSCTL_RCGC2_R |= SYSCTL_GPIOHBCTL_PORTJ;
95 // Enable clock to B0 and B1 pins - USB0ID/USB0VBUS pins.
96 SYSCTL_RCGC2_R |= SYSCTL_GPIOHBCTL_PORTB;
97 // Make sure AHB (Advanced High-Performance Bus) is disabled
98 // for previously selected pins.
99 SYSCTL_GPIOHBCTL_R &= ~(SYSCTL_GPIOHBCTL_PORTJ | SYSCTL_GPIOHBCTL_PORTB);
100 // The analog functions of the pins are enabled, the isolation is
101 // disabled, and the pins are capable of analog functions.
103 analog_function_enable(GPIO_PORTJ_PIN1);
104 // Enable general USB clock.
105 SYSCTL_RCGC2_R |= SYSCTL_RCGC2_USB0;
106}
107
108 // usb
109 // middleware
110
111#ifdef __cplusplus
112}
113#endif
114
115#endif // _USB_HW_H_
116// ------------------------------------------------------------------------- END
#define GPIO_PORTJ_PIN0
Pin numbers.
Definition usb_hw.h:82
#define analog_function_enable(_pin)
Enable analog functionality.
Definition usb_hw.h:77