Initial revision
[chise/xemacs-chise.git.1] / src / m / aviion.h
1 /* machine description 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 2, 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 XEmacs; see the file COPYING.  If not, write to
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19 Boston, MA 02111-1307, USA.  */
20
21 /* Synched up with: FSF 19.31. */
22
23 /* Define WORD_MACHINE if addresses and such have
24  * to be corrected before they can be used as byte counts.  */
25
26 #define WORD_MACHINE
27
28 /* Define DATA_SEG_BITS if pointers need to be corrected with
29    a segment field.  */
30
31 #ifdef FIX_ADDRESS
32 #define DATA_SEG_BITS 0xef000000
33 #endif
34
35 /* Now define a symbol for the cpu type, if your compiler
36    does not define it automatically:
37    Ones defined so far include vax, m68000, ns16000, pyramid,
38    orion, tahoe, APOLLO and many others */
39
40 /*#ifndef m88k*/
41 /*#define m88k*/
42 /*#endif*/
43
44 /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend
45    the bit field into an int.  In other words, if bit fields
46    are always unsigned.
47
48    If you use NO_UNION_TYPE, this flag does not matter.  */
49
50 #define EXPLICIT_SIGN_EXTEND
51
52 /* Data type of load average, as read out of kmem.  */
53
54 /* #define LOAD_AVE_TYPE long */
55
56 /* Convert that into an integer that is 100 for a load average of 1.0  */
57
58 /* #define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0 / FSCALE) */
59
60 /* Define CANNOT_DUMP on machines where unexec does not work.
61    Then the function dump-emacs will not be defined
62    and temacs will do (load "loadup") automatically unless told otherwise.  */
63
64 /* #define CANNOT_DUMP */
65
66 /* Define VIRT_ADDR_VARIES if the virtual addresses of
67    pure and impure space as loaded can vary, and even their
68    relative order cannot be relied on.
69
70    Otherwise Emacs assumes that text space precedes data space,
71    numerically.  */
72
73 /* #define VIRT_ADDR_VARIES */
74
75 /* Define C_ALLOCA if this machine does not support a true alloca
76    and the one written in C should be used instead.
77    Define HAVE_ALLOCA to say that the system provides a properly
78    working alloca function and it should be used.
79    Define neither one if an assembler-language alloca
80    in the file alloca.s should be used.  */
81
82 /* #define C_ALLOCA */
83 #define HAVE_ALLOCA
84 #define alloca(x) __builtin_alloca(x)
85
86 /* Define NO_REMAP if memory segmentation makes it not work well
87    to change the boundary between the text section and data section
88    when Emacs is dumped.  If you define this, the preloaded Lisp
89    code will not be sharable; but that's better than failing completely.  */
90
91 #define NO_REMAP
92
93 /* Define ADDR_CORRECT(ADDR) to be a macro to correct an int which is
94    the bit pattern of a pointer to a byte into an int which is the
95    number of a byte.
96
97    This macro has a default definition which is usually right.
98    This default definition is a no-op on most machines (where a
99    pointer looks like an int) but not on all machines. */
100
101 #define ADDR_CORRECT(ADDR) ((int)ADDR)
102
103 /* Some machines that use COFF executables require that each section
104    start on a certain boundary *in the COFF file*.  Such machines should
105    define SECTION_ALIGNMENT to a mask of the low-order bits that must be
106    zero on such a boundary.  This mask is used to control padding between
107    segments in the COFF file.
108
109    If SECTION_ALIGNMENT is not defined, the segments are written
110    consecutively with no attempt at alignment.  This is right for
111    unmodified system V.  */
112
113 #define SECTION_ALIGNMENT 0x7
114