Mercurial > emacs
comparison src/m/ibmrt.h @ 446:76b7a95526d3
Initial revision
author | Jim Blandy <jimb@redhat.com> |
---|---|
date | Fri, 06 Dec 1991 07:16:11 +0000 |
parents | |
children | 1ffd52c765c7 |
comparison
equal
deleted
inserted
replaced
445:2a2230dd1b1c | 446:76b7a95526d3 |
---|---|
1 /* RTPC machine dependent defines | |
2 Copyright (C) 1986 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 line tells the configuration script what sort of | |
22 operating system this machine is likely to run. | |
23 USUAL-OPSYS="bsd4-2" */ | |
24 | |
25 /* The following three symbols give information on | |
26 the size of various data types. */ | |
27 | |
28 #define SHORTBITS 16 /* Number of bits in a short */ | |
29 | |
30 #define INTBITS 32 /* Number of bits in an int */ | |
31 | |
32 #define LONGBITS 32 /* Number of bits in a long */ | |
33 | |
34 /* Define BIG_ENDIAN iff lowest-numbered byte in a word | |
35 is the most significant byte. */ | |
36 | |
37 #define BIG_ENDIAN | |
38 | |
39 /* Define NO_ARG_ARRAY if you cannot take the address of the first of a | |
40 * group of arguments and treat it as an array of the arguments. */ | |
41 | |
42 #define NO_ARG_ARRAY | |
43 | |
44 /* Define WORD_MACHINE if addresses and such have | |
45 * to be corrected before they can be used as byte counts. */ | |
46 | |
47 #define WORD_MACHINE | |
48 | |
49 /* Define how to take a char and sign-extend into an int. | |
50 On machines where char is signed, this is a no-op. */ | |
51 | |
52 #define SIGN_EXTEND_CHAR(c) ((signed char)(c)) | |
53 | |
54 /* Now define a symbol for the cpu type, if your compiler | |
55 does not define it automatically. */ | |
56 | |
57 #define ibmrt | |
58 #define romp /* unfortunately old include files are hanging around. */ | |
59 | |
60 /* Use type int rather than a union, to represent Lisp_Object */ | |
61 /* This is desirable for most machines. */ | |
62 | |
63 #define NO_UNION_TYPE | |
64 | |
65 /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend | |
66 the 24-bit bit field into an int. In other words, if bit fields | |
67 are always unsigned. | |
68 | |
69 If you use NO_UNION_TYPE, this flag does not matter. */ | |
70 | |
71 #define EXPLICIT_SIGN_EXTEND | |
72 | |
73 /* Data type of load average, as read out of kmem. */ | |
74 | |
75 #define LOAD_AVE_TYPE double /* For AIS (sysV) */ | |
76 | |
77 /* Convert that into an integer that is 100 for a load average of 1.0 */ | |
78 | |
79 #define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0) | |
80 | |
81 /* Define CANNOT_DUMP on machines where unexec does not work. | |
82 Then the function dump-emacs will not be defined | |
83 and temacs will do (load "loadup") automatically unless told otherwise. */ | |
84 | |
85 /* #define CANNOT_DUMP */ | |
86 | |
87 /* Define VIRT_ADDR_VARIES if the virtual addresses of | |
88 pure and impure space as loaded can vary, and even their | |
89 relative order cannot be relied on. | |
90 | |
91 Otherwise Emacs assumes that text space precedes data space, | |
92 numerically. */ | |
93 | |
94 #undef VIRT_ADDR_VARIES | |
95 | |
96 /* Define C_ALLOCA if this machine does not support a true alloca | |
97 and the one written in C should be used instead. | |
98 Define HAVE_ALLOCA to say that the system provides a properly | |
99 working alloca function and it should be used. | |
100 Define neither one if an assembler-language alloca | |
101 in the file alloca.s should be used. */ | |
102 | |
103 #define HAVE_ALLOCA | |
104 | |
105 /* The data segment in this machine starts at a fixed address. | |
106 An address of data cannot be stored correctly in a Lisp object; | |
107 we always lose the high bits. We must tell XPNTR to add them back. */ | |
108 | |
109 #define DATA_SEG_BITS 0x10000000 | |
110 #define DATA_START 0x10000000 | |
111 | |
112 /* The text segment always starts at a fixed address. | |
113 This way we don't need to have a label _start defined. */ | |
114 #define TEXT_START 0 | |
115 | |
116 #define VALBITS 26 | |
117 #define GCTYPEBITS 5 | |
118 | |
119 /* Taking a pointer to a char casting it as int pointer */ | |
120 /* and then taking the int which the int pointer points to */ | |
121 /* is practically guaranteed to give erroneous results */ | |
122 | |
123 #define NEED_ERRNO | |
124 | |
125 #define SKTPAIR | |
126 | |
127 /* BSD has BSTRING. */ | |
128 | |
129 #define BSTRING | |
130 | |
131 /* Special switches to give the C compiler. */ | |
132 | |
133 #define C_SWITCH_MACHINE -Dalloca=_Alloca | |
134 | |
135 /* Don't attempt to relabel some of the data as text when dumping. | |
136 It does not work because their virtual addresses are not consecutive. | |
137 This enables us to use the standard crt0.o. */ | |
138 | |
139 #define NO_REMAP |