usart_sim.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. #include <rthw.h>
  2. #include <rtthread.h>
  3. #ifdef _WIN32
  4. #include <windows.h>
  5. #include <mmsystem.h>
  6. #endif
  7. #include <stdio.h>
  8. #include <conio.h>
  9. #include "serial.h"
  10. struct serial_int_rx serial_rx;
  11. extern struct rt_device serial_device;
  12. /*
  13. * Handler for OSKey Thread
  14. */
  15. static HANDLE OSKey_Thread;
  16. static DWORD OSKey_ThreadID;
  17. static DWORD WINAPI ThreadforKeyGet(LPVOID lpParam);
  18. void rt_hw_usart_init(void)
  19. {
  20. /*
  21. * create serial thread that receive key input from keyboard
  22. */
  23. OSKey_Thread = CreateThread(NULL,
  24. 0,
  25. (LPTHREAD_START_ROUTINE)ThreadforKeyGet,
  26. 0,
  27. CREATE_SUSPENDED,
  28. &OSKey_ThreadID);
  29. if (OSKey_Thread == NULL)
  30. {
  31. //Display Error Message
  32. return;
  33. }
  34. SetThreadPriority(OSKey_Thread,
  35. THREAD_PRIORITY_NORMAL);
  36. SetThreadPriorityBoost(OSKey_Thread,
  37. TRUE);
  38. SetThreadAffinityMask(OSKey_Thread,
  39. 0x01);
  40. /*
  41. * Start OS get key Thread
  42. */
  43. ResumeThread(OSKey_Thread);
  44. }
  45. /*
  46. * 方向键(←): 0xe04b
  47. * 方向键(↑): 0xe048
  48. * 方向键(→): 0xe04d
  49. * 方向键(↓): 0xe050
  50. */
  51. static int savekey(unsigned char key)
  52. {
  53. /* save on rx buffer */
  54. {
  55. rt_base_t level;
  56. /* disable interrupt */
  57. //暂时关闭中断,因为要操作uart数据结构
  58. level = rt_hw_interrupt_disable();
  59. /* save character */
  60. serial_rx.rx_buffer[serial_rx.save_index] = key;
  61. serial_rx.save_index ++;
  62. //下面的代码检查save_index是否已经到到缓冲区尾部,如果是则回转到头部,称为一个环形缓冲区
  63. if (serial_rx.save_index >= SERIAL_RX_BUFFER_SIZE)
  64. serial_rx.save_index = 0;
  65. //这种情况表示反转后的save_index追上了read_index,则增大read_index,丢弃一个旧的数据
  66. /* if the next position is read index, discard this 'read char' */
  67. if (serial_rx.save_index == serial_rx.read_index)
  68. {
  69. serial_rx.read_index ++;
  70. if (serial_rx.read_index >= SERIAL_RX_BUFFER_SIZE)
  71. serial_rx.read_index = 0;
  72. }
  73. /* enable interrupt */
  74. //uart数据结构已经操作完成,重新使能中断
  75. rt_hw_interrupt_enable(level);
  76. }
  77. /* invoke callback */
  78. if (serial_device.rx_indicate != RT_NULL)
  79. {
  80. rt_size_t rx_length;
  81. /* get rx length */
  82. rx_length = serial_rx.read_index > serial_rx.save_index ?
  83. SERIAL_RX_BUFFER_SIZE - serial_rx.read_index + serial_rx.save_index :
  84. serial_rx.save_index - serial_rx.read_index;
  85. serial_device.rx_indicate(&serial_device, rx_length);
  86. }
  87. return 0;
  88. }
  89. static DWORD WINAPI ThreadforKeyGet(LPVOID lpParam)
  90. {
  91. unsigned char key;
  92. (void)lpParam; //prevent compiler warnings
  93. for (;;)
  94. {
  95. key = getch();
  96. if (key == 0xE0)
  97. {
  98. key = getch();
  99. if (key == 0x48) //up key , 0x1b 0x5b 0x41
  100. {
  101. savekey(0x1b);
  102. savekey(0x5b);
  103. savekey(0x41);
  104. }
  105. else if (key == 0x50)//0x1b 0x5b 0x42
  106. {
  107. savekey(0x1b);
  108. savekey(0x5b);
  109. savekey(0x42);
  110. }
  111. continue;
  112. }
  113. savekey(key);
  114. }
  115. } /*** ThreadforKeyGet ***/