X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=daemon%2Ffallocate.c;h=0c948ffff6ebc3fa5d884f4caf5aa4ea2de6b3cd;hp=47e84c6970b5162e51c1c82357ccf569b6331816;hb=6b500f1b8e1ac8d28c485a5591c2833b18cc86e2;hpb=0e6e32025885286e2de39efca34ced2aaf26b3a3;ds=sidebyside diff --git a/daemon/fallocate.c b/daemon/fallocate.c index 47e84c6..0c948ff 100644 --- a/daemon/fallocate.c +++ b/daemon/fallocate.c @@ -23,32 +23,61 @@ #include #include #include +#include #include "daemon.h" #include "actions.h" int -do_fallocate (char *path, int len) +do_fallocate (const char *path, int len) { - int fd, r; + if (len < 0) { + reply_with_error ("length < 0"); + return -1; + } + + return do_fallocate64 (path, len); +} - NEED_ROOT (-1); - ABS_PATH (path, -1); +int +do_fallocate64 (const char *path, int64_t len) +{ + int fd; CHROOT_IN; fd = open (path, O_WRONLY | O_CREAT | O_TRUNC | O_NOCTTY, 0666); CHROOT_OUT; if (fd == -1) { - reply_with_perror (path); + reply_with_perror ("open: %s", path); return -1; } - r = posix_fallocate (fd, 0, len); - if (r == -1) { - reply_with_perror ("posix_fallocate: %s", path); +#ifdef HAVE_POSIX_FALLOCATE + int err = posix_fallocate (fd, 0, len); + if (err != 0) { + errno = err; + reply_with_perror ("%s", path); close (fd); return -1; } +#else + ssize_t r; + char buf[BUFSIZ]; + const size_t len_sz = (size_t) len; + size_t n; + + memset (buf, 0, BUFSIZ); + n = 0; + while (n < len_sz) { + r = write (fd, buf, len_sz - n < BUFSIZ ? len_sz - n : BUFSIZ); + if (r == -1) { + reply_with_perror ("write: %s", path); + close (fd); + return -1; + } + n += r; + } +#endif if (close (fd) == -1) { reply_with_perror ("close: %s", path);