ac0043e104dc93870bd29c57f5a28add37821f0e
[sbcl.git] / src / compiler / generic / parms.lisp
1 ;;;; This file contains some parameterizations of various VM
2 ;;;; attributes common to all architectures.
3
4 ;;;; This software is part of the SBCL system. See the README file for
5 ;;;; more information.
6 ;;;;
7 ;;;; This software is derived from the CMU CL system, which was
8 ;;;; written at Carnegie Mellon University and released into the
9 ;;;; public domain. The software is in the public domain and is
10 ;;;; provided with absolutely no warranty. See the COPYING and CREDITS
11 ;;;; files for more information.
12
13 (in-package "SB!VM")
14
15 (defparameter *c-callable-static-symbols*
16   '(sub-gc
17     sb!kernel::internal-error
18     sb!kernel::control-stack-exhausted-error
19     sb!kernel::heap-exhausted-error
20     sb!kernel::undefined-alien-variable-error
21     sb!kernel::undefined-alien-function-error
22     sb!kernel::memory-fault-error
23     sb!di::handle-breakpoint
24     fdefinition-object
25     #!+sb-thread sb!thread::run-interruption
26     #!+win32 sb!kernel::handle-win32-exception))
27
28 (defparameter *common-static-symbols*
29   '(t
30
31     ;; filled in by the C code to propagate to Lisp
32     *posix-argv* *core-string*
33
34     ;; free pointers.  Note that these are FIXNUM word counts, not (as
35     ;; one might expect) byte counts or SAPs. The reason seems to be
36     ;; that by representing them this way, we can avoid consing
37     ;; bignums.  -- WHN 2000-10-02
38     *read-only-space-free-pointer*
39     *static-space-free-pointer*
40     *initial-dynamic-space-free-pointer*
41
42     ;; things needed for non-local-exit
43     *current-catch-block*
44     *current-unwind-protect-block*
45
46     ;; stack pointers
47     *binding-stack-start*
48     *control-stack-start*
49     *control-stack-end*
50
51     ;; interrupt handling
52     *free-interrupt-context-index*
53     sb!unix::*interrupts-enabled*
54     sb!unix::*interrupt-pending*
55     *gc-inhibit*
56     *gc-pending*
57
58     ;; hash table weaknesses
59     :key
60     :value
61     :key-and-value
62     :key-or-value))