State of the Components v2 migration

The Component Framework is one of the key foundations for Fuchsia's usermode runtime environment. The original incarnation of components dates back to the inception of the Fuchsia OS and the initial commits in 2016. The framework has steadily evolved since then.

Components v1 vs. v2

Presently there are two revisions of the Component Framework that exist on Fuchsia, which are referred to as Components v1 and Components v2.

Components v1 is largely comprised of:

  • appmgr, a program that manages the runtime environment for v1 components. appmgr implements the root of the v1 components tree, as well as some foundational services such as the Components v1 ELF runner and Loader service.
  • sysmgr, a component that manages the so-called "sys" realm. sysmgr is launched by appmgr.
  • The .cmx file format for v1 component manifests.
  • The fuchsia.sys.* FIDL library.

Components v1 development reached its peak in 2018. In 2019, Fuchsia team began developing Component Framework v2.

Components v2 is largely comprised of:

  • Component manager, a program that manages the runtime environment for v2 components. Component manager is now responsible for launching appmgr. appmgr has become a v2 component itself, which serves as the parent of all v1 components still present in the system.
  • The .cml file format for v2 component manifests.
  • The fuchsia.sys2.* FIDL library.

In addition, both Components v1 and v2 use cmc (component manifest compiler), a build-time host tool that processes all formats of component manifest files.

Incremental progress

The nature of migrations is that they may take a long time and happen in incremental steps. The final step for migrating a component from v1 to v2 typically involves replacing a .cmx file with a .cml file.

Please see the self-service migration guide.

Latest status

Last updated: April 2021

A high-level diagram of the system's component topology is shown below:

Realms diagram

  • v2 components are shown in blue boxes.
  • v1 components are shown in red boxes.
  • Boxes with dashed lines represent components that are only present on some build configurations.

Component manager is one of the initial processes that are started in the system boot sequence. The system startup sequence then launches a number of low-level system components that deal with various responsibilities, including in no particular order:

  • Power management: device administration, thermals, power button, etc'.
  • System diagnostics: Archivist, Detect, and associated components.
  • Device driver management.
  • Filesystem management.
  • Developer tools support, such as Remote Control Service and the serial debugger bridge.
  • The package resolver, package cache, and system update committer.
  • The runtime for the session framework.
  • Various other system services such as the font provider, Stash system configurations service, the DHCP daemon, activity service, last reboot logger, etc'.

Interoperability with v1 components

Component manager launches appmgr, itself a v2 component, in order to manage v1 components. All v1 components on the system run under appmgr. Users may continue developing and maintaining v1 components while v2 migrations take place at their own pace.

Build configurations that use the Session Framework also include the session_manager component. All v1-backed capabilities the session needs are routed to the session_manager from appmgr.

Current areas of focus

Last updated: April 2021

Components v2 migrations are happening throughout the system. However there is currently additional focus on:

  • The stack of Software Delivery components and associated tests, including the package cache and package resolver.
  • The Netstack2 components, including migration of Netemul and associated tests to Test Runner Framework.
  • The Bluetooth components and associated tests.
  • Components under sysmgr that are critical to system functionality but each have a smaller footprint than the ones above, tracked here.
  • Scaling migrations by creating and expanding a self-service guide.