提交 22a64baa 编写于 作者: V vlivanov

8022456: LogCompilation tool does not work with C1 output again

Reviewed-by: kvn
上级 eb144b4a
...@@ -106,10 +106,12 @@ public class CallSite { ...@@ -106,10 +106,12 @@ public class CallSite {
" (" + getMethod().getBytes() + " bytes) " + getReason()); " (" + getMethod().getBytes() + " bytes) " + getReason());
} }
} }
stream.printf(" (end time: %6.4f", getTimeStamp());
if (getEndNodes() > 0) { if (getEndNodes() > 0) {
stream.printf(" (end time: %6.4f nodes: %d live: %d)", getTimeStamp(), getEndNodes(), getEndLiveNodes()); stream.printf(" nodes: %d live: %d", getEndNodes(), getEndLiveNodes());
} }
stream.println(""); stream.println(")");
if (getReceiver() != null) { if (getReceiver() != null) {
emit(stream, indent + 4); emit(stream, indent + 4);
// stream.println("type profile " + method.holder + " -> " + receiver + " (" + // stream.println("type profile " + method.holder + " -> " + receiver + " (" +
......
...@@ -207,7 +207,12 @@ public class LogParser extends DefaultHandler implements ErrorHandler, Constants ...@@ -207,7 +207,12 @@ public class LogParser extends DefaultHandler implements ErrorHandler, Constants
} }
String search(Attributes attr, String name) { String search(Attributes attr, String name) {
return search(attr, name, null); String result = attr.getValue(name);
if (result != null) {
return result;
} else {
throw new InternalError("can't find " + name);
}
} }
String search(Attributes attr, String name, String defaultValue) { String search(Attributes attr, String name, String defaultValue) {
...@@ -215,14 +220,8 @@ public class LogParser extends DefaultHandler implements ErrorHandler, Constants ...@@ -215,14 +220,8 @@ public class LogParser extends DefaultHandler implements ErrorHandler, Constants
if (result != null) { if (result != null) {
return result; return result;
} }
if (defaultValue != null) {
return defaultValue; return defaultValue;
} }
for (int i = 0; i < attr.getLength(); i++) {
System.out.println(attr.getQName(i) + " " + attr.getValue(attr.getQName(i)));
}
throw new InternalError("can't find " + name);
}
int indent = 0; int indent = 0;
String type(String id) { String type(String id) {
...@@ -268,17 +267,18 @@ public class LogParser extends DefaultHandler implements ErrorHandler, Constants ...@@ -268,17 +267,18 @@ public class LogParser extends DefaultHandler implements ErrorHandler, Constants
Phase p = new Phase(search(atts, "name"), Phase p = new Phase(search(atts, "name"),
Double.parseDouble(search(atts, "stamp")), Double.parseDouble(search(atts, "stamp")),
Integer.parseInt(search(atts, "nodes", "0")), Integer.parseInt(search(atts, "nodes", "0")),
Integer.parseInt(search(atts, "live"))); Integer.parseInt(search(atts, "live", "0")));
phaseStack.push(p); phaseStack.push(p);
} else if (qname.equals("phase_done")) { } else if (qname.equals("phase_done")) {
Phase p = phaseStack.pop(); Phase p = phaseStack.pop();
if (! p.getId().equals(search(atts, "name"))) { String phaseName = search(atts, "name", null);
if (phaseName != null && !p.getId().equals(phaseName)) {
System.out.println("phase: " + p.getId()); System.out.println("phase: " + p.getId());
throw new InternalError("phase name mismatch"); throw new InternalError("phase name mismatch");
} }
p.setEnd(Double.parseDouble(search(atts, "stamp"))); p.setEnd(Double.parseDouble(search(atts, "stamp")));
p.setEndNodes(Integer.parseInt(search(atts, "nodes", "0"))); p.setEndNodes(Integer.parseInt(search(atts, "nodes", "0")));
p.setEndLiveNodes(Integer.parseInt(search(atts, "live"))); p.setEndLiveNodes(Integer.parseInt(search(atts, "live", "0")));
compile.getPhases().add(p); compile.getPhases().add(p);
} else if (qname.equals("task")) { } else if (qname.equals("task")) {
compile = new Compilation(Integer.parseInt(search(atts, "compile_id", "-1"))); compile = new Compilation(Integer.parseInt(search(atts, "compile_id", "-1")));
...@@ -413,8 +413,8 @@ public class LogParser extends DefaultHandler implements ErrorHandler, Constants ...@@ -413,8 +413,8 @@ public class LogParser extends DefaultHandler implements ErrorHandler, Constants
} }
} else if (qname.equals("parse_done")) { } else if (qname.equals("parse_done")) {
CallSite call = scopes.pop(); CallSite call = scopes.pop();
call.setEndNodes(Integer.parseInt(search(atts, "nodes", "1"))); call.setEndNodes(Integer.parseInt(search(atts, "nodes", "0")));
call.setEndLiveNodes(Integer.parseInt(search(atts, "live", "1"))); call.setEndLiveNodes(Integer.parseInt(search(atts, "live", "0")));
call.setTimeStamp(Double.parseDouble(search(atts, "stamp"))); call.setTimeStamp(Double.parseDouble(search(atts, "stamp")));
scopes.push(call); scopes.push(call);
} }
......
...@@ -74,16 +74,19 @@ class PhaseTraceTime: public TraceTime { ...@@ -74,16 +74,19 @@ class PhaseTraceTime: public TraceTime {
private: private:
JavaThread* _thread; JavaThread* _thread;
CompileLog* _log; CompileLog* _log;
TimerName _timer;
public: public:
PhaseTraceTime(TimerName timer) PhaseTraceTime(TimerName timer)
: TraceTime("", &timers[timer], CITime || CITimeEach, Verbose), _log(NULL) { : TraceTime("", &timers[timer], CITime || CITimeEach, Verbose),
_log(NULL), _timer(timer)
{
if (Compilation::current() != NULL) { if (Compilation::current() != NULL) {
_log = Compilation::current()->log(); _log = Compilation::current()->log();
} }
if (_log != NULL) { if (_log != NULL) {
_log->begin_head("phase name='%s'", timer_name[timer]); _log->begin_head("phase name='%s'", timer_name[_timer]);
_log->stamp(); _log->stamp();
_log->end_head(); _log->end_head();
} }
...@@ -91,7 +94,7 @@ class PhaseTraceTime: public TraceTime { ...@@ -91,7 +94,7 @@ class PhaseTraceTime: public TraceTime {
~PhaseTraceTime() { ~PhaseTraceTime() {
if (_log != NULL) if (_log != NULL)
_log->done("phase"); _log->done("phase name='%s'", timer_name[_timer]);
} }
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册