summaryrefslogtreecommitdiff
path: root/packages/qemu/files/qemu-amd64-32b-mapping-0.9.0.patch
diff options
context:
space:
mode:
authorMichael Lauer <mickey@vanille-media.de>2007-08-23 11:47:15 +0000
committerMichael Lauer <mickey@vanille-media.de>2007-08-23 11:47:15 +0000
commitf1d0d79f48ab191a1ed0b5065e39046e1d95fef4 (patch)
tree860036a8554d604726a256d7408c711df834b7cb /packages/qemu/files/qemu-amd64-32b-mapping-0.9.0.patch
parent2534c12ac4c879178132751e51db09c6e4f22cf9 (diff)
parent958b8822656bed6e5526f9441fea36570787f9c7 (diff)
merge of '88dd6a801655485b76bb6d591c1f763d51ff47b8'
and 'ea2a23cae4f4d939a07f699c39b603c4c2559ad1'
Diffstat (limited to 'packages/qemu/files/qemu-amd64-32b-mapping-0.9.0.patch')
-rw-r--r--packages/qemu/files/qemu-amd64-32b-mapping-0.9.0.patch31
1 files changed, 31 insertions, 0 deletions
diff --git a/packages/qemu/files/qemu-amd64-32b-mapping-0.9.0.patch b/packages/qemu/files/qemu-amd64-32b-mapping-0.9.0.patch
new file mode 100644
index 0000000000..d9303e3464
--- /dev/null
+++ b/packages/qemu/files/qemu-amd64-32b-mapping-0.9.0.patch
@@ -0,0 +1,31 @@
+--- qemu.orig/linux-user/mmap.c
++++ qemu/linux-user/mmap.c
+@@ -29,6 +29,10 @@
+
+ //#define DEBUG_MMAP
+
++#ifndef MAP_32BIT
++#define MAP_32BIT 0
++#endif
++
+ /* NOTE: all the constants are the HOST ones, but addresses are target. */
+ int target_mprotect(target_ulong start, target_ulong len, int prot)
+ {
+@@ -234,7 +238,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' */
+@@ -388,7 +392,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);