bypass_register.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  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-11-20 zhujiale the first version
  9. */
  10. #include <rtthread.h>
  11. #include <rtdevice.h>
  12. #include "utest.h"
  13. static struct rt_serial_device* _serial0;
  14. static struct rt_spinlock lock;
  15. static rt_err_t utest_001_run(struct rt_serial_device* serial, char ch, void* data)
  16. {
  17. return 0;
  18. }
  19. static void thread_serial_register1(void* parameter)
  20. {
  21. for (int i = 2; i < 10; i += 2)
  22. {
  23. rt_bypass_upper_register(_serial0, "test", i, utest_001_run, RT_NULL);
  24. }
  25. }
  26. static void thread_serial_register_upper(void* parameter)
  27. {
  28. for (int i = 1; i < 10; i++)
  29. {
  30. rt_bypass_upper_register(_serial0, "test", i, utest_001_run, RT_NULL);
  31. }
  32. }
  33. static void thread_serial_register_lower(void* parameter)
  34. {
  35. for (int i = 1; i < 10; i++)
  36. {
  37. rt_bypass_lower_register(_serial0, "test", i, utest_001_run, RT_NULL);
  38. }
  39. }
  40. static void bypass_register_001(void)
  41. {
  42. rt_thread_t t1 = rt_thread_create("serial_register", thread_serial_register1, RT_NULL, 2048, RT_THREAD_PRIORITY_MAX - 5, 10);
  43. rt_bypass_upper_register(_serial0, "test", 0, utest_001_run, RT_NULL);
  44. rt_thread_startup(t1);
  45. for (int i = 1; i < 10; i += 2)
  46. {
  47. rt_bypass_upper_register(_serial0, "test", i, utest_001_run, RT_NULL);
  48. }
  49. rt_thread_mdelay(1000);
  50. rt_list_t* node = _serial0->bypass->upper_h->head.next;
  51. for (int i = 0; i < 10;i++)
  52. {
  53. rt_list_t* next = node->next;
  54. struct rt_serial_bypass_func* temp = rt_container_of(node, struct rt_serial_bypass_func, node);
  55. uassert_true(temp->level == i);
  56. rt_bypass_upper_unregister(_serial0, temp->level);
  57. node = next;
  58. }
  59. }
  60. static void bypass_register_002(void)
  61. {
  62. rt_thread_t t1 = rt_thread_create("serial_register", thread_serial_register_upper, RT_NULL, 2048, RT_THREAD_PRIORITY_MAX - 5, 10);
  63. rt_thread_t t2 = rt_thread_create("serial_register", thread_serial_register_lower, RT_NULL, 2048, RT_THREAD_PRIORITY_MAX - 5, 10);
  64. rt_bypass_upper_register(_serial0, "test", 0, utest_001_run, RT_NULL);
  65. rt_thread_startup(t1);
  66. rt_thread_startup(t2);
  67. rt_thread_mdelay(1000);
  68. rt_list_t* node = _serial0->bypass->upper_h->head.next;
  69. for (int i = 0; i < 10;i++)
  70. {
  71. rt_list_t* next = node->next;
  72. struct rt_serial_bypass_func* temp = rt_container_of(node, struct rt_serial_bypass_func, node);
  73. uassert_true(temp->level == i);
  74. rt_bypass_upper_unregister(_serial0, temp->level);
  75. node = next;
  76. }
  77. node = _serial0->bypass->lower_h->head.next;
  78. for (int i = 1; i < 10;i++)
  79. {
  80. rt_list_t* next = node->next;
  81. struct rt_serial_bypass_func* temp = rt_container_of(node, struct rt_serial_bypass_func, node);
  82. uassert_true(temp->level == i);
  83. rt_bypass_lower_unregister(_serial0, temp->level);
  84. node = next;
  85. }
  86. }
  87. static rt_err_t utest_tc_init(void)
  88. {
  89. _serial0 = (struct rt_serial_device*)rt_console_get_device();
  90. rt_spin_lock_init(&lock);
  91. return RT_EOK;
  92. }
  93. static rt_err_t utest_tc_cleanup(void)
  94. {
  95. return RT_EOK;
  96. }
  97. static void _testcase(void)
  98. {
  99. UTEST_UNIT_RUN(bypass_register_001);
  100. UTEST_UNIT_RUN(bypass_register_002);
  101. }
  102. UTEST_TC_EXPORT(_testcase, "components.drivers.serial.bypass_register", utest_tc_init, utest_tc_cleanup, 10);