Declare types of END and TEST in N{LIST,VECTOR}-SUBSTITUTE-IF[-NOT]*
[sbcl.git] / src / compiler / x86 / backend-parms.lisp
1 ;;;; that part of the parms.lisp file from original CMU CL which is defined in
2 ;;;; terms of the BACKEND structure
3 ;;;;
4 ;;;; FIXME: When we break up the BACKEND structure, this might be mergeable
5 ;;;; back into the parms.lisp file.
6
7 ;;;; This software is part of the SBCL system. See the README file for
8 ;;;; more information.
9 ;;;;
10 ;;;; This software is derived from the CMU CL system, which was
11 ;;;; written at Carnegie Mellon University and released into the
12 ;;;; public domain. The software is in the public domain and is
13 ;;;; provided with absolutely no warranty. See the COPYING and CREDITS
14 ;;;; files for more information.
15
16 (in-package "SB!VM")
17 \f
18 ;;;; compiler constants
19
20 (def!constant +backend-fasl-file-implementation+ :x86)
21
22 (setf *backend-register-save-penalty* 3)
23
24 (setf *backend-byte-order* :little-endian)
25
26 ;;; KLUDGE: It would seem natural to set this by asking our C runtime
27 ;;; code for it, but mostly we need it for GENESIS, which doesn't in
28 ;;; general have our C runtime code running to ask, so instead we set
29 ;;; it by hand. -- WHN 2001-04-15
30 ;;;
31 ;;; Actually any information that we can retrieve C-side would be
32 ;;; useless in SBCL, since it's possible for otherwise binary
33 ;;; compatible systems to return different values for getpagesize().
34 ;;; -- JES, 2007-01-06
35 (eval-when (:compile-toplevel :load-toplevel :execute)
36   (setf *backend-page-bytes* 4096))
37 ;;; comment from CMU CL:
38 ;;;
39 ;;;   in case we ever wanted to do this for Windows NT..
40 ;;;
41 ;;;   Windows NT uses a memory system granularity of 64K, which means
42 ;;;   everything that gets mapped must be a multiple of that. The real
43 ;;;   page size is 512, but that doesn't do us a whole lot of good.
44 ;;;   Effectively, the page size is 64K.
45 ;;;
46 ;;;   would be: (setf *backend-page-bytes* 65536)
47
48 ;;; The size in bytes of GENCGC cards, i.e. the granularity at which
49 ;;; writes to old generations are logged.  With mprotect-based write
50 ;;; barriers, this must be a multiple of the OS page size.
51 (def!constant gencgc-card-bytes *backend-page-bytes*)
52 ;;; The minimum size of new allocation regions.  While it doesn't
53 ;;; currently make a lot of sense to have a card size lower than
54 ;;; the alloc granularity, it will, once we are smarter about finding
55 ;;; the start of objects.
56 (def!constant gencgc-alloc-granularity 0)
57 ;;; The minimum size at which we release address ranges to the OS.
58 ;;; This must be a multiple of the OS page size.
59 (def!constant gencgc-release-granularity *backend-page-bytes*)