• Home
  • History
  • Annotate
Name Date Size #Lines LOC

..--

CMakeLists.txtD23-Nov-20235.9 KiB192165

JSON.cppD23-Nov-202310.9 KiB370322

JSON.hD23-Nov-2023871 2912

JSONTest.cppD23-Nov-20236.2 KiB199169

LibcBenchmark.cppD23-Nov-20231.3 KiB4229

LibcBenchmark.hD23-Nov-202311.6 KiB

LibcBenchmarkTest.cppD23-Nov-20236.3 KiB177143

LibcMemoryBenchmark.cppD23-Nov-20232.4 KiB6342

LibcMemoryBenchmark.hD23-Nov-20235.9 KiB184100

LibcMemoryBenchmarkMain.cppD23-Nov-20233.4 KiB10382

LibcMemoryBenchmarkMain.hD23-Nov-20231.2 KiB3717

LibcMemoryBenchmarkTest.cppD23-Nov-20233.3 KiB12091

Memcmp.cppD23-Nov-20232.8 KiB8864

Memcpy.cppD23-Nov-20232.4 KiB7452

MemorySizeDistributions.cppD23-Nov-202353.6 KiB6456

MemorySizeDistributions.hD23-Nov-20231.6 KiB4516

Memset.cppD23-Nov-20232.3 KiB7149

RATIONALE.mdD23-Nov-202311 KiB244186

README.mdD23-Nov-20233.8 KiB10975

configuration_big.jsonD23-Nov-2023468 2524

configuration_small.jsonD23-Nov-2023457 2524

render.py3D23-Nov-20235.6 KiB195164

README.md

1# Libc mem* benchmarks
2
3This framework has been designed to evaluate and compare relative performance of
4memory function implementations on a particular host.
5
6It will also be use to track implementations performances over time.
7
8## Quick start
9
10### Setup
11
12**Python 2** [being deprecated](https://www.python.org/doc/sunset-python-2/) it is
13advised to used **Python 3**.
14
15Then make sure to have `matplotlib`, `scipy` and `numpy` setup correctly:
16
17```shell
18apt-get install python3-pip
19pip3 install matplotlib scipy numpy
20```
21You may need `python3-gtk` or similar package for displaying benchmark results.
22
23To get good reproducibility it is important to make sure that the system runs in
24`performance` mode. This is achieved by running:
25
26```shell
27cpupower frequency-set --governor performance
28```
29
30### Run and display `memcpy` benchmark
31
32The following commands will run the benchmark and display a 95 percentile
33confidence interval curve of **time per copied bytes**. It also features **host
34informations** and **benchmarking configuration**.
35
36```shell
37cd llvm-project
38cmake -B/tmp/build -Sllvm -DLLVM_ENABLE_PROJECTS='clang;clang-tools-extra;libc' -DCMAKE_BUILD_TYPE=Release -G Ninja
39ninja -C /tmp/build display-libc-memcpy-benchmark-small
40```
41
42The display target will attempt to open a window on the machine where you're
43running the benchmark. If this may not work for you then you may want `render`
44or `run` instead as detailed below.
45
46## Benchmarking targets
47
48The benchmarking process occurs in two steps:
49
501. Benchmark the functions and produce a `json` file
512. Display (or renders) the `json` file
52
53Targets are of the form `<action>-libc-<function>-benchmark-<configuration>`
54
55 - `action` is one of :
56    - `run`, runs the benchmark and writes the `json` file
57    - `display`, displays the graph on screen
58    - `render`, renders the graph on disk as a `png` file
59 - `function` is one of : `memcpy`, `memcmp`, `memset`
60 - `configuration` is one of : `small`, `big`
61
62## Benchmarking regimes
63
64Using a profiler to observe size distributions for calls into libc functions, it
65was found most operations act on a small number of bytes.
66
67Function           | % of calls with size ≤ 128 | % of calls with size ≤ 1024
68------------------ | --------------------------: | ---------------------------:
69memcpy             | 96%                         | 99%
70memset             | 91%                         | 99.9%
71memcmp<sup>1</sup> | 99.5%                       | ~100%
72
73Benchmarking configurations come in two flavors:
74
75 - [small](libc/utils/benchmarks/configuration_small.json)
76    - Exercises sizes up to `1KiB`, representative of normal usage
77    - The data is kept in the `L1` cache to prevent measuring the memory
78      subsystem
79 - [big](libc/utils/benchmarks/configuration_big.json)
80    - Exercises sizes up to `32MiB` to test large operations
81    - Caching effects can show up here which prevents comparing different hosts
82
83_<sup>1</sup> - The size refers to the size of the buffers to compare and not
84the number of bytes until the first difference._
85
86## Superposing curves
87
88It is possible to **merge** several `json` files into a single graph. This is
89useful to **compare** implementations.
90
91In the following example we superpose the curves for `memcpy`, `memset` and
92`memcmp`:
93
94```shell
95> make -C /tmp/build run-libc-memcpy-benchmark-small run-libc-memcmp-benchmark-small run-libc-memset-benchmark-small
96> python libc/utils/benchmarks/render.py3 /tmp/last-libc-memcpy-benchmark-small.json /tmp/last-libc-memcmp-benchmark-small.json /tmp/last-libc-memset-benchmark-small.json
97```
98
99## Useful `render.py3` flags
100
101 - To save the produced graph `--output=/tmp/benchmark_curve.png`.
102 - To prevent the graph from appearing on the screen `--headless`.
103
104
105## Under the hood
106
107 To learn more about the design decisions behind the benchmarking framework,
108 have a look at the [RATIONALE.md](RATIONALE.md) file.
109