From e5947b5ec0c3dbd2573ed47277223bd3479dea7c Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Thu, 6 Aug 2009 15:58:26 -0600 Subject: [PATCH 1/4] remove bashism from test.sh --- test/test.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/test/test.sh b/test/test.sh index fd028e39f0..55b4ff54a6 100644 --- a/test/test.sh +++ b/test/test.sh @@ -1,4 +1,4 @@ -#!/bin/bash +#!/bin/sh log=build/log.txt vg="nice valgrind --leak-check=full --num-callers=32 \ @@ -28,7 +28,7 @@ for test in ${tests}; do exit 1;; esac - if (( ${?} == 0 )); then + if [ "${?}" = "0" ]; then echo "success" else echo "fail" From 012d548bbb185c715a71080770c6066863c71e25 Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Fri, 7 Aug 2009 14:48:30 -0600 Subject: [PATCH 2/4] fix sign extension from int to long on x86_64 --- src/x86.cpp | 2 +- test/Longs.java | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/src/x86.cpp b/src/x86.cpp index 59959a2ce9..1854a01427 100644 --- a/src/x86.cpp +++ b/src/x86.cpp @@ -895,7 +895,7 @@ moveRR(Context* c, unsigned aSize, Assembler::Register* a, case 4: if (bSize == 8) { if (BytesPerWord == 8) { - alwaysRex(c, aSize, b, a); + alwaysRex(c, bSize, b, a); opcode(c, 0x63); modrm(c, 0xc0, a, b); } else { diff --git a/test/Longs.java b/test/Longs.java index daa6966677..51fad92969 100644 --- a/test/Longs.java +++ b/test/Longs.java @@ -35,7 +35,13 @@ public class Longs { return a - (a % b); } + private static int negativeOne() { + return -1; + } + public static void main(String[] args) { + expect(((long) negativeOne()) == -1); + { long foo = 25214903884L; int radix = 10; expect(foo > 0); From 2da6980eb5098eedbe20badfac3886d6db7ab369 Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Fri, 7 Aug 2009 16:27:24 -0600 Subject: [PATCH 3/4] print intptr_t's as pointers in compareIpToMethodBounds to avoid printf compatibility issues --- src/compile.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/compile.cpp b/src/compile.cpp index ff6f15a5a6..add06d4845 100644 --- a/src/compile.cpp +++ b/src/compile.cpp @@ -189,8 +189,10 @@ compareIpToMethodBounds(Thread* t, intptr_t ip, object method) intptr_t start = methodCompiled(t, method); if (DebugMethodTree) { - fprintf(stderr, "find 0x%"LX" in (0x%"LX",0x%"LX")\n", ip, start, - start + compiledSize(start)); + fprintf(stderr, "find %p in (%p,%p)\n", + reinterpret_cast(ip), + reinterpret_cast(start), + reinterpret_cast(start + compiledSize(start))); } if (ip < start) { From 2f864ebea5fda6401c07cefaacf143c6ad9f5f16 Mon Sep 17 00:00:00 2001 From: Joel Dice Date: Fri, 7 Aug 2009 16:28:47 -0600 Subject: [PATCH 4/4] fix LLD definition for MinGW 4.4 --- src/common.h | 20 ++++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/src/common.h b/src/common.h index 7e1f94e93b..10690c6046 100644 --- a/src/common.h +++ b/src/common.h @@ -31,14 +31,18 @@ #if (defined __i386__) || (defined __POWERPC__) || (defined __arm__) # define LD "ld" -# define LLD "lld" -#ifdef __APPLE__ -# define ULD "lu" -# define LX "lx" -#else -# define LX "x" -# define ULD "u" -#endif +# ifdef __MINGW32__ +# define LLD "I64d" +# else +# define LLD "lld" +# endif +# ifdef __APPLE__ +# define ULD "lu" +# define LX "lx" +# else +# define LX "x" +# define ULD "u" +# endif #elif defined __x86_64__ # ifdef __MINGW32__ # define LD "I64d"