diff options
Diffstat (limited to 'util-linux')
-rw-r--r-- | util-linux/fbset.c | 6 | ||||
-rw-r--r-- | util-linux/fdformat.c | 17 | ||||
-rw-r--r-- | util-linux/fdisk.c | 18 | ||||
-rw-r--r-- | util-linux/freeramdisk.c | 6 | ||||
-rw-r--r-- | util-linux/hwclock.c | 13 |
5 files changed, 16 insertions, 44 deletions
diff --git a/util-linux/fbset.c b/util-linux/fbset.c index f963040bd..69986df25 100644 --- a/util-linux/fbset.c +++ b/util-linux/fbset.c @@ -385,8 +385,7 @@ int fbset_main(int argc, char **argv) } fh = xopen(fbdev, O_RDONLY); - if (ioctl(fh, FBIOGET_VSCREENINFO, &var)) - bb_perror_msg_and_die("ioctl(%sT_VSCREENINFO)", "GE"); + xioctl(fh, FBIOGET_VSCREENINFO, &var); if (g_options & OPT_READMODE) { if (!readmode(&var, modefile, mode)) { bb_error_msg_and_die("unknown video mode '%s'", mode); @@ -397,8 +396,7 @@ int fbset_main(int argc, char **argv) if (g_options & OPT_CHANGE) { if (g_options & OPT_ALL) var.activate = FB_ACTIVATE_ALL; - if (ioctl(fh, FBIOPUT_VSCREENINFO, &var)) - bb_perror_msg_and_die("ioctl(%sT_VSCREENINFO)", "PU"); + xioctl(fh, FBIOPUT_VSCREENINFO, &var); } showmode(&var); /* Don't close the file, as exiting will take care of that */ diff --git a/util-linux/fdformat.c b/util-linux/fdformat.c index e9fbeee7b..5e253efa8 100644 --- a/util-linux/fdformat.c +++ b/util-linux/fdformat.c @@ -45,13 +45,6 @@ struct format_descr { #define FDGETPRM _IOR(2, 0x04, struct floppy_struct) #define FD_FILL_BYTE 0xF6 /* format fill byte. */ -static void xioctl(int fd, int request, void *argp, const char *string) -{ - if (ioctl(fd, request, argp) < 0) { - bb_perror_msg_and_die(string); - } -} - int fdformat_main(int argc,char **argv); int fdformat_main(int argc,char **argv) { @@ -77,7 +70,7 @@ int fdformat_main(int argc,char **argv) fd = xopen(*argv, O_RDWR); /* original message was: "Could not determine current format type" */ - xioctl(fd, FDGETPRM, ¶m, "FDGETPRM"); + xioctl(fd, FDGETPRM, ¶m); printf("%s-sided, %d tracks, %d sec/track. Total capacity %d kB\n", (param.head == 2) ? "Double" : "Single", @@ -85,21 +78,21 @@ int fdformat_main(int argc,char **argv) /* FORMAT */ printf("Formatting... "); - xioctl(fd, FDFMTBEG, NULL, "FDFMTBEG"); + xioctl(fd, FDFMTBEG, NULL); /* n == track */ for (n = 0; n < param.track; n++) { descr.head = 0; descr.track = n; - xioctl(fd, FDFMTTRK, &descr, "FDFMTTRK"); + xioctl(fd, FDFMTTRK, &descr); printf("%3d\b\b\b", n); if (param.head == 2) { descr.head = 1; - xioctl(fd, FDFMTTRK, &descr, "FDFMTTRK"); + xioctl(fd, FDFMTTRK, &descr); } } - xioctl(fd, FDFMTEND, NULL, "FDFMTEND"); + xioctl(fd, FDFMTEND, NULL); printf("done\n"); /* VERIFY */ diff --git a/util-linux/fdisk.c b/util-linux/fdisk.c index 870789112..3b9892fa8 100644 --- a/util-linux/fdisk.c +++ b/util-linux/fdisk.c @@ -2434,23 +2434,9 @@ reread_partition_table(int leave) printf("Calling ioctl() to re-read partition table\n"); sync(); /* sleep(2); Huh? */ - i = ioctl(fd, BLKRRPART); -#if 0 - else { - /* some kernel versions (1.2.x) seem to have trouble - rereading the partition table, but if asked to do it - twice, the second time works. - biro@yggdrasil.com */ - sync(); - sleep(2); - i = ioctl(fd, BLKRRPART); - } -#endif - - if (i) { - bb_perror_msg("WARNING: rereading partition table " + i = ioctl_or_perror(fd, BLKRRPART, NULL, + "WARNING: rereading partition table " "failed, kernel still uses old table"); - } - #if 0 if (dos_changed) printf( diff --git a/util-linux/freeramdisk.c b/util-linux/freeramdisk.c index a1f2c56cf..4bd93781b 100644 --- a/util-linux/freeramdisk.c +++ b/util-linux/freeramdisk.c @@ -17,7 +17,6 @@ int freeramdisk_main(int argc, char **argv); int freeramdisk_main(int argc, char **argv) { - int result; int fd; if (argc != 2) bb_show_usage(); @@ -25,11 +24,10 @@ int freeramdisk_main(int argc, char **argv) fd = xopen(argv[1], O_RDWR); // Act like freeramdisk, fdflush, or both depending on configuration. - result = ioctl(fd, (ENABLE_FREERAMDISK && applet_name[1]=='r') - || !ENABLE_FDFLUSH ? BLKFLSBUF : FDFLUSH); + ioctl_or_perror_and_die(fd, (ENABLE_FREERAMDISK && applet_name[1]=='r') + || !ENABLE_FDFLUSH ? BLKFLSBUF : FDFLUSH, NULL, "%s", argv[1]); if (ENABLE_FEATURE_CLEAN_UP) close(fd); - if (result) bb_perror_msg_and_die("%s", argv[1]); return EXIT_SUCCESS; } diff --git a/util-linux/hwclock.c b/util-linux/hwclock.c index 204a103c3..8b65df6a6 100644 --- a/util-linux/hwclock.c +++ b/util-linux/hwclock.c @@ -59,25 +59,23 @@ static time_t read_rtc(int utc) int rtc = xopen_rtc(O_RDONLY); memset(&tm, 0, sizeof(struct tm)); - if (ioctl(rtc, RTC_RD_TIME, &tm) < 0) - bb_perror_msg_and_die("cannot read time from RTC"); + xioctl(rtc, RTC_RD_TIME, &tm); tm.tm_isdst = -1; /* not known */ close(rtc); if (utc) { oldtz = getenv("TZ"); - setenv("TZ", "UTC 0", 1); + putenv((char*)"TZ=UTC0"); tzset(); } t = mktime(&tm); if (utc) { + unsetenv("TZ"); if (oldtz) - setenv("TZ", oldtz, 1); - else - unsetenv("TZ"); + putenv(oldtz - 3); tzset(); } return t; @@ -91,8 +89,7 @@ static void write_rtc(time_t t, int utc) tm = *(utc ? gmtime(&t) : localtime(&t)); tm.tm_isdst = 0; - if (ioctl(rtc, RTC_SET_TIME, &tm) < 0) - bb_perror_msg_and_die("cannot set the RTC time"); + xioctl(rtc, RTC_SET_TIME, &tm); close(rtc); } |