annotate src/m/mips.h @ 103512:ce2fc4a55d15

(lisp-indent-offset): Fix safe-local-variable property. (lisp-indent-function): Make it a defcustom.
author Glenn Morris <rgm@gnu.org>
date Mon, 22 Jun 2009 06:24:32 +0000
parents cfe3ab5226d6
children bae3b52cda07
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1113
0ffcf74fb8ad entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 749
diff changeset
1 /* m- file for Mips machines.
94714
7e5b32f86a4c Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 87730
diff changeset
2 Copyright (C) 1987, 1992, 1999, 2001, 2002, 2003, 2004, 2005, 2006,
100951
e038c1a8307c Add 2009 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 96877
diff changeset
3 2007, 2008, 2009 Free Software Foundation, Inc.
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5 This file is part of GNU Emacs.
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6
94714
7e5b32f86a4c Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 87730
diff changeset
7 GNU Emacs is free software: you can redistribute it and/or modify
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
8 it under the terms of the GNU General Public License as published by
94714
7e5b32f86a4c Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 87730
diff changeset
9 the Free Software Foundation, either version 3 of the License, or
7e5b32f86a4c Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 87730
diff changeset
10 (at your option) any later version.
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
11
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
12 GNU Emacs is distributed in the hope that it will be useful,
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
15 GNU General Public License for more details.
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
16
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
94714
7e5b32f86a4c Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 87730
diff changeset
18 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
19
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
20
49600
23a1cea22d13 Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents: 48552
diff changeset
21 /* The following line tells the configuration script what sort of
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
22 operating system this machine is likely to run.
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
23 USUAL-OPSYS="note"
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
24
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
25 NOTE-START
96719
f8ef0d7d5451 * m/mips.h: Remove boilerplate comments and code for systems that
Dan Nicolaescu <dann@ics.uci.edu>
parents: 96620
diff changeset
26 This is only used on GNU/Linux.
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
27 NOTE-END */
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
28
78499
49b363c28dce Replace `iff' in comments.
Glenn Morris <rgm@gnu.org>
parents: 78258
diff changeset
29 /* Define WORDS_BIG_ENDIAN if lowest-numbered byte in a word
9095
23f72b18b420 (WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents: 8892
diff changeset
30 is the most significant byte. */
23f72b18b420 (WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents: 8892
diff changeset
31
48552
b5cd6d8c8889 (WORDS_BIG_ENDIAN): Define conditionally.
Dave Love <fx@gnu.org>
parents: 44601
diff changeset
32 #if ! (defined (__MIPSEL__) || defined (MIPSEL) || defined (_MIPSEL))
9095
23f72b18b420 (WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents: 8892
diff changeset
33 #define WORDS_BIG_ENDIAN
48552
b5cd6d8c8889 (WORDS_BIG_ENDIAN): Define conditionally.
Dave Love <fx@gnu.org>
parents: 44601
diff changeset
34 #endif
9095
23f72b18b420 (WORDS_BIG_ENDIAN): define or undef appropriately, superseding BIG_ENDIAN.
Karl Heuer <kwzh@gnu.org>
parents: 8892
diff changeset
35
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
36 /* Define NO_ARG_ARRAY if you cannot take the address of the first of a
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
37 * group of arguments and treat it as an array of the arguments. */
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
38
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
39 #define NO_ARG_ARRAY
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
40
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
41 /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
42 the 24-bit bit field into an int. In other words, if bit fields
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
43 are always unsigned.
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
44
96602
0e3e875ffade * lisp.h:
Dan Nicolaescu <dann@ics.uci.edu>
parents: 96581
diff changeset
45 This flag only matters if you use USE_LISP_UNION_TYPE. */
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
46
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
47 #define EXPLICIT_SIGN_EXTEND
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
48
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
49 /* Describe layout of the address space in an executing process. */
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
50
18397
2af6faafc827 Test __linux__ along with NEWSOS5.
Richard M. Stallman <rms@gnu.org>
parents: 16441
diff changeset
51 #define TEXT_START 0x00400000
103275
cfe3ab5226d6 * m/mips.h [GNU_LINUX]: Don't define DATA_START (Bug#2685).
Chong Yidong <cyd@stupidchicken.com>
parents: 102344
diff changeset
52
cfe3ab5226d6 * m/mips.h [GNU_LINUX]: Don't define DATA_START (Bug#2685).
Chong Yidong <cyd@stupidchicken.com>
parents: 102344
diff changeset
53 #ifndef GNU_LINUX
18397
2af6faafc827 Test __linux__ along with NEWSOS5.
Richard M. Stallman <rms@gnu.org>
parents: 16441
diff changeset
54 #define DATA_START 0x10000000
103275
cfe3ab5226d6 * m/mips.h [GNU_LINUX]: Don't define DATA_START (Bug#2685).
Chong Yidong <cyd@stupidchicken.com>
parents: 102344
diff changeset
55 #endif
102344
2f1c4821a7d3 (DATA_SEG_BITS, XUINT, XSET): Definitions disabled.
Richard M. Stallman <rms@gnu.org>
parents: 100951
diff changeset
56
2f1c4821a7d3 (DATA_SEG_BITS, XUINT, XSET): Definitions disabled.
Richard M. Stallman <rms@gnu.org>
parents: 100951
diff changeset
57
2f1c4821a7d3 (DATA_SEG_BITS, XUINT, XSET): Definitions disabled.
Richard M. Stallman <rms@gnu.org>
parents: 100951
diff changeset
58 #if 0 /* These definitions were advantageous when not using
2f1c4821a7d3 (DATA_SEG_BITS, XUINT, XSET): Definitions disabled.
Richard M. Stallman <rms@gnu.org>
parents: 100951
diff changeset
59 USE_LSB_TAG. With that, they get ignored but cause errors. */
2f1c4821a7d3 (DATA_SEG_BITS, XUINT, XSET): Definitions disabled.
Richard M. Stallman <rms@gnu.org>
parents: 100951
diff changeset
60
18397
2af6faafc827 Test __linux__ along with NEWSOS5.
Richard M. Stallman <rms@gnu.org>
parents: 16441
diff changeset
61 #define DATA_SEG_BITS 0x10000000
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
62
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
63 /* The standard definitions of these macros would work ok,
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
64 but these are faster because the constants are short. */
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
65
13365
2cd15d90fec6 (SHORTBITS, INTBITS, LONGBITS): Deleted; now in config.h
Karl Heuer <kwzh@gnu.org>
parents: 9258
diff changeset
66 #define XUINT(a) (((unsigned)(a) << (BITS_PER_INT-VALBITS)) >> (BITS_PER_INT-VALBITS))
456
c0335c02f1d7 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
67
1113
0ffcf74fb8ad entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 749
diff changeset
68 #define XSET(var, type, ptr) \
0ffcf74fb8ad entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 749
diff changeset
69 ((var) = \
0ffcf74fb8ad entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 749
diff changeset
70 ((int)(type) << VALBITS) \
13365
2cd15d90fec6 (SHORTBITS, INTBITS, LONGBITS): Deleted; now in config.h
Karl Heuer <kwzh@gnu.org>
parents: 9258
diff changeset
71 + (((unsigned) (ptr) << (BITS_PER_INT-VALBITS)) >> (BITS_PER_INT-VALBITS)))
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 49600
diff changeset
72
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 49600
diff changeset
73 /* arch-tag: 8fd020ee-78a7-4d87-96ce-6129f52f7bee
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 49600
diff changeset
74 (do not change this comment) */
102344
2f1c4821a7d3 (DATA_SEG_BITS, XUINT, XSET): Definitions disabled.
Richard M. Stallman <rms@gnu.org>
parents: 100951
diff changeset
75
2f1c4821a7d3 (DATA_SEG_BITS, XUINT, XSET): Definitions disabled.
Richard M. Stallman <rms@gnu.org>
parents: 100951
diff changeset
76 #endif /* 0 */
2f1c4821a7d3 (DATA_SEG_BITS, XUINT, XSET): Definitions disabled.
Richard M. Stallman <rms@gnu.org>
parents: 100951
diff changeset
77