home *** CD-ROM | disk | FTP | other *** search
/ Linux Cubed Series 2: Applications / Linux Cubed Series 2 - Applications.iso / editors / emacs / xemacs / xemacs-1.004 / xemacs-1 / xemacs-19.13 / src / m / mg1.h < prev    next >
Encoding:
Text File  |  1995-07-28  |  3.9 KB  |  104 lines

  1. /* machine description file for Whitechapel Computer Works MG1 (ns16000 based).
  2.    Copyright (C) 1985 Free Software Foundation, Inc.
  3.    MG-1 version by L.M.McLoughlin
  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. /* Synched up with: FSF 19.29. */
  22.  
  23. /* The following line tells the configuration script what sort of 
  24.    operating system this machine is likely to run.
  25.    USUAL-OPSYS="note"
  26.  
  27. NOTE-START
  28. We are in the dark about what operating system runs on the Whitechapel
  29. systems.  Consult share-lib/MACHINES for information on which
  30. operating systems Emacs has already been ported to; one of them might
  31. work.  If you find an existing system name that works or write your
  32. own configuration files, please let the Free Software Foundation in on
  33. your work; we'd like to distribute this information.
  34. NOTE-END  */
  35.  
  36. /* Define WORD_MACHINE if addresses and such have
  37.  * to be corrected before they can be used as byte counts.  */
  38. /* ns16000 addresses are byte addresses */
  39. #undef WORD_MACHINE
  40.  
  41. /* Now define a symbol for the cpu type, if your compiler
  42.    does not define it automatically:
  43.    vax, m68000, ns16000, pyramid, orion, tahoe and APOLLO
  44.    are the ones defined so far.  */
  45. /* Say this machine is a 16000 and an mg1, cpp says its a 32000 */
  46. #define ns16000
  47. #define mg1
  48.  
  49. /* Use type int rather than a union, to represent Lisp_Object */
  50. /* This is desirable for most machines.  */
  51. /* Not sure on mg-1 but this shouldn't hurt! */
  52. #define NO_UNION_TYPE
  53.  
  54. /* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend
  55.    the bit field into an int.  In other words, if bit fields
  56.    are always unsigned.
  57.  
  58.    If you use NO_UNION_TYPE, this flag does not matter.  */
  59.  
  60. #define EXPLICIT_SIGN_EXTEND
  61.  
  62. /* Data type of load average, as read out of kmem.  */
  63. /* mg1 its an unsigned long */
  64. #define LOAD_AVE_TYPE unsigned long
  65.  
  66. /* Convert that into an integer that is 100 for a load average of 1.0  */
  67. #define    FSCALE    1000.0
  68. #define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0 / FSCALE)
  69.  
  70. /* Define CANNOT_DUMP on machines where unexec does not work.
  71.    Then the function dump-emacs will not be defined
  72.    and temacs will do (load "loadup") automatically unless told otherwise.  */
  73. /* ns16000's have an unexec, so should the mg-1 */
  74. #undef CANNOT_DUMP
  75.  
  76. /* Define VIRT_ADDR_VARIES if the virtual addresses of
  77.    pure and impure space as loaded can vary, and even their
  78.    relative order cannot be relied on.
  79.  
  80.    Otherwise Emacs assumes that text space precedes data space,
  81.    numerically.  */
  82. /* hmmmm... not sure.  copied sequent.h */
  83. #undef VIRT_ADDR_VARIES
  84.  
  85. /* Define C_ALLOCA if this machine does not support a true alloca
  86.    and the one written in C should be used instead.
  87.    Define HAVE_ALLOCA to say that the system provides a properly
  88.    working alloca function and it should be used.
  89.    Define neither one if an assembler-language alloca
  90.    in the file alloca.s should be used.  */
  91. /* hmmmm... again not sure.  so copied sequent.h again! */
  92. #undef C_ALLOCA
  93. #undef HAVE_ALLOCA
  94.  
  95. /* Define NO_REMAP if memory segmentation makes it not work well
  96.    to change the boundary between the text section and data section
  97.    when Emacs is dumped.  If you define this, the preloaded Lisp
  98.    code will not be sharable; but that's better than failing completely.  */
  99. /* mapping seems screwy */
  100. #define NO_REMAP
  101.  
  102. /* Avoids a compiler bug */
  103. /* borrowed from sequent.h */
  104.