Mercurial > emacs
annotate src/m/alpha.h @ 95948:d55ec23f052d
*** empty log message ***
| author | Glenn Morris <rgm@gnu.org> |
|---|---|
| date | Sun, 15 Jun 2008 02:53:17 +0000 |
| parents | 7e5b32f86a4c |
| children | 0e3e875ffade |
| rev | line source |
|---|---|
| 8836 | 1 /* machine description file For the alpha chip. |
|
94714
7e5b32f86a4c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
2 Copyright (C) 1994, 1997, 1999, 2001, 2002, 2003, 2004, 2005, 2006, |
|
7e5b32f86a4c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
3 2007, 2008 Free Software Foundation, Inc. |
| 8836 | 4 |
| 5 This file is part of GNU Emacs. | |
| 6 | |
|
94714
7e5b32f86a4c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
7 GNU Emacs is free software: you can redistribute it and/or modify |
| 8836 | 8 it under the terms of the GNU General Public License as published by |
|
94714
7e5b32f86a4c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
9 the Free Software Foundation, either version 3 of the License, or |
|
7e5b32f86a4c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
10 (at your option) any later version. |
| 8836 | 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 | |
|
94714
7e5b32f86a4c
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
87649
diff
changeset
|
18 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */ |
| 8836 | 19 |
| 20 | |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
48428
diff
changeset
|
21 /* The following line tells the configuration script what sort of |
| 8836 | 22 operating system this machine is likely to run. |
| 23 USUAL-OPSYS="note" | |
| 24 | |
| 25 NOTE-START | |
| 26 Use -opsystem=osf1 | |
| 27 NOTE-END | |
| 28 | |
| 29 */ | |
| 30 | |
| 28647 | 31 #ifndef _LP64 |
| 29912 | 32 #define _LP64 /* This doesn't appear to be necessary |
| 33 on OSF 4/5 -- fx. */ | |
| 28647 | 34 #endif |
| 8836 | 35 |
| 78499 | 36 /* Define WORDS_BIG_ENDIAN if lowest-numbered byte in a word |
|
9095
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
8892
diff
changeset
|
37 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
|
38 |
|
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
8892
diff
changeset
|
39 #undef WORDS_BIG_ENDIAN |
|
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
8892
diff
changeset
|
40 |
| 8836 | 41 /* Define NO_ARG_ARRAY if you cannot take the address of the first of a |
| 42 * group of arguments and treat it as an array of the arguments. */ | |
| 43 | |
| 44 #define NO_ARG_ARRAY | |
| 45 | |
| 46 /* Now define a symbol for the cpu type, if your compiler | |
| 47 does not define it automatically: | |
| 48 Ones defined so far include vax, m68000, ns16000, pyramid, | |
| 49 orion, tahoe, APOLLO and many others */ | |
| 50 | |
| 51 /* __alpha defined automatically */ | |
| 52 | |
| 53 | |
| 54 /* Use type EMACS_INT rather than a union, to represent Lisp_Object */ | |
| 55 /* This is desirable for most machines. */ | |
| 56 #define NO_UNION_TYPE | |
| 57 | |
| 58 /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend | |
| 59 the 24-bit bit field into an int. In other words, if bit fields | |
| 60 are always unsigned. | |
| 61 | |
| 62 If you use NO_UNION_TYPE, this flag does not matter. */ | |
| 63 | |
| 64 #define EXPLICIT_SIGN_EXTEND | |
| 65 | |
| 66 /* Data type of load average, as read out of kmem. */ | |
| 67 | |
| 68 #define LOAD_AVE_TYPE long | |
| 69 | |
| 70 /* Convert that into an integer that is 100 for a load average of 1.0 */ | |
| 71 | |
| 72 #define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0 / FSCALE) | |
| 73 | |
| 74 /* GNU malloc and the relocating allocator do not work together | |
|
11979
10035163f8d5
(LD_SWITCH_MACHINE) [!__GNUC__]: Don't define.
Karl Heuer <kwzh@gnu.org>
parents:
11696
diff
changeset
|
75 with X. [Who wrote that?] */ |
|
10035163f8d5
(LD_SWITCH_MACHINE) [!__GNUC__]: Don't define.
Karl Heuer <kwzh@gnu.org>
parents:
11696
diff
changeset
|
76 |
|
10035163f8d5
(LD_SWITCH_MACHINE) [!__GNUC__]: Don't define.
Karl Heuer <kwzh@gnu.org>
parents:
11696
diff
changeset
|
77 /* May 1995: reportedly [Rainer Schoepf <schoepf@uni-mainz.de>] both the |
|
10035163f8d5
(LD_SWITCH_MACHINE) [!__GNUC__]: Don't define.
Karl Heuer <kwzh@gnu.org>
parents:
11696
diff
changeset
|
78 system and the gnu malloc system work with "alpha-dec-osf3.0" and |
|
10035163f8d5
(LD_SWITCH_MACHINE) [!__GNUC__]: Don't define.
Karl Heuer <kwzh@gnu.org>
parents:
11696
diff
changeset
|
79 "alpha-dec-osf3.2". */ |
|
10035163f8d5
(LD_SWITCH_MACHINE) [!__GNUC__]: Don't define.
Karl Heuer <kwzh@gnu.org>
parents:
11696
diff
changeset
|
80 |
|
10035163f8d5
(LD_SWITCH_MACHINE) [!__GNUC__]: Don't define.
Karl Heuer <kwzh@gnu.org>
parents:
11696
diff
changeset
|
81 /* May 1995: it seems to me [Morten Welinder <terra@diku.dk>] that both |
|
10035163f8d5
(LD_SWITCH_MACHINE) [!__GNUC__]: Don't define.
Karl Heuer <kwzh@gnu.org>
parents:
11696
diff
changeset
|
82 mallocs work with "alpha-dec-osf2.0", but I daren't break anything |
|
10035163f8d5
(LD_SWITCH_MACHINE) [!__GNUC__]: Don't define.
Karl Heuer <kwzh@gnu.org>
parents:
11696
diff
changeset
|
83 right now. Feel free to play if you want. */ |
| 8836 | 84 |
|
12301
69f08a14593b
(malloc, realloc): If not _MALLOC_INTERNAL, always use void *.
Richard M. Stallman <rms@gnu.org>
parents:
12235
diff
changeset
|
85 /* #define SYSTEM_MALLOC */ |
| 8836 | 86 |
|
15850
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
87 #ifdef __ELF__ |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
88 /* With ELF, make sure that all common symbols get allocated to in the |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
89 data section. Otherwise, the dump of temacs may miss variables in |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
90 the shared library that have been initialized. For example, with |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
91 GNU libc, __malloc_initialized would normally be resolved to the |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
92 shared library's .bss section, which is fatal. */ |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
93 # ifdef __GNUC__ |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
94 # define C_SWITCH_MACHINE -fno-common |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
95 # else |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
96 # error What gives? Fix me if DEC Unix supports ELF now. |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
97 # endif |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
98 #endif |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
99 |
|
15851
9aaeb5dc2851
[__ELF__] (UNEXEC): Use unexelf1.c.
Richard M. Stallman <rms@gnu.org>
parents:
15850
diff
changeset
|
100 #ifdef __ELF__ |
|
9aaeb5dc2851
[__ELF__] (UNEXEC): Use unexelf1.c.
Richard M. Stallman <rms@gnu.org>
parents:
15850
diff
changeset
|
101 #undef UNEXEC |
|
16119
8b44e50334a8
(UNEXEC): Use unexelf.c.
Richard M. Stallman <rms@gnu.org>
parents:
15851
diff
changeset
|
102 #define UNEXEC unexelf.o |
|
47512
a1fefb8caf04
[LINUX]: Don't define DATA_START.
Andreas Schwab <schwab@suse.de>
parents:
46651
diff
changeset
|
103 #ifndef LINUX |
|
46651
9f027dd3047f
(BITS_PER_LONG, BITS_PER_EMACS_INT, EMACS_INT,
Ken Raeburn <raeburn@raeburn.org>
parents:
44601
diff
changeset
|
104 #define DATA_START 0x140000000 |
|
15851
9aaeb5dc2851
[__ELF__] (UNEXEC): Use unexelf1.c.
Richard M. Stallman <rms@gnu.org>
parents:
15850
diff
changeset
|
105 #endif |
|
47512
a1fefb8caf04
[LINUX]: Don't define DATA_START.
Andreas Schwab <schwab@suse.de>
parents:
46651
diff
changeset
|
106 #endif |
|
15851
9aaeb5dc2851
[__ELF__] (UNEXEC): Use unexelf1.c.
Richard M. Stallman <rms@gnu.org>
parents:
15850
diff
changeset
|
107 |
|
15850
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
108 #ifndef __ELF__ |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
109 |
| 8836 | 110 /* Describe layout of the address space in an executing process. */ |
| 111 | |
| 112 #define TEXT_START 0x120000000 | |
| 113 #define DATA_START 0x140000000 | |
| 114 | |
|
15850
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
115 /* The program to be used for unexec. */ |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
116 |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
117 #define UNEXEC unexalpha.o |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
118 |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
119 #endif /* notdef __ELF__ */ |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
120 |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
121 #if defined (LINUX) && __GNU_LIBRARY__ - 0 < 6 |
|
13616
0e584934cd9e
[LINUX] (LINUX_SBRK_BUG): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
13534
diff
changeset
|
122 /* This controls a conditional in main. */ |
|
0e584934cd9e
[LINUX] (LINUX_SBRK_BUG): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
13534
diff
changeset
|
123 #define LINUX_SBRK_BUG |
|
0e584934cd9e
[LINUX] (LINUX_SBRK_BUG): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
13534
diff
changeset
|
124 #endif |
| 8836 | 125 |
|
15850
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
126 /* On the Alpha it's best to avoid including TERMIO since struct |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
127 termio and struct termios are mutually incompatible. */ |
|
12827
b0f8f54fe739
[linux] (COFF, NO_TERMIO): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
12825
diff
changeset
|
128 #define NO_TERMIO |
|
b0f8f54fe739
[linux] (COFF, NO_TERMIO): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
12825
diff
changeset
|
129 |
|
20031
6b1b51bc8b17
Test __OpenBSD__ along with __NetBSD__.
Richard M. Stallman <rms@gnu.org>
parents:
18101
diff
changeset
|
130 #if defined (LINUX) || defined (__NetBSD__) || defined (__OpenBSD__) |
|
15850
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
131 # define TEXT_END ({ extern int _etext; &_etext; }) |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
132 # ifndef __ELF__ |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
133 # define COFF |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
134 # define DATA_END ({ extern int _EDATA; &_EDATA; }) |
|
d6c4d581ad25
[__ELF__ && __GNUC__] (C_SWITCH_MACHINE): Add -fno-common.
Richard M. Stallman <rms@gnu.org>
parents:
15719
diff
changeset
|
135 # endif /* notdef __ELF__ */ |
|
12827
b0f8f54fe739
[linux] (COFF, NO_TERMIO): Defined.
Richard M. Stallman <rms@gnu.org>
parents:
12825
diff
changeset
|
136 #endif |
|
20031
6b1b51bc8b17
Test __OpenBSD__ along with __NetBSD__.
Richard M. Stallman <rms@gnu.org>
parents:
18101
diff
changeset
|
137 |
|
6b1b51bc8b17
Test __OpenBSD__ along with __NetBSD__.
Richard M. Stallman <rms@gnu.org>
parents:
18101
diff
changeset
|
138 #if (defined (__NetBSD__) || defined (__OpenBSD__)) && defined (__ELF__) |
|
6b1b51bc8b17
Test __OpenBSD__ along with __NetBSD__.
Richard M. Stallman <rms@gnu.org>
parents:
18101
diff
changeset
|
139 #define HAVE_TEXT_START |
|
6b1b51bc8b17
Test __OpenBSD__ along with __NetBSD__.
Richard M. Stallman <rms@gnu.org>
parents:
18101
diff
changeset
|
140 #endif |
|
20201
09b52c2bc2f1
(DBL_MIN_REPLACEMENT): New macro.
Paul Eggert <eggert@twinsun.com>
parents:
20031
diff
changeset
|
141 |
|
09b52c2bc2f1
(DBL_MIN_REPLACEMENT): New macro.
Paul Eggert <eggert@twinsun.com>
parents:
20031
diff
changeset
|
142 /* Many Alpha implementations (e.g. gas 2.8) can't handle DBL_MIN: |
|
09b52c2bc2f1
(DBL_MIN_REPLACEMENT): New macro.
Paul Eggert <eggert@twinsun.com>
parents:
20031
diff
changeset
|
143 they generate code that uses a signaling NaN instead of DBL_MIN. |
|
09b52c2bc2f1
(DBL_MIN_REPLACEMENT): New macro.
Paul Eggert <eggert@twinsun.com>
parents:
20031
diff
changeset
|
144 Define DBL_MIN_REPLACEMENT to be the next value larger than DBL_MIN: |
|
09b52c2bc2f1
(DBL_MIN_REPLACEMENT): New macro.
Paul Eggert <eggert@twinsun.com>
parents:
20031
diff
changeset
|
145 this avoids the assembler bug. */ |
|
09b52c2bc2f1
(DBL_MIN_REPLACEMENT): New macro.
Paul Eggert <eggert@twinsun.com>
parents:
20031
diff
changeset
|
146 #define DBL_MIN_REPLACEMENT 2.2250738585072019e-308 |
| 52401 | 147 |
| 148 /* arch-tag: 978cb578-1e25-4a60-819b-adae0972aa78 | |
| 149 (do not change this comment) */ |
