sync with w3m-0.2.2-inu-1.1/gc, so Patches/ews4800 no longer needed

This commit is contained in:
Fumitoshi UKAI
2001-12-20 00:43:19 +00:00
parent 548b9dd8db
commit 0135453e04
3 changed files with 5 additions and 178 deletions

View File

@@ -1,6 +1,8 @@
2001-12-20 Fumitoshi UKAI <ukai@debian.or.jp>
* gc/: sync with w3m-0.2.2-inu-1.1/gc
* Patches/ews4800: deleted
* configure: comment out Patches/ews4800
2001-12-20 Hironori Sakamoto <hsaka@mth.biglobe.ne.jp>
@@ -1316,4 +1318,4 @@
* release-0-2-1
* import w3m-0.2.1
$Id: ChangeLog,v 1.140 2001/12/20 00:39:30 ukai Exp $
$Id: ChangeLog,v 1.141 2001/12/20 00:44:44 ukai Exp $

View File

@@ -1,175 +0,0 @@
diff -bcrN gc.org/doc/README.ews4800 gc/doc/README.ews4800
*** gc.org/doc/README.ews4800 Thu Jan 1 09:00:00 1970
--- gc/doc/README.ews4800 Wed Jul 25 17:38:57 2001
***************
*** 0 ****
--- 1,75 ----
+ GC on EWS4800
+ -------------
+
+ 1. About EWS4800
+ EWS4800 is 32bit/64bit workstation.
+
+ Vender: NEC Corporation
+ OS: UX/4800 R9.* - R13.* (SystemV R4.2)
+ CPU: R4000, R4400, R10000 (MIPS)
+
+ 2. Compiler
+
+ 32bit:
+ Use ANSI C compiler.
+ CC = /usr/abiccs/bin/cc
+
+ 64bit:
+ Use 64bit ANSI C compiler.
+ CC = /usr/ccs64/bin/cc
+ AR = /usr/ccs64/bin/ar
+
+ 3. ELF file format
+ *** Caution: The following infomation is empirical. ***
+
+ 32bit:
+ ELF file has an unique format. (See a.out(4) and end(3C).)
+
+ &_start
+ : text segment
+ &etext
+ DATASTART
+ : data segment (initialized)
+ &edata
+ DATASTART2
+ : data segment (uninitialized)
+ &end
+
+ Here, DATASTART and DATASTART2 are macros of GC, and are defined as
+ the following equations. (See include/private/gcconfig.h.)
+ The algorithm for DATASTART is similar with the function
+ GC_SysVGetDataStart() in os_dep.c.
+
+ DATASTART = ((&etext + 0x3ffff) & ~0x3ffff) + (&etext & 0xffff)
+
+ Dynamically linked:
+ DATASTART2 = (&_gp + 0x8000 + 0x3ffff) & ~0x3ffff
+
+ Statically linked:
+ DATASTART2 = &edata
+
+ GC has to check addresses both between DATASTART and &edata, and
+ between DATASTART2 and &end. If a program accesses between &etext
+ and DATASTART, or between &edata and DATASTART2, the segmentation
+ error occurs and the program stops.
+
+ If a program is statically linked, there is not a gap between
+ &edata and DATASTART2. The global symbol &_DYNAMIC_LINKING is used
+ for the detection.
+
+ 64bit:
+ ELF file has a simple format. (See end(3C).)
+
+ _ftext
+ : text segment
+ _etext
+ _fdata = DATASTART
+ : data segment (initialized)
+ _edata
+ _fbss
+ : data segment (uninitialized)
+ _end = DATAEND
+
+ --
+ Hironori SAKAMOTO <hsaka@mth.biglobe.ne.jp>
+
diff -bcrN gc.org/include/private/gcconfig.h gc/include/private/gcconfig.h
*** gc.org/include/private/gcconfig.h Sun Jul 1 06:29:27 2001
--- gc/include/private/gcconfig.h Wed Jul 25 17:38:57 2001
***************
*** 75,83 ****
# endif
# define mach_type_known
# endif
! # if defined(mips) || defined(__mips)
# define MIPS
! # if !defined(LINUX)
# if defined(ultrix) || defined(__ultrix) || defined(__NetBSD__)
# define ULTRIX
# else
--- 75,86 ----
# endif
# define mach_type_known
# endif
! # if defined(mips) || defined(__mips) || defined(_mips)
# define MIPS
! # if defined(nec_ews) || defined(_nec_ews)
! # define EWS4800
! # endif
! # if !defined(LINUX) && !defined(EWS4800)
# if defined(ultrix) || defined(__ultrix) || defined(__NetBSD__)
# define ULTRIX
# else
***************
*** 1083,1088 ****
--- 1086,1114 ----
/* instead. But some kernel versions seem to give the wrong */
/* value from /proc. */
# endif /* Linux */
+ # ifdef EWS4800
+ # define HEURISTIC2
+ # if defined(_MIPS_SZPTR) && (_MIPS_SZPTR == 64)
+ extern int _fdata[], _end[];
+ # define DATASTART ((ptr_t)_fdata)
+ # define DATAEND ((ptr_t)_end)
+ # define CPP_WORDSZ _MIPS_SZPTR
+ # define ALIGNMENT (_MIPS_SZPTR/8)
+ # else
+ extern int etext, edata, end;
+ extern int _DYNAMIC_LINKING, _gp;
+ # define DATASTART ((ptr_t)((((word)&etext + 0x3ffff) & ~0x3ffff) \
+ + ((word)&etext & 0xffff)))
+ # define DATAEND (&edata)
+ # define DATASTART2 (&_DYNAMIC_LINKING \
+ ? (ptr_t)(((word)&_gp + 0x8000 + 0x3ffff) & ~0x3ffff) \
+ : (ptr_t)&edata)
+ # define DATAEND2 (&end)
+ # define ALIGNMENT 4
+ # endif
+ # define OS_TYPE "EWS4800"
+ # define USE_GENERIC_PUSH_REGS 1
+ # endif
# ifdef ULTRIX
# define HEURISTIC2
# define DATASTART (ptr_t)0x10000000
diff -bcrN gc.org/mach_dep.c gc/mach_dep.c
*** gc.org/mach_dep.c Thu Jun 28 05:54:23 2001
--- gc/mach_dep.c Wed Jul 25 17:38:57 2001
***************
*** 429,435 ****
*i = 0;
}
# if defined(POWERPC) || defined(MSWIN32) || defined(MSWINCE) \
! || defined(UTS4) || defined(LINUX)
(void) setjmp(regs);
# else
(void) _setjmp(regs);
--- 429,435 ----
*i = 0;
}
# if defined(POWERPC) || defined(MSWIN32) || defined(MSWINCE) \
! || defined(UTS4) || defined(LINUX) || defined(EWS4800)
(void) setjmp(regs);
# else
(void) _setjmp(regs);
diff -bcrN gc.org/os_dep.c gc/os_dep.c
*** gc.org/os_dep.c Tue Jun 26 11:32:26 2001
--- gc/os_dep.c Wed Jul 25 17:38:57 2001
***************
*** 1088,1093 ****
--- 1088,1096 ----
GC_add_roots_inner(DATASTART, (char *)sbrk(0), FALSE);
# else
GC_add_roots_inner(DATASTART, (char *)(DATAEND), FALSE);
+ # if defined(DATASTART2)
+ GC_add_roots_inner(DATASTART2, (char *)(DATAEND2), FALSE);
+ # endif
# endif
# endif
# if !defined(PCR) && (defined(NEXT) || defined(MACOSX))

4
configure vendored
View File

@@ -1,5 +1,5 @@
#!/bin/sh
# $Id: configure,v 1.37 2001/12/19 18:16:18 ukai Exp $
# $Id: configure,v 1.38 2001/12/20 00:44:00 ukai Exp $
# Configuration.
#
@@ -1039,7 +1039,7 @@ if [ "$gclib" = "gc/gc.a" -a ! -f patch_done ]; then
case "$platform:$sysname" in
R3000:*System_V*|R4000:UNIX_SYSV|R*000:UNIX_SV)
# EWS-4800
patchfile=Patches/ews4800
# patchfile=Patches/ews4800
gc_cflags=-Dmips
;;
esac