Open FFBoard
Open source force feedback firmware
usbd_pvt.h
Go to the documentation of this file.
1/*
2 * The MIT License (MIT)
3 *
4 * Copyright (c) 2019 Ha Thach (tinyusb.org)
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to deal
8 * in the Software without restriction, including without limitation the rights
9 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 * copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22 * THE SOFTWARE.
23 *
24 * This file is part of the TinyUSB stack.
25 */
26#ifndef TUSB_USBD_PVT_H_
27#define TUSB_USBD_PVT_H_
28
29#include "osal/osal.h"
30#include "common/tusb_fifo.h"
31#include "common/tusb_private.h"
32
33#ifdef __cplusplus
34 extern "C" {
35#endif
36
37#define TU_LOG_USBD(...) TU_LOG(CFG_TUD_LOG_LEVEL, __VA_ARGS__)
38
39//--------------------------------------------------------------------+
40// MACRO CONSTANT TYPEDEF PROTYPES
41//--------------------------------------------------------------------+
42
43typedef enum {
44 SOF_CONSUMER_USER = 0,
45 SOF_CONSUMER_AUDIO,
46} sof_consumer_t;
47
48//--------------------------------------------------------------------+
49// Class Driver API
50//--------------------------------------------------------------------+
51
52typedef struct {
53 char const* name;
54 void (* init ) (void);
55 bool (* deinit ) (void);
56 void (* reset ) (uint8_t rhport);
57 uint16_t (* open ) (uint8_t rhport, tusb_desc_interface_t const * desc_intf, uint16_t max_len);
58 bool (* control_xfer_cb ) (uint8_t rhport, uint8_t stage, tusb_control_request_t const * request);
59 bool (* xfer_cb ) (uint8_t rhport, uint8_t ep_addr, xfer_result_t result, uint32_t xferred_bytes);
60 void (* sof ) (uint8_t rhport, uint32_t frame_count); // optional
62
63// Invoked when initializing device stack to get additional class drivers.
64// Can be implemented by application to extend/overwrite class driver support.
65// Note: The drivers array must be accessible at all time when stack is active
66usbd_class_driver_t const* usbd_app_driver_get_cb(uint8_t* driver_count) TU_ATTR_WEAK;
67
68typedef bool (*usbd_control_xfer_cb_t)(uint8_t rhport, uint8_t stage, tusb_control_request_t const * request);
69
70void usbd_int_set(bool enabled);
71
72//--------------------------------------------------------------------+
73// USBD Endpoint API
74// Note: rhport should be 0 since device stack only support 1 rhport for now
75//--------------------------------------------------------------------+
76
77// Open an endpoint
78bool usbd_edpt_open(uint8_t rhport, tusb_desc_endpoint_t const * desc_ep);
79
80// Close an endpoint
81void usbd_edpt_close(uint8_t rhport, uint8_t ep_addr);
82
83// Submit a usb transfer
84bool usbd_edpt_xfer(uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t total_bytes);
85
86// Submit a usb ISO transfer by use of a FIFO (ring buffer) - all bytes in FIFO get transmitted
87bool usbd_edpt_xfer_fifo(uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16_t total_bytes);
88
89// Claim an endpoint before submitting a transfer.
90// If caller does not make any transfer, it must release endpoint for others.
91bool usbd_edpt_claim(uint8_t rhport, uint8_t ep_addr);
92
93// Release claimed endpoint without submitting a transfer
94bool usbd_edpt_release(uint8_t rhport, uint8_t ep_addr);
95
96// Check if endpoint is busy transferring
97bool usbd_edpt_busy(uint8_t rhport, uint8_t ep_addr);
98
99// Stall endpoint
100void usbd_edpt_stall(uint8_t rhport, uint8_t ep_addr);
101
102// Clear stalled endpoint
103void usbd_edpt_clear_stall(uint8_t rhport, uint8_t ep_addr);
104
105// Check if endpoint is stalled
106bool usbd_edpt_stalled(uint8_t rhport, uint8_t ep_addr);
107
108// Allocate packet buffer used by ISO endpoints
109bool usbd_edpt_iso_alloc(uint8_t rhport, uint8_t ep_addr, uint16_t largest_packet_size);
110
111// Configure and enable an ISO endpoint according to descriptor
112bool usbd_edpt_iso_activate(uint8_t rhport, tusb_desc_endpoint_t const * p_endpoint_desc);
113
114// Check if endpoint is ready (not busy and not stalled)
115TU_ATTR_ALWAYS_INLINE static inline
116bool usbd_edpt_ready(uint8_t rhport, uint8_t ep_addr) {
117 return !usbd_edpt_busy(rhport, ep_addr) && !usbd_edpt_stalled(rhport, ep_addr);
118}
119
120// Enable SOF interrupt
121void usbd_sof_enable(uint8_t rhport, sof_consumer_t consumer, bool en);
122
123/*------------------------------------------------------------------*/
124/* Helper
125 *------------------------------------------------------------------*/
126
127bool usbd_open_edpt_pair(uint8_t rhport, uint8_t const* p_desc, uint8_t ep_count, uint8_t xfer_type, uint8_t* ep_out, uint8_t* ep_in);
128void usbd_defer_func(osal_task_func_t func, void *param, bool in_isr);
129
130#ifdef __cplusplus
131 }
132#endif
133
134#endif
static bool in_isr
uint16_t total_bytes
Definition: dcd_nuc505.c:113
uint8_t const * buffer
Definition: midi_device.h:100
AUDIO Channel Cluster Descriptor (4.1)
Definition: audio.h:647
char const * name
Definition: usbd_pvt.h:53
xfer_result_t
Definition: tusb_types.h:236
static TU_ATTR_ALWAYS_INLINE bool usbd_edpt_ready(uint8_t rhport, uint8_t ep_addr)
Definition: usbd_pvt.h:116
void usbd_edpt_clear_stall(uint8_t rhport, uint8_t ep_addr)
Definition: usbd.c:1398
void usbd_edpt_close(uint8_t rhport, uint8_t ep_addr)
Definition: usbd.c:1424
bool usbd_edpt_xfer(uint8_t rhport, uint8_t ep_addr, uint8_t *buffer, uint16_t total_bytes)
Definition: usbd.c:1309
void usbd_edpt_stall(uint8_t rhport, uint8_t ep_addr)
Definition: usbd.c:1385
bool usbd_edpt_open(uint8_t rhport, tusb_desc_endpoint_t const *desc_ep)
Definition: usbd.c:1277
bool usbd_edpt_claim(uint8_t rhport, uint8_t ep_addr)
Definition: usbd.c:1286
void usbd_defer_func(osal_task_func_t func, void *param, bool in_isr)
Definition: usbd.c:1262
bool usbd_edpt_busy(uint8_t rhport, uint8_t ep_addr)
Definition: usbd.c:1376
bool usbd_edpt_release(uint8_t rhport, uint8_t ep_addr)
Definition: usbd.c:1299
bool usbd_open_edpt_pair(uint8_t rhport, uint8_t const *p_desc, uint8_t ep_count, uint8_t xfer_type, uint8_t *ep_out, uint8_t *ep_in)
Definition: usbd.c:1238
bool usbd_edpt_xfer_fifo(uint8_t rhport, uint8_t ep_addr, tu_fifo_t *ff, uint16_t total_bytes)
Definition: usbd.c:1348
bool usbd_edpt_iso_activate(uint8_t rhport, tusb_desc_endpoint_t const *p_endpoint_desc)
Definition: usbd.c:1474
void usbd_int_set(bool enabled)
Definition: usbd.c:1226
void usbd_sof_enable(uint8_t rhport, sof_consumer_t consumer, bool en)
Definition: usbd.c:1445
bool usbd_edpt_stalled(uint8_t rhport, uint8_t ep_addr)
Definition: usbd.c:1411
usbd_class_driver_t const * usbd_app_driver_get_cb(uint8_t *driver_count) TU_ATTR_WEAK
bool usbd_edpt_iso_alloc(uint8_t rhport, uint8_t ep_addr, uint16_t largest_packet_size)
Definition: usbd.c:1462
bool(* usbd_control_xfer_cb_t)(uint8_t rhport, uint8_t stage, tusb_control_request_t const *request)
Definition: usbd_pvt.h:68
CFG_TUH_MEM_ALIGN tusb_control_request_t request
Definition: usbh.c:259
volatile uint8_t stage
Definition: usbh.c:265