X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=daemon%2Ffallocate.c;h=494743075854fd814555535592c2a3c3fd07d6be;hb=a34fadf900625f1f7359ecf3ca760820ffa20815;hp=f61c496ec2858487a4ae32126e1bd868f80abd0f;hpb=0dd6c8c8442d4ff588f6dac2efab24d3409b0dec;p=libguestfs.git diff --git a/daemon/fallocate.c b/daemon/fallocate.c index f61c496..4947430 100644 --- a/daemon/fallocate.c +++ b/daemon/fallocate.c @@ -23,32 +23,50 @@ #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; - - NEED_ROOT (-1); - ABS_PATH (path, return -1); + 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);