summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sbin/fdisk/user.c40
1 files changed, 24 insertions, 16 deletions
diff --git a/sbin/fdisk/user.c b/sbin/fdisk/user.c
index 1f721a89335..1972211a2a3 100644
--- a/sbin/fdisk/user.c
+++ b/sbin/fdisk/user.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: user.c,v 1.54 2021/05/14 15:31:01 krw Exp $ */
+/* $OpenBSD: user.c,v 1.55 2021/05/15 15:20:17 krw Exp $ */
/*
* Copyright (c) 1997 Tobias Weingartner
@@ -155,27 +155,35 @@ USER_print_disk(int verbosity)
MBR_parse(&dos_mbr, offset, firstoff, &mbr);
if (offset == 0) {
efi = MBR_protective_mbr(&mbr);
- if (verbosity == VERBOSE || efi != -1) {
+ if (efi == -1) {
+ /* No valid 0xEE partition means no GPT. */
if (verbosity == VERBOSE) {
- printf("Primary GPT:\n");
- GPT_read(PRIMARYGPT);
+ printf("Primary GPT:\nNot Found\n");
+ printf("\nSecondary GPT:\nNot Found\n");
}
+ } else if (verbosity == TERSE) {
+ /* Should already have read one of Primary/Secondary GPT. */
+ if (letoh64(gh.gh_sig) == GPTSIGNATURE) {
+ GPT_print("s", verbosity);
+ return;
+ }
+ } else {
+ /*. Read & print both primary and secondary GPT. */
+ printf("Primary GPT:\n");
+ GPT_read(PRIMARYGPT);
if (letoh64(gh.gh_sig) == GPTSIGNATURE)
GPT_print("s", verbosity);
else
printf("\tNot Found\n");
- if (verbosity == VERBOSE) {
- printf("\n");
- printf("Secondary GPT:\n");
- GPT_read(SECONDARYGPT);
- if (letoh64(gh.gh_sig) == GPTSIGNATURE)
- GPT_print("s", verbosity);
- else
- printf("\tNot Found\n");
- printf("\nMBR:\n");
- } else
- break;
- }
+ printf("\nSecondary GPT:\n");
+ GPT_read(SECONDARYGPT);
+ if (letoh64(gh.gh_sig) == GPTSIGNATURE)
+ GPT_print("s", verbosity);
+ else
+ printf("\tNot Found\n");
+ }
+ if (verbosity == VERBOSE)
+ printf("\nMBR:\n");
}
MBR_print(&mbr, NULL);