summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--bridges/source/cpp_uno/gcc3_linux_x86-64/callvirtualmethod.cxx11
1 files changed, 11 insertions, 0 deletions
diff --git a/bridges/source/cpp_uno/gcc3_linux_x86-64/callvirtualmethod.cxx b/bridges/source/cpp_uno/gcc3_linux_x86-64/callvirtualmethod.cxx
index 04dd2dc6a5f6..bf3e7f388108 100644
--- a/bridges/source/cpp_uno/gcc3_linux_x86-64/callvirtualmethod.cxx
+++ b/bridges/source/cpp_uno/gcc3_linux_x86-64/callvirtualmethod.cxx
@@ -27,6 +27,13 @@
#include "abi.hxx"
#include "callvirtualmethod.hxx"
+#if defined(__has_feature)
+# if __has_feature(memory_sanitizer)
+# include <sanitizer/msan_interface.h>
+# define MEMORY_SANITIZER
+# endif
+#endif
+
// The call instruction within the asm block of callVirtualMethod may throw
// exceptions. At least GCC 4.7.0 with -O0 would create (unnecessary)
// .gcc_exception_table call-site table entries around all other calls in this
@@ -154,6 +161,10 @@ void CPPU_CURRENT_NAMESPACE::callVirtualMethod(
*static_cast<float *>(pRegisterReturn) = *reinterpret_cast<float *>(&data.xmm0);
break;
case typelib_TypeClass_DOUBLE:
+#if defined(MEMORY_SANITIZER)
+ // In the absence of a better idea just unpoison this
+ __msan_unpoison(&data.xmm0, sizeof(data.xmm0));
+#endif
*static_cast<double *>( pRegisterReturn ) = data.xmm0;
break;
default: