bsp_common.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  1. /*
  2. * Copyright (c) 2022 OpenLuat & AirM2M
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a copy of
  5. * this software and associated documentation files (the "Software"), to deal in
  6. * the Software without restriction, including without limitation the rights to
  7. * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  8. * the Software, and to permit persons to whom the Software is furnished to do so,
  9. * subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in all
  12. * copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  16. * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  17. * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  18. * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  19. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  20. */
  21. #ifndef __BSP_COMMON_H__
  22. #define __BSP_COMMON_H__
  23. #include <string.h>
  24. #include <stdio.h>
  25. #include <stdlib.h>
  26. #include <stdint.h>
  27. #include <stdarg.h>
  28. #include "cmsis_gcc.h"
  29. typedef struct
  30. {
  31. uint32_t MaigcNum; //升级包标识,标识不对直接抛弃
  32. uint32_t CRC32; //后续字节的CRC32校验,所有CRC32规则与ZIP压缩一致
  33. uint32_t Param1; //升级参数,其中byte0升级类型,byte1升级包存放位置,byte2外设总线序号,和platform_define里的外设序号一致
  34. uint32_t Param2; //额外的参数,需要和外置存储总线配合使用,一般是外置存储总线的PIN
  35. uint32_t DataStartAddress;//升级包在flash中的起始地址,外部和内部都可以用
  36. uint32_t DataLen;//升级包大小
  37. uint32_t DataCRC32;//升级包整包数据的CRC32
  38. char FilePath[100];//升级包在文件系统中的绝对路径,如果在flash中则随意填写
  39. }CoreUpgrade_HeadStruct;
  40. typedef struct
  41. {
  42. uint32_t param_max_num;
  43. uint32_t param_max_len;
  44. uint32_t param_num;
  45. int8_t *param_str;
  46. }CmdParam;
  47. typedef struct
  48. {
  49. uint8_t Sec;
  50. uint8_t Min;
  51. uint8_t Hour;
  52. uint8_t Week;//表示日期0~6,sun~sat,表示预约时,bit0~bit6,sun~sat
  53. }Time_UserDataStruct;
  54. typedef struct
  55. {
  56. uint16_t Year;
  57. uint8_t Mon;
  58. uint8_t Day;
  59. }Date_UserDataStruct;
  60. typedef union
  61. {
  62. uint32_t dwTime;
  63. Time_UserDataStruct Time;
  64. }Time_Union;
  65. typedef union
  66. {
  67. uint32_t dwDate;
  68. Date_UserDataStruct Date;
  69. }Date_Union;
  70. typedef struct
  71. {
  72. uint8_t *Data;
  73. uint32_t Len;
  74. uint32_t Offset;
  75. uint32_t MaxLength;
  76. uint32_t DataSize;
  77. }Loop_Buffer;
  78. typedef struct
  79. {
  80. uint8_t *Data;
  81. uint32_t Pos;
  82. uint32_t MaxLen;
  83. }Buffer_Struct;
  84. typedef struct
  85. {
  86. uint8_t *pCache[2];
  87. uint32_t pCacheLen[2];
  88. uint32_t MaxLen;
  89. uint8_t CurCacheSn;
  90. }DBuffer_Struct;
  91. typedef union
  92. {
  93. void *p;
  94. char *pc8;
  95. uint8_t *pu8;
  96. uint16_t *pu16;
  97. uint32_t *pu32;
  98. uint32_t u32;
  99. uint8_t u8[4];
  100. uint16_t u16[2];
  101. }PV_Union;
  102. enum
  103. {
  104. ERROR_NONE,
  105. ERROR_NO_SUCH_ID,
  106. ERROR_PERMISSION_DENIED,
  107. ERROR_PARAM_INVALID,
  108. ERROR_PARAM_OVERFLOW,
  109. ERROR_DEVICE_BUSY,
  110. ERROR_OPERATION_FAILED,
  111. ERROR_BUFFER_FULL,
  112. ERROR_NO_MEMORY,
  113. ERROR_CMD_NOT_SUPPORT,
  114. ERROR_NO_DATA,
  115. ERROR_NO_FLASH,
  116. ERROR_NO_TIMER,
  117. ERROR_TIMEOUT,
  118. ERROR_SSL_HANDSHAKE,
  119. ERROR_PROTOCL,
  120. ERROR_ID_INVALID,
  121. ERROR_MID_INVALID,
  122. ERROR_RETRY_TOO_MUCH,
  123. ERROR_CMD_BLOCK,
  124. LIST_FIND = 1,
  125. LIST_PASS = 0,
  126. LIST_DEL = -1,
  127. DMA_CB_DONE = 0,
  128. UART_CB_TX_BUFFER_DONE,
  129. UART_CB_TX_ALL_DONE,
  130. UART_CB_RX_NEW,
  131. UART_CB_RX_TIMEOUT,
  132. UART_CB_RX_BUFFER_FULL,
  133. UART_CB_ERROR,
  134. UART_CB_CONNECTED, //串口工具对方已经打开
  135. DMA_CB_ERROR = 0xffffffff,
  136. CORE_EVENT_ID_ANY = 0,
  137. CORE_EVENT_ID_START = 0xf0000000,
  138. CORE_EVENT_TIMEOUT,
  139. CORE_TIMER_TIMEOUT = 0xf0010000,
  140. SERVICE_EVENT_ID_START = 0xf0100000,
  141. DEV_EVENT_ID_START = 0xf0200000,
  142. DEV_SPIFLASH_SPI_DONE,
  143. DEV_SDHC_SPI_DONE,
  144. USB_APP_EVENT_ID_START = 0xf0300000,
  145. USER_EVENT_ID_START = 0xf1000000,
  146. INVALID_EVENT_ID = 0xffffffff,
  147. };
  148. #define INVALID_HANDLE_VALUE ((void *)0xffffffff)
  149. #define INVALID_PARAM (0xffffffff)
  150. #define CRC32_GEN (0x04C11DB7)
  151. #define CRC32_START (0xffffffff)
  152. #define CRC16_CCITT_GEN (0x1021)
  153. #define CRC16_MODBUS_GEN (0x8005)
  154. #define CRC16_START (0xffff)
  155. #define CRC16_IBM_SEED (0xffff)
  156. #define CRC16_CCITT_SEED (0x1D0F)
  157. #define HANDLE void *
  158. #define BIT(n) (1UL << (n))
  159. #define MIN(X,Y) (((X) < (Y))?(X):(Y))
  160. typedef void (* TaskFun_t)( void * );
  161. typedef void (* CommonFun_t)(void);
  162. typedef void(* CBDataFun_t)(uint8_t *Data, uint32_t Len);
  163. typedef int32_t(*CBFuncEx_t)(void *pData, void *pParam);
  164. typedef uint64_t LongInt;
  165. #define INIT_FUN_EXPORT(fn, location, level) const CommonFun_t __ex_init_##fn __attribute__((section(location level))) = fn
  166. #define INIT_HW_EXPORT(fn, level) INIT_FUN_EXPORT(fn, ".preinit_fun_array.", level)
  167. #define INIT_DRV_EXPORT(fn, level) INIT_FUN_EXPORT(fn, ".init_fun_array.", level)
  168. #define INIT_TASK_EXPORT(fn, level) INIT_FUN_EXPORT(fn, ".task_fun_array.", level)
  169. /* board init routines will be called in board_init() function */
  170. #define INIT_BOARD_EXPORT(fn) INIT_EXPORT(fn, "1")
  171. /* pre/device/component/env/app init routines will be called in init_thread */
  172. /* components pre-initialization (pure software initilization) */
  173. #define INIT_PREV_EXPORT(fn) INIT_EXPORT(fn, "2")
  174. /* device initialization */
  175. #define INIT_DEVICE_EXPORT(fn) INIT_EXPORT(fn, "3")
  176. /* components initialization (dfs, lwip, ...) */
  177. #define INIT_COMPONENT_EXPORT(fn) INIT_EXPORT(fn, "4")
  178. /* environment initialization (mount disk, ...) */
  179. #define INIT_ENV_EXPORT(fn) INIT_EXPORT(fn, "5")
  180. /* appliation initialization (rtgui application etc ...) */
  181. #define INIT_APP_EXPORT(fn) INIT_EXPORT(fn, "6")
  182. typedef struct
  183. {
  184. CBFuncEx_t CB;
  185. union {
  186. void *pParam; //用户回调模式
  187. uint32_t MaxCnt; //设置捕获模式时的最大tick,捕获时的tick
  188. }uParam;
  189. union {
  190. struct {
  191. uint8_t Level; //IO输入输出电平,捕获模式下中断时IO电平
  192. uint8_t PullMode; //IO上下拉控制
  193. } IOArg;
  194. struct {
  195. uint8_t ExtiMode; //中断模式
  196. uint8_t PullMode; //IO上下拉控制
  197. } ExitArg;
  198. uint16_t Time; //delay时间,us
  199. } uArg;
  200. uint8_t Operation; //操作类型
  201. uint8_t PinOrDelay; //IO操作时为IOpin,delay操作时则为微调值,0~47,48为1us
  202. }OPQueue_CmdStruct;
  203. __attribute__((weak)) uint8_t OS_CheckInIrq(void);
  204. #ifdef __BUILD_OS__
  205. HANDLE OS_MutexCreate(void);
  206. HANDLE OS_MutexCreateUnlock(void);
  207. void OS_MutexLock(HANDLE Sem);
  208. int32_t OS_MutexLockWtihTime(HANDLE Sem, uint32_t TimeoutMs);
  209. HANDLE OS_MutexRelease(HANDLE Sem);
  210. void OS_MutexDelete(HANDLE Sem);
  211. #endif
  212. uint32_t OS_EnterCritical(void);
  213. void OS_ExitCritical(uint32_t Critical);
  214. void *OS_Malloc(uint32_t Size);
  215. void *OS_Zalloc(uint32_t Size);
  216. void OS_Free(void *p);
  217. void *OS_Realloc(void *buf, uint32_t size);
  218. void OS_MemInfo(uint32_t *curalloc, uint32_t *totfree, uint32_t *maxfree);
  219. int32_t OS_InitBuffer(Buffer_Struct *Buf, uint32_t Size);
  220. void OS_DeInitBuffer(Buffer_Struct *Buf);
  221. int32_t OS_ReInitBuffer(Buffer_Struct *Buf, uint32_t Size);
  222. int32_t OS_ReSizeBuffer(Buffer_Struct *Buf, uint32_t Size);
  223. int32_t OS_BufferWrite(Buffer_Struct *Buf, void *Data, uint32_t Len);
  224. int32_t OS_BufferWriteLimit(Buffer_Struct *Buf, void *Data, uint32_t Len);
  225. void OS_BufferRemove(Buffer_Struct *Buf, uint32_t Len);
  226. void DBuffer_Init(DBuffer_Struct *DBuf, uint32_t Size);
  227. void DBuffer_ReInit(DBuffer_Struct *DBuf, uint32_t Size);
  228. void DBuffer_DeInit(DBuffer_Struct *DBuf);
  229. void *DBuffer_GetCache(DBuffer_Struct *DBuf, uint8_t IsCurrent);
  230. void DBuffer_SwapCache(DBuffer_Struct *DBuf);
  231. void DBuffer_SetDataLen(DBuffer_Struct *DBuf, uint32_t Len, uint8_t IsCurrent);
  232. uint32_t DBuffer_GetDataLen(DBuffer_Struct *DBuf, uint8_t IsCurrent);
  233. void Buffer_StaticInit(Buffer_Struct *Buf, void *Src, uint32_t MaxLen);
  234. int32_t Buffer_StaticWrite(Buffer_Struct *Buf, void *Data, uint32_t Len);
  235. void Buffer_Remove(Buffer_Struct *Buf, uint32_t Len);
  236. void LoopBuffer_Init(Loop_Buffer *Buf, void *Src, uint32_t MaxLen, uint32_t DataSize);
  237. uint32_t LoopBuffer_Query(Loop_Buffer *Buf, void *Src, uint32_t Len);
  238. uint32_t LoopBuffer_Read(Loop_Buffer *Buf, void *Src, uint32_t Len);
  239. void LoopBuffer_Del(Loop_Buffer *Buf, uint32_t Len);
  240. uint32_t LoopBuffer_Write(Loop_Buffer *Buf, void *Src, uint32_t Len);
  241. int32_t BSP_SetBit(uint8_t *Data, uint32_t Sn, uint8_t Value);
  242. int32_t BSP_GetBit(uint8_t *Data, uint32_t Sn, uint8_t *Value);
  243. uint8_t BSP_TestBit(uint8_t *Data, uint32_t Sn);
  244. uint8_t XorCheck(void *Src, uint32_t Len, uint8_t CheckStart);
  245. uint8_t SumCheck(uint8_t *Data, uint32_t Len);
  246. uint16_t CRC16Cal(void *Data, uint16_t Len, uint16_t CRC16Last, uint16_t CRCRoot, uint8_t IsReverse);
  247. uint32_t AsciiToU32(uint8_t *Src, uint32_t Len);
  248. void CRC32_CreateTable(uint32_t *Tab, uint32_t Gen);
  249. uint32_t CRC32_Cal(uint32_t * CRC32_Table, uint8_t *Buf, uint32_t Size, uint32_t CRC32Last);
  250. uint32_t CmdParseParam(int8_t* pStr, CmdParam *CmdParam, int8_t Cut);
  251. uint8_t IsLeapYear(uint32_t Year);
  252. LongInt UTC2Tamp(Date_UserDataStruct *Date, Time_UserDataStruct *Time);
  253. uint32_t Tamp2UTC(LongInt Sec, Date_UserDataStruct *Date, Time_UserDataStruct *Time, uint32_t LastDDay);
  254. /*
  255. * 转义解包
  256. * 标识Flag,即包头包尾加入Flag
  257. * 数据中遇到Code F1 -> Flag
  258. * 数据中遇到Code F2 -> Code
  259. * 数据中遇到Flag 出错返回0
  260. */
  261. uint32_t TransferUnpack(uint8_t Flag, uint8_t Code, uint8_t F1, uint8_t F2, uint8_t *InBuf, uint32_t Len, uint8_t *OutBuf);
  262. /*
  263. * llist相关代码,大部分来自linux内核
  264. */
  265. /**
  266. * container_of - cast a member of a structure out to the containing structure
  267. *
  268. * @ptr: the pointer to the member.
  269. * @type: the type of the container struct this is embedded in.
  270. * @member: the name of the member within the struct.
  271. *
  272. */
  273. #define container_of(ptr, type, member) ({ \
  274. const typeof( ((type *)0)->member ) *__mptr = (ptr); \
  275. (type *)( (char *)__mptr - offsetof(type,member) );})
  276. /*
  277. * These are non-NULL pointers that will result in page faults
  278. * under normal circumstances, used to verify that nobody uses
  279. * non-initialized llist entries.
  280. */
  281. #define LLIST_POISON1 (0)
  282. #define LLIST_POISON2 (0)
  283. /*
  284. * Simple doubly linked llist implementation.
  285. *
  286. * Some of the internal functions ("__xxx") are useful when
  287. * manipulating whole llists rather than single entries, as
  288. * sometimes we already know the next/prev entries and we can
  289. * generate better code by using them directly rather than
  290. * using the generic single-entry routines.
  291. */
  292. typedef struct llist_head_t{
  293. struct llist_head_t *next, *prev;
  294. }llist_head;
  295. #define LLIST_HEAD_INIT(name) { &(name), &(name) }
  296. #define LLIST_HEAD(name) \
  297. llist_head name = LLIST_HEAD_INIT(name)
  298. #define INIT_LLIST_HEAD(ptr) do { \
  299. (ptr)->next = (ptr); (ptr)->prev = (ptr); \
  300. } while (0)
  301. /*
  302. * Insert a new entry between two known consecutive entries.
  303. *
  304. * This is only for internal llist manipulation where we know
  305. * the prev/next entries already!
  306. */
  307. void __llist_add(llist_head *p,
  308. llist_head *prev,
  309. llist_head *next);
  310. /**
  311. * llist_add - add a new entry
  312. * @new: new entry to be added
  313. * @head: llist head to add it after
  314. *
  315. * Insert a new entry after the specified head.
  316. * This is good for implementing stacks.
  317. */
  318. void llist_add(llist_head *p, llist_head *head);
  319. /**
  320. * llist_add_tail - add a new entry
  321. * @new: new entry to be added
  322. * @head: llist head to add it before
  323. *
  324. * Insert a new entry before the specified head.
  325. * This is useful for implementing queues.
  326. */
  327. void llist_add_tail(llist_head *p, llist_head *head);
  328. /*
  329. * Delete a llist entry by making the prev/next entries
  330. * point to each other.
  331. *
  332. * This is only for internal llist manipulation where we know
  333. * the prev/next entries already!
  334. */
  335. void __llist_del(llist_head * prev, llist_head * next);
  336. /**
  337. * llist_del - deletes entry from llist.
  338. * @entry: the element to delete from the llist.
  339. * Note: llist_empty on entry does not return true after this, the entry is
  340. * in an undefined state.
  341. */
  342. void llist_del(llist_head *entry);
  343. /**
  344. * llist_del_init - deletes entry from llist and reinitialize it.
  345. * @entry: the element to delete from the llist.
  346. */
  347. void llist_del_init(llist_head *entry);
  348. /**
  349. * llist_move - delete from one llist and add as another's head
  350. * @llist: the entry to move
  351. * @head: the head that will precede our entry
  352. */
  353. void llist_move(llist_head *llist, llist_head *head);
  354. /**
  355. * llist_move_tail - delete from one llist and add as another's tail
  356. * @llist: the entry to move
  357. * @head: the head that will follow our entry
  358. */
  359. void llist_move_tail(llist_head *llist,
  360. llist_head *head);
  361. /**
  362. * llist_empty - tests whether a llist is empty
  363. * @head: the llist to test.
  364. */
  365. int llist_empty(const llist_head *head);
  366. uint32_t llist_num(const llist_head *head);
  367. void *llist_traversal(llist_head *head, CBFuncEx_t cb, void *pData);
  368. /**
  369. * llist_entry - get the struct for this entry
  370. * @ptr: the &llist_head pointer.
  371. * @type: the type of the struct this is embedded in.
  372. * @member: the name of the llist_struct within the struct.
  373. */
  374. #define llist_entry(ptr, type, member) \
  375. container_of(ptr, type, member)
  376. uint16_t BSP_Swap16(uint16_t n);
  377. uint32_t BSP_Swap32(uint32_t n);
  378. uint8_t BytesGet8(const void *ptr);
  379. void BytesPut8(void *ptr, uint8_t v);
  380. uint16_t BytesGetBe16(const void *ptr);
  381. void BytesPutBe16(void *ptr, uint16_t v);
  382. uint32_t BytesGetBe32(const void *ptr);
  383. void BytesPutBe32(void *ptr, uint32_t v);
  384. uint16_t BytesGetLe16(const void *ptr);
  385. void BytesPutLe16(void *ptr, uint16_t v);
  386. uint32_t BytesGetLe32(const void *ptr);
  387. void BytesPutLe32(void *ptr, uint32_t v);
  388. uint64_t BytesGetLe64(const void *ptr);
  389. void BytesPutLe64(void *ptr, uint64_t v);
  390. uint8_t BytesGet8FromBuf(Buffer_Struct *Buf);
  391. void BytesPut8ToBuf(Buffer_Struct *Buf, uint8_t v);
  392. uint16_t BytesGetBe16FromBuf(Buffer_Struct *Buf);
  393. void BytesPutBe16ToBuf(Buffer_Struct *Buf, uint16_t v);
  394. uint32_t BytesGetBe32FromBuf(Buffer_Struct *Buf);
  395. void BytesPutBe32ToBuf(Buffer_Struct *Buf, uint32_t v);
  396. uint16_t BytesGetLe16FromBuf(Buffer_Struct *Buf);
  397. void BytesPutLe16ToBuf(Buffer_Struct *Buf, uint16_t v);
  398. uint32_t BytesGetLe32FromBuf(Buffer_Struct *Buf);
  399. void BytesPutLe32ToBuf(Buffer_Struct *Buf, uint32_t v);
  400. uint64_t BytesGetLe64FromBuf(Buffer_Struct *Buf);
  401. void BytesPutLe64ToBuf(Buffer_Struct *Buf, uint64_t v);
  402. float BytesGetFloatFromBuf(Buffer_Struct *Buf);
  403. void BytesPutFloatToBuf(Buffer_Struct *Buf, float v);
  404. double BytesGetDoubleFromBuf(Buffer_Struct *Buf);
  405. void BytesPutDoubleToBuf(Buffer_Struct *Buf, double v);
  406. /*************************************************************************/
  407. #define malloc OS_Malloc
  408. #define free OS_Free
  409. #define realloc OS_Realloc
  410. #define zalloc OS_Zalloc
  411. #define calloc OS_Calloc
  412. #if(defined(__DEBUG__) || defined(DEBUG))
  413. #define ASSERT( x ) if( ( x ) == 0 ) { __disable_irq(); DBG_Trace("\r\nassert %s,%d", __FUNCTION__, __LINE__); for( ;; ); }
  414. #else
  415. #define ASSERT( x )
  416. #endif
  417. #endif