summaryrefslogtreecommitdiff
path: root/mcc_generated_files/usb/usb_device.h
blob: 09da2cdca492bf7a0bc550f4470533dd21bfad2d (plain)
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
*/