blob: b8e9b257f0c48ad47bbfa4debc774c3f41811d8a [file] [log] [blame]
/* 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>
*
* Licensed under GPLv2 or later, see file LICENSE in this source tree.
*/
//config:config READAHEAD
//config: bool "readahead"
//config: default y
//config: depends on LFS
//config: select PLATFORM_LINUX
//config: help
//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.
//config:
//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.
//config:
//config: As readahead(2) blocks until each file has been read, it is best to
//config: run this applet as a background job.
//applet:IF_READAHEAD(APPLET(readahead, BB_DIR_USR_SBIN, BB_SUID_DROP))
//kbuild:lib-$(CONFIG_READAHEAD) += readahead.o
//usage:#define readahead_trivial_usage
//usage: "[FILE]..."
//usage:#define readahead_full_usage "\n\n"
//usage: "Preload FILEs to RAM"
#include "libbb.h"
int readahead_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
int readahead_main(int argc UNUSED_PARAM, char **argv)
{
int retval = EXIT_SUCCESS;
if (!argv[1]) {
bb_show_usage();
}
while (*++argv) {
int fd = open_or_warn(*argv, O_RDONLY);
if (fd >= 0) {
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);
close(fd);
if (r >= 0)
continue;
}
retval = EXIT_FAILURE;
}
return retval;
}