Binary searching jdk repo to find a problematic commit?

David Chase david.r.chase at oracle.com
Sat Sep 7 11:22:51 PDT 2013


Dawid,

For git versus mercurial, once you get your good and bad endpoints figured out for hotspot,
you probably want to read "hg -v help bisect".  I've never used this feature myself, but it is
clearly meant for this purpose.

David


On 2013-09-06, at 7:02 PM, Vladimir Kozlov <vladimir.kozlov at oracle.com> wrote:

> Dawid,
> 
> 7u3 uses Hotspot version hs22.1 (it is security release and has only bug fixes):
> 
> Java(TM) SE Runtime Environment (build 1.7.0_03-b04)
> Java HotSpot(TM) Server VM (build 22.1-b02, mixed mode)
> 
> It was based on hs22 in jdk7u2:
> 
> Java(TM) SE Runtime Environment (build 1.7.0_02-b13)
> Java HotSpot(TM) Server VM (build 22.0-b10, mixed mode)
> 
> 7u4 start using Hotspot version hs23:
> 
> Java(TM) SE Runtime Environment (build 1.7.0_04-ea-b01)
> Java HotSpot(TM) Server VM (build 23.0-b03, mixed mode)
> 
> If you think it is JVM problem you need to search VM changes (libjvm.so) which you can build separately and replace in one JDK (at exclude effects from jdk changes).
> 
> Hotspot has separate repository where we do all development which is periodically forked for jdk releases:
> 
> http://hg.openjdk.java.net/hsx/hotspot-main/hotspot/
> 
> Forked repository for hs23 is here:
> 
> http://hg.openjdk.java.net/hsx/hsx23/hotspot/
> 
> I think you should use it for your search.
> 
> You need to do 'hg clone' first for revision you need:
> 
> hg clone -r hs22-b06 http://hg.openjdk.java.net/hsx/hsx23/hotspot
> 
> To build product VM:
> 
> cd hotspot/make
> gnumake product LP64=1 MAKE_VERBOSE=
> 
> or to build fastdebug 32-bit:
> gnumake fastdebug
> 
> cp ../build/linux/linux_amd64_compiler2/fastdebug/libjvm.so <your_jdk_dir>/jre/lib/amd64/server/
> 
> To pull next set of patches do:
> 
> cd hotspot
> hg pull -r hs23-b01
> 
> Build and test again.
> 
> Regards,
> Vladimir
> 
> On 9/6/13 2:29 PM, Dawid Weiss wrote:
>> 
>> I'm more familiar with git than with mercurial, so this may be something
>> obvious. I want to dissect commits made to hotspot between the official
>> jdk7u3 and jdk7u4 and I've hit a couple of questions.
>> 
>> 1) Interestingly the "top level" project doesn't have the tag my
>> "official" jdk7u3 presents itself with:
>> 
>> 1.7.0_03-b05
>> 
>> the tags present in http://hg.openjdk.java.net/jdk7u/jdk7u are up to
>> jdk7u3-b04. Which version was it built from? Is the tag missing?
>> 
>> 2) When I look for build tags in between jdk7u3-b04:jdk7u4-b22 I see
>> things like:
>> 
>> $ hg log -r jdk7u3-b04:jdk7u4-b22 | grep "tag:"
>> tag:         jdk7u3-b04
>> tag:         jdk7u4-b13
>> tag:         jdk7u4-b14
>> tag:         jdk7u6-b01
>> tag:         jdk7u6-b02
>> ...
>> 
>> This is slightly confusing to me but I guess it makes sense if parallel
>> branches coexist in the same repo and are merged/ tagged at the same
>> time. Anyway, would this series of tags really reflect something useful
>> for a rough binary-searching scheme over incremental (semi-stable) builds?
>> 
>> 3) I'm used to git's submodules which hold versioned references to
>> sub-projects. I assume the forrest extension doesn't do it and every
>> subproject is tagged at the time of the release, am I correct? What
>> confused me was that the instructions to update sources
>> in README-builds.html always pull subprojects to their tip. I assume to
>> get the same set of sources I need to run something like:
>> 
>> ./make/scripts/hgforest.sh pull <tag>
>> 
>> (or an equivalent, depending on the JDK version)?
>> 
>> Thanks for clarifying,
>> Dawid
>> 
>> 



More information about the hotspot-compiler-dev mailing list