Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sbin/resize_ffs Use getfsspecname and getrawdiskname so we c...
details: https://anonhg.NetBSD.org/src/rev/26f6cb998af7
branches: trunk
changeset: 1010377:26f6cb998af7
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Sun May 24 14:41:26 2020 +0000
description:
Use getfsspecname and getrawdiskname so we can resize by NAME= label.
diffstat:
sbin/resize_ffs/Makefile | 5 ++++-
sbin/resize_ffs/resize_ffs.c | 19 ++++++++++++++-----
2 files changed, 18 insertions(+), 6 deletions(-)
diffs (87 lines):
diff -r 88c932e1fe87 -r 26f6cb998af7 sbin/resize_ffs/Makefile
--- a/sbin/resize_ffs/Makefile Sun May 24 14:40:21 2020 +0000
+++ b/sbin/resize_ffs/Makefile Sun May 24 14:41:26 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.5 2015/04/06 22:44:04 jmcneill Exp $
+# $NetBSD: Makefile,v 1.6 2020/05/24 14:41:26 jmcneill Exp $
.include <bsd.own.mk>
@@ -8,6 +8,9 @@
CPPFLAGS+=-I${NETBSDSRCDIR}/sbin/fsck
+DPADD+= ${LIBUTIL}
+LDADD+= -lutil
+
.PATH: ${NETBSDSRCDIR}/sys/ufs/ffs
.PATH: ${NETBSDSRCDIR}/sbin/fsck
diff -r 88c932e1fe87 -r 26f6cb998af7 sbin/resize_ffs/resize_ffs.c
--- a/sbin/resize_ffs/resize_ffs.c Sun May 24 14:40:21 2020 +0000
+++ b/sbin/resize_ffs/resize_ffs.c Sun May 24 14:41:26 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: resize_ffs.c,v 1.54 2019/04/21 11:45:08 maya Exp $ */
+/* $NetBSD: resize_ffs.c,v 1.55 2020/05/24 14:41:26 jmcneill Exp $ */
/* From sources sent on February 17, 2003 */
/*-
* As its sole author, I explicitly place this code in the public
@@ -36,7 +36,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: resize_ffs.c,v 1.54 2019/04/21 11:45:08 maya Exp $");
+__RCSID("$NetBSD: resize_ffs.c,v 1.55 2020/05/24 14:41:26 jmcneill Exp $");
#include <sys/disk.h>
#include <sys/disklabel.h>
@@ -58,6 +58,7 @@
#include <stdlib.h>
#include <strings.h>
#include <unistd.h>
+#include <util.h>
#include "progress.h"
@@ -68,7 +69,7 @@
static int fd;
/* disk device or file path */
-char *special;
+const char *special;
/* must we break up big I/O operations - see checksmallio() */
static int smallio;
@@ -2110,7 +2111,7 @@
}
static off_t
-get_dev_size(char *dev_name)
+get_dev_size(const char *dev_name)
{
struct dkwedge_info dkw;
struct partition *pp;
@@ -2145,6 +2146,9 @@
int ExpertFlag;
int SFlag;
size_t i;
+ char specname[MAXPATHLEN];
+ char rawname[MAXPATHLEN];
+ const char *raw;
char reply[5];
@@ -2187,7 +2191,12 @@
usage();
}
- special = *argv;
+ special = getfsspecname(specname, sizeof(specname), argv[0]);
+ if (special == NULL)
+ err(EXIT_FAILURE, "%s: %s", argv[0], specname);
+ raw = getdiskrawname(rawname, sizeof(rawname), special);
+ if (raw != NULL)
+ special = raw;
if (ExpertFlag == 0 && CheckOnlyFlag == 0) {
printf("It's required to manually run fsck on file system "
Home |
Main Index |
Thread Index |
Old Index