X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=daemon%2Fzero.c;h=df4ebd643e19fdf6dc42c06a834f5d7e3ba71d71;hp=864e9a66ec17295e6e7e47ea741e600c32b81649;hb=07f4b20ae959069fca41756b0dc103ec5fa99754;hpb=0c07f0d23698798475e0d09491812aca52440328 diff --git a/daemon/zero.c b/daemon/zero.c index 864e9a6..df4ebd6 100644 --- a/daemon/zero.c +++ b/daemon/zero.c @@ -20,6 +20,7 @@ #include #include +#include #include #include #include @@ -28,7 +29,7 @@ #include "actions.h" int -do_zero (char *device) +do_zero (const char *device) { int fd, i; char buf[4096]; @@ -42,9 +43,52 @@ do_zero (char *device) memset (buf, 0, sizeof buf); for (i = 0; i < 32; ++i) - (void) write (fd, buf, sizeof buf); + if (write (fd, buf, sizeof buf) != sizeof buf) { + reply_with_perror ("write: %s", device); + close (fd); + return -1; + } - close (fd); + if (close (fd) == -1) { + reply_with_perror ("close: %s", device); + return -1; + } + + 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; }