1 /*
2 * Copyright (c) 2022 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7 #ifndef ZEPHYR_INCLUDE_USBD_CH9_H
8 #define ZEPHYR_INCLUDE_USBD_CH9_H
9
10 #include <zephyr/usb/usbd.h>
11
12 /**
13 * @brief Check whether USB device is in default state.
14 *
15 * @param[in] node Pointer to a device context
16 *
17 * @return true if USB device is in default state, false otherwise
18 */
usbd_state_is_default(const struct usbd_context * const uds_ctx)19 static inline bool usbd_state_is_default(const struct usbd_context *const uds_ctx)
20 {
21 return (uds_ctx->ch9_data.state == USBD_STATE_DEFAULT) ? true : false;
22 }
23
24 /**
25 * @brief Check whether USB device is in address state.
26 *
27 * @param[in] node Pointer to a device context
28 *
29 * @return true if USB device is in address state, false otherwise
30 */
usbd_state_is_address(const struct usbd_context * const uds_ctx)31 static inline bool usbd_state_is_address(const struct usbd_context *const uds_ctx)
32 {
33 return (uds_ctx->ch9_data.state == USBD_STATE_ADDRESS) ? true : false;
34 }
35
36 /**
37 * @brief Check whether USB device is in configured state.
38 *
39 * @param[in] node Pointer to a device context
40 *
41 * @return true if USB device is in configured state, false otherwise
42 */
usbd_state_is_configured(const struct usbd_context * const uds_ctx)43 static inline bool usbd_state_is_configured(const struct usbd_context *const uds_ctx)
44 {
45 return (uds_ctx->ch9_data.state == USBD_STATE_CONFIGURED) ? true : false;
46 }
47
48 /**
49 * @brief Get current configuration value
50 *
51 * @param[in] uds_ctx Pointer to a device context
52 *
53 * @return current configuration value
54 */
usbd_get_config_value(const struct usbd_context * const uds_ctx)55 static inline uint8_t usbd_get_config_value(const struct usbd_context *const uds_ctx)
56 {
57 return uds_ctx->ch9_data.configuration;
58 }
59
60 /**
61 * @brief Set current configuration value
62 *
63 * @param[in] uds_ctx Pointer to a device context
64 * @param[in] value New configuration value
65 */
usbd_set_config_value(struct usbd_context * const uds_ctx,const uint8_t value)66 static inline void usbd_set_config_value(struct usbd_context *const uds_ctx,
67 const uint8_t value)
68 {
69 uds_ctx->ch9_data.configuration = value;
70 }
71
72 /**
73 * @brief Get interface alternate value
74 *
75 * @param[in] uds_ctx Pointer to a device context
76 * @param[in] iface Interface number
77 * @param[out] alt Alternate value
78 *
79 * @return 0 on success, other values on fail.
80 */
usbd_get_alt_value(const struct usbd_context * const uds_ctx,const uint8_t iface,uint8_t * const alt)81 static inline int usbd_get_alt_value(const struct usbd_context *const uds_ctx,
82 const uint8_t iface,
83 uint8_t *const alt)
84 {
85 if (iface >= USBD_NUMOF_INTERFACES_MAX) {
86 return -ENOENT;
87 }
88
89 *alt = uds_ctx->ch9_data.alternate[iface];
90
91 return 0;
92 }
93
94 /**
95 * @brief Set interface alternate value
96 *
97 * @param[in] uds_ctx Pointer to a device context
98 * @param[in] iface Interface number
99 * @param[out] alt Alternate value
100 *
101 * @return 0 on success, other values on fail.
102 */
usbd_set_alt_value(struct usbd_context * const uds_ctx,const uint8_t iface,const uint8_t alt)103 static inline int usbd_set_alt_value(struct usbd_context *const uds_ctx,
104 const uint8_t iface,
105 const uint8_t alt)
106 {
107 if (iface >= USBD_NUMOF_INTERFACES_MAX) {
108 return -ENOENT;
109 }
110
111 uds_ctx->ch9_data.alternate[iface] = alt;
112
113 return 0;
114 }
115
116 /**
117 * @brief Get pointer to last received setup packet
118 *
119 * @param[in] uds_ctx Pointer to a device context
120 *
121 * @return Pointer to last received setup packet
122 */
123 static inline struct usb_setup_packet *
usbd_get_setup_pkt(struct usbd_context * const uds_ctx)124 usbd_get_setup_pkt(struct usbd_context *const uds_ctx)
125 {
126 return &uds_ctx->ch9_data.setup;
127 }
128
129 /**
130 * @brief Handle control endpoint transfer result
131 *
132 * @param[in] uds_ctx Pointer to a device context
133 * @param[in] buf Pointer to UDC request buffer
134 * @param[in] err Transfer status
135 *
136 * @return 0 on success, other values on fail.
137 */
138 int usbd_handle_ctrl_xfer(struct usbd_context *uds_ctx,
139 struct net_buf *buf, int err);
140
141 /**
142 * @brief Initialize control pipe to default values
143 *
144 * @param[in] uds_ctx Pointer to a device context
145 *
146 * @return 0 on success, other values on fail.
147 */
148 int usbd_init_control_pipe(struct usbd_context *uds_ctx);
149
150
151 #endif /* ZEPHYR_INCLUDE_USBD_CH9_H */
152