From 41ad9160b3eeeefc4a78e07210b8e4fc7c969a41 Mon Sep 17 00:00:00 2001 From: nerdCopter <56646290+nerdCopter@users.noreply.github.com> Date: Thu, 28 Mar 2024 15:34:55 -0500 Subject: [PATCH 1/2] [target] add NBD_INFINITYAIOV2 (not pro) --- src/main/target/NBD_INFINITYAIOV2/target.c | 41 ++++++ src/main/target/NBD_INFINITYAIOV2/target.h | 142 ++++++++++++++++++++ src/main/target/NBD_INFINITYAIOV2/target.mk | 21 +++ 3 files changed, 204 insertions(+) create mode 100644 src/main/target/NBD_INFINITYAIOV2/target.c create mode 100644 src/main/target/NBD_INFINITYAIOV2/target.h create mode 100644 src/main/target/NBD_INFINITYAIOV2/target.mk diff --git a/src/main/target/NBD_INFINITYAIOV2/target.c b/src/main/target/NBD_INFINITYAIOV2/target.c new file mode 100644 index 0000000000..eee0de7bb5 --- /dev/null +++ b/src/main/target/NBD_INFINITYAIOV2/target.c @@ -0,0 +1,41 @@ +/* + * This file is part of EmuFlight. It is derived from Betaflight. + * + * This is 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. + * + * This software 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 this software. + * + * If not, see . + */ + +// This resource file generated using https://github.com/nerdCopter/target-convert +// Commit: 4cb7ad1 + +#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(TIM3, CH1, PC6, TIM_USE_MOTOR, 0, 0), // motor 1 + DEF_TIM(TIM3, CH2, PC7, TIM_USE_MOTOR, 0, 0), // motor 2 + DEF_TIM(TIM3, CH3, PC8, TIM_USE_MOTOR, 0, 0), // motor 3 + DEF_TIM(TIM3, CH4, PC9, TIM_USE_MOTOR, 0, 0), // motor 4 + DEF_TIM(TIM1, CH2, PA9, TIM_USE_LED, 0, 0), // led + DEF_TIM(TIM4, CH2, PD13, TIM_USE_ANY, 0, 0), +}; + +// notice - this file was programmatically generated and may be incomplete. diff --git a/src/main/target/NBD_INFINITYAIOV2/target.h b/src/main/target/NBD_INFINITYAIOV2/target.h new file mode 100644 index 0000000000..aeb5612074 --- /dev/null +++ b/src/main/target/NBD_INFINITYAIOV2/target.h @@ -0,0 +1,142 @@ +/* + * This file is part of EmuFlight. It is derived from Betaflight. + * + * This is 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. + * + * This software 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 this software. + * + * If not, see . + */ + +// This resource file generated using https://github.com/nerdCopter/target-convert +// Commit: 4cb7ad1 + +#pragma once + +#define TARGET_MANUFACTURER_IDENTIFIER "NEBD" +#define USBD_PRODUCT_STRING "NBD_INFINITYAIOV2" + +#define FC_TARGET_MCU STM32F745 // not used in EmuF +#define TARGET_BOARD_IDENTIFIER "S745" // generic ID + +#define USE_ACC +#define USE_GYRO +#define USE_ACCGYRO_BMI270 +#define USE_FLASH +#define USE_FLASH_W25Q128FV +#define USE_MAX7456 +#define USE_SPI_GYRO + +#define USE_VCP +#define USE_FLASHFS +#define USE_FLASH_M25P16 // 16MB Micron M25P16 and others (ref: https://github.com/betaflight/betaflight/blob/master/src/main/drivers/flash_m25p16.c) +//#define USE_FLASH_W25M // 1Gb NAND flash support +//#define USE_FLASH_W25M512 // 16, 32, 64 or 128MB Winbond stacked die support +//#define USE_FLASH_W25Q // 512Kb (256Kb x 2 stacked) NOR flash support +#define USE_OSD + +#define USE_LED +#define LED0_PIN PC0 +#define LED_STRIP_PIN PA9 +#define USE_BEEPER +#define BEEPER_PIN PD13 +#define BEEPER_INVERTED + +#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_3 +#define SPI3_SCK_PIN PB3 +#define SPI3_MISO_PIN PB4 +#define SPI3_MOSI_PIN PD6 +#define USE_SPI_DEVICE_4 +#define SPI4_SCK_PIN PE12 +#define SPI4_MISO_PIN PE13 +#define SPI4_MOSI_PIN PE14 + +#define GYRO_1_ALIGN CW180_DEG +#define ACC_1_ALIGN CW180_DEG +#define GYRO_1_CS_PIN PE11 +#define GYRO_1_EXTI_PIN PB1 +#define GYRO_1_SPI_INSTANCE SPI4 +#define MPU_INT_EXTI PB1 + + +#define USE_EXTI // notice - REQUIRED when USE_GYRO_EXTI +#define USE_GYRO_EXTI + +#define USE_SPI_GYRO +#define ACC_BMI270_ALIGN CW180_DEG +#define GYRO_BMI270_ALIGN CW180_DEG +#define BMI270_CS_PIN PE11 +#define BMI270_SPI_INSTANCE SPI4 + +#define USE_UART1 +#define UART1_RX_PIN PB7 +#define USE_UART2 +#define UART2_TX_PIN PA2 +#define UART2_RX_PIN PA3 +#define USE_UART3 +#define UART3_TX_PIN PB10 +#define UART3_RX_PIN PB11 +#define USE_UART5 +#define UART5_RX_PIN PD2 +#define USE_UART7 +#define UART7_TX_PIN PE8 +#define USE_UART8 +#define UART8_TX_PIN PE1 +#define UART8_RX_PIN PE0 +#define SERIAL_PORT_COUNT 7 +// notice - please verify serial count. UARTs defined as NONE may need to be included. + +#define USE_I2C +#define USE_I2C_DEVICE_1 +#define I2C_DEVICE (I2CDEV_1) +#define MAG_I2C_INSTANCE (I2CDEV_1) +#define I2C1_SCL PB8 +#define I2C1_SDA PB9 + +#define FLASH_CS_PIN PB0 +#define FLASH_SPI_INSTANCE SPI1 +#define ENABLE_BLACKBOX_LOGGING_ON_SPIFLASH_BY_DEFAULT + +#define MAX7456_SPI_CS_PIN PA15 +#define MAX7456_SPI_INSTANCE SPI3 + +#define VBAT_ADC_PIN PC1 +#define CURRENT_METER_ADC_PIN PC2 +#define ADC1_DMA_STREAM DMA2_Stream4 //# ADC 1: DMA2 Stream 4 Channel 0 +#define DEFAULT_VOLTAGE_METER_SOURCE VOLTAGE_METER_ADC +#define DEFAULT_CURRENT_METER_SOURCE CURRENT_METER_ADC +#define DEFAULT_CURRENT_METER_SCALE 230 + +#define ENABLE_DSHOT_DMAR true + +#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 +// notice - masks were programmatically generated - please verify last port group for 0xffff or (BIT(2)) + +#define DEFAULT_FEATURES (FEATURE_OSD | FEATURE_TELEMETRY | FEATURE_AIRMODE | FEATURE_RX_SERIAL) +#define DEFAULT_RX_FEATURE FEATURE_RX_SERIAL + +#define USABLE_TIMER_CHANNEL_COUNT 6 +#define USED_TIMERS ( TIM_N(1) | TIM_N(3) | TIM_N(4) ) + +// notice - this file was programmatically generated and may be incomplete. + diff --git a/src/main/target/NBD_INFINITYAIOV2/target.mk b/src/main/target/NBD_INFINITYAIOV2/target.mk new file mode 100644 index 0000000000..ddc166a745 --- /dev/null +++ b/src/main/target/NBD_INFINITYAIOV2/target.mk @@ -0,0 +1,21 @@ +F7X5XG_TARGETS += $(TARGET) +FEATURES += VCP ONBOARDFLASH + +TARGET_SRC = \ +drivers/accgyro/accgyro_mpu.c \ +drivers/accgyro/accgyro_spi_bmi270.c \ +drivers/light_led.h \ +drivers/light_ws2811strip.c \ +drivers/max7456.c \ +drivers/barometer/barometer_bmp085.c \ +drivers/barometer/barometer_bmp280.c \ +drivers/barometer/barometer_fake.c \ +drivers/barometer/barometer_lps.c \ +drivers/barometer/barometer_ms5611.c \ +drivers/barometer/barometer_qmp6988.c \ + +# notice - this file was programmatically generated and may be incomplete. +# eg: flash, compass, barometer, vtx6705, ledstrip, pinio, etc. especially mag/baro + +# This resource file generated using https://github.com/nerdCopter/target-convert +# Commit: 4cb7ad1 From c6d24cd27a6fb0980703d324f7e186e15e8f7c2d Mon Sep 17 00:00:00 2001 From: nerdCopter <56646290+nerdCopter@users.noreply.github.com> Date: Tue, 2 Apr 2024 11:09:00 -0500 Subject: [PATCH 2/2] [target] add NBD_INFINITYAIOV2 (not pro) ; cleanup --- src/main/target/NBD_INFINITYAIOV2/target.h | 8 +------- src/main/target/NBD_INFINITYAIOV2/target.mk | 1 - 2 files changed, 1 insertion(+), 8 deletions(-) diff --git a/src/main/target/NBD_INFINITYAIOV2/target.h b/src/main/target/NBD_INFINITYAIOV2/target.h index aeb5612074..7d12bc723b 100644 --- a/src/main/target/NBD_INFINITYAIOV2/target.h +++ b/src/main/target/NBD_INFINITYAIOV2/target.h @@ -41,9 +41,6 @@ #define USE_VCP #define USE_FLASHFS #define USE_FLASH_M25P16 // 16MB Micron M25P16 and others (ref: https://github.com/betaflight/betaflight/blob/master/src/main/drivers/flash_m25p16.c) -//#define USE_FLASH_W25M // 1Gb NAND flash support -//#define USE_FLASH_W25M512 // 16, 32, 64 or 128MB Winbond stacked die support -//#define USE_FLASH_W25Q // 512Kb (256Kb x 2 stacked) NOR flash support #define USE_OSD #define USE_LED @@ -74,7 +71,6 @@ #define GYRO_1_SPI_INSTANCE SPI4 #define MPU_INT_EXTI PB1 - #define USE_EXTI // notice - REQUIRED when USE_GYRO_EXTI #define USE_GYRO_EXTI @@ -99,8 +95,7 @@ #define USE_UART8 #define UART8_TX_PIN PE1 #define UART8_RX_PIN PE0 -#define SERIAL_PORT_COUNT 7 -// notice - please verify serial count. UARTs defined as NONE may need to be included. +#define SERIAL_PORT_COUNT 9 #define USE_I2C #define USE_I2C_DEVICE_1 @@ -139,4 +134,3 @@ #define USED_TIMERS ( TIM_N(1) | TIM_N(3) | TIM_N(4) ) // notice - this file was programmatically generated and may be incomplete. - diff --git a/src/main/target/NBD_INFINITYAIOV2/target.mk b/src/main/target/NBD_INFINITYAIOV2/target.mk index ddc166a745..6d826148cc 100644 --- a/src/main/target/NBD_INFINITYAIOV2/target.mk +++ b/src/main/target/NBD_INFINITYAIOV2/target.mk @@ -15,7 +15,6 @@ drivers/barometer/barometer_ms5611.c \ drivers/barometer/barometer_qmp6988.c \ # notice - this file was programmatically generated and may be incomplete. -# eg: flash, compass, barometer, vtx6705, ledstrip, pinio, etc. especially mag/baro # This resource file generated using https://github.com/nerdCopter/target-convert # Commit: 4cb7ad1