annotate src/m/arm.h @ 412:697ef44129c6 r21-2-14

Import from CVS: tag r21-2-14
author cvs
date Mon, 13 Aug 2007 11:20:41 +0200
parents de805c49cfc1
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
321
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
1 /* Machine description file for digital/intel arm/strongarm
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
2 Copyright (C) 1987 Free Software Foundation, Inc.
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
3
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
4 This file is part of GNU Emacs.
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
5
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
6 GNU Emacs is free software; you can redistribute it and/or modify
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
7 it under the terms of the GNU General Public License as published by
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
8 the Free Software Foundation; either version 2, or (at your option)
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
9 any later version.
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
10
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
11 GNU Emacs is distributed in the hope that it will be useful,
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
14 GNU General Public License for more details.
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
15
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
17 along with XEmacs; see the file COPYING. If not, write to
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
19 Boston, MA 02111-1307, USA. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
20
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
21 /* Synched up with: FSF 19.31. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
22
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
23 /* Define WORD_MACHINE if addresses and such have
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
24 * to be corrected before they can be used as byte counts. */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
25
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
26 #undef WORD_MACHINE
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
27
321
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
28 /* Now define a symbol for the cpu type, if your compiler
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
29 does not define it automatically:
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
30 Ones defined so far include vax, m68000, ns16000, pyramid,
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
31 orion, tahoe, APOLLO and many others */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
32
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
33 #ifndef arm
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
34 #define arm
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
35 #endif
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
36
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
37 /* crt0.c, if it is used, should use the i386-bsd style of entry.
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
38 with no extra dummy args. On USG and XENIX,
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
39 NO_REMAP says this isn't used. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
40
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
41 /* Mly 16-Jan-96 16:38:32: this is part of a prototype -- same bug present in
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
42 other m*.h files */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
43 #define CRT0_DUMMIES int bogus_fp,
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
44
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
45 /* crt0.c should define a symbol `start' and do .globl with a dot. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
46
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
47 #define DOT_GLOBAL_START
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
48
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
49 #ifdef USG5_4 /* Older USG systems do not support the load average. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
50 /* Data type of load average, as read out of kmem. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
51
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
52 #define LOAD_AVE_TYPE long
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
53
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
54 /* Convert that into an integer that is 100 for a load average of 1.0 */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
55 /* This is totally uncalibrated. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
56
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
57
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
58 /* FSHIFT and FSCALE are defined in param.h, but are required by
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
59 LOAD_AVE_CVT, so they need to be defined here. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
60
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
61 #ifndef FSHIFT
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
62 #define FSHIFT 8 /* bits to right of fixed binary point */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
63 #endif
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
64
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
65 #ifndef FSCALE
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
66 #define FSCALE (1<<FSHIFT)
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
67 #endif
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
68
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
69 #define LOAD_AVE_CVT(x) ((int) (((double) (x)) * 100.0 / FSCALE))
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
70 #endif
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
71
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
72
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
73 /* Define CANNOT_DUMP on machines where unexec does not work.
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
74 Then the function dump-emacs will not be defined
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
75 and temacs will do (load "loadup") automatically unless told otherwise. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
76
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
77 #undef CANNOT_DUMP
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
78
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
79 /* Define VIRT_ADDR_VARIES if the virtual addresses of
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
80 pure and impure space as loaded can vary, and even their
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
81 relative order cannot be relied on.
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
82
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
83 Otherwise Emacs assumes that text space precedes data space,
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
84 numerically. */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
85
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
86 #undef VIRT_ADDR_VARIES
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
87
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
88
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
89 /* this brings in alloca() if we're using cc */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
90 #ifdef USG
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
91 #define NO_REMAP
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
92 #define TEXT_START 0
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
93 #endif /* USG */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
94
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
95
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
96 #ifdef USG5_4
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
97 #define DATA_SEG_BITS 0x08000000
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
98 #endif
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
99
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
100 #ifdef MSDOS
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
101 #define NO_REMAP
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
102 #endif
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
103
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
104 #ifdef WINDOWSNT
321
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
105 #define VIRT_ADDR_VARIES
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
106 #define DATA_END get_data_end ()
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
107 #define DATA_START get_data_start ()
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
108 #define HAVE_ALLOCA
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
109 #endif
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
110
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
111 #ifdef linux
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
112 /* libc-linux/sysdeps/linux/i386/ulimit.c says that due to shared library, */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
113 /* we cannot get the maximum address for brk */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
114 #define ULIMIT_BREAK_VALUE (32*1024*1024)
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
115
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
116 #define SEGMENT_MASK ((SEGMENT_SIZE)-1)
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
117 #endif
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
118
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
119 #if 0
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
120 #ifdef __GNUC__
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
121 /* GCC's alloca() is semi-broken. See lisp.h.
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
122
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
123 This brokenness has been confirmed under both Linux and NetBSD.
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
124 It may also exist on non-Intel architectures. */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
125 #define BROKEN_ALLOCA_IN_FUNCTION_CALLS
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
126 #endif
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
127 #endif
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
128
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
129
321
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
130 /* XEmacs change: John Hughes <john@AtlanTech.COM> says using vfork
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
131 under i386-unknown-sysv4.2 makes C-g sometimes cause a SIGSEGV
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
132 in TTY mode; the problem goes away if you use fork */
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
133 #ifdef USG5_4_2
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
134 #define vfork fork
19dcec799385 Import from CVS: tag r21-0-58
cvs
parents:
diff changeset
135 #endif