diff options
author | Ben Murdoch <benm@google.com> | 2016-09-26 15:26:03 +0000 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2016-09-26 15:26:03 +0000 |
commit | 5e33b08932de0903bf5d6e6759b3eeb432ed0e85 (patch) | |
tree | e4e31ed903eb4bbc3379245fce9974e5a9fe5c87 | |
parent | 10ba92037335259108a2cecc8fded23c94aaa542 (diff) | |
parent | 85c91d5683431930be9abf06e6e21f29fb4eb7ac (diff) | |
download | v8-5e33b08932de0903bf5d6e6759b3eeb432ed0e85.tar.gz |
Merge V8 5.1.281.59 DO NOT MERGE
am: 85c91d5683
Change-Id: Ib9547873d1f0d8447a094ffd4dfe7c9acc7abd2a
-rw-r--r-- | V8_MERGE_REVISION | 4 | ||||
-rw-r--r-- | include/v8-version.h | 2 | ||||
-rw-r--r-- | src/compiler/s390/code-generator-s390.cc | 46 | ||||
-rw-r--r-- | src/heap/spaces.cc | 4 | ||||
-rw-r--r-- | src/s390/macro-assembler-s390.cc | 38 | ||||
-rw-r--r-- | src/s390/macro-assembler-s390.h | 3 |
6 files changed, 34 insertions, 63 deletions
diff --git a/V8_MERGE_REVISION b/V8_MERGE_REVISION index 56848e5d..5278fb50 100644 --- a/V8_MERGE_REVISION +++ b/V8_MERGE_REVISION @@ -1,2 +1,2 @@ -v8 5.1.281.57 -https://chromium.googlesource.com/v8/v8/+/5.1.281.57 +v8 5.1.281.59 +https://chromium.googlesource.com/v8/v8/+/5.1.281.59 diff --git a/include/v8-version.h b/include/v8-version.h index 2c6c726d..545ec70e 100644 --- a/include/v8-version.h +++ b/include/v8-version.h @@ -11,7 +11,7 @@ #define V8_MAJOR_VERSION 5 #define V8_MINOR_VERSION 1 #define V8_BUILD_NUMBER 281 -#define V8_PATCH_LEVEL 57 +#define V8_PATCH_LEVEL 59 // Use 1 for candidates and 0 otherwise. // (Boolean macro values are not supported by all preprocessors.) diff --git a/src/compiler/s390/code-generator-s390.cc b/src/compiler/s390/code-generator-s390.cc index 68c1d9d5..1d968566 100644 --- a/src/compiler/s390/code-generator-s390.cc +++ b/src/compiler/s390/code-generator-s390.cc @@ -1307,8 +1307,8 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { #endif case kS390_Push: if (instr->InputAt(0)->IsDoubleRegister()) { - __ StoreDouble(i.InputDoubleRegister(0), MemOperand(sp, -kDoubleSize)); __ lay(sp, MemOperand(sp, -kDoubleSize)); + __ StoreDouble(i.InputDoubleRegister(0), MemOperand(sp)); frame_access_state()->IncreaseSPDelta(kDoubleSize / kPointerSize); } else { __ Push(i.InputRegister(0)); @@ -1317,14 +1317,14 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { break; case kS390_PushFrame: { int num_slots = i.InputInt32(1); + __ lay(sp, MemOperand(sp, -num_slots * kPointerSize)); if (instr->InputAt(0)->IsDoubleRegister()) { __ StoreDouble(i.InputDoubleRegister(0), - MemOperand(sp, -num_slots * kPointerSize)); + MemOperand(sp)); } else { __ StoreP(i.InputRegister(0), - MemOperand(sp, -num_slots * kPointerSize)); + MemOperand(sp)); } - __ lay(sp, MemOperand(sp, -num_slots * kPointerSize)); break; } case kS390_StoreToStackSlot: { @@ -1499,36 +1499,30 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { __ ldebr(i.OutputDoubleRegister(), i.InputDoubleRegister(0)); break; case kS390_DoubleExtractLowWord32: - // TODO(john.yan): this can cause problem when interrupting, - // use freg->greg instruction - __ stdy(i.InputDoubleRegister(0), MemOperand(sp, -kDoubleSize)); - __ LoadlW(i.OutputRegister(), - MemOperand(sp, -kDoubleSize + Register::kMantissaOffset)); + __ lgdr(i.OutputRegister(), i.InputDoubleRegister(0)); + __ llgfr(i.OutputRegister(), i.OutputRegister()); break; case kS390_DoubleExtractHighWord32: - // TODO(john.yan): this can cause problem when interrupting, - // use freg->greg instruction - __ stdy(i.InputDoubleRegister(0), MemOperand(sp, -kDoubleSize)); - __ LoadlW(i.OutputRegister(), - MemOperand(sp, -kDoubleSize + Register::kExponentOffset)); + __ lgdr(i.OutputRegister(), i.InputDoubleRegister(0)); + __ srlg(i.OutputRegister(), i.OutputRegister(), Operand(32)); break; case kS390_DoubleInsertLowWord32: - __ InsertDoubleLow(i.OutputDoubleRegister(), i.InputRegister(1)); + __ lgdr(kScratchReg, i.OutputDoubleRegister()); + __ lr(kScratchReg, i.InputRegister(1)); + __ ldgr(i.OutputDoubleRegister(), kScratchReg); break; case kS390_DoubleInsertHighWord32: - __ InsertDoubleHigh(i.OutputDoubleRegister(), i.InputRegister(1)); + __ sllg(kScratchReg, i.InputRegister(1), Operand(32)); + __ lgdr(r0, i.OutputDoubleRegister()); + __ lr(kScratchReg, r0); + __ ldgr(i.OutputDoubleRegister(), kScratchReg); break; case kS390_DoubleConstruct: -// TODO(john.yan): this can cause problem when interrupting, -// use greg->freg instruction -#if V8_TARGET_LITTLE_ENDIAN - __ StoreW(i.InputRegister(0), MemOperand(sp, -kDoubleSize / 2)); - __ StoreW(i.InputRegister(1), MemOperand(sp, -kDoubleSize)); -#else - __ StoreW(i.InputRegister(1), MemOperand(sp, -kDoubleSize / 2)); - __ StoreW(i.InputRegister(0), MemOperand(sp, -kDoubleSize)); -#endif - __ ldy(i.OutputDoubleRegister(), MemOperand(sp, -kDoubleSize)); + __ sllg(kScratchReg, i.InputRegister(0), Operand(32)); + __ lr(kScratchReg, i.InputRegister(1)); + + // Bitwise convert from GPR to FPR + __ ldgr(i.OutputDoubleRegister(), kScratchReg); break; case kS390_LoadWordS8: ASSEMBLE_LOAD_INTEGER(LoadlB); diff --git a/src/heap/spaces.cc b/src/heap/spaces.cc index 63e7c33c..a0a37523 100644 --- a/src/heap/spaces.cc +++ b/src/heap/spaces.cc @@ -792,7 +792,9 @@ MemoryChunk* MemoryAllocator::AllocatePagePooled(SpaceType* owner) { const Address start = reinterpret_cast<Address>(chunk); const Address area_start = start + MemoryChunk::kObjectStartOffset; const Address area_end = start + size; - CommitBlock(reinterpret_cast<Address>(chunk), size, NOT_EXECUTABLE); + if (!CommitBlock(reinterpret_cast<Address>(chunk), size, NOT_EXECUTABLE)) { + return nullptr; + } base::VirtualMemory reservation(start, size); MemoryChunk::Initialize(isolate_->heap(), start, size, area_start, area_end, NOT_EXECUTABLE, owner, &reservation); diff --git a/src/s390/macro-assembler-s390.cc b/src/s390/macro-assembler-s390.cc index e6abf68f..21058f42 100644 --- a/src/s390/macro-assembler-s390.cc +++ b/src/s390/macro-assembler-s390.cc @@ -205,26 +205,6 @@ void MacroAssembler::Move(DoubleRegister dst, DoubleRegister src) { } } -void MacroAssembler::InsertDoubleLow(DoubleRegister dst, Register src) { - StoreDouble(dst, MemOperand(sp, -kDoubleSize)); -#if V8_TARGET_LITTLE_ENDIAN - StoreW(src, MemOperand(sp, -kDoubleSize)); -#else - StoreW(src, MemOperand(sp, -kDoubleSize / 2)); -#endif - ldy(dst, MemOperand(sp, -kDoubleSize)); -} - -void MacroAssembler::InsertDoubleHigh(DoubleRegister dst, Register src) { - StoreDouble(dst, MemOperand(sp, -kDoubleSize)); -#if V8_TARGET_LITTLE_ENDIAN - StoreW(src, MemOperand(sp, -kDoubleSize / 2)); -#else - StoreW(src, MemOperand(sp, -kDoubleSize)); -#endif - ldy(dst, MemOperand(sp, -kDoubleSize)); -} - void MacroAssembler::MultiPush(RegList regs, Register location) { int16_t num_to_push = NumberOfBitsSet(regs); int16_t stack_offset = num_to_push * kPointerSize; @@ -1113,9 +1093,8 @@ void MacroAssembler::EnterExitFrame(bool save_doubles, int stack_space) { ClearRightImm(sp, sp, Operand(3)); // equivalent to &= -8 } - StoreP(MemOperand(sp, -kNumRequiredStackFrameSlots * kPointerSize), - Operand::Zero(), r0); lay(sp, MemOperand(sp, -kNumRequiredStackFrameSlots * kPointerSize)); + StoreP(MemOperand(sp), Operand::Zero(), r0); // Set the exit frame sp value to point just before the return address // location. lay(r1, MemOperand(sp, kStackFrameSPSlot * kPointerSize)); @@ -2332,9 +2311,8 @@ void MacroAssembler::TestDoubleIsMinusZero(DoubleRegister input, } void MacroAssembler::TestDoubleSign(DoubleRegister input, Register scratch) { - stdy(input, MemOperand(sp, -kDoubleSize)); - LoadlW(scratch, MemOperand(sp, -kDoubleSize + Register::kExponentOffset)); - Cmp32(scratch, Operand::Zero()); + lgdr(scratch, input); + cgfi(scratch, Operand::Zero()); } void MacroAssembler::TestHeapNumberSign(Register input, Register scratch) { @@ -2379,8 +2357,8 @@ void MacroAssembler::TryInt32Floor(Register result, DoubleRegister double_input, Label exception; // Move high word into input_high - StoreDouble(double_input, MemOperand(sp, -kDoubleSize)); lay(sp, MemOperand(sp, -kDoubleSize)); + StoreDouble(double_input, MemOperand(sp)); LoadlW(input_high, MemOperand(sp, Register::kExponentOffset)); la(sp, MemOperand(sp, kDoubleSize)); @@ -2446,8 +2424,8 @@ void MacroAssembler::TruncateDoubleToI(Register result, // If we fell through then inline version didn't succeed - call stub instead. push(r14); // Put input on stack. - StoreDouble(double_input, MemOperand(sp, -kDoubleSize)); lay(sp, MemOperand(sp, -kDoubleSize)); + StoreDouble(double_input, MemOperand(sp)); DoubleToIStub stub(isolate(), sp, result, 0, true, true); CallStub(&stub); @@ -5223,12 +5201,12 @@ void MacroAssembler::ShiftRight(Register dst, Register src, // Shift right logical for 32-bit integer types. void MacroAssembler::ShiftRight(Register dst, Register src, Register val) { - DCHECK(!dst.is(val)); // The lr/srl path clobbers val. if (dst.is(src)) { srl(dst, val); } else if (CpuFeatures::IsSupported(DISTINCT_OPS)) { srlk(dst, src, val); } else { + DCHECK(!dst.is(val)); // The lr/srl path clobbers val. lr(dst, src); srl(dst, val); } @@ -5249,12 +5227,12 @@ void MacroAssembler::ShiftLeftArith(Register dst, Register src, // Shift left arithmetic for 32-bit integer types. void MacroAssembler::ShiftLeftArith(Register dst, Register src, Register val) { - DCHECK(!dst.is(val)); // The lr/sla path clobbers val. if (dst.is(src)) { sla(dst, val); } else if (CpuFeatures::IsSupported(DISTINCT_OPS)) { slak(dst, src, val); } else { + DCHECK(!dst.is(val)); // The lr/sla path clobbers val. lr(dst, src); sla(dst, val); } @@ -5275,12 +5253,12 @@ void MacroAssembler::ShiftRightArith(Register dst, Register src, // Shift right arithmetic for 32-bit integer types. void MacroAssembler::ShiftRightArith(Register dst, Register src, Register val) { - DCHECK(!dst.is(val)); // The lr/sra path clobbers val. if (dst.is(src)) { sra(dst, val); } else if (CpuFeatures::IsSupported(DISTINCT_OPS)) { srak(dst, src, val); } else { + DCHECK(!dst.is(val)); // The lr/sra path clobbers val. lr(dst, src); sra(dst, val); } diff --git a/src/s390/macro-assembler-s390.h b/src/s390/macro-assembler-s390.h index d8d543ee..77fcccb1 100644 --- a/src/s390/macro-assembler-s390.h +++ b/src/s390/macro-assembler-s390.h @@ -214,9 +214,6 @@ class MacroAssembler : public Assembler { void Move(Register dst, Register src, Condition cond = al); void Move(DoubleRegister dst, DoubleRegister src); - void InsertDoubleLow(DoubleRegister dst, Register src); - void InsertDoubleHigh(DoubleRegister dst, Register src); - void MultiPush(RegList regs, Register location = sp); void MultiPop(RegList regs, Register location = sp); |