Normalize line endings
This commit is contained in:
		| @@ -1,275 +1,275 @@ | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common | ||||
|  *  \defgroup Group_CommonH common.h | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_COMMON_H_ | ||||
| #define _TUSB_COMMON_H_ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Macros Helper | ||||
| //--------------------------------------------------------------------+ | ||||
| #define TU_ARRAY_SIZE(_arr)   ( sizeof(_arr) / sizeof(_arr[0]) ) | ||||
| #define TU_MIN(_x, _y)        ( ( (_x) < (_y) ) ? (_x) : (_y) ) | ||||
| #define TU_MAX(_x, _y)        ( ( (_x) > (_y) ) ? (_x) : (_y) ) | ||||
|  | ||||
| #define TU_U16_HIGH(u16)      ((uint8_t) (((u16) >> 8) & 0x00ff)) | ||||
| #define TU_U16_LOW(u16)       ((uint8_t) ((u16)       & 0x00ff)) | ||||
| #define U16_TO_U8S_BE(u16)    TU_U16_HIGH(u16), TU_U16_LOW(u16) | ||||
| #define U16_TO_U8S_LE(u16)    TU_U16_LOW(u16), TU_U16_HIGH(u16) | ||||
|  | ||||
| #define U32_B1_U8(u32)        ((uint8_t) (((u32) >> 24) & 0x000000ff)) // MSB | ||||
| #define U32_B2_U8(u32)        ((uint8_t) (((u32) >> 16) & 0x000000ff)) | ||||
| #define U32_B3_U8(u32)        ((uint8_t) (((u32) >>  8) & 0x000000ff)) | ||||
| #define U32_B4_U8(u32)        ((uint8_t) ((u32)         & 0x000000ff)) // LSB | ||||
|  | ||||
| #define U32_TO_U8S_BE(u32)    U32_B1_U8(u32), U32_B2_U8(u32), U32_B3_U8(u32), U32_B4_U8(u32) | ||||
| #define U32_TO_U8S_LE(u32)    U32_B4_U8(u32), U32_B3_U8(u32), U32_B2_U8(u32), U32_B1_U8(u32) | ||||
|  | ||||
| #define TU_BIT(n)             (1U << (n)) | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Includes | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // Standard Headers | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include <stddef.h> | ||||
| #include <string.h> | ||||
| #include <stdio.h> | ||||
|  | ||||
| // Tinyusb Common Headers | ||||
| #include "tusb_option.h" | ||||
| #include "tusb_compiler.h" | ||||
| #include "tusb_verify.h" | ||||
| #include "tusb_error.h" // TODO remove | ||||
| #include "tusb_timeout.h" | ||||
| #include "tusb_types.h" | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Inline Functions | ||||
| //--------------------------------------------------------------------+ | ||||
| #define tu_memclr(buffer, size)  memset((buffer), 0, (size)) | ||||
| #define tu_varclr(_var)          tu_memclr(_var, sizeof(*(_var))) | ||||
|  | ||||
| static inline uint32_t tu_u32(uint8_t b1, uint8_t b2, uint8_t b3, uint8_t b4) | ||||
| { | ||||
|   return ( ((uint32_t) b1) << 24) + ( ((uint32_t) b2) << 16) + ( ((uint32_t) b3) << 8) + b4; | ||||
| } | ||||
|  | ||||
| static inline uint16_t tu_u16(uint8_t high, uint8_t low) | ||||
| { | ||||
|   return (uint16_t)((((uint16_t) high) << 8) + low); | ||||
| } | ||||
|  | ||||
| static inline uint8_t tu_u16_high(uint16_t u16) { return (uint8_t) (((uint16_t) (u16 >> 8)) & 0x00ff); } | ||||
| static inline uint8_t tu_u16_low (uint16_t u16) { return (uint8_t) (u16 & 0x00ff); } | ||||
|  | ||||
| // Min | ||||
| static inline uint8_t  tu_min8  (uint8_t  x, uint8_t y ) { return (x < y) ? x : y; } | ||||
| static inline uint16_t tu_min16 (uint16_t x, uint16_t y) { return (x < y) ? x : y; } | ||||
| static inline uint32_t tu_min32 (uint32_t x, uint32_t y) { return (x < y) ? x : y; } | ||||
|  | ||||
| // Max | ||||
| static inline uint8_t  tu_max8  (uint8_t  x, uint8_t y ) { return (x > y) ? x : y; } | ||||
| static inline uint16_t tu_max16 (uint16_t x, uint16_t y) { return (x > y) ? x : y; } | ||||
| static inline uint32_t tu_max32 (uint32_t x, uint32_t y) { return (x > y) ? x : y; } | ||||
|  | ||||
| // Align | ||||
| static inline uint32_t tu_align_n(uint32_t value, uint32_t alignment) | ||||
| { | ||||
|   return value & ((uint32_t) ~(alignment-1)); | ||||
| } | ||||
|  | ||||
| static inline uint32_t tu_align32 (uint32_t value) { return (value & 0xFFFFFFE0UL); } | ||||
| static inline uint32_t tu_align16 (uint32_t value) { return (value & 0xFFFFFFF0UL); } | ||||
| static inline uint32_t tu_align4k (uint32_t value) { return (value & 0xFFFFF000UL); } | ||||
| static inline uint32_t tu_offset4k(uint32_t value) { return (value & 0xFFFUL); } | ||||
|  | ||||
| //------------- Mathematics -------------// | ||||
| static inline uint32_t tu_abs(int32_t value) { return (uint32_t)((value < 0) ? (-value) : value); } | ||||
|  | ||||
| /// inclusive range checking | ||||
| static inline bool tu_within(uint32_t lower, uint32_t value, uint32_t upper) | ||||
| { | ||||
|   return (lower <= value) && (value <= upper); | ||||
| } | ||||
|  | ||||
| // log2 of a value is its MSB's position | ||||
| // TODO use clz TODO remove | ||||
| static inline uint8_t tu_log2(uint32_t value) | ||||
| { | ||||
|   uint8_t result = 0; | ||||
|  | ||||
|   while (value >>= 1) | ||||
|   { | ||||
|     result++; | ||||
|   } | ||||
|   return result; | ||||
| } | ||||
|  | ||||
| // Bit | ||||
| static inline uint32_t tu_bit_set  (uint32_t value, uint8_t pos) { return value | TU_BIT(pos);                  } | ||||
| static inline uint32_t tu_bit_clear(uint32_t value, uint8_t pos) { return value & (~TU_BIT(pos));               } | ||||
| static inline bool     tu_bit_test (uint32_t value, uint8_t pos) { return (value & TU_BIT(pos)) ? true : false; } | ||||
|  | ||||
| /*------------------------------------------------------------------*/ | ||||
| /* Count number of arguments of __VA_ARGS__ | ||||
|  * - reference https://groups.google.com/forum/#!topic/comp.std.c/d-6Mj5Lko_s | ||||
|  * - _GET_NTH_ARG() takes args >= N (64) but only expand to Nth one (64th) | ||||
|  * - _RSEQ_N() is reverse sequential to N to add padding to have | ||||
|  * Nth position is the same as the number of arguments | ||||
|  * - ##__VA_ARGS__ is used to deal with 0 paramerter (swallows comma) | ||||
|  *------------------------------------------------------------------*/ | ||||
| #ifndef TU_ARGS_NUM | ||||
|  | ||||
| #define TU_ARGS_NUM(...) 	 NARG_(_0, ##__VA_ARGS__,_RSEQ_N()) | ||||
|  | ||||
| #define NARG_(...)        _GET_NTH_ARG(__VA_ARGS__) | ||||
| #define _GET_NTH_ARG( \ | ||||
|           _1, _2, _3, _4, _5, _6, _7, _8, _9,_10, \ | ||||
|          _11,_12,_13,_14,_15,_16,_17,_18,_19,_20, \ | ||||
|          _21,_22,_23,_24,_25,_26,_27,_28,_29,_30, \ | ||||
|          _31,_32,_33,_34,_35,_36,_37,_38,_39,_40, \ | ||||
|          _41,_42,_43,_44,_45,_46,_47,_48,_49,_50, \ | ||||
|          _51,_52,_53,_54,_55,_56,_57,_58,_59,_60, \ | ||||
|          _61,_62,_63,N,...) N | ||||
| #define _RSEQ_N() \ | ||||
|          62,61,60,                      \ | ||||
|          59,58,57,56,55,54,53,52,51,50, \ | ||||
|          49,48,47,46,45,44,43,42,41,40, \ | ||||
|          39,38,37,36,35,34,33,32,31,30, \ | ||||
|          29,28,27,26,25,24,23,22,21,20, \ | ||||
|          19,18,17,16,15,14,13,12,11,10, \ | ||||
|          9,8,7,6,5,4,3,2,1,0 | ||||
| #endif | ||||
|  | ||||
| // To be removed | ||||
| //------------- Binary constant -------------// | ||||
| #if defined(__GNUC__) && !defined(__CC_ARM) | ||||
|  | ||||
| #define TU_BIN8(x)               ((uint8_t)  (0b##x)) | ||||
| #define TU_BIN16(b1, b2)         ((uint16_t) (0b##b1##b2)) | ||||
| #define TU_BIN32(b1, b2, b3, b4) ((uint32_t) (0b##b1##b2##b3##b4)) | ||||
|  | ||||
| #else | ||||
|  | ||||
| //  internal macro of B8, B16, B32 | ||||
| #define _B8__(x) (((x&0x0000000FUL)?1:0) \ | ||||
|                 +((x&0x000000F0UL)?2:0) \ | ||||
|                 +((x&0x00000F00UL)?4:0) \ | ||||
|                 +((x&0x0000F000UL)?8:0) \ | ||||
|                 +((x&0x000F0000UL)?16:0) \ | ||||
|                 +((x&0x00F00000UL)?32:0) \ | ||||
|                 +((x&0x0F000000UL)?64:0) \ | ||||
|                 +((x&0xF0000000UL)?128:0)) | ||||
|  | ||||
| #define TU_BIN8(d) ((uint8_t) _B8__(0x##d##UL)) | ||||
| #define TU_BIN16(dmsb,dlsb) (((uint16_t)TU_BIN8(dmsb)<<8) + TU_BIN8(dlsb)) | ||||
| #define TU_BIN32(dmsb,db2,db3,dlsb) \ | ||||
|             (((uint32_t)TU_BIN8(dmsb)<<24) \ | ||||
|             + ((uint32_t)TU_BIN8(db2)<<16) \ | ||||
|             + ((uint32_t)TU_BIN8(db3)<<8) \ | ||||
|             + TU_BIN8(dlsb)) | ||||
| #endif | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Debug Function | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // CFG_TUSB_DEBUG for debugging | ||||
| // 0 : no debug | ||||
| // 1 : print when there is error | ||||
| // 2 : print out log | ||||
| #if CFG_TUSB_DEBUG | ||||
|  | ||||
| void tu_print_mem(void const *buf, uint16_t count, uint8_t indent); | ||||
|  | ||||
| #ifndef tu_printf | ||||
|   #define tu_printf         printf | ||||
| #endif | ||||
|  | ||||
| // Log with debug level 1 | ||||
| #define TU_LOG1               tu_printf | ||||
| #define TU_LOG1_MEM           tu_print_mem | ||||
| #define TU_LOG1_LOCATION()    tu_printf("%s: %d:\n", __PRETTY_FUNCTION__, __LINE__) | ||||
|  | ||||
| // Log with debug level 2 | ||||
| #if CFG_TUSB_DEBUG > 1 | ||||
|   #define TU_LOG2             TU_LOG1 | ||||
|   #define TU_LOG2_MEM         TU_LOG1_MEM | ||||
|   #define TU_LOG2_LOCATION()  TU_LOG1_LOCATION() | ||||
| #endif | ||||
|  | ||||
|  | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t key; | ||||
|   char const * data; | ||||
| }lookup_entry_t; | ||||
|  | ||||
| typedef struct | ||||
| { | ||||
|   uint16_t count; | ||||
|   lookup_entry_t const* items; | ||||
| } lookup_table_t; | ||||
|  | ||||
| static inline char const* lookup_find(lookup_table_t const* p_table, uint32_t key) | ||||
| { | ||||
|   for(uint16_t i=0; i<p_table->count; i++) | ||||
|   { | ||||
|     if (p_table->items[i].key == key) return p_table->items[i].data; | ||||
|   } | ||||
|  | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| #endif // CFG_TUSB_DEBUG | ||||
|  | ||||
| #ifndef TU_LOG1 | ||||
|   #define TU_LOG1(...) | ||||
|   #define TU_LOG1_MEM(...) | ||||
| #endif | ||||
|  | ||||
| #ifndef TU_LOG2 | ||||
|   #define TU_LOG2(...) | ||||
|   #define TU_LOG2_MEM(...) | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_COMMON_H_ */ | ||||
|  | ||||
| /**  @} */ | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common | ||||
|  *  \defgroup Group_CommonH common.h | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_COMMON_H_ | ||||
| #define _TUSB_COMMON_H_ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Macros Helper | ||||
| //--------------------------------------------------------------------+ | ||||
| #define TU_ARRAY_SIZE(_arr)   ( sizeof(_arr) / sizeof(_arr[0]) ) | ||||
| #define TU_MIN(_x, _y)        ( ( (_x) < (_y) ) ? (_x) : (_y) ) | ||||
| #define TU_MAX(_x, _y)        ( ( (_x) > (_y) ) ? (_x) : (_y) ) | ||||
|  | ||||
| #define TU_U16_HIGH(u16)      ((uint8_t) (((u16) >> 8) & 0x00ff)) | ||||
| #define TU_U16_LOW(u16)       ((uint8_t) ((u16)       & 0x00ff)) | ||||
| #define U16_TO_U8S_BE(u16)    TU_U16_HIGH(u16), TU_U16_LOW(u16) | ||||
| #define U16_TO_U8S_LE(u16)    TU_U16_LOW(u16), TU_U16_HIGH(u16) | ||||
|  | ||||
| #define U32_B1_U8(u32)        ((uint8_t) (((u32) >> 24) & 0x000000ff)) // MSB | ||||
| #define U32_B2_U8(u32)        ((uint8_t) (((u32) >> 16) & 0x000000ff)) | ||||
| #define U32_B3_U8(u32)        ((uint8_t) (((u32) >>  8) & 0x000000ff)) | ||||
| #define U32_B4_U8(u32)        ((uint8_t) ((u32)         & 0x000000ff)) // LSB | ||||
|  | ||||
| #define U32_TO_U8S_BE(u32)    U32_B1_U8(u32), U32_B2_U8(u32), U32_B3_U8(u32), U32_B4_U8(u32) | ||||
| #define U32_TO_U8S_LE(u32)    U32_B4_U8(u32), U32_B3_U8(u32), U32_B2_U8(u32), U32_B1_U8(u32) | ||||
|  | ||||
| #define TU_BIT(n)             (1U << (n)) | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Includes | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // Standard Headers | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include <stddef.h> | ||||
| #include <string.h> | ||||
| #include <stdio.h> | ||||
|  | ||||
| // Tinyusb Common Headers | ||||
| #include "tusb_option.h" | ||||
| #include "tusb_compiler.h" | ||||
| #include "tusb_verify.h" | ||||
| #include "tusb_error.h" // TODO remove | ||||
| #include "tusb_timeout.h" | ||||
| #include "tusb_types.h" | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Inline Functions | ||||
| //--------------------------------------------------------------------+ | ||||
| #define tu_memclr(buffer, size)  memset((buffer), 0, (size)) | ||||
| #define tu_varclr(_var)          tu_memclr(_var, sizeof(*(_var))) | ||||
|  | ||||
| static inline uint32_t tu_u32(uint8_t b1, uint8_t b2, uint8_t b3, uint8_t b4) | ||||
| { | ||||
|   return ( ((uint32_t) b1) << 24) + ( ((uint32_t) b2) << 16) + ( ((uint32_t) b3) << 8) + b4; | ||||
| } | ||||
|  | ||||
| static inline uint16_t tu_u16(uint8_t high, uint8_t low) | ||||
| { | ||||
|   return (uint16_t)((((uint16_t) high) << 8) + low); | ||||
| } | ||||
|  | ||||
| static inline uint8_t tu_u16_high(uint16_t u16) { return (uint8_t) (((uint16_t) (u16 >> 8)) & 0x00ff); } | ||||
| static inline uint8_t tu_u16_low (uint16_t u16) { return (uint8_t) (u16 & 0x00ff); } | ||||
|  | ||||
| // Min | ||||
| static inline uint8_t  tu_min8  (uint8_t  x, uint8_t y ) { return (x < y) ? x : y; } | ||||
| static inline uint16_t tu_min16 (uint16_t x, uint16_t y) { return (x < y) ? x : y; } | ||||
| static inline uint32_t tu_min32 (uint32_t x, uint32_t y) { return (x < y) ? x : y; } | ||||
|  | ||||
| // Max | ||||
| static inline uint8_t  tu_max8  (uint8_t  x, uint8_t y ) { return (x > y) ? x : y; } | ||||
| static inline uint16_t tu_max16 (uint16_t x, uint16_t y) { return (x > y) ? x : y; } | ||||
| static inline uint32_t tu_max32 (uint32_t x, uint32_t y) { return (x > y) ? x : y; } | ||||
|  | ||||
| // Align | ||||
| static inline uint32_t tu_align_n(uint32_t value, uint32_t alignment) | ||||
| { | ||||
|   return value & ((uint32_t) ~(alignment-1)); | ||||
| } | ||||
|  | ||||
| static inline uint32_t tu_align32 (uint32_t value) { return (value & 0xFFFFFFE0UL); } | ||||
| static inline uint32_t tu_align16 (uint32_t value) { return (value & 0xFFFFFFF0UL); } | ||||
| static inline uint32_t tu_align4k (uint32_t value) { return (value & 0xFFFFF000UL); } | ||||
| static inline uint32_t tu_offset4k(uint32_t value) { return (value & 0xFFFUL); } | ||||
|  | ||||
| //------------- Mathematics -------------// | ||||
| static inline uint32_t tu_abs(int32_t value) { return (uint32_t)((value < 0) ? (-value) : value); } | ||||
|  | ||||
| /// inclusive range checking | ||||
| static inline bool tu_within(uint32_t lower, uint32_t value, uint32_t upper) | ||||
| { | ||||
|   return (lower <= value) && (value <= upper); | ||||
| } | ||||
|  | ||||
| // log2 of a value is its MSB's position | ||||
| // TODO use clz TODO remove | ||||
| static inline uint8_t tu_log2(uint32_t value) | ||||
| { | ||||
|   uint8_t result = 0; | ||||
|  | ||||
|   while (value >>= 1) | ||||
|   { | ||||
|     result++; | ||||
|   } | ||||
|   return result; | ||||
| } | ||||
|  | ||||
| // Bit | ||||
| static inline uint32_t tu_bit_set  (uint32_t value, uint8_t pos) { return value | TU_BIT(pos);                  } | ||||
| static inline uint32_t tu_bit_clear(uint32_t value, uint8_t pos) { return value & (~TU_BIT(pos));               } | ||||
| static inline bool     tu_bit_test (uint32_t value, uint8_t pos) { return (value & TU_BIT(pos)) ? true : false; } | ||||
|  | ||||
| /*------------------------------------------------------------------*/ | ||||
| /* Count number of arguments of __VA_ARGS__ | ||||
|  * - reference https://groups.google.com/forum/#!topic/comp.std.c/d-6Mj5Lko_s | ||||
|  * - _GET_NTH_ARG() takes args >= N (64) but only expand to Nth one (64th) | ||||
|  * - _RSEQ_N() is reverse sequential to N to add padding to have | ||||
|  * Nth position is the same as the number of arguments | ||||
|  * - ##__VA_ARGS__ is used to deal with 0 paramerter (swallows comma) | ||||
|  *------------------------------------------------------------------*/ | ||||
| #ifndef TU_ARGS_NUM | ||||
|  | ||||
| #define TU_ARGS_NUM(...) 	 NARG_(_0, ##__VA_ARGS__,_RSEQ_N()) | ||||
|  | ||||
| #define NARG_(...)        _GET_NTH_ARG(__VA_ARGS__) | ||||
| #define _GET_NTH_ARG( \ | ||||
|           _1, _2, _3, _4, _5, _6, _7, _8, _9,_10, \ | ||||
|          _11,_12,_13,_14,_15,_16,_17,_18,_19,_20, \ | ||||
|          _21,_22,_23,_24,_25,_26,_27,_28,_29,_30, \ | ||||
|          _31,_32,_33,_34,_35,_36,_37,_38,_39,_40, \ | ||||
|          _41,_42,_43,_44,_45,_46,_47,_48,_49,_50, \ | ||||
|          _51,_52,_53,_54,_55,_56,_57,_58,_59,_60, \ | ||||
|          _61,_62,_63,N,...) N | ||||
| #define _RSEQ_N() \ | ||||
|          62,61,60,                      \ | ||||
|          59,58,57,56,55,54,53,52,51,50, \ | ||||
|          49,48,47,46,45,44,43,42,41,40, \ | ||||
|          39,38,37,36,35,34,33,32,31,30, \ | ||||
|          29,28,27,26,25,24,23,22,21,20, \ | ||||
|          19,18,17,16,15,14,13,12,11,10, \ | ||||
|          9,8,7,6,5,4,3,2,1,0 | ||||
| #endif | ||||
|  | ||||
| // To be removed | ||||
| //------------- Binary constant -------------// | ||||
| #if defined(__GNUC__) && !defined(__CC_ARM) | ||||
|  | ||||
| #define TU_BIN8(x)               ((uint8_t)  (0b##x)) | ||||
| #define TU_BIN16(b1, b2)         ((uint16_t) (0b##b1##b2)) | ||||
| #define TU_BIN32(b1, b2, b3, b4) ((uint32_t) (0b##b1##b2##b3##b4)) | ||||
|  | ||||
| #else | ||||
|  | ||||
| //  internal macro of B8, B16, B32 | ||||
| #define _B8__(x) (((x&0x0000000FUL)?1:0) \ | ||||
|                 +((x&0x000000F0UL)?2:0) \ | ||||
|                 +((x&0x00000F00UL)?4:0) \ | ||||
|                 +((x&0x0000F000UL)?8:0) \ | ||||
|                 +((x&0x000F0000UL)?16:0) \ | ||||
|                 +((x&0x00F00000UL)?32:0) \ | ||||
|                 +((x&0x0F000000UL)?64:0) \ | ||||
|                 +((x&0xF0000000UL)?128:0)) | ||||
|  | ||||
| #define TU_BIN8(d) ((uint8_t) _B8__(0x##d##UL)) | ||||
| #define TU_BIN16(dmsb,dlsb) (((uint16_t)TU_BIN8(dmsb)<<8) + TU_BIN8(dlsb)) | ||||
| #define TU_BIN32(dmsb,db2,db3,dlsb) \ | ||||
|             (((uint32_t)TU_BIN8(dmsb)<<24) \ | ||||
|             + ((uint32_t)TU_BIN8(db2)<<16) \ | ||||
|             + ((uint32_t)TU_BIN8(db3)<<8) \ | ||||
|             + TU_BIN8(dlsb)) | ||||
| #endif | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Debug Function | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // CFG_TUSB_DEBUG for debugging | ||||
| // 0 : no debug | ||||
| // 1 : print when there is error | ||||
| // 2 : print out log | ||||
| #if CFG_TUSB_DEBUG | ||||
|  | ||||
| void tu_print_mem(void const *buf, uint16_t count, uint8_t indent); | ||||
|  | ||||
| #ifndef tu_printf | ||||
|   #define tu_printf         printf | ||||
| #endif | ||||
|  | ||||
| // Log with debug level 1 | ||||
| #define TU_LOG1               tu_printf | ||||
| #define TU_LOG1_MEM           tu_print_mem | ||||
| #define TU_LOG1_LOCATION()    tu_printf("%s: %d:\n", __PRETTY_FUNCTION__, __LINE__) | ||||
|  | ||||
| // Log with debug level 2 | ||||
| #if CFG_TUSB_DEBUG > 1 | ||||
|   #define TU_LOG2             TU_LOG1 | ||||
|   #define TU_LOG2_MEM         TU_LOG1_MEM | ||||
|   #define TU_LOG2_LOCATION()  TU_LOG1_LOCATION() | ||||
| #endif | ||||
|  | ||||
|  | ||||
| typedef struct | ||||
| { | ||||
|   uint32_t key; | ||||
|   char const * data; | ||||
| }lookup_entry_t; | ||||
|  | ||||
| typedef struct | ||||
| { | ||||
|   uint16_t count; | ||||
|   lookup_entry_t const* items; | ||||
| } lookup_table_t; | ||||
|  | ||||
| static inline char const* lookup_find(lookup_table_t const* p_table, uint32_t key) | ||||
| { | ||||
|   for(uint16_t i=0; i<p_table->count; i++) | ||||
|   { | ||||
|     if (p_table->items[i].key == key) return p_table->items[i].data; | ||||
|   } | ||||
|  | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| #endif // CFG_TUSB_DEBUG | ||||
|  | ||||
| #ifndef TU_LOG1 | ||||
|   #define TU_LOG1(...) | ||||
|   #define TU_LOG1_MEM(...) | ||||
| #endif | ||||
|  | ||||
| #ifndef TU_LOG2 | ||||
|   #define TU_LOG2(...) | ||||
|   #define TU_LOG2_MEM(...) | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_COMMON_H_ */ | ||||
|  | ||||
| /**  @} */ | ||||
|   | ||||
| @@ -1,140 +1,140 @@ | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common | ||||
|  *  \defgroup Group_Compiler Compiler | ||||
|  *  \brief Group_Compiler brief | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_COMPILER_H_ | ||||
| #define _TUSB_COMPILER_H_ | ||||
|  | ||||
| #define TU_STRING(x)      #x              ///< stringify without expand | ||||
| #define TU_XSTRING(x)     TU_STRING(x)    ///< expand then stringify | ||||
| #define TU_STRCAT(a, b)   a##b            ///< concat without expand | ||||
| #define TU_XSTRCAT(a, b)  TU_STRCAT(a, b) ///< expand then concat | ||||
|  | ||||
| #if defined __COUNTER__ && __COUNTER__ != __COUNTER__ | ||||
|   #define _TU_COUNTER_ __COUNTER__ | ||||
| #else | ||||
|   #define _TU_COUNTER_ __LINE__ | ||||
| #endif | ||||
|  | ||||
| // Compile-time Assert | ||||
| #if __STDC_VERSION__ >= 201112L | ||||
|   #define TU_VERIFY_STATIC   _Static_assert | ||||
| #else | ||||
|   #define TU_VERIFY_STATIC(const_expr, _mess) enum { TU_XSTRCAT(_verify_static_, _TU_COUNTER_) = 1/(!!(const_expr)) } | ||||
| #endif | ||||
|  | ||||
| // for declaration of reserved field, make use of _TU_COUNTER_ | ||||
| #define TU_RESERVED           TU_XSTRCAT(reserved, _TU_COUNTER_) | ||||
|  | ||||
| #define TU_LITTLE_ENDIAN (0x12u) | ||||
| #define TU_BIG_ENDIAN (0x21u) | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Compiler porting with Attribute and Endian | ||||
| //--------------------------------------------------------------------+ | ||||
| #if defined(__GNUC__) | ||||
|   #define TU_ATTR_ALIGNED(Bytes)        __attribute__ ((aligned(Bytes))) | ||||
|   #define TU_ATTR_SECTION(sec_name)     __attribute__ ((section(#sec_name))) | ||||
|   #define TU_ATTR_PACKED                __attribute__ ((packed)) | ||||
|   #define TU_ATTR_PREPACKED | ||||
|   #define TU_ATTR_WEAK                  __attribute__ ((weak)) | ||||
|   #define TU_ATTR_DEPRECATED(mess)      __attribute__ ((deprecated(mess))) // warn if function with this attribute is used | ||||
|   #define TU_ATTR_UNUSED                __attribute__ ((unused))           // Function/Variable is meant to be possibly unused | ||||
|   #define TU_ATTR_USED                  __attribute__ ((used))             // Function/Variable is meant to be used | ||||
|  | ||||
|   // Endian conversion use well-known host to network (big endian) naming | ||||
|   #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__ | ||||
|     #define TU_BYTE_ORDER TU_LITTLE_ENDIAN | ||||
|   #else | ||||
|     #define TU_BYTE_ORDER TU_BIG_ENDIAN | ||||
|   #endif | ||||
|  | ||||
|   #define TU_BSWAP16(u16) (__builtin_bswap16(u16)) | ||||
|   #define TU_BSWAP32(u32) (__builtin_bswap32(u32)) | ||||
|  | ||||
| #elif defined(__TI_COMPILER_VERSION__) | ||||
|   #define TU_ATTR_ALIGNED(Bytes)        __attribute__ ((aligned(Bytes))) | ||||
|   #define TU_ATTR_SECTION(sec_name)     __attribute__ ((section(#sec_name))) | ||||
|   #define TU_ATTR_PACKED                __attribute__ ((packed)) | ||||
|   #define TU_ATTR_PREPACKED | ||||
|   #define TU_ATTR_WEAK                  __attribute__ ((weak)) | ||||
|   #define TU_ATTR_DEPRECATED(mess)      __attribute__ ((deprecated(mess))) // warn if function with this attribute is used | ||||
|   #define TU_ATTR_UNUSED                __attribute__ ((unused))           // Function/Variable is meant to be possibly unused | ||||
|   #define TU_ATTR_USED                  __attribute__ ((used)) | ||||
|  | ||||
|   // __BYTE_ORDER is defined in the TI ARM compiler, but not MSP430 (which is little endian) | ||||
|   #if ((__BYTE_ORDER__) == (__ORDER_LITTLE_ENDIAN__)) || defined(__MSP430__) | ||||
|     #define TU_BYTE_ORDER TU_LITTLE_ENDIAN | ||||
|   #else | ||||
|     #define TU_BYTE_ORDER TU_BIG_ENDIAN | ||||
|   #endif | ||||
|  | ||||
|   #define TU_BSWAP16(u16) (__builtin_bswap16(u16)) | ||||
|   #define TU_BSWAP32(u32) (__builtin_bswap32(u32)) | ||||
|  | ||||
| #else | ||||
|   #error "Compiler attribute porting is required" | ||||
| #endif | ||||
|  | ||||
| #if (TU_BYTE_ORDER == TU_LITTLE_ENDIAN) | ||||
|  | ||||
|   #define tu_htons(u16)  (TU_BSWAP16(u16)) | ||||
|   #define tu_ntohs(u16)  (TU_BSWAP16(u16)) | ||||
|  | ||||
|   #define tu_htonl(u32)  (TU_BSWAP32(u32)) | ||||
|   #define tu_ntohl(u32)  (TU_BSWAP32(u32)) | ||||
|  | ||||
|   #define tu_htole16(u16) (u16) | ||||
|   #define tu_le16toh(u16) (u16) | ||||
|  | ||||
|   #define tu_htole32(u32) (u32) | ||||
|   #define tu_le32toh(u32) (u32) | ||||
|  | ||||
| #elif (TU_BYTE_ORDER == TU_BIG_ENDIAN) | ||||
|  | ||||
|   #define tu_htons(u16)  (u16) | ||||
|   #define tu_ntohs(u16)  (u16) | ||||
|  | ||||
|   #define tu_htonl(u32)  (u32) | ||||
|   #define tu_ntohl(u32)  (u32) | ||||
|  | ||||
|   #define tu_htole16(u16) (tu_bswap16(u16)) | ||||
|   #define tu_le16toh(u16) (tu_bswap16(u16)) | ||||
|  | ||||
|   #define tu_htole32(u32) (tu_bswap32(u32)) | ||||
|   #define tu_le32toh(u32) (tu_bswap32(u32)) | ||||
|  | ||||
| #else | ||||
|   #error Byte order is undefined | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_COMPILER_H_ */ | ||||
|  | ||||
| /// @} | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common | ||||
|  *  \defgroup Group_Compiler Compiler | ||||
|  *  \brief Group_Compiler brief | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_COMPILER_H_ | ||||
| #define _TUSB_COMPILER_H_ | ||||
|  | ||||
| #define TU_STRING(x)      #x              ///< stringify without expand | ||||
| #define TU_XSTRING(x)     TU_STRING(x)    ///< expand then stringify | ||||
| #define TU_STRCAT(a, b)   a##b            ///< concat without expand | ||||
| #define TU_XSTRCAT(a, b)  TU_STRCAT(a, b) ///< expand then concat | ||||
|  | ||||
| #if defined __COUNTER__ && __COUNTER__ != __COUNTER__ | ||||
|   #define _TU_COUNTER_ __COUNTER__ | ||||
| #else | ||||
|   #define _TU_COUNTER_ __LINE__ | ||||
| #endif | ||||
|  | ||||
| // Compile-time Assert | ||||
| #if __STDC_VERSION__ >= 201112L | ||||
|   #define TU_VERIFY_STATIC   _Static_assert | ||||
| #else | ||||
|   #define TU_VERIFY_STATIC(const_expr, _mess) enum { TU_XSTRCAT(_verify_static_, _TU_COUNTER_) = 1/(!!(const_expr)) } | ||||
| #endif | ||||
|  | ||||
| // for declaration of reserved field, make use of _TU_COUNTER_ | ||||
| #define TU_RESERVED           TU_XSTRCAT(reserved, _TU_COUNTER_) | ||||
|  | ||||
| #define TU_LITTLE_ENDIAN (0x12u) | ||||
| #define TU_BIG_ENDIAN (0x21u) | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Compiler porting with Attribute and Endian | ||||
| //--------------------------------------------------------------------+ | ||||
| #if defined(__GNUC__) | ||||
|   #define TU_ATTR_ALIGNED(Bytes)        __attribute__ ((aligned(Bytes))) | ||||
|   #define TU_ATTR_SECTION(sec_name)     __attribute__ ((section(#sec_name))) | ||||
|   #define TU_ATTR_PACKED                __attribute__ ((packed)) | ||||
|   #define TU_ATTR_PREPACKED | ||||
|   #define TU_ATTR_WEAK                  __attribute__ ((weak)) | ||||
|   #define TU_ATTR_DEPRECATED(mess)      __attribute__ ((deprecated(mess))) // warn if function with this attribute is used | ||||
|   #define TU_ATTR_UNUSED                __attribute__ ((unused))           // Function/Variable is meant to be possibly unused | ||||
|   #define TU_ATTR_USED                  __attribute__ ((used))             // Function/Variable is meant to be used | ||||
|  | ||||
|   // Endian conversion use well-known host to network (big endian) naming | ||||
|   #if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__ | ||||
|     #define TU_BYTE_ORDER TU_LITTLE_ENDIAN | ||||
|   #else | ||||
|     #define TU_BYTE_ORDER TU_BIG_ENDIAN | ||||
|   #endif | ||||
|  | ||||
|   #define TU_BSWAP16(u16) (__builtin_bswap16(u16)) | ||||
|   #define TU_BSWAP32(u32) (__builtin_bswap32(u32)) | ||||
|  | ||||
| #elif defined(__TI_COMPILER_VERSION__) | ||||
|   #define TU_ATTR_ALIGNED(Bytes)        __attribute__ ((aligned(Bytes))) | ||||
|   #define TU_ATTR_SECTION(sec_name)     __attribute__ ((section(#sec_name))) | ||||
|   #define TU_ATTR_PACKED                __attribute__ ((packed)) | ||||
|   #define TU_ATTR_PREPACKED | ||||
|   #define TU_ATTR_WEAK                  __attribute__ ((weak)) | ||||
|   #define TU_ATTR_DEPRECATED(mess)      __attribute__ ((deprecated(mess))) // warn if function with this attribute is used | ||||
|   #define TU_ATTR_UNUSED                __attribute__ ((unused))           // Function/Variable is meant to be possibly unused | ||||
|   #define TU_ATTR_USED                  __attribute__ ((used)) | ||||
|  | ||||
|   // __BYTE_ORDER is defined in the TI ARM compiler, but not MSP430 (which is little endian) | ||||
|   #if ((__BYTE_ORDER__) == (__ORDER_LITTLE_ENDIAN__)) || defined(__MSP430__) | ||||
|     #define TU_BYTE_ORDER TU_LITTLE_ENDIAN | ||||
|   #else | ||||
|     #define TU_BYTE_ORDER TU_BIG_ENDIAN | ||||
|   #endif | ||||
|  | ||||
|   #define TU_BSWAP16(u16) (__builtin_bswap16(u16)) | ||||
|   #define TU_BSWAP32(u32) (__builtin_bswap32(u32)) | ||||
|  | ||||
| #else | ||||
|   #error "Compiler attribute porting is required" | ||||
| #endif | ||||
|  | ||||
| #if (TU_BYTE_ORDER == TU_LITTLE_ENDIAN) | ||||
|  | ||||
|   #define tu_htons(u16)  (TU_BSWAP16(u16)) | ||||
|   #define tu_ntohs(u16)  (TU_BSWAP16(u16)) | ||||
|  | ||||
|   #define tu_htonl(u32)  (TU_BSWAP32(u32)) | ||||
|   #define tu_ntohl(u32)  (TU_BSWAP32(u32)) | ||||
|  | ||||
|   #define tu_htole16(u16) (u16) | ||||
|   #define tu_le16toh(u16) (u16) | ||||
|  | ||||
|   #define tu_htole32(u32) (u32) | ||||
|   #define tu_le32toh(u32) (u32) | ||||
|  | ||||
| #elif (TU_BYTE_ORDER == TU_BIG_ENDIAN) | ||||
|  | ||||
|   #define tu_htons(u16)  (u16) | ||||
|   #define tu_ntohs(u16)  (u16) | ||||
|  | ||||
|   #define tu_htonl(u32)  (u32) | ||||
|   #define tu_ntohl(u32)  (u32) | ||||
|  | ||||
|   #define tu_htole16(u16) (tu_bswap16(u16)) | ||||
|   #define tu_le16toh(u16) (tu_bswap16(u16)) | ||||
|  | ||||
|   #define tu_htole32(u32) (tu_bswap32(u32)) | ||||
|   #define tu_le32toh(u32) (tu_bswap32(u32)) | ||||
|  | ||||
| #else | ||||
|   #error Byte order is undefined | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_COMPILER_H_ */ | ||||
|  | ||||
| /// @} | ||||
|   | ||||
| @@ -1,74 +1,74 @@ | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common | ||||
|  *  \defgroup Group_Error Error Codes | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_ERRORS_H_ | ||||
| #define _TUSB_ERRORS_H_ | ||||
|  | ||||
| #include "tusb_option.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| #define ERROR_ENUM(x) x, | ||||
| #define ERROR_STRING(x) #x, | ||||
|  | ||||
| #define ERROR_TABLE(ENTRY) \ | ||||
|     ENTRY(TUSB_ERROR_NONE                            )\ | ||||
|     ENTRY(TUSB_ERROR_INVALID_PARA                    )\ | ||||
|     ENTRY(TUSB_ERROR_DEVICE_NOT_READY                )\ | ||||
|     ENTRY(TUSB_ERROR_INTERFACE_IS_BUSY               )\ | ||||
|     ENTRY(TUSB_ERROR_HCD_OPEN_PIPE_FAILED            )\ | ||||
|     ENTRY(TUSB_ERROR_OSAL_TIMEOUT                    )\ | ||||
|     ENTRY(TUSB_ERROR_CDCH_DEVICE_NOT_MOUNTED         )\ | ||||
|     ENTRY(TUSB_ERROR_MSCH_DEVICE_NOT_MOUNTED         )\ | ||||
|     ENTRY(TUSB_ERROR_NOT_SUPPORTED                   )\ | ||||
|     ENTRY(TUSB_ERROR_NOT_ENOUGH_MEMORY               )\ | ||||
|     ENTRY(TUSB_ERROR_FAILED                          )\ | ||||
|  | ||||
| /// \brief Error Code returned | ||||
| typedef enum | ||||
| { | ||||
|   ERROR_TABLE(ERROR_ENUM) | ||||
|   TUSB_ERROR_COUNT | ||||
| }tusb_error_t; | ||||
|  | ||||
| #if CFG_TUSB_DEBUG | ||||
| /// Enum to String for debugging purposes. Only available if \ref CFG_TUSB_DEBUG > 0 | ||||
| extern char const* const tusb_strerr[TUSB_ERROR_COUNT]; | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_ERRORS_H_ */ | ||||
|  | ||||
| /**  @} */ | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common | ||||
|  *  \defgroup Group_Error Error Codes | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_ERRORS_H_ | ||||
| #define _TUSB_ERRORS_H_ | ||||
|  | ||||
| #include "tusb_option.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| #define ERROR_ENUM(x) x, | ||||
| #define ERROR_STRING(x) #x, | ||||
|  | ||||
| #define ERROR_TABLE(ENTRY) \ | ||||
|     ENTRY(TUSB_ERROR_NONE                            )\ | ||||
|     ENTRY(TUSB_ERROR_INVALID_PARA                    )\ | ||||
|     ENTRY(TUSB_ERROR_DEVICE_NOT_READY                )\ | ||||
|     ENTRY(TUSB_ERROR_INTERFACE_IS_BUSY               )\ | ||||
|     ENTRY(TUSB_ERROR_HCD_OPEN_PIPE_FAILED            )\ | ||||
|     ENTRY(TUSB_ERROR_OSAL_TIMEOUT                    )\ | ||||
|     ENTRY(TUSB_ERROR_CDCH_DEVICE_NOT_MOUNTED         )\ | ||||
|     ENTRY(TUSB_ERROR_MSCH_DEVICE_NOT_MOUNTED         )\ | ||||
|     ENTRY(TUSB_ERROR_NOT_SUPPORTED                   )\ | ||||
|     ENTRY(TUSB_ERROR_NOT_ENOUGH_MEMORY               )\ | ||||
|     ENTRY(TUSB_ERROR_FAILED                          )\ | ||||
|  | ||||
| /// \brief Error Code returned | ||||
| typedef enum | ||||
| { | ||||
|   ERROR_TABLE(ERROR_ENUM) | ||||
|   TUSB_ERROR_COUNT | ||||
| }tusb_error_t; | ||||
|  | ||||
| #if CFG_TUSB_DEBUG | ||||
| /// Enum to String for debugging purposes. Only available if \ref CFG_TUSB_DEBUG > 0 | ||||
| extern char const* const tusb_strerr[TUSB_ERROR_COUNT]; | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_ERRORS_H_ */ | ||||
|  | ||||
| /**  @} */ | ||||
|   | ||||
| @@ -1,288 +1,288 @@ | ||||
| /* | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| #include <string.h> | ||||
|  | ||||
| #include "osal/osal.h" | ||||
| #include "tusb_fifo.h" | ||||
|  | ||||
| // implement mutex lock and unlock | ||||
| #if CFG_FIFO_MUTEX | ||||
|  | ||||
| static void tu_fifo_lock(tu_fifo_t *f) | ||||
| { | ||||
|   if (f->mutex) | ||||
|   { | ||||
|     osal_mutex_lock(f->mutex, OSAL_TIMEOUT_WAIT_FOREVER); | ||||
|   } | ||||
| } | ||||
|  | ||||
| static void tu_fifo_unlock(tu_fifo_t *f) | ||||
| { | ||||
|   if (f->mutex) | ||||
|   { | ||||
|     osal_mutex_unlock(f->mutex); | ||||
|   } | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| #define tu_fifo_lock(_ff) | ||||
| #define tu_fifo_unlock(_ff) | ||||
|  | ||||
| #endif | ||||
|  | ||||
| bool tu_fifo_config(tu_fifo_t *f, void* buffer, uint16_t depth, uint16_t item_size, bool overwritable) | ||||
| { | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   f->buffer = (uint8_t*) buffer; | ||||
|   f->depth  = depth; | ||||
|   f->item_size = item_size; | ||||
|   f->overwritable = overwritable; | ||||
|  | ||||
|   f->rd_idx = f->wr_idx = f->count = 0; | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| // retrieve data from fifo | ||||
| static void _tu_ff_pull(tu_fifo_t* f, void * buffer) | ||||
| { | ||||
|   memcpy(buffer, | ||||
|          f->buffer + (f->rd_idx * f->item_size), | ||||
|          f->item_size); | ||||
|  | ||||
|   f->rd_idx = (f->rd_idx + 1) % f->depth; | ||||
|   f->count--; | ||||
| } | ||||
|  | ||||
| // send data to fifo | ||||
| static void _tu_ff_push(tu_fifo_t* f, void const * data) | ||||
| { | ||||
|   memcpy( f->buffer + (f->wr_idx * f->item_size), | ||||
|           data, | ||||
|           f->item_size); | ||||
|  | ||||
|   f->wr_idx = (f->wr_idx + 1) % f->depth; | ||||
|  | ||||
|   if (tu_fifo_full(f)) | ||||
|   { | ||||
|     f->rd_idx = f->wr_idx; // keep the full state (rd == wr && len = size) | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     f->count++; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief Read one byte out of the RX buffer. | ||||
|  | ||||
|     This function will return the byte located at the array index of the | ||||
|     read pointer, and then increment the read pointer index.  If the read | ||||
|     pointer exceeds the maximum buffer size, it will roll over to zero. | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  buffer | ||||
|                 Pointer to the place holder for data read from the buffer | ||||
|  | ||||
|     @returns TRUE if the queue is not empty | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| bool tu_fifo_read(tu_fifo_t* f, void * buffer) | ||||
| { | ||||
|   if( tu_fifo_empty(f) ) return false; | ||||
|  | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   _tu_ff_pull(f, buffer); | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief This function will read n elements into the array index specified by | ||||
|     the write pointer and increment the write index. If the write index | ||||
|     exceeds the max buffer size, then it will roll over to zero. | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  buffer | ||||
|                 The pointer to data location | ||||
|     @param[in]  count | ||||
|                 Number of element that buffer can afford | ||||
|  | ||||
|     @returns number of items read from the FIFO | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| uint16_t tu_fifo_read_n (tu_fifo_t* f, void * buffer, uint16_t count) | ||||
| { | ||||
|   if( tu_fifo_empty(f) ) return 0; | ||||
|  | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   /* Limit up to fifo's count */ | ||||
|   if ( count > f->count ) count = f->count; | ||||
|  | ||||
|   uint8_t* buf8 = (uint8_t*) buffer; | ||||
|   uint16_t len = 0; | ||||
|  | ||||
|   while (len < count) | ||||
|   { | ||||
|     _tu_ff_pull(f, buf8); | ||||
|  | ||||
|     len++; | ||||
|     buf8 += f->item_size; | ||||
|   } | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return len; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief Reads one item without removing it from the FIFO | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  pos | ||||
|                 Position to read from in the FIFO buffer | ||||
|     @param[in]  p_buffer | ||||
|                 Pointer to the place holder for data read from the buffer | ||||
|  | ||||
|     @returns TRUE if the queue is not empty | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| bool tu_fifo_peek_at(tu_fifo_t* f, uint16_t pos, void * p_buffer) | ||||
| { | ||||
|   if ( pos >= f->count ) return false; | ||||
|  | ||||
|   // rd_idx is pos=0 | ||||
|   uint16_t index = (f->rd_idx + pos) % f->depth; | ||||
|   memcpy(p_buffer, | ||||
|          f->buffer + (index * f->item_size), | ||||
|          f->item_size); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief Write one element into the RX buffer. | ||||
|  | ||||
|     This function will write one element into the array index specified by | ||||
|     the write pointer and increment the write index. If the write index | ||||
|     exceeds the max buffer size, then it will roll over to zero. | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  data | ||||
|                 The byte to add to the FIFO | ||||
|  | ||||
|     @returns TRUE if the data was written to the FIFO (overwrittable | ||||
|              FIFO will always return TRUE) | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| bool tu_fifo_write (tu_fifo_t* f, const void * data) | ||||
| { | ||||
|   if ( tu_fifo_full(f) && !f->overwritable ) return false; | ||||
|  | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   _tu_ff_push(f, data); | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief This function will write n elements into the array index specified by | ||||
|     the write pointer and increment the write index. If the write index | ||||
|     exceeds the max buffer size, then it will roll over to zero. | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  data | ||||
|                 The pointer to data to add to the FIFO | ||||
|     @param[in]  count | ||||
|                 Number of element | ||||
|     @return Number of written elements | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| uint16_t tu_fifo_write_n (tu_fifo_t* f, const void * data, uint16_t count) | ||||
| { | ||||
|   if ( count == 0 ) return 0; | ||||
|  | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   // Not overwritable limit up to full | ||||
|   if (!f->overwritable) count = tu_min16(count, tu_fifo_remaining(f)); | ||||
|  | ||||
|   uint8_t const* buf8 = (uint8_t const*) data; | ||||
|   uint16_t len = 0; | ||||
|  | ||||
|   while (len < count) | ||||
|   { | ||||
|     _tu_ff_push(f, buf8); | ||||
|  | ||||
|     len++; | ||||
|     buf8 += f->item_size; | ||||
|   } | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return len; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief Clear the fifo read and write pointers and set length to zero | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| bool tu_fifo_clear(tu_fifo_t *f) | ||||
| { | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   f->rd_idx = f->wr_idx = f->count = 0; | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
| /* | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| #include <string.h> | ||||
|  | ||||
| #include "osal/osal.h" | ||||
| #include "tusb_fifo.h" | ||||
|  | ||||
| // implement mutex lock and unlock | ||||
| #if CFG_FIFO_MUTEX | ||||
|  | ||||
| static void tu_fifo_lock(tu_fifo_t *f) | ||||
| { | ||||
|   if (f->mutex) | ||||
|   { | ||||
|     osal_mutex_lock(f->mutex, OSAL_TIMEOUT_WAIT_FOREVER); | ||||
|   } | ||||
| } | ||||
|  | ||||
| static void tu_fifo_unlock(tu_fifo_t *f) | ||||
| { | ||||
|   if (f->mutex) | ||||
|   { | ||||
|     osal_mutex_unlock(f->mutex); | ||||
|   } | ||||
| } | ||||
|  | ||||
| #else | ||||
|  | ||||
| #define tu_fifo_lock(_ff) | ||||
| #define tu_fifo_unlock(_ff) | ||||
|  | ||||
| #endif | ||||
|  | ||||
| bool tu_fifo_config(tu_fifo_t *f, void* buffer, uint16_t depth, uint16_t item_size, bool overwritable) | ||||
| { | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   f->buffer = (uint8_t*) buffer; | ||||
|   f->depth  = depth; | ||||
|   f->item_size = item_size; | ||||
|   f->overwritable = overwritable; | ||||
|  | ||||
|   f->rd_idx = f->wr_idx = f->count = 0; | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| // retrieve data from fifo | ||||
| static void _tu_ff_pull(tu_fifo_t* f, void * buffer) | ||||
| { | ||||
|   memcpy(buffer, | ||||
|          f->buffer + (f->rd_idx * f->item_size), | ||||
|          f->item_size); | ||||
|  | ||||
|   f->rd_idx = (f->rd_idx + 1) % f->depth; | ||||
|   f->count--; | ||||
| } | ||||
|  | ||||
| // send data to fifo | ||||
| static void _tu_ff_push(tu_fifo_t* f, void const * data) | ||||
| { | ||||
|   memcpy( f->buffer + (f->wr_idx * f->item_size), | ||||
|           data, | ||||
|           f->item_size); | ||||
|  | ||||
|   f->wr_idx = (f->wr_idx + 1) % f->depth; | ||||
|  | ||||
|   if (tu_fifo_full(f)) | ||||
|   { | ||||
|     f->rd_idx = f->wr_idx; // keep the full state (rd == wr && len = size) | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     f->count++; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief Read one byte out of the RX buffer. | ||||
|  | ||||
|     This function will return the byte located at the array index of the | ||||
|     read pointer, and then increment the read pointer index.  If the read | ||||
|     pointer exceeds the maximum buffer size, it will roll over to zero. | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  buffer | ||||
|                 Pointer to the place holder for data read from the buffer | ||||
|  | ||||
|     @returns TRUE if the queue is not empty | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| bool tu_fifo_read(tu_fifo_t* f, void * buffer) | ||||
| { | ||||
|   if( tu_fifo_empty(f) ) return false; | ||||
|  | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   _tu_ff_pull(f, buffer); | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief This function will read n elements into the array index specified by | ||||
|     the write pointer and increment the write index. If the write index | ||||
|     exceeds the max buffer size, then it will roll over to zero. | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  buffer | ||||
|                 The pointer to data location | ||||
|     @param[in]  count | ||||
|                 Number of element that buffer can afford | ||||
|  | ||||
|     @returns number of items read from the FIFO | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| uint16_t tu_fifo_read_n (tu_fifo_t* f, void * buffer, uint16_t count) | ||||
| { | ||||
|   if( tu_fifo_empty(f) ) return 0; | ||||
|  | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   /* Limit up to fifo's count */ | ||||
|   if ( count > f->count ) count = f->count; | ||||
|  | ||||
|   uint8_t* buf8 = (uint8_t*) buffer; | ||||
|   uint16_t len = 0; | ||||
|  | ||||
|   while (len < count) | ||||
|   { | ||||
|     _tu_ff_pull(f, buf8); | ||||
|  | ||||
|     len++; | ||||
|     buf8 += f->item_size; | ||||
|   } | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return len; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief Reads one item without removing it from the FIFO | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  pos | ||||
|                 Position to read from in the FIFO buffer | ||||
|     @param[in]  p_buffer | ||||
|                 Pointer to the place holder for data read from the buffer | ||||
|  | ||||
|     @returns TRUE if the queue is not empty | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| bool tu_fifo_peek_at(tu_fifo_t* f, uint16_t pos, void * p_buffer) | ||||
| { | ||||
|   if ( pos >= f->count ) return false; | ||||
|  | ||||
|   // rd_idx is pos=0 | ||||
|   uint16_t index = (f->rd_idx + pos) % f->depth; | ||||
|   memcpy(p_buffer, | ||||
|          f->buffer + (index * f->item_size), | ||||
|          f->item_size); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief Write one element into the RX buffer. | ||||
|  | ||||
|     This function will write one element into the array index specified by | ||||
|     the write pointer and increment the write index. If the write index | ||||
|     exceeds the max buffer size, then it will roll over to zero. | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  data | ||||
|                 The byte to add to the FIFO | ||||
|  | ||||
|     @returns TRUE if the data was written to the FIFO (overwrittable | ||||
|              FIFO will always return TRUE) | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| bool tu_fifo_write (tu_fifo_t* f, const void * data) | ||||
| { | ||||
|   if ( tu_fifo_full(f) && !f->overwritable ) return false; | ||||
|  | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   _tu_ff_push(f, data); | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief This function will write n elements into the array index specified by | ||||
|     the write pointer and increment the write index. If the write index | ||||
|     exceeds the max buffer size, then it will roll over to zero. | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
|     @param[in]  data | ||||
|                 The pointer to data to add to the FIFO | ||||
|     @param[in]  count | ||||
|                 Number of element | ||||
|     @return Number of written elements | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| uint16_t tu_fifo_write_n (tu_fifo_t* f, const void * data, uint16_t count) | ||||
| { | ||||
|   if ( count == 0 ) return 0; | ||||
|  | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   // Not overwritable limit up to full | ||||
|   if (!f->overwritable) count = tu_min16(count, tu_fifo_remaining(f)); | ||||
|  | ||||
|   uint8_t const* buf8 = (uint8_t const*) data; | ||||
|   uint16_t len = 0; | ||||
|  | ||||
|   while (len < count) | ||||
|   { | ||||
|     _tu_ff_push(f, buf8); | ||||
|  | ||||
|     len++; | ||||
|     buf8 += f->item_size; | ||||
|   } | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return len; | ||||
| } | ||||
|  | ||||
| /******************************************************************************/ | ||||
| /*! | ||||
|     @brief Clear the fifo read and write pointers and set length to zero | ||||
|  | ||||
|     @param[in]  f | ||||
|                 Pointer to the FIFO buffer to manipulate | ||||
| */ | ||||
| /******************************************************************************/ | ||||
| bool tu_fifo_clear(tu_fifo_t *f) | ||||
| { | ||||
|   tu_fifo_lock(f); | ||||
|  | ||||
|   f->rd_idx = f->wr_idx = f->count = 0; | ||||
|  | ||||
|   tu_fifo_unlock(f); | ||||
|  | ||||
|   return true; | ||||
| } | ||||
|   | ||||
| @@ -1,131 +1,131 @@ | ||||
| /* | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common | ||||
|  * \defgroup group_fifo fifo | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_FIFO_H_ | ||||
| #define _TUSB_FIFO_H_ | ||||
|  | ||||
| // mutex is only needed for RTOS | ||||
| // for OS None, we don't get preempted | ||||
| #define CFG_FIFO_MUTEX      (CFG_TUSB_OS != OPT_OS_NONE) | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| #if CFG_FIFO_MUTEX | ||||
| #define tu_fifo_mutex_t  osal_mutex_t | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /** \struct tu_fifo_t | ||||
|  * \brief Simple Circular FIFO | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|            uint8_t* buffer    ; ///< buffer pointer | ||||
|            uint16_t depth     ; ///< max items | ||||
|            uint16_t item_size ; ///< size of each item | ||||
|            bool overwritable  ; | ||||
|  | ||||
|   volatile uint16_t count     ; ///< number of items in queue | ||||
|   volatile uint16_t wr_idx    ; ///< write pointer | ||||
|   volatile uint16_t rd_idx    ; ///< read pointer | ||||
|  | ||||
| #if CFG_FIFO_MUTEX | ||||
|   tu_fifo_mutex_t mutex; | ||||
| #endif | ||||
|  | ||||
| } tu_fifo_t; | ||||
|  | ||||
| #define TU_FIFO_DEF(_name, _depth, _type, _overwritable) \ | ||||
|   uint8_t _name##_buf[_depth*sizeof(_type)]; \ | ||||
|   tu_fifo_t _name = {                        \ | ||||
|       .buffer       = _name##_buf,           \ | ||||
|       .depth        = _depth,                \ | ||||
|       .item_size    = sizeof(_type),         \ | ||||
|       .overwritable = _overwritable,         \ | ||||
|   } | ||||
|  | ||||
| bool tu_fifo_clear(tu_fifo_t *f); | ||||
| bool tu_fifo_config(tu_fifo_t *f, void* buffer, uint16_t depth, uint16_t item_size, bool overwritable); | ||||
|  | ||||
| #if CFG_FIFO_MUTEX | ||||
| static inline void tu_fifo_config_mutex(tu_fifo_t *f, tu_fifo_mutex_t mutex_hdl) | ||||
| { | ||||
|   f->mutex = mutex_hdl; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| bool     tu_fifo_write   (tu_fifo_t* f, void const * p_data); | ||||
| uint16_t tu_fifo_write_n (tu_fifo_t* f, void const * p_data, uint16_t count); | ||||
|  | ||||
| bool     tu_fifo_read    (tu_fifo_t* f, void * p_buffer); | ||||
| uint16_t tu_fifo_read_n  (tu_fifo_t* f, void * p_buffer, uint16_t count); | ||||
|  | ||||
| bool     tu_fifo_peek_at (tu_fifo_t* f, uint16_t pos, void * p_buffer); | ||||
|  | ||||
| static inline bool tu_fifo_peek(tu_fifo_t* f, void * p_buffer) | ||||
| { | ||||
|   return tu_fifo_peek_at(f, 0, p_buffer); | ||||
| } | ||||
|  | ||||
| static inline bool tu_fifo_empty(tu_fifo_t* f) | ||||
| { | ||||
|   return (f->count == 0); | ||||
| } | ||||
|  | ||||
| static inline bool tu_fifo_full(tu_fifo_t* f) | ||||
| { | ||||
|   return (f->count == f->depth); | ||||
| } | ||||
|  | ||||
| static inline uint16_t tu_fifo_count(tu_fifo_t* f) | ||||
| { | ||||
|   return f->count; | ||||
| } | ||||
|  | ||||
| static inline uint16_t tu_fifo_remaining(tu_fifo_t* f) | ||||
| { | ||||
|   return f->depth - f->count; | ||||
| } | ||||
|  | ||||
| static inline uint16_t tu_fifo_depth(tu_fifo_t* f) | ||||
| { | ||||
|   return f->depth; | ||||
| } | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_FIFO_H_ */ | ||||
| /* | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common | ||||
|  * \defgroup group_fifo fifo | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_FIFO_H_ | ||||
| #define _TUSB_FIFO_H_ | ||||
|  | ||||
| // mutex is only needed for RTOS | ||||
| // for OS None, we don't get preempted | ||||
| #define CFG_FIFO_MUTEX      (CFG_TUSB_OS != OPT_OS_NONE) | ||||
|  | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| #if CFG_FIFO_MUTEX | ||||
| #define tu_fifo_mutex_t  osal_mutex_t | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /** \struct tu_fifo_t | ||||
|  * \brief Simple Circular FIFO | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|            uint8_t* buffer    ; ///< buffer pointer | ||||
|            uint16_t depth     ; ///< max items | ||||
|            uint16_t item_size ; ///< size of each item | ||||
|            bool overwritable  ; | ||||
|  | ||||
|   volatile uint16_t count     ; ///< number of items in queue | ||||
|   volatile uint16_t wr_idx    ; ///< write pointer | ||||
|   volatile uint16_t rd_idx    ; ///< read pointer | ||||
|  | ||||
| #if CFG_FIFO_MUTEX | ||||
|   tu_fifo_mutex_t mutex; | ||||
| #endif | ||||
|  | ||||
| } tu_fifo_t; | ||||
|  | ||||
| #define TU_FIFO_DEF(_name, _depth, _type, _overwritable) \ | ||||
|   uint8_t _name##_buf[_depth*sizeof(_type)]; \ | ||||
|   tu_fifo_t _name = {                        \ | ||||
|       .buffer       = _name##_buf,           \ | ||||
|       .depth        = _depth,                \ | ||||
|       .item_size    = sizeof(_type),         \ | ||||
|       .overwritable = _overwritable,         \ | ||||
|   } | ||||
|  | ||||
| bool tu_fifo_clear(tu_fifo_t *f); | ||||
| bool tu_fifo_config(tu_fifo_t *f, void* buffer, uint16_t depth, uint16_t item_size, bool overwritable); | ||||
|  | ||||
| #if CFG_FIFO_MUTEX | ||||
| static inline void tu_fifo_config_mutex(tu_fifo_t *f, tu_fifo_mutex_t mutex_hdl) | ||||
| { | ||||
|   f->mutex = mutex_hdl; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| bool     tu_fifo_write   (tu_fifo_t* f, void const * p_data); | ||||
| uint16_t tu_fifo_write_n (tu_fifo_t* f, void const * p_data, uint16_t count); | ||||
|  | ||||
| bool     tu_fifo_read    (tu_fifo_t* f, void * p_buffer); | ||||
| uint16_t tu_fifo_read_n  (tu_fifo_t* f, void * p_buffer, uint16_t count); | ||||
|  | ||||
| bool     tu_fifo_peek_at (tu_fifo_t* f, uint16_t pos, void * p_buffer); | ||||
|  | ||||
| static inline bool tu_fifo_peek(tu_fifo_t* f, void * p_buffer) | ||||
| { | ||||
|   return tu_fifo_peek_at(f, 0, p_buffer); | ||||
| } | ||||
|  | ||||
| static inline bool tu_fifo_empty(tu_fifo_t* f) | ||||
| { | ||||
|   return (f->count == 0); | ||||
| } | ||||
|  | ||||
| static inline bool tu_fifo_full(tu_fifo_t* f) | ||||
| { | ||||
|   return (f->count == f->depth); | ||||
| } | ||||
|  | ||||
| static inline uint16_t tu_fifo_count(tu_fifo_t* f) | ||||
| { | ||||
|   return f->count; | ||||
| } | ||||
|  | ||||
| static inline uint16_t tu_fifo_remaining(tu_fifo_t* f) | ||||
| { | ||||
|   return f->depth - f->count; | ||||
| } | ||||
|  | ||||
| static inline uint16_t tu_fifo_depth(tu_fifo_t* f) | ||||
| { | ||||
|   return f->depth; | ||||
| } | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_FIFO_H_ */ | ||||
|   | ||||
| @@ -1,80 +1,80 @@ | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common Common Files | ||||
|  *  \defgroup Group_TimeoutTimer timeout timer | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_TIMEOUT_H_ | ||||
| #define _TUSB_TIMEOUT_H_ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| typedef struct { | ||||
|   uint32_t start; | ||||
|   uint32_t interval; | ||||
| }tu_timeout_t; | ||||
|  | ||||
| #if 0 | ||||
|  | ||||
| extern uint32_t tusb_hal_millis(void); | ||||
|  | ||||
| static inline void tu_timeout_set(tu_timeout_t* tt, uint32_t msec) | ||||
| { | ||||
|   tt->interval = msec; | ||||
|   tt->start    = tusb_hal_millis(); | ||||
| } | ||||
|  | ||||
| static inline bool tu_timeout_expired(tu_timeout_t* tt) | ||||
| { | ||||
|   return ( tusb_hal_millis() - tt->start ) >= tt->interval; | ||||
| } | ||||
|  | ||||
| // For used with periodic event to prevent drift | ||||
| static inline void tu_timeout_reset(tu_timeout_t* tt) | ||||
| { | ||||
|   tt->start += tt->interval; | ||||
| } | ||||
|  | ||||
| static inline void tu_timeout_restart(tu_timeout_t* tt) | ||||
| { | ||||
|   tt->start = tusb_hal_millis(); | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_TIMEOUT_H_ */ | ||||
|  | ||||
| /** @} */ | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup Group_Common Common Files | ||||
|  *  \defgroup Group_TimeoutTimer timeout timer | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_TIMEOUT_H_ | ||||
| #define _TUSB_TIMEOUT_H_ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| typedef struct { | ||||
|   uint32_t start; | ||||
|   uint32_t interval; | ||||
| }tu_timeout_t; | ||||
|  | ||||
| #if 0 | ||||
|  | ||||
| extern uint32_t tusb_hal_millis(void); | ||||
|  | ||||
| static inline void tu_timeout_set(tu_timeout_t* tt, uint32_t msec) | ||||
| { | ||||
|   tt->interval = msec; | ||||
|   tt->start    = tusb_hal_millis(); | ||||
| } | ||||
|  | ||||
| static inline bool tu_timeout_expired(tu_timeout_t* tt) | ||||
| { | ||||
|   return ( tusb_hal_millis() - tt->start ) >= tt->interval; | ||||
| } | ||||
|  | ||||
| // For used with periodic event to prevent drift | ||||
| static inline void tu_timeout_reset(tu_timeout_t* tt) | ||||
| { | ||||
|   tt->start += tt->interval; | ||||
| } | ||||
|  | ||||
| static inline void tu_timeout_restart(tu_timeout_t* tt) | ||||
| { | ||||
|   tt->start = tusb_hal_millis(); | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_TIMEOUT_H_ */ | ||||
|  | ||||
| /** @} */ | ||||
|   | ||||
| @@ -1,481 +1,481 @@ | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup group_usb_definitions | ||||
|  *  \defgroup USBDef_Type USB Types | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_TYPES_H_ | ||||
| #define _TUSB_TYPES_H_ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "tusb_compiler.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| /*------------------------------------------------------------------*/ | ||||
| /* CONSTANTS | ||||
|  *------------------------------------------------------------------*/ | ||||
|  | ||||
| /// defined base on EHCI specs value for Endpoint Speed | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_SPEED_FULL = 0, | ||||
|   TUSB_SPEED_LOW     , | ||||
|   TUSB_SPEED_HIGH | ||||
| }tusb_speed_t; | ||||
|  | ||||
| /// defined base on USB Specs Endpoint's bmAttributes | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_XFER_CONTROL = 0 , | ||||
|   TUSB_XFER_ISOCHRONOUS , | ||||
|   TUSB_XFER_BULK        , | ||||
|   TUSB_XFER_INTERRUPT | ||||
| }tusb_xfer_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_DIR_OUT = 0, | ||||
|   TUSB_DIR_IN  = 1, | ||||
|  | ||||
|   TUSB_DIR_IN_MASK = 0x80 | ||||
| }tusb_dir_t; | ||||
|  | ||||
| /// USB Descriptor Types | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_DESC_DEVICE                = 0x01, | ||||
|   TUSB_DESC_CONFIGURATION         = 0x02, | ||||
|   TUSB_DESC_STRING                = 0x03, | ||||
|   TUSB_DESC_INTERFACE             = 0x04, | ||||
|   TUSB_DESC_ENDPOINT              = 0x05, | ||||
|   TUSB_DESC_DEVICE_QUALIFIER      = 0x06, | ||||
|   TUSB_DESC_OTHER_SPEED_CONFIG    = 0x07, | ||||
|   TUSB_DESC_INTERFACE_POWER       = 0x08, | ||||
|   TUSB_DESC_OTG                   = 0x09, | ||||
|   TUSB_DESC_DEBUG                 = 0x0A, | ||||
|   TUSB_DESC_INTERFACE_ASSOCIATION = 0x0B, | ||||
|  | ||||
|   TUSB_DESC_BOS                   = 0x0F, | ||||
|   TUSB_DESC_DEVICE_CAPABILITY     = 0x10, | ||||
|  | ||||
|   TUSB_DESC_FUNCTIONAL            = 0x21, | ||||
|  | ||||
|   // Class Specific Descriptor | ||||
|   TUSB_DESC_CS_DEVICE             = 0x21, | ||||
|   TUSB_DESC_CS_CONFIGURATION      = 0x22, | ||||
|   TUSB_DESC_CS_STRING             = 0x23, | ||||
|   TUSB_DESC_CS_INTERFACE          = 0x24, | ||||
|   TUSB_DESC_CS_ENDPOINT           = 0x25, | ||||
|  | ||||
|   TUSB_DESC_SUPERSPEED_ENDPOINT_COMPANION     = 0x30, | ||||
|   TUSB_DESC_SUPERSPEED_ISO_ENDPOINT_COMPANION = 0x31 | ||||
| }tusb_desc_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_REQ_GET_STATUS        = 0  , | ||||
|   TUSB_REQ_CLEAR_FEATURE     = 1  , | ||||
|   TUSB_REQ_RESERVED          = 2  , | ||||
|   TUSB_REQ_SET_FEATURE       = 3  , | ||||
|   TUSB_REQ_RESERVED2         = 4  , | ||||
|   TUSB_REQ_SET_ADDRESS       = 5  , | ||||
|   TUSB_REQ_GET_DESCRIPTOR    = 6  , | ||||
|   TUSB_REQ_SET_DESCRIPTOR    = 7  , | ||||
|   TUSB_REQ_GET_CONFIGURATION = 8  , | ||||
|   TUSB_REQ_SET_CONFIGURATION = 9  , | ||||
|   TUSB_REQ_GET_INTERFACE     = 10 , | ||||
|   TUSB_REQ_SET_INTERFACE     = 11 , | ||||
|   TUSB_REQ_SYNCH_FRAME       = 12 | ||||
| }tusb_request_code_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_REQ_FEATURE_EDPT_HALT     = 0, | ||||
|   TUSB_REQ_FEATURE_REMOTE_WAKEUP = 1, | ||||
|   TUSB_REQ_FEATURE_TEST_MODE     = 2 | ||||
| }tusb_request_feature_selector_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_REQ_TYPE_STANDARD = 0, | ||||
|   TUSB_REQ_TYPE_CLASS, | ||||
|   TUSB_REQ_TYPE_VENDOR, | ||||
|   TUSB_REQ_TYPE_INVALID | ||||
| } tusb_request_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_REQ_RCPT_DEVICE =0, | ||||
|   TUSB_REQ_RCPT_INTERFACE, | ||||
|   TUSB_REQ_RCPT_ENDPOINT, | ||||
|   TUSB_REQ_RCPT_OTHER | ||||
| } tusb_request_recipient_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_CLASS_UNSPECIFIED          = 0    , | ||||
|   TUSB_CLASS_AUDIO                = 1    , | ||||
|   TUSB_CLASS_CDC                  = 2    , | ||||
|   TUSB_CLASS_HID                  = 3    , | ||||
|   TUSB_CLASS_RESERVED_4           = 4    , | ||||
|   TUSB_CLASS_PHYSICAL             = 5    , | ||||
|   TUSB_CLASS_IMAGE                = 6    , | ||||
|   TUSB_CLASS_PRINTER              = 7    , | ||||
|   TUSB_CLASS_MSC                  = 8    , | ||||
|   TUSB_CLASS_HUB                  = 9    , | ||||
|   TUSB_CLASS_CDC_DATA             = 10   , | ||||
|   TUSB_CLASS_SMART_CARD           = 11   , | ||||
|   TUSB_CLASS_RESERVED_12          = 12   , | ||||
|   TUSB_CLASS_CONTENT_SECURITY     = 13   , | ||||
|   TUSB_CLASS_VIDEO                = 14   , | ||||
|   TUSB_CLASS_PERSONAL_HEALTHCARE  = 15   , | ||||
|   TUSB_CLASS_AUDIO_VIDEO          = 16   , | ||||
|  | ||||
|   TUSB_CLASS_DIAGNOSTIC           = 0xDC , | ||||
|   TUSB_CLASS_WIRELESS_CONTROLLER  = 0xE0 , | ||||
|   TUSB_CLASS_MISC                 = 0xEF , | ||||
|   TUSB_CLASS_APPLICATION_SPECIFIC = 0xFE , | ||||
|   TUSB_CLASS_VENDOR_SPECIFIC      = 0xFF | ||||
| }tusb_class_code_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   MISC_SUBCLASS_COMMON = 2 | ||||
| }misc_subclass_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   MISC_PROTOCOL_IAD = 1 | ||||
| }misc_protocol_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   DEVICE_CAPABILITY_WIRELESS_USB               = 0x01, | ||||
|   DEVICE_CAPABILITY_USB20_EXTENSION            = 0x02, | ||||
|   DEVICE_CAPABILITY_SUPERSPEED_USB             = 0x03, | ||||
|   DEVICE_CAPABILITY_CONTAINER_id               = 0x04, | ||||
|   DEVICE_CAPABILITY_PLATFORM                   = 0x05, | ||||
|   DEVICE_CAPABILITY_POWER_DELIVERY             = 0x06, | ||||
|   DEVICE_CAPABILITY_BATTERY_INFO               = 0x07, | ||||
|   DEVICE_CAPABILITY_PD_CONSUMER_PORT           = 0x08, | ||||
|   DEVICE_CAPABILITY_PD_PROVIDER_PORT           = 0x09, | ||||
|   DEVICE_CAPABILITY_SUPERSPEED_PLUS            = 0x0A, | ||||
|   DEVICE_CAPABILITY_PRECESION_TIME_MEASUREMENT = 0x0B, | ||||
|   DEVICE_CAPABILITY_WIRELESS_USB_EXT           = 0x0C, | ||||
|   DEVICE_CAPABILITY_BILLBOARD                  = 0x0D, | ||||
|   DEVICE_CAPABILITY_AUTHENTICATION             = 0x0E, | ||||
|   DEVICE_CAPABILITY_BILLBOARD_EX               = 0x0F, | ||||
|   DEVICE_CAPABILITY_CONFIGURATION_SUMMARY      = 0x10 | ||||
| }device_capability_type_t; | ||||
|  | ||||
| enum { | ||||
|   TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP = TU_BIT(5), | ||||
|   TUSB_DESC_CONFIG_ATT_SELF_POWERED  = TU_BIT(6), | ||||
| }; | ||||
|  | ||||
| #define TUSB_DESC_CONFIG_POWER_MA(x)  ((x)/2) | ||||
|  | ||||
| /// Device State TODO remove | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_DEVICE_STATE_UNPLUG = 0  , | ||||
|   TUSB_DEVICE_STATE_CONFIGURED  , | ||||
|   TUSB_DEVICE_STATE_SUSPENDED   , | ||||
| }tusb_device_state_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   XFER_RESULT_SUCCESS, | ||||
|   XFER_RESULT_FAILED, | ||||
|   XFER_RESULT_STALLED, | ||||
| }xfer_result_t; | ||||
|  | ||||
| enum // TODO remove | ||||
| { | ||||
|   DESC_OFFSET_LEN  = 0, | ||||
|   DESC_OFFSET_TYPE = 1 | ||||
| }; | ||||
|  | ||||
| enum | ||||
| { | ||||
|   INTERFACE_INVALID_NUMBER = 0xff | ||||
| }; | ||||
|  | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   MS_OS_20_SET_HEADER_DESCRIPTOR       = 0x00, | ||||
|   MS_OS_20_SUBSET_HEADER_CONFIGURATION = 0x01, | ||||
|   MS_OS_20_SUBSET_HEADER_FUNCTION      = 0x02, | ||||
|   MS_OS_20_FEATURE_COMPATBLE_ID        = 0x03, | ||||
|   MS_OS_20_FEATURE_REG_PROPERTY        = 0x04, | ||||
|   MS_OS_20_FEATURE_MIN_RESUME_TIME     = 0x05, | ||||
|   MS_OS_20_FEATURE_MODEL_ID            = 0x06, | ||||
|   MS_OS_20_FEATURE_CCGP_DEVICE         = 0x07, | ||||
|   MS_OS_20_FEATURE_VENDOR_REVISION     = 0x08 | ||||
| } microsoft_os_20_type_t; | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // USB Descriptors | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| /// USB Device Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength            ; ///< Size of this descriptor in bytes. | ||||
|   uint8_t  bDescriptorType    ; ///< DEVICE Descriptor Type. | ||||
|   uint16_t bcdUSB             ; ///< BUSB Specification Release Number in Binary-Coded Decimal (i.e., 2.10 is 210H). This field identifies the release of the USB Specification with which the device and its descriptors are compliant. | ||||
|  | ||||
|   uint8_t  bDeviceClass       ; ///< Class code (assigned by the USB-IF). \li If this field is reset to zero, each interface within a configuration specifies its own class information and the various interfaces operate independently. \li If this field is set to a value between 1 and FEH, the device supports different class specifications on different interfaces and the interfaces may not operate independently. This value identifies the class definition used for the aggregate interfaces. \li If this field is set to FFH, the device class is vendor-specific. | ||||
|   uint8_t  bDeviceSubClass    ; ///< Subclass code (assigned by the USB-IF). These codes are qualified by the value of the bDeviceClass field. \li If the bDeviceClass field is reset to zero, this field must also be reset to zero. \li If the bDeviceClass field is not set to FFH, all values are reserved for assignment by the USB-IF. | ||||
|   uint8_t  bDeviceProtocol    ; ///< Protocol code (assigned by the USB-IF). These codes are qualified by the value of the bDeviceClass and the bDeviceSubClass fields. If a device supports class-specific protocols on a device basis as opposed to an interface basis, this code identifies the protocols that the device uses as defined by the specification of the device class. \li If this field is reset to zero, the device does not use class-specific protocols on a device basis. However, it may use classspecific protocols on an interface basis. \li If this field is set to FFH, the device uses a vendor-specific protocol on a device basis. | ||||
|   uint8_t  bMaxPacketSize0    ; ///< Maximum packet size for endpoint zero (only 8, 16, 32, or 64 are valid). For HS devices is fixed to 64. | ||||
|  | ||||
|   uint16_t idVendor           ; ///< Vendor ID (assigned by the USB-IF). | ||||
|   uint16_t idProduct          ; ///< Product ID (assigned by the manufacturer). | ||||
|   uint16_t bcdDevice          ; ///< Device release number in binary-coded decimal. | ||||
|   uint8_t  iManufacturer      ; ///< Index of string descriptor describing manufacturer. | ||||
|   uint8_t  iProduct           ; ///< Index of string descriptor describing product. | ||||
|   uint8_t  iSerialNumber      ; ///< Index of string descriptor describing the device's serial number. | ||||
|  | ||||
|   uint8_t  bNumConfigurations ; ///< Number of possible configurations. | ||||
| } tusb_desc_device_t; | ||||
|  | ||||
| // USB Binary Device Object Store (BOS) Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength         ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType ; ///< CONFIGURATION Descriptor Type | ||||
|   uint16_t wTotalLength    ; ///< Total length of data returned for this descriptor | ||||
|   uint8_t  bNumDeviceCaps  ; ///< Number of device capability descriptors in the BOS | ||||
| } tusb_desc_bos_t; | ||||
|  | ||||
| /// USB Configuration Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength             ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType     ; ///< CONFIGURATION Descriptor Type | ||||
|   uint16_t wTotalLength        ; ///< Total length of data returned for this configuration. Includes the combined length of all descriptors (configuration, interface, endpoint, and class- or vendor-specific) returned for this configuration. | ||||
|  | ||||
|   uint8_t  bNumInterfaces      ; ///< Number of interfaces supported by this configuration | ||||
|   uint8_t  bConfigurationValue ; ///< Value to use as an argument to the SetConfiguration() request to select this configuration. | ||||
|   uint8_t  iConfiguration      ; ///< Index of string descriptor describing this configuration | ||||
|   uint8_t  bmAttributes        ; ///< Configuration characteristics \n D7: Reserved (set to one)\n D6: Self-powered \n D5: Remote Wakeup \n D4...0: Reserved (reset to zero) \n D7 is reserved and must be set to one for historical reasons. \n A device configuration that uses power from the bus and a local source reports a non-zero value in bMaxPower to indicate the amount of bus power required and sets D6. The actual power source at runtime may be determined using the GetStatus(DEVICE) request (see USB 2.0 spec Section 9.4.5). \n If a device configuration supports remote wakeup, D5 is set to one. | ||||
|   uint8_t  bMaxPower           ; ///< Maximum power consumption of the USB device from the bus in this specific configuration when the device is fully operational. Expressed in 2 mA units (i.e., 50 = 100 mA). | ||||
| } tusb_desc_configuration_t; | ||||
|  | ||||
| /// USB Interface Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength            ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType    ; ///< INTERFACE Descriptor Type | ||||
|  | ||||
|   uint8_t  bInterfaceNumber   ; ///< Number of this interface. Zero-based value identifying the index in the array of concurrent interfaces supported by this configuration. | ||||
|   uint8_t  bAlternateSetting  ; ///< Value used to select this alternate setting for the interface identified in the prior field | ||||
|   uint8_t  bNumEndpoints      ; ///< Number of endpoints used by this interface (excluding endpoint zero). If this value is zero, this interface only uses the Default Control Pipe. | ||||
|   uint8_t  bInterfaceClass    ; ///< Class code (assigned by the USB-IF). \li A value of zero is reserved for future standardization. \li If this field is set to FFH, the interface class is vendor-specific. \li All other values are reserved for assignment by the USB-IF. | ||||
|   uint8_t  bInterfaceSubClass ; ///< Subclass code (assigned by the USB-IF). \n These codes are qualified by the value of the bInterfaceClass field. \li If the bInterfaceClass field is reset to zero, this field must also be reset to zero. \li If the bInterfaceClass field is not set to FFH, all values are reserved for assignment by the USB-IF. | ||||
|   uint8_t  bInterfaceProtocol ; ///< Protocol code (assigned by the USB). \n These codes are qualified by the value of the bInterfaceClass and the bInterfaceSubClass fields. If an interface supports class-specific requests, this code identifies the protocols that the device uses as defined by the specification of the device class. \li If this field is reset to zero, the device does not use a class-specific protocol on this interface. \li If this field is set to FFH, the device uses a vendor-specific protocol for this interface. | ||||
|   uint8_t  iInterface         ; ///< Index of string descriptor describing this interface | ||||
| } tusb_desc_interface_t; | ||||
|  | ||||
| /// USB Endpoint Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength          ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType  ; ///< ENDPOINT Descriptor Type | ||||
|  | ||||
|   uint8_t  bEndpointAddress ; ///< The address of the endpoint on the USB device described by this descriptor. The address is encoded as follows: \n Bit 3...0: The endpoint number \n Bit 6...4: Reserved, reset to zero \n Bit 7: Direction, ignored for control endpoints 0 = OUT endpoint 1 = IN endpoint. | ||||
|  | ||||
|   struct TU_ATTR_PACKED { | ||||
|     uint8_t xfer  : 2; | ||||
|     uint8_t sync  : 2; | ||||
|     uint8_t usage : 2; | ||||
|     uint8_t       : 2; | ||||
|   } bmAttributes     ; ///< This field describes the endpoint's attributes when it is configured using the bConfigurationValue. \n Bits 1..0: Transfer Type \n- 00 = Control \n- 01 = Isochronous \n- 10 = Bulk \n- 11 = Interrupt \n If not an isochronous endpoint, bits 5..2 are reserved and must be set to zero. If isochronous, they are defined as follows: \n Bits 3..2: Synchronization Type \n- 00 = No Synchronization \n- 01 = Asynchronous \n- 10 = Adaptive \n- 11 = Synchronous \n Bits 5..4: Usage Type \n- 00 = Data endpoint \n- 01 = Feedback endpoint \n- 10 = Implicit feedback Data endpoint \n- 11 = Reserved \n Refer to Chapter 5 of USB 2.0 specification for more information. \n All other bits are reserved and must be reset to zero. Reserved bits must be ignored by the host. | ||||
|  | ||||
|   struct TU_ATTR_PACKED { | ||||
|     uint16_t size           : 11; ///< Maximum packet size this endpoint is capable of sending or receiving when this configuration is selected. \n For isochronous endpoints, this value is used to reserve the bus time in the schedule, required for the per-(micro)frame data payloads. The pipe may, on an ongoing basis, actually use less bandwidth than that reserved. The device reports, if necessary, the actual bandwidth used via its normal, non-USB defined mechanisms. \n For all endpoints, bits 10..0 specify the maximum packet size (in bytes). \n For high-speed isochronous and interrupt endpoints: \n Bits 12..11 specify the number of additional transaction opportunities per microframe: \n- 00 = None (1 transaction per microframe) \n- 01 = 1 additional (2 per microframe) \n- 10 = 2 additional (3 per microframe) \n- 11 = Reserved \n Bits 15..13 are reserved and must be set to zero. | ||||
|     uint16_t hs_period_mult : 2; | ||||
|     uint16_t : 0; | ||||
|   }wMaxPacketSize; | ||||
|  | ||||
|   uint8_t  bInterval        ; ///< Interval for polling endpoint for data transfers. Expressed in frames or microframes depending on the device operating speed (i.e., either 1 millisecond or 125 us units). \n- For full-/high-speed isochronous endpoints, this value must be in the range from 1 to 16. The bInterval value is used as the exponent for a \f$ 2^(bInterval-1) \f$ value; e.g., a bInterval of 4 means a period of 8 (\f$ 2^(4-1) \f$). \n- For full-/low-speed interrupt endpoints, the value of this field may be from 1 to 255. \n- For high-speed interrupt endpoints, the bInterval value is used as the exponent for a \f$ 2^(bInterval-1) \f$ value; e.g., a bInterval of 4 means a period of 8 (\f$ 2^(4-1) \f$) . This value must be from 1 to 16. \n- For high-speed bulk/control OUT endpoints, the bInterval must specify the maximum NAK rate of the endpoint. A value of 0 indicates the endpoint never NAKs. Other values indicate at most 1 NAK each bInterval number of microframes. This value must be in the range from 0 to 255. \n Refer to Chapter 5 of USB 2.0 specification for more information. | ||||
| } tusb_desc_endpoint_t; | ||||
|  | ||||
| /// USB Other Speed Configuration Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength             ; ///< Size of descriptor | ||||
|   uint8_t  bDescriptorType     ; ///< Other_speed_Configuration Type | ||||
|   uint16_t wTotalLength        ; ///< Total length of data returned | ||||
|  | ||||
|   uint8_t  bNumInterfaces      ; ///< Number of interfaces supported by this speed configuration | ||||
|   uint8_t  bConfigurationValue ; ///< Value to use to select configuration | ||||
|   uint8_t  IConfiguration      ; ///< Index of string descriptor | ||||
|   uint8_t  bmAttributes        ; ///< Same as Configuration descriptor | ||||
|   uint8_t  bMaxPower           ; ///< Same as Configuration descriptor | ||||
| } tusb_desc_other_speed_t; | ||||
|  | ||||
| /// USB Device Qualifier Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength            ; ///< Size of descriptor | ||||
|   uint8_t  bDescriptorType    ; ///< Device Qualifier Type | ||||
|   uint16_t bcdUSB             ; ///< USB specification version number (e.g., 0200H for V2.00) | ||||
|  | ||||
|   uint8_t  bDeviceClass       ; ///< Class Code | ||||
|   uint8_t  bDeviceSubClass    ; ///< SubClass Code | ||||
|   uint8_t  bDeviceProtocol    ; ///< Protocol Code | ||||
|   uint8_t  bMaxPacketSize0    ; ///< Maximum packet size for other speed | ||||
|   uint8_t  bNumConfigurations ; ///< Number of Other-speed Configurations | ||||
|   uint8_t  bReserved          ; ///< Reserved for future use, must be zero | ||||
| } tusb_desc_device_qualifier_t; | ||||
|  | ||||
| /// USB Interface Association Descriptor (IAD ECN) | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t bLength           ; ///< Size of descriptor | ||||
|   uint8_t bDescriptorType   ; ///< Other_speed_Configuration Type | ||||
|  | ||||
|   uint8_t bFirstInterface   ; ///< Index of the first associated interface. | ||||
|   uint8_t bInterfaceCount   ; ///< Total number of associated interfaces. | ||||
|  | ||||
|   uint8_t bFunctionClass    ; ///< Interface class ID. | ||||
|   uint8_t bFunctionSubClass ; ///< Interface subclass ID. | ||||
|   uint8_t bFunctionProtocol ; ///< Interface protocol ID. | ||||
|  | ||||
|   uint8_t iFunction         ; ///< Index of the string descriptor describing the interface association. | ||||
| } tusb_desc_interface_assoc_t; | ||||
|  | ||||
| // USB String Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength         ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType ; ///< Descriptor Type | ||||
|   uint16_t unicode_string[]; | ||||
| } tusb_desc_string_t; | ||||
|  | ||||
| // USB Binary Device Object Store (BOS) | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t bLength; | ||||
|   uint8_t bDescriptorType ; | ||||
|   uint8_t bDevCapabilityType; | ||||
|   uint8_t bReserved; | ||||
|   uint8_t PlatformCapabilityUUID[16]; | ||||
|   uint8_t CapabilityData[]; | ||||
| } tusb_desc_bos_platform_t; | ||||
|  | ||||
| // USB WebuSB URL Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t bLength; | ||||
|   uint8_t bDescriptorType; | ||||
|   uint8_t bScheme; | ||||
|   char    url[]; | ||||
| } tusb_desc_webusb_url_t; | ||||
|  | ||||
| /*------------------------------------------------------------------*/ | ||||
| /* Types | ||||
|  *------------------------------------------------------------------*/ | ||||
| typedef struct TU_ATTR_PACKED{ | ||||
|   union { | ||||
|     struct TU_ATTR_PACKED { | ||||
|       uint8_t recipient :  5; ///< Recipient type tusb_request_recipient_t. | ||||
|       uint8_t type      :  2; ///< Request type tusb_request_type_t. | ||||
|       uint8_t direction :  1; ///< Direction type. tusb_dir_t | ||||
|     } bmRequestType_bit; | ||||
|  | ||||
|     uint8_t bmRequestType; | ||||
|   }; | ||||
|  | ||||
|   uint8_t  bRequest; | ||||
|   uint16_t wValue; | ||||
|   uint16_t wIndex; | ||||
|   uint16_t wLength; | ||||
| } tusb_control_request_t; | ||||
|  | ||||
| TU_VERIFY_STATIC( sizeof(tusb_control_request_t) == 8, "mostly compiler option issue"); | ||||
|  | ||||
| // TODO move to somewhere suitable | ||||
| static inline uint8_t bm_request_type(uint8_t direction, uint8_t type, uint8_t recipient) | ||||
| { | ||||
|   return ((uint8_t) (direction << 7)) | ((uint8_t) (type << 5)) | (recipient); | ||||
| } | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Endpoint helper | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // Get direction from Endpoint address | ||||
| static inline tusb_dir_t tu_edpt_dir(uint8_t addr) | ||||
| { | ||||
|   return (addr & TUSB_DIR_IN_MASK) ? TUSB_DIR_IN : TUSB_DIR_OUT; | ||||
| } | ||||
|  | ||||
| // Get Endpoint number from address | ||||
| static inline uint8_t tu_edpt_number(uint8_t addr) | ||||
| { | ||||
|   return (uint8_t)(addr & (~TUSB_DIR_IN_MASK)); | ||||
| } | ||||
|  | ||||
| static inline uint8_t tu_edpt_addr(uint8_t num, uint8_t dir) | ||||
| { | ||||
|   return (uint8_t)(num | (dir ? TUSB_DIR_IN_MASK : 0)); | ||||
| } | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Descriptor helper | ||||
| //--------------------------------------------------------------------+ | ||||
| static inline uint8_t const * tu_desc_next(void const* desc) | ||||
| { | ||||
|   uint8_t const* desc8 = (uint8_t const*) desc; | ||||
|   return desc8 + desc8[DESC_OFFSET_LEN]; | ||||
| } | ||||
|  | ||||
| static inline uint8_t tu_desc_type(void const* desc) | ||||
| { | ||||
|   return ((uint8_t const*) desc)[DESC_OFFSET_TYPE]; | ||||
| } | ||||
|  | ||||
| static inline uint8_t tu_desc_len(void const* desc) | ||||
| { | ||||
|   return ((uint8_t const*) desc)[DESC_OFFSET_LEN]; | ||||
| } | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_TYPES_H_ */ | ||||
|  | ||||
| /** @} */ | ||||
| /*  | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2019 Ha Thach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * This file is part of the TinyUSB stack. | ||||
|  */ | ||||
|  | ||||
| /** \ingroup group_usb_definitions | ||||
|  *  \defgroup USBDef_Type USB Types | ||||
|  *  @{ */ | ||||
|  | ||||
| #ifndef _TUSB_TYPES_H_ | ||||
| #define _TUSB_TYPES_H_ | ||||
|  | ||||
| #include <stdbool.h> | ||||
| #include <stdint.h> | ||||
| #include "tusb_compiler.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| /*------------------------------------------------------------------*/ | ||||
| /* CONSTANTS | ||||
|  *------------------------------------------------------------------*/ | ||||
|  | ||||
| /// defined base on EHCI specs value for Endpoint Speed | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_SPEED_FULL = 0, | ||||
|   TUSB_SPEED_LOW     , | ||||
|   TUSB_SPEED_HIGH | ||||
| }tusb_speed_t; | ||||
|  | ||||
| /// defined base on USB Specs Endpoint's bmAttributes | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_XFER_CONTROL = 0 , | ||||
|   TUSB_XFER_ISOCHRONOUS , | ||||
|   TUSB_XFER_BULK        , | ||||
|   TUSB_XFER_INTERRUPT | ||||
| }tusb_xfer_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_DIR_OUT = 0, | ||||
|   TUSB_DIR_IN  = 1, | ||||
|  | ||||
|   TUSB_DIR_IN_MASK = 0x80 | ||||
| }tusb_dir_t; | ||||
|  | ||||
| /// USB Descriptor Types | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_DESC_DEVICE                = 0x01, | ||||
|   TUSB_DESC_CONFIGURATION         = 0x02, | ||||
|   TUSB_DESC_STRING                = 0x03, | ||||
|   TUSB_DESC_INTERFACE             = 0x04, | ||||
|   TUSB_DESC_ENDPOINT              = 0x05, | ||||
|   TUSB_DESC_DEVICE_QUALIFIER      = 0x06, | ||||
|   TUSB_DESC_OTHER_SPEED_CONFIG    = 0x07, | ||||
|   TUSB_DESC_INTERFACE_POWER       = 0x08, | ||||
|   TUSB_DESC_OTG                   = 0x09, | ||||
|   TUSB_DESC_DEBUG                 = 0x0A, | ||||
|   TUSB_DESC_INTERFACE_ASSOCIATION = 0x0B, | ||||
|  | ||||
|   TUSB_DESC_BOS                   = 0x0F, | ||||
|   TUSB_DESC_DEVICE_CAPABILITY     = 0x10, | ||||
|  | ||||
|   TUSB_DESC_FUNCTIONAL            = 0x21, | ||||
|  | ||||
|   // Class Specific Descriptor | ||||
|   TUSB_DESC_CS_DEVICE             = 0x21, | ||||
|   TUSB_DESC_CS_CONFIGURATION      = 0x22, | ||||
|   TUSB_DESC_CS_STRING             = 0x23, | ||||
|   TUSB_DESC_CS_INTERFACE          = 0x24, | ||||
|   TUSB_DESC_CS_ENDPOINT           = 0x25, | ||||
|  | ||||
|   TUSB_DESC_SUPERSPEED_ENDPOINT_COMPANION     = 0x30, | ||||
|   TUSB_DESC_SUPERSPEED_ISO_ENDPOINT_COMPANION = 0x31 | ||||
| }tusb_desc_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_REQ_GET_STATUS        = 0  , | ||||
|   TUSB_REQ_CLEAR_FEATURE     = 1  , | ||||
|   TUSB_REQ_RESERVED          = 2  , | ||||
|   TUSB_REQ_SET_FEATURE       = 3  , | ||||
|   TUSB_REQ_RESERVED2         = 4  , | ||||
|   TUSB_REQ_SET_ADDRESS       = 5  , | ||||
|   TUSB_REQ_GET_DESCRIPTOR    = 6  , | ||||
|   TUSB_REQ_SET_DESCRIPTOR    = 7  , | ||||
|   TUSB_REQ_GET_CONFIGURATION = 8  , | ||||
|   TUSB_REQ_SET_CONFIGURATION = 9  , | ||||
|   TUSB_REQ_GET_INTERFACE     = 10 , | ||||
|   TUSB_REQ_SET_INTERFACE     = 11 , | ||||
|   TUSB_REQ_SYNCH_FRAME       = 12 | ||||
| }tusb_request_code_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_REQ_FEATURE_EDPT_HALT     = 0, | ||||
|   TUSB_REQ_FEATURE_REMOTE_WAKEUP = 1, | ||||
|   TUSB_REQ_FEATURE_TEST_MODE     = 2 | ||||
| }tusb_request_feature_selector_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_REQ_TYPE_STANDARD = 0, | ||||
|   TUSB_REQ_TYPE_CLASS, | ||||
|   TUSB_REQ_TYPE_VENDOR, | ||||
|   TUSB_REQ_TYPE_INVALID | ||||
| } tusb_request_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_REQ_RCPT_DEVICE =0, | ||||
|   TUSB_REQ_RCPT_INTERFACE, | ||||
|   TUSB_REQ_RCPT_ENDPOINT, | ||||
|   TUSB_REQ_RCPT_OTHER | ||||
| } tusb_request_recipient_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_CLASS_UNSPECIFIED          = 0    , | ||||
|   TUSB_CLASS_AUDIO                = 1    , | ||||
|   TUSB_CLASS_CDC                  = 2    , | ||||
|   TUSB_CLASS_HID                  = 3    , | ||||
|   TUSB_CLASS_RESERVED_4           = 4    , | ||||
|   TUSB_CLASS_PHYSICAL             = 5    , | ||||
|   TUSB_CLASS_IMAGE                = 6    , | ||||
|   TUSB_CLASS_PRINTER              = 7    , | ||||
|   TUSB_CLASS_MSC                  = 8    , | ||||
|   TUSB_CLASS_HUB                  = 9    , | ||||
|   TUSB_CLASS_CDC_DATA             = 10   , | ||||
|   TUSB_CLASS_SMART_CARD           = 11   , | ||||
|   TUSB_CLASS_RESERVED_12          = 12   , | ||||
|   TUSB_CLASS_CONTENT_SECURITY     = 13   , | ||||
|   TUSB_CLASS_VIDEO                = 14   , | ||||
|   TUSB_CLASS_PERSONAL_HEALTHCARE  = 15   , | ||||
|   TUSB_CLASS_AUDIO_VIDEO          = 16   , | ||||
|  | ||||
|   TUSB_CLASS_DIAGNOSTIC           = 0xDC , | ||||
|   TUSB_CLASS_WIRELESS_CONTROLLER  = 0xE0 , | ||||
|   TUSB_CLASS_MISC                 = 0xEF , | ||||
|   TUSB_CLASS_APPLICATION_SPECIFIC = 0xFE , | ||||
|   TUSB_CLASS_VENDOR_SPECIFIC      = 0xFF | ||||
| }tusb_class_code_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   MISC_SUBCLASS_COMMON = 2 | ||||
| }misc_subclass_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   MISC_PROTOCOL_IAD = 1 | ||||
| }misc_protocol_type_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   DEVICE_CAPABILITY_WIRELESS_USB               = 0x01, | ||||
|   DEVICE_CAPABILITY_USB20_EXTENSION            = 0x02, | ||||
|   DEVICE_CAPABILITY_SUPERSPEED_USB             = 0x03, | ||||
|   DEVICE_CAPABILITY_CONTAINER_id               = 0x04, | ||||
|   DEVICE_CAPABILITY_PLATFORM                   = 0x05, | ||||
|   DEVICE_CAPABILITY_POWER_DELIVERY             = 0x06, | ||||
|   DEVICE_CAPABILITY_BATTERY_INFO               = 0x07, | ||||
|   DEVICE_CAPABILITY_PD_CONSUMER_PORT           = 0x08, | ||||
|   DEVICE_CAPABILITY_PD_PROVIDER_PORT           = 0x09, | ||||
|   DEVICE_CAPABILITY_SUPERSPEED_PLUS            = 0x0A, | ||||
|   DEVICE_CAPABILITY_PRECESION_TIME_MEASUREMENT = 0x0B, | ||||
|   DEVICE_CAPABILITY_WIRELESS_USB_EXT           = 0x0C, | ||||
|   DEVICE_CAPABILITY_BILLBOARD                  = 0x0D, | ||||
|   DEVICE_CAPABILITY_AUTHENTICATION             = 0x0E, | ||||
|   DEVICE_CAPABILITY_BILLBOARD_EX               = 0x0F, | ||||
|   DEVICE_CAPABILITY_CONFIGURATION_SUMMARY      = 0x10 | ||||
| }device_capability_type_t; | ||||
|  | ||||
| enum { | ||||
|   TUSB_DESC_CONFIG_ATT_REMOTE_WAKEUP = TU_BIT(5), | ||||
|   TUSB_DESC_CONFIG_ATT_SELF_POWERED  = TU_BIT(6), | ||||
| }; | ||||
|  | ||||
| #define TUSB_DESC_CONFIG_POWER_MA(x)  ((x)/2) | ||||
|  | ||||
| /// Device State TODO remove | ||||
| typedef enum | ||||
| { | ||||
|   TUSB_DEVICE_STATE_UNPLUG = 0  , | ||||
|   TUSB_DEVICE_STATE_CONFIGURED  , | ||||
|   TUSB_DEVICE_STATE_SUSPENDED   , | ||||
| }tusb_device_state_t; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   XFER_RESULT_SUCCESS, | ||||
|   XFER_RESULT_FAILED, | ||||
|   XFER_RESULT_STALLED, | ||||
| }xfer_result_t; | ||||
|  | ||||
| enum // TODO remove | ||||
| { | ||||
|   DESC_OFFSET_LEN  = 0, | ||||
|   DESC_OFFSET_TYPE = 1 | ||||
| }; | ||||
|  | ||||
| enum | ||||
| { | ||||
|   INTERFACE_INVALID_NUMBER = 0xff | ||||
| }; | ||||
|  | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   MS_OS_20_SET_HEADER_DESCRIPTOR       = 0x00, | ||||
|   MS_OS_20_SUBSET_HEADER_CONFIGURATION = 0x01, | ||||
|   MS_OS_20_SUBSET_HEADER_FUNCTION      = 0x02, | ||||
|   MS_OS_20_FEATURE_COMPATBLE_ID        = 0x03, | ||||
|   MS_OS_20_FEATURE_REG_PROPERTY        = 0x04, | ||||
|   MS_OS_20_FEATURE_MIN_RESUME_TIME     = 0x05, | ||||
|   MS_OS_20_FEATURE_MODEL_ID            = 0x06, | ||||
|   MS_OS_20_FEATURE_CCGP_DEVICE         = 0x07, | ||||
|   MS_OS_20_FEATURE_VENDOR_REVISION     = 0x08 | ||||
| } microsoft_os_20_type_t; | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // USB Descriptors | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| /// USB Device Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength            ; ///< Size of this descriptor in bytes. | ||||
|   uint8_t  bDescriptorType    ; ///< DEVICE Descriptor Type. | ||||
|   uint16_t bcdUSB             ; ///< BUSB Specification Release Number in Binary-Coded Decimal (i.e., 2.10 is 210H). This field identifies the release of the USB Specification with which the device and its descriptors are compliant. | ||||
|  | ||||
|   uint8_t  bDeviceClass       ; ///< Class code (assigned by the USB-IF). \li If this field is reset to zero, each interface within a configuration specifies its own class information and the various interfaces operate independently. \li If this field is set to a value between 1 and FEH, the device supports different class specifications on different interfaces and the interfaces may not operate independently. This value identifies the class definition used for the aggregate interfaces. \li If this field is set to FFH, the device class is vendor-specific. | ||||
|   uint8_t  bDeviceSubClass    ; ///< Subclass code (assigned by the USB-IF). These codes are qualified by the value of the bDeviceClass field. \li If the bDeviceClass field is reset to zero, this field must also be reset to zero. \li If the bDeviceClass field is not set to FFH, all values are reserved for assignment by the USB-IF. | ||||
|   uint8_t  bDeviceProtocol    ; ///< Protocol code (assigned by the USB-IF). These codes are qualified by the value of the bDeviceClass and the bDeviceSubClass fields. If a device supports class-specific protocols on a device basis as opposed to an interface basis, this code identifies the protocols that the device uses as defined by the specification of the device class. \li If this field is reset to zero, the device does not use class-specific protocols on a device basis. However, it may use classspecific protocols on an interface basis. \li If this field is set to FFH, the device uses a vendor-specific protocol on a device basis. | ||||
|   uint8_t  bMaxPacketSize0    ; ///< Maximum packet size for endpoint zero (only 8, 16, 32, or 64 are valid). For HS devices is fixed to 64. | ||||
|  | ||||
|   uint16_t idVendor           ; ///< Vendor ID (assigned by the USB-IF). | ||||
|   uint16_t idProduct          ; ///< Product ID (assigned by the manufacturer). | ||||
|   uint16_t bcdDevice          ; ///< Device release number in binary-coded decimal. | ||||
|   uint8_t  iManufacturer      ; ///< Index of string descriptor describing manufacturer. | ||||
|   uint8_t  iProduct           ; ///< Index of string descriptor describing product. | ||||
|   uint8_t  iSerialNumber      ; ///< Index of string descriptor describing the device's serial number. | ||||
|  | ||||
|   uint8_t  bNumConfigurations ; ///< Number of possible configurations. | ||||
| } tusb_desc_device_t; | ||||
|  | ||||
| // USB Binary Device Object Store (BOS) Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength         ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType ; ///< CONFIGURATION Descriptor Type | ||||
|   uint16_t wTotalLength    ; ///< Total length of data returned for this descriptor | ||||
|   uint8_t  bNumDeviceCaps  ; ///< Number of device capability descriptors in the BOS | ||||
| } tusb_desc_bos_t; | ||||
|  | ||||
| /// USB Configuration Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength             ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType     ; ///< CONFIGURATION Descriptor Type | ||||
|   uint16_t wTotalLength        ; ///< Total length of data returned for this configuration. Includes the combined length of all descriptors (configuration, interface, endpoint, and class- or vendor-specific) returned for this configuration. | ||||
|  | ||||
|   uint8_t  bNumInterfaces      ; ///< Number of interfaces supported by this configuration | ||||
|   uint8_t  bConfigurationValue ; ///< Value to use as an argument to the SetConfiguration() request to select this configuration. | ||||
|   uint8_t  iConfiguration      ; ///< Index of string descriptor describing this configuration | ||||
|   uint8_t  bmAttributes        ; ///< Configuration characteristics \n D7: Reserved (set to one)\n D6: Self-powered \n D5: Remote Wakeup \n D4...0: Reserved (reset to zero) \n D7 is reserved and must be set to one for historical reasons. \n A device configuration that uses power from the bus and a local source reports a non-zero value in bMaxPower to indicate the amount of bus power required and sets D6. The actual power source at runtime may be determined using the GetStatus(DEVICE) request (see USB 2.0 spec Section 9.4.5). \n If a device configuration supports remote wakeup, D5 is set to one. | ||||
|   uint8_t  bMaxPower           ; ///< Maximum power consumption of the USB device from the bus in this specific configuration when the device is fully operational. Expressed in 2 mA units (i.e., 50 = 100 mA). | ||||
| } tusb_desc_configuration_t; | ||||
|  | ||||
| /// USB Interface Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength            ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType    ; ///< INTERFACE Descriptor Type | ||||
|  | ||||
|   uint8_t  bInterfaceNumber   ; ///< Number of this interface. Zero-based value identifying the index in the array of concurrent interfaces supported by this configuration. | ||||
|   uint8_t  bAlternateSetting  ; ///< Value used to select this alternate setting for the interface identified in the prior field | ||||
|   uint8_t  bNumEndpoints      ; ///< Number of endpoints used by this interface (excluding endpoint zero). If this value is zero, this interface only uses the Default Control Pipe. | ||||
|   uint8_t  bInterfaceClass    ; ///< Class code (assigned by the USB-IF). \li A value of zero is reserved for future standardization. \li If this field is set to FFH, the interface class is vendor-specific. \li All other values are reserved for assignment by the USB-IF. | ||||
|   uint8_t  bInterfaceSubClass ; ///< Subclass code (assigned by the USB-IF). \n These codes are qualified by the value of the bInterfaceClass field. \li If the bInterfaceClass field is reset to zero, this field must also be reset to zero. \li If the bInterfaceClass field is not set to FFH, all values are reserved for assignment by the USB-IF. | ||||
|   uint8_t  bInterfaceProtocol ; ///< Protocol code (assigned by the USB). \n These codes are qualified by the value of the bInterfaceClass and the bInterfaceSubClass fields. If an interface supports class-specific requests, this code identifies the protocols that the device uses as defined by the specification of the device class. \li If this field is reset to zero, the device does not use a class-specific protocol on this interface. \li If this field is set to FFH, the device uses a vendor-specific protocol for this interface. | ||||
|   uint8_t  iInterface         ; ///< Index of string descriptor describing this interface | ||||
| } tusb_desc_interface_t; | ||||
|  | ||||
| /// USB Endpoint Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength          ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType  ; ///< ENDPOINT Descriptor Type | ||||
|  | ||||
|   uint8_t  bEndpointAddress ; ///< The address of the endpoint on the USB device described by this descriptor. The address is encoded as follows: \n Bit 3...0: The endpoint number \n Bit 6...4: Reserved, reset to zero \n Bit 7: Direction, ignored for control endpoints 0 = OUT endpoint 1 = IN endpoint. | ||||
|  | ||||
|   struct TU_ATTR_PACKED { | ||||
|     uint8_t xfer  : 2; | ||||
|     uint8_t sync  : 2; | ||||
|     uint8_t usage : 2; | ||||
|     uint8_t       : 2; | ||||
|   } bmAttributes     ; ///< This field describes the endpoint's attributes when it is configured using the bConfigurationValue. \n Bits 1..0: Transfer Type \n- 00 = Control \n- 01 = Isochronous \n- 10 = Bulk \n- 11 = Interrupt \n If not an isochronous endpoint, bits 5..2 are reserved and must be set to zero. If isochronous, they are defined as follows: \n Bits 3..2: Synchronization Type \n- 00 = No Synchronization \n- 01 = Asynchronous \n- 10 = Adaptive \n- 11 = Synchronous \n Bits 5..4: Usage Type \n- 00 = Data endpoint \n- 01 = Feedback endpoint \n- 10 = Implicit feedback Data endpoint \n- 11 = Reserved \n Refer to Chapter 5 of USB 2.0 specification for more information. \n All other bits are reserved and must be reset to zero. Reserved bits must be ignored by the host. | ||||
|  | ||||
|   struct TU_ATTR_PACKED { | ||||
|     uint16_t size           : 11; ///< Maximum packet size this endpoint is capable of sending or receiving when this configuration is selected. \n For isochronous endpoints, this value is used to reserve the bus time in the schedule, required for the per-(micro)frame data payloads. The pipe may, on an ongoing basis, actually use less bandwidth than that reserved. The device reports, if necessary, the actual bandwidth used via its normal, non-USB defined mechanisms. \n For all endpoints, bits 10..0 specify the maximum packet size (in bytes). \n For high-speed isochronous and interrupt endpoints: \n Bits 12..11 specify the number of additional transaction opportunities per microframe: \n- 00 = None (1 transaction per microframe) \n- 01 = 1 additional (2 per microframe) \n- 10 = 2 additional (3 per microframe) \n- 11 = Reserved \n Bits 15..13 are reserved and must be set to zero. | ||||
|     uint16_t hs_period_mult : 2; | ||||
|     uint16_t : 0; | ||||
|   }wMaxPacketSize; | ||||
|  | ||||
|   uint8_t  bInterval        ; ///< Interval for polling endpoint for data transfers. Expressed in frames or microframes depending on the device operating speed (i.e., either 1 millisecond or 125 us units). \n- For full-/high-speed isochronous endpoints, this value must be in the range from 1 to 16. The bInterval value is used as the exponent for a \f$ 2^(bInterval-1) \f$ value; e.g., a bInterval of 4 means a period of 8 (\f$ 2^(4-1) \f$). \n- For full-/low-speed interrupt endpoints, the value of this field may be from 1 to 255. \n- For high-speed interrupt endpoints, the bInterval value is used as the exponent for a \f$ 2^(bInterval-1) \f$ value; e.g., a bInterval of 4 means a period of 8 (\f$ 2^(4-1) \f$) . This value must be from 1 to 16. \n- For high-speed bulk/control OUT endpoints, the bInterval must specify the maximum NAK rate of the endpoint. A value of 0 indicates the endpoint never NAKs. Other values indicate at most 1 NAK each bInterval number of microframes. This value must be in the range from 0 to 255. \n Refer to Chapter 5 of USB 2.0 specification for more information. | ||||
| } tusb_desc_endpoint_t; | ||||
|  | ||||
| /// USB Other Speed Configuration Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength             ; ///< Size of descriptor | ||||
|   uint8_t  bDescriptorType     ; ///< Other_speed_Configuration Type | ||||
|   uint16_t wTotalLength        ; ///< Total length of data returned | ||||
|  | ||||
|   uint8_t  bNumInterfaces      ; ///< Number of interfaces supported by this speed configuration | ||||
|   uint8_t  bConfigurationValue ; ///< Value to use to select configuration | ||||
|   uint8_t  IConfiguration      ; ///< Index of string descriptor | ||||
|   uint8_t  bmAttributes        ; ///< Same as Configuration descriptor | ||||
|   uint8_t  bMaxPower           ; ///< Same as Configuration descriptor | ||||
| } tusb_desc_other_speed_t; | ||||
|  | ||||
| /// USB Device Qualifier Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength            ; ///< Size of descriptor | ||||
|   uint8_t  bDescriptorType    ; ///< Device Qualifier Type | ||||
|   uint16_t bcdUSB             ; ///< USB specification version number (e.g., 0200H for V2.00) | ||||
|  | ||||
|   uint8_t  bDeviceClass       ; ///< Class Code | ||||
|   uint8_t  bDeviceSubClass    ; ///< SubClass Code | ||||
|   uint8_t  bDeviceProtocol    ; ///< Protocol Code | ||||
|   uint8_t  bMaxPacketSize0    ; ///< Maximum packet size for other speed | ||||
|   uint8_t  bNumConfigurations ; ///< Number of Other-speed Configurations | ||||
|   uint8_t  bReserved          ; ///< Reserved for future use, must be zero | ||||
| } tusb_desc_device_qualifier_t; | ||||
|  | ||||
| /// USB Interface Association Descriptor (IAD ECN) | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t bLength           ; ///< Size of descriptor | ||||
|   uint8_t bDescriptorType   ; ///< Other_speed_Configuration Type | ||||
|  | ||||
|   uint8_t bFirstInterface   ; ///< Index of the first associated interface. | ||||
|   uint8_t bInterfaceCount   ; ///< Total number of associated interfaces. | ||||
|  | ||||
|   uint8_t bFunctionClass    ; ///< Interface class ID. | ||||
|   uint8_t bFunctionSubClass ; ///< Interface subclass ID. | ||||
|   uint8_t bFunctionProtocol ; ///< Interface protocol ID. | ||||
|  | ||||
|   uint8_t iFunction         ; ///< Index of the string descriptor describing the interface association. | ||||
| } tusb_desc_interface_assoc_t; | ||||
|  | ||||
| // USB String Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t  bLength         ; ///< Size of this descriptor in bytes | ||||
|   uint8_t  bDescriptorType ; ///< Descriptor Type | ||||
|   uint16_t unicode_string[]; | ||||
| } tusb_desc_string_t; | ||||
|  | ||||
| // USB Binary Device Object Store (BOS) | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t bLength; | ||||
|   uint8_t bDescriptorType ; | ||||
|   uint8_t bDevCapabilityType; | ||||
|   uint8_t bReserved; | ||||
|   uint8_t PlatformCapabilityUUID[16]; | ||||
|   uint8_t CapabilityData[]; | ||||
| } tusb_desc_bos_platform_t; | ||||
|  | ||||
| // USB WebuSB URL Descriptor | ||||
| typedef struct TU_ATTR_PACKED | ||||
| { | ||||
|   uint8_t bLength; | ||||
|   uint8_t bDescriptorType; | ||||
|   uint8_t bScheme; | ||||
|   char    url[]; | ||||
| } tusb_desc_webusb_url_t; | ||||
|  | ||||
| /*------------------------------------------------------------------*/ | ||||
| /* Types | ||||
|  *------------------------------------------------------------------*/ | ||||
| typedef struct TU_ATTR_PACKED{ | ||||
|   union { | ||||
|     struct TU_ATTR_PACKED { | ||||
|       uint8_t recipient :  5; ///< Recipient type tusb_request_recipient_t. | ||||
|       uint8_t type      :  2; ///< Request type tusb_request_type_t. | ||||
|       uint8_t direction :  1; ///< Direction type. tusb_dir_t | ||||
|     } bmRequestType_bit; | ||||
|  | ||||
|     uint8_t bmRequestType; | ||||
|   }; | ||||
|  | ||||
|   uint8_t  bRequest; | ||||
|   uint16_t wValue; | ||||
|   uint16_t wIndex; | ||||
|   uint16_t wLength; | ||||
| } tusb_control_request_t; | ||||
|  | ||||
| TU_VERIFY_STATIC( sizeof(tusb_control_request_t) == 8, "mostly compiler option issue"); | ||||
|  | ||||
| // TODO move to somewhere suitable | ||||
| static inline uint8_t bm_request_type(uint8_t direction, uint8_t type, uint8_t recipient) | ||||
| { | ||||
|   return ((uint8_t) (direction << 7)) | ((uint8_t) (type << 5)) | (recipient); | ||||
| } | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Endpoint helper | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // Get direction from Endpoint address | ||||
| static inline tusb_dir_t tu_edpt_dir(uint8_t addr) | ||||
| { | ||||
|   return (addr & TUSB_DIR_IN_MASK) ? TUSB_DIR_IN : TUSB_DIR_OUT; | ||||
| } | ||||
|  | ||||
| // Get Endpoint number from address | ||||
| static inline uint8_t tu_edpt_number(uint8_t addr) | ||||
| { | ||||
|   return (uint8_t)(addr & (~TUSB_DIR_IN_MASK)); | ||||
| } | ||||
|  | ||||
| static inline uint8_t tu_edpt_addr(uint8_t num, uint8_t dir) | ||||
| { | ||||
|   return (uint8_t)(num | (dir ? TUSB_DIR_IN_MASK : 0)); | ||||
| } | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // Descriptor helper | ||||
| //--------------------------------------------------------------------+ | ||||
| static inline uint8_t const * tu_desc_next(void const* desc) | ||||
| { | ||||
|   uint8_t const* desc8 = (uint8_t const*) desc; | ||||
|   return desc8 + desc8[DESC_OFFSET_LEN]; | ||||
| } | ||||
|  | ||||
| static inline uint8_t tu_desc_type(void const* desc) | ||||
| { | ||||
|   return ((uint8_t const*) desc)[DESC_OFFSET_TYPE]; | ||||
| } | ||||
|  | ||||
| static inline uint8_t tu_desc_len(void const* desc) | ||||
| { | ||||
|   return ((uint8_t const*) desc)[DESC_OFFSET_LEN]; | ||||
| } | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|  | ||||
| #endif /* _TUSB_TYPES_H_ */ | ||||
|  | ||||
| /** @} */ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Nathan Conrad
					Nathan Conrad