Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 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/wasm/wasm-interpreter.h" | 5 #include "src/wasm/wasm-interpreter.h" |
| 6 | 6 |
| 7 #include "src/utils.h" | 7 #include "src/utils.h" |
| 8 #include "src/wasm/decoder.h" | 8 #include "src/wasm/decoder.h" |
| 9 #include "src/wasm/function-body-decoder.h" | 9 #include "src/wasm/function-body-decoder.h" |
| 10 #include "src/wasm/wasm-external-refs.h" | 10 #include "src/wasm/wasm-external-refs.h" |
| (...skipping 1161 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1172 size_t pop_count = stack_.size() - dest - arity; | 1172 size_t pop_count = stack_.size() - dest - arity; |
| 1173 for (size_t i = 0; i < arity; i++) { | 1173 for (size_t i = 0; i < arity; i++) { |
| 1174 stack_[dest + i] = stack_[dest + pop_count + i]; | 1174 stack_[dest + i] = stack_[dest + pop_count + i]; |
| 1175 } | 1175 } |
| 1176 stack_.resize(stack_.size() - pop_count); | 1176 stack_.resize(stack_.size() - pop_count); |
| 1177 } | 1177 } |
| 1178 | 1178 |
| 1179 void Execute(InterpreterCode* code, pc_t pc, int max) { | 1179 void Execute(InterpreterCode* code, pc_t pc, int max) { |
| 1180 Decoder decoder(code->start, code->end); | 1180 Decoder decoder(code->start, code->end); |
| 1181 pc_t limit = code->end - code->start; | 1181 pc_t limit = code->end - code->start; |
| 1182 while (--max >= 0) { | 1182 while (pc >= limit || --max >= 0) { |
|
titzer
2017/01/25 12:25:06
Hmm, that's weird. Why are we checking that the pc
Clemens Hammacher
2017/01/25 12:33:33
To run into the if 4 lines below. I can also make
| |
| 1183 #define PAUSE_IF_BREAK_FLAG(flag) \ | 1183 #define PAUSE_IF_BREAK_FLAG(flag) \ |
| 1184 if (V8_UNLIKELY(break_flags_ & WasmInterpreter::BreakFlag::flag)) max = 0; | 1184 if (V8_UNLIKELY(break_flags_ & WasmInterpreter::BreakFlag::flag)) max = 0; |
| 1185 | 1185 |
| 1186 if (pc >= limit) { | 1186 if (pc >= limit) { |
| 1187 DCHECK_EQ(pc, limit); | |
| 1187 // Fell off end of code; do an implicit return. | 1188 // Fell off end of code; do an implicit return. |
| 1188 TRACE("@%-3zu: ImplicitReturn\n", pc); | 1189 TRACE("@%-3zu: ImplicitReturn\n", pc); |
| 1189 if (!DoReturn(&code, &pc, &limit, code->function->sig->return_count())) | 1190 if (!DoReturn(&code, &pc, &limit, code->function->sig->return_count())) |
| 1190 return; | 1191 return; |
| 1191 decoder.Reset(code->start, code->end); | 1192 decoder.Reset(code->start, code->end); |
| 1192 PAUSE_IF_BREAK_FLAG(AfterReturn); | 1193 PAUSE_IF_BREAK_FLAG(AfterReturn); |
| 1193 continue; | 1194 continue; |
| 1194 } | 1195 } |
| 1195 | 1196 |
| 1196 const char* skip = " "; | 1197 const char* skip = " "; |
| (...skipping 725 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1922 return none; | 1923 return none; |
| 1923 } | 1924 } |
| 1924 | 1925 |
| 1925 void InterpretedFrame::SetLocalVal(int index, WasmVal val) { UNIMPLEMENTED(); } | 1926 void InterpretedFrame::SetLocalVal(int index, WasmVal val) { UNIMPLEMENTED(); } |
| 1926 | 1927 |
| 1927 void InterpretedFrame::SetExprVal(int pc, WasmVal val) { UNIMPLEMENTED(); } | 1928 void InterpretedFrame::SetExprVal(int pc, WasmVal val) { UNIMPLEMENTED(); } |
| 1928 | 1929 |
| 1929 } // namespace wasm | 1930 } // namespace wasm |
| 1930 } // namespace internal | 1931 } // namespace internal |
| 1931 } // namespace v8 | 1932 } // namespace v8 |
| OLD | NEW |