Build error on Windows after 8221507: Implement JFR Events for Shenandoah
    Langer, Christoph 
    christoph.langer at sap.com
       
    Wed May 22 07:44:25 UTC 2019
    
    
  
Hi Thomas,
I believe it was not caught because Oracle/jdk-submit builds with Shenandoah turned off…
/Christoph
From: Thomas Stüfe <thomas.stuefe at gmail.com>
Sent: Mittwoch, 22. Mai 2019 07:00
To: Langer, Christoph <christoph.langer at sap.com>
Cc: Ken Dobson <kdobson at redhat.com>; hotspot-jfr-dev at openjdk.java.net
Subject: Re: Build error on Windows after 8221507: Implement JFR Events for Shenandoah
I am confused how this can even happen, should jdk-submit tests not have captured that before pushing?
Cheers, Thomas
On Tue, May 21, 2019 at 10:02 PM Langer, Christoph <christoph.langer at sap.com<mailto:christoph.langer at sap.com>> wrote:
Hi Ken,
after you pushed JDK-8221507, I see build errors on Windows (enabled warnings as errors):
shenandoahHeapRegion.cpp
.../jdk/src/hotspot/share/gc/shenandoah/shenandoahHeapRegion.cpp(687): error C2220: warning treated as error - no 'object' file generated
.../jdk/src/hotspot/share/gc/shenandoah/shenandoahHeapRegion.cpp(687): warning C4267: 'argument': conversion from 'size_t' to 'unsigned int', possible loss of data
   ... (rest of output omitted)
* For target hotspot_variant-server_libjvm_objs_shenandoahJfrSupport.obj:
shenandoahJfrSupport.cpp
.../jdk/src/hotspot/share/gc/shenandoah/shenandoahJfrSupport.cpp(60): error C2220: warning treated as error - no 'object' file generated
.../jdk/src/hotspot/share/gc/shenandoah/shenandoahJfrSupport.cpp(60): warning C4267: 'argument': conversion from 'size_t' to 'unsigned int', possible loss of data
   ... (rest of output omitted)
