usart_sim.c 3.5 KB

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