From 9c0d7044e2c0bf614da0df859ade25676cb0bdd8 Mon Sep 17 00:00:00 2001
From: nerdCopter <56646290+nerdCopter@users.noreply.github.com>
Date: Wed, 14 Jun 2023 10:36:17 -0500
Subject: [PATCH 1/6] bugfix gating USE_GYRO_DATA_ANALYSE (#917)
bugfix gating USE_GYRO_DATA_ANALYSE when is used
---
src/main/flight/pid.c | 4 +++-
src/main/sensors/gyro.h | 2 ++
2 files changed, 5 insertions(+), 1 deletion(-)
diff --git a/src/main/flight/pid.c b/src/main/flight/pid.c
index 2344beb3d5..19b51d18f7 100644
--- a/src/main/flight/pid.c
+++ b/src/main/flight/pid.c
@@ -315,12 +315,14 @@ void pidInitFilters(const pidProfile_t *pidProfile) {
dtermABGapplyFn = (filterApplyFnPtr)alphaBetaGammaApply;
ABGInit(&dtermABG[axis], pidProfile->dterm_ABG_alpha, pidProfile->dterm_ABG_boost, pidProfile->dterm_ABG_half_life, dT);
}
-
+#ifdef USE_GYRO_DATA_ANALYSE
if (isDynamicFilterActive()) {
for (int axis2 = 0; axis2 < gyroConfig()->dyn_notch_count; axis2++) {
biquadFilterInit(&dtermNotch[axis][axis2], 400, targetPidLooptime, gyroConfig()->dyn_notch_q / 100.0f, FILTER_NOTCH);
}
}
+#endif
+
}
#if defined(USE_THROTTLE_BOOST)
diff --git a/src/main/sensors/gyro.h b/src/main/sensors/gyro.h
index 4387c872e3..0f32c699e1 100644
--- a/src/main/sensors/gyro.h
+++ b/src/main/sensors/gyro.h
@@ -198,7 +198,9 @@ bool gyroYawSpinDetected(void);
uint16_t gyroAbsRateDps(int axis);
uint8_t gyroReadRegister(uint8_t whichSensor, uint8_t reg);
float applySmithPredictor(smithPredictor_t *smithPredictor, float gyroFiltered);
+#ifdef USE_GYRO_DATA_ANALYSE
bool isDynamicFilterActive(void);
+#endif
#ifdef USE_YAW_SPIN_RECOVERY
void initYawSpinRecovery(int maxYawRate);
#endif
From a0b59bba2b204e301b10d3aa8abcb95b48de27d4 Mon Sep 17 00:00:00 2001
From: nerdCopter <56646290+nerdCopter@users.noreply.github.com>
Date: Fri, 30 Jun 2023 11:06:54 -0500
Subject: [PATCH 2/6] [Target] fix FLYWOOF411_5IN1_AIO ICM42688P alignment
(#911)
fix FLYWOOF411_5IN1_AIO ICM42688P align
---
src/main/target/FLYWOOF411_5IN1_AIO/target.h | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/main/target/FLYWOOF411_5IN1_AIO/target.h b/src/main/target/FLYWOOF411_5IN1_AIO/target.h
index fc3d6d1f90..5e93cd6460 100644
--- a/src/main/target/FLYWOOF411_5IN1_AIO/target.h
+++ b/src/main/target/FLYWOOF411_5IN1_AIO/target.h
@@ -66,8 +66,8 @@
#define ICM42688P_SPI_INSTANCE SPI1
#define ICM42688P_CS_PIN PB2
-#define ACC_ICM426XX_ALIGN CW90_DEG
-#define GYRO_ICM426XX_ALIGN CW90_DEG
+#define ACC_ICM42688P_ALIGN CW0_DEG_FLIP
+#define GYRO_ICM42688P_ALIGN CW0_DEG_FLIP
// *************** Baro **************************
#define USE_I2C
From f25f0494a7fa07a8f028d642483e9053116e7926 Mon Sep 17 00:00:00 2001
From: BeauBrewski <85623381+BeauBrewski@users.noreply.github.com>
Date: Wed, 12 Jul 2023 11:03:18 -0500
Subject: [PATCH 3/6] [Target] IFLIGHT_F745_AIO_V2 (MPU6000 Only) (#895)
* IFLIGHT_F745_AIO_V2 (MPU6000 ONLY) TARGET
* IFLIGHT_F745_AIO_V2 - target.mk replace tabs w/ spaces
---
src/main/target/IFLIGHT_F745_AIO_V2/target.c | 44 ++++
src/main/target/IFLIGHT_F745_AIO_V2/target.h | 188 ++++++++++++++++++
src/main/target/IFLIGHT_F745_AIO_V2/target.mk | 15 ++
3 files changed, 247 insertions(+)
create mode 100644 src/main/target/IFLIGHT_F745_AIO_V2/target.c
create mode 100644 src/main/target/IFLIGHT_F745_AIO_V2/target.h
create mode 100644 src/main/target/IFLIGHT_F745_AIO_V2/target.mk
diff --git a/src/main/target/IFLIGHT_F745_AIO_V2/target.c b/src/main/target/IFLIGHT_F745_AIO_V2/target.c
new file mode 100644
index 0000000000..c57c497050
--- /dev/null
+++ b/src/main/target/IFLIGHT_F745_AIO_V2/target.c
@@ -0,0 +1,44 @@
+/*
+ * This file is part of Cleanflight and Betaflight.
+ *
+ * Cleanflight and Betaflight are free software. You can redistribute
+ * this software and/or modify this software 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 and Betaflight are distributed in the hope that they
+ * 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 this software.
+ *
+ * If not, see .
+ */
+
+#include
+
+#include "platform.h"
+#include "drivers/io.h"
+
+#include "drivers/dma.h"
+#include "drivers/timer.h"
+#include "drivers/timer_def.h"
+
+const timerHardware_t timerHardware[USABLE_TIMER_CHANNEL_COUNT] = {
+
+ DEF_TIM(TIM1, CH1, PA8, TIM_USE_LED, 0, 0 ), //LED
+ DEF_TIM(TIM2, CH2, PB3, TIM_USE_ANY, 0, 0 ), //CAM
+
+ DEF_TIM(TIM3, CH3, PB0, TIM_USE_MOTOR, 0, 0 ), // M1
+ DEF_TIM(TIM3, CH4, PB1, TIM_USE_MOTOR, 0, 0 ), // M2
+ DEF_TIM(TIM3, CH1, PB4, TIM_USE_MOTOR, 0, 0 ), // M3
+ DEF_TIM(TIM3, CH2, PB5, TIM_USE_MOTOR, 0, 0 ), // M4
+ DEF_TIM(TIM4, CH1, PD12, TIM_USE_MOTOR, 0, 0 ), // M5
+ DEF_TIM(TIM4, CH2, PD13, TIM_USE_MOTOR, 0, 0 ), // M6
+ DEF_TIM(TIM8, CH3, PC8, TIM_USE_MOTOR, 0, 1 ), // M7
+ DEF_TIM(TIM8, CH4, PC9, TIM_USE_MOTOR, 0, 0 ), // M8
+
+ };
diff --git a/src/main/target/IFLIGHT_F745_AIO_V2/target.h b/src/main/target/IFLIGHT_F745_AIO_V2/target.h
new file mode 100644
index 0000000000..6eec787ed9
--- /dev/null
+++ b/src/main/target/IFLIGHT_F745_AIO_V2/target.h
@@ -0,0 +1,188 @@
+/*
+ * This file is part of Cleanflight and Betaflight.
+ *
+ * Cleanflight and Betaflight are free software. You can redistribute
+ * this software and/or modify this software 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 and Betaflight are distributed in the hope that they
+ * 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 this software.
+ *
+ * If not, see .
+ */
+
+#pragma once
+
+#define TARGET_BOARD_IDENTIFIER "IFRC"
+
+#define USBD_PRODUCT_STRING "IFLIGHT_F745_AIO_V2"
+
+#define ENABLE_DSHOT_DMAR true
+
+#define LED0_PIN PC13
+
+#define USE_BEEPER
+#define BEEPER_PIN PD2
+#define BEEPER_INVERTED
+
+//**********Gyro Acc *************//
+
+#define USE_ACC
+#define USE_GYRO
+#define USE_DUAL_GYRO
+
+#define USE_SPI_GYRO
+//#define USE_ACCGYRO_BMI270
+#define USE_GYRO_SPI_MPU6000
+#define USE_ACC_SPI_MPU6000
+
+#define USE_EXTI
+#define USE_GYRO_EXTI
+#define GYRO_1_EXTI_PIN PD0
+#define GYRO_2_EXTI_PIN PD8
+#define MPU_INT_EXTI
+
+#define GYRO_1_CS_PIN PA4
+#define GYRO_1_SPI_INSTANCE SPI1
+#define GYRO_2_CS_PIN PB12
+#define GYRO_2_SPI_INSTANCE SPI2
+
+#define GYRO_1_ALIGN CW0_DEG
+#define ACC_1_ALIGN CW0_DEG
+#define GYRO_2_ALIGN CW180_DEG
+#define ACC_2_ALIGN CW180_DEG
+
+#define USE_MPU_DATA_READY_SIGNAL
+#define ENSURE_MPU_DATA_READY_IS_LOW
+#define GYRO_CONFIG_USE_GYRO_DEFAULT GYRO_CONFIG_USE_GYRO_1
+
+//**********Mag and Baro**********//
+
+#define USE_MAG
+#define USE_MAG_HMC5883
+#define USE_MAG_QMC5883
+#define MAG_HMC5883_ALIGN CW180_DEG
+#define MAG_QMC5883_ALIGN CW180_DEG
+#define MAG_I2C_INSTANCE (I2CDEV_1)
+
+#define USE_BARO
+#define USE_BARO_MS5611
+#define USE_BARO_BMP280
+#define USE_BARO_DPS310
+#define BARO_I2C_INSTANCE (I2CDEV_1)
+
+//**********Serial****************//
+
+#define USE_VCP
+//#define USE_USB_DETECT
+//#define USB_DETECT_PIN PC4
+
+#define USE_UART1
+#define UART1_RX_PIN PA10
+#define UART1_TX_PIN PA9
+
+#define USE_UART2
+#define UART2_RX_PIN PA3
+#define UART2_TX_PIN PA2
+
+#define USE_UART3
+#define UART3_RX_PIN PB11
+#define UART3_TX_PIN PB10
+
+#define USE_UART4
+#define UART4_RX_PIN PA1
+#define UART4_TX_PIN PA0
+
+#define USE_UART6
+#define UART6_RX_PIN PC7
+#define UART6_TX_PIN PC6
+
+#define USE_UART7
+#define UART7_RX_PIN PE7
+#define UART7_TX_PIN PE8
+
+#define USE_UART8
+#define UART8_RX_PIN PE0
+#define UART8_TX_PIN PE1
+
+#define SERIAL_PORT_COUNT 8 //VCP, USART1, USART2, USART3, UART4, USART6, USART7, USART8
+
+#define USE_ESCSERIAL
+#define USE_CAMERA_CONTROL
+#define CAMERA_CONTROL_PIN PB3
+
+#define USE_SPI
+#define USE_SPI_DEVICE_1
+#define USE_SPI_DEVICE_2
+#define USE_SPI_DEVICE_3
+#define USE_SPI_DEVICE_4
+
+#define SPI1_SCK_PIN PA5
+#define SPI1_MISO_PIN PA6
+#define SPI1_MOSI_PIN PA7
+
+#define SPI2_SCK_PIN PB13
+#define SPI2_MISO_PIN PB14
+#define SPI2_MOSI_PIN PB15
+
+#define SPI3_SCK_PIN PC10
+#define SPI3_MISO_PIN PC11
+#define SPI3_MOSI_PIN PC12
+
+#define SPI4_SCK_PIN PE2
+#define SPI4_MISO_PIN PE5
+#define SPI4_MOSI_PIN PE6
+
+#define USE_MAX7456
+#define MAX7456_SPI_INSTANCE SPI4
+#define MAX7456_SPI_CS_PIN PE4
+#define MAX7456_SPI_CLK (SPI_CLOCK_STANDARD) // 10MHz
+#define MAX7456_RESTORE_CLK (SPI_CLOCK_FAST)
+
+#define ENABLE_BLACKBOX_LOGGING_ON_SPIFLASH_BY_DEFAULT
+#define USE_FLASHFS
+#define USE_FLASH_M25P16
+#define FLASH_CS_PIN PA15
+#define FLASH_SPI_INSTANCE SPI3
+
+#define USE_I2C
+#define USE_I2C_DEVICE_1
+#define I2C_DEVICE_1 (I2CDEV_1)
+#define I2C1_SCL PB8
+#define I2C1_SDA PB9
+
+#define USE_I2C_DEVICE_2
+#define I2C_DEVICE_2 (I2CDEV_2)
+#define I2C2_SCL PB10
+#define I2C2_SDA PB11
+
+#define USE_ADC
+#define VBAT_ADC_PIN PC3
+#define CURRENT_METER_ADC_PIN PC2
+#define RSSI_ADC_PIN PC5
+#define DEFAULT_VOLTAGE_METER_SOURCE VOLTAGE_METER_ADC
+#define DEFAULT_CURRENT_METER_SOURCE CURRENT_METER_ADC
+#define CURRENT_METER_SCALE_DEFAULT 100
+
+#define USE_LED_STRIP
+
+#define DEFAULT_FEATURES (FEATURE_OSD | FEATURE_TELEMETRY )
+#define DEFAULT_RX_FEATURE FEATURE_RX_SERIAL
+#define SERIALRX_PROVIDER SERIALRX_SBUS
+
+#define TARGET_IO_PORTA 0xffff
+#define TARGET_IO_PORTB 0xffff
+#define TARGET_IO_PORTC 0xffff
+#define TARGET_IO_PORTD 0xffff
+#define TARGET_IO_PORTE 0xffff
+
+#define USABLE_TIMER_CHANNEL_COUNT 10
+
+#define USED_TIMERS ( TIM_N(1) | TIM_N(2) | TIM_N(3) | TIM_N(4) | TIM_N(8) )
diff --git a/src/main/target/IFLIGHT_F745_AIO_V2/target.mk b/src/main/target/IFLIGHT_F745_AIO_V2/target.mk
new file mode 100644
index 0000000000..525f68127c
--- /dev/null
+++ b/src/main/target/IFLIGHT_F745_AIO_V2/target.mk
@@ -0,0 +1,15 @@
+F7X5XG_TARGETS += $(TARGET)
+FEATURES += VCP ONBOARDFLASH
+
+TARGET_SRC = \
+ drivers/accgyro/accgyro_spi_mpu6000.c \
+ drivers/accgyro/accgyro_mpu.c \
+ drivers/barometer/barometer_ms5611.c \
+ drivers/barometer/barometer_bmp280.c \
+ drivers/barometer/barometer_bmp085.c \
+ drivers/barometer/barometer_ms5611.c \
+ drivers/compass/compass_hmc5883l.c \
+ drivers/compass/compass_qmc5883l.c \
+ drivers/light_ws2811strip.c \
+ drivers/light_ws2811strip_hal.c \
+ drivers/max7456.c
From 75b47d1591249f40f1f9c0fa5aa2422f7a7d9997 Mon Sep 17 00:00:00 2001
From: nerdCopter <56646290+nerdCopter@users.noreply.github.com>
Date: Wed, 23 Aug 2023 11:34:21 -0500
Subject: [PATCH 4/6] [Target] JHEF7DUAL add ICM42688P (#902)
add ICM42688P to JHEF7DUAL
---
src/main/target/JHEF7DUAL/target.h | 7 ++++++-
src/main/target/JHEF7DUAL/target.mk | 1 +
2 files changed, 7 insertions(+), 1 deletion(-)
diff --git a/src/main/target/JHEF7DUAL/target.h b/src/main/target/JHEF7DUAL/target.h
index e7e4e5c221..1545a2a13c 100644
--- a/src/main/target/JHEF7DUAL/target.h
+++ b/src/main/target/JHEF7DUAL/target.h
@@ -53,10 +53,12 @@
#define USE_GYRO
#define USE_GYRO_SPI_MPU6000
#define USE_GYRO_SPI_ICM20689
+#define USE_GYRO_SPI_ICM42688P
#define USE_ACC
#define USE_ACC_SPI_MPU6000
#define USE_ACC_SPI_ICM20689
+#define USE_ACC_SPI_ICM42688P
#define ACC_ICM20689_1_ALIGN CW90_DEG
#define GYRO_ICM20689_1_ALIGN CW90_DEG
@@ -68,6 +70,9 @@
#define GYRO_2_ALIGN GYRO_MPU6000_2_ALIGN
#define ACC_2_ALIGN ACC_MPU6000_2_ALIGN
+#define ACC_ICM42688P_ALIGN CW90_DEG
+#define GYRO_ICM42688P_ALIGN CW90_DEG
+
#define GYRO_CONFIG_USE_GYRO_DEFAULT GYRO_CONFIG_USE_GYRO_1
// *************** Baro **************************
@@ -140,7 +145,7 @@
#define USE_ADC
#define ADC_INSTANCE ADC3
-#define ADC3_DMA_OPT 0 // DMA 2 Stream 0 Channel 2
+#define ADC3_DMA_OPT 0 // DMA 2 Stream 0 Channel 2
#define CURRENT_METER_ADC_PIN PC1
#define VBAT_ADC_PIN PC2
diff --git a/src/main/target/JHEF7DUAL/target.mk b/src/main/target/JHEF7DUAL/target.mk
index 8b16c3f1b2..42e86d325d 100644
--- a/src/main/target/JHEF7DUAL/target.mk
+++ b/src/main/target/JHEF7DUAL/target.mk
@@ -5,6 +5,7 @@ TARGET_SRC = \
drivers/accgyro/accgyro_mpu.c \
drivers/accgyro/accgyro_spi_mpu6000.c \
drivers/accgyro/accgyro_spi_icm20689.c \
+ drivers/accgyro/accgyro_spi_icm426xx.c \
drivers/barometer/barometer_bmp280.c \
drivers/compass/compass_fake.c \
drivers/light_ws2811strip.c \
From b54d768a99a0ab8a4b4474e3682445fc726a9379 Mon Sep 17 00:00:00 2001
From: nerdCopter <56646290+nerdCopter@users.noreply.github.com>
Date: Wed, 23 Aug 2023 11:44:33 -0500
Subject: [PATCH 5/6] [Target] GEPRC_F722_AIO ICM42688P (#903)
* GEPRC_F722_AIO ICM42688P
Co-authored-by: BeauBrewski <85623381+BeauBrewski@users.noreply.github.com>
---
src/main/target/GEPRC_F722_AIO/target.c | 45 +++++++
src/main/target/GEPRC_F722_AIO/target.h | 158 +++++++++++++++++++++++
src/main/target/GEPRC_F722_AIO/target.mk | 15 +++
3 files changed, 218 insertions(+)
create mode 100644 src/main/target/GEPRC_F722_AIO/target.c
create mode 100644 src/main/target/GEPRC_F722_AIO/target.h
create mode 100644 src/main/target/GEPRC_F722_AIO/target.mk
diff --git a/src/main/target/GEPRC_F722_AIO/target.c b/src/main/target/GEPRC_F722_AIO/target.c
new file mode 100644
index 0000000000..5fdda10d02
--- /dev/null
+++ b/src/main/target/GEPRC_F722_AIO/target.c
@@ -0,0 +1,45 @@
+/*
+ * This file is part of Cleanflight and Betaflight.
+ *
+ * Cleanflight and Betaflight are free software. You can redistribute
+ * this software and/or modify this software 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 and Betaflight are distributed in the hope that they
+ * 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 this software.
+ *
+ * If not, see .
+ */
+
+#include
+
+#include "platform.h"
+#include "drivers/io.h"
+
+#include "drivers/dma.h"
+#include "drivers/timer.h"
+#include "drivers/timer_def.h"
+
+const timerHardware_t timerHardware[USABLE_TIMER_CHANNEL_COUNT] = {
+DEF_TIM(TIM5, CH1, PA0, TIM_USE_ANY, 0, 0), //CAMERA CONTROL
+DEF_TIM(TIM9, CH2, PA3, TIM_USE_ANY, 0, 0), //PPM
+
+DEF_TIM(TIM8, CH4, PC9, TIM_USE_MOTOR, 0, 0), //MOTOR 1
+DEF_TIM(TIM8, CH3, PC8, TIM_USE_MOTOR, 0, 1), //MOTOR 2
+DEF_TIM(TIM8, CH2, PC7, TIM_USE_MOTOR, 0, 1), //MOTOR 3
+DEF_TIM(TIM8, CH1, PC6, TIM_USE_MOTOR, 0, 0), //MOTOR 4
+
+//DEF_TIM(TIM4, CH1, PB6, TIM_USE_ANY, 0, 0), //in config but match no pins
+//DEF_TIM(TIM4, CH2, PB7, TIM_USE_ANY, 0, 0), //pretty sure left over from
+//DEF_TIM(TIM3, CH4, PB1, TIM_USE_ANY, 0, 0), //geprc_f722_bthd target/config
+//DEF_TIM(TIM3, CH3, PB0, TIM_USE_ANY, 0, 0), //as match motors 5-8
+
+DEF_TIM(TIM2, CH2, PA1, TIM_USE_LED, 0, 0) //LED
+};
diff --git a/src/main/target/GEPRC_F722_AIO/target.h b/src/main/target/GEPRC_F722_AIO/target.h
new file mode 100644
index 0000000000..2cb368bae7
--- /dev/null
+++ b/src/main/target/GEPRC_F722_AIO/target.h
@@ -0,0 +1,158 @@
+/*
+ * This file is part of Cleanflight and Betaflight.
+ *
+ * Cleanflight and Betaflight are free software. You can redistribute
+ * this software and/or modify this software 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 and Betaflight are distributed in the hope that they
+ * 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 this software.
+ *
+ * If not, see .
+ *
+ * Prepared by Kaio
+ */
+#pragma once
+
+#define TARGET_BOARD_IDENTIFIER "S7X2"
+#define USBD_PRODUCT_STRING "GEPRC_F722_AIO"
+#define TARGET_MANUFACTURER_IDENTIFIER "GEPR"
+
+#define LED0_PIN PC4
+
+#define USE_BEEPER
+#define BEEPER_PIN PC15
+#define BEEPER_INVERTED
+
+#define ENABLE_DSHOT_DMAR true
+
+#define USE_EXTI
+#define MPU_INT_EXTI PA8
+#define USE_MPU_DATA_READY_SIGNAL
+
+#define USE_GYRO
+
+#define USE_GYRO_SPI_ICM42688P
+#define ICM42688P_CS_PIN PA15
+#define ICM42688P_SPI_INSTANCE SPI1
+#define GYRO_ICM42688P_ALIGN CW90_DEG
+
+#define USE_GYRO_SPI_MPU6000
+#define MPU6000_CS_PIN PA15
+#define MPU6000_SPI_INSTANCE SPI1
+#define GYRO_MPU6000_ALIGN CW90_DEG
+
+#define USE_ACC
+
+#define USE_ACC_SPI_ICM42688P
+#define ACC_ICM42688P_ALIGN CW90_DEG
+
+#define USE_ACC_SPI_MPU6000
+#define USE_ACC_SPI_MPU6500
+#define ACC_MPU6000_ALIGN CW90_DEG
+
+#define USE_BARO
+#define USE_BARO_BMP280
+#define USE_BARO_BMP085
+#define USE_BARO_MS5611
+#define BARO_I2C_INSTANCE (I2CDEV_2)
+
+#define USE_MAG
+#define USE_MAG_HMC5883
+#define USE_MAG_QMC5883
+#define MAG_I2C_INSTANCE (I2CDEV_2)
+
+#define USE_MAX7456
+#define MAX7456_SPI_INSTANCE SPI2
+#define MAX7456_SPI_CS_PIN PB12
+
+#define USE_FLASHFS
+#define USE_FLASH_M25P16
+#define FLASH_SPI_INSTANCE SPI3
+#define FLASH_CS_PIN PB9
+#define ENABLE_BLACKBOX_LOGGING_ON_SPIFLASH_BY_DEFAULT
+
+#define USE_VCP
+#define USE_USB_DETECT
+
+#define USE_UART1
+#define UART1_RX_PIN PA10
+#define UART1_TX_PIN PA9
+
+#define USE_UART2
+#define UART2_RX_PIN PA3
+#define UART2_TX_PIN PA2
+
+#define USE_UART3
+#define UART3_RX_PIN PB11
+#define UART3_TX_PIN PB10
+
+#define USE_UART4
+#define UART4_RX_PIN PC11
+#define UART4_TX_PIN PC10
+
+#define USE_UART5
+#define UART5_RX_PIN PD2
+#define UART5_TX_PIN PC12
+
+#define SERIAL_PORT_COUNT 6 //USB + 5 UARTS
+
+#define USE_ESCSERIAL //PPM
+#define ESCSERIAL_TIMER_TX_PIN PA3
+
+#define USE_SPI
+#define USE_SPI_DEVICE_1
+#define SPI1_SCK_PIN PA5
+#define SPI1_MISO_PIN PA6
+#define SPI1_MOSI_PIN PA7
+
+#define USE_SPI_DEVICE_2
+#define SPI2_SCK_PIN PB13
+#define SPI2_MISO_PIN PB14
+#define SPI2_MOSI_PIN PB15
+
+#define USE_SPI_DEVICE_3
+#define SPI3_SCK_PIN PB3
+#define SPI3_MISO_PIN PB4
+#define SPI3_MOSI_PIN PB5
+
+//#define USE_I2C
+//#define USE_I2C_DEVICE_1
+//#define I2C1_SCL PB8
+//#define I2C1_SDA PB9
+//#define I2C_DEVICE (I2CDEV_1)
+
+#define USE_I2C_DEVICE_2
+#define I2C2_SCL PB10
+#define I2C2_SDA PB11
+#define I2C_DEVICE (I2CDEV_2)
+
+#define USE_ADC
+#define ADC3_DMA_STREAM DMA2_Stream0
+#define VBAT_ADC_PIN PC2
+#define CURRENT_METER_ADC_PIN PC1
+//#define RSSI_ADC_PIN PC2
+#define DEFAULT_VOLTAGE_METER_SOURCE VOLTAGE_METER_ADC
+#define DEFAULT_CURRENT_METER_SOURCE CURRENT_METER_ADC
+#define CURRENT_METER_SCALE_DEFAULT 100
+
+#define SERIALRX_PROVIDER SERIALRX_SBUS
+//#define SERIALRX_UART SERIAL_PORT_USART2
+
+#define DEFAULT_RX_FEATURE FEATURE_RX_SERIAL
+#define DEFAULT_FEATURES ( FEATURE_OSD | FEATURE_TELEMETRY )
+
+#define TARGET_IO_PORTA ( 0xffff )
+#define TARGET_IO_PORTB ( 0xffff )
+#define TARGET_IO_PORTC ( 0xffff )
+#define TARGET_IO_PORTD ( 0xffff )
+
+#define USABLE_TIMER_CHANNEL_COUNT 7
+#define USED_TIMERS ( TIM_N(2) | TIM_N(5) | TIM_N(8) | TIM_N(9) )
diff --git a/src/main/target/GEPRC_F722_AIO/target.mk b/src/main/target/GEPRC_F722_AIO/target.mk
new file mode 100644
index 0000000000..ed078d59ff
--- /dev/null
+++ b/src/main/target/GEPRC_F722_AIO/target.mk
@@ -0,0 +1,15 @@
+F7X2RE_TARGETS += $(TARGET)
+FEATURES += VCP ONBOARDFLASH
+TARGET_SRC = \
+ drivers/accgyro/accgyro_spi_icm426xx.c \
+ drivers/accgyro/accgyro_mpu.c \
+ drivers/accgyro/accgyro_mpu6500.c \
+ drivers/accgyro/accgyro_spi_mpu6000.c \
+ drivers/accgyro/accgyro_spi_mpu6500.c \
+ drivers/barometer/barometer_ms5611.c \
+ drivers/barometer/barometer_bmp280.c \
+ drivers/barometer/barometer_bmp085.c \
+ drivers/compass/compass_hmc5883l.c \
+ drivers/compass/compass_qmc5883l.c \
+ drivers/max7456.c\
+ drivers/light_ws2811strip.c
From 11d38e5a06dee654f359d5681b4c4473b4e22b92 Mon Sep 17 00:00:00 2001
From: nerdCopter <56646290+nerdCopter@users.noreply.github.com>
Date: Wed, 23 Aug 2023 13:00:18 -0500
Subject: [PATCH 6/6] [Target] RUSHBLADEF7HD add ICM42688P (#904)
* RUSHBLADEF7HD; ICM42688P, MPU6000
---
.../target.c | 0
src/main/target/RUSHBLADEF7HD/target.h | 156 ++++++++++++++++++
src/main/target/RUSHBLADEF7HD/target.mk | 12 ++
src/main/target/RUSH_BLADE_F7_HD/target.h | 151 -----------------
src/main/target/RUSH_BLADE_F7_HD/target.mk | 11 --
5 files changed, 168 insertions(+), 162 deletions(-)
rename src/main/target/{RUSH_BLADE_F7_HD => RUSHBLADEF7HD}/target.c (100%)
create mode 100644 src/main/target/RUSHBLADEF7HD/target.h
create mode 100644 src/main/target/RUSHBLADEF7HD/target.mk
delete mode 100644 src/main/target/RUSH_BLADE_F7_HD/target.h
delete mode 100644 src/main/target/RUSH_BLADE_F7_HD/target.mk
diff --git a/src/main/target/RUSH_BLADE_F7_HD/target.c b/src/main/target/RUSHBLADEF7HD/target.c
similarity index 100%
rename from src/main/target/RUSH_BLADE_F7_HD/target.c
rename to src/main/target/RUSHBLADEF7HD/target.c
diff --git a/src/main/target/RUSHBLADEF7HD/target.h b/src/main/target/RUSHBLADEF7HD/target.h
new file mode 100644
index 0000000000..3041655e66
--- /dev/null
+++ b/src/main/target/RUSHBLADEF7HD/target.h
@@ -0,0 +1,156 @@
+/*
+* This file is part of Cleanflight and Betaflight.
+*
+* Cleanflight and Betaflight are free software. You can redistribute
+* this software and/or modify this software 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 and Betaflight are distributed in the hope that they
+* 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 this software.
+*
+* If not, see .
+*/
+
+#pragma once
+//#define USE_TARGET_CONFIG
+
+#define TARGET_BOARD_IDENTIFIER "RUSH"
+#define USBD_PRODUCT_STRING "BLADE_F7_HD"
+
+#define ENABLE_DSHOT_DMAR true
+
+#define USE_LED_STRIP
+
+#define LED0_PIN PB10
+
+#define USE_BEEPER
+#define BEEPER_PIN PB2
+#define BEEPER_INVERTED
+
+
+// *************** SPI1 Gyro & ACC *******************
+
+#define USE_SPI
+#define USE_SPI_DEVICE_1
+#define SPI1_SCK_PIN PA5
+#define SPI1_MISO_PIN PA6
+#define SPI1_MOSI_PIN PA7
+
+#define USE_EXTI
+#define USE_GYRO
+#define USE_ACC
+
+#define USE_GYRO_SPI_MPU6000
+#define USE_ACC_SPI_MPU6000
+#define MPU6000_CS_PIN PC4
+#define MPU_INT_EXTI PA4
+#define MPU6000_SPI_INSTANCE SPI1
+#define GYRO_MPU6000_ALIGN CW270_DEG
+#define ACC_MPU6000_ALIGN CW270_DEG
+
+#define USE_GYRO_SPI_ICM42688P
+#define USE_ACC_SPI_ICM42688P
+#define ICM42688P_EXTI_PIN PA4
+#define ICM42688P_CS_PIN PC4
+#define ICM42688P_SPI_INSTANCE SPI1
+#define GYRO_ICM42688P_ALIGN CW270_DEG
+#define ACC_ICM42688P_ALIGN CW270_DEG
+
+#define USE_MPU_DATA_READY_SIGNAL
+#define ENSURE_MPU_DATA_READY_IS_LOW
+
+// *************** I2C /Baro/Mag *********************
+
+#define USE_I2C
+
+#define USE_I2C_DEVICE_1
+#define I2C_DEVICE_1 (I2CDEV_1)
+#define I2C1_SCL PB8
+#define I2C1_SDA PB9
+
+#define BARO_I2C_INSTANCE (I2CDEV_1)
+#define USE_BARO
+#define USE_BARO_BMP280
+#define USE_BARO_MS5611
+#define USE_BARO_BMP085
+
+//#define MAG_I2C_INSTANCE (I2CDEV_1)
+//#define USE_MAG
+//#define USE_MAG_HMC5883
+//#define USE_MAG_QMC5883
+
+// *************** SPI3 BLACKBOX****************
+
+#define USE_SPI_DEVICE_2
+#define SPI2_SCK_PIN PB13
+#define SPI2_MISO_PIN PB14
+#define SPI2_MOSI_PIN PB15
+
+#define ENABLE_BLACKBOX_LOGGING_ON_SPIFLASH_BY_DEFAULT
+#define USE_FLASHFS
+#define USE_FLASH_M25P16
+#define FLASH_CS_PIN PB12
+#define FLASH_SPI_INSTANCE SPI2
+
+// *************** UART *****************************
+
+#define USE_VCP
+#define USE_USB_DETECT
+
+#define USE_UART1
+#define UART1_TX_PIN PA9
+#define UART1_RX_PIN PA10
+
+#define USE_UART2
+#define UART2_TX_PIN PA2
+#define UART2_RX_PIN PA3
+
+#define USE_UART3
+#define UART3_TX_PIN PC10
+#define UART3_RX_PIN PC11
+
+#define USE_UART4
+#define UART4_TX_PIN PA0
+#define UART4_RX_PIN PA1
+
+#define USE_UART5
+#define UART5_TX_PIN PC12
+#define UART5_RX_PIN PD2
+
+#define SERIAL_PORT_COUNT 6
+
+#define DEFAULT_RX_FEATURE FEATURE_RX_SERIAL
+#define SERIALRX_PROVIDER SERIALRX_SBUS
+#define SERIALRX_UART SERIAL_PORT_USART2
+
+// *************** ADC *****************************
+#define USE_ADC
+//#define ADC1_DMA_STREAM DMA2_Stream0
+#define VBAT_ADC_PIN PC0
+#define CURRENT_METER_ADC_PIN PC1
+//#define RSSI_ADC_PIN PC1
+
+// *************** Others ***************************
+
+
+#define DEFAULT_FEATURES ( FEATURE_TELEMETRY )
+#define DEFAULT_VOLTAGE_METER_SOURCE VOLTAGE_METER_ADC
+#define DEFAULT_CURRENT_METER_SOURCE CURRENT_METER_ADC
+#define CURRENT_METER_SCALE_DEFAULT 179
+
+#define USE_ESCSERIAL
+
+#define TARGET_IO_PORTA 0xffff
+#define TARGET_IO_PORTB 0xffff
+#define TARGET_IO_PORTC 0xffff
+#define TARGET_IO_PORTD 0xffff
+
+#define USABLE_TIMER_CHANNEL_COUNT 10
+#define USED_TIMERS (TIM_N(1)|TIM_N(2)|TIM_N(3)|TIM_N(4)|TIM_N(8))
diff --git a/src/main/target/RUSHBLADEF7HD/target.mk b/src/main/target/RUSHBLADEF7HD/target.mk
new file mode 100644
index 0000000000..4a0083c78c
--- /dev/null
+++ b/src/main/target/RUSHBLADEF7HD/target.mk
@@ -0,0 +1,12 @@
+F7X2RE_TARGETS += $(TARGET)
+FEATURES += VCP ONBOARDFLASH
+
+TARGET_SRC = \
+drivers/accgyro/accgyro_mpu.c \
+drivers/accgyro/accgyro_spi_mpu6000.c \
+drivers/accgyro/accgyro_spi_icm426xx.c \
+drivers/barometer/barometer_ms5611.c \
+drivers/barometer/barometer_bmp280.c \
+drivers/barometer/barometer_bmp085.c \
+drivers/light_ws2811strip.c \
+drivers/max7456.c
diff --git a/src/main/target/RUSH_BLADE_F7_HD/target.h b/src/main/target/RUSH_BLADE_F7_HD/target.h
deleted file mode 100644
index 1ad1a5f0c1..0000000000
--- a/src/main/target/RUSH_BLADE_F7_HD/target.h
+++ /dev/null
@@ -1,151 +0,0 @@
-/*
- * This file is part of Cleanflight and Betaflight.
- *
- * Cleanflight and Betaflight are free software. You can redistribute
- * this software and/or modify this software 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 and Betaflight are distributed in the hope that they
- * 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 this software.
- *
- * If not, see .
- */
-
- #pragma once
- //#define USE_TARGET_CONFIG
-
- #define TARGET_BOARD_IDENTIFIER "RUSH"
- #define USBD_PRODUCT_STRING "BLADE_F7_HD"
-
- #define ENABLE_DSHOT_DMAR true
-
- #define USE_LED_STRIP
-
- #define LED0_PIN PB10
-
- #define USE_BEEPER
- #define BEEPER_PIN PB2
- #define BEEPER_INVERTED
-
-
- // *************** SPI1 Gyro & ACC *******************
-
- #define USE_SPI
- #define USE_SPI_DEVICE_1
- #define SPI1_SCK_PIN PA5
- #define SPI1_MISO_PIN PA6
- #define SPI1_MOSI_PIN PA7
-
- #define USE_EXTI
- #define MPU_INT_EXTI PA4
-
- #define MPU6000_CS_PIN PC4
- #define MPU6000_SPI_INSTANCE SPI1
-
- #define USE_GYRO
- #define USE_GYRO_SPI_MPU6000
-
- #define USE_ACC
- #define USE_ACC_SPI_MPU6000
-
- #define GYRO_MPU6000_ALIGN CW270_DEG
- #define ACC_MPU6000_ALIGN CW270_DEG
-
- #define USE_MPU_DATA_READY_SIGNAL
- #define ENSURE_MPU_DATA_READY_IS_LOW
-
- // *************** I2C /Baro/Mag *********************
-
- #define USE_I2C
-
- #define USE_I2C_DEVICE_1
- #define I2C_DEVICE_1 (I2CDEV_1)
- #define I2C1_SCL PB8
- #define I2C1_SDA PB9
-
- #define BARO_I2C_INSTANCE (I2CDEV_1)
- #define USE_BARO
- #define USE_BARO_BMP280
- #define USE_BARO_MS5611
- #define USE_BARO_BMP085
-
- //#define MAG_I2C_INSTANCE (I2CDEV_1)
- //#define USE_MAG
- //#define USE_MAG_HMC5883
- //#define USE_MAG_QMC5883
-
- // *************** SPI3 BLACKBOX****************
-
- #define USE_SPI_DEVICE_2
- #define SPI2_SCK_PIN PB13
- #define SPI2_MISO_PIN PB14
- #define SPI2_MOSI_PIN PB15
-
- #define ENABLE_BLACKBOX_LOGGING_ON_SPIFLASH_BY_DEFAULT
- #define USE_FLASHFS
- #define USE_FLASH_M25P16
- #define FLASH_CS_PIN PB12
- #define FLASH_SPI_INSTANCE SPI2
-
- // *************** UART *****************************
-
- #define USE_VCP
- #define USE_USB_DETECT
-
- #define USE_UART1
- #define UART1_TX_PIN PA9
- #define UART1_RX_PIN PA10
-
- #define USE_UART2
- #define UART2_TX_PIN PA2
- #define UART2_RX_PIN PA3
-
- #define USE_UART3
- #define UART3_TX_PIN PC10
- #define UART3_RX_PIN PC11
-
- #define USE_UART4
- #define UART4_TX_PIN PA0
- #define UART4_RX_PIN PA1
-
- #define USE_UART5
- #define UART5_TX_PIN PC12
- #define UART5_RX_PIN PD2
-
- #define SERIAL_PORT_COUNT 6
-
- #define DEFAULT_RX_FEATURE FEATURE_RX_SERIAL
- #define SERIALRX_PROVIDER SERIALRX_SBUS
- #define SERIALRX_UART SERIAL_PORT_USART2
-
- // *************** ADC *****************************
- #define USE_ADC
- //#define ADC1_DMA_STREAM DMA2_Stream0
- #define VBAT_ADC_PIN PC0
- #define CURRENT_METER_ADC_PIN PC1
- //#define RSSI_ADC_PIN PC1
-
- // *************** Others ***************************
-
-
- #define DEFAULT_FEATURES ( FEATURE_TELEMETRY )
- #define DEFAULT_VOLTAGE_METER_SOURCE VOLTAGE_METER_ADC
- #define DEFAULT_CURRENT_METER_SOURCE CURRENT_METER_ADC
- #define CURRENT_METER_SCALE_DEFAULT 179
-
- #define USE_ESCSERIAL
-
- #define TARGET_IO_PORTA 0xffff
- #define TARGET_IO_PORTB 0xffff
- #define TARGET_IO_PORTC 0xffff
- #define TARGET_IO_PORTD 0xffff
-
- #define USABLE_TIMER_CHANNEL_COUNT 10
- #define USED_TIMERS (TIM_N(1)|TIM_N(2)|TIM_N(3)|TIM_N(4)|TIM_N(8))
diff --git a/src/main/target/RUSH_BLADE_F7_HD/target.mk b/src/main/target/RUSH_BLADE_F7_HD/target.mk
deleted file mode 100644
index 3b2730cf37..0000000000
--- a/src/main/target/RUSH_BLADE_F7_HD/target.mk
+++ /dev/null
@@ -1,11 +0,0 @@
-F7X2RE_TARGETS += $(TARGET)
-FEATURES += VCP ONBOARDFLASH
-
-TARGET_SRC = \
- drivers/accgyro/accgyro_mpu.c \
- drivers/accgyro/accgyro_spi_mpu6000.c \
- drivers/barometer/barometer_ms5611.c \
- drivers/barometer/barometer_bmp280.c \
- drivers/barometer/barometer_bmp085.c \
- drivers/light_ws2811strip.c \
- drivers/max7456.c