Blame SOURCES/0058-libparted-dasd-unify-vtoc-handling-for-cdl-ldl.patch

0cb0b9
From ebb6eef20792a17388da30f1c312ede4b03140fd Mon Sep 17 00:00:00 2001
0cb0b9
From: Wang Dong <dongdwdw@linux.vnet.ibm.com>
0cb0b9
Date: Wed, 26 Oct 2016 04:22:46 +0200
0cb0b9
Subject: [PATCH 58/75] libparted/dasd: unify vtoc handling for cdl/ldl
0cb0b9
0cb0b9
Merge volume label cdl and ldl. It is convenient to manipulate
0cb0b9
the same structure. Also remove unused arguments in the functions.
0cb0b9
0cb0b9
Signed-off-by: Wang Dong <dongdwdw@linux.vnet.ibm.com>
0cb0b9
Signed-off-by: Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
0cb0b9
Signed-off-by: Brian C. Lane <bcl@redhat.com>
0cb0b9
---
0cb0b9
 include/parted/vtoc.in.h | 34 +++++++++++++++++++---------------
0cb0b9
 libparted/labels/dasd.c  |  8 +++-----
0cb0b9
 libparted/labels/vtoc.c  | 38 +++++++++++++++++---------------------
0cb0b9
 3 files changed, 39 insertions(+), 41 deletions(-)
0cb0b9
0cb0b9
diff --git a/include/parted/vtoc.in.h b/include/parted/vtoc.in.h
0cb0b9
index 499c2d3..b9da23a 100644
0cb0b9
--- a/include/parted/vtoc.in.h
0cb0b9
+++ b/include/parted/vtoc.in.h
0cb0b9
@@ -62,7 +62,6 @@ typedef struct cchh             cchh_t;
0cb0b9
 typedef struct labeldate        labeldate_t;
0cb0b9
 typedef struct volume_label     volume_label_t;
0cb0b9
 typedef struct cms_volume_label cms_volume_label_t;
0cb0b9
-typedef struct ldl_volume_label ldl_volume_label_t;
0cb0b9
 typedef struct extent           extent_t;
0cb0b9
 typedef struct dev_const        dev_const_t;
0cb0b9
 typedef struct format1_label    format1_label_t;
0cb0b9
@@ -94,6 +93,19 @@ struct __attribute__ ((packed)) labeldate {
0cb0b9
         u_int16_t day;
0cb0b9
 };
0cb0b9
 
