Mercurial > public > ostc4
comparison Small_CPU/Src/uart.c @ 662:1b995079c045 Betatest
PSCR Mode
| author | heinrichs weikamp |
|---|---|
| date | Tue, 14 Dec 2021 15:36:10 +0100 |
| parents | 5f11787b4f42 |
| children | fca2bd25e6e2 |
comparison
equal
deleted
inserted
replaced
| 661:87bee7cc77b3 | 662:1b995079c045 |
|---|---|
| 18 * | 18 * |
| 19 ****************************************************************************** | 19 ****************************************************************************** |
| 20 */ | 20 */ |
| 21 /* Includes ------------------------------------------------------------------*/ | 21 /* Includes ------------------------------------------------------------------*/ |
| 22 #include "uart.h" | 22 #include "uart.h" |
| 23 #include "externalInterface.h" | |
| 24 #include "data_exchange.h" | |
| 23 | 25 |
| 24 /* Private variables ---------------------------------------------------------*/ | 26 /* Private variables ---------------------------------------------------------*/ |
| 25 | 27 |
| 26 UART_HandleTypeDef huart2; | 28 #define CHUNK_SIZE (20u) /* the DMA will handle chunk size transfers */ |
| 27 | 29 #define CHUNKS_PER_BUFFER (3u) |
| 28 | 30 UART_HandleTypeDef huart1; |
| 31 | |
| 32 DMA_HandleTypeDef hdma_usart1_rx; | |
| 33 | |
| 34 uint8_t rxBuffer[CHUNK_SIZE * CHUNKS_PER_BUFFER]; /* The complete buffer has a X * chunk size to allow fariations in buffer read time */ | |
| 35 static uint8_t rxWriteIndex; /* Index of the data item which is analysed */ | |
| 36 static uint8_t rxReadIndex; /* Index at which new data is stared */ | |
| 37 static uint8_t lastCmdIndex; /* Index of last command which has not been completly received */ | |
| 38 static uint8_t dmaActive; /* Indicator if DMA receiption needs to be started */ | |
| 39 | |
| 40 float LED_Level = 0.0; /* Normalized LED value which may be used as indication for the health status of the sensor */ | |
| 41 float LED_ZeroOffset = 0.0; | |
| 42 float pCO2 = 0.0; | |
| 29 /* Exported functions --------------------------------------------------------*/ | 43 /* Exported functions --------------------------------------------------------*/ |
| 30 | 44 |
| 31 void MX_USART2_UART_Init(void) | 45 void MX_USART1_UART_Init(void) |
| 32 { | 46 { |
| 33 /* pullup special */ | |
| 34 GPIO_InitTypeDef GPIO_InitStructure; | |
| 35 __GPIOA_CLK_ENABLE(); | |
| 36 GPIO_InitStructure.Pin = GPIO_PIN_2; | |
| 37 GPIO_InitStructure.Mode = GPIO_MODE_OUTPUT_PP; | |
| 38 GPIO_InitStructure.Pull = GPIO_PULLUP; | |
| 39 GPIO_InitStructure.Speed = GPIO_SPEED_FAST; | |
| 40 HAL_GPIO_Init(GPIOA, &GPIO_InitStructure); | |
| 41 | |
| 42 /* regular init */ | 47 /* regular init */ |
| 43 huart2.Instance = USART2; | 48 |
| 44 huart2.Init.BaudRate = 1200; | 49 huart1.Instance = USART1; |
| 45 huart2.Init.WordLength = UART_WORDLENGTH_8B; | 50 huart1.Init.BaudRate = 9600; |
| 46 huart2.Init.StopBits = UART_STOPBITS_1; | 51 huart1.Init.WordLength = UART_WORDLENGTH_8B; |
| 47 huart2.Init.Parity = UART_PARITY_NONE; | 52 huart1.Init.StopBits = UART_STOPBITS_1; |
| 48 huart2.Init.Mode = UART_MODE_TX_RX; | 53 huart1.Init.Parity = UART_PARITY_NONE; |
| 49 huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE; | 54 huart1.Init.Mode = UART_MODE_TX_RX; |
| 50 huart2.Init.OverSampling = UART_OVERSAMPLING_16; | 55 huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE; |
| 51 HAL_UART_Init(&huart2); | 56 huart1.Init.OverSampling = UART_OVERSAMPLING_16; |
| 52 } | 57 |
| 53 | 58 HAL_UART_Init(&huart1); |
| 54 | 59 |
| 55 uint8_t UART_ButtonAdjust(uint8_t *array) | 60 rxReadIndex = 0; |
| 56 { | 61 lastCmdIndex = 0; |
| 57 uint8_t answer[4]; | 62 rxWriteIndex = 0; |
| 58 | 63 dmaActive = 0; |
| 59 HAL_UART_Transmit(&huart2,array,4,1000); | 64 } |
| 60 HAL_UART_Receive(&huart2,answer,4,2000); | 65 |
| 61 if( (answer[0] == array[0]) | 66 void MX_USART1_UART_DeInit(void) |
| 62 &&(answer[1] == array[1]) | 67 { |
| 63 &&(answer[2] == array[2]) | 68 HAL_DMA_DeInit(&hdma_usart1_rx); |
| 64 &&(answer[3] == array[3])) | 69 HAL_UART_DeInit(&huart1); |
| 65 return 1; | 70 } |
| 66 else | 71 |
| 67 return 0; | 72 void MX_USART1_DMA_Init() |
| 68 } | 73 { |
| 69 | 74 /* DMA controller clock enable */ |
| 70 void MX_USART2_UART_DeInit(void) | 75 __DMA2_CLK_ENABLE(); |
| 71 { | 76 |
| 72 HAL_UART_DeInit(&huart2); | 77 /* Peripheral DMA init*/ |
| 73 } | 78 hdma_usart1_rx.Instance = DMA2_Stream5; |
| 79 hdma_usart1_rx.Init.Channel = DMA_CHANNEL_4; | |
| 80 hdma_usart1_rx.Init.Direction = DMA_PERIPH_TO_MEMORY; //DMA_MEMORY_TO_PERIPH; | |
| 81 hdma_usart1_rx.Init.PeriphInc = DMA_PINC_DISABLE; | |
| 82 hdma_usart1_rx.Init.MemInc = DMA_MINC_ENABLE; | |
| 83 hdma_usart1_rx.Init.PeriphDataAlignment = DMA_MDATAALIGN_BYTE; | |
| 84 hdma_usart1_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE; | |
| 85 hdma_usart1_rx.Init.Mode = DMA_NORMAL; | |
| 86 hdma_usart1_rx.Init.Priority = DMA_PRIORITY_LOW; | |
| 87 hdma_usart1_rx.Init.FIFOMode = DMA_FIFOMODE_DISABLE; | |
| 88 HAL_DMA_Init(&hdma_usart1_rx); | |
| 89 | |
| 90 __HAL_LINKDMA(&huart1,hdmarx,hdma_usart1_rx); | |
| 91 | |
| 92 /* DMA interrupt init */ | |
| 93 HAL_NVIC_SetPriority(DMA2_Stream5_IRQn, 0, 0); | |
| 94 HAL_NVIC_EnableIRQ(DMA2_Stream5_IRQn); | |
| 95 } | |
| 96 | |
| 97 | |
| 98 uint32_t dataValue = 0; | |
| 99 | |
| 100 void HandleUARTData(void) | |
| 101 { | |
| 102 uint8_t localRX = rxReadIndex; | |
| 103 uint8_t dataType = 0; | |
| 104 static receiveState_t rxState = RX_Ready; | |
| 105 static uint32_t lastReceiveTick = 0; | |
| 106 | |
| 107 while(localRX != rxWriteIndex) | |
| 108 { | |
| 109 lastReceiveTick = HAL_GetTick(); | |
| 110 if(rxState == RX_Ready) /* identify data content */ | |
| 111 { | |
| 112 switch(rxBuffer[localRX]) | |
| 113 { | |
| 114 case 'l': | |
| 115 case 'D': | |
| 116 case 'Z': | |
| 117 dataType = rxBuffer[localRX]; | |
| 118 rxState = RX_Data0; | |
| 119 dataValue = 0; | |
| 120 break; | |
| 121 | |
| 122 default: /* unknown or corrupted => ignore */ | |
| 123 break; | |
| 124 } | |
| 125 } | |
| 126 else if((rxState >= RX_Data0) && (rxState <= RX_Data4)) | |
| 127 { | |
| 128 if((rxBuffer[localRX] >= '0') && (rxBuffer[localRX] <= '9')) | |
| 129 { | |
| 130 dataValue = dataValue * 10 + (rxBuffer[localRX] - '0'); | |
| 131 rxState++; | |
| 132 } | |
| 133 } | |
| 134 if((rxBuffer[localRX] == ' ') || (rxBuffer[localRX] == '\n')) /* Abort data detection */ | |
| 135 { | |
| 136 if(rxState == RX_DataComplete) | |
| 137 { | |
| 138 if(externalInterface_GetCO2State() == 0) | |
| 139 { | |
| 140 externalInterface_SetCO2State(EXT_INTERFACE_33V_ON); | |
| 141 } | |
| 142 switch(dataType) | |
| 143 { | |
| 144 case 'D': externalInterface_SetCO2SignalStrength(dataValue); | |
| 145 break; | |
| 146 case 'l': LED_ZeroOffset = dataValue; | |
| 147 break; | |
| 148 case 'Z': externalInterface_SetCO2Value(dataValue); | |
| 149 break; | |
| 150 default: break; | |
| 151 } | |
| 152 } | |
| 153 if(rxState != RX_Data0) /* reset state machine because message in wrong format */ | |
| 154 { | |
| 155 rxState = RX_Ready; | |
| 156 } | |
| 157 } | |
| 158 | |
| 159 localRX++; | |
| 160 rxReadIndex++; | |
| 161 if(rxReadIndex >= CHUNK_SIZE * CHUNKS_PER_BUFFER) | |
| 162 { | |
| 163 localRX = 0; | |
| 164 rxReadIndex = 0; | |
| 165 } | |
| 166 } | |
| 167 | |
| 168 if(time_elapsed_ms(lastReceiveTick,HAL_GetTick()) > 2000) /* check for communication timeout */ | |
| 169 { | |
| 170 externalInterface_SetCO2State(0); | |
| 171 } | |
| 172 | |
| 173 if((dmaActive == 0) && (externalInterface_isEnabledPower33())) /* Should never happen in normal operation => restart in case of communication error */ | |
| 174 { | |
| 175 if(HAL_OK == HAL_UART_Receive_DMA (&huart1, &rxBuffer[rxWriteIndex], CHUNK_SIZE)) | |
| 176 { | |
| 177 dmaActive = 1; | |
| 178 } | |
| 179 } | |
| 180 } | |
| 181 | |
| 182 void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart) | |
| 183 { | |
| 184 if(huart == &huart1) | |
| 185 { | |
| 186 dmaActive = 0; | |
| 187 rxWriteIndex+=CHUNK_SIZE; | |
| 188 if(rxWriteIndex >= CHUNK_SIZE * CHUNKS_PER_BUFFER) | |
| 189 { | |
| 190 rxWriteIndex = 0; | |
| 191 } | |
| 192 if((rxWriteIndex / CHUNK_SIZE) != (rxReadIndex / CHUNK_SIZE)) /* start next transfer if we did not catch up with read index */ | |
| 193 { | |
| 194 if(externalInterface_isEnabledPower33()) | |
| 195 { | |
| 196 if(HAL_OK == HAL_UART_Receive_DMA (&huart1, &rxBuffer[rxWriteIndex], CHUNK_SIZE)) | |
| 197 { | |
| 198 dmaActive = 1; | |
| 199 } | |
| 200 } | |
| 201 } | |
| 202 } | |
| 203 } | |
| 204 | |
| 205 | |
| 206 | |
| 207 | |
| 208 | |
| 209 | |
| 74 | 210 |
| 75 | 211 |
| 76 /************************ (C) COPYRIGHT heinrichs weikamp *****END OF FILE****/ | 212 /************************ (C) COPYRIGHT heinrichs weikamp *****END OF FILE****/ |
