X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=daemon%2Ffallocate.c;h=1800292d0ba61290e2f70c51227ba1ab75d8d5eb;hp=20a75e67f5f3218d1ee108c9ef082e75afc7da73;hb=73c587ff0f2f8f76af39b16dafb0949be7bf0883;hpb=9b0ab841856ed7168171f6dceaede88dc9fbb9b2 diff --git a/daemon/fallocate.c b/daemon/fallocate.c index 20a75e6..1800292 100644 --- a/daemon/fallocate.c +++ b/daemon/fallocate.c @@ -30,7 +30,7 @@ int do_fallocate (const char *path, int len) { - int fd, r; + int fd; CHROOT_IN; fd = open (path, O_WRONLY | O_CREAT | O_TRUNC | O_NOCTTY, 0666); @@ -40,12 +40,33 @@ do_fallocate (const char *path, int len) return -1; } +#ifdef HAVE_POSIX_FALLOCATE + int r; + r = posix_fallocate (fd, 0, len); if (r == -1) { reply_with_perror ("posix_fallocate: %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);