0cb0b9
+/*
0cb0b9
+ * The following structure is a merger of the cdl and ldl volume label.
0cb0b9
+ * On an ldl disk there is no key information, so when reading an
0cb0b9
+ * ldl label from disk, the data should be copied at the address of vollbl.
0cb0b9
+ * On the other side, the field ldl_version is reserved in a cdl record
0cb0b9
+ * and the field formatted_blocks exists only for ldl labels. So when
0cb0b9
+ * reading a cdl label from disk, the formatted_blocks field will contain
0cb0b9
+ * arbitrary data.
0cb0b9
+ * This layout may be a bit awkward, but the advantage of having the
0cb0b9
+ * same label type for both disk layout types is bigger than the effort
0cb0b9
+ * for taking a bit of extra care at the fringes.
0cb0b9
+ */
0cb0b9
+
0cb0b9
 struct __attribute__ ((packed)) volume_label {
0cb0b9
 	char volkey[4];         /* volume key = volume label                 */
0cb0b9
 	char vollbl[4];	        /* volume label ("VOL1" in EBCDIC)           */
0cb0b9
@@ -107,15 +119,8 @@ struct __attribute__ ((packed)) volume_label {
0cb0b9
 	char labperci[4];       /* no of labels per CI (FBA), blanks for CKD */
0cb0b9
 	char res2[4];	        /* reserved                                  */
0cb0b9
 	char lvtoc[14];	        /* owner code for LVTOC                      */
0cb0b9
-	char res3[29];	        /* reserved                                  */
0cb0b9
-        char fudge[4];          /* filler to match length of ldl label       */
0cb0b9
-};
0cb0b9
-
0cb0b9
-struct __attribute__ ((packed)) ldl_volume_label {
0cb0b9
-	char vollbl[4];         /* Label identifier ("LNX1" in EBCDIC)       */
0cb0b9
-        char volid[6];          /* Volume identifier                         */
0cb0b9
-        char res3[69];          /* Reserved field                            */
0cb0b9
-        char ldl_version[1];    /* Version number, valid for ldl format      */
0cb0b9
+        char res3[28];	        /* reserved                                  */
0cb0b9
+        char ldl_version;       /* version number, valid for ldl format      */
0cb0b9
         u_int64_t formatted_blocks;  /* valid when ldl_version >= "2" (in
0cb0b9
                                         EBCDIC)                              */
0cb0b9
 };
0cb0b9
@@ -335,11 +340,10 @@ void vtoc_write_label (int fd, unsigned long position,
0cb0b9
                        format7_label_t const *f7,
0cb0b9
                        format9_label_t const *f9);
0cb0b9
 
0cb0b9
-void vtoc_init_format1_label (char *volid, unsigned int blksize,
0cb0b9
+void vtoc_init_format1_label (unsigned int blksize,
0cb0b9
                               extent_t *part_extent, format1_label_t *f1);
0cb0b9
 
0cb0b9
 void vtoc_init_format4_label (format4_label_t *f4lbl,
0cb0b9
-                              unsigned int usable_partitions,
0cb0b9
                               unsigned int compat_cylinders,
0cb0b9
                               unsigned int real_cylinders,
0cb0b9
                               unsigned int tracks,
0cb0b9
@@ -352,11 +356,11 @@ void vtoc_update_format4_label (format4_label_t *f4, cchhb_t *highest_f1,
0cb0b9
 
0cb0b9
 void vtoc_init_format5_label (format5_label_t *f5);
0cb0b9
 
0cb0b9
-void vtoc_update_format5_label_add (format5_label_t *f5, int verbose, int cyl,
0cb0b9
+void vtoc_update_format5_label_add (format5_label_t *f5, int verbose,
0cb0b9
                                     int trk, u_int16_t a, u_int16_t b,
0cb0b9
                                     u_int8_t c);
0cb0b9
 
0cb0b9
-void vtoc_update_format5_label_del (format5_label_t *f5, int verbose, int cyl,
0cb0b9
+void vtoc_update_format5_label_del (format5_label_t *f5, int verbose,
0cb0b9
                                     int trk, u_int16_t a, u_int16_t b,
0cb0b9
                                     u_int8_t c);
0cb0b9
 
0cb0b9
@@ -368,7 +372,7 @@ void vtoc_update_format7_label_add (format7_label_t *f7, int verbose,
0cb0b9
 void vtoc_update_format7_label_del (format7_label_t *f7, int verbose,
0cb0b9
                                     u_int32_t a, u_int32_t b);
0cb0b9
 
0cb0b9
-void vtoc_init_format8_label (char *volid, unsigned int blksize,
0cb0b9
+void vtoc_init_format8_label (unsigned int blksize,
0cb0b9
                               extent_t *part_extent, format1_label_t *f1);
0cb0b9
 
0cb0b9
 void vtoc_update_format8_label (cchhb_t *associated_f9, format1_label_t *f8);
0cb0b9
diff --git a/libparted/labels/dasd.c b/libparted/labels/dasd.c
0cb0b9
index 4e68512..7594e96 100644
0cb0b9
--- a/libparted/labels/dasd.c
0cb0b9
+++ b/libparted/labels/dasd.c
0cb0b9
@@ -330,13 +330,12 @@ dasd_read (PedDisk* disk)
0cb0b9
 		DasdPartitionData* dasd_data;
0cb0b9
 
0cb0b9
 		union vollabel {
0cb0b9
-			volume_label_t unused;
0cb0b9
-			ldl_volume_label_t ldl;
0cb0b9
+			volume_label_t ldl;
0cb0b9
 			cms_volume_label_t cms;
0cb0b9
 		};
0cb0b9
 		union vollabel *cms_ptr1 = (union vollabel *) anchor.vlabel;
0cb0b9
 		cms_volume_label_t *cms_ptr = &cms_ptr1->cms;
0cb0b9
-		ldl_volume_label_t *ldl_ptr = &cms_ptr1->ldl;
0cb0b9
+		volume_label_t *ldl_ptr = &cms_ptr1->ldl;
0cb0b9
 		int partition_start_block;
0cb0b9
 
0cb0b9
 		disk_specific->format_type = 1;
0cb0b9
@@ -360,8 +359,7 @@ dasd_read (PedDisk* disk)
0cb0b9
 				* (long long) cms_ptr->disk_offset;
0cb0b9
 
0cb0b9
 		if (is_ldl)
0cb0b9
-		   if (strncmp(ldl_ptr->ldl_version,
0cb0b9
-			       vtoc_ebcdic_enc("2", str, 1), 1) >= 0)
0cb0b9
+		   if (ldl_ptr->ldl_version >= 0xf2)
0cb0b9
 		      end = (long long) arch_specific->real_sector_size
0cb0b9
 			    / (long long) disk->dev->sector_size
0cb0b9
 			    * (long long) ldl_ptr->formatted_blocks - 1;
0cb0b9
diff --git a/libparted/labels/vtoc.c b/libparted/labels/vtoc.c
0cb0b9
index fdfa94f..d47b791 100644
0cb0b9
--- a/libparted/labels/vtoc.c
0cb0b9
+++ b/libparted/labels/vtoc.c
0cb0b9
@@ -150,7 +150,7 @@ enum failure {
0cb0b9
 	unable_to_read
0cb0b9
 };
0cb0b9
 
0cb0b9
-static char buffer[89];
0cb0b9
+static char buffer[93];
0cb0b9
 
0cb0b9
 static void
0cb0b9
 vtoc_error (enum failure why, char const *s1, char const *s2)
0cb0b9
@@ -329,7 +329,7 @@ void
0cb0b9
 vtoc_volume_label_init (volume_label_t *vlabel)
0cb0b9
 {
0cb0b9
 	PDEBUG
0cb0b9
-	sprintf(buffer, "%88s", " ");
0cb0b9
+	sprintf(buffer, "%92s", " ");
0cb0b9
 	vtoc_ebcdic_enc(buffer, buffer, sizeof *vlabel);
0cb0b9
 	memcpy(vlabel, buffer, sizeof *vlabel);
0cb0b9
 }
0cb0b9
@@ -348,8 +348,8 @@ vtoc_read_volume_label (int f, unsigned long vlabel_start,
0cb0b9
 	typedef union vollabel vollabel_t;
0cb0b9
 
0cb0b9
 	union __attribute__((packed)) vollabel {
0cb0b9
+		/* cdl and ldl have the same data struct */
0cb0b9
 		volume_label_t cdl;
0cb0b9
-		ldl_volume_label_t ldl;
0cb0b9
 		cms_volume_label_t cms;
0cb0b9
 	};
0cb0b9
 
0cb0b9
@@ -373,9 +373,7 @@ vtoc_read_volume_label (int f, unsigned long vlabel_start,
0cb0b9
 	}
0cb0b9
 
0cb0b9
 	rc = read(f, vlabel, sizeof(volume_label_t));
0cb0b9
-	if (rc != sizeof(volume_label_t) &&
0cb0b9
-	/* For CDL we ask to read 88 bytes, but only get 84 */
0cb0b9
-            rc != sizeof(volume_label_t) - 4) {
0cb0b9
+	if (rc != sizeof(volume_label_t)) {
0cb0b9
 		vtoc_error(unable_to_read, "vtoc_read_volume_label",
0cb0b9
 			   _("Could not read volume label."));
0cb0b9
 		return 1;
0cb0b9
@@ -427,10 +425,8 @@ vtoc_write_volume_label (int f, unsigned long vlabel_start,
0cb0b9
 		vtoc_error(unable_to_seek, "vtoc_write_volume_label",
0cb0b9
 			   _("Could not write volume label."));
0cb0b9
 
0cb0b9
-	rc = write(f, vlabel, sizeof(volume_label_t) - 4);
0cb0b9
-	/* Subtract 4 to leave off the "fudge" variable when writing.
0cb0b9
-           We only write CDL volume labels, never LDL or CMS.  */
0cb0b9
-	if (rc != sizeof(volume_label_t) - 4)
0cb0b9
+	rc = write(f, vlabel, sizeof(volume_label_t));
0cb0b9
+	if (rc != sizeof(volume_label_t))
0cb0b9
 		vtoc_error(unable_to_write, "vtoc_write_volume_label",
0cb0b9
 			   _("Could not write volume label."));
0cb0b9
 
0cb0b9
@@ -632,7 +628,7 @@ vtoc_write_label (int f, unsigned long position,
0cb0b9
  * initializes a format4 label
0cb0b9
  */
0cb0b9
 void
0cb0b9
-vtoc_init_format4_label (format4_label_t *f4, unsigned int usable_partitions,
0cb0b9
+vtoc_init_format4_label (format4_label_t *f4,
0cb0b9
                          unsigned int compat_cylinders,
0cb0b9
                          unsigned int real_cylinders, unsigned int tracks,
0cb0b9
                          unsigned int blocks, unsigned int blksize,
0cb0b9
@@ -740,7 +736,7 @@ vtoc_init_format7_label (format7_label_t *f7)
0cb0b9
  * format1 or format 8 label, all but the field DS1FMTID
0cb0b9
  */
0cb0b9
 void
0cb0b9
-vtoc_init_format_1_8_label (char *volid, unsigned int blksize,
0cb0b9
+vtoc_init_format_1_8_label (unsigned int blksize,
0cb0b9
                             extent_t *part_extent, format1_label_t *f1)
0cb0b9
 {
0cb0b9
 	PDEBUG
0cb0b9
@@ -794,18 +790,18 @@ vtoc_init_format_1_8_label (char *volid, unsigned int blksize,
0cb0b9
 }
0cb0b9
 
0cb0b9
 void
0cb0b9
-vtoc_init_format1_label (char *volid, unsigned int blksize,
0cb0b9
+vtoc_init_format1_label (unsigned int blksize,
0cb0b9
                          extent_t *part_extent, format1_label_t *f1)
0cb0b9
 {
0cb0b9
-	vtoc_init_format_1_8_label(volid, blksize, part_extent, f1);
0cb0b9
+	vtoc_init_format_1_8_label(blksize, part_extent, f1);
0cb0b9
 	f1->DS1FMTID = 0xf1;
0cb0b9
 }
0cb0b9
 
0cb0b9
 void
0cb0b9
-vtoc_init_format8_label (char *volid, unsigned int blksize,
0cb0b9
+vtoc_init_format8_label (unsigned int blksize,
0cb0b9
                          extent_t *part_extent, format1_label_t *f8)
0cb0b9
 {
0cb0b9
-	vtoc_init_format_1_8_label(volid, blksize, part_extent, f8);
0cb0b9
+	vtoc_init_format_1_8_label(blksize, part_extent, f8);
0cb0b9
 	f8->DS1FMTID = 0xf8;
0cb0b9
 }
0cb0b9
 
0cb0b9
@@ -886,7 +882,7 @@ vtoc_reorganize_FMT5_extents (format5_label_t *f5)
0cb0b9
  * add a free space extent description to the VTOC FMT5 DSCB
0cb0b9
  */
0cb0b9
 void
0cb0b9
-vtoc_update_format5_label_add (format5_label_t *f5, int verbose, int cyl,
0cb0b9
+vtoc_update_format5_label_add (format5_label_t *f5, int verbose,
0cb0b9
                                int trk, u_int16_t a, u_int16_t b, u_int8_t c)
0cb0b9
 {
0cb0b9
 	PDEBUG
0cb0b9
@@ -974,7 +970,7 @@ vtoc_update_format5_label_add (format5_label_t *f5, int verbose, int cyl,
0cb0b9
  * remove a free space extent description from the VTOC FMT5 DSCB
0cb0b9
  */
0cb0b9
 void
0cb0b9
-vtoc_update_format5_label_del (format5_label_t *f5, int verbose, int cyl,
0cb0b9
+vtoc_update_format5_label_del (format5_label_t *f5, int verbose,
0cb0b9
                                int trk, u_int16_t a, u_int16_t b, u_int8_t c)
0cb0b9
 {
0cb0b9
 	PDEBUG
0cb0b9
@@ -1054,7 +1050,7 @@ vtoc_update_format5_label_del (format5_label_t *f5, int verbose, int cyl,
0cb0b9
 			ext->ft = (a - ext->t) % trk;
0cb0b9
 
0cb0b9
 			vtoc_update_format5_label_add(f5, verbose,
0cb0b9
-						      cyl, trk, x, y, z);
0cb0b9
+						      trk, x, y, z);
0cb0b9
 
0cb0b9
 			if (verbose)
0cb0b9
 				puts ("FMT5 del extent: 2 pieces");
0cb0b9
@@ -1322,9 +1318,9 @@ vtoc_set_freespace(format4_label_t *f4, format5_label_t *f5,
0cb0b9
 		z =  (u_int8_t) ((stop - start + 1) % trk);
0cb0b9
 
0cb0b9
 		if (ch == '+')
0cb0b9
-			vtoc_update_format5_label_add(f5, verbose, cyl, trk, x, y, z);
0cb0b9
+			vtoc_update_format5_label_add(f5, verbose, trk, x, y, z);
0cb0b9
 		else if (ch == '-')
0cb0b9
-			vtoc_update_format5_label_del(f5, verbose, cyl, trk, x, y, z);
0cb0b9
+			vtoc_update_format5_label_del(f5, verbose, trk, x, y, z);
0cb0b9
 		else
0cb0b9
 			puts ("BUG: syntax error in vtoc_set_freespace call");
0cb0b9
 
0cb0b9
-- 
0cb0b9
2.9.3
0cb0b9