FBT is the entry point for firmware-related commands and utilities.
It is invoked by ./fbt
in the firmware project root directory. Internally, it is a wrapper around scons build system.
Please install Python packages required by assets build scripts: pip3 install -r scripts/requirements.txt
fbt
constructs all referenced environments & their targets' dependency trees on startup. So, to keep startup time as low as possible, we're hiding construction of certain targets behind command-line options.fbt
always performsgit submodule update --init
on start, unless you setFBT_NO_SYNC=1
in environment:- On Windows, that's
set "FBT_NO_SYNC=1"
in the shell you're runningfbt
from - On *nix, it's
$ FBT_NO_SYNC=1 ./fbt ...
- On Windows, that's
fbt
builds updater & firmware in separate subdirectories inbuild
, with their names depending on optimization settings (COMPACT
&DEBUG
options). However, for ease of integration with IDEs, latest built variant's directory is always linked asbuilt/latest
. Additionally,compile_commands.json
is generated in that folder, which is used for code completion support in IDE.
To build with FBT, call it specifying configuration options & targets to build. For example,
./fbt COMPACT=1 DEBUG=0 VERBOSE=1 updater_package copro_dist
To run cleanup (think of make clean
) for specified targets, add -c
option.
fbt
includes basic development environment configuration for VSCode. To deploy it, run ./fbt vscode_dist
. That will copy initial environment configuration to .vscode
folder. After that, you can use that configuration by starting VSCode and choosing firmware root folder in "File > Open Folder" menu.
- On first start, you'll be prompted to install recommended plug-ins. Please install them for best development experience. You can find a list of them in
.vscode/extensions.json
. - Basic build tasks are invoked in Ctrl+Shift+B menu.
- Debugging requires a supported probe. That includes:
- Wi-Fi devboard with stock firmware (blackmagic),
- ST-Link and compatible devices,
- J-Link for flashing and debugging (in VSCode only). Note that J-Link tools are not included with our toolchain and you have to download them yourself and put on your system's PATH.
- Without a supported probe, you can install firmware on Flipper using USB installation method.
fbt
keeps track of internal dependencies, so you only need to build the highest-level target you need, and fbt
will make sure everything they depend on is up-to-date.
fw_dist
- build & publish firmware todist
folder. This is a default target, when no other are specifiedplugin_dist
- build external plugins & publish todist
folderupdater_package
,updater_minpackage
- build self-update package. Minimal version only inclues firmware's DFU file; full version also includes radio stack & resources for SD cardcopro_dist
- bundle Core2 FUS+stack binaries for qFlipperflash
- flash attached device with OpenOCD over ST-Linkflash_usb
,flash_usb_full
- build, upload and install update package to device over USB. See details onupdater_package
,updater_minpackage
debug
- build and flash firmware, then attach with gdb with firmware's .elf loadeddebug_other
,debug_other_blackmagic
- attach gdb without loading any .elf. Allows to manually add external elf files withadd-symbol-file
in gdbupdater_debug
- attach gdb with updater's .elf loadedblackmagic
- debug firmware with Blackmagic probe (WiFi dev board)openocd
- just start OpenOCDget_blackmagic
- output blackmagic address in gdb remote format. Useful for IDE integrationlint
,format
- run clang-format on C source code to check and reformat it according to.clang-format
specslint_py
,format_py
- run black on Python source code, build system files & application manifests
firmware_extapps
- build all plug-ins as separate .elf filesfirmware_snake_game
, etc - build single plug-in as .elf by its name- Check out
--extra-ext-apps
for force adding extra apps to external build firmware_snake_game_list
, etc - generate source + assembler listing for app's .elf
flash
,firmware_flash
- flash current version to attached device with OpenOCD over ST-Linkjflash
- flash current version to attached device with JFlash using J-Link probe. JFlash executable must be on your $PATHflash_blackmagic
- flash current version to attached device with Blackmagic probefirmware_all
,updater_all
- build basic set of binariesfirmware_list
,updater_list
- generate source + assembler listingfirmware_cdb
,updater_cdb
- generatecompilation_database.json
file for external tools and IDEs. It can be created without actually building the firmware.
resources
- build resources and their Manifestdolphin_ext
- process dolphin animations for SD card
icons
- generate .c+.h for icons from png assetsproto
- generate .pb.c+.pb.h for .proto sourcesproto_ver
- generate .h with protobuf versiondolphin_internal
,dolphin_blocking
- generate .c+.h for corresponding dolphin assets
--options optionfile.py
(default valuefbt_options.py
) - load file with multiple configuration values--with-updater
- enables updater-related targets and dependency tracking. Enabling this option introduces extra startup time costs, so use it when bundling update packages. Explicily enabling this should no longer be required,fbt
now has specific handling for updater-related targets--extra-int-apps=app1,app2,appN
- forces listed apps to be built as internal withfirmware
target--extra-ext-apps=app1,app2,appN
- forces listed apps to be built as external withfirmware_extapps
target
Default configuration variables are set in the configuration file fbt_options.py
.
Values set on command-line have higher precedence over configuration file.
You can find out available options with ./fbt -h
.
You can create customized firmware builds by modifying the application list to be included in the build. Application presets are configured with the FIRMWARE_APPS
option, which is a map(configuration_name:str -> application_list:tuple(str)). To specify application set to use in a build, set FIRMWARE_APP_SET
to its name.
For example, to build a firmware image with unit tests, run ./fbt FIRMWARE_APP_SET=unit_tests
.
Check out fbt_options.py
for details.