libcamera: base: Add thread safety annotation macros

Clang compiler is able to do a thread safety analysis with
annotations [1]. This introduces the thread safety annotation
macros and also enable the analysis by adding -Wthread-safety
if a clang compiler is used.

[1] https://clang.llvm.org/docs/ThreadSafetyAnalysis.html.

Signed-off-by: Hirokazu Honda <hiroh@chromium.org>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: Umang Jain <umang.jain@ideasonboard.com>
Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
This commit is contained in:
Hirokazu Honda
2021-12-01 16:53:40 +09:00
committed by Laurent Pinchart
parent 7b86854e40
commit 16efd83f5d
3 changed files with 82 additions and 0 deletions

View File

@@ -19,6 +19,7 @@ libcamera_base_headers = files([
'signal.h',
'span.h',
'thread.h',
'thread_annotations.h',
'timer.h',
'utils.h',
])

View File

@@ -0,0 +1,80 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
/*
* Copyright (C) 2021, Google Inc.
*
* thread_annotation.h - Macro of Clang thread safety analysis
*/
#pragma once
/*
* Enable thread safety attributes only with clang.
* The attributes can be safely erased when compiling with other compilers.
*/
#if defined(__clang__) && !defined(SWIG)
#define LIBCAMERA_TSA_ATTRIBUTE__(x) __attribute__((x))
#else
#define LIBCAMERA_TSA_ATTRIBUTE__(x) /* no-op */
#endif
/* See https://clang.llvm.org/docs/ThreadSafetyAnalysis.html for these usages. */
#define LIBCAMERA_TSA_CAPABILITY(x) \
LIBCAMERA_TSA_ATTRIBUTE__(capability(x))
#define LIBCAMERA_TSA_SCOPED_CAPABILITY \
LIBCAMERA_TSA_ATTRIBUTE__(scoped_lockable)
#define LIBCAMERA_TSA_GUARDED_BY(x) \
LIBCAMERA_TSA_ATTRIBUTE__(guarded_by(x))
#define LIBCAMERA_TSA_PT_GUARDED_BY(x) \
LIBCAMERA_TSA_ATTRIBUTE__(pt_guarded_by(x))
#define LIBCAMERA_TSA_ACQUIRED_BEFORE(...) \
LIBCAMERA_TSA_ATTRIBUTE__(acquired_before(__VA_ARGS__))
#define LIBCAMERA_TSA_ACQUIRED_AFTER(...) \
LIBCAMERA_TSA_ATTRIBUTE__(acquired_after(__VA_ARGS__))
#define LIBCAMERA_TSA_REQUIRES(...) \
LIBCAMERA_TSA_ATTRIBUTE__(requires_capability(__VA_ARGS__))
#define LIBCAMERA_TSA_REQUIRES_SHARED(...) \
LIBCAMERA_TSA_ATTRIBUTE__(requires_shared_capability(__VA_ARGS__))
#define LIBCAMERA_TSA_ACQUIRE(...) \
LIBCAMERA_TSA_ATTRIBUTE__(acquire_capability(__VA_ARGS__))
#define LIBCAMERA_TSA_ACQUIRE_SHARED(...) \
LIBCAMERA_TSA_ATTRIBUTE__(acquire_shared_capability(__VA_ARGS__))
#define LIBCAMERA_TSA_RELEASE(...) \
LIBCAMERA_TSA_ATTRIBUTE__(release_capability(__VA_ARGS__))
#define LIBCAMERA_TSA_RELEASE_SHARED(...) \
LIBCAMERA_TSA_ATTRIBUTE__(release_shared_capability(__VA_ARGS__))
#define LIBCAMERA_TSA_RELEASE_GENERIC(...) \
LIBCAMERA_TSA_ATTRIBUTE__(release_generic_capability(__VA_ARGS__))
#define LIBCAMERA_TSA_TRY_ACQUIRE(...) \
LIBCAMERA_TSA_ATTRIBUTE__(try_acquire_capability(__VA_ARGS__))
#define LIBCAMERA_TSA_TRY_ACQUIRE_SHARED(...) \
LIBCAMERA_TSA_ATTRIBUTE__(try_acquire_shared_capability(__VA_ARGS__))
#define LIBCAMERA_TSA_EXCLUDES(...) \
LIBCAMERA_TSA_ATTRIBUTE__(locks_excluded(__VA_ARGS__))
#define LIBCAMERA_TSA_ASSERT_CAPABILITY(x) \
LIBCAMERA_TSA_ATTRIBUTE__(assert_capability(x))
#define LIBCAMERA_TSA_ASSERT_SHARED_CAPABILITY(x) \
LIBCAMERA_TSA_ATTRIBUTE__(assert_shared_capability(x))
#define LIBCAMERA_TSA_RETURN_CAPABILITY(x) \
LIBCAMERA_TSA_ATTRIBUTE__(lock_returned(x))
#define LIBCAMERA_TSA_NO_THREAD_SAFETY_ANALYSIS \
LIBCAMERA_TSA_ATTRIBUTE__(no_thread_safety_analysis)

View File

@@ -72,6 +72,7 @@ if cc.get_id() == 'clang'
cpp_arguments += [
'-Wextra-semi',
'-Wthread-safety',
]
endif