Blame SOURCES/0066-UP-dos-4k-partition-fix.patch

4728c8
---
4728c8
 kpartx/dos.c    |   17 ++++++++++-------
4728c8
 kpartx/gpt.c    |   20 +-------------------
4728c8
 kpartx/kpartx.c |   12 ++++++++++++
4728c8
 kpartx/kpartx.h |    8 ++++++++
4728c8
 4 files changed, 31 insertions(+), 26 deletions(-)
4728c8
4728c8
Index: multipath-tools-130222/kpartx/dos.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/kpartx/dos.c
4728c8
+++ multipath-tools-130222/kpartx/dos.c
4728c8
@@ -26,7 +26,9 @@ read_extended_partition(int fd, struct p
4728c8
 	int moretodo = 1;
4728c8
 	int i, n=0;
4728c8
 
4728c8
-	next = start = le32_to_cpu(ep->start_sect);
4728c8
+	int sector_size_mul = get_sector_size(fd)/512;
4728c8
+
4728c8
+	next = start = sector_size_mul * le32_to_cpu(ep->start_sect);
4728c8
 
4728c8
 	while (moretodo) {
4728c8
 		here = next;
4728c8
@@ -45,14 +47,14 @@ read_extended_partition(int fd, struct p
4728c8
 			memcpy(&p, bp + 0x1be + i * sizeof (p), sizeof (p));
4728c8
 			if (is_extended(p.sys_type)) {
4728c8
 				if (p.nr_sects && !moretodo) {
4728c8
-					next = start + le32_to_cpu(p.start_sect);
4728c8
+					next = start + sector_size_mul * le32_to_cpu(p.start_sect);
4728c8
 					moretodo = 1;
4728c8
 				}
4728c8
 				continue;
4728c8
 			}
4728c8
 			if (n < ns) {
4728c8
-				sp[n].start = here + le32_to_cpu(p.start_sect);
4728c8
-				sp[n].size = le32_to_cpu(p.nr_sects);
4728c8
+				sp[n].start = here + sector_size_mul * le32_to_cpu(p.start_sect);
4728c8
+				sp[n].size = sector_size_mul * le32_to_cpu(p.nr_sects);
4728c8
 				n++;
4728c8
 			} else {
4728c8
 				fprintf(stderr,
4728c8
@@ -76,6 +78,7 @@ read_dos_pt(int fd, struct slice all, st
4728c8
 	unsigned long offset = all.start;
4728c8
 	int i, n=4;
4728c8
 	unsigned char *bp;
4728c8
+	int sector_size_mul = get_sector_size(fd)/512;
4728c8
 
4728c8
 	bp = (unsigned char *)getblock(fd, offset);
4728c8
 	if (bp == NULL)
4728c8
@@ -89,8 +92,8 @@ read_dos_pt(int fd, struct slice all, st
4728c8
 		if (is_gpt(p.sys_type))
4728c8
 			return 0;
4728c8
 		if (i < ns) {
4728c8
-			sp[i].start =  le32_to_cpu(p.start_sect);
4728c8
-			sp[i].size = le32_to_cpu(p.nr_sects);
4728c8
+			sp[i].start =  sector_size_mul * le32_to_cpu(p.start_sect);
4728c8
+			sp[i].size = sector_size_mul * le32_to_cpu(p.nr_sects);
4728c8
 		} else {
4728c8
 			fprintf(stderr,
4728c8
 				"dos_partition: too many slices\n");
4728c8
@@ -99,7 +102,7 @@ read_dos_pt(int fd, struct slice all, st
4728c8
 		if (is_extended(p.sys_type)) {
4728c8
 			n += read_extended_partition(fd, &p, sp+n, ns-n);
4728c8
 			/* hide the extended partition itself */
4728c8
-			sp[i].size = 2;
4728c8
+			sp[i].size = sector_size_mul * 2;
4728c8
 		}
4728c8
 	}
4728c8
 	return n;
4728c8
Index: multipath-tools-130222/kpartx/gpt.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/kpartx/gpt.c
4728c8
+++ multipath-tools-130222/kpartx/gpt.c
4728c8
@@ -38,6 +38,7 @@
4728c8
 #include <byteswap.h>
4728c8
 #include <linux/fs.h>
4728c8
 #include "crc32.h"
4728c8
+#include "kpartx.h"
4728c8
 
4728c8
 #if BYTE_ORDER == LITTLE_ENDIAN
4728c8
 #  define __le16_to_cpu(x) (x)
4728c8
@@ -116,25 +117,6 @@ is_pmbr_valid(legacy_mbr *mbr)
4728c8
 
4728c8
 
4728c8
 /************************************************************
4728c8
- * get_sector_size
4728c8
- * Requires:
4728c8
- *  - filedes is an open file descriptor, suitable for reading
4728c8
- * Modifies: nothing
4728c8
- * Returns:
4728c8
- *  sector size, or 512.
4728c8
- ************************************************************/
4728c8
-static int
4728c8
-get_sector_size(int filedes)
4728c8
-{
4728c8
-	int rc, sector_size = 512;
4728c8
-
4728c8
-	rc = ioctl(filedes, BLKSSZGET, &sector_size);
4728c8
-	if (rc)
4728c8
-		sector_size = 512;
4728c8
-	return sector_size;
4728c8
-}
4728c8
-
4728c8
-/************************************************************
4728c8
  * _get_num_sectors
4728c8
  * Requires:
4728c8
  *  - filedes is an open file descriptor, suitable for reading
4728c8
Index: multipath-tools-130222/kpartx/kpartx.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/kpartx/kpartx.c
4728c8
+++ multipath-tools-130222/kpartx/kpartx.c
4728c8
@@ -26,6 +26,7 @@
4728c8
 #include <string.h>
4728c8
 #include <unistd.h>
4728c8
 #include <stdint.h>
4728c8
+#include <sys/ioctl.h>
4728c8
 #include <sys/stat.h>
4728c8
 #include <sys/types.h>
4728c8
 #include <ctype.h>
4728c8
@@ -606,3 +607,14 @@ getblock (int fd, unsigned int secnr) {
4728c8
 
4728c8
 	return bp->block;
4728c8
 }
4728c8
+
4728c8
+int
4728c8
+get_sector_size(int filedes)
4728c8
+{
4728c8
+	int rc, sector_size = 512;
4728c8
+
4728c8
+	rc = ioctl(filedes, BLKSSZGET, &sector_size);
4728c8
+	if (rc)
4728c8
+		sector_size = 512;
4728c8
+	return sector_size;
4728c8
+}
4728c8
Index: multipath-tools-130222/kpartx/kpartx.h
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/kpartx/kpartx.h
4728c8
+++ multipath-tools-130222/kpartx/kpartx.h
4728c8
@@ -2,6 +2,7 @@
4728c8
 #define _KPARTX_H
4728c8
 
4728c8
 #include <stdint.h>
4728c8
+#include <sys/ioctl.h>
4728c8
 
4728c8
 /*
4728c8
  * For each partition type there is a routine that takes
4728c8
@@ -18,6 +19,13 @@
4728c8
 #define safe_sprintf(var, format, args...)	\
4728c8
 	snprintf(var, sizeof(var), format, ##args) >= sizeof(var)
4728c8
 
4728c8
+#ifndef BLKSSZGET
4728c8
+#define BLKSSZGET  _IO(0x12,104)	/* get block device sector size */
4728c8
+#endif
4728c8
+
4728c8
+int
4728c8
+get_sector_size(int filedes);
4728c8
+
4728c8
 /*
4728c8
  * units: 512 byte sectors
4728c8
  */