2006-08-21 03:42:18 +05:30
|
|
|
/* vi: set sw=4 ts=4: */
|
|
|
|
/*
|
|
|
|
* readahead implementation for busybox
|
|
|
|
*
|
|
|
|
* Preloads the given files in RAM, to reduce access time.
|
|
|
|
* Does this by calling the readahead(2) system call.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2006 Michael Opdenacker <michael@free-electrons.com>
|
|
|
|
*
|
2010-08-16 23:44:46 +05:30
|
|
|
* Licensed under GPLv2 or later, see file LICENSE in this source tree.
|
2006-08-21 03:42:18 +05:30
|
|
|
*/
|
2016-11-23 03:44:24 +05:30
|
|
|
//config:config READAHEAD
|
2018-12-28 07:50:17 +05:30
|
|
|
//config: bool "readahead (1.5 kb)"
|
2016-11-23 03:44:24 +05:30
|
|
|
//config: default y
|
|
|
|
//config: depends on LFS
|
|
|
|
//config: select PLATFORM_LINUX
|
|
|
|
//config: help
|
2017-07-21 13:20:55 +05:30
|
|
|
//config: Preload the files listed on the command line into RAM cache so that
|
|
|
|
//config: subsequent reads on these files will not block on disk I/O.
|
2016-11-23 03:44:24 +05:30
|
|
|
//config:
|
2017-07-21 13:20:55 +05:30
|
|
|
//config: This applet just calls the readahead(2) system call on each file.
|
|
|
|
//config: It is mainly useful in system startup scripts to preload files
|
|
|
|
//config: or executables before they are used. When used at the right time
|
|
|
|
//config: (in particular when a CPU bound process is running) it can
|
|
|
|
//config: significantly speed up system startup.
|
2016-11-23 03:44:24 +05:30
|
|
|
//config:
|
2017-07-21 13:20:55 +05:30
|
|
|
//config: As readahead(2) blocks until each file has been read, it is best to
|
|
|
|
//config: run this applet as a background job.
|
2006-08-21 03:42:18 +05:30
|
|
|
|
2016-11-23 04:24:17 +05:30
|
|
|
//applet:IF_READAHEAD(APPLET(readahead, BB_DIR_USR_SBIN, BB_SUID_DROP))
|
|
|
|
|
|
|
|
//kbuild:lib-$(CONFIG_READAHEAD) += readahead.o
|
|
|
|
|
2011-04-11 06:59:49 +05:30
|
|
|
//usage:#define readahead_trivial_usage
|
|
|
|
//usage: "[FILE]..."
|
|
|
|
//usage:#define readahead_full_usage "\n\n"
|
|
|
|
//usage: "Preload FILEs to RAM"
|
|
|
|
|
2007-05-27 00:30:18 +05:30
|
|
|
#include "libbb.h"
|
2006-08-21 03:42:18 +05:30
|
|
|
|
2007-10-11 15:35:36 +05:30
|
|
|
int readahead_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
|
2010-01-04 18:45:38 +05:30
|
|
|
int readahead_main(int argc UNUSED_PARAM, char **argv)
|
2006-08-21 03:42:18 +05:30
|
|
|
{
|
|
|
|
int retval = EXIT_SUCCESS;
|
|
|
|
|
2010-01-04 18:45:38 +05:30
|
|
|
if (!argv[1]) {
|
|
|
|
bb_show_usage();
|
|
|
|
}
|
2006-08-21 03:42:18 +05:30
|
|
|
|
|
|
|
while (*++argv) {
|
2007-11-06 08:35:54 +05:30
|
|
|
int fd = open_or_warn(*argv, O_RDONLY);
|
|
|
|
if (fd >= 0) {
|
2008-01-28 05:11:34 +05:30
|
|
|
off_t len;
|
|
|
|
int r;
|
|
|
|
|
|
|
|
/* fdlength was reported to be unreliable - use seek */
|
|
|
|
len = xlseek(fd, 0, SEEK_END);
|
|
|
|
xlseek(fd, 0, SEEK_SET);
|
|
|
|
r = readahead(fd, 0, len);
|
2007-11-06 08:35:54 +05:30
|
|
|
close(fd);
|
2008-01-28 05:11:34 +05:30
|
|
|
if (r >= 0)
|
|
|
|
continue;
|
2006-08-21 03:42:18 +05:30
|
|
|
}
|
|
|
|
retval = EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
}
|