X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=make-target-2.sh;h=fb27e2743c1f9954372a92959a89b2bbb6621ac4;hb=b2ad48f269cd6b9403820588d65eac526e4e32fd;hp=58bd72310590c57c192d7937b8019a9f2ad90436;hpb=4eb1a6d3ad2b7dcc19ac0ec979a1eb1eb049659a;p=sbcl.git diff --git a/make-target-2.sh b/make-target-2.sh index 58bd723..fb27e27 100644 --- a/make-target-2.sh +++ b/make-target-2.sh @@ -28,10 +28,10 @@ echo //doing warm init ./src/runtime/sbcl \ --core output/cold-sbcl.core \ --sysinit /dev/null --userinit /dev/null <<-'EOF' || exit 1 - ;; Now that we use the compiler for macros, interpreted ;; /SHOW doesn't work until later in init. #+sb-show (print "/hello, world!") + (sb!ext:purify) ;; Until PRINT-OBJECT and other machinery is set up, ;; we want limits on printing to avoid infinite output. @@ -42,6 +42,7 @@ echo //doing warm init ;; initialized yet.) (setq *print-length* 10) (setq *print-level* 5) + (setq *print-circle* t) ;; Do warm init. #+sb-show (print "/about to LOAD warm.lisp") @@ -56,19 +57,40 @@ echo //doing warm init ;; control variables to their ANSI defaults. (setq *print-length* nil) (setq *print-level* nil) + (setq *print-circle* nil) ;; FIXME: Why is it that, at least on x86 sbcl-0.6.12.46, ;; GC :FULL T isn't nearly as effective as PURIFY here? ;; (GC :FULL T gets us down to about 38 Mbytes, but PURIFY ;; gets us down to about 19 Mbytes.) - (let ((*gc-notify-stream* *standard-output*)) - (sb-int:/show "done with warm.lisp, about to GC :FULL T") - (gc :full t)) + (sb-int:/show "done with warm.lisp, about to GC :FULL T") + (gc :full t) + + ;; resetting compilation policy to neutral values in + ;; preparation for SAVE-LISP-AND-DIE as final SBCL core (not + ;; in warm.lisp because SB-C::*POLICY* has file scope) + (sb-int:/show "setting compilation policy to neutral values") + (proclaim '(optimize (compilation-speed 1) + (debug 1) + (inhibit-warnings 1) + (safety 1) + (space 1) + (speed 1))) + + ;; Lock internal packages + #+sb-package-locks + (dolist (p (list-all-packages)) + (unless (member p (mapcar #'find-package '(:keyword :cl-user))) + (lock-package p))) (sb-int:/show "done with warm.lisp, about to SAVE-LISP-AND-DIE") ;; Even if /SHOW output was wanted during build, it's probably ;; not wanted by default after build is complete. (And if it's ;; wanted, it can easily be turned back on.) #+sb-show (setf sb-int:*/show* nil) + ;; The system is complete now, all standard functions are + ;; defined. + (sb-kernel::ctype-of-cache-clear) + (setq sb-c::*flame-on-necessarily-undefined-function* t) (sb-ext:save-lisp-and-die "output/sbcl.core" :purify t) EOF