diff options
author | alepulver <alepulver@FreeBSD.org> | 2008-03-05 02:17:45 +0800 |
---|---|---|
committer | alepulver <alepulver@FreeBSD.org> | 2008-03-05 02:17:45 +0800 |
commit | a8e38ad645da7ae2709ec851c75e69c3408b8c43 (patch) | |
tree | b96ada896961f6b0c3dbc1babad62fa210acc725 | |
parent | 5ed0073ee1fcd8f37565865af9b0157281d3d174 (diff) | |
download | freebsd-ports-gnome-a8e38ad645da7ae2709ec851c75e69c3408b8c43.tar.gz freebsd-ports-gnome-a8e38ad645da7ae2709ec851c75e69c3408b8c43.tar.zst freebsd-ports-gnome-a8e38ad645da7ae2709ec851c75e69c3408b8c43.zip |
- Enable use of mmap() instead of malloc() in the x86 VM.
- Fix building the amd64 VM (MAP_ANONYMOUS -> MAP_ANON) [1].
Reported by: Dominic Fandrey <kamikaze@bsdforen.de> [1]
-rw-r--r-- | games/iourbanterror/files/patch-Makefile | 36 | ||||
-rw-r--r-- | games/iourbanterror/files/patch-code__qcommon__vm_x86.c | 20 | ||||
-rw-r--r-- | games/iourbanterror/files/patch-code__qcommon__vm_x86_64.c | 11 |
3 files changed, 56 insertions, 11 deletions
diff --git a/games/iourbanterror/files/patch-Makefile b/games/iourbanterror/files/patch-Makefile index 9cebe77b385d..1efcfda57fe6 100644 --- a/games/iourbanterror/files/patch-Makefile +++ b/games/iourbanterror/files/patch-Makefile @@ -1,5 +1,5 @@ ---- Makefile.orig Sun Dec 16 18:09:18 2007 -+++ Makefile Sun Jan 27 15:36:33 2008 +--- Makefile.orig 2007-12-16 18:09:18.000000000 -0300 ++++ Makefile 2008-02-28 11:39:45.000000000 -0300 @@ -27,16 +27,22 @@ endif endif @@ -170,7 +170,7 @@ - BASE_CFLAGS += -DNO_VM_COMPILED + ifeq ($(USE_SDL_AUDIO),1) + BASE_CFLAGS += -DUSE_SDL_SOUND=1 -+ endif + endif + + ifeq ($(USE_SDL_VIDEO),1) + BASE_CFLAGS += -DUSE_SDL_VIDEO=1 @@ -183,7 +183,7 @@ + RELEASE_CFLAGS+=-falign-loops=2 -falign-jumps=2 -falign-functions=2 \ + -fstrength-reduce + endif - endif ++ endif + + ifneq ($(HAVE_VM_COMPILED),true) + BASE_CFLAGS += -DNO_VM_COMPILED @@ -353,7 +353,21 @@ $(echo_cmd) "LD $@" $(Q)$(CC) -o $@ $(Q3OBJ) $(Q3POBJ_SMP) $(CLIENT_LDFLAGS) \ $(THREAD_LDFLAGS) $(LDFLAGS) $(LIBSDLMAIN) -@@ -1248,7 +1274,7 @@ +@@ -1240,15 +1266,21 @@ + ifeq ($(ARCH),x86) + Q3DOBJ += $(B)/ded/vm_x86.o + endif ++ ifeq ($(ARCH),amd64) ++ Q3DOBJ += $(B)/ded/vm_x86_64.o $(B)/client/vm_x86_64_assembler.o ++ endif + ifeq ($(ARCH),x86_64) + Q3DOBJ += $(B)/ded/vm_x86_64.o $(B)/client/vm_x86_64_assembler.o + endif ++ ifeq ($(ARCH),powerpc) ++ Q3DOBJ += $(B)/ded/vm_ppc.o ++ endif + ifeq ($(ARCH),ppc) + Q3DOBJ += $(B)/ded/vm_ppc.o endif endif @@ -362,7 +376,7 @@ $(echo_cmd) "LD $@" $(Q)$(CC) -o $@ $(Q3DOBJ) $(LDFLAGS) -@@ -1287,7 +1313,7 @@ +@@ -1287,7 +1319,7 @@ Q3CGOBJ = $(Q3CGOBJ_) $(B)/baseq3/cgame/cg_syscalls.o Q3CGVMOBJ = $(Q3CGOBJ_:%.o=%.asm) $(B)/baseq3/game/bg_lib.asm @@ -371,7 +385,7 @@ $(echo_cmd) "LD $@" $(Q)$(CC) $(SHLIBLDFLAGS) -o $@ $(Q3CGOBJ) -@@ -1330,7 +1356,7 @@ +@@ -1330,7 +1362,7 @@ MPCGOBJ = $(MPCGOBJ_) $(B)/missionpack/cgame/cg_syscalls.o MPCGVMOBJ = $(MPCGOBJ_:%.o=%.asm) $(B)/missionpack/game/bg_lib.asm @@ -380,7 +394,7 @@ $(echo_cmd) "LD $@" $(Q)$(CC) $(SHLIBLDFLAGS) -o $@ $(MPCGOBJ) -@@ -1382,7 +1408,7 @@ +@@ -1382,7 +1414,7 @@ Q3GOBJ = $(Q3GOBJ_) $(B)/baseq3/game/g_syscalls.o Q3GVMOBJ = $(Q3GOBJ_:%.o=%.asm) $(B)/baseq3/game/bg_lib.asm @@ -389,7 +403,7 @@ $(echo_cmd) "LD $@" $(Q)$(CC) $(SHLIBLDFLAGS) -o $@ $(Q3GOBJ) -@@ -1432,7 +1458,7 @@ +@@ -1432,7 +1464,7 @@ MPGOBJ = $(MPGOBJ_) $(B)/missionpack/game/g_syscalls.o MPGVMOBJ = $(MPGOBJ_:%.o=%.asm) $(B)/missionpack/game/bg_lib.asm @@ -398,7 +412,7 @@ $(echo_cmd) "LD $@" $(Q)$(CC) $(SHLIBLDFLAGS) -o $@ $(MPGOBJ) -@@ -1494,7 +1520,7 @@ +@@ -1494,7 +1526,7 @@ Q3UIOBJ = $(Q3UIOBJ_) $(B)/missionpack/ui/ui_syscalls.o Q3UIVMOBJ = $(Q3UIOBJ_:%.o=%.asm) $(B)/baseq3/game/bg_lib.asm @@ -407,7 +421,7 @@ $(echo_cmd) "LD $@" $(Q)$(CC) $(CFLAGS) $(SHLIBLDFLAGS) -o $@ $(Q3UIOBJ) -@@ -1521,7 +1547,7 @@ +@@ -1521,7 +1553,7 @@ MPUIOBJ = $(MPUIOBJ_) $(B)/missionpack/ui/ui_syscalls.o MPUIVMOBJ = $(MPUIOBJ_:%.o=%.asm) $(B)/baseq3/game/bg_lib.asm diff --git a/games/iourbanterror/files/patch-code__qcommon__vm_x86.c b/games/iourbanterror/files/patch-code__qcommon__vm_x86.c new file mode 100644 index 000000000000..0614c97804e1 --- /dev/null +++ b/games/iourbanterror/files/patch-code__qcommon__vm_x86.c @@ -0,0 +1,20 @@ +--- ./code/qcommon/vm_x86.c.orig 2007-10-09 02:47:22.000000000 -0300 ++++ ./code/qcommon/vm_x86.c 2008-03-04 10:45:08.000000000 -0300 +@@ -36,7 +36,7 @@ + + /* need this on NX enabled systems (i386 with PAE kernel or + * noexec32=on x86_64) */ +-#ifdef __linux__ ++#ifdef __unix__ + #define VM_X86_MMAP + #endif + +@@ -1081,7 +1081,7 @@ + // copy to an exact size buffer on the hunk + vm->codeLength = compiledOfs; + #ifdef VM_X86_MMAP +- vm->codeBase = mmap(NULL, compiledOfs, PROT_WRITE, MAP_SHARED|MAP_ANONYMOUS, -1, 0); ++ vm->codeBase = mmap(NULL, compiledOfs, PROT_WRITE, MAP_SHARED|MAP_ANON, -1, 0); + if(vm->codeBase == (void*)-1) + Com_Error(ERR_DROP, "VM_CompileX86: can't mmap memory"); + #elif _WIN32 diff --git a/games/iourbanterror/files/patch-code__qcommon__vm_x86_64.c b/games/iourbanterror/files/patch-code__qcommon__vm_x86_64.c new file mode 100644 index 000000000000..0c1c5b5da16b --- /dev/null +++ b/games/iourbanterror/files/patch-code__qcommon__vm_x86_64.c @@ -0,0 +1,11 @@ +--- ./code/qcommon/vm_x86_64.c.orig 2007-10-09 02:47:22.000000000 -0300 ++++ ./code/qcommon/vm_x86_64.c 2008-03-04 10:45:08.000000000 -0300 +@@ -534,7 +534,7 @@ + { + compiledOfs = assembler_get_code_size(); + vm->codeLength = compiledOfs; +- vm->codeBase = mmap(NULL, compiledOfs, PROT_WRITE, MAP_SHARED|MAP_ANONYMOUS, -1, 0); ++ vm->codeBase = mmap(NULL, compiledOfs, PROT_WRITE, MAP_SHARED|MAP_ANON, -1, 0); + if(vm->codeBase == (void*)-1) + Com_Error(ERR_DROP, "VM_CompileX86: can't mmap memory"); + |