2019-01-31 22:44:12 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 Koen Zandberg
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup usb_usbus
|
|
|
|
* @brief USBUS control endpoint module
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief USBUS control endpoint module interface
|
|
|
|
*
|
|
|
|
* @author Koen Zandberg <koen@bergzand.net>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef USB_USBUS_CONTROL_H
|
|
|
|
#define USB_USBUS_CONTROL_H
|
|
|
|
|
|
|
|
#include "usb/usbus.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief helper struct to divide control messages in multiple parts
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
size_t start; /**< Start offset of the current part */
|
|
|
|
size_t cur; /**< Current position in the message */
|
|
|
|
size_t len; /**< Length of the full message */
|
2019-10-23 21:16:22 +02:00
|
|
|
size_t transferred; /**< Number of bytes transferred */
|
2019-01-31 22:44:12 +01:00
|
|
|
size_t reqlen; /**< Maximum length of the request */
|
|
|
|
} usbus_control_slicer_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Endpoint zero event handler
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2019-09-11 21:21:32 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief inherited generic handler
|
|
|
|
*/
|
|
|
|
usbus_handler_t handler;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Last received setup packet
|
|
|
|
*/
|
|
|
|
usb_setup_t setup;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Control request state machine state
|
|
|
|
*/
|
|
|
|
usbus_control_request_state_t control_request_state;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Slicer state for multipart control request messages
|
|
|
|
*/
|
|
|
|
usbus_control_slicer_t slicer;
|
|
|
|
|
2019-09-17 19:48:09 +02:00
|
|
|
/**
|
|
|
|
* @brief Received bytes for set requests
|
|
|
|
*/
|
|
|
|
size_t received_len;
|
|
|
|
|
2019-09-11 21:21:32 +02:00
|
|
|
/**
|
|
|
|
* @brief EP0 OUT endpoint
|
|
|
|
*/
|
|
|
|
usbdev_ep_t *out;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief EP0 IN endpoint
|
|
|
|
*/
|
|
|
|
usbdev_ep_t *in;
|
2019-01-31 22:44:12 +01:00
|
|
|
} usbus_control_handler_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize the control endpoint handler
|
|
|
|
*
|
|
|
|
* @param[in] usbus USBUS context
|
|
|
|
* @param[in] handler control handler to initialize
|
|
|
|
*/
|
|
|
|
void usbus_control_init(usbus_t *usbus, usbus_control_handler_t *handler);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Helper function for adding bytes to the current control message part
|
|
|
|
*
|
|
|
|
* @param[in] usbus USBUS context
|
|
|
|
* @param[in] buf Buffer to add bytes from
|
|
|
|
* @param[in] len Length of @p buf
|
|
|
|
*
|
|
|
|
* @return Actual number of bytes written
|
|
|
|
*/
|
|
|
|
size_t usbus_control_slicer_put_bytes(usbus_t *usbus, const uint8_t *buf,
|
|
|
|
size_t len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Helper function for adding single bytes to the current control
|
|
|
|
* message part
|
|
|
|
*
|
|
|
|
* @param[in] usbus USBUS context
|
|
|
|
* @param[in] c byte to add
|
|
|
|
*
|
|
|
|
* @return Actual number of bytes written
|
|
|
|
*/
|
|
|
|
size_t usbus_control_slicer_put_char(usbus_t *usbus, char c);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Helper function to signal the end of the control message
|
|
|
|
*
|
|
|
|
* @param[in] usbus USBUS context
|
|
|
|
*/
|
|
|
|
void usbus_control_slicer_ready(usbus_t *usbus);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize the next slice of the control message
|
|
|
|
*
|
|
|
|
* @param[in] usbus USBUS context
|
|
|
|
*
|
|
|
|
* @return 1 when there is a next slice
|
2019-10-23 10:40:02 +02:00
|
|
|
* @return 0 when the data is fully transferred
|
2019-01-31 22:44:12 +01:00
|
|
|
*/
|
|
|
|
int usbus_control_slicer_nextslice(usbus_t *usbus);
|
|
|
|
|
2019-09-17 19:48:09 +02:00
|
|
|
/**
|
|
|
|
* @brief Retrieve the data from the OUT pipe of the control endpoint
|
|
|
|
*
|
|
|
|
* @pre usbus->state == USBUS_CONTROL_REQUEST_STATE_OUTDATA
|
|
|
|
*
|
|
|
|
* @param[in] usbus USBUS context
|
|
|
|
* @param[out] len Length of the data part
|
|
|
|
*
|
|
|
|
* @return pointer to the data buffer
|
|
|
|
*/
|
|
|
|
uint8_t *usbus_control_get_out_data(usbus_t *usbus, size_t *len);
|
|
|
|
|
2019-01-31 22:44:12 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* USB_USBUS_CONTROL_H */
|
|
|
|
/** @} */
|