Rob Landley | 0e4690d | 2006-08-20 22:12:18 +0000 | [diff] [blame] | 1 | /* vi: set sw=4 ts=4: */ |
| 2 | /* |
| 3 | * readahead implementation for busybox |
| 4 | * |
| 5 | * Preloads the given files in RAM, to reduce access time. |
| 6 | * Does this by calling the readahead(2) system call. |
| 7 | * |
| 8 | * Copyright (C) 2006 Michael Opdenacker <michael@free-electrons.com> |
| 9 | * |
Denys Vlasenko | 0ef64bd | 2010-08-16 20:14:46 +0200 | [diff] [blame] | 10 | * Licensed under GPLv2 or later, see file LICENSE in this source tree. |
Rob Landley | 0e4690d | 2006-08-20 22:12:18 +0000 | [diff] [blame] | 11 | */ |
Denys Vlasenko | fb4da16 | 2016-11-22 23:14:24 +0100 | [diff] [blame] | 12 | //config:config READAHEAD |
Denys Vlasenko | b097a84 | 2018-12-28 03:20:17 +0100 | [diff] [blame] | 13 | //config: bool "readahead (1.5 kb)" |
Denys Vlasenko | fb4da16 | 2016-11-22 23:14:24 +0100 | [diff] [blame] | 14 | //config: default y |
| 15 | //config: depends on LFS |
Denys Vlasenko | fb4da16 | 2016-11-22 23:14:24 +0100 | [diff] [blame] | 16 | //config: help |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 17 | //config: Preload the files listed on the command line into RAM cache so that |
| 18 | //config: subsequent reads on these files will not block on disk I/O. |
Denys Vlasenko | fb4da16 | 2016-11-22 23:14:24 +0100 | [diff] [blame] | 19 | //config: |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 20 | //config: This applet just calls the readahead(2) system call on each file. |
| 21 | //config: It is mainly useful in system startup scripts to preload files |
| 22 | //config: or executables before they are used. When used at the right time |
| 23 | //config: (in particular when a CPU bound process is running) it can |
| 24 | //config: significantly speed up system startup. |
Denys Vlasenko | fb4da16 | 2016-11-22 23:14:24 +0100 | [diff] [blame] | 25 | //config: |
Denys Vlasenko | 72089cf | 2017-07-21 09:50:55 +0200 | [diff] [blame] | 26 | //config: As readahead(2) blocks until each file has been read, it is best to |
| 27 | //config: run this applet as a background job. |
Rob Landley | 0e4690d | 2006-08-20 22:12:18 +0000 | [diff] [blame] | 28 | |
Denys Vlasenko | f88e3bf | 2016-11-22 23:54:17 +0100 | [diff] [blame] | 29 | //applet:IF_READAHEAD(APPLET(readahead, BB_DIR_USR_SBIN, BB_SUID_DROP)) |
| 30 | |
| 31 | //kbuild:lib-$(CONFIG_READAHEAD) += readahead.o |
| 32 | |
Pere Orga | 5bc8c00 | 2011-04-11 03:29:49 +0200 | [diff] [blame] | 33 | //usage:#define readahead_trivial_usage |
| 34 | //usage: "[FILE]..." |
| 35 | //usage:#define readahead_full_usage "\n\n" |
| 36 | //usage: "Preload FILEs to RAM" |
| 37 | |
Denis Vlasenko | b6adbf1 | 2007-05-26 19:00:18 +0000 | [diff] [blame] | 38 | #include "libbb.h" |
Rob Landley | 0e4690d | 2006-08-20 22:12:18 +0000 | [diff] [blame] | 39 | |
Denis Vlasenko | 9b49a5e | 2007-10-11 10:05:36 +0000 | [diff] [blame] | 40 | int readahead_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; |
Denys Vlasenko | 2ec91ae | 2010-01-04 14:15:38 +0100 | [diff] [blame] | 41 | int readahead_main(int argc UNUSED_PARAM, char **argv) |
Rob Landley | 0e4690d | 2006-08-20 22:12:18 +0000 | [diff] [blame] | 42 | { |
Rob Landley | 0e4690d | 2006-08-20 22:12:18 +0000 | [diff] [blame] | 43 | int retval = EXIT_SUCCESS; |
| 44 | |
Denys Vlasenko | 2ec91ae | 2010-01-04 14:15:38 +0100 | [diff] [blame] | 45 | if (!argv[1]) { |
| 46 | bb_show_usage(); |
| 47 | } |
Rob Landley | 0e4690d | 2006-08-20 22:12:18 +0000 | [diff] [blame] | 48 | |
| 49 | while (*++argv) { |
Denis Vlasenko | 6bef3d1 | 2007-11-06 03:05:54 +0000 | [diff] [blame] | 50 | int fd = open_or_warn(*argv, O_RDONLY); |
| 51 | if (fd >= 0) { |
Denis Vlasenko | b5c60fc | 2008-01-27 23:41:34 +0000 | [diff] [blame] | 52 | off_t len; |
| 53 | int r; |
| 54 | |
| 55 | /* fdlength was reported to be unreliable - use seek */ |
| 56 | len = xlseek(fd, 0, SEEK_END); |
| 57 | xlseek(fd, 0, SEEK_SET); |
| 58 | r = readahead(fd, 0, len); |
Denis Vlasenko | 6bef3d1 | 2007-11-06 03:05:54 +0000 | [diff] [blame] | 59 | close(fd); |
Denis Vlasenko | b5c60fc | 2008-01-27 23:41:34 +0000 | [diff] [blame] | 60 | if (r >= 0) |
| 61 | continue; |
Rob Landley | 0e4690d | 2006-08-20 22:12:18 +0000 | [diff] [blame] | 62 | } |
| 63 | retval = EXIT_FAILURE; |
| 64 | } |
| 65 | |
| 66 | return retval; |
| 67 | } |