Commit b25513e3 authored by yangguo@chromium.org's avatar yangguo@chromium.org

Revert interrupt handling code changed in r21208.

R=svenpanne@chromium.org

Review URL: https://codereview.chromium.org/277233004

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@21252 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent cf832799
......@@ -388,18 +388,6 @@ void StackGuard::ClearInterrupt(int flagbit) {
}
bool StackGuard::CheckAndClearInterrupt(InterruptFlag flag,
const ExecutionAccess& lock) {
int flagbit = 1 << flag;
bool result = (thread_local_.interrupt_flags_ & flagbit);
thread_local_.interrupt_flags_ &= ~flagbit;
if (!should_postpone_interrupts(lock) && !has_pending_interrupts(lock)) {
reset_limits(lock);
}
return result;
}
char* StackGuard::ArchiveStackGuard(char* to) {
ExecutionAccess access(isolate_);
OS::MemCopy(to, reinterpret_cast<char*>(&thread_local_), sizeof(ThreadLocal));
......@@ -732,37 +720,44 @@ void Execution::ProcessDebugMessages(Isolate* isolate,
Object* StackGuard::HandleInterrupts() {
ExecutionAccess access(isolate_);
if (should_postpone_interrupts(access)) {
return isolate_->heap()->undefined_value();
{ ExecutionAccess access(isolate_);
if (should_postpone_interrupts(access)) {
return isolate_->heap()->undefined_value();
}
}
if (CheckAndClearInterrupt(API_INTERRUPT, access)) {
if (CheckApiInterrupt()) {
ClearApiInterrupt();
isolate_->InvokeApiInterruptCallback();
}
if (CheckAndClearInterrupt(GC_REQUEST, access)) {
if (CheckGC()) {
isolate_->heap()->CollectAllGarbage(Heap::kNoGCFlags, "GC interrupt");
ClearGC();
}
if (CheckDebugBreak() || CheckDebugCommand()) {
Execution::DebugBreakHelper(isolate_);
}
if (CheckAndClearInterrupt(TERMINATE_EXECUTION, access)) {
if (CheckTerminateExecution()) {
ClearTerminateExecution();
return isolate_->TerminateExecution();
}
if (CheckAndClearInterrupt(FULL_DEOPT, access)) {
if (CheckFullDeopt()) {
ClearFullDeopt();
Deoptimizer::DeoptimizeAll(isolate_);
}
if (CheckAndClearInterrupt(DEOPT_MARKED_ALLOCATION_SITES, access)) {
if (CheckDeoptMarkedAllocationSites()) {
ClearDeoptMarkedAllocationSites();
isolate_->heap()->DeoptMarkedAllocationSites();
}
if (CheckAndClearInterrupt(INSTALL_CODE, access)) {
if (CheckInstallCode()) {
ASSERT(isolate_->concurrent_recompilation_enabled());
ClearInstallCode();
isolate_->optimizing_compiler_thread()->InstallOptimizedFunctions();
}
......
......@@ -210,7 +210,6 @@ enum InterruptFlag {
bool CheckInterrupt(int flagbit);
void RequestInterrupt(int flagbit);
void ClearInterrupt(int flagbit);
bool CheckAndClearInterrupt(InterruptFlag flag, const ExecutionAccess& lock);
void InvokeApiInterruptCallback();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment