<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=us-ascii"><meta name=Generator content="Microsoft Word 12 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:Wingdings;
        panose-1:5 0 0 0 0 0 0 0 0 0;}
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p.MsoListParagraph, li.MsoListParagraph, div.MsoListParagraph
        {mso-style-priority:34;
        margin-top:0cm;
        margin-right:0cm;
        margin-bottom:0cm;
        margin-left:36.0pt;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri","sans-serif";
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:70.85pt 70.85pt 70.85pt 70.85pt;}
div.WordSection1
        {page:WordSection1;}
/* List Definitions */
@list l0
        {mso-list-id:944725203;
        mso-list-type:hybrid;
        mso-list-template-ids:-1404511362 -40583994 69009411 69009413 69009409 69009411 69009413 69009409 69009411 69009413;}
@list l0:level1
        {mso-level-start-at:0;
        mso-level-number-format:bullet;
        mso-level-text:-;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        font-family:"Calibri","sans-serif";
        mso-fareast-font-family:Calibri;
        mso-bidi-font-family:"Times New Roman";}
ol
        {margin-bottom:0cm;}
ul
        {margin-bottom:0cm;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=SV link=blue vlink=purple><div class=WordSection1><p class=MsoNormal>Greetings,<o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><span lang=EN-US>Kindly asking for reviews for the following changeset:<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US><o:p>&nbsp;</o:p></span></p><p class=MsoNormal>Webrev: <a href="http://cr.openjdk.java.net/~mgronlun/8028128/webrev01/">http://cr.openjdk.java.net/~mgronlun/8028128/webrev01/</a> <o:p></o:p></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><span lang=EN-US>Bug: </span><a href="https://bugs.openjdk.java.net/browse/JDK-8028128"><span lang=EN-US>https://bugs.openjdk.java.net/browse/JDK-8028128</span></a><span lang=EN-US><o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><b>Description:<o:p></o:p></b></p><p class=MsoNormal><o:p>&nbsp;</o:p></p><p class=MsoNormal><span lang=EN-US style='color:black'>Currently, when working with counter based data, the primary data type representation in the VM are raw jlong's. jlong's are employed to represent both: <br><br>1. a single instance in time, for example a &quot;now&quot; timestamp <br>2. a time duration, a timespan, for example the duration between &quot;now&quot; - &quot;then&quot; <br><br>Having a raw jlong type represent both of these shifts the responsibility to the programmer to always ensure the correct validity of the counter data, without any assistance either at compile time or at runtime. <br><br>The event based tracing framework relies heavily on counter based data in order to keep track of time and timing related information and we have seen counter data errors where the representation sent to the tracing framework has submitted the wrong time, i.e. a timespan when a time instant was expected and vice versa. <br><br>We should therefore add an alternative to jlongs for representing counter based data. We should enlist the help of the type system to enforce the correct data types at compile time as well as introduce strong runtime asserts in order to help with the correct usage of time and to reduce the number of potential bugs. <br><br>I will therefore add two new types in src/share/vm/utilities: <br><br>1. &quot;Ticks&quot; - represents a single counter based timestamp, a single instance in time.<br>2. &quot;Tickspan&quot; - represents a counter based duration, a timespan, &nbsp;between two &quot;Ticks&quot; <o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US style='color:black'><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><span lang=EN-US style='color:black'>Please see the added files:<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US style='color:black'><o:p>&nbsp;</o:p></span></p><p class=MsoListParagraph style='text-indent:-18.0pt;mso-list:l0 level1 lfo1'><![if !supportLists]><span lang=EN-US><span style='mso-list:Ignore'>-<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><![endif]><span lang=EN-US>src/share/vm/utilities/ticks.hpp<o:p></o:p></span></p><p class=MsoListParagraph style='text-indent:-18.0pt;mso-list:l0 level1 lfo1'><![if !supportLists]><span lang=EN-US><span style='mso-list:Ignore'>-<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><![endif]><span lang=EN-US>src/share/vm/utilities/ticks.inline.hpp<o:p></o:p></span></p><p class=MsoListParagraph style='text-indent:-18.0pt;mso-list:l0 level1 lfo1'><![if !supportLists]><span lang=EN-US><span style='mso-list:Ignore'>-<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><![endif]><span lang=EN-US>src/share/vm/utilities/ticks.cpp<o:p></o:p></span></p><p class=MsoListParagraph><span lang=EN-US style='color:black'><o:p>&nbsp;</o:p></span></p><p class=MsoListParagraph style='margin-left:0cm'><span lang=EN-US style='color:black'>I have also updated some of the existing event based tracing &quot;event sites&quot; to employ usage of these new types as well as updated a few places in the event based tracing framework implementation to accommodate these types.<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US style='color:black'><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><b><span lang=EN-US style='color:black'>Testing completed:<o:p></o:p></span></b></p><p class=MsoNormal><span lang=EN-US style='color:black'><o:p>&nbsp;</o:p></span></p><p class=MsoNormal><span style='color:black'>nsk.stress.testlist (UTE/Aurora)<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US style='color:black'>GC nightlies (Aurora)<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US style='color:black'>gc/gctests/* (UTE/Aurora)<o:p></o:p></span></p><p class=MsoNormal><span style='color:black'>nsk.gc.testlist (UTE/Aurora)<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US style='color:black'>SpecJBB2013 (no regression)<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US style='color:black'>SpecJBB2005 (no regression)<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US style='color:black'>Kitchensink (locally Windows) runs for +&gt; 9 days (still running&#8230;)<br><br>Thanks in advance<br>Markus<o:p></o:p></span></p></div></body></html>