All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] block: partitions: efi: Always check for alternative GPT at end of drive
@ 2016-04-26  1:06 ` Julius Werner
  0 siblings, 0 replies; 27+ messages in thread
From: Julius Werner @ 2016-04-26  1:06 UTC (permalink / raw)
  To: Davidlohr Bueso
  Cc: linux-efi, linux-kernel, linux-block, Gwendal Grignou,
	Doug Anderson, Julius Werner

The GUID Partiton Table layout maintains two synonymous partition tables
on a block device, one starting in sector 1 and one in the very last
sectors of the block device. This is useful if one of the tables gets
accidentally corrupted (e.g. through a partial write because of an
unexpected power loss).

Linux normally only boots if the primary GPT is valid. It will not even
try to find the alternative GPT to an invalid primary one unless the
"gpt" command line option forces more aggressive detection. This doesn't
really make any sense... if the "gpt" option is not set, the code
validates the protective or hybrid MBR in sector 0 anyway before it even
starts looking for the actual GPTs. If we get to the point where a valid
proctective or hybrid MBR was found but the primary GPT was not found
(valid), checking the alternative GPT is our best bet: we know that this
block device is meant to use GPT (because any other partitioning system
would've presumably overwritten sector 0), and we know that if the
alternative GPT is valid it should contain more accurate information
than parsing the protective/hybrid MBR with msdos_partition() would
yield (which would otherwise be what happens next).

Signed-off-by: Julius Werner <jwerner@chromium.org>
---
 block/partitions/efi.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/block/partitions/efi.c b/block/partitions/efi.c
index 26cb624..0d4ca8e 100644
--- a/block/partitions/efi.c
+++ b/block/partitions/efi.c
@@ -625,7 +625,7 @@ static int find_valid_gpt(struct parsed_partitions *state, gpt_header **gpt,
 		good_agpt = is_gpt_valid(state,
 					 le64_to_cpu(pgpt->alternate_lba),
 					 &agpt, &aptes);
-        if (!good_agpt && force_gpt)
+        if (!good_agpt)
                 good_agpt = is_gpt_valid(state, lastlba, &agpt, &aptes);
 
         /* The obviously unsuccessful case */
-- 
2.1.2

^ permalink raw reply related	[flat|nested] 27+ messages in thread

end of thread, other threads:[~2016-04-27 21:44 UTC | newest]

Thread overview: 27+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-04-26  1:06 [PATCH] block: partitions: efi: Always check for alternative GPT at end of drive Julius Werner
2016-04-26  1:06 ` Julius Werner
2016-04-26 10:20 ` Karel Zak
2016-04-26 10:20   ` Karel Zak
2016-04-26 18:33   ` Davidlohr Bueso
2016-04-26 20:13     ` Julius Werner
2016-04-26 20:13       ` Julius Werner
2016-04-26 20:34     ` Elliott, Robert (Persistent Memory)
2016-04-26 21:15       ` Davidlohr Bueso
2016-04-26 21:15         ` Davidlohr Bueso
2016-04-26 21:51         ` Gwendal Grignou
2016-04-26 21:51           ` Gwendal Grignou
2016-04-27 15:09           ` Karel Zak
2016-04-27 15:09             ` Karel Zak
2016-04-27 15:45             ` Doug Anderson
2016-04-27 21:44             ` Julius Werner
2016-04-27 21:44               ` Julius Werner
2016-04-27  6:00       ` Ard Biesheuvel
2016-04-27  6:00         ` Ard Biesheuvel
2016-04-27 12:59         ` Austin S. Hemmelgarn
2016-04-27 12:59           ` Austin S. Hemmelgarn
2016-04-26 14:38 ` Austin S. Hemmelgarn
2016-04-26 14:38   ` Austin S. Hemmelgarn
2016-04-26 18:10   ` Davidlohr Bueso
2016-04-26 18:10     ` Davidlohr Bueso
2016-04-26 19:27     ` Austin S. Hemmelgarn
2016-04-26 19:27       ` Austin S. Hemmelgarn

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.