-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* ls: Remove allocations by eliminating collect/clones * ls: Introduce PathData structure - PathData will hold Path related metadata / strings that are required frequently in subsequent functions - All data is precomputed and cached and subsequent functions just use cached data * ls: Cache more data related to paths - Cache filename and sort by filename instead of full path - Cache uid->usr and gid->grp mappings https://github.com/uutils/coreutils/pull/2099/files * ls: Add BENCHMARKING.md * ls: Document PathData structure * tests/ls: Add testcase for error paths with width option * ls: Fix unused import warning cached will be only used for unix currently as current use of caching gid/uid mappings is only relevant on unix * ls: Suggest checking syscall count in BENCHMARKING.md * ls: Remove mentions of sort in BENCHMARKING.md * ls: Remove dependency on cached Implement caching using HashMap and lazy_static * ls: Fix MSRV error related to map_or Rust 1.40 did not support map_or for result types
- Loading branch information
1 parent
b756b98
commit 8554cdf
Showing
3 changed files
with
179 additions
and
71 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
# Benchmarking ls | ||
|
||
ls majorly involves fetching a lot of details (depending upon what details are requested, eg. time/date, inode details, etc) for each path using system calls. Ideally, any system call should be done only once for each of the paths - not adhering to this principle leads to a lot of system call overhead multiplying and bubbling up, especially for recursive ls, therefore it is important to always benchmark multiple scenarios. | ||
This is an overwiew over what was benchmarked, and if you make changes to `ls`, you are encouraged to check | ||
how performance was affected for the workloads listed below. Feel free to add other workloads to the | ||
list that we should improve / make sure not to regress. | ||
|
||
Run `cargo build --release` before benchmarking after you make a change! | ||
|
||
## Simple recursive ls | ||
|
||
- Get a large tree, for example linux kernel source tree. | ||
- Benchmark simple recursive ls with hyperfine: `hyperfine --warmup 2 "target/release/coreutils ls -R tree > /dev/null"`. | ||
|
||
## Recursive ls with all and long options | ||
|
||
- Same tree as above | ||
- Benchmark recursive ls with -al -R options with hyperfine: `hyperfine --warmup 2 "target/release/coreutils ls -al -R tree > /dev/null"`. | ||
|
||
## Comparing with GNU ls | ||
|
||
Hyperfine accepts multiple commands to run and will compare them. To compare performance with GNU ls | ||
duplicate the string you passed to hyperfine but remove the `target/release/coreutils` bit from it. | ||
|
||
Example: `hyperfine --warmup 2 "target/release/coreutils ls -al -R tree > /dev/null"` becomes | ||
`hyperfine --warmup 2 "target/release/coreutils ls -al -R tree > /dev/null" "ls -al -R tree > /dev/null"` | ||
(This assumes GNU ls is installed as `ls`) | ||
|
||
This can also be used to compare with version of ls built before your changes to ensure your change does not regress this | ||
|
||
## Checking system call count | ||
|
||
- Another thing to look at would be system calls count using strace (on linux) or equivalent on other operating systems. | ||
- Example: `strace -c target/release/coreutils ls -al -R tree` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters