From fd5fe6d83424cb1ce963cb76cce22122765995f6 Mon Sep 17 00:00:00 2001 From: Luca Boccassi Date: Tue, 22 Nov 2022 16:24:54 +0000 Subject: [PATCH] repart: respect --discard=no also for block devices It's only used to avoid BLKDISCARD on individual partitions at the moment. It can take a lot of time to run on very slow devices, so avoid it for them too. (cherry picked from commit 0dce448bbc97c861520c287b01d632b887442925) (cherry picked from commit d5e3625a61db2abd96c400af52bda4f39e06f65d) --- src/partition/repart.c | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/src/partition/repart.c b/src/partition/repart.c index 9076968f7b..3da6507bb9 100644 --- a/src/partition/repart.c +++ b/src/partition/repart.c @@ -3489,13 +3489,15 @@ static int context_write_partition_table( log_info("Wiped block device."); - r = context_discard_range(context, 0, context->total); - if (r == -EOPNOTSUPP) - log_info("Storage does not support discard, not discarding entire block device data."); - else if (r < 0) - return log_error_errno(r, "Failed to discard entire block device: %m"); - else if (r > 0) - log_info("Discarded entire block device."); + if (arg_discard) { + r = context_discard_range(context, 0, context->total); + if (r == -EOPNOTSUPP) + log_info("Storage does not support discard, not discarding entire block device data."); + else if (r < 0) + return log_error_errno(r, "Failed to discard entire block device: %m"); + else if (r > 0) + log_info("Discarded entire block device."); + } } r = fdisk_get_partitions(context->fdisk_context, &original_table);