2018-08-23 14:41:11 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 Koen Zandberg <koen@bergzand.net>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @defgroup usb USB
|
|
|
|
* @ingroup sys
|
|
|
|
* @brief Configuration defines for USB peripheral devices.
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Definition of global compile time configuration options
|
|
|
|
*
|
|
|
|
* @author Koen Zandberg <koen@bergzand.net>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef USB_H
|
|
|
|
#define USB_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-04-14 23:55:53 +02:00
|
|
|
#include "board.h"
|
|
|
|
|
2019-12-04 15:09:56 +01:00
|
|
|
/**
|
|
|
|
* @defgroup usb_conf USB peripheral compile time configurations
|
|
|
|
* @ingroup config
|
|
|
|
* @{
|
|
|
|
*/
|
2020-01-16 19:05:49 +01:00
|
|
|
|
2020-04-14 23:55:53 +02:00
|
|
|
/* These can be overridden by boards that should come up with their board
|
|
|
|
* supplier VID/PID pair. Boards should only override this if the RIOT built-in
|
|
|
|
* peripherals are compatible with whatever is usually shipped with that pair
|
|
|
|
* */
|
|
|
|
#ifndef INTERNAL_PERIPHERAL_VID
|
|
|
|
/** Reserved for RIOT standard peripherals as per http://pid.codes/1209/7D00/ */
|
|
|
|
#define INTERNAL_PERIPHERAL_VID (0x1209)
|
|
|
|
#endif
|
|
|
|
#ifndef INTERNAL_PERIPHERAL_PID
|
|
|
|
/** Reserved for RIOT standard peripherals as per http://pid.codes/1209/7D00/ */
|
|
|
|
#define INTERNAL_PERIPHERAL_PID (0x7D00)
|
|
|
|
#endif
|
|
|
|
|
2020-01-16 19:05:49 +01:00
|
|
|
#if !(defined(CONFIG_USB_VID) && defined(CONFIG_USB_PID))
|
|
|
|
#ifdef USB_H_USER_IS_RIOT_INTERNAL
|
2020-04-14 23:55:53 +02:00
|
|
|
#define CONFIG_USB_VID INTERNAL_PERIPHERAL_VID
|
|
|
|
#define CONFIG_USB_PID INTERNAL_PERIPHERAL_PID
|
2020-01-16 19:05:49 +01:00
|
|
|
#else
|
|
|
|
#error Please configure your vendor and product IDs. For development, you may \
|
2020-02-14 13:59:31 +01:00
|
|
|
set USB_VID=${USB_VID_TESTING} USB_PID=${USB_PID_TESTING}.
|
2020-01-16 19:05:49 +01:00
|
|
|
#endif
|
2023-04-06 09:18:29 +02:00
|
|
|
#else
|
|
|
|
#if CONFIG_USB_VID == INTERNAL_PERIPHERAL_VID && \
|
|
|
|
CONFIG_USB_PID == INTERNAL_PERIPHERAL_PID
|
|
|
|
#error Please configure your vendor and product IDs differently than the \
|
|
|
|
INTERNAL_PERIPHERAL_* settings. For development, you may set \
|
|
|
|
USB_VID=${USB_VID_TESTING} \
|
|
|
|
USB_PID=${USB_PID_TESTING}.
|
2020-01-16 19:05:49 +01:00
|
|
|
#endif
|
2023-04-06 09:18:29 +02:00
|
|
|
#endif /* !(defined(CONFIG_USB_VID) && defined(CONFIG_USB_PID)) */
|
2020-01-16 19:05:49 +01:00
|
|
|
|
2018-08-23 14:41:11 +02:00
|
|
|
/**
|
|
|
|
* @brief USB peripheral device vendor ID
|
2019-12-04 15:04:11 +01:00
|
|
|
*
|
|
|
|
* @note You must provide your own VID/PID combination when manufacturing a
|
|
|
|
* device with USB.
|
2018-08-23 14:41:11 +02:00
|
|
|
*/
|
2019-12-04 15:04:11 +01:00
|
|
|
#ifdef DOXYGEN
|
2019-12-05 13:17:30 +01:00
|
|
|
#define CONFIG_USB_VID
|
2019-12-04 15:04:11 +01:00
|
|
|
#endif
|
2018-08-23 14:41:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB peripheral device product ID
|
|
|
|
*
|
2019-12-04 15:04:11 +01:00
|
|
|
* @note You must provide your own VID/PID combination when manufacturing a
|
|
|
|
* device with USB.
|
2018-08-23 14:41:11 +02:00
|
|
|
*/
|
2019-12-04 15:04:11 +01:00
|
|
|
#ifdef DOXYGEN
|
2019-12-05 13:17:30 +01:00
|
|
|
#define CONFIG_USB_PID
|
2019-12-04 15:04:11 +01:00
|
|
|
#endif
|
2018-08-23 14:41:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB peripheral manufacturer string
|
|
|
|
*/
|
2019-12-05 13:17:30 +01:00
|
|
|
#ifndef CONFIG_USB_MANUF_STR
|
|
|
|
#define CONFIG_USB_MANUF_STR "RIOT-os.org"
|
2018-08-23 14:41:11 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB peripheral product string
|
|
|
|
*/
|
2019-12-05 13:17:30 +01:00
|
|
|
#ifndef CONFIG_USB_PRODUCT_STR
|
2022-08-29 16:39:05 +02:00
|
|
|
#define CONFIG_USB_PRODUCT_STR RIOT_BOARD
|
2018-08-23 14:41:11 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB peripheral configuration string
|
|
|
|
*/
|
2019-12-05 13:17:30 +01:00
|
|
|
#ifndef CONFIG_USB_CONFIGURATION_STR
|
|
|
|
#define CONFIG_USB_CONFIGURATION_STR "USB config"
|
2018-08-23 14:41:11 +02:00
|
|
|
#endif
|
|
|
|
|
2020-12-16 17:22:30 +01:00
|
|
|
/**
|
|
|
|
* @brief USB peripheral serial string
|
|
|
|
*
|
|
|
|
* Compile-time value to override the serial string with. An LUID-based hex
|
|
|
|
* string is generated when this value is not used.
|
|
|
|
*
|
|
|
|
* This string does not have to be a number, but it must be unique between
|
|
|
|
* devices with identical VID:PID combination.
|
|
|
|
*/
|
|
|
|
#ifdef DOXYGEN
|
|
|
|
#define CONFIG_USB_SERIAL_STR "RIOT-12345"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB peripheral serial string length
|
|
|
|
*
|
|
|
|
* Maximum value is 63. Sensible values are between 8 to 32 depending on the
|
|
|
|
* number of expected devices.
|
|
|
|
*
|
|
|
|
* The length here is in bytes. The generated hex string is twice as many chars
|
|
|
|
* in length due to conversion from bytes to hex chars.
|
|
|
|
*/
|
|
|
|
#if !defined(CONFIG_USB_SERIAL_STR) && !defined(CONFIG_USB_SERIAL_BYTE_LENGTH)
|
|
|
|
#define CONFIG_USB_SERIAL_BYTE_LENGTH 8
|
|
|
|
#endif
|
|
|
|
|
2018-08-23 14:41:11 +02:00
|
|
|
/**
|
|
|
|
* @brief USB peripheral device version
|
|
|
|
*
|
|
|
|
* This is the version number of this peripheral
|
|
|
|
* @note Not to be be confused with the USB version number
|
|
|
|
*/
|
2019-12-05 13:17:30 +01:00
|
|
|
#ifndef CONFIG_USB_PRODUCT_BCDVERSION
|
|
|
|
#define CONFIG_USB_PRODUCT_BCDVERSION 0x0100
|
2019-01-31 22:41:20 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB specification version
|
|
|
|
*/
|
2019-12-05 13:17:30 +01:00
|
|
|
#ifndef CONFIG_USB_SPEC_BCDVERSION
|
2019-12-05 13:22:36 +01:00
|
|
|
#if defined(CONFIG_USB_SPEC_BCDVERSION_1_1)
|
|
|
|
#define CONFIG_USB_SPEC_BCDVERSION 0x0110
|
|
|
|
#elif defined(CONFIG_USB_SPEC_BCDVERSION_2_0)
|
2019-12-05 13:17:30 +01:00
|
|
|
#define CONFIG_USB_SPEC_BCDVERSION 0x0200
|
2019-12-05 13:22:36 +01:00
|
|
|
#else
|
|
|
|
#define CONFIG_USB_SPEC_BCDVERSION 0x0200
|
|
|
|
#endif
|
2018-08-23 14:41:11 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB peripheral setting to indicate self powered devices.
|
|
|
|
*/
|
2019-12-05 13:17:30 +01:00
|
|
|
#ifndef CONFIG_USB_SELF_POWERED
|
|
|
|
#define CONFIG_USB_SELF_POWERED (0)
|
2018-08-23 14:41:11 +02:00
|
|
|
#endif
|
|
|
|
|
2021-11-22 21:34:32 +01:00
|
|
|
/**
|
|
|
|
* @brief USB peripheral setting to indicate remote wakeup capability.
|
|
|
|
*/
|
|
|
|
#ifndef CONFIG_USB_REM_WAKEUP
|
|
|
|
#define CONFIG_USB_REM_WAKEUP (0)
|
|
|
|
#endif
|
|
|
|
|
2018-08-23 14:41:11 +02:00
|
|
|
/**
|
|
|
|
* @brief USB device max power draw in mA, between 0 and 500mA
|
|
|
|
*/
|
2019-12-05 13:17:30 +01:00
|
|
|
#ifndef CONFIG_USB_MAX_POWER
|
|
|
|
#define CONFIG_USB_MAX_POWER (100)
|
2018-08-23 14:41:11 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default LANG ID reported to the host
|
|
|
|
*/
|
2019-12-05 13:17:30 +01:00
|
|
|
#ifndef CONFIG_USB_DEFAULT_LANGID
|
|
|
|
#define CONFIG_USB_DEFAULT_LANGID 0x0409 /* EN-US */
|
2018-08-23 14:41:11 +02:00
|
|
|
#endif
|
2019-12-04 15:09:56 +01:00
|
|
|
/** @} */
|
2020-01-16 18:55:56 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief RIOT-internal USB peripheral clearance indicator
|
|
|
|
*
|
2020-01-16 19:05:49 +01:00
|
|
|
* This define must only be set in compilation units that are RIOT internal,
|
|
|
|
* and only when they implement peripherals that can be considered default RIOT
|
|
|
|
* peripherals.
|
|
|
|
*
|
2020-01-16 18:55:56 +01:00
|
|
|
* When this is defined in all uses of `usb.h`, the board can use the
|
|
|
|
* 0x1209/0x7D00 VID/PID pair unless explicit configuration using @ref
|
|
|
|
* CONFIG_USB_VID and @ref CONFIG_USB_PID say otherwise.
|
|
|
|
*
|
2020-01-16 19:32:43 +01:00
|
|
|
* There is no sharp characterization of what consititutes an internal
|
|
|
|
* peripheral; a good check is this: If an application can, just by switching
|
|
|
|
* between boards, can have a feature provided by either RIOT's USB stack or a
|
|
|
|
* different mechanism, the USB version is a default RIOT peripheral.
|
|
|
|
*
|
|
|
|
* Examples are stdio access (is provided by most boards using a UART and an
|
|
|
|
* external USB UART adapter), Ethernet (is provided by other boards using
|
|
|
|
* ethos) and firmware upload and reset (is provided by other boards using an
|
|
|
|
* on-board programmer).
|
|
|
|
*
|
2020-01-16 18:55:56 +01:00
|
|
|
* See http://pid.codes/1209/7D00/ for the allocation of that code.
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#ifdef DOXYGEN
|
|
|
|
#define USB_H_USER_IS_RIOT_INTERNAL
|
|
|
|
#endif
|
|
|
|
/** @} */
|
2018-08-23 14:41:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB version definitions
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
USB_VERSION_1x, /* USB 1.0 or 1.1 device */
|
|
|
|
USB_VERSION_20, /* USB 2.0 device */
|
|
|
|
} usb_version_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB speed definitions
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
USB_SPEED_LOW, /* Low speed (1.5Mbit/s) */
|
|
|
|
USB_SPEED_FULL, /* Full speed (12Mbit/s) */
|
|
|
|
USB_SPEED_HIGH, /* High speed (480Mbit/s) */
|
|
|
|
} usb_speed_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB endpoint types
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
USB_EP_TYPE_NONE = 0, /**< Unused endpoint */
|
|
|
|
USB_EP_TYPE_CONTROL, /**< Control type */
|
|
|
|
USB_EP_TYPE_INTERRUPT, /**< Interrupt type */
|
|
|
|
USB_EP_TYPE_BULK, /**< Bulk type */
|
|
|
|
USB_EP_TYPE_ISOCHRONOUS, /**< Isochronous type */
|
|
|
|
} usb_ep_type_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief USB endpoint directions
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
USB_EP_DIR_OUT, /**< Host out, device in */
|
|
|
|
USB_EP_DIR_IN, /**< Host in, device out */
|
|
|
|
} usb_ep_dir_t;
|
|
|
|
|
2023-03-31 14:28:12 +02:00
|
|
|
/**
|
|
|
|
* @brief Maximum transfer size for interrupt endpoints at full speed
|
|
|
|
*/
|
|
|
|
#define USB_ENDPOINT_INTERRUPT_FS_MAX_SIZE (64)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum transfer size for interrupt endpoints at high speed
|
|
|
|
*/
|
|
|
|
#define USB_ENDPOINT_INTERRUPT_HS_MAX_SIZE (1024)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum transfer size for bulk endpoints at full speed
|
|
|
|
*/
|
|
|
|
#define USB_ENDPOINT_BULK_FS_MAX_SIZE (64)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum transfer size for bulk endpoints at high speed
|
|
|
|
*/
|
|
|
|
#define USB_ENDPOINT_BULK_HS_MAX_SIZE (512)
|
|
|
|
|
2018-08-23 14:41:11 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* USB_H */
|
|
|
|
/** @} */
|