pkgsrc-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[pkgsrc/trunk]: pkgsrc/lang/drscheme Add DragonFly support based on patch by ...
details:   https://anonhg.NetBSD.org/pkgsrc/rev/83fe94ea4e03
branches:  trunk
changeset: 517783:83fe94ea4e03
user:      joerg <joerg%pkgsrc.org@localhost>
date:      Tue Aug 22 20:17:23 2006 +0000
description:
Add DragonFly support based on patch by Jeffrey Hsu.
Fix build with X11BASE!=/usr/X11R6.
diffstat:
 lang/drscheme/Makefile         |    7 ++-
 lang/drscheme/distinfo         |    8 ++-
 lang/drscheme/patches/patch-aa |   42 ++++++++++++++
 lang/drscheme/patches/patch-ab |   36 ++++++++++++
 lang/drscheme/patches/patch-ac |   71 ++++++++++++++++++++++++
 lang/drscheme/patches/patch-ad |   20 ++++++
 lang/drscheme/patches/patch-ae |  121 +++++++++++++++++++++++++++++++++++++++++
 lang/drscheme/patches/patch-af |   42 ++++++++++++++
 8 files changed, 345 insertions(+), 2 deletions(-)
diffs (truncated from 399 to 300 lines):
diff -r 8417a9efbe91 -r 83fe94ea4e03 lang/drscheme/Makefile
--- a/lang/drscheme/Makefile    Tue Aug 22 19:37:40 2006 +0000
+++ b/lang/drscheme/Makefile    Tue Aug 22 20:17:23 2006 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.37 2006/07/22 04:46:16 rillig Exp $
+# $NetBSD: Makefile,v 1.38 2006/08/22 20:17:23 joerg Exp $
 #
 
 DISTNAME=              plt-${DRSCHEME_VERSION}-src-unix
@@ -29,6 +29,11 @@
 
 USE_LANGUAGES=         c c++
 
+SUBST_CLASSES+=                x11root
+SUBST_STAGE.x11root=   post-patch
+SUBST_FILES.x11root=   ${WRKDIR}/plt/collects/sgl/makefile.ss
+SUBST_SED.x11root=     -e 's,/usr/X11R6,${X11BASE},'
+
 DRSCHEME_VERSION=      209
 
 # XXX: we pass this as the prefix to the configure script (see below) so
diff -r 8417a9efbe91 -r 83fe94ea4e03 lang/drscheme/distinfo
--- a/lang/drscheme/distinfo    Tue Aug 22 19:37:40 2006 +0000
+++ b/lang/drscheme/distinfo    Tue Aug 22 20:17:23 2006 +0000
@@ -1,4 +1,4 @@
-$NetBSD: distinfo,v 1.12 2005/02/24 09:03:06 agc Exp $
+$NetBSD: distinfo,v 1.13 2006/08/22 20:17:23 joerg Exp $
 
 SHA1 (drscheme/209/mred-doc.plt) = 8acbb38af09f7d0cbf60db0f28ea3b1cfdbecbcc
 RMD160 (drscheme/209/mred-doc.plt) = 89b0d4b5d1093b6e9f5d6d7afad0fc7fbb99dc3c
@@ -15,6 +15,12 @@
 SHA1 (drscheme/209/plt-209-src-unix.tgz) = 080b3a84ccc2600033ef082e726a5b3b07820a0f
 RMD160 (drscheme/209/plt-209-src-unix.tgz) = 1041d9a7e66d4565adf9a4e139d77885d0edd556
 Size (drscheme/209/plt-209-src-unix.tgz) = 10731358 bytes
+SHA1 (patch-aa) = bc92cf718d684f008e5ab0b182c589fc7f6971a9
+SHA1 (patch-ab) = f0c67e4b890569fcef614bc0d4c403c68df6c58d
+SHA1 (patch-ac) = 2bbd5efb27022c07ef22f0508516c60a197e912b
+SHA1 (patch-ad) = 205ecb6a6d996ebb703588de9f14baf32fdea927
+SHA1 (patch-ae) = 7323ae61c6685d2ed04cbca7dc98b80d37b982a2
+SHA1 (patch-af) = 50e731f41359997e4ef59a517c4fffc4a12ffc13
 SHA1 (patch-ag) = 4670f21302de022e299be0aeaa9d6c22abadd1ee
 SHA1 (patch-ah) = 4c6fa4ca44ae951b67ea4ebc1f8df841ccabdf10
 SHA1 (patch-ai) = cdab7bed524279a287845f03c642c7aafead7dc6
