Reviewer needed - fix for regression test hotspot/test/runtime/6929067/Test6929067
Pavel Tisnovsky
ptisnovs at redhat.com
Tue Nov 16 08:24:15 PST 2010
Dr Andrew John Hughes wrote:
> On 16:14 Tue 16 Nov , Pavel Tisnovsky wrote:
>> Dr Andrew John Hughes wrote:
>>> On 18:44 Mon 15 Nov , Pavel Tisnovsky wrote:
>>>> Hi all,
>>>>
>>>> can anybody please review fix for regression test
>>>> hotspot/test/runtime/6929067/Test6929067
>>>>
>>>> I changed this test in a way that it now correctly works on x86_64
>>>> platform, for example (it has to find where libjvm.so is placed instead
>>>> of using constant path). Tested on RHEL 5 x86_64 but it should works on
>>>> another systems too.
>>>>
>>> ARCH=$(uname -m)
>>> if test "${ARCH}" == "x86_64"; then
>>> ARCH=amd64;
>>> fi
>>> LD_LIBRARY_PATH=.:${TESTJAVA}/jre/lib/${ARCH}/client:${TESTJAVA}/jre/lib/${ARCH}/server:/usr/openwin/lib:/usr/dt/lib:/usr/lib:$LD_LIBRARY_PATH
>>>
>>> would achieve the same goal without using find.
>> Yeah it nicely solves the first problem, but I'd like to stay on my
>> version because we also have to use the exact path to properly compile
>> "invoke" tool - calling of gcc is located near the end of this script.
>>
>
> The problem with using find is that you don't know what libjvm.so you'll
> end up with, which makes any future issues hard to diagnose. With the
> above, we know it's the client vm if available, and the server vm if not.
>
> IMHO, the gcc invocation should be using -ljvm.
Do you mean this solution or something more simpler?
gcc -o invoke -L${TESTJAVA}/jre/lib/${ARCH}/client
-L${TESTJAVA}/jre/lib/${ARCH}/server -ljvm -I${TESTJAVA}/include
-I${TESTJAVA}/include/linux invoke.c
(btw it works only when library paths are set)
>
>>>> Diffstat produced against IcedTea6 HEAD is stored in attachment.
>>>>
>>> Again, no 'icedtea-' prefix.
>>>
>>>> Thank you in advance
>>>> Pavel
>>>> # HG changeset patch
>>>> # User ptisnovs
>>>> # Date 1289843015 -3600
>>>> # Node ID bf47d6f0dd12f7ed7a34d0110d2bbd6361d6616b
>>>> # Parent ad1c77031a41739f3a912d27459a23a930ef4b88
>>>> Testcase correction.
>>>>
>>>> diff -r ad1c77031a41 -r bf47d6f0dd12 ChangeLog
>>>> --- a/ChangeLog Fri Nov 12 18:17:22 2010 +0000
>>>> +++ b/ChangeLog Mon Nov 15 18:43:35 2010 +0100
>>>> @@ -1,3 +1,10 @@
>>>> +2010-11-15 Pavel Tisnovsky <ptisnovs at redhat.com>
>>>> +
>>>> + * Makefile.am: Add new patch.
>>>> + * patches/jtreg-patch-Test6929067.patch:
>>>> + Testcase correction - now the test works correctly also on x86_64 and
>>>> + other platforms.
>>>> +
>>>> 2010-11-12 Andrew John Hughes <ahughes at redhat.com>
>>>>
>>>> * Makefile.am:
>>>> diff -r ad1c77031a41 -r bf47d6f0dd12 Makefile.am
>>>> --- a/Makefile.am Fri Nov 12 18:17:22 2010 +0000
>>>> +++ b/Makefile.am Mon Nov 15 18:43:35 2010 +0100
>>>> @@ -300,7 +300,8 @@
>>>> patches/openjdk/6622432-bigdecimal_performance.patch \
>>>> patches/openjdk/6850606-bigdecimal_regression.patch \
>>>> patches/openjdk/6876282-bigdecimal_divide.patch \
>>>> - patches/f14-fonts.patch
>>>> + patches/f14-fonts.patch \
>>>> + patches/icedtea-jtreg-Test6929067.patch
>>>>
>>>> if WITH_ALT_HSBUILD
>>>> ICEDTEA_PATCHES += \
>>>> diff -r ad1c77031a41 -r bf47d6f0dd12 patches/icedtea-jtreg-Test6929067.patch
>>>> --- /dev/null Thu Jan 01 00:00:00 1970 +0000
>>>> +++ b/patches/icedtea-jtreg-Test6929067.patch Mon Nov 15 18:43:35 2010 +0100
>>>> @@ -0,0 +1,23 @@
>>>> +--- openjdk-old/hotspot/test/runtime/6929067/Test6929067.sh 2010-10-08 22:29:24.000000000 +0200
>>>> ++++ openjdk/hotspot/test/runtime/6929067/Test6929067.sh 2010-11-15 12:47:57.000000000 +0100
>>>> +@@ -42,7 +42,11 @@
>>>> + ;;
>>>> + esac
>>>> +
>>>> +-LD_LIBRARY_PATH=.:${TESTJAVA}/jre/lib/i386/client:/usr/openwin/lib:/usr/dt/lib:/usr/lib:$LD_LIBRARY_PATH
>>>> ++PATH_TO_LIBJVM=`find ${TESTJAVA}/jre/lib -name libjvm.so | tail -n 1 | sed 's/\(.*\)\(\/libjvm\.so\)/\1/g'`
>>>> ++
>>>> ++echo $PATH_TO_LIBJVM
>>>> ++
>>>> ++LD_LIBRARY_PATH=.:${PATH_TO_LIBJVM}:/usr/openwin/lib:/usr/dt/lib:/usr/lib:$LD_LIBRARY_PATH
>>>> + export LD_LIBRARY_PATH
>>>> +
>>>> + THIS_DIR=`pwd`
>>>> +@@ -55,6 +59,6 @@
>>>> +
>>>> + ${TESTJAVA}${FS}bin${FS}javac T.java
>>>> +
>>>> +-gcc -o invoke -I${TESTJAVA}/include -I${TESTJAVA}/include/linux invoke.c ${TESTJAVA}/jre/lib/i386/client/libjvm.so
>>>> ++gcc -o invoke -I${TESTJAVA}/include -I${TESTJAVA}/include/linux invoke.c ${PATH_TO_LIBJVM}/libjvm.so
>>>> + ./invoke
>>>> + exit $?
>>>
>
More information about the distro-pkg-dev
mailing list