Mercurial > public > ostc4
diff Small_CPU/Src/externalInterface.c @ 932:effadaa3a1f7 Evo_2_23
Cleanup Gnss UART implementation:
The first draft of the internal UART implementation was just a copy of the external UART handling. To avoid duplicated code and maintainance issue both UARTs (external/internal 6/1) share the same functions. To enable this a control structure has to be used as function input which defines the none shared resources like DMA control and rx/tx buffers
author | Ideenmodellierer |
---|---|
date | Sat, 07 Dec 2024 21:28:08 +0100 |
parents | eb4109d7d1e9 |
children | 083afabc6578 |
line wrap: on
line diff
--- a/Small_CPU/Src/externalInterface.c Tue Dec 03 20:32:51 2024 +0100 +++ b/Small_CPU/Src/externalInterface.c Sat Dec 07 21:28:08 2024 +0100 @@ -39,6 +39,7 @@ extern SGlobal global; extern UART_HandleTypeDef huart1; +extern sUartComCtrl Uart1Ctrl; #define ADC_ANSWER_LENGTH (5u) /* 3424 will provide addr + 4 data bytes */ #define ADC_TIMEOUT (10u) /* conversion stuck for unknown reason => restart */ @@ -936,7 +937,7 @@ tmpSensorMap[EXT_INTERFACE_MUX_OFFSET] = SENSOR_SENTINEL; externalInterface_SwitchUART(EXT_INTERFACE_UART_SENTINEL); externalInterface_CheckBaudrate(SENSOR_SENTINEL); - UART_StartDMA_Receiption(); + UART_StartDMA_Receiption(&Uart1Ctrl); } break; @@ -1144,7 +1145,7 @@ if(externalInterface_SensorState[activeSensorId] != UART_COMMON_INIT) { UART_ReadData(pmap[activeSensorId]); - UART_WriteData(); + UART_WriteData(&Uart1Ctrl); } if(externalInterface_SensorState[activeSensorId] == UART_COMMON_INIT) { @@ -1175,7 +1176,8 @@ if((externalInterface_SensorState[activeSensorId] == UART_O2_REQ_O2) /* timeout */ || (externalInterface_SensorState[activeSensorId] == UART_O2_REQ_RAW) || (externalInterface_SensorState[activeSensorId] == UART_CO2_OPERATING) - || (externalInterface_SensorState[activeSensorId] == UART_GNSS_GET_PVT)) + || (externalInterface_SensorState[activeSensorId] == UART_GNSS_GET_PVT) + || (externalInterface_SensorState[activeSensorId] == UART_GNSS_GET_SAT)) { forceMuxChannel = 1; externalInterface_SensorState[activeSensorId] = UART_O2_IDLE;