diff options
author | Lennart Poettering <lennart@poettering.net> | 2022-11-30 18:43:18 +0100 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2023-04-05 20:45:30 +0200 |
commit | 84be0c710d9d562f6d2cf986cc2a8ff4c98a138b (patch) | |
tree | b374ebea1d604154fa0e004560f428c7f111352c /src/partition/repart.c | |
parent | d452335aa47fb1f1b11dc75bc462697431e64af3 (diff) | |
download | systemd-84be0c710d9d562f6d2cf986cc2a8ff4c98a138b.tar.gz |
tree-wide: hook up image dissection policy logic everywhere
Diffstat (limited to 'src/partition/repart.c')
-rw-r--r-- | src/partition/repart.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/partition/repart.c b/src/partition/repart.c index e4ae8a2c89..bc3bfa15fb 100644 --- a/src/partition/repart.c +++ b/src/partition/repart.c @@ -148,6 +148,7 @@ static FilterPartitionsType arg_filter_partitions_type = FILTER_PARTITIONS_NONE; static sd_id128_t *arg_defer_partitions = NULL; static size_t arg_n_defer_partitions = 0; static uint64_t arg_sector_size = 0; +static ImagePolicy *arg_image_policy = NULL; STATIC_DESTRUCTOR_REGISTER(arg_root, freep); STATIC_DESTRUCTOR_REGISTER(arg_image, freep); @@ -158,6 +159,7 @@ STATIC_DESTRUCTOR_REGISTER(arg_certificate, X509_freep); STATIC_DESTRUCTOR_REGISTER(arg_tpm2_device, freep); STATIC_DESTRUCTOR_REGISTER(arg_tpm2_public_key, freep); STATIC_DESTRUCTOR_REGISTER(arg_filter_partitions, freep); +STATIC_DESTRUCTOR_REGISTER(arg_image_policy, image_policy_freep); typedef struct FreeArea FreeArea; @@ -5632,6 +5634,8 @@ static int help(void) { " --can-factory-reset Test whether factory reset is defined\n" " --root=PATH Operate relative to root path\n" " --image=PATH Operate relative to image file\n" + " --image-policy=POLICY\n" + " Specify disk image dissection policy\n" " --definitions=DIR Find partition definitions in specified directory\n" " --key-file=PATH Key to use when encrypting partitions\n" " --private-key=PATH Private key to use when generating verity roothash\n" @@ -5697,6 +5701,8 @@ static int parse_argv(int argc, char *argv[]) { ARG_EXCLUDE_PARTITIONS, ARG_DEFER_PARTITIONS, ARG_SECTOR_SIZE, + ARG_SKIP_PARTITIONS, + ARG_IMAGE_POLICY, }; static const struct option options[] = { @@ -5728,6 +5734,7 @@ static int parse_argv(int argc, char *argv[]) { { "exclude-partitions", required_argument, NULL, ARG_EXCLUDE_PARTITIONS }, { "defer-partitions", required_argument, NULL, ARG_DEFER_PARTITIONS }, { "sector-size", required_argument, NULL, ARG_SECTOR_SIZE }, + { "image-policy", required_argument, NULL, ARG_IMAGE_POLICY }, {} }; @@ -6022,6 +6029,18 @@ static int parse_argv(int argc, char *argv[]) { break; + case ARG_IMAGE_POLICY: { + _cleanup_(image_policy_freep) ImagePolicy *p = NULL; + + r = image_policy_from_string(optarg, &p); + if (r < 0) + return log_error_errno(r, "Failed to parse image policy: %s", optarg); + + image_policy_free(arg_image_policy); + arg_image_policy = TAKE_PTR(p); + break; + } + case '?': return -EINVAL; @@ -6522,6 +6541,7 @@ static int run(int argc, char *argv[]) { * systems */ r = mount_image_privately_interactively( arg_image, + arg_image_policy, DISSECT_IMAGE_MOUNT_READ_ONLY | (arg_node ? DISSECT_IMAGE_DEVICE_READ_ONLY : 0) | /* If a different node to make changes to is specified let's open the device in read-only mode) */ DISSECT_IMAGE_GPT_ONLY | |