Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.sbin/sysinst Avoid using the global "pm" variable in uti...



details:   https://anonhg.NetBSD.org/src/rev/6232671f22da
branches:  trunk
changeset: 1006452:6232671f22da
user:      martin <martin%NetBSD.org@localhost>
date:      Wed Jan 15 19:37:41 2020 +0000

description:
Avoid using the global "pm" variable in utility functions - during
extended partitioning they may point to a different device.

diffstat:

 usr.sbin/sysinst/label.c |  34 +++++++++++++++++++---------------
 1 files changed, 19 insertions(+), 15 deletions(-)

diffs (108 lines):

diff -r db570663e77f -r 6232671f22da usr.sbin/sysinst/label.c
--- a/usr.sbin/sysinst/label.c  Wed Jan 15 19:36:30 2020 +0000
+++ b/usr.sbin/sysinst/label.c  Wed Jan 15 19:37:41 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: label.c,v 1.18 2020/01/09 13:22:30 martin Exp $        */
+/*     $NetBSD: label.c,v 1.19 2020/01/15 19:37:41 martin Exp $        */
 
 /*
  * Copyright 1997 Jonathan Stone
@@ -36,7 +36,7 @@
 
 #include <sys/cdefs.h>
 #if defined(LIBC_SCCS) && !defined(lint)
-__RCSID("$NetBSD: label.c,v 1.18 2020/01/09 13:22:30 martin Exp $");
+__RCSID("$NetBSD: label.c,v 1.19 2020/01/15 19:37:41 martin Exp $");
 #endif
 
 #include <sys/types.h>
@@ -1983,14 +1983,16 @@
                        i = min;
                        localsizemult = 1;
                } else {
-                       i = parse_disk_pos(isize, &localsizemult, pm->dlcylsize, NULL);
+                       i = parse_disk_pos(isize, &localsizemult, 
+                           parts->pscheme->get_cylinder_size(parts), NULL);
                        if (i < 0) {
                                errmsg = msg_string(MSG_invalid_sector_number);
                                continue;
                        }
                }
                /* round to cylinder size if localsizemult != 1 */
-               i = NUMSEC(i, localsizemult, pm->dlcylsize);
+               int cylsize = parts->pscheme->get_cylinder_size(parts);
+               i = NUMSEC(i, localsizemult, cylsize);
                /* Adjust to start of slice if needed */
                if ((i < min && (min - i) < localsizemult) ||
                    (i > min && (i - min) < localsizemult)) {
@@ -2014,10 +2016,11 @@
        char dsize[24], isize[24], max_size[24], maxpartc, valid_parts[4],
            *label_msg, *prompt, *head, *hint, *tail;
        const char *errmsg = NULL;
-       daddr_t i, partend, localsizemult, max, max_r, dflt_r;
+       daddr_t i, partend, diskend, localsizemult, max, max_r, dflt_r;
        struct disk_part_info info;
        part_id partn;
 
+       diskend = parts->disk_start + parts->disk_size;
        max = parts->pscheme->max_free_space_at(parts, partstart);
 
        /* We need to keep both the unrounded and rounded (_r) max and dflt */
@@ -2092,7 +2095,7 @@
                        max_r = max;
                } else {
                        i = parse_disk_pos(isize, &localsizemult,
-                           pm->dlcylsize, NULL);
+                           parts->pscheme->get_cylinder_size(parts), NULL);
                        if (localsizemult != sizemult)
                                max_r = max;
                }
@@ -2107,18 +2110,19 @@
                 * partend is aligned to a cylinder if localsizemult
                 * is not 1 sector
                 */
+               int cylsize = parts->pscheme->get_cylinder_size(parts);
                partend = NUMSEC((partstart + i*localsizemult) / localsizemult,
-                   localsizemult, pm->dlcylsize);
+                   localsizemult, cylsize);
                /* Align to end-of-disk or end-of-slice if close enough */
-               if (partend > (pm->dlsize - sizemult)
-                   && partend < (pm->dlsize + sizemult))
-                       partend = pm->dlsize;
+               if (partend > (diskend - sizemult)
+                   && partend < (diskend + sizemult))
+                       partend = diskend;
                if (partend > (partstart + max - sizemult)
                    && partend < (partstart + max + sizemult))
                        partend = partstart + max;
                /* sanity checks */
-               if (partend > (partstart + pm->dlsize)) {
-                       partend = pm->dlsize;
+               if (partend > diskend) {
+                       partend = diskend;
                        errmsg = msg_string(MSG_endoutsidedisk);
                        continue;
                }
@@ -2161,19 +2165,19 @@
                if (*cp == 'G' || *cp == 'g') {
                        if (mult_found)
                                return -1;
-                       *localsizemult = GIG / pm->sectorsize;
+                       *localsizemult = GIG / 512;
                        goto next;
                }
                if (*cp == 'M' || *cp == 'm') {
                        if (mult_found)
                                return -1;
-                       *localsizemult = MEG / pm->sectorsize;
+                       *localsizemult = MEG / 512;
                        goto next;
                }
                if (*cp == 'c' || *cp == 'C') {
                        if (mult_found)
                                return -1;
-                       *localsizemult = pm->dlcylsize;
+                       *localsizemult = cyl_size;
                        goto next;
                }
                if (*cp == 's' || *cp == 'S') {



Home | Main Index | Thread Index | Old Index