2021-02-02 01:57:40 +08:00
|
|
|
Notes on Valgrind
|
|
|
|
=================
|
2019-05-03 02:37:18 +08:00
|
|
|
|
|
|
|
Valgrind is a test harness that includes many tools such as memcheck,
|
|
|
|
which is commonly used to check for memory leaks, etc. The default tool
|
|
|
|
run by Valgrind is memcheck. There are other tools available, but this
|
|
|
|
will focus on memcheck.
|
|
|
|
|
|
|
|
Valgrind runs programs in a virtual machine, this means OpenSSL unit
|
|
|
|
tests run under Valgrind will take longer than normal.
|
|
|
|
|
|
|
|
Requirements
|
|
|
|
------------
|
|
|
|
|
|
|
|
1. Platform supported by Valgrind
|
2020-06-10 23:49:25 +08:00
|
|
|
See <http://valgrind.org/info/platforms.html>
|
2019-05-03 02:37:18 +08:00
|
|
|
2. Valgrind installed on the platform
|
2020-06-10 23:49:25 +08:00
|
|
|
See <http://valgrind.org/downloads/current.html>
|
2021-12-04 06:47:26 +08:00
|
|
|
3. OpenSSL compiled
|
2020-06-10 23:49:25 +08:00
|
|
|
See [INSTALL.md](INSTALL.md)
|
2019-05-03 02:37:18 +08:00
|
|
|
|
|
|
|
Running Tests
|
|
|
|
-------------
|
|
|
|
|
|
|
|
Test behavior can be modified by adjusting environment variables.
|
|
|
|
|
2020-06-23 01:47:50 +08:00
|
|
|
`EXE_SHELL`
|
2019-05-03 02:37:18 +08:00
|
|
|
|
|
|
|
This variable is used to specify the shell used to execute OpenSSL test
|
2020-06-10 23:49:25 +08:00
|
|
|
programs. The default wrapper (`util/wrap.pl`) initializes the environment
|
2020-02-18 15:25:06 +08:00
|
|
|
to allow programs to find shared libraries. The variable can be modified
|
|
|
|
to specify a different executable environment.
|
2019-05-03 02:37:18 +08:00
|
|
|
|
2020-06-10 23:49:25 +08:00
|
|
|
EXE_SHELL=\
|
|
|
|
"`/bin/pwd`/util/wrap.pl valgrind --error-exitcode=1 --leak-check=full -q"
|
2019-05-03 02:37:18 +08:00
|
|
|
|
2020-06-10 23:49:25 +08:00
|
|
|
This will start up Valgrind with the default checker (`memcheck`).
|
|
|
|
The `--error-exitcode=1` option specifies that Valgrind should exit with an
|
2019-05-03 02:37:18 +08:00
|
|
|
error code of 1 when memory leaks occur.
|
2020-06-10 23:49:25 +08:00
|
|
|
The `--leak-check=full` option specifies extensive memory checking.
|
|
|
|
The `-q` option prints only error messages.
|
|
|
|
Additional Valgrind options may be added to the `EXE_SHELL` variable.
|
2019-05-03 02:37:18 +08:00
|
|
|
|
2020-06-23 01:47:50 +08:00
|
|
|
`OPENSSL_ia32cap`
|
2019-05-03 02:37:18 +08:00
|
|
|
|
|
|
|
This variable controls the processor-specific code on Intel processors.
|
|
|
|
By default, OpenSSL will attempt to figure out the capabilities of a
|
|
|
|
processor, and use it to its fullest capability. This variable can be
|
|
|
|
used to control what capabilities OpenSSL uses.
|
|
|
|
|
|
|
|
As of valgrind-3.15.0 on Linux/x86_64, instructions up to AVX2 are
|
|
|
|
supported. Setting the following disables instructions beyond AVX2:
|
|
|
|
|
2020-06-23 14:38:24 +08:00
|
|
|
`OPENSSL_ia32cap=":0"`
|
2019-05-03 02:37:18 +08:00
|
|
|
|
|
|
|
This variable may need to be set to something different based on the
|
|
|
|
processor and Valgrind version you are running tests on. More information
|
2020-06-10 23:49:25 +08:00
|
|
|
may be found in [doc/man3/OPENSSL_ia32cap.pod](doc/man3/OPENSSL_ia32cap.pod).
|
2019-05-03 02:37:18 +08:00
|
|
|
|
2020-06-23 01:47:50 +08:00
|
|
|
Additional variables (such as `VERBOSE` and `TESTS`) are described in the
|
2020-06-23 14:38:24 +08:00
|
|
|
file [test/README.md](test/README.md).
|
2019-05-03 02:37:18 +08:00
|
|
|
|
|
|
|
Example command line:
|
|
|
|
|
2020-06-10 23:49:25 +08:00
|
|
|
$ make test EXE_SHELL="`/bin/pwd`/util/wrap.pl valgrind --error-exitcode=1 \
|
|
|
|
--leak-check=full -q" OPENSSL_ia32cap=":0"
|
2019-05-03 02:37:18 +08:00
|
|
|
|
2020-06-10 23:49:25 +08:00
|
|
|
If an error occurs, you can then run the specific test via the `TESTS` variable
|
|
|
|
with the `VERBOSE` or `VF` or `VFP` options to gather additional information.
|
2019-05-03 02:37:18 +08:00
|
|
|
|
2020-06-10 23:49:25 +08:00
|
|
|
$ make test VERBOSE=1 TESTS=test_test EXE_SHELL="`/bin/pwd`/util/wrap.pl \
|
|
|
|
valgrind --error-exitcode=1 --leak-check=full -q" OPENSSL_ia32cap=":0"
|