summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorphk <phk@FreeBSD.org>1994-11-19 23:59:03 +0000
committerphk <phk@FreeBSD.org>1994-11-19 23:59:03 +0000
commitf7ebe8faec3faacaeb35ea728602c304e1c97eed (patch)
treeb0f3ff9a81613fcb4fad12bfcd57043c150f2be0
parentb486198d8fad8d3e429d0e11dfb01675581ef29d (diff)
downloadFreeBSD-src-f7ebe8faec3faacaeb35ea728602c304e1c97eed.zip
FreeBSD-src-f7ebe8faec3faacaeb35ea728602c304e1c97eed.tar.gz
Changes to match Pauls code. Had to "globalize" the variables for the
mountpoints.
-rw-r--r--sbin/sysinstall/stage1.c3
-rw-r--r--sbin/sysinstall/stage2.c69
-rw-r--r--sbin/sysinstall/sysinstall.h2
3 files changed, 37 insertions, 37 deletions
diff --git a/sbin/sysinstall/stage1.c b/sbin/sysinstall/stage1.c
index e268d5a..b094827 100644
--- a/sbin/sysinstall/stage1.c
+++ b/sbin/sysinstall/stage1.c
@@ -54,11 +54,9 @@ char selection[30];
char *device_names[] = {"wd", "sd", "cd", "mcd", 0};
struct devconf *device_list[MAX_NO_DEVICES];
struct disk disk_list[MAX_NO_DEVICES];
-struct fstab *mounts[MAX_NO_MOUNTS];
int no_devices;
int no_disks;
-int no_mounts;
int
alloc_memory()
@@ -247,4 +245,5 @@ stage1()
mounts[no_mounts++] = &disk_list[i].mounts[j];
}
}
+ return 0;
}
diff --git a/sbin/sysinstall/stage2.c b/sbin/sysinstall/stage2.c
index b9dac93..881155f 100644
--- a/sbin/sysinstall/stage2.c
+++ b/sbin/sysinstall/stage2.c
@@ -6,7 +6,7 @@
* this stuff is worth it, you can buy me a beer in return. Poul-Henning Kamp
* ----------------------------------------------------------------------------
*
- * $Id: stage2.c,v 1.16 1994/11/18 11:30:04 phk Exp $
+ * $Id: stage2.c,v 1.17 1994/11/19 00:17:55 ache Exp $
*
*/
@@ -16,7 +16,7 @@
#include <stdarg.h>
#include <string.h>
#include <unistd.h>
-
+#include <fstab.h>
#include <fcntl.h>
#include <dialog.h>
#include <errno.h>
@@ -35,45 +35,47 @@ stage2()
char dbuf[90];
FILE *f1;
int i, j;
+ int fidx[MAX_NO_MOUNTS];
+ struct fstab *fp;
if (dialog_yesno("Last Chance!", "Are you sure you want to proceed with the installation?\nLast chance before wiping your hard disk!", -1, -1))
exit(0);
/* Sort in mountpoint order */
- memset(Fsize, 0, sizeof Fsize);
-
- for (i = 1; Fname[i]; i++)
- Fsize[i] = i;
- Fsize[i] = 0;
+ memset(fidx, 0, sizeof fidx);
for (j = 1; j;)
- for (j = 0, i = 1; Fsize[i+1]; i++) {
- if (strcmp(Fmount[Fsize[i]], Fmount[Fsize[i+1]]) > 0) {
- j = Fsize[i];
- Fsize[i] = Fsize[i+1];
- Fsize[i + 1] = j;
+ for (j = 0, i = 0; i < no_mounts; i++) {
+ if (strcmp(mounts[i]->fs_file, mounts[i+1]->fs_file) > 0) {
+ fp = mounts[i];
+ mounts[i] = mounts[i+1];
+ mounts[i+1] = fp;
+ j++;
}
}
- for (j = 1; Fsize[j]; j++) {
- if (strcmp(Ftype[Fsize[j]], "ufs"))
+ for (j = 0; j < no_mounts; j++) {
+ if (strcmp(mounts[j]->fs_vfstype, "ufs"))
continue;
- p = Fname[Fsize[j]];
+ if (!strcmp(mounts[j]->fs_mntops, "YES"))
+ continue;
+ p = mounts[j]->fs_spec;
TellEm("newfs /dev/r%s",p);
strcpy(pbuf, "/dev/r");
strcat(pbuf, p);
i = exec(0, "/stand/newfs", "/stand/newfs", "-n", "1", pbuf, 0);
if (i)
Fatal("Exec(/stand/newfs) failed, code=%d.",i);
- }
+ }
- for (j = 1; Fsize[j]; j++) {
- if (strcmp(Ftype[Fsize[j]], "ufs"))
- continue;
+ for (j = 0; fidx[j]; j++) {
strcpy(dbuf, "/mnt");
- p = Fname[Fsize[j]];
- q = Fmount[Fsize[j]];
+ p = mounts[j]->fs_spec;
+ q = mounts[j]->fs_file;
if (strcmp(q, "/"))
strcat(dbuf, q);
+ Mkdir(dbuf);
+ if (strcmp(mounts[j]->fs_vfstype, "ufs"))
+ continue;
MountUfs(p, dbuf, 1, 0);
}
@@ -84,9 +86,6 @@ stage2()
TellEm("unzipping /stand/sysinstall onto hard disk");
exec(4, "/stand/gzip", "zcat", 0 );
-/*
- CopyFile("/stand/sysinstall","/mnt/stand/sysinstall");
-*/
Link("/mnt/stand/sysinstall","/mnt/stand/cpio");
Link("/mnt/stand/sysinstall","/mnt/stand/bad144");
Link("/mnt/stand/sysinstall","/mnt/stand/gunzip");
@@ -108,12 +107,15 @@ stage2()
Fatal("Couldn't open /mnt/etc/fstab for writing.");
TellEm("Writing filesystems");
- for (j = 1; Fsize[j]; j++) {
- if (!strcmp(Ftype[Fsize[j]],"swap"))
- fprintf(f1, "/dev/%s\t\tnone\tswap sw 0 0\n", Fname[Fsize[j]]);
+ for (j = 0; j < no_mounts; j++) {
+ if (!strcmp(mounts[j]->fs_vfstype,"swap"))
+ fprintf(f1, "/dev/%s\t\tnone\tswap sw 0 0\n",
+ mounts[j]->fs_spec);
else
fprintf(f1, "/dev/%s\t\t%s\t%s rw 1 1\n",
- Fname[Fsize[j]], Fmount[Fsize[j]], Ftype[Fsize[j]]);
+ mounts[j]->fs_spec,
+ mounts[j]->fs_file,
+ mounts[j]->fs_vfstype);
}
TellEm("Writing procfs");
fprintf(f1,"proc\t\t/proc\tprocfs rw 0 0\n");
@@ -125,15 +127,12 @@ stage2()
close(i);
TellEm("Unmount disks");
- for (j = 1; Fsize[j]; j++)
- continue;
-
- for (j--; j > 0; j--) {
- if (!strcmp(Ftype[Fsize[j]],"swap"))
+ for (j = no_mounts-1; j >= 0; j--) {
+ if (strcmp(mounts[j]->fs_vfstype,"ufs"))
continue;
strcpy(dbuf,"/mnt");
- if (strcmp(Fmount[Fsize[j]],"/"))
- strcat(dbuf, Fmount[Fsize[j]]);
+ if (strcmp(mounts[j]->fs_file,"/"))
+ strcat(dbuf, mounts[j]->fs_file);
TellEm("unmount %s", dbuf);
/* Don't do error-check, we reboot anyway... */
unmount(dbuf, 0);
diff --git a/sbin/sysinstall/sysinstall.h b/sbin/sysinstall/sysinstall.h
index 370cc02..657d153 100644
--- a/sbin/sysinstall/sysinstall.h
+++ b/sbin/sysinstall/sysinstall.h
@@ -81,6 +81,8 @@ EXTERN int dialog_active;
EXTERN char selection[];
EXTERN int debug_fd;
+EXTERN int no_mounts;
+EXTERN struct fstab *mounts[MAX_NO_MOUNTS];
extern unsigned char *scratch;
extern unsigned char *errmsg;
OpenPOWER on IntegriCloud