Mercurial > emacs
annotate src/m/hp800.h @ 13451:3a69848f7892
(Fwrite_region): Move the code that writes annotations for empty files.
author | Richard M. Stallman <rms@gnu.org> |
---|---|
date | Fri, 10 Nov 1995 06:44:54 +0000 |
parents | 2cd15d90fec6 |
children | 51d3a3fa828c |
rev | line source |
---|---|
456 | 1 /* machine description file for hp9000 series 800 machines. |
2 Copyright (C) 1987 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 | |
3699 | 8 the Free Software Foundation; either version 2, or (at your option) |
456 | 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 line tells the configuration script what sort of | |
22 operating system this machine is likely to run. | |
23 USUAL-OPSYS="hpux" */ | |
24 | |
9095
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
9040
diff
changeset
|
25 /* 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:
9040
diff
changeset
|
26 is the most significant byte. */ |
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
9040
diff
changeset
|
27 |
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
9040
diff
changeset
|
28 #define WORDS_BIG_ENDIAN |
23f72b18b420
(WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents:
9040
diff
changeset
|
29 |
456 | 30 /* Define NO_ARG_ARRAY if you cannot take the address of the first of a |
31 * group of arguments and treat it as an array of the arguments. */ | |
32 | |
33 #define NO_ARG_ARRAY | |
34 | |
35 /* Define WORD_MACHINE if addresses and such have | |
36 * to be corrected before they can be used as byte counts. */ | |
37 | |
38 #undef WORD_MACHINE | |
39 | |
40 /* Now define a symbol for the cpu type, if your compiler | |
41 does not define it automatically: | |
42 Ones defined so far include vax, m68000, ns16000, pyramid, | |
43 orion, tahoe, APOLLO and many others */ | |
7159
2b5401aa9630
Renamed from hp9000s800.h.
Richard M. Stallman <rms@gnu.org>
parents:
7146
diff
changeset
|
44 #ifndef hp9000s800 |
2b5401aa9630
Renamed from hp9000s800.h.
Richard M. Stallman <rms@gnu.org>
parents:
7146
diff
changeset
|
45 # define hp9000s800 |
456 | 46 #endif |
47 | |
48 /* Use type int rather than a union, to represent Lisp_Object */ | |
49 /* This is desirable for most machines. */ | |
50 | |
51 #define NO_UNION_TYPE | |
52 | |
53 /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend | |
10362
f145d62266f6
(VALBITS, GCTYPEBITS): Deleted; default is better.
Karl Heuer <kwzh@gnu.org>
parents:
9258
diff
changeset
|
54 the bit field into an int. In other words, if bit fields |
456 | 55 are always unsigned. |
56 | |
57 If you use NO_UNION_TYPE, this flag does not matter. */ | |
58 | |
59 #define EXPLICIT_SIGN_EXTEND | |
60 | |
61 /* Data type of load average, as read out of kmem. */ | |
62 | |
63 #define LOAD_AVE_TYPE double | |
64 | |
65 /* Convert that into an integer that is 100 for a load average of 1.0 */ | |
66 | |
67 #define LOAD_AVE_CVT(x) ((int) (x * 100.0)) | |
68 | |
69 | |
70 /* Define CANNOT_DUMP on machines where unexec does not work. | |
71 Then the function dump-emacs will not be defined | |
72 and temacs will do (load "loadup") automatically unless told otherwise. */ | |
73 | |
74 #undef CANNOT_DUMP | |
75 | |
76 /* Define VIRT_ADDR_VARIES if the virtual addresses of | |
77 pure and impure space as loaded can vary, and even their | |
78 relative order cannot be relied on. | |
79 | |
80 Otherwise Emacs assumes that text space precedes data space, | |
81 numerically. */ | |
82 | |
83 #define VIRT_ADDR_VARIES | |
84 | |
85 /* Define C_ALLOCA if this machine does not support a true alloca | |
86 and the one written in C should be used instead. | |
87 Define HAVE_ALLOCA to say that the system provides a properly | |
88 working alloca function and it should be used. | |
89 Define neither one if an assembler-language alloca | |
90 in the file alloca.s should be used. */ | |
91 | |
92 #define C_ALLOCA | |
93 /* #define HAVE_ALLOCA */ | |
94 | |
95 /* the data segment on this machine always starts at address 0x40000000. */ | |
96 | |
97 #define DATA_SEG_BITS 0x40000000 | |
98 | |
99 #define DATA_START 0x40000000 | |
100 #define TEXT_START 0x00000000 | |
101 | |
102 #define STACK_DIRECTION 1 | |
103 | |
104 /* Define NO_REMAP if memory segmentation makes it not work well | |
105 to change the boundary between the text section and data section | |
106 when Emacs is dumped. If you define this, the preloaded Lisp | |
107 code will not be sharable; but that's better than failing completely. */ | |
108 | |
109 #define NO_REMAP | |
110 | |
111 /* This machine requires completely different unexec code | |
112 which lives in a separate file. Specify the file name. */ | |
113 | |
114 #define UNEXEC unexhp9k800.o | |
115 | |
116 #define LIBS_MACHINE | |
117 #define LIBS_DEBUG | |
118 | |
119 /* Define NEED_BSDTTY if you have such. */ | |
120 | |
121 #define NEED_BSDTTY | |
122 | |
123 /* The standard definitions of these macros would work ok, | |
124 but these are faster because the constants are short. */ | |
125 | |
126 | |
13365
2cd15d90fec6
(SHORTBITS, INTBITS, LONGBITS): Deleted; now in config.h
Karl Heuer <kwzh@gnu.org>
parents:
10362
diff
changeset
|
127 #define XUINT(a) (((unsigned)(a) << BITS_PER_INT-VALBITS) >> BITS_PER_INT-VALBITS) |
456 | 128 |
129 #define XSET(var, type, ptr) \ | |
13365
2cd15d90fec6
(SHORTBITS, INTBITS, LONGBITS): Deleted; now in config.h
Karl Heuer <kwzh@gnu.org>
parents:
10362
diff
changeset
|
130 ((var) = ((int)(type) << VALBITS) + (((unsigned) (ptr) << BITS_PER_INT-VALBITS) >> BITS_PER_INT-VALBITS)) |
456 | 131 |
132 #define XMARKBIT(a) ((a) < 0) | |
133 #define XSETMARKBIT(a,b) ((a) = ((b) ? (a)|MARKBIT : (a) & ~MARKBIT)) | |
134 | |
135 #if 0 /* Loses when sign bit of type field is set. */ | |
13365
2cd15d90fec6
(SHORTBITS, INTBITS, LONGBITS): Deleted; now in config.h
Karl Heuer <kwzh@gnu.org>
parents:
10362
diff
changeset
|
136 #define XUNMARK(a) ((a) = (((a) << BITS_PER_INT-GCTYPEBITS-VALBITS) >> BITS_PER_INT-GCTYPEBITS-VALBITS)) |
456 | 137 #endif |
138 | |
139 /* The symbol in the kernel where the load average is found | |
140 is named _avenrun. At this time there are two major flavors | |
141 of hp-ux (there is the s800 and s300 (s200) flavors). The | |
142 differences are thusly moved to the corresponding machine description file. | |
143 */ | |
144 | |
145 /* no underscore please */ | |
146 #define LDAV_SYMBOL "avenrun" | |
147 | |
148 #if 0 /* Supposedly no longer true. */ | |
149 /* In hpux, for unknown reasons, S_IFLNK is defined even though | |
150 symbolic links do not exist. | |
151 Make sure our conditionals based on S_IFLNK are not confused. | |
152 | |
153 Here we assume that stat.h is included before config.h | |
154 so that we can override it here. */ | |
155 | |
156 #undef S_IFLNK | |
157 #endif | |
158 | |
159 /* Define the BSTRING functions in terms of the sysV functions. */ | |
5175
7099e53fe4eb
(bcopy, bzero, bcmp): If HAVE_BCOPY, don't #define.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
160 /* On HPUX 8.05, including types.h can include strings.h |
5176 | 161 which declares these as functions. Hence the #ifndef. */ |
456 | 162 |
5175
7099e53fe4eb
(bcopy, bzero, bcmp): If HAVE_BCOPY, don't #define.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
163 #ifndef HAVE_BCOPY |
456 | 164 #define bcopy(a,b,s) memcpy (b,a,s) |
165 #define bzero(a,s) memset (a,0,s) | |
166 #define bcmp memcmp | |
5175
7099e53fe4eb
(bcopy, bzero, bcmp): If HAVE_BCOPY, don't #define.
Richard M. Stallman <rms@gnu.org>
parents:
3699
diff
changeset
|
167 #endif |
456 | 168 |
169 /* On USG systems these have different names. */ | |
170 | |
171 #define index strchr | |
172 #define rindex strrchr | |
173 | |
174 /* Include the file bsdtty.h, since this machine has job control. */ | |
175 #define NEED_BSDTTY |