OLD | NEW |
---|---|
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/api.h" | 5 #include "src/api.h" |
6 | 6 |
7 #include <string.h> // For memcpy, strlen. | 7 #include <string.h> // For memcpy, strlen. |
8 #ifdef V8_USE_ADDRESS_SANITIZER | 8 #ifdef V8_USE_ADDRESS_SANITIZER |
9 #include <sanitizer/asan_interface.h> | 9 #include <sanitizer/asan_interface.h> |
10 #endif // V8_USE_ADDRESS_SANITIZER | 10 #endif // V8_USE_ADDRESS_SANITIZER |
(...skipping 22 matching lines...) Expand all Loading... | |
33 #include "src/json-parser.h" | 33 #include "src/json-parser.h" |
34 #include "src/messages.h" | 34 #include "src/messages.h" |
35 #include "src/natives.h" | 35 #include "src/natives.h" |
36 #include "src/parser.h" | 36 #include "src/parser.h" |
37 #include "src/profile-generator-inl.h" | 37 #include "src/profile-generator-inl.h" |
38 #include "src/property.h" | 38 #include "src/property.h" |
39 #include "src/property-details.h" | 39 #include "src/property-details.h" |
40 #include "src/prototype.h" | 40 #include "src/prototype.h" |
41 #include "src/runtime.h" | 41 #include "src/runtime.h" |
42 #include "src/runtime-profiler.h" | 42 #include "src/runtime-profiler.h" |
43 #include "src/sampler.h" | |
43 #include "src/scanner-character-streams.h" | 44 #include "src/scanner-character-streams.h" |
44 #include "src/simulator.h" | 45 #include "src/simulator.h" |
45 #include "src/snapshot.h" | 46 #include "src/snapshot.h" |
46 #include "src/unicode-inl.h" | 47 #include "src/unicode-inl.h" |
47 #include "src/v8threads.h" | 48 #include "src/v8threads.h" |
48 #include "src/version.h" | 49 #include "src/version.h" |
49 #include "src/vm-state-inl.h" | 50 #include "src/vm-state-inl.h" |
50 | 51 |
51 | 52 |
52 #define LOG_API(isolate, expr) LOG(isolate, ApiEntryCall(expr)) | 53 #define LOG_API(isolate, expr) LOG(isolate, ApiEntryCall(expr)) |
(...skipping 6715 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
6768 i::Heap* heap = isolate->heap(); | 6769 i::Heap* heap = isolate->heap(); |
6769 heap_statistics->total_heap_size_ = heap->CommittedMemory(); | 6770 heap_statistics->total_heap_size_ = heap->CommittedMemory(); |
6770 heap_statistics->total_heap_size_executable_ = | 6771 heap_statistics->total_heap_size_executable_ = |
6771 heap->CommittedMemoryExecutable(); | 6772 heap->CommittedMemoryExecutable(); |
6772 heap_statistics->total_physical_size_ = heap->CommittedPhysicalMemory(); | 6773 heap_statistics->total_physical_size_ = heap->CommittedPhysicalMemory(); |
6773 heap_statistics->used_heap_size_ = heap->SizeOfObjects(); | 6774 heap_statistics->used_heap_size_ = heap->SizeOfObjects(); |
6774 heap_statistics->heap_size_limit_ = heap->MaxReserved(); | 6775 heap_statistics->heap_size_limit_ = heap->MaxReserved(); |
6775 } | 6776 } |
6776 | 6777 |
6777 | 6778 |
6779 void Isolate::GetSample(void* sp, void* fp, Sample* sample) { | |
alph
2014/09/18 11:34:29
What about pc register? It is essential to determi
gholap
2014/09/18 23:24:14
Done.
| |
6780 i::Isolate* isolate = reinterpret_cast<i::Isolate*>(this); | |
6781 i::TickSample tick_sample; | |
6782 i::RegisterState state; | |
6783 state.sp = reinterpret_cast<i::Address>(sp); | |
6784 state.fp = reinterpret_cast<i::Address>(fp); | |
6785 tick_sample.Init(isolate, state); | |
6786 sample = new (sample) Sample(&tick_sample.stack[0], | |
6787 &tick_sample.stack[tick_sample.frames_count]); | |
6788 } | |
6789 | |
6790 | |
6778 void Isolate::SetEventLogger(LogEventCallback that) { | 6791 void Isolate::SetEventLogger(LogEventCallback that) { |
6779 // Do not overwrite the event logger if we want to log explicitly. | 6792 // Do not overwrite the event logger if we want to log explicitly. |
6780 if (i::FLAG_log_timer_events) return; | 6793 if (i::FLAG_log_timer_events) return; |
6781 i::Isolate* isolate = reinterpret_cast<i::Isolate*>(this); | 6794 i::Isolate* isolate = reinterpret_cast<i::Isolate*>(this); |
6782 isolate->set_event_logger(that); | 6795 isolate->set_event_logger(that); |
6783 } | 6796 } |
6784 | 6797 |
6785 | 6798 |
6786 void Isolate::AddCallCompletedCallback(CallCompletedCallback callback) { | 6799 void Isolate::AddCallCompletedCallback(CallCompletedCallback callback) { |
6787 if (callback == NULL) return; | 6800 if (callback == NULL) return; |
(...skipping 957 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
7745 Isolate* isolate = reinterpret_cast<Isolate*>(info.GetIsolate()); | 7758 Isolate* isolate = reinterpret_cast<Isolate*>(info.GetIsolate()); |
7746 Address callback_address = | 7759 Address callback_address = |
7747 reinterpret_cast<Address>(reinterpret_cast<intptr_t>(callback)); | 7760 reinterpret_cast<Address>(reinterpret_cast<intptr_t>(callback)); |
7748 VMState<EXTERNAL> state(isolate); | 7761 VMState<EXTERNAL> state(isolate); |
7749 ExternalCallbackScope call_scope(isolate, callback_address); | 7762 ExternalCallbackScope call_scope(isolate, callback_address); |
7750 callback(info); | 7763 callback(info); |
7751 } | 7764 } |
7752 | 7765 |
7753 | 7766 |
7754 } } // namespace v8::internal | 7767 } } // namespace v8::internal |
OLD | NEW |