OLD | NEW |
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #include "vm/bootstrap_natives.h" | 5 #include "vm/bootstrap_natives.h" |
6 | 6 |
7 #include "include/dart_api.h" | 7 #include "include/dart_api.h" |
8 | 8 |
9 #include "vm/native_entry.h" | 9 #include "vm/native_entry.h" |
10 #include "vm/object.h" | 10 #include "vm/object.h" |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
48 if (recorder == NULL) { | 48 if (recorder == NULL) { |
49 return Object::null(); | 49 return Object::null(); |
50 } | 50 } |
51 | 51 |
52 if (!isolate->GetDartStream()->Enabled()) { | 52 if (!isolate->GetDartStream()->Enabled()) { |
53 // Dart stream is not enabled for this isolate, do nothing. | 53 // Dart stream is not enabled for this isolate, do nothing. |
54 return Object::null(); | 54 return Object::null(); |
55 } | 55 } |
56 | 56 |
57 int64_t pid = OS::ProcessId(); | 57 int64_t pid = OS::ProcessId(); |
58 int64_t tid = OSThread::ThreadIdToIntPtr(OSThread::GetCurrentThreadTraceId()); | 58 OSThread* os_thread = thread->os_thread(); |
| 59 ASSERT(os_thread != NULL); |
| 60 int64_t tid = OSThread::ThreadIdToIntPtr(os_thread->trace_id()); |
59 | 61 |
60 char* json = OS::SCreate(zone, | 62 char* json = OS::SCreate(zone, |
61 "{\"name\":\"%s\",\"cat\":\"%s\",\"tid\":%" Pd64 ",\"pid\":%" Pd64 "," | 63 "{\"name\":\"%s\",\"cat\":\"%s\",\"tid\":%" Pd64 ",\"pid\":%" Pd64 "," |
62 "\"ts\":%" Pd64 ",\"ph\":\"%s\",\"id\":%" Pd64 ", \"args\":%s}", | 64 "\"ts\":%" Pd64 ",\"ph\":\"%s\",\"id\":%" Pd64 ", \"args\":%s}", |
63 name.ToCString(), | 65 name.ToCString(), |
64 category.ToCString(), | 66 category.ToCString(), |
65 tid, | 67 tid, |
66 pid, | 68 pid, |
67 start.AsInt64Value(), | 69 start.AsInt64Value(), |
68 phase.ToCString(), | 70 phase.ToCString(), |
(...skipping 25 matching lines...) Expand all Loading... |
94 return Object::null(); | 96 return Object::null(); |
95 } | 97 } |
96 | 98 |
97 if (!isolate->GetDartStream()->Enabled()) { | 99 if (!isolate->GetDartStream()->Enabled()) { |
98 // Dart stream is not enabled for this isolate, do nothing. | 100 // Dart stream is not enabled for this isolate, do nothing. |
99 return Object::null(); | 101 return Object::null(); |
100 } | 102 } |
101 | 103 |
102 int64_t duration = end.AsInt64Value() - start.AsInt64Value(); | 104 int64_t duration = end.AsInt64Value() - start.AsInt64Value(); |
103 int64_t pid = OS::ProcessId(); | 105 int64_t pid = OS::ProcessId(); |
104 int64_t tid = OSThread::ThreadIdToIntPtr(OSThread::GetCurrentThreadTraceId()); | 106 OSThread* os_thread = thread->os_thread(); |
| 107 ASSERT(os_thread != NULL); |
| 108 int64_t tid = OSThread::ThreadIdToIntPtr(os_thread->trace_id()); |
105 | 109 |
106 char* json = OS::SCreate(zone, | 110 char* json = OS::SCreate(zone, |
107 "{\"name\":\"%s\",\"cat\":\"%s\",\"tid\":%" Pd64 ",\"pid\":%" Pd64 "," | 111 "{\"name\":\"%s\",\"cat\":\"%s\",\"tid\":%" Pd64 ",\"pid\":%" Pd64 "," |
108 "\"ts\":%" Pd64 ",\"ph\":\"X\",\"dur\":%" Pd64 ",\"args\":%s}", | 112 "\"ts\":%" Pd64 ",\"ph\":\"X\",\"dur\":%" Pd64 ",\"args\":%s}", |
109 name.ToCString(), | 113 name.ToCString(), |
110 category.ToCString(), | 114 category.ToCString(), |
111 tid, | 115 tid, |
112 pid, | 116 pid, |
113 start.AsInt64Value(), | 117 start.AsInt64Value(), |
114 duration, | 118 duration, |
(...skipping 22 matching lines...) Expand all Loading... |
137 if (recorder == NULL) { | 141 if (recorder == NULL) { |
138 return Object::null(); | 142 return Object::null(); |
139 } | 143 } |
140 | 144 |
141 if (!isolate->GetDartStream()->Enabled()) { | 145 if (!isolate->GetDartStream()->Enabled()) { |
142 // Dart stream is not enabled for this isolate, do nothing. | 146 // Dart stream is not enabled for this isolate, do nothing. |
143 return Object::null(); | 147 return Object::null(); |
144 } | 148 } |
145 | 149 |
146 int64_t pid = OS::ProcessId(); | 150 int64_t pid = OS::ProcessId(); |
147 int64_t tid = OSThread::ThreadIdToIntPtr(OSThread::GetCurrentThreadTraceId()); | 151 OSThread* os_thread = thread->os_thread(); |
| 152 ASSERT(os_thread != NULL); |
| 153 int64_t tid = OSThread::ThreadIdToIntPtr(os_thread->trace_id()); |
148 | 154 |
149 char* json = OS::SCreate(zone, | 155 char* json = OS::SCreate(zone, |
150 "{\"name\":\"%s\",\"cat\":\"%s\",\"tid\":%" Pd64 ",\"pid\":%" Pd64 "," | 156 "{\"name\":\"%s\",\"cat\":\"%s\",\"tid\":%" Pd64 ",\"pid\":%" Pd64 "," |
151 "\"ts\":%" Pd64 ",\"ph\":\"I\",\"args\":%s}", | 157 "\"ts\":%" Pd64 ",\"ph\":\"I\",\"args\":%s}", |
152 name.ToCString(), | 158 name.ToCString(), |
153 category.ToCString(), | 159 category.ToCString(), |
154 tid, | 160 tid, |
155 pid, | 161 pid, |
156 start.AsInt64Value(), | 162 start.AsInt64Value(), |
157 args.ToCString()); | 163 args.ToCString()); |
158 | 164 |
159 TimelineEvent* event = isolate->GetDartStream()->StartEvent(); | 165 TimelineEvent* event = isolate->GetDartStream()->StartEvent(); |
160 if (event == NULL) { | 166 if (event == NULL) { |
161 // Stream was turned off. | 167 // Stream was turned off. |
162 return Object::null(); | 168 return Object::null(); |
163 } | 169 } |
164 // json was allocated in the zone and a copy will be stored in event. | 170 // json was allocated in the zone and a copy will be stored in event. |
165 event->SerializedJSON(json); | 171 event->SerializedJSON(json); |
166 event->Complete(); | 172 event->Complete(); |
167 | 173 |
168 return Object::null(); | 174 return Object::null(); |
169 } | 175 } |
170 | 176 |
171 } // namespace dart | 177 } // namespace dart |
OLD | NEW |