diff options
| author | Denis Vlasenko <vda.linux@googlemail.com> | 2007-07-14 22:07:14 +0000 |
|---|---|---|
| committer | Denis Vlasenko <vda.linux@googlemail.com> | 2007-07-14 22:07:14 +0000 |
| commit | fb79a2e2cfe33002398f1898c26d8e4f341db006 (patch) | |
| tree | f5b3ee27db5bc8c9b181fbec171f8fa430a75ba5 /util-linux | |
| parent | fcfaf2e18aba06dd90b16958ecfbfcfbf59ceb02 (diff) | |
| download | busybox-w32-fb79a2e2cfe33002398f1898c26d8e4f341db006.tar.gz busybox-w32-fb79a2e2cfe33002398f1898c26d8e4f341db006.tar.bz2 busybox-w32-fb79a2e2cfe33002398f1898c26d8e4f341db006.zip | |
xioctl and friends by Tito <farmatito@tiscali.it>
function old new delta
do_iptunnel 203 977 +774
process_dev 5328 5494 +166
ioctl_or_perror - 54 +54
ioctl_or_perror_and_die - 51 +51
ioctl_alt_func - 49 +49
bb_ioctl_or_warn - 47 +47
do_add_ioctl 102 145 +43
bb_xioctl - 39 +39
print_value_on_off - 31 +31
get_lcm 105 123 +18
arp_main 2155 2167 +12
..................
zcip_main 1576 1566 -10
setlogcons_main 92 82 -10
dumpkmap_main 263 253 -10
do_get_ioctl 85 75 -10
setkeycodes_main 165 154 -11
write_table 244 232 -12
vconfig_main 318 306 -12
do_del_ioctl 93 81 -12
set_address 75 62 -13
maybe_set_utc 30 16 -14
loadfont_main 495 479 -16
slattach_main 712 695 -17
do_loadfont 191 174 -17
do_iplink 1155 1136 -19
getty_main 2583 2562 -21
fbset_main 2058 2035 -23
do_time 588 565 -23
xioctl 25 - -25
read_rtc 186 160 -26
parse_conf 1299 1270 -29
udhcp_read_interface 269 239 -30
bb_ioctl 45 - -45
bb_ioctl_alt 70 - -70
bb_ioctl_on_off 78 - -78
.rodata 129370 129018 -352
do_show 799 - -799
------------------------------------------------------------------------------
(add/remove: 6/5 grow/shrink: 13/49 up/down: 1316/-1864) Total: -548 bytes
text data bss dec hex filename
675352 2740 13968 692060 a8f5c busybox_old
674804 2740 13968 691512 a8d38 busybox_unstripped
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) | |||
| 385 | } | 385 | } |
| 386 | 386 | ||
| 387 | fh = xopen(fbdev, O_RDONLY); | 387 | fh = xopen(fbdev, O_RDONLY); |
| 388 | if (ioctl(fh, FBIOGET_VSCREENINFO, &var)) | 388 | xioctl(fh, FBIOGET_VSCREENINFO, &var); |
| 389 | bb_perror_msg_and_die("ioctl(%sT_VSCREENINFO)", "GE"); | ||
| 390 | if (g_options & OPT_READMODE) { | 389 | if (g_options & OPT_READMODE) { |
| 391 | if (!readmode(&var, modefile, mode)) { | 390 | if (!readmode(&var, modefile, mode)) { |
| 392 | bb_error_msg_and_die("unknown video mode '%s'", mode); | 391 | bb_error_msg_and_die("unknown video mode '%s'", mode); |
| @@ -397,8 +396,7 @@ int fbset_main(int argc, char **argv) | |||
| 397 | if (g_options & OPT_CHANGE) { | 396 | if (g_options & OPT_CHANGE) { |
| 398 | if (g_options & OPT_ALL) | 397 | if (g_options & OPT_ALL) |
| 399 | var.activate = FB_ACTIVATE_ALL; | 398 | var.activate = FB_ACTIVATE_ALL; |
| 400 | if (ioctl(fh, FBIOPUT_VSCREENINFO, &var)) | 399 | xioctl(fh, FBIOPUT_VSCREENINFO, &var); |
| 401 | bb_perror_msg_and_die("ioctl(%sT_VSCREENINFO)", "PU"); | ||
| 402 | } | 400 | } |
| 403 | showmode(&var); | 401 | showmode(&var); |
| 404 | /* Don't close the file, as exiting will take care of that */ | 402 | /* 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 { | |||
| 45 | #define FDGETPRM _IOR(2, 0x04, struct floppy_struct) | 45 | #define FDGETPRM _IOR(2, 0x04, struct floppy_struct) |
| 46 | #define FD_FILL_BYTE 0xF6 /* format fill byte. */ | 46 | #define FD_FILL_BYTE 0xF6 /* format fill byte. */ |
| 47 | 47 | ||
| 48 | static void xioctl(int fd, int request, void *argp, const char *string) | ||
| 49 | { | ||
| 50 | if (ioctl(fd, request, argp) < 0) { | ||
| 51 | bb_perror_msg_and_die(string); | ||
| 52 | } | ||
| 53 | } | ||
| 54 | |||
| 55 | int fdformat_main(int argc,char **argv); | 48 | int fdformat_main(int argc,char **argv); |
| 56 | int fdformat_main(int argc,char **argv) | 49 | int fdformat_main(int argc,char **argv) |
| 57 | { | 50 | { |
| @@ -77,7 +70,7 @@ int fdformat_main(int argc,char **argv) | |||
| 77 | fd = xopen(*argv, O_RDWR); | 70 | fd = xopen(*argv, O_RDWR); |
| 78 | 71 | ||
| 79 | /* original message was: "Could not determine current format type" */ | 72 | /* original message was: "Could not determine current format type" */ |
| 80 | xioctl(fd, FDGETPRM, ¶m, "FDGETPRM"); | 73 | xioctl(fd, FDGETPRM, ¶m); |
| 81 | 74 | ||
| 82 | printf("%s-sided, %d tracks, %d sec/track. Total capacity %d kB\n", | 75 | printf("%s-sided, %d tracks, %d sec/track. Total capacity %d kB\n", |
| 83 | (param.head == 2) ? "Double" : "Single", | 76 | (param.head == 2) ? "Double" : "Single", |
| @@ -85,21 +78,21 @@ int fdformat_main(int argc,char **argv) | |||
| 85 | 78 | ||
| 86 | /* FORMAT */ | 79 | /* FORMAT */ |
| 87 | printf("Formatting... "); | 80 | printf("Formatting... "); |
| 88 | xioctl(fd, FDFMTBEG, NULL, "FDFMTBEG"); | 81 | xioctl(fd, FDFMTBEG, NULL); |
| 89 | 82 | ||
| 90 | /* n == track */ | 83 | /* n == track */ |
| 91 | for (n = 0; n < param.track; n++) { | 84 | for (n = 0; n < param.track; n++) { |
| 92 | descr.head = 0; | 85 | descr.head = 0; |
| 93 | descr.track = n; | 86 | descr.track = n; |
| 94 | xioctl(fd, FDFMTTRK, &descr, "FDFMTTRK"); | 87 | xioctl(fd, FDFMTTRK, &descr); |
| 95 | printf("%3d\b\b\b", n); | 88 | printf("%3d\b\b\b", n); |
| 96 | if (param.head == 2) { | 89 | if (param.head == 2) { |
| 97 | descr.head = 1; | 90 | descr.head = 1; |
| 98 | xioctl(fd, FDFMTTRK, &descr, "FDFMTTRK"); | 91 | xioctl(fd, FDFMTTRK, &descr); |
| 99 | } | 92 | } |
| 100 | } | 93 | } |
| 101 | 94 | ||
| 102 | xioctl(fd, FDFMTEND, NULL, "FDFMTEND"); | 95 | xioctl(fd, FDFMTEND, NULL); |
| 103 | printf("done\n"); | 96 | printf("done\n"); |
| 104 | 97 | ||
| 105 | /* VERIFY */ | 98 | /* 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) | |||
| 2434 | printf("Calling ioctl() to re-read partition table\n"); | 2434 | printf("Calling ioctl() to re-read partition table\n"); |
| 2435 | sync(); | 2435 | sync(); |
| 2436 | /* sleep(2); Huh? */ | 2436 | /* sleep(2); Huh? */ |
| 2437 | i = ioctl(fd, BLKRRPART); | 2437 | i = ioctl_or_perror(fd, BLKRRPART, NULL, |
| 2438 | #if 0 | 2438 | "WARNING: rereading partition table " |
| 2439 | else { | ||
| 2440 | /* some kernel versions (1.2.x) seem to have trouble | ||
| 2441 | rereading the partition table, but if asked to do it | ||
| 2442 | twice, the second time works. - biro@yggdrasil.com */ | ||
| 2443 | sync(); | ||
| 2444 | sleep(2); | ||
| 2445 | i = ioctl(fd, BLKRRPART); | ||
| 2446 | } | ||
| 2447 | #endif | ||
| 2448 | |||
| 2449 | if (i) { | ||
| 2450 | bb_perror_msg("WARNING: rereading partition table " | ||
| 2451 | "failed, kernel still uses old table"); | 2439 | "failed, kernel still uses old table"); |
| 2452 | } | ||
| 2453 | |||
| 2454 | #if 0 | 2440 | #if 0 |
| 2455 | if (dos_changed) | 2441 | if (dos_changed) |
| 2456 | printf( | 2442 | 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 @@ | |||
| 17 | int freeramdisk_main(int argc, char **argv); | 17 | int freeramdisk_main(int argc, char **argv); |
| 18 | int freeramdisk_main(int argc, char **argv) | 18 | int freeramdisk_main(int argc, char **argv) |
| 19 | { | 19 | { |
| 20 | int result; | ||
| 21 | int fd; | 20 | int fd; |
| 22 | 21 | ||
| 23 | if (argc != 2) bb_show_usage(); | 22 | if (argc != 2) bb_show_usage(); |
| @@ -25,11 +24,10 @@ int freeramdisk_main(int argc, char **argv) | |||
| 25 | fd = xopen(argv[1], O_RDWR); | 24 | fd = xopen(argv[1], O_RDWR); |
| 26 | 25 | ||
| 27 | // Act like freeramdisk, fdflush, or both depending on configuration. | 26 | // Act like freeramdisk, fdflush, or both depending on configuration. |
| 28 | result = ioctl(fd, (ENABLE_FREERAMDISK && applet_name[1]=='r') | 27 | ioctl_or_perror_and_die(fd, (ENABLE_FREERAMDISK && applet_name[1]=='r') |
| 29 | || !ENABLE_FDFLUSH ? BLKFLSBUF : FDFLUSH); | 28 | || !ENABLE_FDFLUSH ? BLKFLSBUF : FDFLUSH, NULL, "%s", argv[1]); |
| 30 | 29 | ||
| 31 | if (ENABLE_FEATURE_CLEAN_UP) close(fd); | 30 | if (ENABLE_FEATURE_CLEAN_UP) close(fd); |
| 32 | 31 | ||
| 33 | if (result) bb_perror_msg_and_die("%s", argv[1]); | ||
| 34 | return EXIT_SUCCESS; | 32 | return EXIT_SUCCESS; |
| 35 | } | 33 | } |
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) | |||
| 59 | int rtc = xopen_rtc(O_RDONLY); | 59 | int rtc = xopen_rtc(O_RDONLY); |
| 60 | 60 | ||
| 61 | memset(&tm, 0, sizeof(struct tm)); | 61 | memset(&tm, 0, sizeof(struct tm)); |
| 62 | if (ioctl(rtc, RTC_RD_TIME, &tm) < 0) | 62 | xioctl(rtc, RTC_RD_TIME, &tm); |
| 63 | bb_perror_msg_and_die("cannot read time from RTC"); | ||
| 64 | tm.tm_isdst = -1; /* not known */ | 63 | tm.tm_isdst = -1; /* not known */ |
| 65 | 64 | ||
| 66 | close(rtc); | 65 | close(rtc); |
| 67 | 66 | ||
| 68 | if (utc) { | 67 | if (utc) { |
| 69 | oldtz = getenv("TZ"); | 68 | oldtz = getenv("TZ"); |
| 70 | setenv("TZ", "UTC 0", 1); | 69 | putenv((char*)"TZ=UTC0"); |
| 71 | tzset(); | 70 | tzset(); |
| 72 | } | 71 | } |
| 73 | 72 | ||
| 74 | t = mktime(&tm); | 73 | t = mktime(&tm); |
| 75 | 74 | ||
| 76 | if (utc) { | 75 | if (utc) { |
| 76 | unsetenv("TZ"); | ||
| 77 | if (oldtz) | 77 | if (oldtz) |
| 78 | setenv("TZ", oldtz, 1); | 78 | putenv(oldtz - 3); |
| 79 | else | ||
| 80 | unsetenv("TZ"); | ||
| 81 | tzset(); | 79 | tzset(); |
| 82 | } | 80 | } |
| 83 | return t; | 81 | return t; |
| @@ -91,8 +89,7 @@ static void write_rtc(time_t t, int utc) | |||
| 91 | tm = *(utc ? gmtime(&t) : localtime(&t)); | 89 | tm = *(utc ? gmtime(&t) : localtime(&t)); |
| 92 | tm.tm_isdst = 0; | 90 | tm.tm_isdst = 0; |
| 93 | 91 | ||
| 94 | if (ioctl(rtc, RTC_SET_TIME, &tm) < 0) | 92 | xioctl(rtc, RTC_SET_TIME, &tm); |
| 95 | bb_perror_msg_and_die("cannot set the RTC time"); | ||
| 96 | 93 | ||
| 97 | close(rtc); | 94 | close(rtc); |
| 98 | } | 95 | } |
