fx - Fuchsia development commands

fx is the entry-point for a set of subcommands that make many tasks related to Fuchsia development easier.

It contains a large number of subcommands. Run fx help to see all the available subcommands. If you use bash or zsh as a shell, source scripts/fx-env.sh
to get some auto-completion.

Also see the global options and flags that affect all subcommands.

fx subcommands

Main subcommands

Subcommands that are part of the fx workflow.

Command Category Description
add-update-source Software delivery register a repository package server as a device's update source
args Build manually edit args.gn for the current build directory
bazel Build Run experimental Bazel build for Fuchsia platform tree
bazel-tool Build Run the bazel-tool script in the Fuchsia Bazel workspace.
bootfs-size-report Run, inspect and debug produce an uncompressed size report from a ZBI
build Build Run Ninja to build Fuchsia
build-metrics Other manage build metrics configuration
build-profile Other manage build profile configuration
cipd Source tree run the cipd command line tool
clean Build clean the current Fuchsia build artifacts
clean-build Build Clean the build directory and then perform a full build
cleandead Build Delete stale generated files in the build output directory.
cleandead-build Build Delete stale generated files and then perform a full build.
cmc Build Component manifest compiler
cp Device management copy a file to/from a target device
create-pb-zip Other Create pb.zip suitable for flashing based on product_bundles.json file.
create Source tree Scaffold new projects
doc-checker Code submission and review Check the markdown documentation using a variety of checks.
exec Other read the current build config, then exec
fargo Build Fargo is a prototype Fuchsia-specific wrapper around Cargo
fetch-build-artifacts Build TODO(https://fxbug.dev/42139110): under construction.
flash Device management flash a connected device
flash-remote Other Remotely build, fetch and flash a Fuchsia image onto a device, see https://fuchsia.dev/fuchsia-src/development/sdk/ffx/flash-a-device
format-code Source tree runs source formatters on modified files
gen Build run gn gen against the Fuchsia build directories.
get-build-artifacts Internal api DEPRECATED! Renamed to list-build-artifacts
get-build-dir Build print the current fuchsia build directory
get-device Device discovery print the current selected device name
get-device-addr Device discovery print the Fuchsia address of the current selected device
get-flash-source Internal api Builds and returns a list of a desired set of build artifacts
get-src-dir Build print the Fuchsia source directory (checkout root, aka "//")
get-workspace-dir Build print the Bazel workspace directory
gn Build meta-build system that generates build files for Ninja
go Build Manage Go source code
helpdoc Documentation create markdown docs for fx subcommands
host-tool Run, inspect and debug run a host tool produced by the build
is-package-server-running Software delivery check if the package server is running
jiri Source tree multi-purpose tool for multi-repo development.
jq Other jq is a utility for manipulating JSON on the command-line.
jq5 Build Extends the functionality of jq to json5 objects.
klog Run, inspect and debug listen for kernel logs
list-boards Build list boards available for building
list-build-artifacts Internal api Builds and returns a list of a desired set of build artifacts
list-devices Device discovery list all nearby devices (excluding those on zedboot)
list-products Build list products available for building
list-usb-disks Other list attached usb disks
local-publish-platform Other Release platform artifacts to local CIPD instances.
log Run, inspect and debug Display logs from a target device.
mdlint Code submission and review Markdown linter
merge-package-config Other
metrics Other manage collection of metrics in fx tools
mkzedboot Software delivery make a zedboot USB key
mkzedboot-remote Software delivery make a zedboot USB key
multi Other Run an fx command across multiple build directories.
netaddr Device discovery get the address of a running fuchsia system
netboot Software delivery run bootserver for netbooting
netboot-remote Other Remotely build, fetch and netboot
netls Device discovery list running fuchsia systems on the local network
ninja Build directly run the build system. Don't use for regular workflows.
ninjatrace2json Build Collect Ninja trace information for analysis in chrome://tracing
node-names Device management find other names for the same node
ota Software delivery perform a system OTA on a connected device
qemu Run, inspect and debug start fuchsia in qemu with a FVM disk
rbe Build check remote build configuration
reboot Device management reboot a target fuchsia system
repro Build Locally replicate the result of infra builds and tests
rfc Source tree Scaffold new RFCs
run-host-tests Test DEPRECATED! build and run tests on host
run-in-build-dir Build Run the given command at the root of the current build directory
run-netboot Run, inspect and debug start fuchsia in qemu via netboot
run-script Other Run a custom combination of commands, able to take advantage of fx -i (iterative mode)
scp Device management invoke scp with the build ssh config
sdk-deps Other List the dependencies of a target, and if dependencies are in SDK
self-build Build build the minimal host dependencies to run fx main workflows
self-test Test run tests of fx and subcommands
serial Device management attach to a serial console
serve Software delivery start the update server and attach to a running fuchsia device
serve-remote Other serve from a remote workstation
set Build set up a build directory
set-build-dir Build set the default build directory used by other fx commands
set-device Device discovery set the default device to interact with
setup-macos Other register host tools at MacOS Application Firewall
setup-ufw Other setup Linux firewall rules to allow Fuchsia device and emulator traffic.
sftp Device management invoke sftp with the build ssh config
shell Device management start a remote interactive shell in the target device
ssh Device management invoke ssh with the ssh keys and configuration for Fuchsia devices.
status Other print relevant information about the developer setup
symbolize Run, inspect and debug Deprecated, please use "ffx debug symbolize"
sync-to Source tree Sync the local Fuchsia source tree to a given state
syslog Run, inspect and debug DEPRECATED! deprecated alias for fx log
test Test Entry point for all Fuchsia tests (host, target, and end-to-end)
testgen Test Component integration test auto-generator
unset-device Device discovery unset the default device to interact with
update Software delivery DEPRECATED! deprecated alias for fx ota
update-if-in-base Software delivery check if packages are in base and update the device if needed
use Build re-use a previous build directory set up by fx set
vendor Other forward commands to vendor/*/scripts/devshell
wait Device management wait for a shell to become available

Contrib subcommands

Subcommands that have been contributed by project members that have other levels of support, ownership, or both. The OWNERS file in the contrib directory provides a pointer to the member that supports each script.

Command Category Description
add-host-test Build add a GN label to args.gn and regen
add-test Build add a GN label to args.gn and regen
arm-esr Other decode ARM Exception Syndrome Register values
bazel2gn Source tree Syncs BUILD.gn and BUILD.bazel for targets that are dual-building in both.
bindc Run, inspect and debug run the bind program compiler and debugger
binutils Run, inspect and debug Provides a shortcut to the prebuilt LLVM binutils tools
bisect-rustc Other
blobstats Run, inspect and debug compute some blobfs statistics from the build
bt-snoop-from-snapshot Run, inspect and debug extract a snoop log from a snapshot as pcap formatted data
build-main-pb Build build the current default product bundle
check-deps Build checks dependency graph in areas
check-goldens Source tree Checks all golden file comparisons in the GN build graph.
check-licenses Documentation analyze the license state of a given package or directory
cl Code submission and review Open in a new browser window the gerrit review URL.
clang-tidy Source tree runs clang-tidy on specified files
clippy Other Runs a Rust helper script inside the fx environment under the lock
clippy Diagnostic
compdb Build DEPRECATED
core-tests Test run zircon core-tests
coverage Test Runs test and exports coverage data.
cpu-stats Run, inspect and debug generate a report of CPU stats from a snapshot
dis Diagnostic Dumps disassembly for binaries from the build.
exec-host-tests Test
extract-pprof Run, inspect and debug Extract pprof data from inspect.json
extract-zbi Other
fastboot Device management interact directly with a device's bootloader via the fastboot protocol
ffx Other execute ffx - developer tools for fuchsia devices.
fidlcat Run, inspect and debug Deprecated, please use "ffx debug fidl"
fidldoc Documentation generate documentation for FIDL
fidltags Other generate tags for .fidl files
find-owner Other
flash-kola Other Flash Fuchsia onto a Kola board that has an unmodified bootloader.
force-ota-from-devhost Software delivery force an Over The Air system update from devhost (reboots!)
fuzz Run, inspect and debug DEPRECATED! run a fuzz test on target a device
gc Software delivery garbage collect packages on the target (reboots!)
gce Other Google Compute Engine commands
gdb Run, inspect and debug Run GDB, the GNU DeBugger.
gen-cargo Other Runs a Rust helper script inside the fx environment
gen-cargo Source tree generate symlinks to Rust Cargo.toml output files
gerrit-split-cl Code submission and review Submits chains of CLs to Gerrit
gerrit-submit Code submission and review Submits chains of CLs to Gerrit
get-main-pb Build print the current main product bundle's label
get-main-pb-path Build get the output path to the provided product bundle
gnu Run, inspect and debug Provides a shortcut to the prebuilt GNU diagnostic tools
grep Source tree print lines in the Fuchsia sources matching the given pattern
init-partition-tables Other run bootserver for initializing partition tables
iquery Other
lint Source tree runs source linters on modified files
list-owners Source tree Finds the nearest OWNERS file corresponding to the provided path, or the
list-packages Build List which packages are built.
ls-buildid Build Find binaries among build directories, the checkout, and cloud storage
make-fuchsia-vol Other build a fuchsia persistent disk
mkinstaller Software delivery make a Fuchsia installer image
mkinstaller-remote Software delivery make a Fuchsia installer image from a remote build host
move-docs Documentation Helper tool to batch move docs from one location to another
pending-commits Source tree view commits not yet published to global integration
power-digest Run, inspect and debug Summarize Inspect power events from Power Broker
power-viz Run, inspect and debug Summarize Inspect power events from Power Broker
pprof Run, inspect and debug pprof wrapper that gives access to local files in symbol-index
publish Software delivery publish a set of packages
qemu-cipd-ensure Other Generate CIPD files to download the current QEMU package.
refresh-bazel-compdb Other
refresh-bazel-compdb-bin.py Other
remove-update-source Software delivery unregister a repository package server as a device's update source
roll-compiler Other
run-boot-test Run, inspect and debug Run a ZBI test
run-boot-test.py Other
run-e2e-tests Test run e2e tests
run-in-build Run, inspect and debug Run a command in the build directory
run-recovery Run, inspect and debug start Fuchsia System Recovery in qemu
run-zbi-test-remote Run, inspect and debug Remotely build a ZBI test, fetch and run it
rust-3p-outdated Other Runs a Rust helper script inside the fx environment under the lock
rust-3p-outdated Diagnostic
rustdoc Other Runs a Rust helper script inside the fx environment
rustdoc-link Other Runs a Rust helper script inside the fx environment
rustdoc-link Documentation Link generated documentation for Rust code. Replaces fx rustdoc
rustdoc Documentation generate documentation for Rust code
rustfmt Other Runs a Rust helper script inside the fx environment
rustfmt Source tree format Rust code
set-petal Source tree configure jiri to manage a specific petal
set-relay Other Actuates the state of an external relay by writing a single byte to |tty|.
setup-go Other Set up the checkout for Go development.
setup-usb-ethernet Other Setup udev rules for USB CDC ethernet
show-package Software delivery lists package contents
shush Source tree silence rust lints with allows or compiler suggested fixes
size-check Other Convenience wrapper for running the product size checker.
smoke-test Other Runs a Python helper script inside the fx environment
smoke-test Test Finds and runs tests affected by the current change.
snapshot Run, inspect and debug Obtain and parse a snapshot from a connected target.
sniff Run, inspect and debug Fuchsia packet capture and display tool
sniff.py Other
symbol-index Build (deprecated) manipulate the symbol-index file
sync-from-stem Source tree sync integration and deps to a state matching fuchsia.git state
system-status Device management Get a summary of system status
test-rustdoc Test runs "fx rustdoc" on all rust targets
test-stats Test Query and calculate test stats.
test-stats.py Test Query and calculate test stats.
triage Run, inspect and debug generate a report of error conditions, with Google-specific rules.
unarchive-package Software delivery unarchive a Fuchsia package archive in FAR format
update-3p-owners Source tree updates OWNERS files for third_party dependencies
update-rust-3p-outdated Source tree updates external Rust dependencies with latest from crates.io
update-rustc-third-party Source tree updates rustc_library and rustc_binary third_party dependencies
validate-sdk Build Attempt to build a few known SDK-based OOT repos based on a core SDK
wipe-partition-tables Other run bootserver for wiping partition tables
zbi_json_to_d3js.py Other
zedmon Other run zedmon client
zxdb Run, inspect and debug Deprecated, please use "ffx debug connect"