mirror of
https://github.com/betaflight/betaflight.git
synced 2025-07-17 21:35:44 +03:00
Move internal serial interface into separate header file
Declaring function from other file is quite dangerous - there is no warning if interfaces get out of sync
This commit is contained in:
parent
7c263254b2
commit
7c62ec9755
5 changed files with 32 additions and 10 deletions
|
@ -34,10 +34,7 @@
|
||||||
|
|
||||||
#include "serial.h"
|
#include "serial.h"
|
||||||
#include "serial_uart.h"
|
#include "serial_uart.h"
|
||||||
|
#include "serial_uart_impl.h"
|
||||||
uartPort_t *serialUSART1(uint32_t baudRate, portMode_t mode);
|
|
||||||
uartPort_t *serialUSART2(uint32_t baudRate, portMode_t mode);
|
|
||||||
uartPort_t *serialUSART3(uint32_t baudRate, portMode_t mode);
|
|
||||||
|
|
||||||
static void usartConfigurePinInversion(uartPort_t *uartPort) {
|
static void usartConfigurePinInversion(uartPort_t *uartPort) {
|
||||||
#if !defined(INVERTER) && !defined(STM32F303xC)
|
#if !defined(INVERTER) && !defined(STM32F303xC)
|
||||||
|
|
|
@ -44,8 +44,6 @@ typedef struct {
|
||||||
USART_TypeDef *USARTx;
|
USART_TypeDef *USARTx;
|
||||||
} uartPort_t;
|
} uartPort_t;
|
||||||
|
|
||||||
extern const struct serialPortVTable uartVTable[];
|
|
||||||
|
|
||||||
serialPort_t *uartOpen(USART_TypeDef *USARTx, serialReceiveCallbackPtr callback, uint32_t baudRate, portMode_t mode, serialInversion_e inversion);
|
serialPort_t *uartOpen(USART_TypeDef *USARTx, serialReceiveCallbackPtr callback, uint32_t baudRate, portMode_t mode, serialInversion_e inversion);
|
||||||
|
|
||||||
// serialPort API
|
// serialPort API
|
||||||
|
|
29
src/main/drivers/serial_uart_impl.h
Normal file
29
src/main/drivers/serial_uart_impl.h
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
/*
|
||||||
|
* This file is part of Cleanflight.
|
||||||
|
*
|
||||||
|
* Cleanflight is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Cleanflight is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Cleanflight. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
// device specific uart implementation is defined here
|
||||||
|
|
||||||
|
extern const struct serialPortVTable uartVTable[];
|
||||||
|
|
||||||
|
void uartStartTxDMA(uartPort_t *s);
|
||||||
|
|
||||||
|
uartPort_t *serialUSART1(uint32_t baudRate, portMode_t mode);
|
||||||
|
uartPort_t *serialUSART2(uint32_t baudRate, portMode_t mode);
|
||||||
|
uartPort_t *serialUSART3(uint32_t baudRate, portMode_t mode);
|
||||||
|
|
|
@ -34,6 +34,7 @@
|
||||||
|
|
||||||
#include "serial.h"
|
#include "serial.h"
|
||||||
#include "serial_uart.h"
|
#include "serial_uart.h"
|
||||||
|
#include "serial_uart_impl.h"
|
||||||
|
|
||||||
#ifdef USE_USART1
|
#ifdef USE_USART1
|
||||||
static uartPort_t uartPort1;
|
static uartPort_t uartPort1;
|
||||||
|
@ -54,8 +55,6 @@ static uartPort_t uartPort3;
|
||||||
#undef USE_USART1_RX_DMA
|
#undef USE_USART1_RX_DMA
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void uartStartTxDMA(uartPort_t *s);
|
|
||||||
|
|
||||||
void usartIrqCallback(uartPort_t *s)
|
void usartIrqCallback(uartPort_t *s)
|
||||||
{
|
{
|
||||||
uint16_t SR = s->USARTx->SR;
|
uint16_t SR = s->USARTx->SR;
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
|
|
||||||
#include "serial.h"
|
#include "serial.h"
|
||||||
#include "serial_uart.h"
|
#include "serial_uart.h"
|
||||||
|
#include "serial_uart_impl.h"
|
||||||
|
|
||||||
// Using RX DMA disables the use of receive callbacks
|
// Using RX DMA disables the use of receive callbacks
|
||||||
#define USE_USART1_RX_DMA
|
#define USE_USART1_RX_DMA
|
||||||
|
@ -74,8 +75,6 @@ static uartPort_t uartPort1;
|
||||||
static uartPort_t uartPort2;
|
static uartPort_t uartPort2;
|
||||||
static uartPort_t uartPort3;
|
static uartPort_t uartPort3;
|
||||||
|
|
||||||
void uartStartTxDMA(uartPort_t *s);
|
|
||||||
|
|
||||||
uartPort_t *serialUSART1(uint32_t baudRate, portMode_t mode)
|
uartPort_t *serialUSART1(uint32_t baudRate, portMode_t mode)
|
||||||
{
|
{
|
||||||
uartPort_t *s;
|
uartPort_t *s;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue