projects
/
ghc-hetmet.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Make FamInst warning-free
[ghc-hetmet.git]
/
rts
/
Exception.cmm
diff --git
a/rts/Exception.cmm
b/rts/Exception.cmm
index
6815b79
..
daa8e4f
100644
(file)
--- a/
rts/Exception.cmm
+++ b/
rts/Exception.cmm
@@
-13,9
+13,7
@@
#include "Cmm.h"
#include "RaiseAsync.h"
#include "Cmm.h"
#include "RaiseAsync.h"
-#ifdef __PIC__
-import base_GHCziBase_True_closure;
-#endif
+import ghczmprim_GHCziBool_True_closure;
/* -----------------------------------------------------------------------------
Exception Primitives
/* -----------------------------------------------------------------------------
Exception Primitives
@@
-214,6
+212,11
@@
killThreadzh_fast
* If the exception went to a catch frame, we'll just continue from
* the handler.
*/
* If the exception went to a catch frame, we'll just continue from
* the handler.
*/
+ loop:
+ if (StgTSO_what_next(target) == ThreadRelocated::I16) {
+ target = StgTSO_link(target);
+ goto loop;
+ }
if (target == CurrentTSO) {
SAVE_THREAD_STATE();
/* ToDo: what if the current thread is blocking exceptions? */
if (target == CurrentTSO) {
SAVE_THREAD_STATE();
/* ToDo: what if the current thread is blocking exceptions? */
@@
-435,8
+438,8
@@
retry_pop_stack:
Sp(5) = stg_raise_ret_info;
Sp(4) = stg_noforceIO_info; // required for unregisterised
Sp(3) = exception; // the AP_STACK
Sp(5) = stg_raise_ret_info;
Sp(4) = stg_noforceIO_info; // required for unregisterised
Sp(3) = exception; // the AP_STACK
- Sp(2) = base_GHCziBase_True_closure; // dummy breakpoint info
- Sp(1) = base_GHCziBase_True_closure; // True <=> a breakpoint
+ Sp(2) = ghczmprim_GHCziBool_True_closure; // dummy breakpoint info
+ Sp(1) = ghczmprim_GHCziBool_True_closure; // True <=> a breakpoint
R1 = ioAction;
jump RET_LBL(stg_ap_pppv);
}
R1 = ioAction;
jump RET_LBL(stg_ap_pppv);
}