comparison src/m/amdahl.h @ 456:c0335c02f1d7

Initial revision
author Jim Blandy <jimb@redhat.com>
date Fri, 13 Dec 1991 18:49:49 +0000
parents
children 1ffd52c765c7
comparison
equal deleted inserted replaced
455:12af79cf16ee 456:c0335c02f1d7
1 /* amdahl machine description file
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
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 This file for amdahl_uts created by modifying the template.h
22 by Jishnu Mukerji 3/1/87
23
24 The following line tells the configuration script what sort of
25 operating system this machine is likely to run.
26 USUAL-OPSYS="usg5-2-2"
27
28 This file works with the Amdahl uts native C compiler. The 5.2u370
29 compiler is so brain damaged that it is not even worth trying to use it.
30 */
31
32 /* The following three symbols give information on
33 the size of various data types. */
34
35 #define SHORTBITS 16 /* Number of bits in a short */
36
37 #define INTBITS 32 /* Number of bits in an int */
38
39 #define LONGBITS 32 /* Number of bits in a long */
40
41 /* Define BIG_ENDIAN iff lowest-numbered byte in a word
42 is the most significant byte. */
43
44 #define BIG_ENDIAN
45
46 /* Define NO_ARG_ARRAY if you cannot take the address of the first of a
47 * group of arguments and treat it as an array of the arguments. */
48
49 #undef NO_ARG_ARRAY
50
51 /* Define WORD_MACHINE if addresses and such have
52 * to be corrected before they can be used as byte counts. */
53
54 #define WORD_MACHINE /* not actually used anywhere yet! */
55
56 /* Define how to take a char and sign-extend into an int.
57 On machines where char is signed, this is a no-op. */
58
59 #define SIGN_EXTEND_CHAR(c) (((sign_extend_temp=(c)) & 0x80) \
60 ? (sign_extend_temp | 0xFFFFFF00) \
61 : (sign_extend_temp))
62
63 /* Now define a symbol for the cpu type, if your compiler
64 does not define it automatically:
65 vax, m68000, ns16000, pyramid, orion, tahoe and APOLLO
66 are the ones defined so far. */
67
68 /* uts gets defined automatically */
69 /* However for clarity define amdahl_uts */
70 #define amdahl_uts
71
72 /* Use type int rather than a union, to represent Lisp_Object */
73 /* This is desirable for most machines. */
74
75 #define NO_UNION_TYPE
76
77 /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend
78 the 24-bit bit field into an int. In other words, if bit fields
79 are always unsigned.
80
81 If you use NO_UNION_TYPE, this flag does not matter. */
82
83 #define EXPLICIT_SIGN_EXTEND
84
85 /* Data type of load average, as read out of kmem. */
86
87 /* #define LOAD_AVE_TYPE long*/
88
89 /* Convert that into an integer that is 100 for a load average of 1.0 */
90
91 /*#define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0)*/
92
93 /* Define CANNOT_DUMP on machines where unexec does not work.
94 Then the function dump-emacs will not be defined
95 and temacs will do (load "loadup") automatically unless told otherwise. */
96
97 /* #define CANNOT_DUMP
98
99 /* Define VIRT_ADDR_VARIES if the virtual addresses of
100 pure and impure space as loaded can vary, and even their
101 relative order cannot be relied on.
102
103 Otherwise Emacs assumes that text space precedes data space,
104 numerically. */
105
106 /* #define VIRT_ADDR_VARIES*/
107
108 /* Define C_ALLOCA if this machine does not support a true alloca
109 and the one written in C should be used instead.
110 Define HAVE_ALLOCA to say that the system provides a properly
111 working alloca function and it should be used.
112 Define neither one if an assembler-language alloca
113 in the file alloca.s should be used. */
114
115 #define C_ALLOCA
116 /*#define HAVE_ALLOCA */
117
118 #ifdef HAVE_ALLOCA
119 #define LIB_STANDARD -lPW -lc
120 #endif
121
122 /* Define NO_REMAP if memory segmentation makes it not work well
123 to change the boundary between the text section and data section
124 when Emacs is dumped. If you define this, the preloaded Lisp
125 code will not be sharable; but that's better than failing completely. */
126
127 /*#define NO_REMAP*/
128
129 #define TERMINFO
130
131 /* The usual definition of XINT, which involves shifting, does not
132 sign-extend properly on this machine. */
133
134 #define XINT(i) (((sign_extend_temp=(i)) & 0x00800000) \
135 ? (sign_extend_temp | 0xFF000000) \
136 : (sign_extend_temp & 0x00FFFFFF))
137
138 #ifdef emacs /* Don't do this when making xmakefile! */
139 extern int sign_extend_temp;
140 #endif
141
142 /* The following needed to load the proper crt0.o and to get the
143 proper declaration of data_start in the #undef NO_REMAP case */
144
145 #ifndef NO_REMAP
146 #define START_FILES pre-crt0.o /lib/crt0.o
147 #endif
148
149 /* Perhaps this means that the optimizer isn't safe to use. */
150
151 #define C_OPTIMIZE_SWITCH
152
153 /* Put text and data on non-segment boundary; makes image smaller */
154
155 #define LD_SWITCH_MACHINE -N
156
157 /* When writing the 'xemacs' file, make text segment ro */
158 #define EXEC_MAGIC 0410
159
160 /* Mask for address bits within a memory segment */
161 #define SEGSIZ 0x10000 /* Should this not be defined elsewhere ? */
162 #define SEGMENT_MASK (SEGSIZ - 1)
163
164 /* Tell alloca.c which direction stack grows. */
165 #define STACK_DIRECTION -1
166
167 /* Compensate for error in signal.h. */
168 #if NSIG==19
169 #undef NSIG
170 #define NSIG 20
171 #endif