PERFORCE change 30669 for review

Robert Watson rwatson at FreeBSD.org
Tue May 6 08:59:33 PDT 2003


http://perforce.freebsd.org/chv.cgi?CH=30669

Change 30669 by rwatson at rwatson_tislabs on 2003/05/06 08:58:38

	Revert local big boot block changes; no longer required to boot
	UFS2.

Affected files ...

.. //depot/projects/trustedbsd/mac/usr.sbin/sysinstall/disks.c#14 edit

Differences ...

==== //depot/projects/trustedbsd/mac/usr.sbin/sysinstall/disks.c#14 (text+ko) ====

@@ -832,12 +832,6 @@
 diskPartitionWrite(dialogMenuItem *self)
 {
     Device **devs;
-#ifdef __i386__
-    size_t boot1size, boot2size;
-    Chunk *slice;
-    PartInfo *pi;
-    int bigbb, nonbigbb;
-#endif
     int i;
 
     if (!variable_cmp(DISK_PARTITIONED, "written"))
@@ -860,60 +854,7 @@
 	if (!devs[i]->enabled)
 	    continue;
 
-#ifdef __i386__
-	/*
-	 * For i386, use "big" boot blocks if the first partition in
-	 * every FreeBSD slice is UFS2 and therefore has 64KB of space
-	 * available rather than UFS1's mere 8KB.  We could be more
-	 * intelligent here and move forward uncreated non-UFS2
-	 * partitions to accomodate, and check that already-created
-	 * slice aren't actually created with an offset from the
-	 * beginning of their slice in the first place.
-	 */
-	nonbigbb = bigbb = 0;
-	for (slice = d->chunks->part; slice; slice = slice->next) {
-	    if (slice->type != freebsd)
-		continue;
-	    if (slice->part->type == unused)
-		continue;	/* just an empty FreeBSD slice */
-	    if (slice->part->subtype != FS_BSDFFS) {
-		nonbigbb = 1;	/* assume non-UFS2 means non-64KB */
-		continue;
-	    }
-	    pi = slice->part->private_data;
-	    if (pi == NULL || pi->newfs_type != NEWFS_UFS ||
-	      !pi->newfs_data.newfs_ufs.ufs2) {
-		nonbigbb = 1;	/* assume non-UFS2 means non-64KB */
-		continue;
-	    }
-	    bigbb = 1;
-	}
-	if (bigbb && nonbigbb)
-	    msgConfirm("Warning: Some FreeBSD slices on this disk preclude the "
-		       "installation of UFS2-capable boot blocks.  You will need "
-		       "to manually use disklabel(8) on these slices to install "
-		       "the correct boot blocks.");
-	/*
-	 * Boot blocks may switch back and forth if the installer is
-	 * writing out labels on multiple disks.
-	 */
-	free(boot1);
-	free(boot2);
-	if (!nonbigbb && bigbb) {
-	    boot1 = bootalloc("boot1", &boot1size);
-	    boot2 = bootalloc("boot2", &boot2size);
-	    Set_Boot_Block_Size(d, 0x10000);
-	    if (Set_Large_Boot_Blocks(d, boot1, boot1size, boot2,
-	      boot2size)) {
-	        msgConfirm("ERROR: Unable to use boot blocks on disk %s!", d->name);
-	        return DITEM_FAILURE;
-	    }
-	} else {
-	    boot1 = bootalloc("boot1", &boot1size);
-	    boot2 = bootalloc("boot2-ufs1", &boot2size);
-	    Set_Boot_Blocks(d, boot1, boot2);
-	}
-#elif defined(__ia64__)
+#if defined(__i386__) || defined(__ia64__)
 	if (!boot1) boot1 = bootalloc("boot1", NULL);
 	if (!boot2) boot2 = bootalloc("boot2", NULL);
 	Set_Boot_Blocks(d, boot1, boot2);


More information about the p4-projects mailing list