sys.c 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  1. /**
  2. * author wulianwei
  3. * title 一般工具
  4. */
  5. #include "sys.h"
  6. //C库
  7. #include <stdarg.h>
  8. #include <string.h>
  9. #include <stdio.h>
  10. uart_recv_t uart_recv = {0};
  11. valid_data_t valid_data = {0};//有效数据
  12. //字节流转HEX字符串
  13. void byteToHexStr(const unsigned char* source, char* dest, int sourceLen)
  14. {
  15. short i;
  16. unsigned char highByte, lowByte;
  17. for (i = 0; i < sourceLen; i++)
  18. {
  19. highByte = source[i] >> 4;
  20. lowByte = source[i] & 0x0f ;
  21. highByte += 0x30;
  22. if (highByte > 0x39)
  23. dest[i * 2] = highByte + 0x07;
  24. else
  25. dest[i * 2] = highByte;
  26. lowByte += 0x30;
  27. if (lowByte > 0x39)
  28. dest[i * 2 + 1] = lowByte + 0x07;
  29. else
  30. dest[i * 2 + 1] = lowByte;
  31. }
  32. return ;
  33. }
  34. /**
  35. * 字母大小写转换, flag = 1 转大写, flag =0 转小写
  36. */
  37. void letterSwitch(char *str, int flag)
  38. {
  39. int data;
  40. while (*str != '\0')
  41. {
  42. if (flag)
  43. {
  44. if (*str >= 'a' && *str <= 'z')
  45. {
  46. *str = *str - 32;
  47. }
  48. }
  49. else
  50. {
  51. if (*str >= 'A' && *str <= 'Z')
  52. {
  53. *str = *str + 32;
  54. }
  55. }
  56. str++;
  57. }
  58. }
  59. void inttohex(u16 value,u8 *hex)
  60. {
  61. u16 x1;
  62. hex[0]=value/(16*16*16)+'0';
  63. x1=value%(16*16*16);
  64. hex[1]=x1/(16*16)+'0';
  65. x1=value%(16*16);
  66. hex[2]=x1/16+'0';
  67. x1=value%16;
  68. hex[3]=x1+'0';
  69. hex[4]=' ';
  70. }
  71. /**
  72. * 整形字符串转整形数字
  73. */
  74. int my_atoi(char *str)
  75. {
  76. int n = 0;
  77. int flag = 0;
  78. if(*str == '-')
  79. {
  80. flag = 1;
  81. str++;
  82. }
  83. while(*str >= '0' && *str <= '9')
  84. {
  85. n = n*10 + (*str - '0');
  86. str++;
  87. }
  88. if(flag == 1)
  89. {
  90. n = -n;
  91. }
  92. return n;
  93. }
  94. /**
  95. * 整形字符串转整形数字绝对值
  96. */
  97. int my_atoabs(char *str)
  98. {
  99. int n = 0;
  100. if(*str == '-')
  101. {
  102. str++;
  103. }
  104. while(*str >= '0' && *str <= '9')
  105. {
  106. n = n*10 + (*str - '0');
  107. str++;
  108. }
  109. return n;
  110. }
  111. /**
  112. * 整形转字符串
  113. * num:待转的数据,str:目标地址,radix:进制2,8,10,16
  114. */
  115. char* my_itoa(int num,char* str,int radix)
  116. {
  117. char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";//索引表
  118. unsigned unum;//存放要转换的整数的绝对值,转换的整数可能是负数
  119. int i=0,j,k;//i用来指示设置字符串相应位,转换之后i其实就是字符串的长度;转换后顺序是逆序的,有正负的情况,k用来指示调整顺序的开始位置;j用来指示调整顺序时的交换。
  120. //获取要转换的整数的绝对值
  121. if(radix==10&&num<0)//要转换成十进制数并且是负数
  122. {
  123. unum=(unsigned)-num;//将num的绝对值赋给unum
  124. str[i++]='-';//在字符串最前面设置为'-'号,并且索引加1
  125. }
  126. else unum=(unsigned)num;//若是num为正,直接赋值给unum
  127. //转换部分,注意转换后是逆序的
  128. do
  129. {
  130. str[i++]=index[unum%(unsigned)radix];//取unum的最后一位,并设置为str对应位,指示索引加1
  131. unum/=radix;//unum去掉最后一位
  132. }while(unum);//直至unum为0退出循环
  133. str[i]='\0';//在字符串最后添加'\0'字符,c语言字符串以'\0'结束。
  134. //将顺序调整过来
  135. if(str[0]=='-') k=1;//如果是负数,符号不用调整,从符号后面开始调整
  136. else k=0;//不是负数,全部都要调整
  137. char temp;//临时变量,交换两个值时用到
  138. for(j=k;j<=(i-1)/2;j++)//头尾一一对称交换,i其实就是字符串的长度,索引最大值比长度少1
  139. {
  140. temp=str[j];//头部赋值给临时变量
  141. str[j]=str[i-1+k-j];//尾部赋值给头部
  142. str[i-1+k-j]=temp;//将临时变量的值(其实就是之前的头部值)赋给尾部
  143. }
  144. return str;//返回转换后的字符串
  145. }
  146. /**
  147. * @Title split,分割字符串
  148. * @Param src:源数据, separator:分割符, dest:目标地址, size:分割数量
  149. */
  150. void split(char *src,const char *separator,char *dest[],int size)
  151. {
  152. char *pNext;
  153. int count = 0;
  154. if (src == NULL || strlen(src) == 0)
  155. return;
  156. if (separator == NULL || strlen(separator) == 0)
  157. return;
  158. pNext = strtok(src,separator);
  159. while(pNext != NULL)
  160. {
  161. dest[count] = pNext;
  162. ++count;
  163. if(size <= count)
  164. break;
  165. pNext = strtok(NULL,separator);
  166. }
  167. }
  168. /**
  169. * @Title split,分割字符串
  170. * @Param src:源数据, separator:分割符, dest:目标地址, limit:分割限制数量
  171. */
  172. int splitCharLimit(char *str, char seprator, char *dest[], int limit)
  173. {
  174. int i, length, ct = 0, start = -1;
  175. length = strlen(str);
  176. for (i = 0; i <= length; i++) {
  177. if (start == -1 && limit <= ct + 1) {
  178. dest[ct] = &str[i];
  179. return ct+1;
  180. }
  181. if (str[i] == seprator) {
  182. if (start != -1) {
  183. dest[ct] = &str[start]; /* set up pointer */
  184. ct++;
  185. }
  186. str[i] = '\0'; /* add a null char; make a C string */
  187. start = -1;
  188. } else {
  189. if (start == -1) {
  190. start = i;
  191. }
  192. }
  193. }
  194. return ct+1;
  195. }
  196. void delay_ms(uint32_t ms)
  197. {
  198. unsigned int i,j;
  199. for(j=0;j<ms;j++)
  200. {
  201. for(i=0;i<1500;i++);
  202. }
  203. }
  204. /************************************************************
  205. * 函数名称: Usart_SendString
  206. *
  207. * 函数功能: 串口数据发送
  208. *
  209. * 入口参数: USARTx:串口组
  210. * str:要发送的数据
  211. * len:数据长度
  212. *
  213. * 返回参数: 无
  214. *
  215. * 说明:
  216. ************************************************************
  217. */
  218. void Usart_SendString(USART_TypeDef *USARTx, unsigned char *str, unsigned short len)
  219. {
  220. unsigned short count = 0;
  221. for(; count < len; count++)
  222. {
  223. USART_SendData(USARTx, *str++); //发送数据
  224. while(USART_GetFlagStatus(USARTx, USART_FLAG_TC) == RESET); //等待发送完成
  225. }
  226. }
  227. /*
  228. ************************************************************
  229. * 函数名称: UsartPrintf
  230. *
  231. * 函数功能: 格式化打印
  232. *
  233. * 入口参数: USARTx:串口组
  234. * fmt:不定长参
  235. *
  236. * 返回参数: 无
  237. *
  238. * 说明:
  239. ************************************************************
  240. */
  241. void UsartPrintf(USART_TypeDef *USARTx, char *fmt,...)
  242. {
  243. //return ;
  244. unsigned char UsartPrintfBuf[512];
  245. va_list ap;
  246. unsigned char *pStr = UsartPrintfBuf;
  247. va_start(ap, fmt);
  248. vsnprintf((char *)UsartPrintfBuf, sizeof(UsartPrintfBuf), fmt, ap); //格式化
  249. va_end(ap);
  250. while(*pStr != 0)
  251. {
  252. USART_SendData(USARTx, *pStr++);
  253. while(USART_GetFlagStatus(USARTx, USART_FLAG_TC) == RESET);
  254. }
  255. }
  256. /**
  257. *@Title 清空串口接收缓存
  258. */
  259. void uart_recv_clear(void)
  260. {
  261. memset(uart_recv.buf,0,sizeof(uart_recv.buf));
  262. uart_recv.len = 0;
  263. uart_recv.recv_flag = REV_WAIT;
  264. }
  265. void valid_data_clear(void)
  266. {
  267. valid_data.len = 0;
  268. memset(valid_data.buf,0,sizeof(valid_data.buf));
  269. }
  270. /**
  271. *@Title 串口接收数据
  272. *@Param timeout:等待时间(ms)
  273. */
  274. void uart_recv_wait(int timeout)
  275. {
  276. int per = 5; //轮询间隔单位ms
  277. int prelen = 0;
  278. if(timeout<=0) return;
  279. timeout=timeout/per+(timeout%per==0? 0 : 1);
  280. while(timeout--)
  281. {
  282. if(uart_recv.len)
  283. {
  284. if(uart_recv.len == prelen)
  285. {
  286. uart_recv.recv_flag = REV_OK; //接收完成
  287. break;
  288. }
  289. else
  290. {
  291. prelen = uart_recv.len;
  292. }
  293. }
  294. delay_ms(per);
  295. }
  296. }
  297. /**
  298. *@Title 串口接收数据匹配特定字符串
  299. *@Param res:匹配的字符串,timeout:等待时间(ms)
  300. **@Return 0:成功, -1:失败
  301. */
  302. int uart_recv_match_wait(char *res,int timeout)
  303. {
  304. int per = 5; //轮询间隔单位ms
  305. if(timeout<=0) return -1;
  306. timeout=timeout/per+(timeout%per==0? 0 : 1);
  307. while(timeout--)
  308. {
  309. if(strstr(uart_recv.buf,res))
  310. {
  311. uart_recv.recv_flag = REV_OK; //接收完成
  312. return 0;
  313. }
  314. delay_ms(per);
  315. }
  316. return -1;
  317. }