Tito unified fdflush and freeramdisk. I tweaked the result a bit.
diff --git a/util-linux/freeramdisk.c b/util-linux/freeramdisk.c
index cfea35b..b544975 100644
--- a/util-linux/freeramdisk.c
+++ b/util-linux/freeramdisk.c
@@ -1,24 +1,12 @@
/* vi: set sw=4 ts=4: */
/*
- * freeramdisk implementation for busybox
+ * freeramdisk and fdflush implementations for busybox
*
* Copyright (C) 2000 and written by Emanuele Caratti <wiz@iol.it>
* Adjusted a bit by Erik Andersen <andersen@codepoet.org>
+ * Unified with fdflush by Tito Ragusa <farmatito@tiscali.it>
*
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- *
+ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
*/
#include <stdio.h>
@@ -30,40 +18,21 @@
#include <unistd.h>
#include "busybox.h"
-
-/* From linux/fs.h */
-#define BLKFLSBUF _IO(0x12,97) /* flush buffer cache */
-
-extern int
-freeramdisk_main(int argc, char **argv)
+extern int freeramdisk_main(int argc, char **argv)
{
int result;
int fd;
- if (argc != 2) {
- bb_show_usage();
- }
+ if (argc != 2) bb_show_usage();
fd = bb_xopen(argv[1], O_RDWR);
- result = ioctl(fd, BLKFLSBUF);
+ // Act like freeramdisk, fdflush, or both depending on configuration.
+ result = ioctl(fd, (bb_applet_name[1]=='r' && ENABLE_FREERAMDISK)
+ || !ENABLE_FDFLUSH ? _IO(0x12,97) : _IO(2,0x4b));
if (ENABLE_FEATURE_CLEAN_UP) close(fd);
- if (result < 0) {
- bb_perror_msg_and_die("failed ioctl on %s", argv[1]);
- }
-
- /* Don't bother closing. Exit does
- * that, so we can save a few bytes */
+ if (result) bb_perror_msg_and_die("%s", argv[1]);
return EXIT_SUCCESS;
}
-
-/*
-Local Variables:
-c-file-style: "linux"
-c-basic-offset: 4
-tab-width: 4
-End:
-*/
-