2019-11-29 17:28:30 +01:00
|
|
|
.. _sanitizer:
|
|
|
|
|
2020-01-24 14:04:41 -05:00
|
|
|
*****************
|
2019-11-29 17:28:30 +01:00
|
|
|
Google Sanitizers
|
2020-01-24 14:04:41 -05:00
|
|
|
*****************
|
2019-11-29 17:28:30 +01:00
|
|
|
|
|
|
|
VPP is instrumented to support `Google Sanitizers <https://github.com/google/sanitizers>`_.
|
|
|
|
As of today, only `AddressSanitizer <https://github.com/google/sanitizers/wiki/AddressSanitizer>`_
|
2020-05-21 16:47:05 +02:00
|
|
|
is supported, both for GCC and clang.
|
2019-11-29 17:28:30 +01:00
|
|
|
|
|
|
|
AddressSanitizer
|
2020-01-24 14:04:41 -05:00
|
|
|
================
|
2019-11-29 17:28:30 +01:00
|
|
|
|
|
|
|
`AddressSanitizer <https://github.com/google/sanitizers/wiki/AddressSanitizer>`_ (aka ASan) is a memory
|
|
|
|
error detector for C/C++. Think Valgrind but much faster.
|
|
|
|
|
|
|
|
In order to use it, VPP must be recompiled with ASan support. It is implemented as a cmake
|
|
|
|
build option, so all VPP targets should be supported. For example:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
# build a debug image with ASan support:
|
2020-05-21 16:47:05 +02:00
|
|
|
$ make rebuild VPP_EXTRA_CMAKE_ARGS=-DVPP_ENABLE_SANITIZE_ADDR=ON
|
2019-11-29 17:28:30 +01:00
|
|
|
....
|
|
|
|
|
|
|
|
# build a release image with ASan support:
|
2020-05-21 16:47:05 +02:00
|
|
|
$ make rebuild-release VPP_EXTRA_CMAKE_ARGS=-DVPP_ENABLE_SANITIZE_ADDR=ON
|
2019-11-29 17:28:30 +01:00
|
|
|
....
|
|
|
|
|
|
|
|
# build packages in debug mode with ASan support:
|
2020-05-21 16:47:05 +02:00
|
|
|
$ make pkg-deb-debug VPP_EXTRA_CMAKE_ARGS=-DVPP_ENABLE_SANITIZE_ADDR=ON
|
2019-11-29 17:28:30 +01:00
|
|
|
....
|
|
|
|
|
|
|
|
# run GBP plugin tests in debug mode with ASan
|
2020-05-21 16:47:05 +02:00
|
|
|
$ make test-debug TEST=test_gbp VPP_EXTRA_CMAKE_ARGS=-DVPP_ENABLE_SANITIZE_ADDR=ON
|
2019-11-29 17:28:30 +01:00
|
|
|
....
|
|
|
|
|
2020-04-21 19:25:14 +02:00
|
|
|
Once VPP has been built with ASan support you can use it as usual including
|
|
|
|
under gdb:
|
2020-05-29 08:56:38 -04:00
|
|
|
|
2019-11-29 17:28:30 +01:00
|
|
|
.. code-block:: console
|
|
|
|
|
2020-04-21 19:25:14 +02:00
|
|
|
$ gdb --args $PWD/build-root/install-vpp_debug-native/vpp/bin/vpp "unix { interactive }"
|
2019-11-29 17:28:30 +01:00
|
|
|
....
|
|
|
|
|