Page MenuHomeFreeBSD

kcsan: add __tsan_mem(cpy|move|set) aliases for clang >= 16
ClosedPublic

Authored by dim on Apr 23 2023, 6:12 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jun 22, 7:11 PM
Unknown Object (File)
Feb 21 2024, 1:13 PM
Unknown Object (File)
Jan 14 2024, 7:11 AM
Unknown Object (File)
Dec 27 2023, 10:45 AM
Unknown Object (File)
Dec 20 2023, 8:19 AM
Unknown Object (File)
Dec 7 2023, 5:21 AM
Unknown Object (File)
Nov 4 2023, 4:05 PM
Unknown Object (File)
Jul 4 2023, 12:03 AM
Subscribers

Details

Summary

After https://github.com/llvm/llvm-project/commit/b4257d3bf58c ("[tsan]
Replace mem intrinsics with calls to interceptors") intrinsic calls to
memcpy, memmove or memset will directly call sanitizer interceptors,
e.g. tsan_memcpy, tsan_memmove or __tsan_memset.

Building GENERIC-KCSAN with clang >= 16 would thus result in link errors
similar to:

ld: error: undefined symbol: __tsan_memcpy
>>> referenced by cam_compat.c:150 (/usr/src/sys/cam/cam_compat.c:150)
>>>               cam_compat.o:(cam_compat_handle_0x17)
>>> referenced by cam_compat.c:151 (/usr/src/sys/cam/cam_compat.c:151)
>>>               cam_compat.o:(cam_compat_handle_0x17)
>>> referenced by cam_compat.c:152 (/usr/src/sys/cam/cam_compat.c:152)
>>>               cam_compat.o:(cam_compat_handle_0x17)
>>> referenced 1692 more times

Similar to subr_msan.c, add aliases from the existing kcsan_* versions
of these functions to __tsan_* names.

MFC after: 3 days

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable