annotate src/m/sr2k.h @ 70686:2006f23b693c

*** empty log message ***
author Thien-Thi Nguyen <ttn@gnuvola.org>
date Wed, 17 May 2006 06:12:44 +0000
parents 3bd95f4f2941
children e90d04cd455a c5406394f567
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
16793
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1 /* machine description file for Hitachi SR2001/SR2201 machines.
68651
3bd95f4f2941 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64767
diff changeset
2 Copyright (C) 1996, 2002, 2003, 2004, 2005,
3bd95f4f2941 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64767
diff changeset
3 2006 Free Software Foundation, Inc.
16793
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
4
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
5 This file is part of GNU Emacs.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
6
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
7 GNU Emacs is free software; you can redistribute it and/or modify
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
8 it under the terms of the GNU General Public License as published by
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
9 the Free Software Foundation; either version 2, or (at your option)
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
10 any later version.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
11
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
12 GNU Emacs is distributed in the hope that it will be useful,
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
15 GNU General Public License for more details.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
16
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
18 along with GNU Emacs; see the file COPYING. If not, write to
64083
23a17af379b1 Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 52495
diff changeset
19 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
23a17af379b1 Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 52495
diff changeset
20 Boston, MA 02110-1301, USA. */
16793
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
21
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
22
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48438
diff changeset
23 /* The following line tells the configuration script what sort of
16793
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
24 operating system this machine is likely to run.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
25 USUAL-OPSYS="hpux" */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
26
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
27 /* Define WORDS_BIG_ENDIAN iff lowest-numbered byte in a word
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
28 is the most significant byte. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
29
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
30 #define WORDS_BIG_ENDIAN
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
31
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
32 /* Define NO_ARG_ARRAY if you cannot take the address of the first of a
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
33 * group of arguments and treat it as an array of the arguments. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
34
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
35 #define NO_ARG_ARRAY
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
36
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
37 /* Define WORD_MACHINE if addresses and such have
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
38 * to be corrected before they can be used as byte counts. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
39
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
40 #undef WORD_MACHINE
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
41
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
42 /* Now define a symbol for the cpu type, if your compiler
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
43 does not define it automatically:
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
44 Ones defined so far include vax, m68000, ns16000, pyramid,
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
45 orion, tahoe, APOLLO and many others */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
46 #ifndef hp9000s800
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
47 # define hp9000s800
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
48 #endif
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
49
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
50 /* Use type int rather than a union, to represent Lisp_Object */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
51 /* This is desirable for most machines. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
52
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
53 #define NO_UNION_TYPE
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
54
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
55 /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
56 the bit field into an int. In other words, if bit fields
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
57 are always unsigned.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
58
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
59 If you use NO_UNION_TYPE, this flag does not matter. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
60
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
61 #define EXPLICIT_SIGN_EXTEND
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
62
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
63 /* The standard definitions of these macros would work ok,
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
64 but these are faster because the constants are short. */
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48438
diff changeset
65
16793
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
66
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
67 #define XUINT(a) (((unsigned)(a) << BITS_PER_INT-VALBITS) >> BITS_PER_INT-VALBITS)
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
68
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
69 #define XSET(var, type, ptr) \
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
70 ((var) = ((int)(type) << VALBITS) + (((unsigned) (ptr) << BITS_PER_INT-VALBITS) >> BITS_PER_INT-VALBITS))
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
71
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
72 /* #ifdef __hpux */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
73 /* Now define a symbol for the cpu type, if your compiler
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
74 does not define it automatically:
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
75 Ones defined so far include vax, m68000, ns16000, pyramid,
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
76 orion, tahoe, APOLLO and many others */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
77
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
78 #ifndef hp9000s800
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
79 # define hp9000s800
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
80 #endif
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
81
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
82
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
83 /* Data type of load average, as read out of kmem. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
84
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
85 #define LOAD_AVE_TYPE double
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
86
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
87 /* Convert that into an integer that is 100 for a load average of 1.0 */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
88
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
89 #define LOAD_AVE_CVT(x) ((int) (x * 100.0))
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
90
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
91
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
92 /* Define CANNOT_DUMP on machines where unexec does not work.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
93 Then the function dump-emacs will not be defined
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
94 and temacs will do (load "loadup") automatically unless told otherwise. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
95
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
96 #undef CANNOT_DUMP
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
97
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
98 /* Define VIRT_ADDR_VARIES if the virtual addresses of
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
99 pure and impure space as loaded can vary, and even their
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
100 relative order cannot be relied on.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
101
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
102 Otherwise Emacs assumes that text space precedes data space,
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
103 numerically. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
104
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
105 #define VIRT_ADDR_VARIES
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
106
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
107 /* the data segment on this machine always starts at address 0x40000000. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
108
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
109 #define DATA_SEG_BITS 0x40000000
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
110
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
111 #define DATA_START 0x40000000
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
112 #define TEXT_START 0x00000000
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
113
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
114 /* Define NO_REMAP if memory segmentation makes it not work well
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
115 to change the boundary between the text section and data section
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
116 when Emacs is dumped. If you define this, the preloaded Lisp
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
117 code will not be sharable; but that's better than failing completely. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
118
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
119 #define NO_REMAP
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
120
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
121 /* This machine requires completely different unexec code
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
122 which lives in a separate file. Specify the file name. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
123
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
124 #define UNEXEC unexhp9k800.o
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
125
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
126 #define LIBS_MACHINE
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
127 #define LIBS_DEBUG
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
128
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
129 /* Include the file bsdtty.h, since this machine has job control. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
130 /* #define NEED_BSDTTY */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
131
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
132 /* The symbol in the kernel where the load average is found
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
133 is named _avenrun. At this time there are two major flavors
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
134 of hp-ux (there is the s800 and s300 (s200) flavors). The
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
135 differences are thusly moved to the corresponding machine description file.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
136 */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
137
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
138 /* no underscore please */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
139 #define LDAV_SYMBOL "avenrun"
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
140
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
141 #if 0 /* Supposedly no longer true. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
142 /* In hpux, for unknown reasons, S_IFLNK is defined even though
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
143 symbolic links do not exist.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
144 Make sure our conditionals based on S_IFLNK are not confused.
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
145
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
146 Here we assume that stat.h is included before config.h
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
147 so that we can override it here. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
148
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
149 #undef S_IFLNK
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
150 #endif
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
151
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
152 /* On USG systems these have different names. */
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
153
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
154 #define index strchr
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
155 #define rindex strrchr
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
156
f932e8b3c525 Initial revision
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
157 /* #endif */
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 51772
diff changeset
158
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 51772
diff changeset
159 /* arch-tag: 4ced5b51-ffe6-4be1-9954-eb40657023a5
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 51772
diff changeset
160 (do not change this comment) */