Commit 2f089197 authored by bradnelson's avatar bradnelson Committed by Commit bot

[wasm][asm.js] Check if a property key is a PropertyName before assumming it.

BUG=681707
R=aseemgarg@chromium.org,titzer@chromium.org

Review-Url: https://codereview.chromium.org/2641513003
Cr-Commit-Position: refs/heads/master@{#42433}
parent 6934db7c
...@@ -385,6 +385,10 @@ AsmTyper::VariableInfo* AsmTyper::ImportLookup(Property* import) { ...@@ -385,6 +385,10 @@ AsmTyper::VariableInfo* AsmTyper::ImportLookup(Property* import) {
return obj_info; return obj_info;
} }
if (!key->IsPropertyName()) {
return nullptr;
}
std::unique_ptr<char[]> aname = key->AsPropertyName()->ToCString(); std::unique_ptr<char[]> aname = key->AsPropertyName()->ToCString();
ObjectTypeMap::iterator i = stdlib->find(std::string(aname.get())); ObjectTypeMap::iterator i = stdlib->find(std::string(aname.get()));
if (i == stdlib->end()) { if (i == stdlib->end()) {
......
// Copyright 2017 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --validate-asm
var foo = (function(stdlib) {
"use asm";
var bar = (stdlib[0]);
function foo() { return bar ("lala"); }
return foo;
})(this);
try {
nop(foo);
foo();
} catch (e) {
}
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