readahead.c 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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. *
  10. * Licensed under GPLv2 or later, see file LICENSE in this source tree.
  11. */
  12. //config:config READAHEAD
  13. //config: bool "readahead (1.7 kb)"
  14. //config: default y
  15. //config: depends on LFS
  16. //config: help
  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.
  19. //config:
  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.
  25. //config:
  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.
  28. //applet:IF_READAHEAD(APPLET(readahead, BB_DIR_USR_SBIN, BB_SUID_DROP))
  29. //kbuild:lib-$(CONFIG_READAHEAD) += readahead.o
  30. //usage:#define readahead_trivial_usage
  31. //usage: "[FILE]..."
  32. //usage:#define readahead_full_usage "\n\n"
  33. //usage: "Preload FILEs to RAM"
  34. #include "libbb.h"
  35. int readahead_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
  36. int readahead_main(int argc UNUSED_PARAM, char **argv)
  37. {
  38. int retval = EXIT_SUCCESS;
  39. if (!argv[1]) {
  40. bb_show_usage();
  41. }
  42. while (*++argv) {
  43. int fd = open_or_warn(*argv, O_RDONLY);
  44. if (fd >= 0) {
  45. off_t len;
  46. int r;
  47. /* fdlength was reported to be unreliable - use seek */
  48. len = xlseek(fd, 0, SEEK_END);
  49. xlseek(fd, 0, SEEK_SET);
  50. r = readahead(fd, 0, len);
  51. close(fd);
  52. if (r >= 0)
  53. continue;
  54. }
  55. retval = EXIT_FAILURE;
  56. }
  57. return retval;
  58. }