MIPS: Ensure that InternalArrays remain InternalArrays regardless of how they are constructed.
Port r10306 (9141da8e) BUG= TEST= Review URL: http://codereview.chromium.org/9080001 Patch from Gergely Kis <gergely@homejinni.com>. git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@10325 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
d9f7cf819c
commit
2063b374d6
@ -1,4 +1,4 @@
|
|||||||
// Copyright 2011 the V8 project authors. All rights reserved.
|
// Copyright 2012 the V8 project authors. All rights reserved.
|
||||||
// Redistribution and use in source and binary forms, with or without
|
// Redistribution and use in source and binary forms, with or without
|
||||||
// modification, are permitted provided that the following conditions are
|
// modification, are permitted provided that the following conditions are
|
||||||
// met:
|
// met:
|
||||||
@ -74,6 +74,22 @@ void Builtins::Generate_Adaptor(MacroAssembler* masm,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Load the built-in InternalArray function from the current context.
|
||||||
|
static void GenerateLoadInternalArrayFunction(MacroAssembler* masm,
|
||||||
|
Register result) {
|
||||||
|
// Load the global context.
|
||||||
|
|
||||||
|
__ lw(result, MemOperand(cp, Context::SlotOffset(Context::GLOBAL_INDEX)));
|
||||||
|
__ lw(result,
|
||||||
|
FieldMemOperand(result, GlobalObject::kGlobalContextOffset));
|
||||||
|
// Load the InternalArray function from the global context.
|
||||||
|
__ lw(result,
|
||||||
|
MemOperand(result,
|
||||||
|
Context::SlotOffset(
|
||||||
|
Context::INTERNAL_ARRAY_FUNCTION_INDEX)));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// Load the built-in Array function from the current context.
|
// Load the built-in Array function from the current context.
|
||||||
static void GenerateLoadArrayFunction(MacroAssembler* masm, Register result) {
|
static void GenerateLoadArrayFunction(MacroAssembler* masm, Register result) {
|
||||||
// Load the global context.
|
// Load the global context.
|
||||||
@ -425,6 +441,42 @@ static void ArrayNativeCode(MacroAssembler* masm,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Builtins::Generate_InternalArrayCode(MacroAssembler* masm) {
|
||||||
|
// ----------- S t a t e -------------
|
||||||
|
// -- a0 : number of arguments
|
||||||
|
// -- ra : return address
|
||||||
|
// -- sp[...]: constructor arguments
|
||||||
|
// -----------------------------------
|
||||||
|
Label generic_array_code, one_or_more_arguments, two_or_more_arguments;
|
||||||
|
|
||||||
|
// Get the InternalArray function.
|
||||||
|
GenerateLoadInternalArrayFunction(masm, a1);
|
||||||
|
|
||||||
|
if (FLAG_debug_code) {
|
||||||
|
// Initial map for the builtin InternalArray functions should be maps.
|
||||||
|
__ lw(a2, FieldMemOperand(a1, JSFunction::kPrototypeOrInitialMapOffset));
|
||||||
|
__ And(t0, a2, Operand(kSmiTagMask));
|
||||||
|
__ Assert(ne, "Unexpected initial map for InternalArray function",
|
||||||
|
t0, Operand(zero_reg));
|
||||||
|
__ GetObjectType(a2, a3, t0);
|
||||||
|
__ Assert(eq, "Unexpected initial map for InternalArray function",
|
||||||
|
t0, Operand(MAP_TYPE));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Run the native code for the InternalArray function called as a normal
|
||||||
|
// function.
|
||||||
|
ArrayNativeCode(masm, &generic_array_code);
|
||||||
|
|
||||||
|
// Jump to the generic array code if the specialized code cannot handle the
|
||||||
|
// construction.
|
||||||
|
__ bind(&generic_array_code);
|
||||||
|
|
||||||
|
Handle<Code> array_code =
|
||||||
|
masm->isolate()->builtins()->ArrayCodeGeneric();
|
||||||
|
__ Jump(array_code, RelocInfo::CODE_TARGET);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void Builtins::Generate_ArrayCode(MacroAssembler* masm) {
|
void Builtins::Generate_ArrayCode(MacroAssembler* masm) {
|
||||||
// ----------- S t a t e -------------
|
// ----------- S t a t e -------------
|
||||||
// -- a0 : number of arguments
|
// -- a0 : number of arguments
|
||||||
|
Loading…
Reference in New Issue
Block a user