aboutsummaryrefslogtreecommitdiff
path: root/util-linux
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2007-07-14 22:07:14 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2007-07-14 22:07:14 +0000
commitfb79a2e2cfe33002398f1898c26d8e4f341db006 (patch)
treef5b3ee27db5bc8c9b181fbec171f8fa430a75ba5 /util-linux
parentfcfaf2e18aba06dd90b16958ecfbfcfbf59ceb02 (diff)
downloadbusybox-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.c6
-rw-r--r--util-linux/fdformat.c17
-rw-r--r--util-linux/fdisk.c18
-rw-r--r--util-linux/freeramdisk.c6
-rw-r--r--util-linux/hwclock.c13
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
48static 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
55int fdformat_main(int argc,char **argv); 48int fdformat_main(int argc,char **argv);
56int fdformat_main(int argc,char **argv) 49int 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, &param, "FDGETPRM"); 73 xioctl(fd, FDGETPRM, &param);
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 @@
17int freeramdisk_main(int argc, char **argv); 17int freeramdisk_main(int argc, char **argv);
18int freeramdisk_main(int argc, char **argv) 18int 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}