12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- NOTES FOR VALGRIND
- ==================
- 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
- See: http://valgrind.org/info/platforms.html
- 2. Valgrind installed on the platform
- See: http://valgrind.org/downloads/current.html
- 3. OpensSSL compiled
- See: INSTALL
- Running Tests
- -------------
- Test behavior can be modified by adjusting environment variables.
- EXE_SHELL
- This variable is used to specify the shell used to execute OpenSSL test
- programs. The default program (util/shlib_wrap.sh) initializes the
- environment to allow programs to find shared libraries. The variable can
- be modified to specify a different executable environment.
- EXE_SHELL="`/bin/pwd`/util/shlib_wrap.sh valgrind --error-exitcode=1 --leak-check=full -q"
- This will start up Valgrind with the default checker (memcheck).
- The --error-exitcode=1 option specifies that Valgrind should exit with an
- error code of 1 when memory leaks occur.
- 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.
- OPENSSL_ia32cap
- 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:
- OPENSSL_ia32cap=":0"
- This variable may need to be set to something different based on the
- processor and Valgrind version you are running tests on. More information
- may be found in docs/man3/OPENSSL_ia32cap.pod.
- Additional variables (i.e. VERBOSE and TESTS) are described in the
- INSTALL file in the root of the OpenSSL source tree.
- Example command line:
- make test EXE_SHELL="`/bin/pwd`/util/shlib_wrap.sh valgrind --error-exitcode=1 --leak-check=full -q" OPENSSL_ia32cap=":0"
- If an error occurs, you can then run the specific test via the TESTS
- variable with the VERBOSE option to gather additional information.
- make test VERBOSE=1 TESTS=test_test EXE_SHELL="`/bin/pwd`/util/shlib_wrap.sh valgrind --error-exitcode=1 --leak-check=full -q" OPENSSL_ia32cap=":0"
|