X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=daemon%2Fzero.c;h=df4ebd643e19fdf6dc42c06a834f5d7e3ba71d71;hp=4d06505260379d8adcecb6d31f2319c5169e0ef7;hb=87e49e7e87e570537f04e34178c9c6d2b876c16c;hpb=bba019781a0df3744ccbfe9e580786b66dc9afa9 diff --git a/daemon/zero.c b/daemon/zero.c index 4d06505..df4ebd6 100644 --- a/daemon/zero.c +++ b/daemon/zero.c @@ -20,6 +20,7 @@ #include #include +#include #include #include #include @@ -55,3 +56,39 @@ do_zero (const char *device) return 0; } + +int +do_zero_device (const char *device) +{ + int64_t size = do_blockdev_getsize64 (device); + if (size == -1) + return -1; + + int fd = open (device, O_WRONLY); + if (fd == -1) { + reply_with_perror ("%s", device); + return -1; + } + + char buf[1024*1024]; + memset (buf, 0, sizeof buf); + + while (size > 0) { + size_t n = (size_t) size > sizeof buf ? sizeof buf : (size_t) size; + ssize_t r = write (fd, buf, n); + if (r == -1) { + reply_with_perror ("write: %s (with %" PRId64 " bytes left to write)", + device, size); + close (fd); + return -1; + } + size -= r; + } + + if (close (fd) == -1) { + reply_with_perror ("close: %s", device); + return -1; + } + + return 0; +}