Mercurial > emacs
annotate src/m/intel386.h @ 90996:f55f9811f5d7
Merge from emacs--devo--0
Patches applied:
* emacs--devo--0 (patch 824-831)
- Update from CVS
- Merge from emacs--rel--22
* emacs--rel--22 (patch 70-74)
- Update from CVS
Revision: emacs@sv.gnu.org/emacs--unicode--0--patch-238
author | Miles Bader <miles@gnu.org> |
---|---|
date | Fri, 27 Jul 2007 10:52:18 +0000 |
parents | 95d0cdf160ea 6aba169c4b1f |
children | 424b655804ca |
rev | line source |
---|---|
525 | 1 /* Machine description file for intel 386. |
75227
e90d04cd455a
Update copyright for years from Emacs 21 to present (mainly adding
Glenn Morris <rgm@gnu.org>
parents:
68651
diff
changeset
|
2 Copyright (C) 1987, 2001, 2002, 2003, 2004, 2005, |
e90d04cd455a
Update copyright for years from Emacs 21 to present (mainly adding
Glenn Morris <rgm@gnu.org>
parents:
68651
diff
changeset
|
3 2006, 2007 Free Software Foundation, Inc. |
456 | 4 |
5 This file is part of GNU Emacs. | |
6 | |
7 GNU Emacs is free software; you can redistribute it and/or modify | |
8 it under the terms of the GNU General Public License as published by | |
78258
6aba169c4b1f
Switch license to GPLv3 or later.
Glenn Morris <rgm@gnu.org>
parents:
75227
diff
changeset
|
9 the Free Software Foundation; either version 3, or (at your option) |
456 | 10 any later version. |
11 | |
12 GNU Emacs is distributed in the hope that it will be useful, | |
13 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 GNU General Public License for more details. | |
16 | |
17 You should have received a copy of the GNU General Public License | |
18 along with GNU Emacs; see the file COPYING. If not, write to | |
64083 | 19 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
20 Boston, MA 02110-1301, USA. */ | |
456 | 21 |
22 | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48433
diff
changeset
|
23 /* The following line tells the configuration script what sort of |
456 | 24 operating system this machine is likely to run. |
25 USUAL-OPSYS="note" | |
26 | |
27 NOTE-START | |
28 Intel 386 (-machine=intel386 or -machine=is386.h) | |
29 | |
30 The possibilities for -opsystem are: bsd4-2, usg5-2-2, usg5-3, | |
2922
7fa859245bd4
Some more changes from Michael K. Johnson for Linux.
Jim Blandy <jimb@redhat.com>
parents:
2677
diff
changeset
|
31 isc2-2, 386-ix, esix, linux, sco3.2v4, and xenix. |
456 | 32 |
33 18.58 should support a wide variety of operating systems. | |
34 Use isc2-2 for Interactive 386/ix version 2.2. | |
35 Use 386ix for prior versions. | |
2922
7fa859245bd4
Some more changes from Michael K. Johnson for Linux.
Jim Blandy <jimb@redhat.com>
parents:
2677
diff
changeset
|
36 Use esix for Esix. |
7fa859245bd4
Some more changes from Michael K. Johnson for Linux.
Jim Blandy <jimb@redhat.com>
parents:
2677
diff
changeset
|
37 Use linux for Linux. |
7fa859245bd4
Some more changes from Michael K. Johnson for Linux.
Jim Blandy <jimb@redhat.com>
parents:
2677
diff
changeset
|
38 It isn't clear what to do on an SCO system. |
456 | 39 |
40 -machine=is386 is used for an Integrated Solutions 386 machine. | |
41 It may also be correct for Microport systems. | |
42 | |
43 Cubix QBx/386 (-machine=intel386 -opsystem=usg5-3) | |
44 | |
45 Changes merged in 19.1. Systems before 2/A/0 may fail to compile etags.c | |
46 due to a compiler bug. | |
47 | |
48 Prime EXL (-machine=intel386 -opsystem=usg5-3) | |
49 | |
50 Minor changes merged in 19.1. | |
51 NOTE-END */ | |
52 | |
9095
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
8892
diff
changeset
|
53 /* Define WORDS_BIG_ENDIAN iff lowest-numbered byte in a word |
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
8892
diff
changeset
|
54 is the most significant byte. */ |
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
8892
diff
changeset
|
55 |
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
8892
diff
changeset
|
56 #undef WORDS_BIG_ENDIAN |
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
8892
diff
changeset
|
57 |
456 | 58 /* Define NO_ARG_ARRAY if you cannot take the address of the first of a |
59 * group of arguments and treat it as an array of the arguments. */ | |
60 | |
61 /* #define NO_ARG_ARRAY */ | |
62 | |
63 /* Define WORD_MACHINE if addresses and such have | |
64 * to be corrected before they can be used as byte counts. */ | |
65 | |
66 /* #define WORD_MACHINE */ | |
67 | |
68 /* Now define a symbol for the cpu type, if your compiler | |
69 does not define it automatically: | |
70 Ones defined so far include vax, m68000, ns16000, pyramid, | |
71 orion, tahoe, APOLLO and many others */ | |
72 | |
73 #define INTEL386 | |
74 | |
75 /* Use type int rather than a union, to represent Lisp_Object */ | |
76 | |
77 #define NO_UNION_TYPE | |
78 | |
79 /* crt0.c, if it is used, should use the i386-bsd style of entry. | |
80 with no extra dummy args. On USG and XENIX, | |
81 NO_REMAP says this isn't used. */ | |
82 | |
83 #define CRT0_DUMMIES bogus_fp, | |
84 | |
85 /* crt0.c should define a symbol `start' and do .globl with a dot. */ | |
86 | |
87 #define DOT_GLOBAL_START | |
88 | |
89 #ifdef XENIX | |
90 /* Data type of load average, as read out of kmem. */ | |
91 #define LOAD_AVE_TYPE short | |
92 | |
93 /* Convert that into an integer that is 100 for a load average of 1.0 */ | |
525 | 94 #define LOAD_AVE_CVT(x) (((double) (x)) * 100.0 / FSCALE) |
8452
b9fe5aec7126
[SOLARIS2] (VALBITS, GCTYPEBITS): New definitions.
Richard M. Stallman <rms@gnu.org>
parents:
8198
diff
changeset
|
95 |
456 | 96 #define FSCALE 256.0 /* determined by experimentation... */ |
97 #endif | |
98 | |
99 | |
7873
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
100 #ifdef SOLARIS2 |
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
101 /* Data type of load average, as read out of kmem. */ |
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
102 #define LOAD_AVE_TYPE long |
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
103 |
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
104 /* Convert that into an integer that is 100 for a load average of 1.0 */ |
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
105 /* This is totally uncalibrated. */ |
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
106 #define LOAD_AVE_CVT(x) ((int) (((double) (x)) * 100.0 / FSCALE)) |
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
107 |
12445
74e5ebf071fb
[SOLARIS] (LIBS_MACHINE): Move this out of the SOLARIS2_4 conditional.
Richard M. Stallman <rms@gnu.org>
parents:
12224
diff
changeset
|
108 /* J.W.Hawtin@lut.ac.uk say Solaris 2.4 as well as Solaris 2.1 on X86 |
17686
a2708b339766
(LIBS_MACHINE): Add -lelf.
Richard M. Stallman <rms@gnu.org>
parents:
16220
diff
changeset
|
109 requires -lkvm as well. |
a2708b339766
(LIBS_MACHINE): Add -lelf.
Richard M. Stallman <rms@gnu.org>
parents:
16220
diff
changeset
|
110 And handa@etl.gov.jp says that -lkvm needs -llelf, at least on 2.5. */ |
a2708b339766
(LIBS_MACHINE): Add -lelf.
Richard M. Stallman <rms@gnu.org>
parents:
16220
diff
changeset
|
111 #define LIBS_MACHINE -lkvm -lelf |
12445
74e5ebf071fb
[SOLARIS] (LIBS_MACHINE): Move this out of the SOLARIS2_4 conditional.
Richard M. Stallman <rms@gnu.org>
parents:
12224
diff
changeset
|
112 |
8507
daeb611442e9
(LIBS_MACHINE): If SOLARIS2_4, don't define this.
Richard M. Stallman <rms@gnu.org>
parents:
8452
diff
changeset
|
113 #ifndef SOLARIS2_4 |
12445
74e5ebf071fb
[SOLARIS] (LIBS_MACHINE): Move this out of the SOLARIS2_4 conditional.
Richard M. Stallman <rms@gnu.org>
parents:
12224
diff
changeset
|
114 /* J.W.hawtin@lut.ac.uk says Solaris 2.1 on the X86 has FSCALE defined in a |
74e5ebf071fb
[SOLARIS] (LIBS_MACHINE): Move this out of the SOLARIS2_4 conditional.
Richard M. Stallman <rms@gnu.org>
parents:
12224
diff
changeset
|
115 system header. */ |
10709
64aee640f211
[SOLARIS2_4, !__GNUC__] (C_SWITCH_SYSTEM): Defined..
Richard M. Stallman <rms@gnu.org>
parents:
10360
diff
changeset
|
116 #else /* SOLARIS2_4 */ |
64aee640f211
[SOLARIS2_4, !__GNUC__] (C_SWITCH_SYSTEM): Defined..
Richard M. Stallman <rms@gnu.org>
parents:
10360
diff
changeset
|
117 #ifndef __GNUC__ |
12224
7e5885cd3109
[!__GNUC__] (C_SWITCH_MACHINE): Disable this; it seems to confuse cpp.
Karl Heuer <kwzh@gnu.org>
parents:
12223
diff
changeset
|
118 #if 0 /* wisner@gryphon.com says this screws up cpp */ |
11121
9fac7d5558e9
(C_SWITCH_SYSTEM): Don't #undef or define it.
Richard M. Stallman <rms@gnu.org>
parents:
10709
diff
changeset
|
119 #define C_SWITCH_MACHINE -Xa |
12224
7e5885cd3109
[!__GNUC__] (C_SWITCH_MACHINE): Disable this; it seems to confuse cpp.
Karl Heuer <kwzh@gnu.org>
parents:
12223
diff
changeset
|
120 #endif |
10709
64aee640f211
[SOLARIS2_4, !__GNUC__] (C_SWITCH_SYSTEM): Defined..
Richard M. Stallman <rms@gnu.org>
parents:
10360
diff
changeset
|
121 #endif /* not __GNUC__ */ |
64aee640f211
[SOLARIS2_4, !__GNUC__] (C_SWITCH_SYSTEM): Defined..
Richard M. Stallman <rms@gnu.org>
parents:
10360
diff
changeset
|
122 #endif /* SOLARIS2_4 */ |
8507
daeb611442e9
(LIBS_MACHINE): If SOLARIS2_4, don't define this.
Richard M. Stallman <rms@gnu.org>
parents:
8452
diff
changeset
|
123 |
daeb611442e9
(LIBS_MACHINE): If SOLARIS2_4, don't define this.
Richard M. Stallman <rms@gnu.org>
parents:
8452
diff
changeset
|
124 /* configure thinks solaris X86 has gethostname, but it does not work, |
daeb611442e9
(LIBS_MACHINE): If SOLARIS2_4, don't define this.
Richard M. Stallman <rms@gnu.org>
parents:
8452
diff
changeset
|
125 so undefine it. */ |
7873
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
126 #undef HAVE_GETHOSTNAME |
7874 | 127 |
128 #else /* not SOLARIS2 */ | |
129 #ifdef USG5_4 /* Older USG systems do not support the load average. */ | |
130 /* Data type of load average, as read out of kmem. */ | |
131 | |
132 #define LOAD_AVE_TYPE long | |
133 | |
134 /* Convert that into an integer that is 100 for a load average of 1.0 */ | |
135 /* This is totally uncalibrated. */ | |
136 | |
137 #define LOAD_AVE_CVT(x) ((int) (((double) (x)) * 100.0 / FSCALE)) | |
138 #define FSCALE 256.0 | |
7873
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
139 #endif |
7874 | 140 #endif /* not SOLARIS2 */ |
7873
09fd0024f046
Add conditional for SOLARIS2.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
141 |
456 | 142 /* Define CANNOT_DUMP on machines where unexec does not work. |
143 Then the function dump-emacs will not be defined | |
144 and temacs will do (load "loadup") automatically unless told otherwise. */ | |
145 | |
146 /* #define CANNOT_DUMP */ | |
147 | |
148 /* Define VIRT_ADDR_VARIES if the virtual addresses of | |
149 pure and impure space as loaded can vary, and even their | |
150 relative order cannot be relied on. | |
151 | |
152 Otherwise Emacs assumes that text space precedes data space, | |
153 numerically. */ | |
154 | |
155 /* #define VIRT_ADDR_VARIES */ | |
156 | |
157 #ifdef XENIX | |
158 /* Define NO_REMAP if memory segmentation makes it not work well | |
159 to change the boundary between the text section and data section | |
160 when Emacs is dumped. If you define this, the preloaded Lisp | |
161 code will not be sharable; but that's better than failing completely. */ | |
162 | |
163 #define NO_REMAP | |
164 | |
165 /* Since cannot purify, use standard Xenix 386 startup code. */ | |
166 | |
167 #define START_FILES /lib/386/Sseg.o pre-crt0.o /lib/386/Scrt0.o | |
168 | |
169 /* These really use terminfo. */ | |
170 | |
171 #define LIBS_TERMCAP /lib/386/Slibcurses.a \ | |
172 /lib/386/Slibtinfo.a /lib/386/Slibx.a | |
173 | |
174 /* Standard libraries for this machine. Since `-l' doesn't work in `ld'. */ | |
175 /* '__fltused' is unresolved w/o Slibcfp.a */ | |
176 #define LIB_STANDARD /lib/386/Slibcfp.a /lib/386/Slibc.a | |
177 #else /* not XENIX */ | |
178 | |
2113
525be9535652
* m/intel386.h (LIB_STANDARD): If USG5_4 is #defined, there's no
Jim Blandy <jimb@redhat.com>
parents:
750
diff
changeset
|
179 /* this brings in alloca() if we're using cc */ |
456 | 180 #ifdef USG |
525 | 181 #ifndef LIB_STANDARD |
2113
525be9535652
* m/intel386.h (LIB_STANDARD): If USG5_4 is #defined, there's no
Jim Blandy <jimb@redhat.com>
parents:
750
diff
changeset
|
182 #ifdef USG5_4 |
525be9535652
* m/intel386.h (LIB_STANDARD): If USG5_4 is #defined, there's no
Jim Blandy <jimb@redhat.com>
parents:
750
diff
changeset
|
183 #define LIB_STANDARD -lc |
525be9535652
* m/intel386.h (LIB_STANDARD): If USG5_4 is #defined, there's no
Jim Blandy <jimb@redhat.com>
parents:
750
diff
changeset
|
184 #else /* not USG5_4 */ |
456 | 185 #define LIB_STANDARD -lPW -lc |
2113
525be9535652
* m/intel386.h (LIB_STANDARD): If USG5_4 is #defined, there's no
Jim Blandy <jimb@redhat.com>
parents:
750
diff
changeset
|
186 #endif /* not USG5_4 */ |
525be9535652
* m/intel386.h (LIB_STANDARD): If USG5_4 is #defined, there's no
Jim Blandy <jimb@redhat.com>
parents:
750
diff
changeset
|
187 #endif /* LIB_STANDARD */ |
525be9535652
* m/intel386.h (LIB_STANDARD): If USG5_4 is #defined, there's no
Jim Blandy <jimb@redhat.com>
parents:
750
diff
changeset
|
188 |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48433
diff
changeset
|
189 #define NO_REMAP |
456 | 190 #define TEXT_START 0 |
7930 | 191 #endif /* USG */ |
456 | 192 #endif /* not XENIX */ |
193 | |
525 | 194 #ifdef USG5_4 |
195 #define DATA_SEG_BITS 0x08000000 | |
196 #endif | |
8198
0ddce8628575
[MSDOS]: #define NO_REMAP.
Richard M. Stallman <rms@gnu.org>
parents:
7930
diff
changeset
|
197 |
0ddce8628575
[MSDOS]: #define NO_REMAP.
Richard M. Stallman <rms@gnu.org>
parents:
7930
diff
changeset
|
198 #ifdef MSDOS |
0ddce8628575
[MSDOS]: #define NO_REMAP.
Richard M. Stallman <rms@gnu.org>
parents:
7930
diff
changeset
|
199 #define NO_REMAP |
0ddce8628575
[MSDOS]: #define NO_REMAP.
Richard M. Stallman <rms@gnu.org>
parents:
7930
diff
changeset
|
200 #endif |
9819
bb44f0c88ec2
[WINDOWSNT]: (VIRT_ADDR_VARIES, DATA_END, DATA_START, HAVE_ALLOCA): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
9095
diff
changeset
|
201 |
bb44f0c88ec2
[WINDOWSNT]: (VIRT_ADDR_VARIES, DATA_END, DATA_START, HAVE_ALLOCA): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
9095
diff
changeset
|
202 #ifdef WINDOWSNT |
bb44f0c88ec2
[WINDOWSNT]: (VIRT_ADDR_VARIES, DATA_END, DATA_START, HAVE_ALLOCA): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
9095
diff
changeset
|
203 #define VIRT_ADDR_VARIES |
bb44f0c88ec2
[WINDOWSNT]: (VIRT_ADDR_VARIES, DATA_END, DATA_START, HAVE_ALLOCA): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
9095
diff
changeset
|
204 #define DATA_END get_data_end () |
bb44f0c88ec2
[WINDOWSNT]: (VIRT_ADDR_VARIES, DATA_END, DATA_START, HAVE_ALLOCA): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
9095
diff
changeset
|
205 #define DATA_START get_data_start () |
11382
f0d9f468dd05
(NO_ARG_ARRAY) [WINDOWSNT]: Defined.
Karl Heuer <kwzh@gnu.org>
parents:
11121
diff
changeset
|
206 #define NO_ARG_ARRAY |
9819
bb44f0c88ec2
[WINDOWSNT]: (VIRT_ADDR_VARIES, DATA_END, DATA_START, HAVE_ALLOCA): Defined.
Karl Heuer <kwzh@gnu.org>
parents:
9095
diff
changeset
|
207 #endif |
12828
f270ad11be9c
[linux] (ULIMIT_BREAK_VALUE, SEGMENT_MASK): Moved from linux.h.
Richard M. Stallman <rms@gnu.org>
parents:
12548
diff
changeset
|
208 |
f270ad11be9c
[linux] (ULIMIT_BREAK_VALUE, SEGMENT_MASK): Moved from linux.h.
Richard M. Stallman <rms@gnu.org>
parents:
12548
diff
changeset
|
209 #ifdef linux |
f270ad11be9c
[linux] (ULIMIT_BREAK_VALUE, SEGMENT_MASK): Moved from linux.h.
Richard M. Stallman <rms@gnu.org>
parents:
12548
diff
changeset
|
210 /* libc-linux/sysdeps/linux/i386/ulimit.c says that due to shared library, */ |
f270ad11be9c
[linux] (ULIMIT_BREAK_VALUE, SEGMENT_MASK): Moved from linux.h.
Richard M. Stallman <rms@gnu.org>
parents:
12548
diff
changeset
|
211 /* we cannot get the maximum address for brk */ |
f270ad11be9c
[linux] (ULIMIT_BREAK_VALUE, SEGMENT_MASK): Moved from linux.h.
Richard M. Stallman <rms@gnu.org>
parents:
12548
diff
changeset
|
212 #define ULIMIT_BREAK_VALUE (32*1024*1024) |
f270ad11be9c
[linux] (ULIMIT_BREAK_VALUE, SEGMENT_MASK): Moved from linux.h.
Richard M. Stallman <rms@gnu.org>
parents:
12548
diff
changeset
|
213 |
f270ad11be9c
[linux] (ULIMIT_BREAK_VALUE, SEGMENT_MASK): Moved from linux.h.
Richard M. Stallman <rms@gnu.org>
parents:
12548
diff
changeset
|
214 #define SEGMENT_MASK ((SEGMENT_SIZE)-1) |
f270ad11be9c
[linux] (ULIMIT_BREAK_VALUE, SEGMENT_MASK): Moved from linux.h.
Richard M. Stallman <rms@gnu.org>
parents:
12548
diff
changeset
|
215 #endif |
52401 | 216 |
217 /* arch-tag: 746338f0-cb7b-4f49-a98c-cb50817cf2ec | |
218 (do not change this comment) */ |