5aba6458f6
- Use PLIST_FILES instead of pkg-plist.
72 lines
1.9 KiB
C
72 lines
1.9 KiB
C
--- ufs_copy.c.orig 2006-09-21 06:28:09 UTC
|
|
+++ ufs_copy.c
|
|
@@ -111,9 +111,11 @@ int
|
|
main(int argc, char *argv[])
|
|
{
|
|
struct fstab *fs;
|
|
- int ch, eval=0;
|
|
+ int ch, eval=0, md;
|
|
char *snapshot = NULL;
|
|
- char *src, *dst;
|
|
+ char *src, *dst, *snap = NULL;
|
|
+ char mddev[256];
|
|
+ FILE *readp;
|
|
|
|
#ifdef USEMMAP
|
|
while ((ch = getopt(argc, argv, "aBb:ceMms:v")) != -1)
|
|
@@ -174,6 +176,21 @@ main(int argc, char *argv[])
|
|
eval = system(buf);
|
|
if (eval)
|
|
errx(eval, "mksnap_ffs failed");
|
|
+
|
|
+ snprintf(buf, sizeof(buf),
|
|
+ "/sbin/mdconfig -a -n -t vnode -f %s", src);
|
|
+ fprintf(stderr, "%s\n", buf);
|
|
+ readp = popen(buf, "r");
|
|
+ if (readp == NULL)
|
|
+ errx(eval, "mdconfig failed");
|
|
+ eval = fscanf(readp, "%d", &md);
|
|
+ if (eval != 1)
|
|
+ errx(eval, "mdconfig failed");
|
|
+ pclose(readp);
|
|
+ snprintf(mddev, sizeof(mddev), "/dev/md%d", md);
|
|
+ snap = src;
|
|
+ src = mddev;
|
|
+ fprintf(stderr, "attached %s as memory disk %s\n", snap, mddev);
|
|
}
|
|
|
|
if ((fs = getfsfile(src)) == NULL) {
|
|
@@ -188,9 +205,19 @@ main(int argc, char *argv[])
|
|
}
|
|
|
|
if (snapshot) {
|
|
- fprintf(stderr, "removing snapshot file %s ... ", src);
|
|
+ char buf[1024];
|
|
+
|
|
+ snprintf(buf, sizeof(buf),
|
|
+ "/sbin/mdconfig -d -u %d", md);
|
|
+ fprintf(stderr, "%s\n", buf);
|
|
+ eval = system(buf);
|
|
+ if (eval)
|
|
+ errx(eval, "mdconfig failed");
|
|
+ fprintf(stderr, "detached memory disk %s\n", mddev);
|
|
+
|
|
+ fprintf(stderr, "removing snapshot file %s ... ", snap);
|
|
fflush(stderr);
|
|
- if (unlink(src) == 0)
|
|
+ if (unlink(snap) == 0)
|
|
fprintf(stderr, "done\n");
|
|
else
|
|
fprintf(stderr, "failed\n");
|
|
@@ -262,6 +289,11 @@ copy_ufs(const char *src_path, const char *dst_path)
|
|
}
|
|
}
|
|
bcopy(&src, &dst, sizeof(dst));
|
|
+#if (defined(__FreeBSD_version) && __FreeBSD_version >= 1300100)
|
|
+ dst.d_si = NULL;
|
|
+#else
|
|
+ dst.d_sbcsum = NULL;
|
|
+#endif
|
|
dst.d_name = dst_path;
|
|
dst.d_fd = open(dst_path, O_CREAT | O_WRONLY, S_IRUSR | S_IWUSR );
|
|
if (dst.d_fd < 0) {
|