projects
/
sbcl.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
1.0.26.2: alloc_code_object facelift
[sbcl.git]
/
src
/
runtime
/
dynbind.c
diff --git
a/src/runtime/dynbind.c
b/src/runtime/dynbind.c
index
77dfd88
..
bb964bf
100644
(file)
--- a/
src/runtime/dynbind.c
+++ b/
src/runtime/dynbind.c
@@
-44,7
+44,6
@@
void bind_variable(lispobj symbol, lispobj value, void *th)
if(!sym->tls_index) {
lispobj *tls_index_lock=
&((struct symbol *)native_pointer(TLS_INDEX_LOCK))->value;
if(!sym->tls_index) {
lispobj *tls_index_lock=
&((struct symbol *)native_pointer(TLS_INDEX_LOCK))->value;
- clear_pseudo_atomic_interrupted(th);
set_pseudo_atomic_atomic(th);
get_spinlock(tls_index_lock,(long)th);
if(!sym->tls_index) {
set_pseudo_atomic_atomic(th);
get_spinlock(tls_index_lock,(long)th);
if(!sym->tls_index) {
@@
-81,6
+80,7
@@
unbind(void *th)
SetTlSymbolValue(symbol, binding->value,thread);
binding->symbol = 0;
SetTlSymbolValue(symbol, binding->value,thread);
binding->symbol = 0;
+ binding->value = 0;
SetBSP(binding);
}
SetBSP(binding);
}
@@
-102,6
+102,7
@@
unbind_to_here(lispobj *bsp,void *th)
SetTlSymbolValue(symbol, binding->value,thread);
}
binding->symbol = 0;
SetTlSymbolValue(symbol, binding->value,thread);
}
binding->symbol = 0;
+ binding->value = 0;
}
}
SetBSP(binding);
}
}
SetBSP(binding);