diff mbox

[1/1] partitions/msdos: Unable to mount UFS 44bsd partitions

Message ID alpine.LNX.2.21.1711061520030.2849@joy.test (mailing list archive)
State New, archived
Headers show

Commit Message

Richard Narron Nov. 6, 2017, 11:25 p.m. UTC
UFS partitions from newer versions of FreeBSD 10 and 11 use 
relative addressing for their subpartitions. 
But older versions of FreeBSD still use absolute addressing just like 
OpenBSD and NetBSD.

Instead of simply testing for a FreeBSD partition, the code needs to also
test if the starting offset of the C subpartition is zero.

https://bugzilla.kernel.org/show_bug.cgi?id=197733

Signed-off-by: Richard Narron <comet.berkeley@gmail.com>
---
diff mbox

Patch

--- a/block/partitions/msdos.c.orig	2017-11-05 13:05:14.000000000 -0800
+++ b/block/partitions/msdos.c	2017-11-06 09:46:00.148228242 -0800
@@ -301,7 +301,9 @@  static void parse_bsd(struct parsed_part
  			continue;
  		bsd_start = le32_to_cpu(p->p_offset);
  		bsd_size = le32_to_cpu(p->p_size);
-		if (memcmp(flavour, "bsd\0", 4) == 0)
+		/* FreeBSD has relative offset if C partition offset is zero */
+		if (memcmp(flavour, "bsd\0", 4) == 0 &&
+		    le32_to_cpu(l->d_partitions[2].p_offset) == 0)
  			bsd_start += offset;
  		if (offset == bsd_start && size == bsd_size)
  			/* full parent partition, we have it already */