1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
/**
* USB_DEVICE_STACK Generated API Header File
*
* @file usb_device.h
*
* @ingroup usb_device_stack
*
* @brief Header file for the USB device setup.
*
* @version USB_DEVICE_STACK Driver Version 1.0.0
*/
/*
© [2025] Microchip Technology Inc. and its subsidiaries.
Subject to your compliance with these terms, you may use Microchip
software and any derivatives exclusively with Microchip products.
You are responsible for complying with 3rd party license terms
applicable to your use of 3rd party software (including open source
software) that may accompany Microchip software. SOFTWARE IS ?AS IS.?
NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, APPLY TO THIS
SOFTWARE, INCLUDING ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT,
MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT
WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE,
INCIDENTAL OR CONSEQUENTIAL LOSS, DAMAGE, COST OR EXPENSE OF ANY
KIND WHATSOEVER RELATED TO THE SOFTWARE, HOWEVER CAUSED, EVEN IF
MICROCHIP HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE
FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP?S
TOTAL LIABILITY ON ALL CLAIMS RELATED TO THE SOFTWARE WILL NOT
EXCEED AMOUNT OF FEES, IF ANY, YOU PAID DIRECTLY TO MICROCHIP FOR
THIS SOFTWARE.
*/
#ifndef USB_DEVICE_H
#define USB_DEVICE_H
#include <usb_core.h>
#include <usb_vendor.h>
#include "usb_descriptors.h"
/**
* @ingroup usb_device_stack
* @brief Initializes the USB device.
* @param None.
* @return None.
*/
void USBDevice_Initialize(void);
/**
* @ingroup usb_device_stack
* @brief Returns the status of the USB device.
* @param None.
* @return USB status code
*/
RETURN_CODE_t USBDevice_StatusGet(void);
/**
* @ingroup usb_device_stack
* @brief Registers the callback for the interface enable setup request handler.
* @param USB_SETUP_EVENT_CALLBACK_t cb - Callback function for the interface enable setup request
* @return None.
*/
void Vendor_InterfaceEnCallbackRegister(USB_SETUP_EVENT_CALLBACK_t cb);
/**
* @ingroup usb_device_stack
* @brief Registers the callback for the control request handler.
* @param USB_SETUP_PROCESS_CALLBACK_t cb - Callback function for the control request
* @return None.
*/
void Vendor_ControlReqCallbackRegister(USB_SETUP_PROCESS_CALLBACK_t cb);
#endif // USB_DEVICE_H
/**
End of File
*/
|