| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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/compiler/instruction-selector.h" | 5 #include "src/compiler/instruction-selector.h" |
| 6 | 6 |
| 7 #include <limits> | 7 #include <limits> |
| 8 | 8 |
| 9 #include "src/base/adapters.h" | 9 #include "src/base/adapters.h" |
| 10 #include "src/compiler/instruction-selector-impl.h" | 10 #include "src/compiler/instruction-selector-impl.h" |
| (...skipping 1694 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1705 | 1705 |
| 1706 EmitPrepareArguments(&(buffer.pushed_nodes), descriptor, node); | 1706 EmitPrepareArguments(&(buffer.pushed_nodes), descriptor, node); |
| 1707 | 1707 |
| 1708 // Pass label of exception handler block. | 1708 // Pass label of exception handler block. |
| 1709 CallDescriptor::Flags flags = descriptor->flags(); | 1709 CallDescriptor::Flags flags = descriptor->flags(); |
| 1710 if (handler) { | 1710 if (handler) { |
| 1711 DCHECK_EQ(IrOpcode::kIfException, handler->front()->opcode()); | 1711 DCHECK_EQ(IrOpcode::kIfException, handler->front()->opcode()); |
| 1712 IfExceptionHint hint = OpParameter<IfExceptionHint>(handler->front()); | 1712 IfExceptionHint hint = OpParameter<IfExceptionHint>(handler->front()); |
| 1713 if (hint == IfExceptionHint::kLocallyCaught) { | 1713 if (hint == IfExceptionHint::kLocallyCaught) { |
| 1714 flags |= CallDescriptor::kHasLocalCatchHandler; | 1714 flags |= CallDescriptor::kHasLocalCatchHandler; |
| 1715 } else if (hint == IfExceptionHint::kLocallyCaughtForPromiseReject) { |
| 1716 flags |= CallDescriptor::kHasLocalCatchHandlerForPromiseReject; |
| 1715 } | 1717 } |
| 1716 flags |= CallDescriptor::kHasExceptionHandler; | 1718 flags |= CallDescriptor::kHasExceptionHandler; |
| 1717 buffer.instruction_args.push_back(g.Label(handler)); | 1719 buffer.instruction_args.push_back(g.Label(handler)); |
| 1718 } | 1720 } |
| 1719 | 1721 |
| 1720 bool from_native_stack = linkage()->GetIncomingDescriptor()->UseNativeStack(); | 1722 bool from_native_stack = linkage()->GetIncomingDescriptor()->UseNativeStack(); |
| 1721 bool to_native_stack = descriptor->UseNativeStack(); | 1723 bool to_native_stack = descriptor->UseNativeStack(); |
| 1722 if (from_native_stack != to_native_stack) { | 1724 if (from_native_stack != to_native_stack) { |
| 1723 // (arm64 only) Mismatch in the use of stack pointers. One or the other | 1725 // (arm64 only) Mismatch in the use of stack pointers. One or the other |
| 1724 // has to be restored manually by the code generator. | 1726 // has to be restored manually by the code generator. |
| (...skipping 263 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1988 return new (instruction_zone()) FrameStateDescriptor( | 1990 return new (instruction_zone()) FrameStateDescriptor( |
| 1989 instruction_zone(), state_info.type(), state_info.bailout_id(), | 1991 instruction_zone(), state_info.type(), state_info.bailout_id(), |
| 1990 state_info.state_combine(), parameters, locals, stack, | 1992 state_info.state_combine(), parameters, locals, stack, |
| 1991 state_info.shared_info(), outer_state); | 1993 state_info.shared_info(), outer_state); |
| 1992 } | 1994 } |
| 1993 | 1995 |
| 1994 | 1996 |
| 1995 } // namespace compiler | 1997 } // namespace compiler |
| 1996 } // namespace internal | 1998 } // namespace internal |
| 1997 } // namespace v8 | 1999 } // namespace v8 |
| OLD | NEW |