projects
/
sbcl.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
1.0.16.33: UNION and NUNION work with :TEST-NOT again
[sbcl.git]
/
src
/
compiler
/
ir2tran.lisp
diff --git
a/src/compiler/ir2tran.lisp
b/src/compiler/ir2tran.lisp
index
c28e37e
..
f2c5381
100644
(file)
--- a/
src/compiler/ir2tran.lisp
+++ b/
src/compiler/ir2tran.lisp
@@
-57,7
+57,10
@@
(defun emit-make-value-cell (node block value res)
(event make-value-cell-event node)
(let ((leaf (tn-leaf res)))
(defun emit-make-value-cell (node block value res)
(event make-value-cell-event node)
(let ((leaf (tn-leaf res)))
- (vop make-value-cell node block value (and leaf (leaf-dynamic-extent leaf))
+ (vop make-value-cell node block value
+ (and leaf (leaf-dynamic-extent leaf)
+ ;; FIXME: See bug 419
+ (policy node (> stack-allocate-value-cells 1)))
res)))
\f
;;;; leaf reference
res)))
\f
;;;; leaf reference
@@
-1182,6
+1185,7
@@
#!+unwind-to-frame-and-call-vop
(when (and (lambda-allow-instrumenting fun)
#!+unwind-to-frame-and-call-vop
(when (and (lambda-allow-instrumenting fun)
+ (not (lambda-inline-expanded fun))
(lambda-return fun)
(policy fun (>= insert-debug-catch 2)))
(vop sb!vm::bind-sentinel node block))
(lambda-return fun)
(policy fun (>= insert-debug-catch 2)))
(vop sb!vm::bind-sentinel node block))
@@
-1213,6
+1217,7
@@
(returns (tail-set-info (lambda-tail-set fun))))
#!+unwind-to-frame-and-call-vop
(when (and (lambda-allow-instrumenting fun)
(returns (tail-set-info (lambda-tail-set fun))))
#!+unwind-to-frame-and-call-vop
(when (and (lambda-allow-instrumenting fun)
+ (not (lambda-inline-expanded fun))
(policy fun (>= insert-debug-catch 2)))
(vop sb!vm::unbind-sentinel node block))
(cond
(policy fun (>= insert-debug-catch 2)))
(vop sb!vm::unbind-sentinel node block))
(cond