Annotation of GNUtools/emacs/src/m-convex.h, revision 1.1.1.1

1.1       root        1: /* m- file for convex C1-C3.
                      2:    Copyright (C) 1987, 1989 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: /* The following three symbols give information on
                     22:  the size of various data types.  */
                     23: 
                     24: #define SHORTBITS 16           /* Number of bits in a short */
                     25: 
                     26: #define INTBITS 32             /* Number of bits in an int */
                     27: 
                     28: #define LONGBITS 32            /* Number of bits in a long */
                     29: 
                     30: /* Define BIG_ENDIAN iff lowest-numbered byte in a word
                     31:    is the most significant byte.  */
                     32: 
                     33: #define BIG_ENDIAN
                     34: 
                     35: /* Define NO_ARG_ARRAY if you cannot take the address of the first of a
                     36:  * group of arguments and treat it as an array of the arguments.  */
                     37: 
                     38: /* #define NO_ARG_ARRAY */
                     39: 
                     40: /* Define WORD_MACHINE if addresses and such have
                     41:  * to be corrected before they can be used as byte counts.  */
                     42: 
                     43: /* #define WORD_MACHINE */
                     44: 
                     45: /* Define how to take a char and sign-extend into an int.
                     46:    On machines where char is signed, this is a no-op.  */
                     47: 
                     48: #define SIGN_EXTEND_CHAR(c) (c)
                     49: 
                     50: /* Now define a symbol for the cpu type, if your compiler
                     51:    does not define it automatically.  */
                     52: 
                     53: /* convex already defined... */
                     54: 
                     55: /* Use type int rather than a union, to represent Lisp_Object */
                     56: /* This is desirable for most machines.  */
                     57: 
                     58: #define NO_UNION_TYPE
                     59: 
                     60: /* crt0.c should use the vax-bsd style of entry, with no dummy args.  */
                     61: 
                     62: #define CRT0_DUMMIES
                     63: 
                     64: /* crt0.c should define a symbol `start' and do .globl with a dot.  */
                     65: 
                     66: #define DOT_GLOBAL_START
                     67: 
                     68: /* Data type of load average, as read out of kmem.  */
                     69: 
                     70: #define LOAD_AVE_TYPE double
                     71: 
                     72: /* Convert that into an integer that is 100 for a load average of 1.0  */
                     73: 
                     74: #define LOAD_AVE_CVT(x) (int) ((x) * 100.0)
                     75: 
                     76: /* Define CANNOT_DUMP on machines where unexec does not work.
                     77:    Then the function dump-emacs will not be defined
                     78:    and temacs will do (load "loadup") automatically unless told otherwise.  */
                     79: 
                     80: /* #define CANNOT_DUMP */
                     81: 
                     82: /* Define VIRT_ADDR_VARIES if the virtual addresses of
                     83:    pure and impure space as loaded can vary, and even their
                     84:    relative order cannot be relied on.
                     85: 
                     86:    Otherwise Emacs assumes that text space precedes data space,
                     87:    numerically.  */
                     88: 
                     89: /* #define VIRT_ADDR_VARIES */
                     90: 
                     91: /* Define C_ALLOCA if this machine does not support a true alloca
                     92:    and the one written in C should be used instead.
                     93:    Define HAVE_ALLOCA to say that the system provides a properly
                     94:    working alloca function and it should be used.
                     95:    Define neither one if an assembler-language alloca
                     96:    in the file alloca.s should be used.  */
                     97: 
                     98: /* #define C_ALLOCA */
                     99: #define HAVE_ALLOCA
                    100: 
                    101: #ifdef __GNUC__
                    102: #define alloca __builtin_alloca
                    103: #endif
                    104: 
                    105: /* Define NO_REMAP if memory segmentation makes it not work well
                    106:    to change the boundary between the text section and data section
                    107:    when Emacs is dumped.  If you define this, the preloaded Lisp
                    108:    code will not be sharable; but that's better than failing completely.  */
                    109: 
                    110: /* #define NO_REMAP */
                    111: 
                    112: /* Addresses on the Convex have the high bit set.  */
                    113: 
                    114: #define DATA_SEG_BITS 0x80000000
                    115: 
                    116: /* Right shift is logical shift, so use this to sign-extend a lisp int.  */
                    117:  
                    118: #define VSIGNBIT (1 << (VALBITS - 1))
                    119: #define VALLBITS ((1 << VALBITS) - 1)
                    120: #define XINT(a) ((int) ((((a) & VALLBITS) ^ VSIGNBIT) - VSIGNBIT))
                    121: 
                    122: /* Convex uses a special version of unexec.  */
                    123: 
                    124: #define UNEXEC unexconvex.o
                    125: 
                    126: /* you gotta define 'COFF' for post 6.1 unexec. */
                    127: 
                    128: #define COFF
                    129: #define TEXT_START 0x80001000
                    130: 
                    131: /* Posix stuff for Convex OS 8.1 and up. */
                    132: 
                    133: #define C_SWITCH_MACHINE -pcc
                    134: #define LD_SWITCH_MACHINE \
                    135:     -e__start -L /usr/lib \
                    136:     '-A__iob=___ap$$iob' '-A_use_libc_sema=___ap$$use_libc_sema'
                    137: 
                    138: /* Use setsid when starting up inferiors. */
                    139: #define HAVE_SETSID
                    140: 
                    141: /* Use <dirent.h>. */
                    142: #define SYSV_SYSTEM_DIR
                    143: #define HAVE_CLOSEDIR
                    144: 
                    145: #ifdef _POSIX_SOURCE
                    146: 
                    147: /* These symbols have been undefined to advance the state of the art. */
                    148: 
                    149: #define S_IFMT _S_IFMT
                    150: #define S_IFDIR _S_IFDIR
                    151: 
                    152: #define S_IREAD _S_IREAD
                    153: #define S_IWRITE _S_IWRITE
                    154: #define S_IEXEC _S_IEXEC
                    155: 
                    156: #endif
                    157: 
                    158: /* Ptys may start below ptyp0; call a routine to hunt for where. */
                    159: 
                    160: #undef FIRST_PTY_LETTER
                    161: #define FIRST_PTY_LETTER first_pty_letter()
                    162: 
                    163: #if 0
                    164: /* 
                    165:  * Force a K&R compilation and libraries with the Convex V 4.0 C compiler
                    166:  */
                    167: #define C_SWITCH_MACHINE -pcc
                    168: #define LIB_STANDARD -lc_old
                    169: #define LIBS_MACHINE -lC2_old
                    170: #define LD_SWITCH_MACHINE -X -NL -fn -Enoposix -A__iob=___ap\$$iob \
                    171:  -A_use_libc_sema=___ap\$$use_libc_sema -L /usr/lib
                    172: #endif

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.