Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
usbd.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2022 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
13
14#ifndef ZEPHYR_INCLUDE_USBD_H_
15#define ZEPHYR_INCLUDE_USBD_H_
16
17#include <zephyr/device.h>
18#include <zephyr/usb/bos.h>
19#include <zephyr/usb/usb_ch9.h>
20#include <zephyr/usb/usbd_msg.h>
23#include <zephyr/sys/slist.h>
24#include <zephyr/logging/log.h>
26
27#ifdef __cplusplus
28extern "C" {
29#endif
30
39
40/* 1 if USB device stack is compiled with High-Speed support */
41#define USBD_SUPPORTS_HIGH_SPEED IS_EQ(CONFIG_USBD_MAX_SPEED, 1)
42
43/* Maximum bulk max packet size the stack supports */
44#define USBD_MAX_BULK_MPS COND_CODE_1(USBD_SUPPORTS_HIGH_SPEED, (512), (64))
45
46/*
47 * The length of the string descriptor (bLength) is calculated from the
48 * size of the two octets bLength and bDescriptorType plus the
49 * length of the UTF16LE string:
50 *
51 * bLength = 2 + bString_length
52 * bLength = 2 + sizeof(initializer_string) * 2 - 2
53 * bLength = sizeof(initializer_string) * 2
54 * Use this macro to determine the bLength of the string descriptor.
55 */
56#define USB_STRING_DESCRIPTOR_LENGTH(s) (sizeof(s) * 2)
57
58struct usbd_context;
59
63enum usbd_str_desc_utype {
64 USBD_DUT_STRING_LANG,
65 USBD_DUT_STRING_MANUFACTURER,
66 USBD_DUT_STRING_PRODUCT,
67 USBD_DUT_STRING_SERIAL_NUMBER,
68 USBD_DUT_STRING_CONFIG,
69 USBD_DUT_STRING_INTERFACE,
70};
71
72enum usbd_bos_desc_utype {
73 USBD_DUT_BOS_NONE,
74 USBD_DUT_BOS_VREQ,
75};
77
85 enum usbd_str_desc_utype utype : 8;
87 unsigned int ascii7 : 1;
89 unsigned int use_hwinfo : 1;
90};
91
131 int (*to_host)(const struct usbd_context *const ctx,
132 const struct usb_setup_packet *const setup,
133 struct net_buf *const buf);
145 int (*to_dev)(const struct usbd_context *const ctx,
146 const struct usb_setup_packet *const setup,
147 const struct net_buf *const buf);
148};
149
155 enum usbd_bos_desc_utype utype : 8;
156 union {
157 struct usbd_vreq_node *const vreq_nd;
158 };
159};
160
181
200
201/* TODO: Kconfig option USBD_NUMOF_INTERFACES_MAX? */
202#define USBD_NUMOF_INTERFACES_MAX 16U
203
215
216
234
246
252 unsigned int initialized : 1;
254 unsigned int enabled : 1;
256 unsigned int suspended : 1;
258 unsigned int rwup : 1;
260 unsigned int self_powered : 1;
263};
264
280typedef void (*usbd_msg_cb_t)(struct usbd_context *const ctx,
281 const struct usbd_msg *const msg);
282
321
331
333#define USBD_CCTX_REGISTERED 0
334
335struct usbd_class_data;
336
342 void (*feature_halt)(struct usbd_class_data *const c_data,
343 uint8_t ep, bool halted);
344
346 void (*update)(struct usbd_class_data *const c_data,
347 uint8_t iface, uint8_t alternate);
348
350 int (*control_to_dev)(struct usbd_class_data *const c_data,
351 const struct usb_setup_packet *const setup,
352 const struct net_buf *const buf);
353
355 int (*control_to_host)(struct usbd_class_data *const c_data,
356 const struct usb_setup_packet *const setup,
357 struct net_buf *const buf);
358
360 int (*request)(struct usbd_class_data *const c_data,
361 struct net_buf *buf, int err);
362
364 void (*suspended)(struct usbd_class_data *const c_data);
365
367 void (*resumed)(struct usbd_class_data *const c_data);
368
370 void (*sof)(struct usbd_class_data *const c_data);
371
373 void (*enable)(struct usbd_class_data *const c_data);
374
376 void (*disable)(struct usbd_class_data *const c_data);
377
379 int (*init)(struct usbd_class_data *const c_data);
380
382 void (*shutdown)(struct usbd_class_data *const c_data);
383
385 void *(*get_desc)(struct usbd_class_data *const c_data,
386 const enum usbd_speed speed);
387};
388
394 const char *name;
398 const struct usbd_class_api *api;
402 void *priv;
403};
404
413struct usbd_class_node {
415 sys_snode_t node;
417 struct usbd_class_data *const c_data;
421 uint32_t ep_assigned;
425 uint32_t ep_active;
427 uint32_t iface_bm;
430};
431
433
444static inline struct usbd_context *usbd_class_get_ctx(const struct usbd_class_data *const c_data)
445{
446 return c_data->uds_ctx;
447}
448
459static inline void *usbd_class_get_private(const struct usbd_class_data *const c_data)
460{
461 return c_data->priv;
462}
463
484#define USBD_DEVICE_DEFINE(device_name, udc_dev, vid, pid) \
485 static struct usb_device_descriptor \
486 fs_desc_##device_name = { \
487 .bLength = sizeof(struct usb_device_descriptor), \
488 .bDescriptorType = USB_DESC_DEVICE, \
489 .bcdUSB = sys_cpu_to_le16(USB_SRN_2_0), \
490 .bDeviceClass = USB_BCC_MISCELLANEOUS, \
491 .bDeviceSubClass = 2, \
492 .bDeviceProtocol = 1, \
493 .bMaxPacketSize0 = USB_CONTROL_EP_MPS, \
494 .idVendor = vid, \
495 .idProduct = pid, \
496 .bcdDevice = sys_cpu_to_le16(USB_BCD_DRN), \
497 .iManufacturer = 0, \
498 .iProduct = 0, \
499 .iSerialNumber = 0, \
500 .bNumConfigurations = 0, \
501 }; \
502 IF_ENABLED(USBD_SUPPORTS_HIGH_SPEED, ( \
503 static struct usb_device_descriptor \
504 hs_desc_##device_name = { \
505 .bLength = sizeof(struct usb_device_descriptor), \
506 .bDescriptorType = USB_DESC_DEVICE, \
507 .bcdUSB = sys_cpu_to_le16(USB_SRN_2_0), \
508 .bDeviceClass = USB_BCC_MISCELLANEOUS, \
509 .bDeviceSubClass = 2, \
510 .bDeviceProtocol = 1, \
511 .bMaxPacketSize0 = 64, \
512 .idVendor = vid, \
513 .idProduct = pid, \
514 .bcdDevice = sys_cpu_to_le16(USB_BCD_DRN), \
515 .iManufacturer = 0, \
516 .iProduct = 0, \
517 .iSerialNumber = 0, \
518 .bNumConfigurations = 0, \
519 }; \
520 )) \
521 static STRUCT_SECTION_ITERABLE(usbd_context, device_name) = { \
522 .name = STRINGIFY(device_name), \
523 .dev = udc_dev, \
524 .fs_desc = &fs_desc_##device_name, \
525 IF_ENABLED(USBD_SUPPORTS_HIGH_SPEED, ( \
526 .hs_desc = &hs_desc_##device_name, \
527 )) \
528 }
529
547#define USBD_CONFIGURATION_DEFINE(name, attrib, power, desc_nd) \
548 static struct usb_cfg_descriptor \
549 cfg_desc_##name = { \
550 .bLength = sizeof(struct usb_cfg_descriptor), \
551 .bDescriptorType = USB_DESC_CONFIGURATION, \
552 .wTotalLength = 0, \
553 .bNumInterfaces = 0, \
554 .bConfigurationValue = 1, \
555 .iConfiguration = 0, \
556 .bmAttributes = USB_SCD_RESERVED | (attrib), \
557 .bMaxPower = (power), \
558 }; \
559 BUILD_ASSERT((power) < 256, "Too much power"); \
560 static struct usbd_config_node name = { \
561 .desc = &cfg_desc_##name, \
562 .str_desc_nd = desc_nd, \
563 }
564
578#define USBD_DESC_LANG_DEFINE(name) \
579 static const uint16_t langid_##name = sys_cpu_to_le16(0x0409); \
580 static struct usbd_desc_node name = { \
581 .str = { \
582 .idx = 0, \
583 .utype = USBD_DUT_STRING_LANG, \
584 }, \
585 .ptr = &langid_##name, \
586 .bLength = sizeof(struct usb_string_descriptor), \
587 .bDescriptorType = USB_DESC_STRING, \
588 }
589
601#define USBD_DESC_STRING_DEFINE(d_name, d_string, d_utype) \
602 static const uint8_t ascii_##d_name[sizeof(d_string)] = d_string; \
603 static struct usbd_desc_node d_name = { \
604 .str = { \
605 .utype = d_utype, \
606 .ascii7 = true, \
607 }, \
608 .ptr = &ascii_##d_name, \
609 .bLength = USB_STRING_DESCRIPTOR_LENGTH(d_string), \
610 .bDescriptorType = USB_DESC_STRING, \
611 }
612
624#define USBD_DESC_MANUFACTURER_DEFINE(d_name, d_string) \
625 USBD_DESC_STRING_DEFINE(d_name, d_string, USBD_DUT_STRING_MANUFACTURER)
626
638#define USBD_DESC_PRODUCT_DEFINE(d_name, d_string) \
639 USBD_DESC_STRING_DEFINE(d_name, d_string, USBD_DUT_STRING_PRODUCT)
640
654#define USBD_DESC_SERIAL_NUMBER_DEFINE(d_name) \
655 BUILD_ASSERT(IS_ENABLED(CONFIG_HWINFO), "HWINFO not enabled"); \
656 static struct usbd_desc_node d_name = { \
657 .str = { \
658 .utype = USBD_DUT_STRING_SERIAL_NUMBER, \
659 .ascii7 = true, \
660 .use_hwinfo = true, \
661 }, \
662 .bDescriptorType = USB_DESC_STRING, \
663 }
664
674#define USBD_DESC_CONFIG_DEFINE(d_name, d_string) \
675 USBD_DESC_STRING_DEFINE(d_name, d_string, USBD_DUT_STRING_CONFIG)
676
689#define USBD_DESC_BOS_DEFINE(name, len, subset) \
690 BUILD_ASSERT(IS_ENABLED(CONFIG_USBD_BOS_SUPPORT), \
691 "USB device BOS support is disabled"); \
692 static struct usbd_desc_node name = { \
693 .bos = { \
694 .utype = USBD_DUT_BOS_NONE, \
695 }, \
696 .ptr = subset, \
697 .bLength = len, \
698 .bDescriptorType = USB_DESC_BOS, \
699 }
700
711#define USBD_VREQUEST_DEFINE(name, vcode, vto_host, vto_dev) \
712 BUILD_ASSERT(IS_ENABLED(CONFIG_USBD_VREQ_SUPPORT), \
713 "USB device vendor request support is disabled"); \
714 static struct usbd_vreq_node name = { \
715 .code = vcode, \
716 .to_host = vto_host, \
717 .to_dev = vto_dev, \
718 }
719
739#define USBD_DESC_BOS_VREQ_DEFINE(name, len, subset, vcode, vto_host, vto_dev) \
740 BUILD_ASSERT(IS_ENABLED(CONFIG_USBD_BOS_SUPPORT), \
741 "USB device BOS support is disabled"); \
742 USBD_VREQUEST_DEFINE(vreq_nd_##name, vcode, vto_host, vto_dev); \
743 static struct usbd_desc_node name = { \
744 .bos = { \
745 .utype = USBD_DUT_BOS_VREQ, \
746 .vreq_nd = &vreq_nd_##name, \
747 }, \
748 .ptr = subset, \
749 .bLength = len, \
750 .bDescriptorType = USB_DESC_BOS, \
751 }
752
764#define USBD_DEFINE_CLASS(class_name, class_api, class_priv, class_v_reqs) \
765 static struct usbd_class_data class_name = { \
766 .name = STRINGIFY(class_name), \
767 .api = class_api, \
768 .v_reqs = class_v_reqs, \
769 .priv = class_priv, \
770 }; \
771 static STRUCT_SECTION_ITERABLE_ALTERNATE( \
772 usbd_class_fs, usbd_class_node, class_name##_fs) = { \
773 .c_data = &class_name, \
774 }; \
775 IF_ENABLED(USBD_SUPPORTS_HIGH_SPEED, ( \
776 static STRUCT_SECTION_ITERABLE_ALTERNATE( \
777 usbd_class_hs, usbd_class_node, class_name##_hs) = { \
778 .c_data = &class_name, \
779 } \
780 ))
781
787#define VENDOR_REQ_DEFINE(_reqs, _len) \
788 { \
789 .reqs = (const uint8_t *)(_reqs), \
790 .len = (_len), \
791 }
792
797#define USBD_VENDOR_REQ(_reqs...) \
798 VENDOR_REQ_DEFINE(((uint8_t []) { _reqs }), \
799 sizeof((uint8_t []) { _reqs }))
800
801
813 struct usbd_desc_node *dn);
814
822uint8_t usbd_str_desc_get_idx(const struct usbd_desc_node *const desc_nd);
823
831void usbd_remove_descriptor(struct usbd_desc_node *const desc_nd);
832
843 const enum usbd_speed speed,
844 struct usbd_config_node *cd);
845
868 const char *name,
869 const enum usbd_speed speed, uint8_t cfg);
870
903 const enum usbd_speed speed, uint8_t cfg,
904 const char *const blocklist[]);
905
921 const char *name,
922 const enum usbd_speed speed, uint8_t cfg);
923
937 const enum usbd_speed speed, uint8_t cfg);
938
947int usbd_msg_register_cb(struct usbd_context *const uds_ctx,
948 const usbd_msg_cb_t cb);
949
963int usbd_init(struct usbd_context *uds_ctx);
964
974int usbd_enable(struct usbd_context *uds_ctx);
975
985int usbd_disable(struct usbd_context *uds_ctx);
986
996int usbd_shutdown(struct usbd_context *const uds_ctx);
997
1006int usbd_ep_set_halt(struct usbd_context *uds_ctx, uint8_t ep);
1007
1016int usbd_ep_clear_halt(struct usbd_context *uds_ctx, uint8_t ep);
1017
1026bool usbd_ep_is_halted(struct usbd_context *uds_ctx, uint8_t ep);
1027
1039struct net_buf *usbd_ep_buf_alloc(const struct usbd_class_data *const c_data,
1040 const uint8_t ep, const size_t size);
1041
1052struct net_buf *usbd_ep_ctrl_data_in_alloc(const struct usbd_context *const uds_ctx,
1053 const size_t size);
1054
1065int usbd_ep_ctrl_enqueue(struct usbd_context *const uds_ctx,
1066 struct net_buf *const buf);
1067
1078int usbd_ep_enqueue(const struct usbd_class_data *const c_data,
1079 struct net_buf *const buf);
1080
1089int usbd_ep_dequeue(struct usbd_context *uds_ctx, const uint8_t ep);
1090
1101int usbd_ep_buf_free(struct usbd_context *uds_ctx, struct net_buf *buf);
1102
1110bool usbd_is_suspended(struct usbd_context *uds_ctx);
1111
1118
1128void usbd_self_powered(struct usbd_context *uds_ctx, const bool status);
1129
1137enum usbd_speed usbd_bus_speed(const struct usbd_context *const uds_ctx);
1138
1146enum usbd_speed usbd_caps_speed(const struct usbd_context *const uds_ctx);
1147
1157int usbd_device_set_bcd_usb(struct usbd_context *const uds_ctx,
1158 const enum usbd_speed speed, const uint16_t bcd);
1159
1168int usbd_device_set_vid(struct usbd_context *const uds_ctx,
1169 const uint16_t vid);
1170
1179int usbd_device_set_pid(struct usbd_context *const uds_ctx,
1180 const uint16_t pid);
1181
1191 const uint16_t bcd);
1192
1205 const enum usbd_speed speed,
1206 const uint8_t base_class,
1207 const uint8_t subclass, const uint8_t protocol);
1208
1219int usbd_config_attrib_rwup(struct usbd_context *const uds_ctx,
1220 const enum usbd_speed speed,
1221 const uint8_t cfg, const bool enable);
1222
1233int usbd_config_attrib_self(struct usbd_context *const uds_ctx,
1234 const enum usbd_speed speed,
1235 const uint8_t cfg, const bool enable);
1236
1247int usbd_config_maxpower(struct usbd_context *const uds_ctx,
1248 const enum usbd_speed speed,
1249 const uint8_t cfg, const uint8_t power);
1250
1263bool usbd_can_detect_vbus(struct usbd_context *const uds_ctx);
1264
1276int usbd_device_register_vreq(struct usbd_context *const uds_ctx,
1277 struct usbd_vreq_node *const vreq_nd);
1278
1282
1283#ifdef __cplusplus
1284}
1285#endif
1286
1287#endif /* ZEPHYR_INCLUDE_USBD_H_ */
USB Binary Device Object Store support.
long atomic_t
Atomic integer variable.
Definition atomic_types.h:31
struct _dnode sys_dnode_t
Doubly-linked list node structure.
Definition dlist.h:57
struct _dnode sys_dlist_t
Doubly-linked list structure.
Definition dlist.h:53
struct _slist sys_slist_t
Single-linked list structure.
Definition slist.h:52
struct _snode sys_snode_t
Single-linked list node structure.
Definition slist.h:42
int usbd_ep_clear_halt(struct usbd_context *uds_ctx, uint8_t ep)
Clear endpoint halt.
int usbd_register_all_classes(struct usbd_context *uds_ctx, const enum usbd_speed speed, uint8_t cfg, const char *const blocklist[])
Register all available USB class instances.
int usbd_device_set_vid(struct usbd_context *const uds_ctx, const uint16_t vid)
Set USB device descriptor value idVendor.
int usbd_ep_dequeue(struct usbd_context *uds_ctx, const uint8_t ep)
Remove all USB device controller requests from endpoint queue.
int usbd_ep_set_halt(struct usbd_context *uds_ctx, uint8_t ep)
Halt endpoint.
int usbd_enable(struct usbd_context *uds_ctx)
Enable the USB device support and registered class instances.
int usbd_unregister_class(struct usbd_context *uds_ctx, const char *name, const enum usbd_speed speed, uint8_t cfg)
Unregister an USB class instance.
struct net_buf * usbd_ep_ctrl_data_in_alloc(const struct usbd_context *const uds_ctx, const size_t size)
Allocate buffer for USB control transfer data stage.
int usbd_unregister_all_classes(struct usbd_context *uds_ctx, const enum usbd_speed speed, uint8_t cfg)
Unregister all available USB class instances.
int usbd_config_attrib_rwup(struct usbd_context *const uds_ctx, const enum usbd_speed speed, const uint8_t cfg, const bool enable)
Setup USB device configuration attribute Remote Wakeup.
void(* usbd_msg_cb_t)(struct usbd_context *const ctx, const struct usbd_msg *const msg)
Callback type definition for USB device message delivery.
Definition usbd.h:280
static void * usbd_class_get_private(const struct usbd_class_data *const c_data)
Get class implementation private data.
Definition usbd.h:459
int usbd_msg_register_cb(struct usbd_context *const uds_ctx, const usbd_msg_cb_t cb)
Register USB notification message callback.
usbd_speed
USB device speed.
Definition usbd.h:238
void usbd_remove_descriptor(struct usbd_desc_node *const desc_nd)
Remove USB string descriptor.
int usbd_add_descriptor(struct usbd_context *uds_ctx, struct usbd_desc_node *dn)
Add common USB descriptor.
int usbd_wakeup_request(struct usbd_context *uds_ctx)
Initiate the USB remote wakeup (TBD).
int usbd_shutdown(struct usbd_context *const uds_ctx)
Shutdown the USB device support.
int usbd_device_set_pid(struct usbd_context *const uds_ctx, const uint16_t pid)
Set USB device descriptor value idProduct.
int usbd_register_class(struct usbd_context *uds_ctx, const char *name, const enum usbd_speed speed, uint8_t cfg)
Register an USB class instance.
int usbd_config_maxpower(struct usbd_context *const uds_ctx, const enum usbd_speed speed, const uint8_t cfg, const uint8_t power)
Setup USB device configuration power consumption.
bool usbd_can_detect_vbus(struct usbd_context *const uds_ctx)
Check that the controller can detect the VBUS state change.
int usbd_add_configuration(struct usbd_context *uds_ctx, const enum usbd_speed speed, struct usbd_config_node *cd)
Add a USB device configuration.
bool usbd_is_suspended(struct usbd_context *uds_ctx)
Checks whether the USB device controller is suspended.
struct net_buf * usbd_ep_buf_alloc(const struct usbd_class_data *const c_data, const uint8_t ep, const size_t size)
Allocate buffer for USB device request.
int usbd_init(struct usbd_context *uds_ctx)
Initialize USB device.
int usbd_device_set_code_triple(struct usbd_context *const uds_ctx, const enum usbd_speed speed, const uint8_t base_class, const uint8_t subclass, const uint8_t protocol)
Set USB device descriptor code triple Base Class, SubClass, and Protocol.
int usbd_ep_buf_free(struct usbd_context *uds_ctx, struct net_buf *buf)
Free USB device request buffer.
int usbd_config_attrib_self(struct usbd_context *const uds_ctx, const enum usbd_speed speed, const uint8_t cfg, const bool enable)
Setup USB device configuration attribute Self-powered.
void usbd_self_powered(struct usbd_context *uds_ctx, const bool status)
Set the self-powered status of the USB device.
bool usbd_ep_is_halted(struct usbd_context *uds_ctx, uint8_t ep)
Checks whether the endpoint is halted.
usbd_ch9_state
USB device support middle layer runtime state.
Definition usbd.h:210
int usbd_ep_ctrl_enqueue(struct usbd_context *const uds_ctx, struct net_buf *const buf)
Queue USB device control request.
int usbd_disable(struct usbd_context *uds_ctx)
Disable the USB device support.
enum usbd_speed usbd_caps_speed(const struct usbd_context *const uds_ctx)
Get highest speed supported by the controller.
int usbd_ep_enqueue(const struct usbd_class_data *const c_data, struct net_buf *const buf)
Queue USB device request.
int usbd_device_register_vreq(struct usbd_context *const uds_ctx, struct usbd_vreq_node *const vreq_nd)
Register an USB vendor request with recipient device.
uint8_t usbd_str_desc_get_idx(const struct usbd_desc_node *const desc_nd)
Get USB string descriptor index from descriptor node.
enum usbd_speed usbd_bus_speed(const struct usbd_context *const uds_ctx)
Get actual device speed.
int usbd_device_set_bcd_usb(struct usbd_context *const uds_ctx, const enum usbd_speed speed, const uint16_t bcd)
Set USB device descriptor value bcdUSB.
#define USBD_NUMOF_INTERFACES_MAX
Definition usbd.h:202
static struct usbd_context * usbd_class_get_ctx(const struct usbd_class_data *const c_data)
Get the USB device runtime context under which the class is registered.
Definition usbd.h:444
int usbd_device_set_bcd_device(struct usbd_context *const uds_ctx, const uint16_t bcd)
Set USB device descriptor value bcdDevice.
@ USBD_SPEED_SS
Device supports or is connected to a super speed bus.
Definition usbd.h:244
@ USBD_SPEED_FS
Device supports or is connected to a full speed bus.
Definition usbd.h:240
@ USBD_SPEED_HS
Device supports or is connected to a high speed bus.
Definition usbd.h:242
@ USBD_STATE_CONFIGURED
Definition usbd.h:213
@ USBD_STATE_DEFAULT
Definition usbd.h:211
@ USBD_STATE_ADDRESS
Definition usbd.h:212
state
Definition parser_state.h:29
Header file for the single-linked list API.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
Kernel mutex structure.
Definition kernel.h:3477
Kernel Spin Lock.
Definition spinlock.h:45
Network buffer representation.
Definition net_buf.h:1015
uint16_t size
Amount of data that this buffer can store.
Definition net_buf.h:1110
USB Setup Data packet.
Definition usb_ch9.h:49
USBD BOS Device Capability descriptor data.
Definition usbd.h:153
enum usbd_bos_desc_utype utype
Descriptor usage type (not bDescriptorType).
Definition usbd.h:155
struct usbd_vreq_node *const vreq_nd
Definition usbd.h:157
Vendor Requests Table.
Definition usbd.h:325
const uint8_t * reqs
Array of vendor requests supported by the class.
Definition usbd.h:327
uint8_t len
Length of the array.
Definition usbd.h:329
USB device support middle layer runtime data.
Definition usbd.h:220
uint8_t configuration
USB device stack selected configuration.
Definition usbd.h:228
uint32_t ep_halt
Halted endpoints bitmap.
Definition usbd.h:226
bool post_status
Post status stage work required, e.g.
Definition usbd.h:230
enum usbd_ch9_state state
Protocol state of the USB device stack.
Definition usbd.h:224
struct usb_setup_packet setup
Setup packet, up-to-date for the respective control request.
Definition usbd.h:222
uint8_t alternate[16U]
Array to track interfaces alternate settings.
Definition usbd.h:232
USB device support class instance API.
Definition usbd.h:340
void(* feature_halt)(struct usbd_class_data *const c_data, uint8_t ep, bool halted)
Feature halt state update handler.
Definition usbd.h:342
void(* update)(struct usbd_class_data *const c_data, uint8_t iface, uint8_t alternate)
Configuration update handler.
Definition usbd.h:346
void(* sof)(struct usbd_class_data *const c_data)
Start of Frame.
Definition usbd.h:370
void(* suspended)(struct usbd_class_data *const c_data)
USB power management handler suspended.
Definition usbd.h:364
void(* shutdown)(struct usbd_class_data *const c_data)
Shutdown of the class implementation.
Definition usbd.h:382
int(* request)(struct usbd_class_data *const c_data, struct net_buf *buf, int err)
Endpoint request completion event handler.
Definition usbd.h:360
int(* init)(struct usbd_class_data *const c_data)
Initialization of the class implementation.
Definition usbd.h:379
int(* control_to_dev)(struct usbd_class_data *const c_data, const struct usb_setup_packet *const setup, const struct net_buf *const buf)
USB control request handler to device.
Definition usbd.h:350
void(* enable)(struct usbd_class_data *const c_data)
Class associated configuration is selected.
Definition usbd.h:373
int(* control_to_host)(struct usbd_class_data *const c_data, const struct usb_setup_packet *const setup, struct net_buf *const buf)
USB control request handler to host.
Definition usbd.h:355
void(* resumed)(struct usbd_class_data *const c_data)
USB power management handler resumed.
Definition usbd.h:367
void(* disable)(struct usbd_class_data *const c_data)
Class associated configuration is disabled.
Definition usbd.h:376
USB device support class data.
Definition usbd.h:392
void * priv
Pointer to private data.
Definition usbd.h:402
struct usbd_context * uds_ctx
Pointer to USB device stack context structure.
Definition usbd.h:396
const struct usbd_cctx_vendor_req * v_reqs
Supported vendor request table, can be NULL.
Definition usbd.h:400
const struct usbd_class_api * api
Pointer to device support class API.
Definition usbd.h:398
const char * name
Name of the USB device class instance.
Definition usbd.h:394
Device configuration node.
Definition usbd.h:190
sys_snode_t node
slist node struct
Definition usbd.h:192
sys_slist_t class_list
List of registered classes (functions).
Definition usbd.h:198
struct usbd_desc_node * str_desc_nd
Optional pointer to string descriptor node.
Definition usbd.h:196
void * desc
Pointer to configuration descriptor.
Definition usbd.h:194
USB device support runtime context.
Definition usbd.h:289
void * fs_desc
Pointer to Full-Speed device descriptor.
Definition usbd.h:315
void * hs_desc
Pointer to High-Speed device descriptor.
Definition usbd.h:317
usbd_msg_cb_t msg_cb
Notification message recipient callback.
Definition usbd.h:297
struct usbd_status status
Status of the USB device support.
Definition usbd.h:313
sys_slist_t hs_configs
slist to manage High-Speed device configurations
Definition usbd.h:309
struct usbd_ch9_data ch9_data
Middle layer runtime data.
Definition usbd.h:303
const struct device * dev
Pointer to UDC device.
Definition usbd.h:295
sys_dlist_t vreqs
dlist to manage vendor requests with recipient device
Definition usbd.h:311
sys_slist_t ep_events
slist to keep endpoint events
Definition usbd.h:299
sys_slist_t fs_configs
slist to manage Full-Speed device configurations
Definition usbd.h:307
struct k_mutex mutex
Access mutex.
Definition usbd.h:293
const char * name
Name of the USB device.
Definition usbd.h:291
sys_dlist_t descriptors
slist to manage descriptors like string, BOS
Definition usbd.h:305
struct k_spinlock ep_event_lock
Endpoint event list spinlock.
Definition usbd.h:301
struct net_buf * setup_buf
Pre-allocated buffer for control transfer SETUP stage.
Definition usbd.h:319
Descriptor node.
Definition usbd.h:167
uint8_t bDescriptorType
Descriptor type.
Definition usbd.h:179
sys_dnode_t node
slist node struct
Definition usbd.h:169
const void *const ptr
Opaque pointer to a descriptor payload.
Definition usbd.h:175
uint8_t bLength
Descriptor size in bytes.
Definition usbd.h:177
struct usbd_str_desc_data str
Definition usbd.h:171
struct usbd_bos_desc_data bos
Definition usbd.h:172
USB device message.
Definition usbd_msg.h:88
USB device support status.
Definition usbd.h:250
unsigned int rwup
USB remote wake-up feature is enabled.
Definition usbd.h:258
unsigned int enabled
USB device support is enabled.
Definition usbd.h:254
enum usbd_speed speed
USB device speed.
Definition usbd.h:262
unsigned int initialized
USB device support is initialized.
Definition usbd.h:252
unsigned int self_powered
USB device is self-powered.
Definition usbd.h:260
unsigned int suspended
USB device is suspended.
Definition usbd.h:256
Used internally to keep descriptors in order.
Definition usbd.h:81
uint8_t idx
Descriptor index, required for string descriptors.
Definition usbd.h:83
enum usbd_str_desc_utype utype
Descriptor usage type (not bDescriptorType).
Definition usbd.h:85
unsigned int use_hwinfo
Device stack obtains SerialNumber using the HWINFO API.
Definition usbd.h:89
unsigned int ascii7
The string descriptor is in ASCII7 format.
Definition usbd.h:87
USBD vendor request node.
Definition usbd.h:125
sys_dnode_t node
Node information for the dlist.
Definition usbd.h:127
const uint8_t code
Vendor code (bRequest value).
Definition usbd.h:129
int(* to_host)(const struct usbd_context *const ctx, const struct usb_setup_packet *const setup, struct net_buf *const buf)
Vendor request callback for device-to-host direction.
Definition usbd.h:131
int(* to_dev)(const struct usbd_context *const ctx, const struct usb_setup_packet *const setup, const struct net_buf *const buf)
Vendor request callback for host-to-device direction.
Definition usbd.h:145
Byte order helpers.
Iterable sections helpers.
Buffers for USB device support.
USB Chapter 9 structures and definitions.
USB support message types and structure.