SHA256
1
0
forked from pool/qemu
OBS User unknown 2007-06-20 17:21:29 +00:00 committed by Git OBS Bridge
parent c55634e3ed
commit c828f62526
4 changed files with 69 additions and 35 deletions

60
qemu-0.8.2-alt-mmap.patch Normal file
View File

@ -0,0 +1,60 @@
diff -uNr qemu-0.8.2.orig/linux-user/mmap.c qemu-0.8.2/linux-user/mmap.c
--- qemu-0.8.2.orig/linux-user/mmap.c 2007-01-16 16:05:33 +0200
+++ qemu-0.8.2/linux-user/mmap.c 2007-01-16 16:27:28 +0200
@@ -27,6 +27,10 @@
#include "qemu.h"
+#if !defined(MAP_32BIT)
+#define MAP_32BIT 0
+#endif
+
//#define DEBUG_MMAP
/* NOTE: all the constants are the HOST ones, but addresses are target. */
@@ -116,7 +120,7 @@
if (prot1 == 0) {
/* no page was there, so we allocate one */
ret = (long)mmap(host_start, qemu_host_page_size, prot,
- flags | MAP_ANONYMOUS, -1, 0);
+ flags | MAP_ANONYMOUS | MAP_32BIT, -1, 0);
if (ret == -1)
return ret;
prot1 = prot;
@@ -217,7 +221,8 @@
abort();
host_len = HOST_PAGE_ALIGN(len) + qemu_host_page_size - TARGET_PAGE_SIZE;
real_start = (long)mmap(g2h(real_start), host_len, PROT_NONE,
- MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
+ MAP_PRIVATE | MAP_ANONYMOUS | MAP_32BIT
+ , -1, 0);
if (real_start == -1)
return real_start;
real_end = real_start + host_len;
@@ -234,7 +239,7 @@
host_offset = offset & qemu_host_page_mask;
host_len = len + offset - host_offset;
host_start = (long)mmap(real_start ? g2h(real_start) : NULL,
- host_len, prot, flags, fd, host_offset);
+ host_len, prot, flags | MAP_32BIT, fd, host_offset);
if (host_start == -1)
return host_start;
/* update start so that it points to the file position at 'offset' */
@@ -312,7 +317,7 @@
else
offset1 = offset + real_start - start;
ret = (long)mmap(g2h(real_start), real_end - real_start,
- prot, flags, fd, offset1);
+ prot, flags | MAP_32BIT, fd, offset1);
if (ret == -1)
return ret;
}
@@ -388,7 +393,7 @@
int prot;
/* XXX: use 5 args syscall */
- new_addr = (long)mremap(g2h(old_addr), old_size, new_size, flags);
+ new_addr = (long)mremap(g2h(old_addr), old_size, new_size, flags | MAP_32BIT);
if (new_addr == -1)
return new_addr;
new_addr = h2g(new_addr);

View File

@ -1,33 +0,0 @@
Index: qemu-0.9.0/linux-user/mmap.c
===================================================================
--- qemu-0.9.0.orig/linux-user/mmap.c
+++ qemu-0.9.0/linux-user/mmap.c
@@ -162,7 +162,7 @@ long target_mmap(target_ulong start, tar
{
target_ulong ret, end, real_start, real_end, retaddr, host_offset, host_len;
long host_start;
-#if defined(__alpha__) || defined(__sparc__) || defined(__x86_64__) || \
+#if defined(__alpha__) || defined(__sparc__) || \
defined(__ia64)
static target_ulong last_start = 0x40000000;
#elif defined(__CYGWIN__)
@@ -170,6 +170,10 @@ long target_mmap(target_ulong start, tar
static target_ulong last_start = 0x18000000;
#endif
+#if defined(__x86_64__)
+ flags |= MAP_32BIT;
+#endif
+
#ifdef DEBUG_MMAP
{
printf("mmap: start=0x%lx len=0x%lx prot=%c%c%c flags=",
@@ -207,7 +211,7 @@ long target_mmap(target_ulong start, tar
real_start = start & qemu_host_page_mask;
if (!(flags & MAP_FIXED)) {
-#if defined(__alpha__) || defined(__sparc__) || defined(__x86_64__) || \
+#if defined(__alpha__) || defined(__sparc__) || \
defined(__ia64) || defined(__CYGWIN__)
/* tell the kenel to search at the same place as i386 */
if (real_start == 0) {

View File

@ -1,3 +1,8 @@
-------------------------------------------------------------------
Wed Jun 20 14:38:47 CEST 2007 - agraf@suse.de
- applied proper fix for x86_64 and the MAP_32BIT flag
------------------------------------------------------------------- -------------------------------------------------------------------
Wed Jun 20 10:59:11 CEST 2007 - uli@suse.de Wed Jun 20 10:59:11 CEST 2007 - uli@suse.de

View File

@ -17,7 +17,7 @@ License: BSD License and BSD-like, GNU General Public License (GPL)
Group: System/Emulators/Other Group: System/Emulators/Other
Summary: Universal CPU emulator Summary: Universal CPU emulator
Version: 0.9.0 Version: 0.9.0
Release: 37 Release: 38
Source: %name-%version.tar.bz2 Source: %name-%version.tar.bz2
#Patch400: qemu-0.7.0-gcc4-dot-syms.patch #Patch400: qemu-0.7.0-gcc4-dot-syms.patch
#Patch401: qemu-0.8.0-gcc4-hacks.patch #Patch401: qemu-0.8.0-gcc4-hacks.patch
@ -52,7 +52,7 @@ Patch38: qemu-0.9.0-kvm-bios.patch
Patch39: qemu-0.9.0-kvm-kqemu-window-caption.patch Patch39: qemu-0.9.0-kvm-kqemu-window-caption.patch
Patch40: qemu-z80.diff Patch40: qemu-z80.diff
Patch41: qemu-0.9.0-sched.patch Patch41: qemu-0.9.0-sched.patch
Patch42: qemu-0.9.0-mmap.x86_64.patch Patch42: qemu-0.8.2-alt-mmap.patch
Patch43: qemu-0.9.0-futex.patch Patch43: qemu-0.9.0-futex.patch
Patch44: qemu-0.9.0-robust_list.patch Patch44: qemu-0.9.0-robust_list.patch
Patch45: qemu-0.9.0-wine.patch Patch45: qemu-0.9.0-wine.patch
@ -332,6 +332,8 @@ rm -rf %{gcc33tmp}
%endif %endif
%changelog %changelog
* Wed Jun 20 2007 - agraf@suse.de
- applied proper fix for x86_64 and the MAP_32BIT flag
* Wed Jun 20 2007 - uli@suse.de * Wed Jun 20 2007 - uli@suse.de
- added secfixes (bug #252519) - added secfixes (bug #252519)
* Thu Jun 14 2007 - agraf@suse.de * Thu Jun 14 2007 - agraf@suse.de