/* SPDX-License-Identifier: LGPL-2.1-or-later */
#include "dissect-image.h"
+#include "extract-word.h"
#include "fd-util.h"
#include "fdisk-util.h"
+#include "parse-util.h"
#if HAVE_LIBFDISK
return sd_id128_from_string(pts, ret);
}
+int fdisk_partition_get_attrs_as_uint64(struct fdisk_partition *pa, uint64_t *ret) {
+ uint64_t flags = 0;
+ const char *a;
+ int r;
+
+ assert(pa);
+ assert(ret);
+
+ /* Retrieve current flags as uint64_t mask */
+
+ a = fdisk_partition_get_attrs(pa);
+ if (!a) {
+ *ret = 0;
+ return 0;
+ }
+
+ for (;;) {
+ _cleanup_free_ char *word = NULL;
+
+ r = extract_first_word(&a, &word, ",", EXTRACT_DONT_COALESCE_SEPARATORS);
+ if (r < 0)
+ return r;
+ if (r == 0)
+ break;
+
+ if (streq(word, "RequiredPartition"))
+ flags |= SD_GPT_FLAG_REQUIRED_PARTITION;
+ else if (streq(word, "NoBlockIOProtocol"))
+ flags |= SD_GPT_FLAG_NO_BLOCK_IO_PROTOCOL;
+ else if (streq(word, "LegacyBIOSBootable"))
+ flags |= SD_GPT_FLAG_LEGACY_BIOS_BOOTABLE;
+ else {
+ const char *e;
+ unsigned u;
+
+ /* Drop "GUID" prefix if specified */
+ e = startswith(word, "GUID:") ?: word;
+
+ if (safe_atou(e, &u) < 0) {
+ log_debug("Unknown partition flag '%s', ignoring.", word);
+ continue;
+ }
+
+ if (u >= sizeof(flags)*8) { /* partition flags on GPT are 64-bit. Let's ignore any further
+ bits should libfdisk report them */
+ log_debug("Partition flag above bit 63 (%s), ignoring.", word);
+ continue;
+ }
+
+ flags |= UINT64_C(1) << u;
+ }
+ }
+
+ *ret = flags;
+ return 0;
+}
+
+int fdisk_partition_set_attrs_as_uint64(struct fdisk_partition *pa, uint64_t flags) {
+ _cleanup_free_ char *attrs = NULL;
+ int r;
+
+ assert(pa);
+
+ for (unsigned i = 0; i < sizeof(flags) * 8; i++) {
+ if (!FLAGS_SET(flags, UINT64_C(1) << i))
+ continue;
+
+ r = strextendf_with_separator(&attrs, ",", "%u", i);
+ if (r < 0)
+ return r;
+ }
+
+ return fdisk_partition_set_attrs(pa, strempty(attrs));
+}
+
#endif
int fdisk_partition_get_uuid_as_id128(struct fdisk_partition *p, sd_id128_t *ret);
int fdisk_partition_get_type_as_id128(struct fdisk_partition *p, sd_id128_t *ret);
+int fdisk_partition_get_attrs_as_uint64(struct fdisk_partition *pa, uint64_t *ret);
+int fdisk_partition_set_attrs_as_uint64(struct fdisk_partition *pa, uint64_t flags);
+
#endif
p->device = mfree(p->device);
}
-static int fdisk_partition_get_attrs_as_uint64(
- struct fdisk_partition *pa,
- uint64_t *ret) {
-
- uint64_t flags = 0;
- const char *a;
- int r;
-
- assert(pa);
- assert(ret);
-
- /* Retrieve current flags as uint64_t mask */
-
- a = fdisk_partition_get_attrs(pa);
- if (!a) {
- *ret = 0;
- return 0;
- }
-
- for (;;) {
- _cleanup_free_ char *word = NULL;
-
- r = extract_first_word(&a, &word, ",", EXTRACT_DONT_COALESCE_SEPARATORS);
- if (r < 0)
- return r;
- if (r == 0)
- break;
-
- if (streq(word, "RequiredPartition"))
- flags |= SD_GPT_FLAG_REQUIRED_PARTITION;
- else if (streq(word, "NoBlockIOProtocol"))
- flags |= SD_GPT_FLAG_NO_BLOCK_IO_PROTOCOL;
- else if (streq(word, "LegacyBIOSBootable"))
- flags |= SD_GPT_FLAG_LEGACY_BIOS_BOOTABLE;
- else {
- const char *e;
- unsigned u;
-
- /* Drop "GUID" prefix if specified */
- e = startswith(word, "GUID:") ?: word;
-
- if (safe_atou(e, &u) < 0) {
- log_debug("Unknown partition flag '%s', ignoring.", word);
- continue;
- }
-
- if (u >= sizeof(flags)*8) { /* partition flags on GPT are 64-bit. Let's ignore any further
- bits should libfdisk report them */
- log_debug("Partition flag above bit 63 (%s), ignoring.", word);
- continue;
- }
-
- flags |= UINT64_C(1) << u;
- }
- }
-
- *ret = flags;
- return 0;
-}
-
-static int fdisk_partition_set_attrs_as_uint64(
- struct fdisk_partition *pa,
- uint64_t flags) {
-
- _cleanup_free_ char *attrs = NULL;
- int r;
-
- assert(pa);
-
- for (unsigned i = 0; i < sizeof(flags) * 8; i++) {
- if (!FLAGS_SET(flags, UINT64_C(1) << i))
- continue;
-
- r = strextendf_with_separator(&attrs, ",", "%u", i);
- if (r < 0)
- return r;
- }
-
- return fdisk_partition_set_attrs(pa, strempty(attrs));
-}
-
int read_partition_info(
struct fdisk_context *c,
struct fdisk_table *t,