rttypes.h 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. /*
  2. * Copyright (c) 2006-2024, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2024-01-18 Shell Separate the basic types from rtdef.h
  9. */
  10. #ifndef __RT_TYPES_H__
  11. #define __RT_TYPES_H__
  12. #include <rtconfig.h>
  13. #include <stdint.h>
  14. #include <stddef.h>
  15. #include <stdarg.h>
  16. #ifndef RT_USING_NANO
  17. #include <sys/types.h>
  18. #include <sys/errno.h>
  19. #if defined(RT_USING_SIGNALS) || defined(RT_USING_SMART)
  20. #include <sys/signal.h>
  21. #endif /* defined(RT_USING_SIGNALS) || defined(RT_USING_SMART) */
  22. #endif /* RT_USING_NANO */
  23. #ifdef __cplusplus
  24. extern "C" {
  25. #endif
  26. /**
  27. * RT-Thread basic data types definition
  28. */
  29. #if defined(_WIN64) || defined(__x86_64__)
  30. #ifndef ARCH_CPU_64BIT
  31. #define ARCH_CPU_64BIT
  32. #endif // ARCH_CPU_64BIT
  33. #endif // defined(_WIN64) || defined(__x86_64__)
  34. typedef int rt_bool_t; /**< boolean type */
  35. #ifndef RT_USING_ARCH_DATA_TYPE
  36. #ifdef RT_USING_LIBC
  37. typedef int8_t rt_int8_t; /**< 8bit integer type */
  38. typedef int16_t rt_int16_t; /**< 16bit integer type */
  39. typedef int32_t rt_int32_t; /**< 32bit integer type */
  40. typedef uint8_t rt_uint8_t; /**< 8bit unsigned integer type */
  41. typedef uint16_t rt_uint16_t; /**< 16bit unsigned integer type */
  42. typedef uint32_t rt_uint32_t; /**< 32bit unsigned integer type */
  43. typedef int64_t rt_int64_t; /**< 64bit integer type */
  44. typedef uint64_t rt_uint64_t; /**< 64bit unsigned integer type */
  45. #else
  46. typedef signed char rt_int8_t; /**< 8bit integer type */
  47. typedef signed short rt_int16_t; /**< 16bit integer type */
  48. typedef signed int rt_int32_t; /**< 32bit integer type */
  49. typedef unsigned char rt_uint8_t; /**< 8bit unsigned integer type */
  50. typedef unsigned short rt_uint16_t; /**< 16bit unsigned integer type */
  51. typedef unsigned int rt_uint32_t; /**< 32bit unsigned integer type */
  52. #ifdef ARCH_CPU_64BIT
  53. typedef signed long rt_int64_t; /**< 64bit integer type */
  54. typedef unsigned long rt_uint64_t; /**< 64bit unsigned integer type */
  55. #else
  56. typedef signed long long rt_int64_t; /**< 64bit integer type */
  57. typedef unsigned long long rt_uint64_t; /**< 64bit unsigned integer type */
  58. #endif /* ARCH_CPU_64BIT */
  59. #endif /* RT_USING_LIBC */
  60. #endif /* RT_USING_ARCH_DATA_TYPE */
  61. #ifdef ARCH_CPU_64BIT
  62. typedef rt_int64_t rt_base_t; /**< Nbit CPU related data type */
  63. typedef rt_uint64_t rt_ubase_t; /**< Nbit unsigned CPU related data type */
  64. #else
  65. typedef rt_int32_t rt_base_t; /**< Nbit CPU related data type */
  66. typedef rt_uint32_t rt_ubase_t; /**< Nbit unsigned CPU related data type */
  67. #endif
  68. #if defined(RT_USING_LIBC) && !defined(RT_USING_NANO)
  69. typedef size_t rt_size_t; /**< Type for size number */
  70. typedef ssize_t rt_ssize_t; /**< Used for a count of bytes or an error indication */
  71. typedef intptr_t rt_intptr_t; /**< Type for signed pointer length integer */
  72. typedef uintptr_t rt_uintptr_t; /**< Type for unsigned pointer length integer */
  73. #else
  74. typedef rt_ubase_t rt_size_t; /**< Type for size number */
  75. typedef rt_base_t rt_ssize_t; /**< Used for a count of bytes or an error indication */
  76. typedef rt_base_t rt_intptr_t; /**< Type for signed pointer length integer */
  77. typedef rt_ubase_t rt_uintptr_t; /**< Type for unsigned pointer length integer */
  78. #endif /* defined(RT_USING_LIBC) && !defined(RT_USING_NANO) */
  79. typedef rt_base_t rt_err_t; /**< Type for error number */
  80. typedef rt_uint32_t rt_time_t; /**< Type for time stamp */
  81. typedef rt_uint32_t rt_tick_t; /**< Type for tick count */
  82. typedef rt_base_t rt_flag_t; /**< Type for flags */
  83. typedef rt_ubase_t rt_dev_t; /**< Type for device */
  84. typedef rt_base_t rt_off_t; /**< Type for offset */
  85. #if defined(RT_USING_STDC_ATOMIC) && __STDC_VERSION__ < 201112L
  86. #undef RT_USING_STDC_ATOMIC
  87. #warning Not using C11 or beyond! Maybe you should change the -std option on your compiler
  88. #endif
  89. #ifdef __cplusplus
  90. typedef rt_base_t rt_atomic_t;
  91. #else
  92. #if defined(RT_USING_STDC_ATOMIC)
  93. #include <stdatomic.h>
  94. typedef _Atomic(rt_base_t) rt_atomic_t;
  95. #elif defined(RT_USING_HW_ATOMIC)
  96. typedef rt_base_t rt_atomic_t;
  97. #else
  98. typedef rt_base_t rt_atomic_t;
  99. #endif /* RT_USING_STDC_ATOMIC */
  100. #endif /* __cplusplus */
  101. /* boolean type definitions */
  102. #define RT_TRUE 1 /**< boolean true */
  103. #define RT_FALSE 0 /**< boolean fails */
  104. /* null pointer definition */
  105. #define RT_NULL 0
  106. /**
  107. * Double List structure
  108. */
  109. struct rt_list_node
  110. {
  111. struct rt_list_node *next; /**< point to next node. */
  112. struct rt_list_node *prev; /**< point to prev node. */
  113. };
  114. typedef struct rt_list_node rt_list_t; /**< Type for lists. */
  115. /**
  116. * Single List structure
  117. */
  118. struct rt_slist_node
  119. {
  120. struct rt_slist_node *next; /**< point to next node. */
  121. };
  122. typedef struct rt_slist_node rt_slist_t; /**< Type for single list. */
  123. /**
  124. * Lock-less Single List structure
  125. */
  126. struct rt_lockless_slist_node
  127. {
  128. rt_atomic_t next; /**< point to next node. */
  129. };
  130. typedef struct rt_lockless_slist_node rt_ll_slist_t; /**< Type for lock-les single list. */
  131. /**
  132. * Spinlock
  133. */
  134. #ifdef RT_USING_SMP
  135. #include <cpuport.h> /* for spinlock from arch */
  136. struct rt_spinlock
  137. {
  138. rt_hw_spinlock_t lock;
  139. #ifdef RT_USING_DEBUG
  140. rt_uint32_t critical_level;
  141. #endif /* RT_USING_DEBUG */
  142. #if defined(RT_DEBUGING_SPINLOCK)
  143. void *owner;
  144. void *pc;
  145. #endif /* RT_DEBUGING_SPINLOCK */
  146. };
  147. #ifndef RT_SPINLOCK_INIT
  148. #define RT_SPINLOCK_INIT {{0}} /* can be overridden by cpuport.h */
  149. #endif /* RT_SPINLOCK_INIT */
  150. #else /* !RT_USING_SMP */
  151. struct rt_spinlock
  152. {
  153. #ifdef RT_USING_DEBUG
  154. rt_uint32_t critical_level;
  155. #endif /* RT_USING_DEBUG */
  156. rt_ubase_t lock;
  157. };
  158. #define RT_SPINLOCK_INIT {0}
  159. #endif /* RT_USING_SMP */
  160. #if defined(RT_DEBUGING_SPINLOCK) && defined(RT_USING_SMP)
  161. #define __OWNER_MAGIC ((void *)0xdeadbeaf)
  162. #if defined(__GNUC__)
  163. #define __GET_RETURN_ADDRESS __builtin_return_address(0)
  164. #else /* !__GNUC__ */
  165. #define __GET_RETURN_ADDRESS RT_NULL
  166. #endif /* __GNUC__ */
  167. #define _SPIN_LOCK_DEBUG_OWNER(lock) \
  168. do \
  169. { \
  170. struct rt_thread *_curthr = rt_thread_self(); \
  171. if (_curthr != RT_NULL) \
  172. { \
  173. (lock)->owner = _curthr; \
  174. (lock)->pc = __GET_RETURN_ADDRESS; \
  175. } \
  176. } while (0)
  177. #define _SPIN_UNLOCK_DEBUG_OWNER(lock) \
  178. do \
  179. { \
  180. (lock)->owner = __OWNER_MAGIC; \
  181. (lock)->pc = RT_NULL; \
  182. } while (0)
  183. #else /* !RT_DEBUGING_SPINLOCK */
  184. #define _SPIN_LOCK_DEBUG_OWNER(lock) RT_UNUSED(lock)
  185. #define _SPIN_UNLOCK_DEBUG_OWNER(lock) RT_UNUSED(lock)
  186. #endif /* RT_DEBUGING_SPINLOCK */
  187. #ifdef RT_DEBUGING_CRITICAL
  188. #define _SPIN_LOCK_DEBUG_CRITICAL(lock) \
  189. do \
  190. { \
  191. (lock)->critical_level = rt_critical_level(); \
  192. } while (0)
  193. #define _SPIN_UNLOCK_DEBUG_CRITICAL(lock, critical) \
  194. do \
  195. { \
  196. (critical) = (lock)->critical_level; \
  197. } while (0)
  198. #else /* !RT_DEBUGING_CRITICAL */
  199. #define _SPIN_LOCK_DEBUG_CRITICAL(lock) RT_UNUSED(lock)
  200. #define _SPIN_UNLOCK_DEBUG_CRITICAL(lock, critical) do {critical = 0; RT_UNUSED(lock);} while (0)
  201. #endif /* RT_DEBUGING_CRITICAL */
  202. #define RT_SPIN_LOCK_DEBUG(lock) \
  203. do \
  204. { \
  205. _SPIN_LOCK_DEBUG_OWNER(lock); \
  206. _SPIN_LOCK_DEBUG_CRITICAL(lock); \
  207. } while (0)
  208. #define RT_SPIN_UNLOCK_DEBUG(lock, critical) \
  209. do \
  210. { \
  211. _SPIN_UNLOCK_DEBUG_OWNER(lock); \
  212. _SPIN_UNLOCK_DEBUG_CRITICAL(lock, critical); \
  213. } while (0)
  214. typedef struct rt_spinlock rt_spinlock_t;
  215. #define RT_DEFINE_SPINLOCK(x) struct rt_spinlock x = RT_SPINLOCK_INIT
  216. #ifdef __cplusplus
  217. }
  218. #endif
  219. #endif /* __RT_TYPES_H__ */