diff options
Diffstat (limited to 'lang/gcc12')
-rw-r--r-- | lang/gcc12/Makefile | 2 | ||||
-rw-r--r-- | lang/gcc12/files/patch-libsanitizer_asan_asan__linux.cpp | 18 |
2 files changed, 19 insertions, 1 deletions
diff --git a/lang/gcc12/Makefile b/lang/gcc12/Makefile index 529e2595718a..5d7601f3635f 100644 --- a/lang/gcc12/Makefile +++ b/lang/gcc12/Makefile @@ -1,6 +1,6 @@ PORTNAME= gcc PORTVERSION= 12.2.0 -PORTREVISION= 3 +PORTREVISION= 4 CATEGORIES= lang MASTER_SITES= GCC PKGNAMESUFFIX= ${SUFFIX} diff --git a/lang/gcc12/files/patch-libsanitizer_asan_asan__linux.cpp b/lang/gcc12/files/patch-libsanitizer_asan_asan__linux.cpp new file mode 100644 index 000000000000..22630767b114 --- /dev/null +++ b/lang/gcc12/files/patch-libsanitizer_asan_asan__linux.cpp @@ -0,0 +1,18 @@ +Since the vDSO shared librares on Linux and FreeBSD are called +differently, the initialization order check fails on FreeBSD. +This patch fixes it by ignoring [vdso] instead of linux-vdso.so. + +GCC gets the original file from the LLVM Project, so this patch should +probably be upstreamed directly to the LLVM Project rather than to GCC. + +--- libsanitizer/asan/asan_linux.cpp.orig 2022-11-23 10:52:45 UTC ++++ libsanitizer/asan/asan_linux.cpp +@@ -135,7 +135,7 @@ static int FindFirstDSOCallback(struct dl_phdr_info *i + return 0; + + // Ignore vDSO +- if (internal_strncmp(info->dlpi_name, "linux-", sizeof("linux-") - 1) == 0) ++ if (internal_strncmp(info->dlpi_name, "[vdso]", sizeof("[vdso]") - 1) == 0) + return 0; + + #if SANITIZER_FREEBSD || SANITIZER_NETBSD |