12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- /* 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 (1.7 kb)"
- //config: default y
- //config: depends on LFS
- //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;
- }
|