-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #13 from jean-edouard/x64_more_segv
ghc: add yet another segv fix
- Loading branch information
Showing
2 changed files
with
57 additions
and
0 deletions.
There are no files selected for viewing
56 changes: 56 additions & 0 deletions
56
...ls/ghc/files/0009-Fix-segfault-in-retainer-profiling-when-using-multiple-cores-5909.patch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
From a5879a6c2412452fbda8c96e9d921c35279b9d9d Mon Sep 17 00:00:00 2001 | ||
From: Simon Marlow <[email protected]> | ||
Date: Tue, 19 Feb 2013 09:58:31 +0000 | ||
Subject: [PATCH] Fix segfault in retainer profiling when using multiple cores | ||
(#5909) | ||
|
||
Thanks to @akio on the ticket for the diagnosis and the patch. I | ||
modified the comments a bit. | ||
--- | ||
rts/sm/Evac.c | 17 +++++++++++++++-- | ||
1 file changed, 15 insertions(+), 2 deletions(-) | ||
|
||
--- a/rts/sm/Evac.c | ||
+++ b/rts/sm/Evac.c | ||
@@ -33,7 +33,7 @@ StgWord64 whitehole_spin = 0; | ||
#define HEAP_ALLOCED_GC(p) HEAP_ALLOCED(p) | ||
#endif | ||
|
||
-#if !defined(PARALLEL_GC) | ||
+#if !defined(PARALLEL_GC) || defined(PROFILING) | ||
#define copy_tag_nolock(p, info, src, size, stp, tag) \ | ||
copy_tag(p, info, src, size, stp, tag) | ||
#endif | ||
@@ -114,6 +114,17 @@ copy_tag(StgClosure **p, const StgInfoTa | ||
const StgInfoTable *new_info; | ||
new_info = (const StgInfoTable *)cas((StgPtr)&src->header.info, (W_)info, MK_FORWARDING_PTR(to)); | ||
if (new_info != info) { | ||
+#ifdef PROFILING | ||
+ // We copied this object at the same time as another | ||
+ // thread. We'll evacuate the object again and the copy | ||
+ // we just made will be discarded at the next GC, but we | ||
+ // may have copied it after the other thread called | ||
+ // SET_EVACUAEE_FOR_LDV(), which would confuse the LDV | ||
+ // profiler when it encounters this closure in | ||
+ // processHeapClosureForDead. So we reset the LDVW field | ||
+ // here. | ||
+ LDVW(to) = 0; | ||
+#endif | ||
return evacuate(p); // does the failed_to_evac stuff | ||
} else { | ||
*p = TAG_CLOSURE(tag,(StgClosure*)to); | ||
@@ -127,11 +138,13 @@ copy_tag(StgClosure **p, const StgInfoTa | ||
#ifdef PROFILING | ||
// We store the size of the just evacuated object in the LDV word so that | ||
// the profiler can guess the position of the next object later. | ||
+ // This is safe only if we are sure that no other thread evacuates | ||
+ // the object again, so we cannot use copy_tag_nolock when PROFILING. | ||
SET_EVACUAEE_FOR_LDV(from, size); | ||
#endif | ||
} | ||
|
||
-#if defined(PARALLEL_GC) | ||
+#if defined(PARALLEL_GC) && !defined(PROFILING) | ||
STATIC_INLINE void | ||
copy_tag_nolock(StgClosure **p, const StgInfoTable *info, | ||
StgClosure *src, nat size, step *stp, StgWord tag) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters