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
This commit is contained in:
@ -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 */
|
||||
|
@ -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 */
|
||||
|
@ -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(
|
||||
|
@ -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;
|
||||
}
|
||||
|
@ -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);
|
||||
}
|
||||
|
Reference in New Issue
Block a user