~ chicken-core (chicken-5) 330f6a29b73288cf2ff5ac3650c2e35038ac9fb9


commit 330f6a29b73288cf2ff5ac3650c2e35038ac9fb9
Author:     felix <bunny351@gmail.com>
AuthorDate: Mon May 31 14:54:51 2010 +0200
Commit:     felix <bunny351@gmail.com>
CommitDate: Mon May 31 14:54:51 2010 +0200

    lifted C_stack_check out of looping direct procedures (suggested by Benedikt Rosenau)

diff --git a/c-backend.scm b/c-backend.scm
index 916a87df..fac2058a 100644
--- a/c-backend.scm
+++ b/c-backend.scm
@@ -855,11 +855,9 @@
 			     (gen #t "C_word ab[" demand "],*a=ab;") ) ]
 			[else
 			 (unless direct (gen #t "C_word *a;"))
-			 (when looping (gen #t "loop:")) 
 			 (when (and direct (not unsafe) (not disable-stack-overflow-checking))
-			   ;;XXX this can be lifted out of the loop, if the procedure
-			   ;;    does not allocate (suggested by Benedikt Rosenau):
-			   (gen #t "C_stack_check;") ) ] )
+			   (gen #t "C_stack_check;") )
+			 (when looping (gen #t "loop:")) ] )
 		  (when (and external (not unsafe) (not no-argc-checks) (not customizable))
 		    ;; (not customizable) implies empty-closure
 		    (if (eq? rest-mode 'none)
@@ -873,12 +871,6 @@
 	   (when (and (not (eq? 'toplevel id))
 		      (not direct)
 		      (or rest external (> demand 0)) )
-;; 	     (cond [(> nec 1)
-;; 		    (gen #t "C_adjust_stack(" nec ");")
-;; 		    (do ([i (if empty-closure 1 0) (+ i 1)])
-;; 			((>= i n))
-;; 		      (gen #t "C_rescue(t" i #\, (- n i 1) ");") ) ]
-;; 		   [(= nec 1) (gen #t "C_save(" (if empty-closure "t1" "t0") ");")] )
 	     (cond [rest
 		    (gen #t (if (> nec 0) "C_save_and_reclaim" "C_reclaim") "((void*)tr" n #\r)
 		    (gen ",(void*)" id "r")
Trap