fw_uart.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. // Copyright 2021 IOsetting <iosetting(at)outlook.com>
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #ifndef ___FW_UART_H___
  15. #define ___FW_UART_H___
  16. #include "fw_conf.h"
  17. #include "fw_types.h"
  18. #include "fw_exti.h"
  19. extern __CODE char HEX_TABLE[16];
  20. int16_t UART_Timer_InitValueCalculate(uint32_t sysclk, HAL_State_t _1TMode, uint32_t baudrate);
  21. /**************************************************************************** /
  22. * UART1
  23. */
  24. typedef enum
  25. {
  26. UART1_BaudSource_Timer1 = 0x00,
  27. UART1_BaudSource_Timer2 = 0x01,
  28. } UART1_BaudSource_t;
  29. /**
  30. * Alternative ports
  31. *
  32. * The ports for STC8G1K08-8Pin and STC8G1K08A are different:
  33. * 00 - P3.0 P3.1, 01 - P3.2 P3.3, 10 - P5.4 P5.5, 11 - n/a
  34. */
  35. typedef enum
  36. {
  37. UART1_AlterPort_P30_P31 = 0x00,
  38. UART1_AlterPort_P36_P37 = 0x01,
  39. UART1_AlterPort_P16_P17 = 0x10,
  40. UART1_AlterPort_P43_P44 = 0x11,
  41. } UART1_AlterPort_t;
  42. #define UART1_SetRxState(__STATE__) SBIT_ASSIGN(REN, __STATE__)
  43. #define UART1_ClearTxInterrupt() SBIT_RESET(TI)
  44. #define UART1_ClearRxInterrupt() SBIT_RESET(RI)
  45. #define UART1_WriteBuffer(__DATA__) (SBUF = (__DATA__))
  46. #define UART1_SetFrameErrDetect(__STATE__) SFR_ASSIGN(PCON, 6, __STATE__)
  47. #define UART1_SetBaudSource(__BAUD_SRC__) SFR_ASSIGN(AUXR, 0, __BAUD_SRC__)
  48. /**
  49. * Mode0: Synchronous shift serial mode, baudrate is fixed, provided by SYSCLK
  50. * Baud = (UART_M0x6 = 0)? (SYSCLK/12) : (SYSCLK/2)
  51. */
  52. #define UART1_ConfigMode0FixedSyncSerial(__STATE__) do{ SM0=0; SM1=0; SFR_ASSIGN(AUXR, 5, __STATE__);}while(0)
  53. #define UART1_SetMode0Baudx6(__STATE__) SFR_ASSIGN(AUXR, 5, __STATE__)
  54. /**
  55. * Mode2: 9-bit UART mode, baudrate is fixed, provided by SYSCLK
  56. * Baud = (SMOD = 0)? (SYSCLK/64) : (SYSCLK/32)
  57. */
  58. #define UART1_ConfigMode2Fixed9bitUart(__STATE__) do{ SM0=1; SM1=0; SFR_ASSIGN(PCON, 7, __STATE__);}while(0)
  59. #define UART1_SetTimer1Mode2Baudx2(__STATE__) SFR_ASSIGN(PCON, 7, __STATE__)
  60. /**
  61. * Alternative port selection: P30/P31, P36/P37, P16/P17, P43/P44
  62. */
  63. #define UART1_SwitchPort(__ALTER_PORT__) (P_SW1 = P_SW1 & ~(0x03 << 6) | ((__ALTER_PORT__) << 6))
  64. /**
  65. * Mode1:
  66. * 8-bit UART;
  67. * dynamic baud-rate;
  68. * 10-bit frame: 1 start, 8 data(lsb), 1 stop;
  69. * clocked by Timer1 or Timer2
  70. *
  71. */
  72. void UART1_Config8bitUart(UART1_BaudSource_t baudSource, HAL_State_t _1TMode, uint32_t baudrate);
  73. /**
  74. * Mode3:
  75. * 9-bit UART;
  76. * dynamic baud-rate;
  77. * 11-bit frame: 1 start, 8 data(lsb), 1 programmable, 1 stop;
  78. * clocked by Timer1 or Timer2
  79. */
  80. void UART1_Config9bitUart(UART1_BaudSource_t baudSource, HAL_State_t _1TMode, uint32_t baudrate);
  81. /**
  82. * FIXME: If place this in first with following TXString(), sending may not work. didn't find the reason
  83. */
  84. void UART1_TxChar(char dat);
  85. void UART1_TxHex(uint8_t hex);
  86. void UART1_TxString(uint8_t *str);
  87. /**************************************************************************** /
  88. * UART2
  89. */
  90. typedef enum
  91. {
  92. UART2_AlterPort_P10_P11 = 0x00,
  93. UART2_AlterPort_P46_P47 = 0x01,
  94. } UART2_AlterPort_t;
  95. #define UART2_SetRxState(__STATE__) SFR_ASSIGN(S2CON, 4, __STATE__)
  96. #define UART2_ClearTxInterrupt() SFR_RESET(S2CON, 1)
  97. #define UART2_ClearRxInterrupt() SFR_RESET(S2CON, 0)
  98. #define UART2_WriteBuffer(__DATA__) (S2BUF = (__DATA__))
  99. #define UART2_TxFinished() (S2CON & (0x01 << 1))
  100. #define UART2_Set8bitUART() SFR_RESET(S2CON, 7)
  101. #define UART2_Set9bitUART() SFR_SET(S2CON, 7)
  102. /**
  103. * Alternative port selection: P10:rx/P11:tx, P46:rx/P47:tx
  104. */
  105. #define UART2_SwitchPort(__ALTER_PORT__) (P_SW2 = P_SW1 & ~(0x01 << 0) | ((__ALTER_PORT__) << 0))
  106. /**
  107. * Dynamic baud-rate, provided by Timer2
  108. */
  109. void UART2_Config(HAL_State_t _1TMode, uint32_t baudrate);
  110. void UART2_TxChar(char dat);
  111. void UART2_TxHex(uint8_t hex);
  112. void UART2_TxString(uint8_t *str);
  113. /**************************************************************************** /
  114. * UART3
  115. */
  116. #define UART3_SetBaudSource(__BAUD_SRC__) SFR_ASSIGN(S3CON, 6, __BAUD_SRC__)
  117. #define UART3_SetRxState(__STATE__) SFR_ASSIGN(S3CON, 4, __STATE__)
  118. #define UART3_Set8bitUART() SFR_RESET(S3CON, 7)
  119. #define UART3_Set9bitUART() SFR_SET(S3CON, 7)
  120. #define UART3_ClearTxInterrupt() SFR_RESET(S3CON, 1)
  121. #define UART3_ClearRxInterrupt() SFR_RESET(S3CON, 0)
  122. #define UART3_WriteBuffer(__DATA__) (S3BUF = (__DATA__))
  123. /**
  124. * dynamic baud-rate from timer2 or timer3
  125. */
  126. void UART3_ConfigOnTimer2(HAL_State_t _1TMode, uint32_t baudrate);
  127. void UART3_ConfigOnTimer3(HAL_State_t _1TMode, uint32_t baudrate);
  128. /**************************************************************************** /
  129. * UART4
  130. */
  131. #define UART4_SetBaudSource(__BAUD_SRC__) SFR_ASSIGN(S4CON, 6, __BAUD_SRC__)
  132. #define UART4_SetRxState(__STATE__) SFR_ASSIGN(S4CON, 4, __STATE__)
  133. #define UART4_Set8bitUART() SFR_RESET(S4CON, 7)
  134. #define UART4_Set9bitUART() SFR_SET(S4CON, 7)
  135. #define UART4_ClearTxInterrupt() SFR_RESET(S4CON, 1)
  136. #define UART4_ClearRxInterrupt() SFR_RESET(S4CON, 0)
  137. #define UART4_WriteBuffer(__DATA__) (S4BUF = (__DATA__))
  138. /**
  139. * dynamic baud-rate from timer2 or timer4
  140. */
  141. void UART4_ConfigOnTimer2(HAL_State_t _1TMode, uint32_t baudrate);
  142. void UART4_ConfigOnTimer4(HAL_State_t _1TMode, uint32_t baudrate);
  143. #endif