misc: asan: disable leak sanitizer by default
[vpp.git] / docs / troubleshooting / sanitizer.rst
1 .. _sanitizer:
2
3 *****************
4 Google Sanitizers
5 *****************
6
7 VPP is instrumented to support `Google Sanitizers <https://github.com/google/sanitizers>`_.
8 As of today, only `AddressSanitizer <https://github.com/google/sanitizers/wiki/AddressSanitizer>`_
9 is supported and only for the heap.
10
11 AddressSanitizer
12 ================
13
14 `AddressSanitizer <https://github.com/google/sanitizers/wiki/AddressSanitizer>`_  (aka ASan) is a memory
15 error detector for C/C++. Think Valgrind but much faster.
16
17 In order to use it, VPP must be recompiled with ASan support. It is implemented as a cmake
18 build option, so all VPP targets should be supported. For example:
19
20 .. code-block:: console
21
22     # build a debug image with ASan support:
23     $ make rebuild VPP_EXTRA_CMAKE_ARGS=-DENABLE_SANITIZE_ADDR=ON
24     ....
25
26     # build a release image with ASan support:
27     $ make rebuild-release VPP_EXTRA_CMAKE_ARGS=-DENABLE_SANITIZE_ADDR=ON
28     ....
29
30     # build packages in debug mode with ASan support:
31     $ make pkg-deb-debug VPP_EXTRA_CMAKE_ARGS=-DENABLE_SANITIZE_ADDR=ON
32     ....
33
34     # run GBP plugin tests in debug mode with ASan
35     $ make test-debug TEST=test_gbp VPP_EXTRA_CMAKE_ARGS=-DENABLE_SANITIZE_ADDR=ON
36     ....
37
38 Once VPP has been built with ASan support you can use it as usual including
39 under gdb:
40 .. code-block:: console
41
42     $ gdb --args $PWD/build-root/install-vpp_debug-native/vpp/bin/vpp "unix { interactive }"
43     ....
44