blob: 1f363de626d0dd55f3cb8e3260b85c6dacff58dd [file] [log] [blame]
Steve Block6ded16b2010-05-10 14:33:55 +01001// Copyright 2010 the V8 project authors. All rights reserved.
2// Redistribution and use in source and binary forms, with or without
3// modification, are permitted provided that the following conditions are
4// met:
5//
6// * Redistributions of source code must retain the above copyright
7// notice, this list of conditions and the following disclaimer.
8// * Redistributions in binary form must reproduce the above
9// copyright notice, this list of conditions and the following
10// disclaimer in the documentation and/or other materials provided
11// with the distribution.
12// * Neither the name of Google Inc. nor the names of its
13// contributors may be used to endorse or promote products derived
14// from this software without specific prior written permission.
15//
16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28#ifndef V8_VM_STATE_INL_H_
29#define V8_VM_STATE_INL_H_
30
31#include "vm-state.h"
Ben Murdochb0fe1622011-05-05 13:52:32 +010032#include "runtime-profiler.h"
Steve Block6ded16b2010-05-10 14:33:55 +010033
34namespace v8 {
35namespace internal {
36
37//
38// VMState class implementation. A simple stack of VM states held by the
39// logger and partially threaded through the call stack. States are pushed by
40// VMState construction and popped by destruction.
41//
42#ifdef ENABLE_VMSTATE_TRACKING
43inline const char* StateToString(StateTag state) {
44 switch (state) {
45 case JS:
46 return "JS";
47 case GC:
48 return "GC";
49 case COMPILER:
50 return "COMPILER";
51 case OTHER:
52 return "OTHER";
Ben Murdochb0fe1622011-05-05 13:52:32 +010053 case EXTERNAL:
54 return "EXTERNAL";
Steve Block6ded16b2010-05-10 14:33:55 +010055 default:
56 UNREACHABLE();
57 return NULL;
58 }
59}
60
Steve Block44f0eee2011-05-26 01:26:41 +010061
62VMState::VMState(Isolate* isolate, StateTag tag)
63 : isolate_(isolate), previous_tag_(isolate->current_vm_state()) {
Steve Block6ded16b2010-05-10 14:33:55 +010064#ifdef ENABLE_LOGGING_AND_PROFILING
65 if (FLAG_log_state_changes) {
Steve Block44f0eee2011-05-26 01:26:41 +010066 LOG(isolate, UncheckedStringEvent("Entering", StateToString(tag)));
67 LOG(isolate, UncheckedStringEvent("From", StateToString(previous_tag_)));
Steve Block6ded16b2010-05-10 14:33:55 +010068 }
69#endif
70
Steve Block44f0eee2011-05-26 01:26:41 +010071 isolate_->SetCurrentVMState(tag);
Ben Murdochb0fe1622011-05-05 13:52:32 +010072
Steve Block6ded16b2010-05-10 14:33:55 +010073#ifdef ENABLE_HEAP_PROTECTION
74 if (FLAG_protect_heap) {
Ben Murdochb0fe1622011-05-05 13:52:32 +010075 if (tag == EXTERNAL) {
Steve Block6ded16b2010-05-10 14:33:55 +010076 // We are leaving V8.
Ben Murdochb0fe1622011-05-05 13:52:32 +010077 ASSERT(previous_tag_ != EXTERNAL);
Steve Block44f0eee2011-05-26 01:26:41 +010078 isolate_->heap()->Protect();
Ben Murdochb0fe1622011-05-05 13:52:32 +010079 } else if (previous_tag_ = EXTERNAL) {
Steve Block6ded16b2010-05-10 14:33:55 +010080 // We are entering V8.
Steve Block44f0eee2011-05-26 01:26:41 +010081 isolate_->heap()->Unprotect();
Steve Block6ded16b2010-05-10 14:33:55 +010082 }
83 }
84#endif
85}
86
87
88VMState::~VMState() {
Steve Block6ded16b2010-05-10 14:33:55 +010089#ifdef ENABLE_LOGGING_AND_PROFILING
90 if (FLAG_log_state_changes) {
Steve Block44f0eee2011-05-26 01:26:41 +010091 LOG(isolate_,
92 UncheckedStringEvent("Leaving",
93 StateToString(isolate_->current_vm_state())));
94 LOG(isolate_,
95 UncheckedStringEvent("To", StateToString(previous_tag_)));
Steve Block6ded16b2010-05-10 14:33:55 +010096 }
97#endif // ENABLE_LOGGING_AND_PROFILING
98
99#ifdef ENABLE_HEAP_PROTECTION
Steve Block44f0eee2011-05-26 01:26:41 +0100100 StateTag tag = isolate_->current_vm_state();
Ben Murdochb0fe1622011-05-05 13:52:32 +0100101#endif
102
Steve Block44f0eee2011-05-26 01:26:41 +0100103 isolate_->SetCurrentVMState(previous_tag_);
Ben Murdochb0fe1622011-05-05 13:52:32 +0100104
105#ifdef ENABLE_HEAP_PROTECTION
Steve Block6ded16b2010-05-10 14:33:55 +0100106 if (FLAG_protect_heap) {
Ben Murdochb0fe1622011-05-05 13:52:32 +0100107 if (tag == EXTERNAL) {
Steve Block6ded16b2010-05-10 14:33:55 +0100108 // We are reentering V8.
Ben Murdochb0fe1622011-05-05 13:52:32 +0100109 ASSERT(previous_tag_ != EXTERNAL);
Steve Block44f0eee2011-05-26 01:26:41 +0100110 isolate_->heap()->Unprotect();
Ben Murdochb0fe1622011-05-05 13:52:32 +0100111 } else if (previous_tag_ == EXTERNAL) {
Steve Block6ded16b2010-05-10 14:33:55 +0100112 // We are leaving V8.
Steve Block44f0eee2011-05-26 01:26:41 +0100113 isolate_->heap()->Protect();
Steve Block6ded16b2010-05-10 14:33:55 +0100114 }
115 }
116#endif // ENABLE_HEAP_PROTECTION
117}
Ben Murdochb0fe1622011-05-05 13:52:32 +0100118
Steve Block6ded16b2010-05-10 14:33:55 +0100119#endif // ENABLE_VMSTATE_TRACKING
120
Ben Murdochb0fe1622011-05-05 13:52:32 +0100121
122#ifdef ENABLE_LOGGING_AND_PROFILING
123
Steve Block44f0eee2011-05-26 01:26:41 +0100124ExternalCallbackScope::ExternalCallbackScope(Isolate* isolate, Address callback)
125 : isolate_(isolate), previous_callback_(isolate->external_callback()) {
126 isolate_->set_external_callback(callback);
Ben Murdochb0fe1622011-05-05 13:52:32 +0100127}
128
129ExternalCallbackScope::~ExternalCallbackScope() {
Steve Block44f0eee2011-05-26 01:26:41 +0100130 isolate_->set_external_callback(previous_callback_);
Ben Murdochb0fe1622011-05-05 13:52:32 +0100131}
132
133#endif // ENABLE_LOGGING_AND_PROFILING
134
135
Steve Block6ded16b2010-05-10 14:33:55 +0100136} } // namespace v8::internal
137
138#endif // V8_VM_STATE_INL_H_