diff options
author | Todd C. Miller <millert@cvs.openbsd.org> | 1999-03-18 01:59:21 +0000 |
---|---|---|
committer | Todd C. Miller <millert@cvs.openbsd.org> | 1999-03-18 01:59:21 +0000 |
commit | 0833e9018abb7ea78e7458b24ba97c795bb9f328 (patch) | |
tree | 517f39284c4191f8d8ce2d417bbdcad0cc07d43b | |
parent | 7bc96a0789e0b95bbb398c07bc15cb8c7d0d51b9 (diff) |
Sort entries by mountpoint, not partition number when writing fstab via
the -F option. We do this to make sure /var occurs before /var/mail,
/usr before /usr/local, etc...
-rw-r--r-- | sbin/disklabel/editor.c | 49 |
1 files changed, 41 insertions, 8 deletions
diff --git a/sbin/disklabel/editor.c b/sbin/disklabel/editor.c index a71eb903fbd..b7967c54d05 100644 --- a/sbin/disklabel/editor.c +++ b/sbin/disklabel/editor.c @@ -1,4 +1,4 @@ -/* $OpenBSD: editor.c,v 1.51 1999/03/16 21:26:04 millert Exp $ */ +/* $OpenBSD: editor.c,v 1.52 1999/03/18 01:59:20 millert Exp $ */ /* * Copyright (c) 1997-1999 Todd C. Miller <Todd.Miller@courtesan.com> @@ -28,7 +28,7 @@ */ #ifndef lint -static char rcsid[] = "$OpenBSD: editor.c,v 1.51 1999/03/16 21:26:04 millert Exp $"; +static char rcsid[] = "$OpenBSD: editor.c,v 1.52 1999/03/18 01:59:20 millert Exp $"; #endif /* not lint */ #include <sys/types.h> @@ -63,6 +63,12 @@ struct diskchunk { u_int32_t stop; }; +/* used when sorting mountpoints in mpsave() */ +struct mountinfo { + char *mountpoint; + int partno; +}; + void edit_parms __P((struct disklabel *, u_int32_t *)); int editor __P((struct disklabel *, int, char *, char *)); void editor_add __P((struct disklabel *, char **, u_int32_t *, char *)); @@ -85,6 +91,7 @@ void find_bounds __P((struct disklabel *)); void set_bounds __P((struct disklabel *, u_int32_t *)); struct diskchunk *free_chunks __P((struct disklabel *)); char ** mpcopy __P((char **, char **)); +int micmp __P((const void *, const void *)); int mpequal __P((char **, char **)); int mpsave __P((struct disklabel *, char **, char *, char *)); int get_bsize __P((struct disklabel *, int)); @@ -1928,16 +1935,21 @@ mpsave(lp, mp, cdev, fstabfile) { int i, mpset; char bdev[MAXPATHLEN], *p; + struct mountinfo mi[MAXPARTITIONS]; FILE *fp; + memset(&mi, 0, sizeof(mi)); + for (i = 0, mpset = 0; i < MAXPARTITIONS; i++) { if (mp[i] != NULL) { + mi[i].mountpoint = mp[i]; + mi[i].partno = i; mpset = 1; - break; } } + /* Exit if there is nothing to do... */ if (!mpset) - return(1); + return(0); /* Convert cdev to bdev */ if (strncmp(_PATH_DEV, cdev, sizeof(_PATH_DEV) - 1) == 0 && @@ -1953,13 +1965,15 @@ mpsave(lp, mp, cdev, fstabfile) } bdev[strlen(bdev) - 1] = '\0'; + /* Sort mountpoints so we don't try to mount /usr/local before /usr */ + qsort((void *)mi, MAXPARTITIONS, sizeof(struct mountinfo), micmp); + if ((fp = fopen(fstabfile, "w")) == NULL) return(1); - for (i = 0; i < MAXPARTITIONS; i++) { - if (mp[i] == NULL) - continue; - fprintf(fp, "%s%c %s %s rw 1 %d\n", bdev, 'a' + i, mp[i], + for (i = 0; i < MAXPARTITIONS && mi[i].mountpoint != NULL; i++) { + fprintf(fp, "%s%c %s %s rw 1 %d\n", bdev, 'a' + mi[i].partno, + mi[i].mountpoint, fstypesnames[lp->d_partitions[i].p_fstype], i == 0 ? 1 : 2); } @@ -2238,3 +2252,22 @@ get_mp(lp, mp, partno) } return(0); } + +int +micmp(a1, a2) + const void *a1; + const void *a2; +{ + struct mountinfo *mi1 = (struct mountinfo *)a1; + struct mountinfo *mi2 = (struct mountinfo *)a2; + + /* We want all the NULLs at the end... */ + if (mi1->mountpoint == NULL && mi2->mountpoint == NULL) + return(0); + else if (mi1->mountpoint == NULL) + return(1); + else if (mi2->mountpoint == NULL) + return(-1); + else + return(strcmp(mi1->mountpoint, mi2->mountpoint)); +} |