rttypes.h 9.2 KB

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