#endif
#define _GPT_ARCH_SEXTET(arch, name) \
- { GPT_ROOT_##arch, "root-" name }, \
- { GPT_ROOT_##arch##_VERITY, "root-" name "-verity" }, \
- { GPT_ROOT_##arch##_VERITY_SIG, "root-" name "-verity-sig" }, \
- { GPT_USR_##arch, "usr-" name }, \
- { GPT_USR_##arch##_VERITY, "usr-" name "-verity" }, \
- { GPT_USR_##arch##_VERITY_SIG, "usr-" name "-verity-sig" }
+ { GPT_ROOT_##arch, "root-" name, ARCHITECTURE_##arch }, \
+ { GPT_ROOT_##arch##_VERITY, "root-" name "-verity", ARCHITECTURE_##arch }, \
+ { GPT_ROOT_##arch##_VERITY_SIG, "root-" name "-verity-sig", ARCHITECTURE_##arch }, \
+ { GPT_USR_##arch, "usr-" name, ARCHITECTURE_##arch }, \
+ { GPT_USR_##arch##_VERITY, "usr-" name "-verity", ARCHITECTURE_##arch }, \
+ { GPT_USR_##arch##_VERITY_SIG, "usr-" name "-verity-sig", ARCHITECTURE_##arch }
const GptPartitionType gpt_partition_type_table[] = {
_GPT_ARCH_SEXTET(ALPHA, "alpha"),
_GPT_ARCH_SEXTET(ARM, "arm"),
_GPT_ARCH_SEXTET(ARM64, "arm64"),
_GPT_ARCH_SEXTET(IA64, "ia64"),
- _GPT_ARCH_SEXTET(LOONGARCH64, "loongarch64"),
+
+ // TODO: Replace with `_GPT_ARCH_SEXTET(LOONGARCH64, "loongarch64")` once
+ // https://github.com/systemd/systemd/pull/21288 is merged. */
+ { GPT_ROOT_LOONGARCH64, "root-loongarch64", _ARCHITECTURE_INVALID },
+ { GPT_ROOT_LOONGARCH64_VERITY, "root-loongarch64-verity", _ARCHITECTURE_INVALID },
+ { GPT_ROOT_LOONGARCH64_VERITY_SIG, "root-loongarch64-verity-sig", _ARCHITECTURE_INVALID },
+ { GPT_USR_LOONGARCH64, "usr-loongarch64", _ARCHITECTURE_INVALID },
+ { GPT_USR_LOONGARCH64_VERITY, "usr-loongarch64-verity", _ARCHITECTURE_INVALID },
+ { GPT_USR_LOONGARCH64_VERITY_SIG, "usr-loongarch64-verity-sig", _ARCHITECTURE_INVALID },
+
_GPT_ARCH_SEXTET(MIPS_LE, "mips-le"),
_GPT_ARCH_SEXTET(MIPS64_LE, "mips64-le"),
_GPT_ARCH_SEXTET(PPC, "ppc"),
_GPT_ARCH_SEXTET(X86, "x86"),
_GPT_ARCH_SEXTET(X86_64, "x86-64"),
#ifdef GPT_ROOT_NATIVE
- { GPT_ROOT_NATIVE, "root" },
- { GPT_ROOT_NATIVE_VERITY, "root-verity" },
- { GPT_ROOT_NATIVE_VERITY_SIG, "root-verity-sig" },
- { GPT_USR_NATIVE, "usr" },
- { GPT_USR_NATIVE_VERITY, "usr-verity" },
- { GPT_USR_NATIVE_VERITY_SIG, "usr-verity-sig" },
+ { GPT_ROOT_NATIVE, "root", native_architecture() },
+ { GPT_ROOT_NATIVE_VERITY, "root-verity", native_architecture() },
+ { GPT_ROOT_NATIVE_VERITY_SIG, "root-verity-sig", native_architecture() },
+ { GPT_USR_NATIVE, "usr", native_architecture() },
+ { GPT_USR_NATIVE_VERITY, "usr-verity", native_architecture() },
+ { GPT_USR_NATIVE_VERITY_SIG, "usr-verity-sig", native_architecture() },
#endif
#ifdef GPT_ROOT_SECONDARY
_GPT_ARCH_SEXTET(SECONDARY, "secondary"),
#endif
- { GPT_ESP, "esp" },
- { GPT_XBOOTLDR, "xbootldr" },
- { GPT_SWAP, "swap" },
- { GPT_HOME, "home" },
- { GPT_SRV, "srv" },
- { GPT_VAR, "var" },
- { GPT_TMP, "tmp" },
- { GPT_USER_HOME, "user-home" },
- { GPT_LINUX_GENERIC, "linux-generic" },
+ { GPT_ESP, "esp", _ARCHITECTURE_INVALID },
+ { GPT_XBOOTLDR, "xbootldr", _ARCHITECTURE_INVALID },
+ { GPT_SWAP, "swap", _ARCHITECTURE_INVALID },
+ { GPT_HOME, "home", _ARCHITECTURE_INVALID },
+ { GPT_SRV, "srv", _ARCHITECTURE_INVALID },
+ { GPT_VAR, "var", _ARCHITECTURE_INVALID },
+ { GPT_TMP, "tmp", _ARCHITECTURE_INVALID },
+ { GPT_USER_HOME, "user-home", _ARCHITECTURE_INVALID },
+ { GPT_LINUX_GENERIC, "linux-generic", _ARCHITECTURE_INVALID },
{}
};
return sd_id128_from_string(s, ret);
}
+Architecture gpt_partition_type_uuid_to_arch(sd_id128_t id) {
+ for (size_t i = 0; i < ELEMENTSOF(gpt_partition_type_table) - 1; i++)
+ if (sd_id128_equal(id, gpt_partition_type_table[i].uuid))
+ return gpt_partition_type_table[i].arch;
+
+ return _ARCHITECTURE_INVALID;
+}
+
int gpt_partition_label_valid(const char *s) {
_cleanup_free_ char16_t *recoded = NULL;