diff -r 8417a9efbe91 -r 83fe94ea4e03 lang/drscheme/patches/patch-aa
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/drscheme/patches/patch-aa    Tue Aug 22 20:17:23 2006 +0000
@@ -0,0 +1,42 @@
+$NetBSD: patch-aa,v 1.5 2006/08/22 20:17:23 joerg Exp $
+
+--- ../include/sconfig.h.orig  2004-12-19 08:38:25.000000000 +0000
++++ ../include/sconfig.h
+@@ -288,6 +288,37 @@
+ 
+ #endif
+ 
++  /************** x86/DragonFly with gcc ****************/
++
++# if defined(__DragonFly__) && defined(i386)
++
++# define SCHEME_PLATFORM_LIBRARY_SUBPATH "dragonfly"
++
++# include "uconfig.h"
++# undef HAS_STANDARD_IOB
++
++# define HAS_BSD_IOB
++
++# define STACK_GROWS_DOWN
++
++# define USE_UNDERSCORE_SETJMP
++
++# define USE_IEEE_FP_PREDS
++# define FREEBSD_CONTROL_387
++# define POW_HANDLES_INF_CORRECTLY
++
++# define USE_DYNAMIC_FDSET_SIZE
++
++# define SIGSET_IS_SIGNAL
++
++# define USE_TM_GMTOFF_FIELD
++
++# define REGISTER_POOR_MACHINE
++
++# define FLAGS_ALREADY_SET
++
++#endif
++
+   /************** x86/FreeBSD with gcc ****************/
+ 
+ # if defined(__FreeBSD__) && defined(i386)
diff -r 8417a9efbe91 -r 83fe94ea4e03 lang/drscheme/patches/patch-ab
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/drscheme/patches/patch-ab    Tue Aug 22 20:17:23 2006 +0000
@@ -0,0 +1,36 @@
+$NetBSD: patch-ab,v 1.5 2006/08/22 20:17:23 joerg Exp $
+
+--- mzscheme/gc/dyn_load.c.orig        2004-12-19 08:38:25.000000000 +0000
++++ mzscheme/gc/dyn_load.c
+@@ -57,6 +57,7 @@
+     !defined(HPUX) && !(defined(LINUX) && defined(__ELF__)) && \
+     !defined(RS6000) && !defined(SCO_ELF) && !defined(DGUX) && \
+     !(defined(FREEBSD) && defined(__ELF__)) && \
++    !(defined(DRAGONFLY) && defined(__ELF__)) && \
+     !(defined(NETBSD) && defined(__ELF__)) && !defined(HURD) && \
+     !defined(DARWIN)
+  --> We only know how to find data segments of dynamic libraries for the
+@@ -81,8 +82,9 @@
+ #endif
+ 
+ #if defined(LINUX) && defined(__ELF__) || defined(SCO_ELF) || \
+-    (defined(FREEBSD) && defined(__ELF__)) || defined(DGUX) || \
+-    (defined(NETBSD) && defined(__ELF__)) || defined(HURD)
++    ((defined(FREEBSD) || defined(DRAGONFLY)) && defined(__ELF__)) || \
++    (defined(NETBSD) && defined(__ELF__)) || \
++    defined(DGUX) || defined(HURD)
+ #   include <stddef.h>
+ #   include <elf.h>
+ #   include <link.h>
+@@ -273,8 +275,9 @@ void GC_register_dynamic_libraries()
+ # endif /* SUNOS */
+ 
+ #if defined(LINUX) && defined(__ELF__) || defined(SCO_ELF) || \
+-    (defined(FREEBSD) && defined(__ELF__)) || defined(DGUX) || \
+-    (defined(NETBSD) && defined(__ELF__)) || defined(HURD)
++    ((defined(FREEBSD) || defined(DRAGONFLY)) && defined(__ELF__)) || \
++    (defined(NETBSD) && defined(__ELF__)) || \
++    defined(DGUX) || defined(HURD)
+ 
+ 
+ #ifdef USE_PROC_FOR_LIBRARIES
diff -r 8417a9efbe91 -r 83fe94ea4e03 lang/drscheme/patches/patch-ac
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/drscheme/patches/patch-ac    Tue Aug 22 20:17:23 2006 +0000
@@ -0,0 +1,71 @@
+$NetBSD: patch-ac,v 1.5 2006/08/22 20:17:23 joerg Exp $
+
+--- mzscheme/gc/include/private/gcconfig.h.orig        2004-12-19 08:38:25.000000000 +0000
++++ mzscheme/gc/include/private/gcconfig.h
+@@ -54,6 +54,11 @@
+ #    define OPENBSD
+ # endif
+ 
++/* And one for DragonFlyBSD: */
++# if defined(__DragonFly__)
++#    define DRAGONFLY
++# endif
++
+ /* And one for FreeBSD: */
+ # if defined(__FreeBSD__)
+ #    define FREEBSD
+@@ -303,7 +308,7 @@
+ #   define OPENBSD
+ #   define mach_type_known
+ # endif
+-# if defined(FREEBSD) && (defined(i386) || defined(__i386__))
++# if (defined(FREEBSD) || defined(DRAGONFLY)) && (defined(i386) || defined(__i386__))
+ #   define I386
+ #   define mach_type_known
+ # endif
+@@ -443,7 +448,8 @@
+                   /*             MACOS and AMIGA variants)            */
+                   /*             I386       ==> Intel 386             */
+                   /*              (SEQUENT, OS2, SCO, LINUX, NETBSD,  */
+-                  /*               FREEBSD, THREE86BSD, MSWIN32,      */
++                  /*               DRAGONFLY, FREEBSD, THREE86BSD,    */
++                  /*               MSWIN32,                           */
+                   /*               BSDI,SUNOS5, NEXT, other variants) */
+                     /*             NS32K      ==> Encore Multimax     */
+                     /*             MIPS       ==> R2000 or R3000      */
+@@ -1188,6 +1194,21 @@
+ #   ifdef OPENBSD
+ #     define OS_TYPE "OPENBSD"
+ #   endif
++#   ifdef DRAGONFLY
++#     define OS_TYPE "DRAGONFLY"
++#     ifndef GC_FREEBSD_THREADS
++#         define MPROTECT_VDB
++#     endif
++#     define SIG_SUSPEND SIGUSR1
++#     define SIG_THR_RESTART SIGUSR2
++#     define FREEBSD_STACKBOTTOM
++#     ifdef __ELF__
++#         define DYNAMIC_LOADING
++#     endif
++      extern char etext[];
++      extern char * GC_FreeBSDGetDataStart();
++#     define DATASTART GC_FreeBSDGetDataStart(0x1000, &etext)
++#   endif
+ #   ifdef FREEBSD
+ #     define OS_TYPE "FREEBSD"
+ #     ifndef GC_FREEBSD_THREADS
+@@ -1940,8 +1961,13 @@
+ #   define SUNOS5SIGS
+ # endif
+ 
++# if defined(DRAGONFLY)
++#   define SUNOS5SIGS
++# endif
++
+ # if defined(SVR4) || defined(LINUX) || defined(IRIX5) || defined(HPUX) \
+           || defined(OPENBSD) || defined(NETBSD) || defined(FREEBSD) \
++          || defined(DRAGONFLY) \
+           || defined(DGUX) || defined(BSD) || defined(SUNOS4) \
+           || defined(_AIX) || defined(DARWIN) || defined(OSF1)
+ #   define UNIX_LIKE   /* Basic Unix-like system calls work.  */
diff -r 8417a9efbe91 -r 83fe94ea4e03 lang/drscheme/patches/patch-ad
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/drscheme/patches/patch-ad    Tue Aug 22 20:17:23 2006 +0000
@@ -0,0 +1,20 @@
+$NetBSD: patch-ad,v 1.5 2006/08/22 20:17:23 joerg Exp $
+
+--- mzscheme/gc/mach_dep.c.orig        2004-12-19 08:38:26.000000000 +0000
++++ mzscheme/gc/mach_dep.c
+@@ -216,6 +216,7 @@ void GC_push_regs()
+       && !defined(SCO) && !defined(SCO_ELF) \
+       && !(defined(LINUX) && defined(__ELF__)) \
+       && !(defined(FREEBSD) && defined(__ELF__)) \
++      && !(defined(DRAGONFLY) && defined(__ELF__)) \
+       && !(defined(NETBSD) && defined(__ELF__)) \
+       && !(defined(OPENBSD) && defined(__ELF__)) \
+       && !(defined(BEOS) && defined(__ELF__)) \
+@@ -235,6 +236,7 @@ void GC_push_regs()
+ 
+ #     if ( defined(I386) && defined(LINUX) && defined(__ELF__) ) \
+       || ( defined(I386) && defined(FREEBSD) && defined(__ELF__) ) \
++      || ( defined(I386) && defined(DRAGONFLY) && defined(__ELF__) ) \
+       || ( defined(I386) && defined(NETBSD) && defined(__ELF__) ) \
+       || ( defined(I386) && defined(OPENBSD) && defined(__ELF__) ) \
+       || ( defined(I386) && defined(HURD) && defined(__ELF__) ) \
diff -r 8417a9efbe91 -r 83fe94ea4e03 lang/drscheme/patches/patch-ae
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/drscheme/patches/patch-ae    Tue Aug 22 20:17:23 2006 +0000
@@ -0,0 +1,121 @@
+$NetBSD: patch-ae,v 1.5 2006/08/22 20:17:23 joerg Exp $
+
+--- mzscheme/gc/os_dep.c.orig  2004-12-19 08:38:26.000000000 +0000
++++ mzscheme/gc/os_dep.c
+@@ -80,7 +80,7 @@
+ #   define NEED_FIND_LIMIT
+ # endif
+ 
+-#if defined(FREEBSD) && defined(I386)
++#if (defined(FREEBSD) || defined(DRAGONFLY)) && defined(I386)
+ #  include <machine/trap.h>
+ #  if !defined(PCR)
+ #    define NEED_FIND_LIMIT
+@@ -129,7 +129,7 @@
+ 
+ #ifdef UNIX_LIKE
+ # include <fcntl.h>
+-# if defined(SUNOS5SIGS) && !defined(FREEBSD)
++# if defined(SUNOS5SIGS) && !(defined(FREEBSD) || defined(DRAGONFLY))
+ #  include <sys/siginfo.h>
+ # endif
+   /* Define SETJMP and friends to be the version that restores        */
+@@ -1385,7 +1385,7 @@ int * etext_addr;
+ }
+ # endif
+ 
+-# if defined(FREEBSD) && defined(I386) && !defined(PCR)
++# if (defined(FREEBSD) || defined(DRAGONFLY)) && defined(I386) && !defined(PCR)
+ /* Its unclear whether this should be identical to the above, or      */
+ /* whether it should apply to non-X86 architectures.                  */
+ /* For now we don't assume that there is always an empty page after   */
+@@ -2253,7 +2253,7 @@ GC_bool is_ptrfree;
+ # endif /* !DARWIN */
+ # endif /* MSWIN32 || MSWINCE || DARWIN */
+ 
+-#if defined(SUNOS4) || (defined(FREEBSD) && !defined(SUNOS5SIGS))
++#if defined(SUNOS4) || ((defined(FREEBSD) || defined(DRAGONFLY)) && !defined(SUNOS5SIGS))
+     typedef void (* SIG_PF)();
+ #endif /* SUNOS4 || (FREEBSD && !SUNOS5SIGS) */
+ 
+@@ -2282,7 +2282,7 @@ GC_bool is_ptrfree;
+ #endif /* IRIX5 || OSF1 || HURD */
+ 
+ #if defined(SUNOS5SIGS)
+-# if defined(HPUX) || defined(FREEBSD)
++# if defined(HPUX) || (defined(FREEBSD) || defined(DRAGONFLY))
+ #   define SIGINFO_T siginfo_t
+ # else
+ #   define SIGINFO_T struct siginfo
+@@ -2387,7 +2387,7 @@ SIG_PF GC_old_segv_handler;      /* Also old 
+ 
+ /*ARGSUSED*/
+ #if !defined(DARWIN)
+-# if defined (SUNOS4) || (defined(FREEBSD) && !defined(SUNOS5SIGS))
++# if defined (SUNOS4) || ((defined(FREEBSD) || defined(DRAGONFLY)) && !defined(SUNOS5SIGS))
+     void GC_write_fault_handler(sig, code, scp, addr)
+     int sig, code;
+     struct sigcontext *scp;
+@@ -2398,7 +2398,7 @@ SIG_PF GC_old_segv_handler;      /* Also old 
+                           || (FC_CODE(code) == FC_OBJERR \
+                              && FC_ERRNO(code) == FC_PROT))
+ #   endif
+-#   ifdef FREEBSD
++#   if (defined(FREEBSD) || defined(DRAGONFLY))
+ #     define SIG_OK (sig == SIGBUS)
+ #     define CODE_OK (code == BUS_PAGE_FAULT)
+ #   endif
+@@ -2459,7 +2459,7 @@ SIG_PF GC_old_segv_handler;      /* Also old 
Home |
Main Index |
Thread Index |
Old Index