| /* 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 (2 kb)" |
| //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; |
| } |