Source-Changes-HG archive

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

[src/trunk]: src/usr.sbin/sysinst Don't force mounting of newfs'd partitions.



details:   https://anonhg.NetBSD.org/src/rev/8de87d7ade74
branches:  trunk
changeset: 1000210:8de87d7ade74
user:      martin <martin%NetBSD.org@localhost>
date:      Sun Jul 14 11:26:18 2019 +0000

description:
Don't force mounting of newfs'd partitions.
Provide MD hooks for setups where we do not need any bootblocks.

diffstat:

 usr.sbin/sysinst/bsddisklabel.c |  64 ++++++++++++++++++++++------------------
 1 files changed, 35 insertions(+), 29 deletions(-)

diffs (109 lines):

diff -r e8718c61bd6a -r 8de87d7ade74 usr.sbin/sysinst/bsddisklabel.c
--- a/usr.sbin/sysinst/bsddisklabel.c   Sun Jul 14 11:25:10 2019 +0000
+++ b/usr.sbin/sysinst/bsddisklabel.c   Sun Jul 14 11:26:18 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: bsddisklabel.c,v 1.19 2019/07/12 18:28:08 martin Exp $ */
+/*     $NetBSD: bsddisklabel.c,v 1.20 2019/07/14 11:26:18 martin Exp $ */
 
 /*
  * Copyright 1997 Piermont Information Systems Inc.
@@ -1375,8 +1375,6 @@
                        infos[i].last_mounted = want->mount;
                        infos[i].fs_type = want->fs_type;
                        infos[i].fs_sub_type = want->fs_version;
-                       if (want->fs_type != FS_UNUSED && want->type != PT_swap)
-                               want->instflags |= PUIINST_NEWFS|PUIINST_MOUNT;
                        new_part_id = ps->pscheme->add_partition(ps,
                            &infos[i], NULL);
                        if (new_part_id == NO_PART)
@@ -1420,8 +1418,11 @@
                infos[i].last_mounted = want->mount;
                infos[i].fs_type = want->fs_type;
                infos[i].fs_sub_type = want->fs_version;
-               if (want->fs_type != FS_UNUSED && want->type != PT_swap)
-                       want->instflags |= PUIINST_NEWFS|PUIINST_MOUNT;
+               if (want->fs_type != FS_UNUSED && want->type != PT_swap) {
+                       want->instflags |= PUIINST_NEWFS;
+                       if (want->mount[0] != 0)
+                               want->instflags |= PUIINST_MOUNT;
+               }
                new_part_id = wanted->parts->pscheme->add_partition(
                    wanted->parts, &infos[i], NULL);
                if (new_part_id == NO_PART)
@@ -1458,9 +1459,6 @@
                infos[i].last_mounted = want->mount;
                infos[i].fs_type = want->fs_type;
                infos[i].fs_sub_type = want->fs_version;
-               if (want->fs_type != FS_UNUSED &&
-                   want->type != PT_swap)
-                       want->instflags |= PUIINST_NEWFS|PUIINST_MOUNT;
 
                if (wanted->parts->pscheme->add_outer_partition
                    != NULL)
@@ -1663,6 +1661,10 @@
        return true;
 }
 
+#ifndef MD_NEED_BOOTBLOCK
+#define MD_NEED_BOOTBLOCK(A)   true
+#endif
+
 /*
  * check that there is at least a / somewhere.
  */
@@ -1678,30 +1680,34 @@
 #endif
 
 #ifdef HAVE_BOOTXX_xFS
-       /* check if we have boot code for the root partition type */
-       bootxx = bootxx_name(install);
-       if (bootxx != NULL) {
-               rv = access(bootxx, R_OK);
-               free(bootxx);
-       } else
-               rv = -1;
-       if (rv != 0) {
-               hit_enter_to_continue(NULL, MSG_No_Bootcode);
-               return false;
+       if (MD_NEED_BOOTBLOCK(install)) {
+               /* check if we have boot code for the root partition type */
+               bootxx = bootxx_name(install);
+               if (bootxx != NULL) {
+                       rv = access(bootxx, R_OK);
+                       free(bootxx);
+               } else
+                       rv = -1;
+               if (rv != 0) {
+                       hit_enter_to_continue(NULL, MSG_No_Bootcode);
+                       return false;
+               }
        }
 #endif
 #ifndef HAVE_UFS2_BOOT
-       for (i = 0; i < install->num; i++) {
-               if (install->infos[i].type != PT_root)
-                       continue;
-               if (strcmp(install->infos[i].mount, "/") != 0)
-                       continue;
-               if (install->infos[i].fs_type != FS_BSDFFS)
-                       continue;
-               if (install->infos[i].fs_version != 2)
-                       continue;
-               hit_enter_to_continue(NULL, MSG_cannot_ufs2_root);
-               return false;
+       if (MD_NEED_BOOTBLOCK(install)) {
+               for (i = 0; i < install->num; i++) {
+                       if (install->infos[i].type != PT_root)
+                               continue;
+                       if (strcmp(install->infos[i].mount, "/") != 0)
+                               continue;
+                       if (install->infos[i].fs_type != FS_BSDFFS)
+                               continue;
+                       if (install->infos[i].fs_version != 2)
+                               continue;
+                       hit_enter_to_continue(NULL, MSG_cannot_ufs2_root);
+                       return false;
+               }
        }
 #endif
 



Home | Main Index | Thread Index | Old Index