[libcamera-devel] [PATCH] test: v4l2_compat: Disable test when ASan is enabled
Paul Elder
paul.elder at ideasonboard.com
Tue Aug 31 05:33:05 CEST 2021
Hi Laurent,
On Fri, Aug 27, 2021 at 11:50:12PM +0300, Laurent Pinchart wrote:
> The V4L2 compat test runs v4l2-ctl and v4l2-compliance with
> v4l2-compat.so preloaded. If libcamera is compiled with the address
> sanitizer enabled, the ASan library will be loaded due to preloading
> v4l2-compat.so. This however doesn't occur early enough in the dynamic
> linking process due to the v4l2 executables not being themselves linked
> to the ASan runtime, which causes ASan to abort with
>
> ==2198==ASan runtime does not come first in initial library list; you should either link runtime to your application or manually preload it with LD_PRELOAD.
>
> Using LD_PRELOAD to load the ASan runtime would fix this issue, but it
> requires knowing the absolute path to the ASan shared object. This is
> compiler-dependent and for clang, architecture-dependent as well.
>
> Until we figure out how to safely retrieve that information, disable the
> test when ASan is enabled as a quick fix.
>
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> ---
> test/v4l2_compat/meson.build | 6 ++++++
> 1 file changed, 6 insertions(+)
>
> diff --git a/test/v4l2_compat/meson.build b/test/v4l2_compat/meson.build
> index 5b29de7c0805..4164e9f945ee 100644
> --- a/test/v4l2_compat/meson.build
> +++ b/test/v4l2_compat/meson.build
> @@ -1,5 +1,11 @@
> # SPDX-License-Identifier: CC0-1.0
>
> +# If ASan is enabled, the link order runtime check will fail as v4l2-ctl and
> +# v4l2-compliance are not linked to ASan. Skip the test in that case.
Should we put a todo?
With or without,
Reviewed-by: Paul Elder <paul.elder at ideasonboard.com>
> +if get_option('b_sanitize').contains('address')
> + subdir_done()
> +endif
> +
> if is_variable('v4l2_compat')
> v4l2_compat_test = files('v4l2_compat_test.py')
>
> --
> Regards,
>
> Laurent Pinchart
>
More information about the libcamera-devel
mailing list