From 05ef28dd1145473d84c13efb9de2b563741fea42 Mon Sep 17 00:00:00 2001 From: =?utf8?q?David=20V=C3=A1zquez?= Date: Sat, 1 Jun 2013 12:47:17 +0100 Subject: [PATCH] Fix bug in reduce-component --- experimental/compiler.lisp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/experimental/compiler.lisp b/experimental/compiler.lisp index 7b757f7..6f6de91 100644 --- a/experimental/compiler.lisp +++ b/experimental/compiler.lisp @@ -925,7 +925,8 @@ (block-pred block) pred))))))) (defun reduce-component (&optional (component *component*)) - (let* ((list-blocks (component-blocks component)) + (let* ((*component* component) + (list-blocks (component-blocks component)) ;; A vector of the blocks in the component. Blocks are added ;; and deleted always at the fill pointer of the vector. (vector-blocks @@ -949,7 +950,8 @@ (setf (block-succ pred) (remove block (block-succ pred))) (dolist (succ (block-succ block)) (pushnew succ (block-succ pred)) - (setf (block-pred succ) (substitute pred block (block-pred succ))))) + (setf (block-pred succ) (remove block (block-pred succ))) + (pushnew pred (block-pred succ)))) t)) ;; This function duplicates the block in component for each input ;; edge. A technique useful to make a general flowgraph reducible. -- 1.7.10.4