I don't know if the fix is to simply add a cast to unsigned int. Can you please check and repair?
Thanks
Christoph
> -----Original Message-----
> From: jmc-dev <jmc-dev-bounces at openjdk.java.net<mailto:jmc-dev-bounces at openjdk.java.net>> On Behalf Of Ken
> Dobson
> Sent: Dienstag, 14. Mai 2019 23:19
> To: Erik Gahlin <erik.gahlin at oracle.com<mailto:erik.gahlin at oracle.com>>
> Cc: hotspot-jfr-dev at openjdk.java.net<mailto:hotspot-jfr-dev at openjdk.java.net>; mikhailo.seledtsov at oracle.com<mailto:mikhailo.seledtsov at oracle.com>; jmc-
> dev at openjdk.java.net<mailto:dev at openjdk.java.net>
> Subject: Re: RFR 8221507: Implement JFR Events for Shenandoah
>
> Thank you for the review again.
>
> Yes, not sure regarding backporting plans but I imagine it will be in the
> future so seemed best to avoid anything that cause issues such as Set.of().
>
> I also think the naming of the jfr's is fine as it's stored in a folder
> named after the test which was easily found now that I'm aware that the
> jfrs are already dumped.
>
> I believe I've addressed the rest of your recommended changes to the tests,
> let me know if I've covered everything.
>
> http://cr.openjdk.java.net/~kdobson/eventswithtests/webrev/
>
> Thanks,
>
> Ken Dobson
>
> On Sun, May 12, 2019 at 8:28 PM Erik Gahlin <erik.gahlin at oracle.com<mailto:erik.gahlin at oracle.com>> wrote:
>
> > Thanks for fixing!
> >
> > Product code looks good, but I think tests could be improved.
> >
> > There is no need to call dump in a final clause.
> >
> > Events.fromRecording(...) will dump the file into the jtreg scratch
> > directory ( "recording-1-pid-xxx.jfr")  by default. I think this is
> > sufficient since there is only one recording per test.  If you think the
> > name is cryptic, consider adding another method to Event.fromRecording
> that
> > takes an additional parameter that becomes a suffix, i.e
> > "recording-1-pid-xxx-test-heap-region-info.jfr"
> >
> > try (Recording r = new recording()) {
> >   r.enable(EVENT_NAME);
> >   r.start();
> >   r.stop()
> >   List<RecordedEvent> events = Events.fromRecording(r);
> >   Events.hasEvents(events);
> >   for (RecordedEvent event : events) {
> >     Events.assertField(event, "index").notEqual(-1);
> >     Events.assertField(event, "used").atMost(1024*1024L);
> >     String state = Events.assertField(event, "state").getValue();
> >     GCHelper.assertShenandoahHeapRegionState(state));
> > }
> >
> > The name of the field in metadata.xml is "state", but the tests looks for
> > "type". That seems incorrect.
> >
> > GCHelper:
> >
> > public static assertShenandoahHeapRegionState(String state) {
> >  if (!shenandoahHeapRegionStates.contains(state)) {
> >     throw new AssertionError("Unknown state '"+ state +"', valid heap
> > region states are " + shenandoahHeapRegionStates);
> > }
> >
> > I assume you don't use Set.of("Empty Uncommitted" , ... , "Trash")
> > because you want to backport to JDK 8.
> >
> > Thanks
> > Erik
> >
> > Thanks everyone for their reviews. I've added tests similar to the tests
> > for the G1 events as well as addressed the changes that Erik
> recommended.
> >
> > Here is the new webrev:
> >
> http://cr.openjdk.java.net/~kdobson/shenandoaheventswithtests/webrev/
> >
> > Please let me know if there's anything else that should be addressed.
> >
> > Thanks,
> >
> > Ken Dobson
> >
> > On Mon, May 6, 2019 at 11:38 AM <mikhailo.seledtsov at oracle.com<mailto:mikhailo.seledtsov at oracle.com>>
> wrote:
> >
> >>
> >>
> >> On 5/4/19 2:16 PM, Erik Gahlin wrote:
> >> > On 2019-05-04 00:19, mikhailo.seledtsov at oracle.com<mailto:mikhailo.seledtsov at oracle.com> wrote:
> >> >> Hi,
> >> >>
> >> >>   If possible and feasible, could you please implement tests for new
> >> >> events?
> >> >>
> >> >> Please place the tests under test/jdk/jdk/jfr/event/gc/. Perhaps
> >> >> create a "shenandoah" subfolder.
> >> >>
> >> >> If the events are too hard to test or not feasible, please add the
> >> >> event names to
> >> >> test/jdk/jdk/jfr/event/metadata/TestLookForUntestedEvents.java, to
> >> >> the hardToTestEvents set. Consider commenting why it is too hard to
> >> >> test.
> >> >
> >> > If events are are marked experimental, tests are ignored by
> >> > TestLookForUntestedEvents. java, so we should not  add them to the
> >> > hardToTestEvents set. That may help them pass under the radar once
> the
> >> > experimental attribute is removed.
> >> Thank you. If the events are "experimental" this approach makes sense.
> >> Once the experimental status is removed, the
> >> TestLookForUntestedEvents.java should be able to notice if the event is
> >> not covered by tests.
> >> > That said, tests never hurts, even if they are experimental. I think
> >> > test/jdk/jdk/jfr/event/gc/detailed would be a good place
> >> +1
> >>
> >> Thank you,
> >> Misha
> >> >
> >> > Erik
> >> >
> >> >>
> >> >> Also, please make sure to run all jfr tests under test/jdk/jdk/jfr/
> >> >> prior to integration.
> >> >>
> >> >>
> >> >> Best regards,
> >> >>
> >> >> Misha
> >> >>
> >> >>
> >> >>
> >> >> On 5/3/19 7:44 AM, Ken Dobson wrote:
> >> >>> Hi all,
> >> >>>
> >> >>> Please review this patch that adds support for two new JFR events
> >> >>> ShenandoahHeapRegionStateChange and
> ShenandoahHeapRegionInformation.
> >> >>>
> >> >>> Bug: https://bugs.openjdk.java.net/browse/JDK-8221507
> >> >>> Webrev: http://cr.openjdk.java.net/~kdobson/53476/webrev/
> >> >>>
> >> >>> The Shenandoah team has also reviewed this patch and approved it
> >> >>> from their
> >> >>> end.
> >> >>>
> >> >>> Thanks,
> >> >>>
> >> >>> Ken Dobson
> >> >>
> >> >
> >>
> >>
> >
    
    
More information about the hotspot-jfr-dev
mailing list