From: Rob Landley Date: Sat, 31 May 2014 22:59:27 +0000 (-0500) Subject: Cleanup partprobe. X-Git-Tag: 0.5.0~189 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=4d22a09d76ef09a169db48a4d6599d8a5fe547ad;p=platform%2Fupstream%2Ftoybox.git Cleanup partprobe. --- diff --git a/toys/pending/partprobe.c b/toys/pending/partprobe.c index 2fe3bd5..e0beb00 100644 --- a/toys/pending/partprobe.c +++ b/toys/pending/partprobe.c @@ -4,48 +4,27 @@ * * see http://man7.org/linux/man-pages/man8/partprobe.8.html -USE_PARTPROBE(NEWTOY(partprobe, NULL, TOYFLAG_SBIN)) +USE_PARTPROBE(NEWTOY(partprobe, "<1", TOYFLAG_SBIN)) config PARTPROBE bool "partprobe" default n help - partprobe - Tell the kernel about partition table changes - - usage: partprobe [devices...] + usage: partprobe DEVICE... - Asks the kernel to re-read the partition table on the specified - devices. + Tell the kernel about partition table changes + + Ask the kernel to re-read the partition table on the specified devices. */ #include "toys.h" -void update_device(char* path) +static void do_partprobe(int fd, char *name) { - int sd_fd = open(path, 0); - - if(sd_fd < 0){ - perror_msg("Unable to open %s", path); - return; - } - - if(ioctl(sd_fd, BLKRRPART, NULL) < 0) - perror_msg("ioctl (BLKRRPART) failed, old layout still used"); - - close(sd_fd); + if (ioctl(fd, BLKRRPART, 0)) perror_msg("ioctl failed"); } void partprobe_main(void) { - char** opt; - if(*toys.optargs == NULL){ - printf("No devices specified.\n"); - exit(EXIT_FAILURE); - } - - for (opt = toys.optargs; *opt; opt++) { - update_device(*opt); - } - - exit(EXIT_SUCCESS); + loopfiles(toys.optargs, do_partprobe); }