Subject: pkg/35149: Mono build patches for NetBSD
To: None <pkg-manager@netbsd.org, gnats-admin@netbsd.org,>
From: None <antiright@gmail.com>
List: pkgsrc-bugs
Date: 11/28/2006 20:20:00
>Number: 35149
>Category: pkg
>Synopsis: Mono build patches for NetBSD
>Confidential: no
>Severity: serious
>Priority: medium
>Responsible: pkg-manager
>State: open
>Class: change-request
>Submitter-Id: net
>Arrival-Date: Tue Nov 28 20:20:00 +0000 2006
>Originator: Jeffrey Bedard
>Release: 3.1_STABLE
>Organization:
University of Rhode Island
>Environment:
NetBSD antiright.dyndns.org 3.1_STABLE NetBSD 3.1_STABLE (AR) #2: Mon Nov 27 17:43:54 EST 2006 root@antiright.dyndns.org:/usr/sources/src/sys/arch/amd64/compile/AR amd64
>Description:
mono does not currently build for NetBSD in pkgsrc. I was able to build mono, however the mcs directory does not yet build. The patches for building without mcs on NetBSD/amd64 are attached.
>How-To-Repeat:
Attempt a mono build on NetBSD/amd64.
>Fix:
--- ./mono/utils/mono-codeman.c.orig 2006-11-27 23:32:19.000000000 -0500
+++ ./mono/utils/mono-codeman.c 2006-11-27 23:34:02.000000000 -0500
@@ -46,7 +46,8 @@
#endif
#ifdef __x86_64__
-#define ARCH_MAP_FLAGS MAP_32BIT
+/*#define ARCH_MAP_FLAGS MAP_32BIT*/
+#define ARCH_MAP_FLAGS 0
#else
#define ARCH_MAP_FLAGS 0
#endif
--- ./mono/io-layer/collection.c.orig 2006-11-27 23:34:35.000000000 -0500
+++ ./mono/io-layer/collection.c 2006-11-27 23:35:47.000000000 -0500
@@ -60,7 +60,7 @@
g_assert (ret == 0);
#ifdef HAVE_PTHREAD_ATTR_SETSTACKSIZE
-#ifdef __FreeBSD__
+#ifdef PLATFORM_BSD
ret = pthread_attr_setstacksize (&attr, 65536);
#else
ret = pthread_attr_setstacksize (&attr, PTHREAD_STACK_MIN);
--- ./mono/metadata/boehm-gc.c.orig 2006-11-27 23:40:40.000000000 -0500
+++ ./mono/metadata/boehm-gc.c 2006-11-27 23:42:42.000000000 -0500
@@ -76,23 +76,20 @@
gboolean
mono_gc_is_gc_thread (void)
{
-#ifdef USE_INCLUDED_LIBGC
- return GC_thread_is_registered ();
-#else
return TRUE;
-#endif
}
gboolean
mono_gc_register_thread (void *baseptr)
{
if (mono_gc_is_gc_thread())
+ {
return TRUE;
-#if defined(USE_INCLUDED_LIBGC) && !defined(PLATFORM_WIN32)
- return GC_thread_register_foreign (baseptr);
-#else
- return FALSE;
-#endif
+ }
+ else
+ {
+ return FALSE;
+ }
}
extern int GC_is_marked (void *p);
--- ./mono/mini/exceptions-amd64.c.orig 2006-11-27 23:46:56.000000000 -0500
+++ ./mono/mini/exceptions-amd64.c 2006-11-27 23:56:01.000000000 -0500
@@ -21,6 +21,9 @@
#include <mono/metadata/exception.h>
#include <mono/metadata/gc-internal.h>
#include <mono/metadata/mono-debug.h>
+#ifdef PLATFORM_BSD
+#include <amd64/mcontext.h>
+#endif
#include "mini.h"
#include "mini-amd64.h"
@@ -634,7 +637,7 @@
static inline guint64*
gregs_from_ucontext (ucontext_t *ctx)
{
-#ifdef __FreeBSD__
+#ifdef PLATFORM_BSD
guint64 *gregs = (guint64 *) &ctx->uc_mcontext;
#else
guint64 *gregs = (guint64 *) &ctx->uc_mcontext.gregs;
@@ -649,7 +652,7 @@
ucontext_t *ctx = (ucontext_t*)sigctx;
guint64 *gregs = gregs_from_ucontext (ctx);
-
+#ifndef PLATFORM_BSD
mctx->rax = gregs [REG_RAX];
mctx->rbx = gregs [REG_RBX];
mctx->rcx = gregs [REG_RCX];
@@ -663,6 +666,22 @@
mctx->r13 = gregs [REG_R13];
mctx->r14 = gregs [REG_R14];
mctx->r15 = gregs [REG_R15];
+#else
+ mctx->rax = gregs [_REG_RAX];
+ mctx->rbx = gregs [_REG_RBX];
+ mctx->rcx = gregs [_REG_RCX];
+ mctx->rdx = gregs [_REG_RDX];
+ mctx->rbp = gregs [_REG_RBP];
+ mctx->rsp = gregs [_REG_URSP];
+ mctx->rsi = gregs [_REG_RSI];
+ mctx->rdi = gregs [_REG_RDI];
+ mctx->rip = gregs [_REG_RIP];
+ mctx->r12 = gregs [_REG_R12];
+ mctx->r13 = gregs [_REG_R13];
+ mctx->r14 = gregs [_REG_R14];
+ mctx->r15 = gregs [_REG_R15];
+
+#endif
}
void
@@ -671,7 +690,7 @@
ucontext_t *ctx = (ucontext_t*)sigctx;
guint64 *gregs = gregs_from_ucontext (ctx);
-
+#ifndef PLATFORM_BSD
gregs [REG_RAX] = mctx->rax;
gregs [REG_RBX] = mctx->rbx;
gregs [REG_RCX] = mctx->rcx;
@@ -685,6 +704,22 @@
gregs [REG_R13] = mctx->r13;
gregs [REG_R14] = mctx->r14;
gregs [REG_R15] = mctx->r15;
+#else
+ gregs [_REG_RAX] = mctx->rax;
+ gregs [_REG_RBX] = mctx->rbx;
+ gregs [_REG_RCX] = mctx->rcx;
+ gregs [_REG_RDX] = mctx->rdx;
+ gregs [_REG_RBP] = mctx->rbp;
+ gregs [_REG_URSP] = mctx->rsp;
+ gregs [_REG_RSI] = mctx->rsi;
+ gregs [_REG_RDI] = mctx->rdi;
+ gregs [_REG_RIP] = mctx->rip;
+ gregs [_REG_R12] = mctx->r12;
+ gregs [_REG_R13] = mctx->r13;
+ gregs [_REG_R14] = mctx->r14;
+ gregs [_REG_R15] = mctx->r15;
+
+#endif
}
gpointer
@@ -693,7 +728,10 @@
ucontext_t *ctx = (ucontext_t*)sigctx;
guint64 *gregs = gregs_from_ucontext (ctx);
-
+#ifndef PLATFORM_BSD
return (gpointer)gregs [REG_RIP];
+#else
+ return (gpointer)gregs [_REG_RIP];
+#endif
}
--- ./mono/mini/aot-runtime.c.orig 2006-11-27 23:56:52.000000000 -0500
+++ ./mono/mini/aot-runtime.c 2006-11-28 00:46:04.000000000 -0500
@@ -398,7 +398,7 @@
res = g_spawn_command_line_sync (cmd, &out, &err, &exit_status, NULL);
-#if !defined(PLATFORM_WIN32) && !defined(__ppc__) && !defined(__powerpc__)
+#if !defined(PLATFORM_WIN32) && !defined(__ppc__) && !defined(__powerpc__) && !defined(PLATFORM_BSD)
if (res) {
if (!WIFEXITED (exit_status) && (WEXITSTATUS (exit_status) == 0))
mono_trace (G_LOG_LEVEL_MESSAGE, MONO_TRACE_AOT, "AOT failed: %s.", err);