1 /* How much read-only Lisp storage a dumped Emacs needs.
2 Copyright (C) 1993, 2001-2021 Free Software Foundation, Inc.
3
4 This file is part of GNU Emacs.
5
6 GNU Emacs is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or (at
9 your option) any later version.
10
11 GNU Emacs is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>. */
18
19 #ifndef EMACS_PURESIZE_H
20 #define EMACS_PURESIZE_H
21
22 #include "lisp.h"
23
24 INLINE_HEADER_BEGIN
25
26 /* Define PURESIZE, the number of bytes of pure Lisp code to leave space for.
27
28 At one point, this was defined in config.h, meaning that changing
29 PURESIZE would make Make recompile all of Emacs. But only a few
30 files actually use PURESIZE, so we split it out to its own .h file.
31
32 Make sure to include this file after config.h, since that tells us
33 whether we are running X windows, which tells us how much pure
34 storage to allocate. */
35
36 /* First define a measure of the amount of data we have. */
37
38 /* A system configuration file may set this to request a certain extra
39 amount of storage. This is a lot more update-robust that defining
40 BASE_PURESIZE or even PURESIZE directly. */
41 #ifndef SYSTEM_PURESIZE_EXTRA
42 #define SYSTEM_PURESIZE_EXTRA 0
43 #endif
44
45 #ifndef SITELOAD_PURESIZE_EXTRA
46 #define SITELOAD_PURESIZE_EXTRA 0
47 #endif
48
49 #ifndef BASE_PURESIZE
50 #define BASE_PURESIZE (2000000 + SYSTEM_PURESIZE_EXTRA + SITELOAD_PURESIZE_EXTRA)
51 #endif
52
53 /* Increase BASE_PURESIZE by a ratio depending on the machine's word size. */
54 #ifndef PURESIZE_RATIO
55 #if EMACS_INT_MAX >> 31 != 0
56 #if PTRDIFF_MAX >> 31 != 0
57 #define PURESIZE_RATIO 10 / 6 /* Don't surround with `()'. */
58 #else
59 #define PURESIZE_RATIO 8 / 6 /* Don't surround with `()'. */
60 #endif
61 #else
62 #define PURESIZE_RATIO 1
63 #endif
64 #endif
65
66 #ifdef ENABLE_CHECKING
67 /* ENABLE_CHECKING somehow increases the purespace used, probably because
68 it tends to cause some macro arguments to be evaluated twice. This is
69 a bug, but it's difficult to track it down. */
70 #define PURESIZE_CHECKING_RATIO 12 / 10 /* Don't surround with `()'. */
71 #else
72 #define PURESIZE_CHECKING_RATIO 1
73 #endif
74
75 /* This is the actual size in bytes to allocate. */
76 #ifndef PURESIZE
77 #define PURESIZE (BASE_PURESIZE * PURESIZE_RATIO * PURESIZE_CHECKING_RATIO)
78 #endif
79
80 extern AVOID pure_write_error (Lisp_Object);
81
82 extern EMACS_INT pure[];
83
84 /* The puresize_h_* macros are private to this include file. */
85
86 /* True if PTR is pure. */
87
88 #define puresize_h_PURE_P(ptr) \
89 ((uintptr_t) (ptr) - (uintptr_t) pure <= PURESIZE)
90
91 INLINE bool
PURE_P(void * ptr)92 PURE_P (void *ptr)
93 {
94 return puresize_h_PURE_P (ptr);
95 }
96
97 /* Signal an error if OBJ is pure. PTR is OBJ untagged. */
98
99 #define puresize_h_CHECK_IMPURE(obj, ptr) \
100 (PURE_P (ptr) ? pure_write_error (obj) : (void) 0)
101
102 INLINE void
CHECK_IMPURE(Lisp_Object obj,void * ptr)103 CHECK_IMPURE (Lisp_Object obj, void *ptr)
104 {
105 puresize_h_CHECK_IMPURE (obj, ptr);
106 }
107
108 #if DEFINE_KEY_OPS_AS_MACROS
109 # define PURE_P(ptr) puresize_h_PURE_P (ptr)
110 # define CHECK_IMPURE(obj, ptr) puresize_h_CHECK_IMPURE (obj, ptr)
111 #endif
112
113 INLINE_HEADER_END
114
115 #endif /* EMACS_PURESIZE_H */
116