diff --git a/src/main/target/ALIENFLIGHTF1/AlienFlight.md b/src/main/target/ALIENFLIGHTF1/AlienFlight.md
index 4c33df568..d4b20af42 100644
--- a/src/main/target/ALIENFLIGHTF1/AlienFlight.md
+++ b/src/main/target/ALIENFLIGHTF1/AlienFlight.md
@@ -1,15 +1,18 @@
-# AlienFlight (ALIENFLIGHTF1, ALIENFLIGHTF3 and ALIENFLIGHTF4 target)
+# AlienFlight (ALIENFLIGHTF1, ALIENFLIGHTF3, ALIENFLIGHTF4 and ALIENFLIGHTNGF7 target)
-AlienWii is now AlienFlight. This targets supports various variants of brushed and brushless flight controllers. The designs for them are released partially for public use at:
+AlienWii is now AlienFlight. This designs are released for public and some for noncommercial use at:
http://www.alienflight.com
-http://www.alienflightng.com
-AlienFlight Classic and F3 Eagle files are available at:
+AlienFlight F3 Eagle files are available at:
https://github.com/MJ666/Flight-Controllers
-All published designs are flight tested by various people. The intention here is to make these flight controllers available and enable skilled users and in some cases RC vendors to build this designs.
+AlienFlightNG (Next Generation) designs are released for noncommercial use can be found here:
+
+http://www.alienflightng.com
+
+This targets supports various variants of brushed and brushless flight controllers. All published designs are flight tested by various people. The intention here is to make these flight controllers available and enable skilled users and in some cases RC vendors to build them.
Some variants of the AlienFlight controllers will be available for purchase from:
@@ -21,8 +24,9 @@ Here are the general hardware specifications for this boards:
- STM32F103CBT6 MCU (ALIENFLIGHTF1)
- STM32F303CCT6 MCU (ALIENFLIGHTF3)
- STM32F405RGT6 MCU (ALIENFLIGHTF4)
+- STM32F711RET6 MCU (ALIENFLIGHTNGF7)
- MPU6050/6500/9250/ICM-20602 accelerometer/gyro(/mag) sensor unit
-- The MPU sensor interrupt is connected to the MCU for all new F3 and F4 designs and enabled in the firmware
+- The MPU sensor interrupt is connected to the MCU for all published designs and enabled in the firmware
- 4-8 x 4.2A to 9.5A brushed ESCs, integrated, to run the strongest micro motors (brushed variants)
- extra-wide traces on the PCB, for maximum power throughput (brushed variants)
- some new F4 boards using a 4-layer PCB for better power distribution
@@ -33,28 +37,38 @@ Here are the general hardware specifications for this boards:
- hardware bind plug for easy binding
- motor connections are at the corners for a clean look with reduced wiring
- small footprint
-- direct operation from a single cell Lipoly battery for brushed versions
+- direct operation from a single cell LIPO battery for brushed versions
- 3.3V LDO power regulator (older prototypes)
- 3.3V buck-boost power converter (all new versions)
- 5V buck-boost power converter for FPV (some versions)
-- brushless versions are designed for 3S operation and also have an 5V power output
-- battery monitoring with an LED or buzzer output (for some ALIENFLIGHTF3 and F4 variants only, F4 V2 has also current monitoring)
-- SDCard Reader for black box monitoring (F4 V2 versions)
-- Integrated OpenSky (FRSky compatible) receiver with FRSky hub telemetry (F4 V2 versions)
+- brushless versions are designed for 4S operation and also have an 5V power output
+- battery monitoring with an LED or buzzer output (for some variants only)
+- current monitoring (F4/F7 V1.1 versions)
+- SDCard Reader for black box monitoring (F4/F7 V1.1 versions)
+- (**) integrated OpenSky (FrSky compatible) receiver with FrSky hub telemetry (F4/F7 V2 versions)
+- hardware detection of brushed and brushless versions with individual defaults
(*) Spektrum Compatible DSM2 satellites are supported out of the box. DSMX sat will work with DSM2 protocol with default settings (DSM2, 11bit, 11ms is preset). This is chosen for maximum compatibility. For optimal connection it is recommended to adjust settings to match the capabilities of your transmitter and satellite receiver. If possible it is recommended to use the DSMX protocol since it is known as more reliable. Also to make use of additional channels you should adjust the following two parameters with the Cleanflight Configurator.
+(**) This receiver is based on the uSky and OpenSky projects. http://www.fishpepper.de
+
set serialrx_provider = 1 (0 for 1024bit, 1 for 2048bit)
set spektrum_sat_bind = 5
For more detail of the different bind modes please refer the CleanFlight Spektrum Bind document.
-Deltang receivers in serial mode will work like any other Spektrum satellite receiver (10bit, 22ms) only the bind process will be different.
+Deltang receivers in serial mode will work like any other Spektrum satellite compatible receiver (10bit, 22ms) only the bind process will be different.
-The pin layout for the ALIENFLIGHTF1 is very similar to NAZE32 or the related clones (MW32, Flip32, etc.). The hardware bind pin is connected to pin 41 (PB5). The pin layout for the ALIENFLIGHTF3 is similar to Sparky. The hardware bind pin is connected to pin 25 (PB12). The new AlienFlightF3 V2 design have the sensor connected via SPI and some slightly different pin layout. All AlienFlight/AlienWii F3 layouts running the same firmware which takes care on the differences with a hardware detection.
+The pin layout for the AlienFlight F1 is very similar to NAZE32 or the related clones (MW32, Flip32, etc.). The pin layout for the AlienFlight F3 is similar to Sparky. The new AlienFlightF3 V2 design have the sensor connected via SPI and some slightly different pin layout. All AlienFlight F3 flight controllers running the same firmware which takes care on the differences with a hardware detection. The AlienFlight F4 and F7 have their individual pin layouts and are independent designs.
-The AlienFlight firmware will be built as target ALIENFLIGHTF1, ALIENFLIGHTF3 or ALIENFLIGHTF4. The firmware image will come with alternative default settings which will give the user a plug and play experience. There is no computer needed to get this into the air with a small Quadcopter. A preconfigured custom mixer for an Octocopter is part of the default settings to allow clean straight wiring with the AlienFlight. The mixer can be activated with "mixer custom" in the CLI. To use the AlienFlight controller in a Hexa- or Octocopter or to do some more tuning additional configuration changes can be done as usual in the CLI or the BetaFlight configurator.
+(**) OpenSky receiver with telemetry is enabled by default if present on the board.
+
+The AlienFlight firmware will be built as target ALIENFLIGHTF1, ALIENFLIGHTF3, ALIENFLIGHTF4 or ALIENFLIGHTNGF7. The firmware image will come with alternative default settings which will give the user a plug and play experience. There is no computer needed to get this into the air with a small Quadcopter. A preconfigured custom mixer for an Octocopter is part of the default settings to allow clean straight wiring with the AlienFlight. The mixer can be activated with "mixer custom" in the CLI. To use the AlienFlight controller in a Hexa- or Octocopter or to do some more tuning additional configuration changes can be done as usual in the CLI or the BetaFlight configurator.
## Flashing the firmware
The firmware can be updated with the BetaFlight configurator as for any other target. All AlienFlight boards have a boot jumper which need to be closed for initial flashing or for recovery from a broken firmware.
+
+The firmware for the OpenSky receiver can be updated via serial pass-through and the embedded boot loader. The initial flashing need to be done with the ISP programming pins. The target for the embedded AlienFlight OpenSky receiver is "AFF4RX". Please refer to the OpenSky project for more details.
+
+https://github.com/fishpepper/OpenSky/blob/master/README.md
diff --git a/src/main/target/ALIENFLIGHTF3/AlienFlight.md b/src/main/target/ALIENFLIGHTF3/AlienFlight.md
index 4c33df568..d4b20af42 100644
--- a/src/main/target/ALIENFLIGHTF3/AlienFlight.md
+++ b/src/main/target/ALIENFLIGHTF3/AlienFlight.md
@@ -1,15 +1,18 @@
-# AlienFlight (ALIENFLIGHTF1, ALIENFLIGHTF3 and ALIENFLIGHTF4 target)
+# AlienFlight (ALIENFLIGHTF1, ALIENFLIGHTF3, ALIENFLIGHTF4 and ALIENFLIGHTNGF7 target)
-AlienWii is now AlienFlight. This targets supports various variants of brushed and brushless flight controllers. The designs for them are released partially for public use at:
+AlienWii is now AlienFlight. This designs are released for public and some for noncommercial use at:
http://www.alienflight.com
-http://www.alienflightng.com
-AlienFlight Classic and F3 Eagle files are available at:
+AlienFlight F3 Eagle files are available at:
https://github.com/MJ666/Flight-Controllers
-All published designs are flight tested by various people. The intention here is to make these flight controllers available and enable skilled users and in some cases RC vendors to build this designs.
+AlienFlightNG (Next Generation) designs are released for noncommercial use can be found here:
+
+http://www.alienflightng.com
+
+This targets supports various variants of brushed and brushless flight controllers. All published designs are flight tested by various people. The intention here is to make these flight controllers available and enable skilled users and in some cases RC vendors to build them.
Some variants of the AlienFlight controllers will be available for purchase from:
@@ -21,8 +24,9 @@ Here are the general hardware specifications for this boards:
- STM32F103CBT6 MCU (ALIENFLIGHTF1)
- STM32F303CCT6 MCU (ALIENFLIGHTF3)
- STM32F405RGT6 MCU (ALIENFLIGHTF4)
+- STM32F711RET6 MCU (ALIENFLIGHTNGF7)
- MPU6050/6500/9250/ICM-20602 accelerometer/gyro(/mag) sensor unit
-- The MPU sensor interrupt is connected to the MCU for all new F3 and F4 designs and enabled in the firmware
+- The MPU sensor interrupt is connected to the MCU for all published designs and enabled in the firmware
- 4-8 x 4.2A to 9.5A brushed ESCs, integrated, to run the strongest micro motors (brushed variants)
- extra-wide traces on the PCB, for maximum power throughput (brushed variants)
- some new F4 boards using a 4-layer PCB for better power distribution
@@ -33,28 +37,38 @@ Here are the general hardware specifications for this boards:
- hardware bind plug for easy binding
- motor connections are at the corners for a clean look with reduced wiring
- small footprint
-- direct operation from a single cell Lipoly battery for brushed versions
+- direct operation from a single cell LIPO battery for brushed versions
- 3.3V LDO power regulator (older prototypes)
- 3.3V buck-boost power converter (all new versions)
- 5V buck-boost power converter for FPV (some versions)
-- brushless versions are designed for 3S operation and also have an 5V power output
-- battery monitoring with an LED or buzzer output (for some ALIENFLIGHTF3 and F4 variants only, F4 V2 has also current monitoring)
-- SDCard Reader for black box monitoring (F4 V2 versions)
-- Integrated OpenSky (FRSky compatible) receiver with FRSky hub telemetry (F4 V2 versions)
+- brushless versions are designed for 4S operation and also have an 5V power output
+- battery monitoring with an LED or buzzer output (for some variants only)
+- current monitoring (F4/F7 V1.1 versions)
+- SDCard Reader for black box monitoring (F4/F7 V1.1 versions)
+- (**) integrated OpenSky (FrSky compatible) receiver with FrSky hub telemetry (F4/F7 V2 versions)
+- hardware detection of brushed and brushless versions with individual defaults
(*) Spektrum Compatible DSM2 satellites are supported out of the box. DSMX sat will work with DSM2 protocol with default settings (DSM2, 11bit, 11ms is preset). This is chosen for maximum compatibility. For optimal connection it is recommended to adjust settings to match the capabilities of your transmitter and satellite receiver. If possible it is recommended to use the DSMX protocol since it is known as more reliable. Also to make use of additional channels you should adjust the following two parameters with the Cleanflight Configurator.
+(**) This receiver is based on the uSky and OpenSky projects. http://www.fishpepper.de
+
set serialrx_provider = 1 (0 for 1024bit, 1 for 2048bit)
set spektrum_sat_bind = 5
For more detail of the different bind modes please refer the CleanFlight Spektrum Bind document.
-Deltang receivers in serial mode will work like any other Spektrum satellite receiver (10bit, 22ms) only the bind process will be different.
+Deltang receivers in serial mode will work like any other Spektrum satellite compatible receiver (10bit, 22ms) only the bind process will be different.
-The pin layout for the ALIENFLIGHTF1 is very similar to NAZE32 or the related clones (MW32, Flip32, etc.). The hardware bind pin is connected to pin 41 (PB5). The pin layout for the ALIENFLIGHTF3 is similar to Sparky. The hardware bind pin is connected to pin 25 (PB12). The new AlienFlightF3 V2 design have the sensor connected via SPI and some slightly different pin layout. All AlienFlight/AlienWii F3 layouts running the same firmware which takes care on the differences with a hardware detection.
+The pin layout for the AlienFlight F1 is very similar to NAZE32 or the related clones (MW32, Flip32, etc.). The pin layout for the AlienFlight F3 is similar to Sparky. The new AlienFlightF3 V2 design have the sensor connected via SPI and some slightly different pin layout. All AlienFlight F3 flight controllers running the same firmware which takes care on the differences with a hardware detection. The AlienFlight F4 and F7 have their individual pin layouts and are independent designs.
-The AlienFlight firmware will be built as target ALIENFLIGHTF1, ALIENFLIGHTF3 or ALIENFLIGHTF4. The firmware image will come with alternative default settings which will give the user a plug and play experience. There is no computer needed to get this into the air with a small Quadcopter. A preconfigured custom mixer for an Octocopter is part of the default settings to allow clean straight wiring with the AlienFlight. The mixer can be activated with "mixer custom" in the CLI. To use the AlienFlight controller in a Hexa- or Octocopter or to do some more tuning additional configuration changes can be done as usual in the CLI or the BetaFlight configurator.
+(**) OpenSky receiver with telemetry is enabled by default if present on the board.
+
+The AlienFlight firmware will be built as target ALIENFLIGHTF1, ALIENFLIGHTF3, ALIENFLIGHTF4 or ALIENFLIGHTNGF7. The firmware image will come with alternative default settings which will give the user a plug and play experience. There is no computer needed to get this into the air with a small Quadcopter. A preconfigured custom mixer for an Octocopter is part of the default settings to allow clean straight wiring with the AlienFlight. The mixer can be activated with "mixer custom" in the CLI. To use the AlienFlight controller in a Hexa- or Octocopter or to do some more tuning additional configuration changes can be done as usual in the CLI or the BetaFlight configurator.
## Flashing the firmware
The firmware can be updated with the BetaFlight configurator as for any other target. All AlienFlight boards have a boot jumper which need to be closed for initial flashing or for recovery from a broken firmware.
+
+The firmware for the OpenSky receiver can be updated via serial pass-through and the embedded boot loader. The initial flashing need to be done with the ISP programming pins. The target for the embedded AlienFlight OpenSky receiver is "AFF4RX". Please refer to the OpenSky project for more details.
+
+https://github.com/fishpepper/OpenSky/blob/master/README.md
diff --git a/src/main/target/ALIENFLIGHTF4/AlienFlight.md b/src/main/target/ALIENFLIGHTF4/AlienFlight.md
index 4c33df568..d4b20af42 100644
--- a/src/main/target/ALIENFLIGHTF4/AlienFlight.md
+++ b/src/main/target/ALIENFLIGHTF4/AlienFlight.md
@@ -1,15 +1,18 @@
-# AlienFlight (ALIENFLIGHTF1, ALIENFLIGHTF3 and ALIENFLIGHTF4 target)
+# AlienFlight (ALIENFLIGHTF1, ALIENFLIGHTF3, ALIENFLIGHTF4 and ALIENFLIGHTNGF7 target)
-AlienWii is now AlienFlight. This targets supports various variants of brushed and brushless flight controllers. The designs for them are released partially for public use at:
+AlienWii is now AlienFlight. This designs are released for public and some for noncommercial use at:
http://www.alienflight.com
-http://www.alienflightng.com
-AlienFlight Classic and F3 Eagle files are available at:
+AlienFlight F3 Eagle files are available at:
https://github.com/MJ666/Flight-Controllers
-All published designs are flight tested by various people. The intention here is to make these flight controllers available and enable skilled users and in some cases RC vendors to build this designs.
+AlienFlightNG (Next Generation) designs are released for noncommercial use can be found here:
+
+http://www.alienflightng.com
+
+This targets supports various variants of brushed and brushless flight controllers. All published designs are flight tested by various people. The intention here is to make these flight controllers available and enable skilled users and in some cases RC vendors to build them.
Some variants of the AlienFlight controllers will be available for purchase from:
@@ -21,8 +24,9 @@ Here are the general hardware specifications for this boards:
- STM32F103CBT6 MCU (ALIENFLIGHTF1)
- STM32F303CCT6 MCU (ALIENFLIGHTF3)
- STM32F405RGT6 MCU (ALIENFLIGHTF4)
+- STM32F711RET6 MCU (ALIENFLIGHTNGF7)
- MPU6050/6500/9250/ICM-20602 accelerometer/gyro(/mag) sensor unit
-- The MPU sensor interrupt is connected to the MCU for all new F3 and F4 designs and enabled in the firmware
+- The MPU sensor interrupt is connected to the MCU for all published designs and enabled in the firmware
- 4-8 x 4.2A to 9.5A brushed ESCs, integrated, to run the strongest micro motors (brushed variants)
- extra-wide traces on the PCB, for maximum power throughput (brushed variants)
- some new F4 boards using a 4-layer PCB for better power distribution
@@ -33,28 +37,38 @@ Here are the general hardware specifications for this boards:
- hardware bind plug for easy binding
- motor connections are at the corners for a clean look with reduced wiring
- small footprint
-- direct operation from a single cell Lipoly battery for brushed versions
+- direct operation from a single cell LIPO battery for brushed versions
- 3.3V LDO power regulator (older prototypes)
- 3.3V buck-boost power converter (all new versions)
- 5V buck-boost power converter for FPV (some versions)
-- brushless versions are designed for 3S operation and also have an 5V power output
-- battery monitoring with an LED or buzzer output (for some ALIENFLIGHTF3 and F4 variants only, F4 V2 has also current monitoring)
-- SDCard Reader for black box monitoring (F4 V2 versions)
-- Integrated OpenSky (FRSky compatible) receiver with FRSky hub telemetry (F4 V2 versions)
+- brushless versions are designed for 4S operation and also have an 5V power output
+- battery monitoring with an LED or buzzer output (for some variants only)
+- current monitoring (F4/F7 V1.1 versions)
+- SDCard Reader for black box monitoring (F4/F7 V1.1 versions)
+- (**) integrated OpenSky (FrSky compatible) receiver with FrSky hub telemetry (F4/F7 V2 versions)
+- hardware detection of brushed and brushless versions with individual defaults
(*) Spektrum Compatible DSM2 satellites are supported out of the box. DSMX sat will work with DSM2 protocol with default settings (DSM2, 11bit, 11ms is preset). This is chosen for maximum compatibility. For optimal connection it is recommended to adjust settings to match the capabilities of your transmitter and satellite receiver. If possible it is recommended to use the DSMX protocol since it is known as more reliable. Also to make use of additional channels you should adjust the following two parameters with the Cleanflight Configurator.
+(**) This receiver is based on the uSky and OpenSky projects. http://www.fishpepper.de
+
set serialrx_provider = 1 (0 for 1024bit, 1 for 2048bit)
set spektrum_sat_bind = 5
For more detail of the different bind modes please refer the CleanFlight Spektrum Bind document.
-Deltang receivers in serial mode will work like any other Spektrum satellite receiver (10bit, 22ms) only the bind process will be different.
+Deltang receivers in serial mode will work like any other Spektrum satellite compatible receiver (10bit, 22ms) only the bind process will be different.
-The pin layout for the ALIENFLIGHTF1 is very similar to NAZE32 or the related clones (MW32, Flip32, etc.). The hardware bind pin is connected to pin 41 (PB5). The pin layout for the ALIENFLIGHTF3 is similar to Sparky. The hardware bind pin is connected to pin 25 (PB12). The new AlienFlightF3 V2 design have the sensor connected via SPI and some slightly different pin layout. All AlienFlight/AlienWii F3 layouts running the same firmware which takes care on the differences with a hardware detection.
+The pin layout for the AlienFlight F1 is very similar to NAZE32 or the related clones (MW32, Flip32, etc.). The pin layout for the AlienFlight F3 is similar to Sparky. The new AlienFlightF3 V2 design have the sensor connected via SPI and some slightly different pin layout. All AlienFlight F3 flight controllers running the same firmware which takes care on the differences with a hardware detection. The AlienFlight F4 and F7 have their individual pin layouts and are independent designs.
-The AlienFlight firmware will be built as target ALIENFLIGHTF1, ALIENFLIGHTF3 or ALIENFLIGHTF4. The firmware image will come with alternative default settings which will give the user a plug and play experience. There is no computer needed to get this into the air with a small Quadcopter. A preconfigured custom mixer for an Octocopter is part of the default settings to allow clean straight wiring with the AlienFlight. The mixer can be activated with "mixer custom" in the CLI. To use the AlienFlight controller in a Hexa- or Octocopter or to do some more tuning additional configuration changes can be done as usual in the CLI or the BetaFlight configurator.
+(**) OpenSky receiver with telemetry is enabled by default if present on the board.
+
+The AlienFlight firmware will be built as target ALIENFLIGHTF1, ALIENFLIGHTF3, ALIENFLIGHTF4 or ALIENFLIGHTNGF7. The firmware image will come with alternative default settings which will give the user a plug and play experience. There is no computer needed to get this into the air with a small Quadcopter. A preconfigured custom mixer for an Octocopter is part of the default settings to allow clean straight wiring with the AlienFlight. The mixer can be activated with "mixer custom" in the CLI. To use the AlienFlight controller in a Hexa- or Octocopter or to do some more tuning additional configuration changes can be done as usual in the CLI or the BetaFlight configurator.
## Flashing the firmware
The firmware can be updated with the BetaFlight configurator as for any other target. All AlienFlight boards have a boot jumper which need to be closed for initial flashing or for recovery from a broken firmware.
+
+The firmware for the OpenSky receiver can be updated via serial pass-through and the embedded boot loader. The initial flashing need to be done with the ISP programming pins. The target for the embedded AlienFlight OpenSky receiver is "AFF4RX". Please refer to the OpenSky project for more details.
+
+https://github.com/fishpepper/OpenSky/blob/master/README.md
diff --git a/src/main/target/ALIENFLIGHTNGF7/AlienFlight.md b/src/main/target/ALIENFLIGHTNGF7/AlienFlight.md
new file mode 100644
index 000000000..d4b20af42
--- /dev/null
+++ b/src/main/target/ALIENFLIGHTNGF7/AlienFlight.md
@@ -0,0 +1,74 @@
+# AlienFlight (ALIENFLIGHTF1, ALIENFLIGHTF3, ALIENFLIGHTF4 and ALIENFLIGHTNGF7 target)
+
+AlienWii is now AlienFlight. This designs are released for public and some for noncommercial use at:
+
+http://www.alienflight.com
+
+AlienFlight F3 Eagle files are available at:
+
+https://github.com/MJ666/Flight-Controllers
+
+AlienFlightNG (Next Generation) designs are released for noncommercial use can be found here:
+
+http://www.alienflightng.com
+
+This targets supports various variants of brushed and brushless flight controllers. All published designs are flight tested by various people. The intention here is to make these flight controllers available and enable skilled users and in some cases RC vendors to build them.
+
+Some variants of the AlienFlight controllers will be available for purchase from:
+
+http://www.microfpv.eu
+https://micro-motor-warehouse.com
+
+Here are the general hardware specifications for this boards:
+
+- STM32F103CBT6 MCU (ALIENFLIGHTF1)
+- STM32F303CCT6 MCU (ALIENFLIGHTF3)
+- STM32F405RGT6 MCU (ALIENFLIGHTF4)
+- STM32F711RET6 MCU (ALIENFLIGHTNGF7)
+- MPU6050/6500/9250/ICM-20602 accelerometer/gyro(/mag) sensor unit
+- The MPU sensor interrupt is connected to the MCU for all published designs and enabled in the firmware
+- 4-8 x 4.2A to 9.5A brushed ESCs, integrated, to run the strongest micro motors (brushed variants)
+- extra-wide traces on the PCB, for maximum power throughput (brushed variants)
+- some new F4 boards using a 4-layer PCB for better power distribution
+- USB port, integrated
+- (*) serial connection for external DSM2/DSMX sat receiver (e.g. Spektrum SAT, OrangeRx R100, Lemon RX or Deltang Rx31) and SBUS
+- CPPM input
+- ground and 3.3V for the receiver, some boards have also the option to power an 5V receiver
+- hardware bind plug for easy binding
+- motor connections are at the corners for a clean look with reduced wiring
+- small footprint
+- direct operation from a single cell LIPO battery for brushed versions
+- 3.3V LDO power regulator (older prototypes)
+- 3.3V buck-boost power converter (all new versions)
+- 5V buck-boost power converter for FPV (some versions)
+- brushless versions are designed for 4S operation and also have an 5V power output
+- battery monitoring with an LED or buzzer output (for some variants only)
+- current monitoring (F4/F7 V1.1 versions)
+- SDCard Reader for black box monitoring (F4/F7 V1.1 versions)
+- (**) integrated OpenSky (FrSky compatible) receiver with FrSky hub telemetry (F4/F7 V2 versions)
+- hardware detection of brushed and brushless versions with individual defaults
+
+(*) Spektrum Compatible DSM2 satellites are supported out of the box. DSMX sat will work with DSM2 protocol with default settings (DSM2, 11bit, 11ms is preset). This is chosen for maximum compatibility. For optimal connection it is recommended to adjust settings to match the capabilities of your transmitter and satellite receiver. If possible it is recommended to use the DSMX protocol since it is known as more reliable. Also to make use of additional channels you should adjust the following two parameters with the Cleanflight Configurator.
+
+(**) This receiver is based on the uSky and OpenSky projects. http://www.fishpepper.de
+
+ set serialrx_provider = 1 (0 for 1024bit, 1 for 2048bit)
+ set spektrum_sat_bind = 5
+
+For more detail of the different bind modes please refer the CleanFlight Spektrum Bind document.
+
+Deltang receivers in serial mode will work like any other Spektrum satellite compatible receiver (10bit, 22ms) only the bind process will be different.
+
+The pin layout for the AlienFlight F1 is very similar to NAZE32 or the related clones (MW32, Flip32, etc.). The pin layout for the AlienFlight F3 is similar to Sparky. The new AlienFlightF3 V2 design have the sensor connected via SPI and some slightly different pin layout. All AlienFlight F3 flight controllers running the same firmware which takes care on the differences with a hardware detection. The AlienFlight F4 and F7 have their individual pin layouts and are independent designs.
+
+(**) OpenSky receiver with telemetry is enabled by default if present on the board.
+
+The AlienFlight firmware will be built as target ALIENFLIGHTF1, ALIENFLIGHTF3, ALIENFLIGHTF4 or ALIENFLIGHTNGF7. The firmware image will come with alternative default settings which will give the user a plug and play experience. There is no computer needed to get this into the air with a small Quadcopter. A preconfigured custom mixer for an Octocopter is part of the default settings to allow clean straight wiring with the AlienFlight. The mixer can be activated with "mixer custom" in the CLI. To use the AlienFlight controller in a Hexa- or Octocopter or to do some more tuning additional configuration changes can be done as usual in the CLI or the BetaFlight configurator.
+
+## Flashing the firmware
+
+The firmware can be updated with the BetaFlight configurator as for any other target. All AlienFlight boards have a boot jumper which need to be closed for initial flashing or for recovery from a broken firmware.
+
+The firmware for the OpenSky receiver can be updated via serial pass-through and the embedded boot loader. The initial flashing need to be done with the ISP programming pins. The target for the embedded AlienFlight OpenSky receiver is "AFF4RX". Please refer to the OpenSky project for more details.
+
+https://github.com/fishpepper/OpenSky/blob/master/README.md
diff --git a/src/main/target/ALIENFLIGHTNGF7/config.c b/src/main/target/ALIENFLIGHTNGF7/config.c
new file mode 100644
index 000000000..dcbda3955
--- /dev/null
+++ b/src/main/target/ALIENFLIGHTNGF7/config.c
@@ -0,0 +1,100 @@
+/*
+ * 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 .
+ */
+
+#include
+#include
+
+#include
+
+#ifdef TARGET_CONFIG
+#include "common/axis.h"
+
+#include "drivers/sensor.h"
+#include "drivers/compass.h"
+#include "drivers/pwm_esc_detect.h"
+#include "drivers/pwm_output.h"
+#include "drivers/serial.h"
+
+#include "fc/rc_controls.h"
+
+#include "flight/failsafe.h"
+#include "flight/mixer.h"
+#include "flight/pid.h"
+
+#include "rx/rx.h"
+
+#include "io/serial.h"
+
+#include "telemetry/telemetry.h"
+
+#include "sensors/sensors.h"
+#include "sensors/compass.h"
+
+#include "config/config_profile.h"
+#include "config/config_master.h"
+#include "config/feature.h"
+
+#include "hardware_revision.h"
+
+#define CURRENTOFFSET 2500 // ACS712/714-30A - 0A = 2.5V
+#define CURRENTSCALE -667 // ACS712/714-30A - 66.666 mV/A inverted mode
+
+#define BRUSHED_MOTORS_PWM_RATE 32000 // 32kHz
+
+// alternative defaults settings for AlienFlight targets
+void targetConfiguration(master_t *config)
+{
+ config->batteryConfig.currentMeterOffset = CURRENTOFFSET;
+ config->batteryConfig.currentMeterScale = CURRENTSCALE;
+ config->compassConfig.mag_hardware = MAG_NONE; // disabled by default
+
+ if (hardwareMotorType == MOTOR_BRUSHED) {
+ config->motorConfig.dev.motorPwmRate = BRUSHED_MOTORS_PWM_RATE;
+ config->pidConfig.pid_process_denom = 1;
+ }
+
+ if (hardwareRevision == AFF7_REV_1) {
+ config->rxConfig.serialrx_provider = SERIALRX_SPEKTRUM2048;
+ config->rxConfig.spektrum_sat_bind = 5;
+ config->rxConfig.spektrum_sat_bind_autoreset = 1;
+ } else {
+ config->rxConfig.serialrx_provider = SERIALRX_SBUS;
+ config->rxConfig.sbus_inversion = 0;
+ config->serialConfig.portConfigs[findSerialPortIndexByIdentifier(TELEMETRY_UART)].functionMask = FUNCTION_TELEMETRY_FRSKY;
+ config->telemetryConfig.telemetry_inversion = 0;
+ intFeatureSet(FEATURE_CURRENT_METER | FEATURE_VBAT | FEATURE_TELEMETRY, &config->featureConfig.enabledFeatures);
+ }
+
+ config->profile[0].pidProfile.P8[ROLL] = 53;
+ config->profile[0].pidProfile.I8[ROLL] = 45;
+ config->profile[0].pidProfile.D8[ROLL] = 52;
+ config->profile[0].pidProfile.P8[PITCH] = 53;
+ config->profile[0].pidProfile.I8[PITCH] = 45;
+ config->profile[0].pidProfile.D8[PITCH] = 52;
+ config->profile[0].pidProfile.P8[YAW] = 64;
+ config->profile[0].pidProfile.D8[YAW] = 18;
+
+ config->customMotorMixer[0] = (motorMixer_t){ 1.0f, -0.414178f, 1.0f, -1.0f }; // REAR_R
+ config->customMotorMixer[1] = (motorMixer_t){ 1.0f, -0.414178f, -1.0f, 1.0f }; // FRONT_R
+ config->customMotorMixer[2] = (motorMixer_t){ 1.0f, 0.414178f, 1.0f, 1.0f }; // REAR_L
+ config->customMotorMixer[3] = (motorMixer_t){ 1.0f, 0.414178f, -1.0f, -1.0f }; // FRONT_L
+ config->customMotorMixer[4] = (motorMixer_t){ 1.0f, -1.0f, -0.414178f, -1.0f }; // MIDFRONT_R
+ config->customMotorMixer[5] = (motorMixer_t){ 1.0f, 1.0f, -0.414178f, 1.0f }; // MIDFRONT_L
+ config->customMotorMixer[6] = (motorMixer_t){ 1.0f, -1.0f, 0.414178f, 1.0f }; // MIDREAR_R
+ config->customMotorMixer[7] = (motorMixer_t){ 1.0f, 1.0f, 0.414178f, -1.0f }; // MIDREAR_L
+}
+#endif
diff --git a/src/main/target/ALIENFLIGHTNGF7/hardware_revision.c b/src/main/target/ALIENFLIGHTNGF7/hardware_revision.c
new file mode 100644
index 000000000..a682d67ae
--- /dev/null
+++ b/src/main/target/ALIENFLIGHTNGF7/hardware_revision.c
@@ -0,0 +1,52 @@
+/*
+ * 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 .
+ */
+
+#include
+#include
+#include
+
+#include "platform.h"
+
+#include "build/build_config.h"
+
+#include "drivers/system.h"
+#include "drivers/io.h"
+#include "hardware_revision.h"
+
+uint8_t hardwareRevision = AFF7_UNKNOWN;
+
+static IO_t HWDetectPin = IO_NONE;
+
+void detectHardwareRevision(void)
+{
+ HWDetectPin = IOGetByTag(IO_TAG(HW_PIN));
+ IOInit(HWDetectPin, OWNER_SYSTEM, 0);
+ IOConfigGPIO(HWDetectPin, IOCFG_IPU);
+
+ delayMicroseconds(10); // allow configuration to settle
+
+ // Check hardware revision
+ if (IORead(HWDetectPin)) {
+ hardwareRevision = AFF7_REV_1;
+ } else {
+ hardwareRevision = AFF7_REV_2;
+ }
+}
+
+void updateHardwareRevision(void)
+{
+}
diff --git a/src/main/target/ALIENFLIGHTNGF7/hardware_revision.h b/src/main/target/ALIENFLIGHTNGF7/hardware_revision.h
new file mode 100644
index 000000000..5a478a7ea
--- /dev/null
+++ b/src/main/target/ALIENFLIGHTNGF7/hardware_revision.h
@@ -0,0 +1,28 @@
+/*
+ * 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 .
+ */
+#pragma once
+
+typedef enum awf7HardwareRevision_t {
+ AFF7_UNKNOWN = 0,
+ AFF7_REV_1, // ICM-20602 (SPI), Current Sensor (ACS712), SDCard Reader
+ AFF7_REV_2 // ICM-20602 (SPI), OpenSky RX (CC2510), Current Sensor (ACS712), SDCard Reader
+} awf7HardwareRevision_e;
+
+extern uint8_t hardwareRevision;
+
+void updateHardwareRevision(void);
+void detectHardwareRevision(void);
diff --git a/src/main/target/ALIENFLIGHTNGF7/target.c b/src/main/target/ALIENFLIGHTNGF7/target.c
new file mode 100644
index 000000000..93a44e744
--- /dev/null
+++ b/src/main/target/ALIENFLIGHTNGF7/target.c
@@ -0,0 +1,46 @@
+/*
+ * 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 .
+ */
+
+#include
+
+#include
+#include "drivers/io.h"
+
+#include "drivers/dma.h"
+#include "drivers/timer.h"
+#include "drivers/timer_def.h"
+
+// DSHOT will work for motor 1-8.
+// If SDCard or USART4 DMA is used motor 6 will not work.
+// If the ADC is used motor 7 will not work.
+// If UART1 DMA is used motor 8 will not work.
+
+const timerHardware_t timerHardware[USABLE_TIMER_CHANNEL_COUNT] = {
+ DEF_TIM(TIM1, CH1, PA8, TIM_USE_PPM | TIM_USE_LED, TIMER_INPUT_ENABLED, 1), // PPM - DMA2_ST6, *DMA2_ST1, DMA2_ST3
+ DEF_TIM(TIM8, CH1, PC6, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM1 - DMA2_ST2, DMA2_ST2
+ DEF_TIM(TIM8, CH2, PC7, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM2 - DMA2_ST3, DMA2_ST2
+ DEF_TIM(TIM1, CH2N, PB14, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED | TIMER_OUTPUT_INVERTED , 0), // PWM3 - DMA2_ST6, DMA2_ST2
+ DEF_TIM(TIM3, CH3, PB0, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM4 - DMA1_ST7
+ DEF_TIM(TIM5, CH1, PA0, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM5 - DMA1_ST2
+ DEF_TIM(TIM5, CH2, PA1, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM6 - (DMA1_ST4) - DMA SDCard, DMA Serial_TX4
+ DEF_TIM(TIM8, CH3, PC8, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM7 - (DMA2_ST4) DMA2_ST2 - DMA ADC
+ DEF_TIM(TIM8, CH4, PC9, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM8 - (DMA2_ST7) - DMA Serial_TX1
+ DEF_TIM(TIM3, CH4, PB1, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM9 - (DMA1_ST2) - Collision
+ DEF_TIM(TIM1, CH3N, PB15, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED | TIMER_OUTPUT_INVERTED , 0), // PWM10 - (DMA2_ST6), (DMA2_ST6) - Collision
+ DEF_TIM(TIM4, CH3, PB8, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM11 - (DMA1_ST7) - Collision
+ DEF_TIM(TIM4, CH4, PB9, TIM_USE_MOTOR, TIMER_OUTPUT_ENABLED, 0), // PWM12 - DMA_NONE
+};
diff --git a/src/main/target/ALIENFLIGHTNGF7/target.h b/src/main/target/ALIENFLIGHTNGF7/target.h
new file mode 100644
index 000000000..2d7bce491
--- /dev/null
+++ b/src/main/target/ALIENFLIGHTNGF7/target.h
@@ -0,0 +1,192 @@
+/*
+ * 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 .
+ */
+
+#pragma once
+#define TARGET_BOARD_IDENTIFIER "AFF7"
+#define TARGET_CONFIG
+
+#define USE_HARDWARE_REVISION_DETECTION
+#define HW_PIN PC13
+#define BRUSHED_ESC_AUTODETECT
+#define USE_DSHOT
+
+#define USBD_PRODUCT_STRING "AlienFlightNG F7"
+
+#define LED0 PC12
+#define LED1 PD2
+
+#define BEEPER PC13
+#define BEEPER_INVERTED
+
+// MPU interrupt
+#define USE_EXTI
+#define MPU_INT_EXTI PC14
+//#define DEBUG_MPU_DATA_READY_INTERRUPT
+#define USE_MPU_DATA_READY_SIGNAL
+#define ENSURE_MPU_DATA_READY_IS_LOW
+
+#define MPU6500_CS_PIN SPI1_NSS_PIN
+#define MPU6500_SPI_INSTANCE SPI1
+
+#define ACC
+#define USE_ACC_SPI_MPU6500
+#define ACC_MPU6500_ALIGN CW270_DEG
+
+#define GYRO
+#define USE_GYRO_SPI_MPU6500
+#define GYRO_MPU6500_ALIGN CW270_DEG
+
+#define MAG
+#define USE_MAG_HMC5883
+#define USE_MAG_SPI_HMC5883
+#define USE_MAG_AK8963
+
+#define HMC5883_CS_PIN PC15
+#define HMC5883_SPI_INSTANCE SPI3
+
+#define MAG_HMC5883_ALIGN CW180_DEG
+#define MAG_AK8963_ALIGN CW270_DEG
+
+#define BARO
+#define USE_BARO_MS5611
+#define USE_BARO_BMP280
+#define USE_BARO_SPI_BMP280
+
+#define BMP280_CS_PIN SPI3_NSS_PIN
+#define BMP280_SPI_INSTANCE SPI3
+
+#define USE_SDCARD
+
+//#define SDCARD_DETECT_INVERTED
+
+#define SDCARD_DETECT_PIN PB11
+#define SDCARD_DETECT_EXTI_LINE EXTI_Line10
+#define SDCARD_DETECT_EXTI_PIN_SOURCE EXTI_PinSource10
+#define SDCARD_DETECT_EXTI_PORT_SOURCE EXTI_PortSourceGPIOB
+#define SDCARD_DETECT_EXTI_IRQn EXTI15_10_IRQn
+
+#define SDCARD_SPI_INSTANCE SPI2
+#define SDCARD_SPI_CS_PIN PB10
+
+// SPI2 is on the APB1 bus whose clock runs at 84MHz. Divide to under 400kHz for init:
+#define SDCARD_SPI_INITIALIZATION_CLOCK_DIVIDER 256 // 328kHz
+// Divide to under 25MHz for normal operation:
+#define SDCARD_SPI_FULL_SPEED_CLOCK_DIVIDER 4 // 21MHz
+
+#define SDCARD_DMA_CHANNEL_TX DMA1_Stream4
+#define SDCARD_DMA_CHANNEL_TX_COMPLETE_FLAG DMA_FLAG_TCIF4
+#define SDCARD_DMA_CLK RCC_AHB1Periph_DMA1
+#define SDCARD_DMA_CHANNEL DMA_CHANNEL_0
+
+// Performance logging for SD card operations:
+// #define AFATFS_USE_INTROSPECTIVE_LOGGING
+
+//#define M25P16_CS_PIN SPI2_NSS_PIN
+//#define M25P16_SPI_INSTANCE SPI2
+
+//#define USE_FLASHFS
+//#define USE_FLASH_M25P16
+
+#define USE_VCP
+
+#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 PC10
+#define UART4_TX_PIN PC11
+
+//#define USE_UART5
+//#define UART5_RX_PIN PD2
+//#define UART5_TX_PIN PC12
+
+#define SERIAL_PORT_COUNT 4
+
+//#define USE_ESCSERIAL
+//#define ESCSERIAL_TIMER_TX_HARDWARE 0 // PWM 1
+
+#define USE_SPI
+#define USE_SPI_DEVICE_1
+#define USE_SPI_DEVICE_2
+#define USE_SPI_DEVICE_3
+
+#define SPI1_NSS_PIN PA4
+#define SPI1_SCK_PIN PA5
+#define SPI1_MISO_PIN PA6
+#define SPI1_MOSI_PIN PA7
+
+#define SPI2_NSS_PIN PB12
+#define SPI2_SCK_PIN PB13
+#define SPI2_MISO_PIN PC2
+#define SPI2_MOSI_PIN PC3
+
+#define SPI3_NSS_PIN PA15
+#define SPI3_SCK_PIN PB3
+#define SPI3_MISO_PIN PB4
+#define SPI3_MOSI_PIN PB5
+
+#define USE_I2C
+#define I2C_DEVICE (I2CDEV_1)
+//#define I2C_DEVICE_EXT (I2CDEV_2)
+#define I2C1_SCL PB6
+#define I2C1_SDA PB7
+
+#define USE_ADC
+#define BOARD_HAS_VOLTAGE_DIVIDER
+#define VBAT_ADC_PIN PC0
+#define CURRENT_METER_ADC_PIN PC1
+#define RSSI_ADC_PIN PC4
+
+// LED strip configuration.
+#define LED_STRIP
+
+#define SPEKTRUM_BIND
+// USART2, PA3
+#define BIND_PIN PA3
+
+#define HARDWARE_BIND_PLUG
+// Hardware bind plug at PB2 (Pin 28)
+#define BINDPLUG_PIN PB2
+
+#define ENABLE_BLACKBOX_LOGGING_ON_SDCARD_BY_DEFAULT
+
+#define DEFAULT_FEATURES (FEATURE_MOTOR_STOP | FEATURE_BLACKBOX)
+#define DEFAULT_RX_FEATURE FEATURE_RX_SERIAL
+#define SERIALRX_UART SERIAL_PORT_USART2
+#define RX_CHANNELS_TAER
+
+#define TELEMETRY_UART SERIAL_PORT_USART1
+
+#define USE_SERIAL_4WAY_BLHELI_INTERFACE
+
+#define TARGET_IO_PORTA 0xffff
+#define TARGET_IO_PORTB 0xffff
+#define TARGET_IO_PORTC 0xffff
+#define TARGET_IO_PORTD (BIT(2))
+
+#define USABLE_TIMER_CHANNEL_COUNT 13
+#define USED_TIMERS ( TIM_N(1) | TIM_N(3) | TIM_N(4) | TIM_N(5) | TIM_N(8) )
+
diff --git a/src/main/target/ALIENFLIGHTNGF7/target.mk b/src/main/target/ALIENFLIGHTNGF7/target.mk
new file mode 100644
index 000000000..175dd29bc
--- /dev/null
+++ b/src/main/target/ALIENFLIGHTNGF7/target.mk
@@ -0,0 +1,15 @@
+F7X2RE_TARGETS += $(TARGET)
+FEATURES += SDCARD VCP
+
+TARGET_SRC = \
+ drivers/accgyro_mpu6500.c \
+ drivers/accgyro_spi_mpu6500.c \
+ drivers/barometer_bmp280.c \
+ drivers/barometer_spi_bmp280.c \
+ drivers/barometer_ms5611.c \
+ drivers/barometer_spi_ms5611.c \
+ drivers/compass_ak8963.c \
+ drivers/compass_hmc5883l.c \
+ drivers/compass_spi_hmc5883l.c \
+ drivers/light_ws2811strip.c \
+ drivers/light_ws2811strip_hal.c