| 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/api.h" | 5 #include "src/api.h" |
| 6 #include "src/api-natives.h" | 6 #include "src/api-natives.h" |
| 7 #include "src/assert-scope.h" | 7 #include "src/assert-scope.h" |
| 8 #include "src/ast/ast.h" | 8 #include "src/ast/ast.h" |
| 9 #include "src/ast/scopes.h" | 9 #include "src/ast/scopes.h" |
| 10 #include "src/factory.h" | 10 #include "src/factory.h" |
| (...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 116 v8::internal::AsmTyper typer(info->isolate(), info->zone(), *(info->script()), | 116 v8::internal::AsmTyper typer(info->isolate(), info->zone(), *(info->script()), |
| 117 info->literal()); | 117 info->literal()); |
| 118 if (i::FLAG_enable_simd_asmjs) { | 118 if (i::FLAG_enable_simd_asmjs) { |
| 119 typer.set_allow_simd(true); | 119 typer.set_allow_simd(true); |
| 120 } | 120 } |
| 121 if (!typer.Validate()) { | 121 if (!typer.Validate()) { |
| 122 thrower->Error("Asm.js validation failed: %s", typer.error_message()); | 122 thrower->Error("Asm.js validation failed: %s", typer.error_message()); |
| 123 return nullptr; | 123 return nullptr; |
| 124 } | 124 } |
| 125 | 125 |
| 126 auto module = v8::internal::wasm::AsmWasmBuilder( | 126 auto module = |
| 127 info->isolate(), info->zone(), info->literal(), foreign) | 127 v8::internal::wasm::AsmWasmBuilder(info->isolate(), info->zone(), |
| 128 .Run(); | 128 info->literal(), foreign, &typer) |
| 129 .Run(); |
| 129 | 130 |
| 130 if (i::FLAG_dump_asmjs_wasm) { | 131 if (i::FLAG_dump_asmjs_wasm) { |
| 131 FILE* wasm_file = fopen(i::FLAG_asmjs_wasm_dumpfile, "wb"); | 132 FILE* wasm_file = fopen(i::FLAG_asmjs_wasm_dumpfile, "wb"); |
| 132 if (wasm_file) { | 133 if (wasm_file) { |
| 133 fwrite(module->Begin(), module->End() - module->Begin(), 1, wasm_file); | 134 fwrite(module->Begin(), module->End() - module->Begin(), 1, wasm_file); |
| 134 fclose(wasm_file); | 135 fclose(wasm_file); |
| 135 } | 136 } |
| 136 } | 137 } |
| 137 | 138 |
| 138 return module; | 139 return module; |
| (...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 282 if (!context->get(Context::WASM_FUNCTION_MAP_INDEX)->IsMap()) { | 283 if (!context->get(Context::WASM_FUNCTION_MAP_INDEX)->IsMap()) { |
| 283 Handle<Map> wasm_function_map = isolate->factory()->NewMap( | 284 Handle<Map> wasm_function_map = isolate->factory()->NewMap( |
| 284 JS_FUNCTION_TYPE, JSFunction::kSize + kPointerSize); | 285 JS_FUNCTION_TYPE, JSFunction::kSize + kPointerSize); |
| 285 wasm_function_map->set_is_callable(); | 286 wasm_function_map->set_is_callable(); |
| 286 context->set_wasm_function_map(*wasm_function_map); | 287 context->set_wasm_function_map(*wasm_function_map); |
| 287 } | 288 } |
| 288 } | 289 } |
| 289 | 290 |
| 290 } // namespace internal | 291 } // namespace internal |
| 291 } // namespace v8 | 292 } // namespace v8 |
| OLD | NEW |