13373
|
1 /* Machine description file for Windows NT.
|
|
2
|
|
3 Copyright (C) 1993, 1994 Free Software Foundation, Inc.
|
|
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
|
|
9 the Free Software Foundation; either version 2, or (at your option)
|
|
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
|
|
19 the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
|
|
20
|
|
21 /* The following line tells the configuration script what sort of
|
|
22 operating system this machine is likely to run.
|
|
23 USUAL-OPSYS="<name of system .h file here, without the s- or .h>" */
|
|
24
|
|
25 /* Define BIG_ENDIAN iff lowest-numbered byte in a word
|
|
26 is the most significant byte. */
|
|
27
|
|
28 /* #define BIG_ENDIAN */
|
|
29
|
|
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 #define 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 */
|
|
44
|
|
45 /* Use type int rather than a union, to represent Lisp_Object */
|
|
46 /* This is desirable for most machines. */
|
|
47
|
|
48 #define NO_UNION_TYPE
|
|
49
|
|
50 /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend
|
|
51 the 24-bit bit field into an int. In other words, if bit fields
|
|
52 are always unsigned.
|
|
53
|
|
54 If you use NO_UNION_TYPE, this flag does not matter. */
|
|
55
|
|
56 #define EXPLICIT_SIGN_EXTEND
|
|
57
|
|
58 /* Data type of load average, as read out of kmem. */
|
|
59
|
|
60 #define LOAD_AVE_TYPE long
|
|
61
|
|
62 /* Convert that into an integer that is 100 for a load average of 1.0 */
|
|
63
|
|
64 #define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0 / FSCALE)
|
|
65
|
|
66 /* Define CANNOT_DUMP on machines where unexec does not work.
|
|
67 Then the function dump-emacs will not be defined
|
|
68 and temacs will do (load "loadup") automatically unless told otherwise. */
|
|
69
|
|
70 /*
|
|
71 #define CANNOT_DUMP 1
|
|
72 #define CANNOT_UNEXEC 1
|
|
73 */
|
|
74
|
|
75 /* Start and end of text and data. */
|
|
76 #define DATA_END get_data_end ()
|
|
77 #define DATA_START get_data_start ()
|
|
78
|
|
79 /* Define VIRT_ADDR_VARIES if the virtual addresses of
|
|
80 pure and impure space as loaded can vary, and even their
|
|
81 relative order cannot be relied on.
|
|
82
|
|
83 Otherwise Emacs assumes that text space precedes data space,
|
|
84 numerically. */
|
|
85
|
|
86 /* Text does preceed data space, but this is never a safe assumption. */
|
|
87 #define VIRT_ADDR_VARIES
|
|
88
|
|
89 /* Define C_ALLOCA if this machine does not support a true alloca
|
|
90 and the one written in C should be used instead.
|
|
91 Define HAVE_ALLOCA to say that the system provides a properly
|
|
92 working alloca function and it should be used.
|
|
93 Define neither one if an assembler-language alloca
|
|
94 in the file alloca.s should be used. */
|
|
95
|
|
96 /* #define C_ALLOCA */
|
|
97 #include <malloc.h>
|
|
98 #define HAVE_ALLOCA
|
|
99
|
|
100 /* Define NO_REMAP if memory segmentation makes it not work well
|
|
101 to change the boundary between the text section and data section
|
|
102 when Emacs is dumped. If you define this, the preloaded Lisp
|
|
103 code will not be sharable; but that's better than failing completely. */
|
|
104
|
|
105 /* #define NO_REMAP */
|
|
106
|
|
107 /* Some really obscure 4.2-based systems (like Sequent DYNIX)
|
|
108 * do not support asynchronous I/O (using SIGIO) on sockets,
|
|
109 * even though it works fine on tty's. If you have one of
|
|
110 * these systems, define the following, and then use it in
|
|
111 * config.h (or elsewhere) to decide when (not) to use SIGIO.
|
|
112 *
|
|
113 * You'd think this would go in an operating-system description file,
|
|
114 * but since it only occurs on some, but not all, BSD systems, the
|
|
115 * reasonable place to select for it is in the machine description
|
|
116 * file.
|
|
117 */
|
|
118
|
|
119 /* #define NO_SOCK_SIGIO */
|
|
120
|
|
121 /* After adding support for a new system, modify the large case
|
|
122 statement in the `configure' script to recognize reasonable
|
|
123 configuration names, and add a description of the system to
|
|
124 `etc/MACHINES'.
|
|
125
|
|
126 If you've just fixed a problem in an existing configuration file,
|
|
127 you should also check `etc/MACHINES' to make sure its descriptions
|
|
128 of known problems in that configuration should be updated. */
|