|
|
1.1 root 1: /* m- file for Data General AViiON.
2: Copyright (C) 1985, 1986, 1991 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 1, or (at your option)
9: 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; see the file COPYING. If not, write to
18: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
19:
20:
21: /* The following three symbols give information on
22: the size of various data types. */
23:
24: #define SHORTBITS 16 /* Number of bits in a short */
25:
26: #define INTBITS 32 /* Number of bits in an int */
27:
28: #define LONGBITS 32 /* Number of bits in a long */
29:
30: /* Define BIG_ENDIAN iff lowest-numbered byte in a word
31: is the most significant byte. */
32:
33: #define BIG_ENDIAN
34:
35: /* Define NO_ARG_ARRAY if you cannot take the address of the first of a
36: * group of arguments and treat it as an array of the arguments. */
37:
38: #define NO_ARG_ARRAY
39:
40: /* Define WORD_MACHINE if addresses and such have
41: * to be corrected before they can be used as byte counts. */
42:
43: #define WORD_MACHINE
44:
45: /* Define how to take a char and sign-extend into an int.
46: On machines where char is signed, this is a no-op. */
47:
48: #define SIGN_EXTEND_CHAR(c) (c)
49:
50: /* Define DATA_SEG_BITS if pointers need to be corrected with
51: a segment field. */
52:
53: #ifdef FIX_ADDRESS
54: #define DATA_SEG_BITS 0xef000000
55: #endif
56:
57: /* Now define a symbol for the cpu type, if your compiler
58: does not define it automatically:
59: Ones defined so far include vax, m68000, ns16000, pyramid,
60: orion, tahoe, APOLLO and many others */
61:
62: #ifndef m88k
63: #define m88k
64: #endif
65:
66: /* Use type int rather than a union, to represent Lisp_Object */
67: /* This is desirable for most machines. */
68:
69: #define NO_UNION_TYPE
70:
71: /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend
72: the 24-bit bit field into an int. In other words, if bit fields
73: are always unsigned.
74:
75: If you use NO_UNION_TYPE, this flag does not matter. */
76:
77: #define EXPLICIT_SIGN_EXTEND
78:
79: /* Data type of load average, as read out of kmem. */
80:
81: /* #define LOAD_AVE_TYPE long */
82:
83: /* Convert that into an integer that is 100 for a load average of 1.0 */
84:
85: /* #define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0 / FSCALE) */
86:
87: /* Define CANNOT_DUMP on machines where unexec does not work.
88: Then the function dump-emacs will not be defined
89: and temacs will do (load "loadup") automatically unless told otherwise. */
90:
91: /* #define CANNOT_DUMP */
92:
93: /* Define VIRT_ADDR_VARIES if the virtual addresses of
94: pure and impure space as loaded can vary, and even their
95: relative order cannot be relied on.
96:
97: Otherwise Emacs assumes that text space precedes data space,
98: numerically. */
99:
100: /* #define VIRT_ADDR_VARIES */
101:
102: /* Define C_ALLOCA if this machine does not support a true alloca
103: and the one written in C should be used instead.
104: Define HAVE_ALLOCA to say that the system provides a properly
105: working alloca function and it should be used.
106: Define neither one if an assembler-language alloca
107: in the file alloca.s should be used. */
108:
109: /* #define C_ALLOCA */
110: #define HAVE_ALLOCA
111: #define alloca(x) __builtin_alloca(x)
112:
113: /* Define NO_REMAP if memory segmentation makes it not work well
114: to change the boundary between the text section and data section
115: when Emacs is dumped. If you define this, the preloaded Lisp
116: code will not be sharable; but that's better than failing completely. */
117:
118: #define NO_REMAP
119:
120: /* Use 26 bits instead of 24 for internal pointer values */
121:
122: #define VALBITS 26
123: #define GCTYPEBITS 5
124:
125: /* Define ADDR_CORRECT(ADDR) to be a macro to correct an int which is
126: the bit pattern of a pointer to a byte into an int which is the
127: number of a byte.
128:
129: This macro has a default definition which is usually right.
130: This default definition is a no-op on most machines (where a
131: pointer looks like an int) but not on all machines. */
132:
133: #define ADDR_CORRECT(ADDR) ((int)ADDR)
134:
135: /* Cast pointers to this type to compare them. */
136:
137: #define PNTR_COMPARISON_TYPE void *
138:
139: /* Some machines that use COFF executables require that each section
140: start on a certain boundary *in the COFF file*. Such machines should
141: define SECTION_ALIGNMENT to a mask of the low-order bits that must be
142: zero on such a boundary. This mask is used to control padding between
143: segments in the COFF file.
144:
145: If SECTION_ALIGNMENT is not defined, the segments are written
146: consecutively with no attempt at alignment. This is right for
147: unmodified system V. */
148:
149: #define SECTION_ALIGNMENT 0x7
150:
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.