uart_nonblocking_rx.c 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. #include <rtthread.h>
  2. #include <rtdevice.h>
  3. #include "utest.h"
  4. #ifdef UTEST_SERIAL_TC
  5. static rt_bool_t nonblock_read(rt_device_t uart_dev)
  6. {
  7. rt_size_t total_length, recv_length;
  8. char uart_read_buffer[1024], log_buffer[64];
  9. /* make sure device is closed and reopen it */
  10. while (rt_device_close(uart_dev) != -RT_ERROR);
  11. rt_device_open(uart_dev, RT_DEVICE_FLAG_TX_BLOCKING | RT_DEVICE_FLAG_RX_NON_BLOCKING);
  12. rt_sprintf(log_buffer, "\nNONBLOCKING READ BEGIN, PLEASE SEND SOME DATAS\n");
  13. rt_device_write(uart_dev, 0, log_buffer, rt_strlen(log_buffer));
  14. total_length = 0;
  15. rt_device_write(uart_dev, 0, "5\n", 2);
  16. recv_length = 0;
  17. recv_length = rt_device_read(uart_dev, -1, uart_read_buffer, 256);
  18. rt_device_write(uart_dev, 0, uart_read_buffer, 256);
  19. total_length += recv_length;
  20. rt_sprintf(log_buffer, "\nnonblock : %d bytes read, total: %d \n", recv_length, total_length);
  21. rt_device_write(uart_dev, 0, log_buffer, rt_strlen(log_buffer));
  22. rt_device_write(uart_dev, 0, "4\n", 2);
  23. recv_length = 0;
  24. recv_length = rt_device_read(uart_dev, -1, uart_read_buffer, 256);
  25. rt_device_write(uart_dev, 0, uart_read_buffer, 256);
  26. total_length += recv_length;
  27. rt_sprintf(log_buffer, "\nnonblock : %d bytes read , total: %d \n", recv_length, total_length);
  28. rt_device_write(uart_dev, 0, log_buffer, rt_strlen(log_buffer));
  29. rt_device_write(uart_dev, 0, "3\n", 2);
  30. recv_length = 0;
  31. recv_length = rt_device_read(uart_dev, -1, uart_read_buffer, 256);
  32. rt_device_write(uart_dev, 0, uart_read_buffer, 256);
  33. total_length += recv_length;
  34. rt_sprintf(log_buffer, "\nnonblock : %d bytes read, total: %d \n", recv_length, total_length);
  35. rt_device_write(uart_dev, 0, log_buffer, rt_strlen(log_buffer));
  36. rt_device_write(uart_dev, 0, "2\n", 2);
  37. recv_length = 0;
  38. recv_length = rt_device_read(uart_dev, -1, uart_read_buffer, 128);
  39. rt_device_write(uart_dev, 0, uart_read_buffer, 128);
  40. total_length += recv_length;
  41. rt_sprintf(log_buffer, "\nnonblock : %d bytes read , total: %d \n", recv_length, total_length);
  42. rt_device_write(uart_dev, 0, log_buffer, rt_strlen(log_buffer));
  43. rt_device_write(uart_dev, 0, "1\n", 2);
  44. recv_length = 0;
  45. recv_length = rt_device_read(uart_dev, -1, uart_read_buffer, 128);
  46. rt_device_write(uart_dev, 0, uart_read_buffer, 128);
  47. total_length += recv_length;
  48. rt_sprintf(log_buffer, "\nnonblock : %d bytes read , total: %d \n", recv_length, total_length);
  49. rt_device_write(uart_dev, 0, log_buffer, rt_strlen(log_buffer));
  50. rt_sprintf(log_buffer, "BLOCKING READ END");
  51. rt_device_write(uart_dev, 0, log_buffer, rt_strlen(log_buffer));
  52. return RT_TRUE;
  53. }
  54. static void uart_test_nonblocking_rx(void)
  55. {
  56. rt_device_t uart_dev;
  57. uart_dev = rt_device_find(RT_SERIAL_TC_DEVICE_NAME);
  58. uassert_not_null(uart_dev);
  59. uassert_true(nonblock_read(uart_dev));
  60. }
  61. static rt_err_t utest_tc_init(void)
  62. {
  63. return RT_EOK;
  64. }
  65. static rt_err_t utest_tc_cleanup(void)
  66. {
  67. rt_device_t uart_dev = rt_device_find(RT_SERIAL_TC_DEVICE_NAME);
  68. while (rt_device_close(uart_dev) != -RT_ERROR);
  69. return RT_EOK;
  70. }
  71. static void testcase(void)
  72. {
  73. UTEST_UNIT_RUN(uart_test_nonblocking_rx);
  74. }
  75. UTEST_TC_EXPORT(testcase, "uart_nonblocking_rx", utest_tc_init, utest_tc_cleanup, 10);
  76. #endif