Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 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/wasm-compiler.h" | 5 #include "src/compiler/wasm-compiler.h" |
| 6 | 6 |
| 7 #include "src/isolate-inl.h" | 7 #include "src/isolate-inl.h" |
| 8 | 8 |
| 9 #include "src/base/platform/elapsed-timer.h" | 9 #include "src/base/platform/elapsed-timer.h" |
| 10 #include "src/base/platform/platform.h" | 10 #include "src/base/platform/platform.h" |
| (...skipping 1908 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1919 DCHECK(module_ && module_->instance); | 1919 DCHECK(module_ && module_->instance); |
| 1920 | 1920 |
| 1921 MachineOperatorBuilder* machine = jsgraph()->machine(); | 1921 MachineOperatorBuilder* machine = jsgraph()->machine(); |
| 1922 | 1922 |
| 1923 // Compute the code object by loading it from the function table. | 1923 // Compute the code object by loading it from the function table. |
| 1924 Node* key = args[0]; | 1924 Node* key = args[0]; |
| 1925 | 1925 |
| 1926 // Bounds check the index. | 1926 // Bounds check the index. |
| 1927 int table_size = static_cast<int>(module_->FunctionTableSize()); | 1927 int table_size = static_cast<int>(module_->FunctionTableSize()); |
| 1928 if (table_size > 0) { | 1928 if (table_size > 0) { |
| 1929 // Bounds check against the table size. | 1929 if (FLAG_wasm_jit_prototype) { |
| 1930 Node* size = Int32Constant(static_cast<int>(table_size)); | 1930 int indirect_table_size = |
| 1931 Node* in_bounds = graph()->NewNode(machine->Uint32LessThan(), key, size); | 1931 static_cast<int>(module_->instance->function_table->length()); |
| 1932 trap_->AddTrapIfFalse(wasm::kTrapFuncInvalid, in_bounds, position); | 1932 |
| 1933 Node* upper_bound = Int32Constant(indirect_table_size / 2); | |
| 1934 Node* less_than_upper_bound = | |
| 1935 graph()->NewNode(machine->Uint32LessThan(), key, upper_bound); | |
| 1936 trap_->AddTrapIfFalse(wasm::kTrapFuncInvalid, less_than_upper_bound, | |
| 1937 position); | |
| 1938 | |
| 1939 Node* lower_bound = Int32Constant(indirect_table_size / 2 - | |
| 1940 module_->instance->padded_entries); | |
|
bradn
2016/06/14 02:02:46
Hey Ritesh.
Actually this isn't quite right.
We do
titzer
2016/06/14 20:58:05
Agree.
bradn
2016/06/14 21:00:25
Actually since it can't run (since we don't know t
| |
| 1941 Node* more_than_lower_bound = | |
| 1942 graph()->NewNode(machine->Uint32LessThanOrEqual(), lower_bound, key); | |
| 1943 trap_->AddTrapIfTrue(wasm::kTrapDefaultFuncCall, more_than_lower_bound, | |
| 1944 position); | |
| 1945 } else { | |
| 1946 // Bounds check against the table size. | |
| 1947 Node* size = Int32Constant(static_cast<int>(table_size)); | |
| 1948 Node* in_bounds = graph()->NewNode(machine->Uint32LessThan(), key, size); | |
| 1949 trap_->AddTrapIfFalse(wasm::kTrapFuncInvalid, in_bounds, position); | |
| 1950 } | |
| 1933 } else { | 1951 } else { |
| 1934 // No function table. Generate a trap and return a constant. | 1952 // No function table. Generate a trap and return a constant. |
| 1935 trap_->AddTrapIfFalse(wasm::kTrapFuncInvalid, Int32Constant(0), position); | 1953 trap_->AddTrapIfFalse(wasm::kTrapFuncInvalid, Int32Constant(0), position); |
| 1936 return trap_->GetTrapValue(module_->GetSignature(index)); | 1954 return trap_->GetTrapValue(module_->GetSignature(index)); |
| 1937 } | 1955 } |
| 1938 Node* table = FunctionTable(); | 1956 Node* table = FunctionTable(); |
| 1939 | 1957 |
| 1940 // Load signature from the table and check. | 1958 // Load signature from the table and check. |
| 1941 // The table is a FixedArray; signatures are encoded as SMIs. | 1959 // The table is a FixedArray; signatures are encoded as SMIs. |
| 1942 // [sig1, sig2, sig3, ...., code1, code2, code3 ...] | 1960 // [sig1, sig2, sig3, ...., code1, code2, code3 ...] |
| (...skipping 1168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3111 const wasm::WasmFunction* function) { | 3129 const wasm::WasmFunction* function) { |
| 3112 WasmCompilationUnit* unit = | 3130 WasmCompilationUnit* unit = |
| 3113 CreateWasmCompilationUnit(thrower, isolate, module_env, function, 0); | 3131 CreateWasmCompilationUnit(thrower, isolate, module_env, function, 0); |
| 3114 ExecuteCompilation(unit); | 3132 ExecuteCompilation(unit); |
| 3115 return FinishCompilation(unit); | 3133 return FinishCompilation(unit); |
| 3116 } | 3134 } |
| 3117 | 3135 |
| 3118 } // namespace compiler | 3136 } // namespace compiler |
| 3119 } // namespace internal | 3137 } // namespace internal |
| 3120 } // namespace v8 | 3138 } // namespace v8 |
| OLD | NEW |