diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index a08d231b72d301930cd27ed9b0e225e20b7cfb55..1c0a45e5e7ffe3be07f996045d418fe267392cee 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2015-01-21  Bernd Edlinger  <bernd.edlinger@hotmail.de>
+
+	* gimplify.c (gimplify_function_tree): Check the no_sanitize_thread
+	decl attribute.
+
 2015-01-21  David Sherwood  <david.sherwood@arm.com>
 	    Tejas Belagod <Tejas.Belagod@arm.com>
 
diff --git a/gcc/gimplify.c b/gcc/gimplify.c
index 947b0af8d566c8b0b29356096d7c07029720453c..1353ada2f857970470f6adbd36fcdc26c45867af 100644
--- a/gcc/gimplify.c
+++ b/gcc/gimplify.c
@@ -9258,7 +9258,8 @@ gimplify_function_tree (tree fndecl)
       bind = new_bind;
     }
 
-  if (flag_sanitize & SANITIZE_THREAD)
+  if ((flag_sanitize & SANITIZE_THREAD) != 0
+      && !lookup_attribute ("no_sanitize_thread", DECL_ATTRIBUTES (fndecl)))
     {
       gcall *call = gimple_build_call_internal (IFN_TSAN_FUNC_EXIT, 0);
       gimple tf = gimple_build_try (seq, call, GIMPLE_TRY_FINALLY);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index f679c04144d24de4bdc64395ef4c4a9115cc9b47..e1a4ce87cfcca1d8cbf6c24e3d4b32a659f0129c 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2015-01-21  Bernd Edlinger  <bernd.edlinger@hotmail.de>
+
+	* gcc/testsuite/c-c++-common/tsan/step.c: New testcase.
+
 2015-01-21  Christophe Lyon  <christophe.lyon@linaro.org>
 
 	* gcc.target/aarch64/advsimd-intrinsics/vqdmull_n.c: New file.
diff --git a/gcc/testsuite/c-c++-common/tsan/step.c b/gcc/testsuite/c-c++-common/tsan/step.c
new file mode 100644
index 0000000000000000000000000000000000000000..ce9edd454a031208ee5fa05fdbc64b231f49270a
--- /dev/null
+++ b/gcc/testsuite/c-c++-common/tsan/step.c
@@ -0,0 +1,15 @@
+/* { dg-do compile } */
+
+extern int sched_yield (void);
+static volatile int serial = 0;
+
+__attribute__((no_sanitize_thread))
+void step (int i)
+{
+   while (__atomic_load_n (&serial, __ATOMIC_ACQUIRE) != i - 1)
+     sched_yield ();
+   __atomic_store_n (&serial, i, __ATOMIC_RELEASE);
+}
+
+/* { dg-final { scan-assembler-not "__tsan_func_entry" } } */
+/* { dg-final { scan-assembler-not "__tsan_func_exit" } } */