mirror of
https://github.com/betaflight/betaflight.git
synced 2025-07-22 07:45:29 +03:00
BST Port
This commit is contained in:
parent
1adcfaa798
commit
6da7ced9be
9 changed files with 2169 additions and 0 deletions
2
Makefile
2
Makefile
|
@ -536,6 +536,8 @@ CHEBUZZF3_SRC = \
|
||||||
|
|
||||||
COLIBRI_RACE_SRC = \
|
COLIBRI_RACE_SRC = \
|
||||||
$(STM32F30x_COMMON_SRC) \
|
$(STM32F30x_COMMON_SRC) \
|
||||||
|
io/i2c_bst.c \
|
||||||
|
drivers/bus_bst_stm32f30x.c \
|
||||||
drivers/display_ug2864hsweg01.c \
|
drivers/display_ug2864hsweg01.c \
|
||||||
drivers/accgyro_mpu.c \
|
drivers/accgyro_mpu.c \
|
||||||
drivers/accgyro_mpu6500.c \
|
drivers/accgyro_mpu6500.c \
|
||||||
|
|
|
@ -838,6 +838,14 @@ void validateAndFixConfig(void)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(COLIBRI_RACE)
|
||||||
|
masterConfig.serialConfig.portConfigs[0].functionMask = FUNCTION_MSP;
|
||||||
|
if(featureConfigured(FEATURE_RX_SERIAL)) {
|
||||||
|
masterConfig.serialConfig.portConfigs[2].functionMask = FUNCTION_RX_SERIAL;
|
||||||
|
masterConfig.rxConfig.serialrx_provider = SERIALRX_SBUS;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
useRxConfig(&masterConfig.rxConfig);
|
useRxConfig(&masterConfig.rxConfig);
|
||||||
|
|
||||||
serialConfig_t *serialConfig = &masterConfig.serialConfig;
|
serialConfig_t *serialConfig = &masterConfig.serialConfig;
|
||||||
|
|
54
src/main/drivers/bus_bst.h
Normal file
54
src/main/drivers/bus_bst.h
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
/*
|
||||||
|
* 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
|
||||||
|
|
||||||
|
#define TBS_CORE_PNP_PRO 0x80
|
||||||
|
#define RESERVED 0x8A
|
||||||
|
#define PNP_PRO_DIDITAL_CURRENT_SENSOR 0xC0
|
||||||
|
#define PNP_PRO_GPS 0xC2
|
||||||
|
#define TSB_BLACKBOX 0xC4
|
||||||
|
#define CLEANFLIGHT_FC 0xC8
|
||||||
|
#define CROSSFIRE_UHF_RECEIVER 0xEC
|
||||||
|
|
||||||
|
#define GPS_POSITION_FRAME_ID 0x02
|
||||||
|
#define GPS_TIME_FRAME_ID 0x03
|
||||||
|
#define FC_ATTITUDE_FRAME_ID 0x1E
|
||||||
|
#define RC_CHANNEL_FRAME_ID 0x15
|
||||||
|
#define CROSSFIRE_RSSI_FRAME_ID 0x14
|
||||||
|
|
||||||
|
typedef enum BSTDevice {
|
||||||
|
BSTDEV_1,
|
||||||
|
BSTDEV_2,
|
||||||
|
BSTDEV_MAX = BSTDEV_2,
|
||||||
|
} BSTDevice;
|
||||||
|
|
||||||
|
void bstInit(BSTDevice index);
|
||||||
|
uint16_t bstGetErrorCounter(void);
|
||||||
|
|
||||||
|
bool bstWriteBusy(void);
|
||||||
|
bool bstMasterWrite(uint8_t* data);
|
||||||
|
bool bstSlaveRead(uint8_t* buf);
|
||||||
|
bool bstSlaveWrite(uint8_t* data);
|
||||||
|
|
||||||
|
void bstMasterWriteLoop(void);
|
||||||
|
void bstMasterReadLoop(void);
|
||||||
|
|
||||||
|
void crc8Cal(uint8_t data_in);
|
||||||
|
|
||||||
|
|
||||||
|
|
396
src/main/drivers/bus_bst_stm32f30x.c
Normal file
396
src/main/drivers/bus_bst_stm32f30x.c
Normal file
|
@ -0,0 +1,396 @@
|
||||||
|
/* By Larry Ho Ka Wai @ 23/06/2015*/
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <math.h>
|
||||||
|
#include <ctype.h>
|
||||||
|
|
||||||
|
#include <platform.h>
|
||||||
|
|
||||||
|
#include <build_config.h>
|
||||||
|
|
||||||
|
#include "bus_bst.h"
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef USE_BST
|
||||||
|
#define BST_SHORT_TIMEOUT ((uint32_t)0x1000)
|
||||||
|
#define BST_LONG_TIMEOUT ((uint32_t)(10 * BST_SHORT_TIMEOUT))
|
||||||
|
|
||||||
|
#if !defined(BST1_SCL_GPIO)
|
||||||
|
#define BST1_SCL_GPIO GPIOB
|
||||||
|
#define BST1_SCL_GPIO_AF GPIO_AF_4
|
||||||
|
#define BST1_SCL_PIN GPIO_Pin_6
|
||||||
|
#define BST1_SCL_PIN_SOURCE GPIO_PinSource6
|
||||||
|
#define BST1_SCL_CLK_SOURCE RCC_AHBPeriph_GPIOB
|
||||||
|
#define BST1_SDA_GPIO GPIOB
|
||||||
|
#define BST1_SDA_GPIO_AF GPIO_AF_4
|
||||||
|
#define BST1_SDA_PIN GPIO_Pin_7
|
||||||
|
#define BST1_SDA_PIN_SOURCE GPIO_PinSource7
|
||||||
|
#define BST1_SDA_CLK_SOURCE RCC_AHBPeriph_GPIOB
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined(BST2_SCL_GPIO)
|
||||||
|
#define BST2_SCL_GPIO GPIOF
|
||||||
|
#define BST2_SCL_GPIO_AF GPIO_AF_4
|
||||||
|
#define BST2_SCL_PIN GPIO_Pin_6
|
||||||
|
#define BST2_SCL_PIN_SOURCE GPIO_PinSource6
|
||||||
|
#define BST2_SCL_CLK_SOURCE RCC_AHBPeriph_GPIOF
|
||||||
|
#define BST2_SDA_GPIO GPIOA
|
||||||
|
#define BST2_SDA_GPIO_AF GPIO_AF_4
|
||||||
|
#define BST2_SDA_PIN GPIO_Pin_10
|
||||||
|
#define BST2_SDA_PIN_SOURCE GPIO_PinSource10
|
||||||
|
#define BST2_SDA_CLK_SOURCE RCC_AHBPeriph_GPIOA
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static uint32_t bstTimeout;
|
||||||
|
|
||||||
|
static volatile uint16_t bst1ErrorCount = 0;
|
||||||
|
static volatile uint16_t bst2ErrorCount = 0;
|
||||||
|
|
||||||
|
static I2C_TypeDef *BSTx = NULL;
|
||||||
|
|
||||||
|
volatile uint8_t CRC8 = 0;
|
||||||
|
volatile bool coreProReady = false;
|
||||||
|
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
// BST TimeoutUserCallback
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
uint32_t bstTimeoutUserCallback(I2C_TypeDef *BSTx)
|
||||||
|
{
|
||||||
|
if (BSTx == I2C1) {
|
||||||
|
bst1ErrorCount++;
|
||||||
|
} else {
|
||||||
|
bst2ErrorCount++;
|
||||||
|
}
|
||||||
|
I2C_SoftwareResetCmd(BSTx);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void bstInitPort(I2C_TypeDef *BSTx/*, uint8_t Address*/)
|
||||||
|
{
|
||||||
|
GPIO_InitTypeDef GPIO_InitStructure;
|
||||||
|
I2C_InitTypeDef BST_InitStructure;
|
||||||
|
|
||||||
|
if (BSTx == I2C1) {
|
||||||
|
RCC_AHBPeriphClockCmd(BST1_SCL_CLK_SOURCE | BST1_SDA_CLK_SOURCE, ENABLE);
|
||||||
|
RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C1, ENABLE);
|
||||||
|
RCC_I2CCLKConfig(RCC_I2C1CLK_SYSCLK);
|
||||||
|
|
||||||
|
GPIO_PinAFConfig(BST1_SCL_GPIO, BST1_SCL_PIN_SOURCE, BST1_SCL_GPIO_AF);
|
||||||
|
GPIO_PinAFConfig(BST1_SDA_GPIO, BST1_SDA_PIN_SOURCE, BST1_SDA_GPIO_AF);
|
||||||
|
|
||||||
|
GPIO_StructInit(&GPIO_InitStructure);
|
||||||
|
I2C_StructInit(&BST_InitStructure);
|
||||||
|
|
||||||
|
// Init pins
|
||||||
|
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
|
||||||
|
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
|
||||||
|
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
|
||||||
|
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
|
||||||
|
|
||||||
|
GPIO_InitStructure.GPIO_Pin = BST1_SCL_PIN;
|
||||||
|
GPIO_Init(BST1_SCL_GPIO, &GPIO_InitStructure);
|
||||||
|
|
||||||
|
GPIO_InitStructure.GPIO_Pin = BST1_SDA_PIN;
|
||||||
|
GPIO_Init(BST1_SDA_GPIO, &GPIO_InitStructure);
|
||||||
|
|
||||||
|
I2C_StructInit(&BST_InitStructure);
|
||||||
|
|
||||||
|
BST_InitStructure.I2C_Mode = I2C_Mode_I2C;
|
||||||
|
BST_InitStructure.I2C_AnalogFilter = I2C_AnalogFilter_Enable;
|
||||||
|
BST_InitStructure.I2C_DigitalFilter = 0x00;
|
||||||
|
BST_InitStructure.I2C_OwnAddress1 = CLEANFLIGHT_FC;
|
||||||
|
//BST_InitStructure.I2C_OwnAddress1 = PNP_PRO_GPS;
|
||||||
|
//BST_InitStructure.I2C_OwnAddress1 = Address;
|
||||||
|
BST_InitStructure.I2C_Ack = I2C_Ack_Enable;
|
||||||
|
BST_InitStructure.I2C_AcknowledgedAddress = I2C_AcknowledgedAddress_7bit;
|
||||||
|
BST_InitStructure.I2C_Timing = 0x30E0257A; // 100 Khz, 72Mhz Clock, Analog Filter Delay ON, Rise 100, Fall 10.
|
||||||
|
|
||||||
|
I2C_Init(I2C1, &BST_InitStructure);
|
||||||
|
|
||||||
|
I2C_Cmd(I2C1, ENABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (BSTx == I2C2) {
|
||||||
|
RCC_AHBPeriphClockCmd(BST2_SCL_CLK_SOURCE | BST2_SDA_CLK_SOURCE, ENABLE);
|
||||||
|
RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C2, ENABLE);
|
||||||
|
RCC_I2CCLKConfig(RCC_I2C2CLK_SYSCLK);
|
||||||
|
|
||||||
|
GPIO_PinAFConfig(BST2_SCL_GPIO, BST2_SCL_PIN_SOURCE, BST2_SCL_GPIO_AF);
|
||||||
|
GPIO_PinAFConfig(BST2_SDA_GPIO, BST2_SDA_PIN_SOURCE, BST2_SDA_GPIO_AF);
|
||||||
|
|
||||||
|
GPIO_StructInit(&GPIO_InitStructure);
|
||||||
|
I2C_StructInit(&BST_InitStructure);
|
||||||
|
|
||||||
|
// Init pins
|
||||||
|
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
|
||||||
|
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
|
||||||
|
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
|
||||||
|
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
|
||||||
|
|
||||||
|
GPIO_InitStructure.GPIO_Pin = BST2_SCL_PIN;
|
||||||
|
GPIO_Init(BST2_SCL_GPIO, &GPIO_InitStructure);
|
||||||
|
|
||||||
|
GPIO_InitStructure.GPIO_Pin = BST2_SDA_PIN;
|
||||||
|
GPIO_Init(BST2_SDA_GPIO, &GPIO_InitStructure);
|
||||||
|
|
||||||
|
I2C_StructInit(&BST_InitStructure);
|
||||||
|
|
||||||
|
BST_InitStructure.I2C_Mode = I2C_Mode_I2C;
|
||||||
|
BST_InitStructure.I2C_AnalogFilter = I2C_AnalogFilter_Enable;
|
||||||
|
BST_InitStructure.I2C_DigitalFilter = 0x00;
|
||||||
|
BST_InitStructure.I2C_OwnAddress1 = CLEANFLIGHT_FC;
|
||||||
|
//BST_InitStructure.I2C_OwnAddress1 = PNP_PRO_GPS;
|
||||||
|
//BST_InitStructure.I2C_OwnAddress1 = Address;
|
||||||
|
BST_InitStructure.I2C_Ack = I2C_Ack_Enable;
|
||||||
|
BST_InitStructure.I2C_AcknowledgedAddress = I2C_AcknowledgedAddress_7bit;
|
||||||
|
BST_InitStructure.I2C_Timing = 0x30E0257A; // 100 Khz, 72Mhz Clock, Analog Filter Delay ON, Rise 100, Fall 10.
|
||||||
|
|
||||||
|
I2C_Init(I2C2, &BST_InitStructure);
|
||||||
|
|
||||||
|
I2C_Cmd(I2C2, ENABLE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void bstInit(BSTDevice index)
|
||||||
|
{
|
||||||
|
if (index == BSTDEV_1) {
|
||||||
|
BSTx = I2C1;
|
||||||
|
} else {
|
||||||
|
BSTx = I2C2;
|
||||||
|
}
|
||||||
|
//bstInitPort(BSTx, PNP_PRO_GPS);
|
||||||
|
//bstInitPort(BSTx, CLEANFLIGHT_FC);
|
||||||
|
bstInitPort(BSTx);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16_t bstGetErrorCounter(void)
|
||||||
|
{
|
||||||
|
if (BSTx == I2C1) {
|
||||||
|
return bst1ErrorCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
return bst2ErrorCount;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*************************************************************************************************/
|
||||||
|
uint8_t dataBuffer[64] = {0};
|
||||||
|
uint8_t bufferPointer = 0;
|
||||||
|
uint8_t bstWriteDataLen = 0;
|
||||||
|
|
||||||
|
bool bstWriteBusy(void)
|
||||||
|
{
|
||||||
|
if(bstWriteDataLen)
|
||||||
|
return true;
|
||||||
|
else
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool bstMasterWrite(uint8_t* data)
|
||||||
|
{
|
||||||
|
if(bstWriteDataLen==0) {
|
||||||
|
CRC8 = 0;
|
||||||
|
bufferPointer = 0;
|
||||||
|
dataBuffer[0] = *data;
|
||||||
|
dataBuffer[1] = *(data+1);
|
||||||
|
bstWriteDataLen = dataBuffer[1] + 2;
|
||||||
|
for(uint8_t i=2; i<bstWriteDataLen; i++) {
|
||||||
|
if(i==(bstWriteDataLen-1)) {
|
||||||
|
crc8Cal(0);
|
||||||
|
dataBuffer[i] = CRC8;
|
||||||
|
} else {
|
||||||
|
dataBuffer[i] = *(data+i);
|
||||||
|
crc8Cal((uint8_t)dataBuffer[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool bstSlaveRead(uint8_t* buf) {
|
||||||
|
if(I2C_GetAddressMatched(BSTx)==CLEANFLIGHT_FC && I2C_GetTransferDirection(BSTx) == I2C_Direction_Transmitter) {
|
||||||
|
//if(I2C_GetTransferDirection(BSTx) == I2C_Direction_Transmitter) {
|
||||||
|
uint8_t len = 0;
|
||||||
|
CRC8 = 0;
|
||||||
|
I2C_ClearFlag(BSTx, I2C_FLAG_ADDR);
|
||||||
|
|
||||||
|
/* Wait until RXNE flag is set */
|
||||||
|
bstTimeout = BST_LONG_TIMEOUT;
|
||||||
|
while (I2C_GetFlagStatus(BSTx, I2C_ISR_RXNE) == RESET) {
|
||||||
|
if ((bstTimeout--) == 0) {
|
||||||
|
return bstTimeoutUserCallback(BSTx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
len = I2C_ReceiveData(BSTx);
|
||||||
|
*buf = len;
|
||||||
|
buf++;
|
||||||
|
while (len) {
|
||||||
|
/* Wait until RXNE flag is set */
|
||||||
|
bstTimeout = BST_LONG_TIMEOUT;
|
||||||
|
while (I2C_GetFlagStatus(BSTx, I2C_ISR_RXNE) == RESET) {
|
||||||
|
if ((bstTimeout--) == 0) {
|
||||||
|
return bstTimeoutUserCallback(BSTx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Read data from RXDR */
|
||||||
|
*buf = I2C_ReceiveData(BSTx);
|
||||||
|
if(len == 1)
|
||||||
|
crc8Cal(0);
|
||||||
|
else
|
||||||
|
crc8Cal((uint8_t)*buf);
|
||||||
|
|
||||||
|
/* Point to the next location where the byte read will be saved */
|
||||||
|
buf++;
|
||||||
|
|
||||||
|
/* Decrement the read bytes counter */
|
||||||
|
len--;
|
||||||
|
}
|
||||||
|
/* If all operations OK */
|
||||||
|
return true;
|
||||||
|
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool bstSlaveWrite(uint8_t* data) {
|
||||||
|
bstTimeout = BST_LONG_TIMEOUT;
|
||||||
|
while (I2C_GetFlagStatus(BSTx, I2C_ISR_ADDR) == RESET) {
|
||||||
|
if ((bstTimeout--) == 0) {
|
||||||
|
return bstTimeoutUserCallback(BSTx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(I2C_GetAddressMatched(BSTx)==CLEANFLIGHT_FC && I2C_GetTransferDirection(BSTx) == I2C_Direction_Receiver) {
|
||||||
|
//if(I2C_GetTransferDirection(BSTx) == I2C_Direction_Receiver) {
|
||||||
|
uint8_t len = 0;
|
||||||
|
CRC8 = 0;
|
||||||
|
I2C_ClearFlag(BSTx, I2C_FLAG_ADDR);
|
||||||
|
|
||||||
|
/* Wait until TXIS flag is set */
|
||||||
|
bstTimeout = BST_LONG_TIMEOUT;
|
||||||
|
while (I2C_GetFlagStatus(BSTx, I2C_ISR_TXIS) == RESET) {
|
||||||
|
if ((bstTimeout--) == 0) {
|
||||||
|
return bstTimeoutUserCallback(BSTx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
len = *data;
|
||||||
|
data++;
|
||||||
|
I2C_SendData(BSTx, (uint8_t) len);
|
||||||
|
while(len) {
|
||||||
|
/* Wait until TXIS flag is set */
|
||||||
|
bstTimeout = BST_LONG_TIMEOUT;
|
||||||
|
while (I2C_GetFlagStatus(BSTx, I2C_ISR_TXIS) == RESET) {
|
||||||
|
if ((bstTimeout--) == 0) {
|
||||||
|
return bstTimeoutUserCallback(BSTx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(len == 1) {
|
||||||
|
crc8Cal(0);
|
||||||
|
I2C_SendData(BSTx, (uint8_t) CRC8);
|
||||||
|
} else {
|
||||||
|
crc8Cal((uint8_t)*data);
|
||||||
|
I2C_SendData(BSTx, (uint8_t)*data);
|
||||||
|
}
|
||||||
|
/* Point to the next location where the byte read will be saved */
|
||||||
|
data++;
|
||||||
|
|
||||||
|
/* Decrement the read bytes counter */
|
||||||
|
len--;
|
||||||
|
}
|
||||||
|
/* If all operations OK */
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*************************************************************************************************/
|
||||||
|
|
||||||
|
uint32_t bstMasterWriteTimeout = 0;
|
||||||
|
void bstMasterWriteLoop(void)
|
||||||
|
{
|
||||||
|
if(bstWriteDataLen != 0) {
|
||||||
|
if(bufferPointer == 0) {
|
||||||
|
bool scl_set = false;
|
||||||
|
if(BSTx == I2C1)
|
||||||
|
scl_set = BST1_SCL_GPIO->IDR&BST1_SCL_PIN;
|
||||||
|
else
|
||||||
|
scl_set = BST2_SCL_GPIO->IDR&BST2_SCL_PIN;
|
||||||
|
|
||||||
|
if(I2C_GetFlagStatus(BSTx, I2C_ISR_BUSY)==RESET && scl_set) {
|
||||||
|
/* Configure slave address, nbytes, reload, end mode and start or stop generation */
|
||||||
|
I2C_TransferHandling(BSTx, dataBuffer[bufferPointer], 1, I2C_Reload_Mode, I2C_Generate_Start_Write);
|
||||||
|
bstMasterWriteTimeout = micros();
|
||||||
|
bufferPointer++;
|
||||||
|
}
|
||||||
|
} else if(bufferPointer == 1) {
|
||||||
|
if(I2C_GetFlagStatus(BSTx, I2C_ISR_TXIS)==SET) {
|
||||||
|
/* Send Register len */
|
||||||
|
I2C_SendData(BSTx, (uint8_t) dataBuffer[bufferPointer]);
|
||||||
|
bstMasterWriteTimeout = micros();
|
||||||
|
} else if(I2C_GetFlagStatus(BSTx, I2C_ISR_TCR)==SET) {
|
||||||
|
/* Configure slave address, nbytes, reload, end mode and start or stop generation */
|
||||||
|
I2C_TransferHandling(BSTx, dataBuffer[bufferPointer-1], dataBuffer[bufferPointer], I2C_AutoEnd_Mode, I2C_No_StartStop);
|
||||||
|
bstMasterWriteTimeout = micros();
|
||||||
|
bufferPointer++;
|
||||||
|
}
|
||||||
|
} else if(bufferPointer == bstWriteDataLen) {
|
||||||
|
if(I2C_GetFlagStatus(BSTx, I2C_ISR_STOPF)==SET) {
|
||||||
|
I2C_ClearFlag(BSTx, I2C_ICR_STOPCF);
|
||||||
|
bstWriteDataLen = 0;
|
||||||
|
bufferPointer = 0;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if(I2C_GetFlagStatus(BSTx, I2C_ISR_TXIS)==SET) {
|
||||||
|
I2C_SendData(BSTx, (uint8_t) dataBuffer[bufferPointer]);
|
||||||
|
bstMasterWriteTimeout = micros();
|
||||||
|
bufferPointer++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
uint32_t currentTime = micros();
|
||||||
|
if(currentTime>bstMasterWriteTimeout+5000) {
|
||||||
|
I2C_SoftwareResetCmd(BSTx);
|
||||||
|
bstWriteDataLen = 0;
|
||||||
|
bufferPointer = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void bstMasterReadLoop(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
/*************************************************************************************************/
|
||||||
|
void crc8Cal(uint8_t data_in)
|
||||||
|
{
|
||||||
|
/* Polynom = x^8+x^7+x^6+x^4+x^2+1 = x^8+x^7+x^6+x^4+x^2+X^0 */
|
||||||
|
uint8_t Polynom = BST_CRC_POLYNOM;
|
||||||
|
bool MSB_Flag;
|
||||||
|
|
||||||
|
/* Step through each bit of the BYTE (8-bits) */
|
||||||
|
for (uint8_t i = 0; i < 8; i++) {
|
||||||
|
/* Clear the Flag */
|
||||||
|
MSB_Flag = false;
|
||||||
|
|
||||||
|
/* MSB_Set = 80; */
|
||||||
|
if (CRC8 & 0x80) {
|
||||||
|
MSB_Flag = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
CRC8 <<= 1;
|
||||||
|
|
||||||
|
/* MSB_Set = 80; */
|
||||||
|
if (data_in & 0x80) {
|
||||||
|
CRC8++;
|
||||||
|
}
|
||||||
|
data_in <<= 1;
|
||||||
|
|
||||||
|
if (MSB_Flag == true) {
|
||||||
|
CRC8 ^= Polynom;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
1657
src/main/io/i2c_bst.c
Normal file
1657
src/main/io/i2c_bst.c
Normal file
File diff suppressed because it is too large
Load diff
30
src/main/io/i2c_bst.h
Normal file
30
src/main/io/i2c_bst.h
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
/*
|
||||||
|
* 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
|
||||||
|
|
||||||
|
#include "drivers/bus_bst.h"
|
||||||
|
|
||||||
|
void bstProcess(void);
|
||||||
|
|
||||||
|
//void writeGpsPositionPrameToBST(void);
|
||||||
|
//void writeGPSTimeFrameToBST(void);
|
||||||
|
//void writeDataToBST(void);
|
||||||
|
bool writeGpsPositionPrameToBST(void);
|
||||||
|
bool writeRollPitchYawToBST(void);
|
||||||
|
bool writeRCChannelToBST(void);
|
||||||
|
|
|
@ -44,6 +44,7 @@
|
||||||
#include "drivers/pwm_rx.h"
|
#include "drivers/pwm_rx.h"
|
||||||
#include "drivers/adc.h"
|
#include "drivers/adc.h"
|
||||||
#include "drivers/bus_i2c.h"
|
#include "drivers/bus_i2c.h"
|
||||||
|
#include "drivers/bus_bst.h"
|
||||||
#include "drivers/bus_spi.h"
|
#include "drivers/bus_spi.h"
|
||||||
#include "drivers/inverter.h"
|
#include "drivers/inverter.h"
|
||||||
#include "drivers/flash_m25p16.h"
|
#include "drivers/flash_m25p16.h"
|
||||||
|
@ -303,6 +304,10 @@ void init(void)
|
||||||
initInverter();
|
initInverter();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef USE_BST
|
||||||
|
bstInit(BST_DEVICE);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef USE_SPI
|
#ifdef USE_SPI
|
||||||
spiInit(SPI1);
|
spiInit(SPI1);
|
||||||
|
|
|
@ -37,6 +37,7 @@
|
||||||
#include "drivers/gpio.h"
|
#include "drivers/gpio.h"
|
||||||
#include "drivers/system.h"
|
#include "drivers/system.h"
|
||||||
#include "drivers/serial.h"
|
#include "drivers/serial.h"
|
||||||
|
#include "drivers/bus_bst.h"
|
||||||
#include "drivers/timer.h"
|
#include "drivers/timer.h"
|
||||||
#include "drivers/pwm_rx.h"
|
#include "drivers/pwm_rx.h"
|
||||||
#include "drivers/gyro_sync.h"
|
#include "drivers/gyro_sync.h"
|
||||||
|
@ -59,6 +60,7 @@
|
||||||
#include "io/gps.h"
|
#include "io/gps.h"
|
||||||
#include "io/ledstrip.h"
|
#include "io/ledstrip.h"
|
||||||
#include "io/serial.h"
|
#include "io/serial.h"
|
||||||
|
#include "io/i2c_bst.h"
|
||||||
#include "io/serial_cli.h"
|
#include "io/serial_cli.h"
|
||||||
#include "io/serial_msp.h"
|
#include "io/serial_msp.h"
|
||||||
#include "io/statusindicator.h"
|
#include "io/statusindicator.h"
|
||||||
|
@ -884,6 +886,12 @@ void loop(void)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef USE_BST
|
||||||
|
bstProcess();
|
||||||
|
bstMasterWriteLoop();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef LED_STRIP
|
#ifdef LED_STRIP
|
||||||
if (feature(FEATURE_LED_STRIP)) {
|
if (feature(FEATURE_LED_STRIP)) {
|
||||||
updateLedStrip();
|
updateLedStrip();
|
||||||
|
|
|
@ -18,6 +18,8 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#define TARGET_BOARD_IDENTIFIER "CLBR"
|
#define TARGET_BOARD_IDENTIFIER "CLBR"
|
||||||
|
#define BST_DEVICE_NAME "COLIBRI RACE"
|
||||||
|
#define BST_DEVICE_NAME_LENGTH 12
|
||||||
|
|
||||||
#define LED0_GPIO GPIOC
|
#define LED0_GPIO GPIOC
|
||||||
#define LED0_PIN Pin_15
|
#define LED0_PIN Pin_15
|
||||||
|
@ -71,6 +73,7 @@
|
||||||
#define BARO
|
#define BARO
|
||||||
#define USE_BARO_MS5611
|
#define USE_BARO_MS5611
|
||||||
|
|
||||||
|
// External I2C MAG
|
||||||
#define MAG
|
#define MAG
|
||||||
#define USE_MAG_HMC5883
|
#define USE_MAG_HMC5883
|
||||||
#define USE_MAG_AK8975
|
#define USE_MAG_AK8975
|
||||||
|
@ -121,6 +124,12 @@
|
||||||
#define I2C2_SDA_PIN_SOURCE GPIO_PinSource10
|
#define I2C2_SDA_PIN_SOURCE GPIO_PinSource10
|
||||||
#define I2C2_SDA_CLK_SOURCE RCC_AHBPeriph_GPIOA
|
#define I2C2_SDA_CLK_SOURCE RCC_AHBPeriph_GPIOA
|
||||||
|
|
||||||
|
#define USE_BST
|
||||||
|
#define BST_DEVICE (BSTDEV_1)
|
||||||
|
/* Configure the CRC peripheral to use the polynomial x8 + x7 + x6 + x4 + x2 + 1 */
|
||||||
|
#define BST_CRC_POLYNOM 0xD5
|
||||||
|
|
||||||
|
|
||||||
#define USE_ADC
|
#define USE_ADC
|
||||||
|
|
||||||
#define ADC_INSTANCE ADC1
|
#define ADC_INSTANCE ADC1
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue