public inbox for dev@dpdk.org
 help / color / mirror / Atom feed
* [RFC 0/1] support ThreadSanitizer
@ 2025-04-08 13:05 Dengdui Huang
  2025-04-08 13:05 ` [RFC 1/1] build: " Dengdui Huang
  0 siblings, 1 reply; 3+ messages in thread
From: Dengdui Huang @ 2025-04-08 13:05 UTC (permalink / raw)
  To: dev; +Cc: lihuisong, fengchengwen, haijie1, liuyonglong

When I tried to enable TSan on DPDK using this patch, DPDK cannot be initialized.

When the DPDK initializes the memseg, a large number of address space is reserved.
However, The introduction of ThreadSanitizer brings a large amount of memory overhead.
As a result, the address space is insufficient and the DPDK cannot be initialized.

I fixed it by changing the value of the macro RTE_MAX_MEM_MB,
but I know that's not a good idea. Suggestions are welcome.

Dengdui Huang (1):
  build: support ThreadSanitizer

 config/meson.build | 14 ++++++++++++++
 1 file changed, 14 insertions(+)

-- 
2.33.0


^ permalink raw reply	[flat|nested] 3+ messages in thread

* [RFC 1/1] build: support ThreadSanitizer
  2025-04-08 13:05 [RFC 0/1] support ThreadSanitizer Dengdui Huang
@ 2025-04-08 13:05 ` Dengdui Huang
  2026-03-31 17:50   ` Stephen Hemminger
  0 siblings, 1 reply; 3+ messages in thread
From: Dengdui Huang @ 2025-04-08 13:05 UTC (permalink / raw)
  To: dev; +Cc: lihuisong, fengchengwen, haijie1, liuyonglong

ThreadSanitizer is a tool that detects data races. It consists of a
compiler instrumentation module and a run-time library.
Typical slowdown introduced by ThreadSanitizer is about 5x-15x.
Typical memory overhead introduced by ThreadSanitizer is about 5x-10x.

UBSan is integrated with gcc and clang and can be enabled via a meson
option: -Db_sanitize=thread.

Signed-off-by: Dengdui Huang <huangdengdui@huawei.com>
---
 config/meson.build | 14 ++++++++++++++
 1 file changed, 14 insertions(+)

diff --git a/config/meson.build b/config/meson.build
index f31fef216c..dca1e2b5a4 100644
--- a/config/meson.build
+++ b/config/meson.build
@@ -519,6 +519,20 @@ if get_option('b_sanitize') == 'address' or get_option('b_sanitize') == 'address
     endif
 endif
 
+if get_option('b_sanitize') == 'thread'
+    if is_windows
+        error('TSan is not supported on windows')
+    endif
+
+    if cc.get_id() == 'gcc'
+        tsan_dep = cc.find_library('tsan', required: true)
+        if (not cc.links('int main(int argc, char *argv[]) { return 0; }',
+                dependencies: tsan_dep))
+            error('broken dependency, "libtsan"')
+        endif
+    endif
+endif
+
 if get_option('default_library') == 'both'
     error( '''
  Unsupported value "both" for "default_library" option.
-- 
2.33.0


^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [RFC 1/1] build: support ThreadSanitizer
  2025-04-08 13:05 ` [RFC 1/1] build: " Dengdui Huang
@ 2026-03-31 17:50   ` Stephen Hemminger
  0 siblings, 0 replies; 3+ messages in thread
From: Stephen Hemminger @ 2026-03-31 17:50 UTC (permalink / raw)
  To: Dengdui Huang; +Cc: dev, lihuisong, fengchengwen, haijie1, liuyonglong

On Tue, 8 Apr 2025 21:05:56 +0800
Dengdui Huang <huangdengdui@huawei.com> wrote:

> ThreadSanitizer is a tool that detects data races. It consists of a
> compiler instrumentation module and a run-time library.
> Typical slowdown introduced by ThreadSanitizer is about 5x-15x.
> Typical memory overhead introduced by ThreadSanitizer is about 5x-10x.
> 
> UBSan is integrated with gcc and clang and can be enabled via a meson
> option: -Db_sanitize=thread.
> 
> Signed-off-by: Dengdui Huang <huangdengdui@huawei.com>
> ---

This didn't look right to me, so asked AI for review.
Please address these comments.

Review: [RFC 1/1] build: support ThreadSanitizer

Patch 1/1 - build: support ThreadSanitizer

Commit message:

Warning: The commit message says "UBSan is integrated with gcc and clang
and can be enabled via a meson option: -Db_sanitize=thread." This is
confusing -- UBSan is the Undefined Behavior Sanitizer, not the Thread
Sanitizer. This sentence appears to be copy-pasted from the UBSan block
and should say "TSan is integrated with gcc and clang..."

Error: The patch uses `get_option('b_sanitize') == 'thread'` (exact
string match) but upstream ASan and UBSan blocks use `.contains()`.
The meson `b_sanitize` option accepts comma-separated values like
`'address,undefined'`. Using `== 'thread'` means the TSan block will
NOT trigger if someone passes `-Db_sanitize=thread,undefined` or any
compound value. Must use `.contains('thread')` to match the existing
pattern:

    if get_option('b_sanitize').contains('thread')

Warning: The ASan and UBSan blocks for GCC both add the library to
link arguments and to `dpdk_extra_ldflags` so that downstream consumers
(pkg-config, static linking) also get the flag. The TSan block is
missing both:

    add_project_link_arguments('-ltsan', language: 'c')
    dpdk_extra_ldflags += '-ltsan'

Without these, the DPDK build itself may link (meson's `b_sanitize`
adds `-fsanitize=thread` to the compiler), but applications linking
against DPDK's static libraries via pkg-config will fail to resolve
TSan symbols.

Info: TSan and ASan are mutually exclusive -- they cannot be used
together. Consider adding a check at the top of the TSan block:

    if get_option('b_sanitize').contains('address')
        error('TSan and ASan cannot be used together')
    endif

This would give a clear error message instead of cryptic linker
failures.

Info: It may be worth adding a `dpdk_conf.set10('RTE_THREAD_SANITIZER', true)`
define (analogous to `RTE_MALLOC_ASAN`) so that DPDK code can use
`#if defined(RTE_THREAD_SANITIZER)` to annotate custom synchronization
primitives with TSan annotations (`__tsan_acquire`, `__tsan_release`,
etc.). Without these annotations, TSan will produce many false positives
on DPDK's custom locking (rte_spinlock, rte_rwlock, rte_ring) since
these use inline atomics that TSan cannot automatically recognize as
synchronization. This would be the main value of build-level TSan
support beyond what the user gets from just passing `-Db_sanitize=thread`.

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2026-03-31 17:50 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-04-08 13:05 [RFC 0/1] support ThreadSanitizer Dengdui Huang
2025-04-08 13:05 ` [RFC 1/1] build: " Dengdui Huang
2026-03-31 17:50   ` Stephen Hemminger

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox