Gadget.yaml fields

The available fields of the gadget.yaml file are defined in snapd/gadget/gadget.go.

A description is provided in the Gadget.yaml section of the Gadget snaps specification.

Here is a list the relevant part of the field hierarchy as of Snapd 2.67:

-volumes,omitempty (map[string]*Volume)
 |-<Key> (string)
 | <Value> (*Volume)
 | |-schema (string) enum:emmc,gpt,mbr
 | |-bootloader (string) enum:android-boot,grub,lk,piboot
 | |-id (string)
 | |-structure ([]VolumeStructure)
 | | |-name (string)
 | | |-type (string)
 | | |-filesystem (string) enum:ext4,vfat,vfat-16,vat-32
 | | |-filesystem-label (string)
 | | |-min-size (Size)
 | | |-size (Size)
 | | |-offset (*Offset)
 | | |-offset-write (*RelativeOffset)
 | | | |-relative-to (string)
 | | | |-offset (Offset)
 | | |-role (string) enum:system-boot,system-data,system-seed,system-seed-null,system-save
 | | |-id (string)
 | | |-content ([]VolumeContent)
 | | | |-source (string)
 | | | |-target (string)
 | | | |-image (string)
 | | | |-offset (*Offset)
 | | | |-size (Size)
 | | | |-unpack (bool)

The type field can have as value:

  • The string bare. This indicates an unformatted partition, e.g. for placing firmware.

  • A two digit partition type for MBR partition tables, e.g. EF

  • A partition type GUID for GPT partition tables, e.g. C12A7328-F81F-11D2-BA4B-00A0C93EC93B

  • a combination of MBR and GPT partition type e.g. EF,C12A7328-F81F-11D2-BA4B-00A0C93EC93B

Size, min.size, and offset fields can use an ‘M’ or ‘G’ postfix to indicate mebibytes or gibibytes. The following would be valid values for size:

  • 1048576

  • 4M

  • 16G

Here is an example:

---
volumes:
  riscv:
    schema: gpt
    bootloader: grub
    structure:
      - name: starfive_visionfive_2_u-boot-spl
        type: 2E54B353-1271-4842-806F-E436D6AF6985
        size: 1M
        content:
          - image: u-boot-starfive/u-boot-spl.bin.normal.out
      - name: starfive_visionfive_2_u-boot
        # random value for type
        type: 816E2DB1-6FE4-4797-B3FF-2DE37CB85318
        size: 16M
        content:
          - image: u-boot-starfive/u-boot.itb
      - name: EFI System
        type: C12A7328-F81F-11D2-BA4B-00A0C93EC93B
        filesystem: vfat
        filesystem-label: esp
        size: 100M
        role: system-boot
        content:
          - source: grub/grubriscv64.efi
            target: EFI/boot/bootriscv64.efi
          - source: grub/grubriscv64.efi
            target: EFI/ubuntu/grubriscv64.efi
          - source: grub/grub.cfg
            target: EFI/debian/grub.cfg
          - source: grub/grub.cfg
            target: EFI/ubuntu/grub.cfg
          - source: dtb/
            target: dtb/
      - name: CIDATA
        type: 0FC63DAF-8483-4772-8E79-3D69D8477DE4
        filesystem: vfat-16
        filesystem-label: CIDATA
        size: 4M
        content:
          - source: cidata/meta-data
            target: meta-data
          - source: cidata/user-data
            target: user-data
      - name: Root Partition
        type: 0FC63DAF-8483-4772-8E79-3D69D8477DE4
        filesystem: ext4
        filesystem-label: writable
        size: 3072M
        role: system-data