rtlink_example.c 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2021-05-15 Sherman the first version
  9. * 2021-08-04 Sherman Adapted to new version of rt-link API
  10. */
  11. #include <stdlib.h>
  12. #include <string.h>
  13. #include <rtthread.h>
  14. #include <rtlink.h>
  15. #define DBG_ENABLE
  16. #define DBG_TAG "rtlink_exam"
  17. #define DBG_LVL DBG_INFO
  18. #include <rtdbg.h>
  19. #define TEST_CONTEXT "This message is sent by RT-Link"
  20. enum
  21. {
  22. NONE_TEST = 0,
  23. SHORT_FRAME_TEST,
  24. LONG_FRAME_TEST
  25. };
  26. void rt_link_speed_test(void *paremeter);
  27. static rt_uint8_t speed_test_type = NONE_TEST;
  28. static struct rt_link_service serv_socket;
  29. static struct rt_link_service serv_wifi;
  30. static void send_cb(struct rt_link_service *service, void *buffer)
  31. {
  32. LOG_I("send_cb: service (%d) buffer (0x%p) err(%d)", service->service, buffer, service->err);
  33. }
  34. static void recv_cb(struct rt_link_service *service, void *data, rt_size_t size)
  35. {
  36. LOG_I("service (%d) size (%d) data(0x%p)", service->service, size, data);
  37. if (size)
  38. {
  39. rt_free(data);
  40. }
  41. }
  42. static void rt_link_speed_test(void *paremeter)
  43. {
  44. int ret;
  45. rt_uint8_t *send_buf, *data;
  46. rt_size_t bufflen = 0;
  47. rt_size_t sentlen = 0;
  48. rt_size_t count = 0;
  49. rt_tick_t tick1, tick2;
  50. rt_size_t total = 0;
  51. rt_uint32_t integer, decimal;
  52. if (speed_test_type == SHORT_FRAME_TEST)
  53. {
  54. bufflen = RT_LINK_MAX_DATA_LENGTH;
  55. }
  56. else
  57. {
  58. bufflen = RT_LINK_MAX_DATA_LENGTH * RT_LINK_FRAMES_MAX;
  59. }
  60. send_buf = rt_malloc(bufflen);
  61. if (send_buf != RT_NULL)
  62. {
  63. data = send_buf;
  64. for (count = 0; count < bufflen; count++)
  65. {
  66. *data++ = (count % 93 + 33);
  67. }
  68. }
  69. else
  70. {
  71. rt_kprintf("speed of send buffer malloc failed.");
  72. return;
  73. }
  74. tick1 = rt_tick_get();
  75. while (speed_test_type)
  76. {
  77. ret = rt_link_send(&serv_socket, send_buf, bufflen);
  78. if (ret > 0)
  79. {
  80. sentlen += ret;
  81. }
  82. else
  83. {
  84. LOG_W("send err %d", ret);
  85. }
  86. tick2 = rt_tick_get();
  87. if (tick2 - tick1 >= RT_TICK_PER_SECOND)
  88. {
  89. total = sentlen * RT_TICK_PER_SECOND / 125 / (tick2 - tick1);
  90. integer = total / 1000;
  91. decimal = total % 1000;
  92. LOG_I("%d.%03d0 Mbps!", integer, decimal);
  93. sentlen = 0;
  94. tick1 = tick2;
  95. }
  96. }
  97. rt_free(send_buf);
  98. LOG_W("speed test end, type %d", speed_test_type);
  99. }
  100. static void create_thead_to_test_speed(rt_uint8_t mutil_num)
  101. {
  102. rt_uint8_t i = 0;
  103. LOG_D("Speed test type [%02d], mutil [%02d]", speed_test_type, mutil_num);
  104. for (i = 0; i < mutil_num; i++)
  105. {
  106. rt_thread_t tid;
  107. char tid_name[RT_NAME_MAX + 1] = {0};
  108. rt_snprintf(tid_name, sizeof(tid_name), "lny_s%03d", i + 1);
  109. tid = rt_thread_create(tid_name, rt_link_speed_test, RT_NULL, 1024, 20, 10);
  110. if (tid)
  111. {
  112. rt_thread_startup(tid);
  113. LOG_I("Speed test thread[%s] startup", tid_name);
  114. }
  115. }
  116. }
  117. static int rtlink_exsend(int argc, char **argv)
  118. {
  119. char *receive = RT_NULL;
  120. rt_size_t length = 0;
  121. rt_uint16_t count = 0;
  122. if (argc == 1)
  123. {
  124. receive = rt_malloc(sizeof(TEST_CONTEXT));
  125. rt_memcpy(receive, TEST_CONTEXT, sizeof(TEST_CONTEXT) - 1);
  126. length = rt_link_send(&serv_socket, receive, sizeof(TEST_CONTEXT) - 1);
  127. LOG_I("send data length: %d.", length);
  128. rt_free(receive);
  129. }
  130. else if (argc >= 3)
  131. {
  132. if (strcmp(argv[1], "-l") == 0)
  133. {
  134. receive = rt_malloc(atoi((const char *)argv[2]));
  135. for (count = 0; count < atoi((const char *)argv[2]); count++)
  136. {
  137. *receive++ = (count % 93 + 33);
  138. }
  139. length = rt_link_send(&serv_socket, receive - atoi((const char *)argv[2]), atoi((const char *)argv[2]));
  140. rt_free(receive - atoi((const char *)argv[2]));
  141. LOG_I("send data length: %d.", length);
  142. }
  143. else if (strcmp(argv[1], "-s") == 0)
  144. {
  145. if (speed_test_type == NONE_TEST)
  146. {
  147. rt_uint8_t mutil_num = 1;
  148. if (argc > 3)
  149. {
  150. mutil_num = atoi((const char *)argv[3]);
  151. }
  152. if (strncmp(argv[2], "-s", rt_strlen(argv[2])) == 0)
  153. {
  154. speed_test_type = SHORT_FRAME_TEST;
  155. }
  156. else if (strncmp(argv[2], "-l", rt_strlen(argv[2])) == 0)
  157. {
  158. speed_test_type = LONG_FRAME_TEST;
  159. }
  160. create_thead_to_test_speed(mutil_num);
  161. }
  162. else
  163. {
  164. speed_test_type = NONE_TEST;
  165. LOG_I("set NONE_TEST");
  166. }
  167. }
  168. else
  169. {
  170. LOG_E("Invalid parameter.");
  171. }
  172. }
  173. return 0;
  174. }
  175. MSH_CMD_EXPORT(rtlink_exsend, rt link layer send test);
  176. int rtlink_exinit(void)
  177. {
  178. serv_socket.service = RT_LINK_SERVICE_SOCKET;
  179. serv_socket.timeout_tx = RT_WAITING_FOREVER;
  180. serv_socket.flag = RT_LINK_FLAG_ACK | RT_LINK_FLAG_CRC;
  181. serv_socket.recv_cb = recv_cb;
  182. serv_socket.send_cb = send_cb;
  183. rt_link_service_attach(&serv_socket);
  184. serv_wifi.service = RT_LINK_SERVICE_WIFI;
  185. serv_wifi.timeout_tx = RT_WAITING_FOREVER;
  186. serv_wifi.flag = RT_NULL;
  187. serv_wifi.recv_cb = recv_cb;
  188. serv_wifi.send_cb = send_cb;
  189. rt_link_service_attach(&serv_wifi);
  190. return RT_EOK;
  191. }
  192. MSH_CMD_EXPORT(rtlink_exinit, rt link example init);