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
|
||||
// modification, are permitted provided that the following conditions are
|
||||
// met:
|
||||
@ -74,17 +74,33 @@ 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.
|
||||
static void GenerateLoadArrayFunction(MacroAssembler* masm, Register result) {
|
||||
// Load the global context.
|
||||
|
||||
__ lw(result, MemOperand(cp, Context::SlotOffset(Context::GLOBAL_INDEX)));
|
||||
__ lw(result,
|
||||
FieldMemOperand(result, GlobalObject::kGlobalContextOffset));
|
||||
FieldMemOperand(result, GlobalObject::kGlobalContextOffset));
|
||||
// Load the Array function from the global context.
|
||||
__ lw(result,
|
||||
MemOperand(result,
|
||||
Context::SlotOffset(Context::ARRAY_FUNCTION_INDEX)));
|
||||
MemOperand(result,
|
||||
Context::SlotOffset(Context::ARRAY_FUNCTION_INDEX)));
|
||||
}
|
||||
|
||||
|
||||
@ -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) {
|
||||
// ----------- S t a t e -------------
|
||||
// -- a0 : number of arguments
|
||||
|
Loading…
Reference in New Issue
Block a user