From fd31bd0f3128ba01c706360af1709b7685fc4e7f Mon Sep 17 00:00:00 2001 From: kris Date: Thu, 18 Mar 2004 22:42:22 +0000 Subject: Port to amd64. Submitted by: James Van Artsdalen (james-freebsd-amd64 at jrv.org) Pointed out by: gallatin Much rejoicing by: kris --- editors/emacs21/files/patch-configure.in | 11 +- editors/emacs21/files/patch-src:m:amd64.h | 184 +++++++++++++++++++++++++++ editors/emacs21/files/patch-src:mem-limits.h | 11 ++ 3 files changed, 201 insertions(+), 5 deletions(-) create mode 100644 editors/emacs21/files/patch-src:m:amd64.h create mode 100644 editors/emacs21/files/patch-src:mem-limits.h (limited to 'editors/emacs21') diff --git a/editors/emacs21/files/patch-configure.in b/editors/emacs21/files/patch-configure.in index 954b7743170d..6a3bd7899d58 100644 --- a/editors/emacs21/files/patch-configure.in +++ b/editors/emacs21/files/patch-configure.in @@ -1,6 +1,6 @@ ---- configure.in.orig Sun Mar 16 14:06:05 2003 -+++ configure.in Thu Nov 20 13:54:06 2003 -@@ -179,6 +179,17 @@ +--- configure.in.orig Sun Mar 16 17:06:05 2003 ++++ configure.in Thu Mar 18 13:31:10 2004 +@@ -179,6 +179,18 @@ machine='' opsys='' unported=no case "${canonical}" in @@ -9,6 +9,7 @@ + opsys=freebsd + case "${canonical}" in + alpha*-*-freebsd*) machine=alpha ;; ++ amd64-*-freebsd*) machine=amd64 ;; + ia64-*-freebsd*) machine=ia64 ;; + i[3456]86-*-freebsd*) machine=intel386 ;; + sparc64-*-freebsd*) machine=sparc ;; @@ -18,7 +19,7 @@ ## NetBSD ports *-*-netbsd* ) opsys=netbsd -@@ -1032,7 +1043,6 @@ +@@ -1032,7 +1044,6 @@ ;; *-sysv4.2uw* ) opsys=unixware; NON_GNU_CPP=/lib/cpp ;; *-386bsd* ) opsys=386bsd ;; @@ -26,7 +27,7 @@ *-nextstep* ) opsys=nextstep ;; ## Otherwise, we'll fall through to the generic opsys code at the bottom. esac -@@ -2050,6 +2060,7 @@ +@@ -2050,6 +2061,7 @@ # Solaris requires -lintl if you want strerror (which calls dgettext) # to return localized messages. AC_CHECK_LIB(intl, dgettext) diff --git a/editors/emacs21/files/patch-src:m:amd64.h b/editors/emacs21/files/patch-src:m:amd64.h new file mode 100644 index 000000000000..3129433e59b5 --- /dev/null +++ b/editors/emacs21/files/patch-src:m:amd64.h @@ -0,0 +1,184 @@ +--- src/m/amd64.h~ Wed Dec 31 18:00:00 1969 ++++ src/m/amd64.h Thu Dec 18 00:21:51 2003 +@@ -0,0 +1,181 @@ ++/* machine description file For the amd64 chip. ++ Copyright (C) 1994, 1997, 1999 Free Software Foundation, Inc. ++ ++This file is part of GNU Emacs. ++ ++GNU Emacs is free software; you can redistribute it and/or modify ++it under the terms of the GNU General Public License as published by ++the Free Software Foundation; either version 1, or (at your option) ++any later version. ++ ++GNU Emacs is distributed in the hope that it will be useful, ++but WITHOUT ANY WARRANTY; without even the implied warranty of ++MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++GNU General Public License for more details. ++ ++You should have received a copy of the GNU General Public License ++along with GNU Emacs; see the file COPYING. If not, write to ++the Free Software Foundation, Inc., 59 Temple Place - Suite 330, ++Boston, MA 02111-1307, USA. */ ++ ++ ++/* The following line tells the configuration script what sort of ++ operating system this machine is likely to run. ++ USUAL-OPSYS="note" ++ ++NOTE-START ++Use -opsystem=freebsd ++NOTE-END ++ ++*/ ++ ++#define BITS_PER_LONG 64 ++#define BITS_PER_EMACS_INT 64 ++#ifndef _LP64 ++#define _LP64 ++#endif ++ ++/* Define WORDS_BIG_ENDIAN iff lowest-numbered byte in a word ++ is the most significant byte. */ ++ ++#undef WORDS_BIG_ENDIAN ++ ++/* Define NO_ARG_ARRAY if you cannot take the address of the first of a ++ * group of arguments and treat it as an array of the arguments. */ ++ ++#define NO_ARG_ARRAY ++ ++/* Now define a symbol for the cpu type, if your compiler ++ does not define it automatically: ++ Ones defined so far include vax, m68000, ns16000, pyramid, ++ orion, tahoe, APOLLO and many others */ ++ ++/* __amd64__ defined automatically */ ++ ++ ++/* Use type EMACS_INT rather than a union, to represent Lisp_Object */ ++/* This is desirable for most machines. */ ++ ++#define NO_UNION_TYPE ++ ++/* Define the type to use. */ ++#define EMACS_INT long ++#define EMACS_UINT unsigned long ++#define SPECIAL_EMACS_INT ++ ++/* Define EXPLICIT_SIGN_EXTEND if XINT must explicitly sign-extend ++ the 24-bit bit field into an int. In other words, if bit fields ++ are always unsigned. ++ ++ If you use NO_UNION_TYPE, this flag does not matter. */ ++ ++#undef EXPLICIT_SIGN_EXTEND ++ ++/* Data type of load average, as read out of kmem. */ ++ ++#define LOAD_AVE_TYPE long ++ ++/* Convert that into an integer that is 100 for a load average of 1.0 */ ++ ++#define LOAD_AVE_CVT(x) (int) (((double) (x)) * 100.0 / FSCALE) ++ ++/* Define C_ALLOCA if this machine does not support a true alloca ++ and the one written in C should be used instead. ++ Define HAVE_ALLOCA to say that the system provides a properly ++ working alloca function and it should be used. ++ Define neither one if an assembler-language alloca ++ in the file alloca.s should be used. */ ++ ++#define HAVE_ALLOCA ++ ++/* GNU malloc and the relocating allocator do not work together ++ with X. [Who wrote that?] */ ++ ++/* May 1995: reportedly [Rainer Schoepf ] both the ++ system and the gnu malloc system work with "alpha-dec-osf3.0" and ++ "alpha-dec-osf3.2". */ ++ ++/* May 1995: it seems to me [Morten Welinder ] that both ++ mallocs work with "alpha-dec-osf2.0", but I daren't break anything ++ right now. Feel free to play if you want. */ ++ ++/* #define SYSTEM_MALLOC */ ++ ++#ifdef __ELF__ ++/* With ELF, make sure that all common symbols get allocated to in the ++ data section. Otherwise, the dump of temacs may miss variables in ++ the shared library that have been initialized. For example, with ++ GNU libc, __malloc_initialized would normally be resolved to the ++ shared library's .bss section, which is fatal. */ ++# ifdef __GNUC__ ++# define C_SWITCH_MACHINE -fno-common ++# else ++# error What gives? Fix me if DEC Unix supports ELF now. ++# endif ++#endif ++ ++#if defined(__OpenBSD__) ++#define ORDINARY_LINK ++#endif ++ ++#ifdef __ELF__ ++#undef UNEXEC ++#define UNEXEC unexelf.o ++#endif ++ ++#if defined (LINUX) && __GNU_LIBRARY__ - 0 < 6 ++/* This controls a conditional in main. */ ++#define LINUX_SBRK_BUG ++#endif ++ ++ ++#define PNTR_COMPARISON_TYPE unsigned long ++ ++/* On the 64 bit architecture, we can use 60 bits for addresses */ ++ ++#define VALBITS 60 ++ ++ ++/* This definition of MARKBIT is necessary because of the comparison of ++ ARRAY_MARK_FLAG and MARKBIT in an #if in lisp.h, which cpp doesn't like. */ ++ ++/* #define MARKBIT 0x8000000000000000L */ ++ ++ ++/* Define XINT and XUINT so that they can take arguments of type int */ ++ ++#define XINT(a) (((long) (a) << (BITS_PER_LONG - VALBITS)) >> (BITS_PER_LONG - VALBITS)) ++#define XUINT(a) ((long) (a) & VALMASK) ++ ++/* Define XPNTR to avoid or'ing with DATA_SEG_BITS */ ++ ++#define XPNTR(a) XUINT (a) ++ ++#ifndef NOT_C_CODE ++/* We need these because pointers are larger than the default ints. */ ++#if !defined(__NetBSD__) && !defined(__OpenBSD__) && !defined(__FreeBSD__) ++#include ++#endif ++#endif /* not NOT_C_CODE */ ++ ++/* On the Alpha it's best to avoid including TERMIO since struct ++ termio and struct termios are mutually incompatible. */ ++/* #define NO_TERMIO */ ++ ++#if defined (LINUX) || defined (__NetBSD__) || defined (__OpenBSD__) ++# define TEXT_END ({ extern int _etext; &_etext; }) ++# ifndef __ELF__ ++# define COFF ++# define DATA_END ({ extern int _EDATA; &_EDATA; }) ++# endif /* notdef __ELF__ */ ++#endif ++ ++#if (defined (__NetBSD__) || defined (__OpenBSD__)) && defined (__ELF__) ++#define HAVE_TEXT_START ++#endif ++ ++/* Many Alpha implementations (e.g. gas 2.8) can't handle DBL_MIN: ++ they generate code that uses a signaling NaN instead of DBL_MIN. ++ Define DBL_MIN_REPLACEMENT to be the next value larger than DBL_MIN: ++ this avoids the assembler bug. */ ++/* #define DBL_MIN_REPLACEMENT 2.2250738585072019e-308 */ diff --git a/editors/emacs21/files/patch-src:mem-limits.h b/editors/emacs21/files/patch-src:mem-limits.h new file mode 100644 index 000000000000..c58dd778e2ec --- /dev/null +++ b/editors/emacs21/files/patch-src:mem-limits.h @@ -0,0 +1,11 @@ +--- src/mem-limits.h.~1~ Wed Mar 8 12:49:46 2000 ++++ src/mem-limits.h Wed Dec 17 03:15:24 2003 +@@ -98,7 +98,7 @@ + static POINTER data_space_start; + + /* Number of bytes of writable memory we can expect to be able to get */ +-static unsigned long lim_data; ++static rlim_t lim_data; + + #ifdef NO_LIM_DATA + static void -- cgit