Merge
This commit is contained in:
commit
6864f9f8a8
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -2946,6 +2946,9 @@ void LIR_Assembler::monitor_address(int monitor_no, LIR_Opr dst_opr) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LIR_Assembler::emit_updatecrc32(LIR_OpUpdateCRC32* op) {
|
||||||
|
fatal("CRC32 intrinsic is not implemented on this platform");
|
||||||
|
}
|
||||||
|
|
||||||
void LIR_Assembler::emit_lock(LIR_OpLock* op) {
|
void LIR_Assembler::emit_lock(LIR_OpLock* op) {
|
||||||
Register obj = op->obj_opr()->as_register();
|
Register obj = op->obj_opr()->as_register();
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -784,6 +784,10 @@ void LIRGenerator::do_ArrayCopy(Intrinsic* x) {
|
|||||||
set_no_result(x);
|
set_no_result(x);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LIRGenerator::do_update_CRC32(Intrinsic* x) {
|
||||||
|
fatal("CRC32 intrinsic is not implemented on this platform");
|
||||||
|
}
|
||||||
|
|
||||||
// _i2l, _i2f, _i2d, _l2i, _l2f, _l2d, _f2i, _f2l, _f2d, _d2i, _d2l, _d2f
|
// _i2l, _i2f, _i2d, _l2i, _l2f, _l2d, _f2i, _f2l, _f2d, _d2i, _d2l, _d2f
|
||||||
// _i2b, _i2c, _i2s
|
// _i2b, _i2c, _i2s
|
||||||
void LIRGenerator::do_Convert(Convert* x) {
|
void LIRGenerator::do_Convert(Convert* x) {
|
||||||
|
@ -50,6 +50,7 @@ define_pd_global(bool, ResizeTLAB, true );
|
|||||||
define_pd_global(intx, ReservedCodeCacheSize, 32*M );
|
define_pd_global(intx, ReservedCodeCacheSize, 32*M );
|
||||||
define_pd_global(intx, CodeCacheExpansionSize, 32*K );
|
define_pd_global(intx, CodeCacheExpansionSize, 32*K );
|
||||||
define_pd_global(uintx, CodeCacheMinBlockLength, 1);
|
define_pd_global(uintx, CodeCacheMinBlockLength, 1);
|
||||||
|
define_pd_global(uintx, CodeCacheMinimumUseSpace, 400*K);
|
||||||
define_pd_global(uintx, MetaspaceSize, 12*M );
|
define_pd_global(uintx, MetaspaceSize, 12*M );
|
||||||
define_pd_global(bool, NeverActAsServerClassMachine, true );
|
define_pd_global(bool, NeverActAsServerClassMachine, true );
|
||||||
define_pd_global(intx, NewSizeThreadIncrease, 16*K );
|
define_pd_global(intx, NewSizeThreadIncrease, 16*K );
|
||||||
|
@ -87,6 +87,7 @@ define_pd_global(intx, CodeCacheExpansionSize, 32*K);
|
|||||||
define_pd_global(uint64_t,MaxRAM, 4ULL*G);
|
define_pd_global(uint64_t,MaxRAM, 4ULL*G);
|
||||||
#endif
|
#endif
|
||||||
define_pd_global(uintx, CodeCacheMinBlockLength, 4);
|
define_pd_global(uintx, CodeCacheMinBlockLength, 4);
|
||||||
|
define_pd_global(uintx, CodeCacheMinimumUseSpace, 400*K);
|
||||||
|
|
||||||
// Heap related flags
|
// Heap related flags
|
||||||
define_pd_global(uintx,MetaspaceSize, ScaleForWordSize(16*M));
|
define_pd_global(uintx,MetaspaceSize, ScaleForWordSize(16*M));
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -1673,6 +1673,11 @@ void Assembler::movdqa(XMMRegister dst, XMMRegister src) {
|
|||||||
emit_simd_arith_nonds(0x6F, dst, src, VEX_SIMD_66);
|
emit_simd_arith_nonds(0x6F, dst, src, VEX_SIMD_66);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Assembler::movdqa(XMMRegister dst, Address src) {
|
||||||
|
NOT_LP64(assert(VM_Version::supports_sse2(), ""));
|
||||||
|
emit_simd_arith_nonds(0x6F, dst, src, VEX_SIMD_66);
|
||||||
|
}
|
||||||
|
|
||||||
void Assembler::movdqu(XMMRegister dst, Address src) {
|
void Assembler::movdqu(XMMRegister dst, Address src) {
|
||||||
NOT_LP64(assert(VM_Version::supports_sse2(), ""));
|
NOT_LP64(assert(VM_Version::supports_sse2(), ""));
|
||||||
emit_simd_arith_nonds(0x6F, dst, src, VEX_SIMD_F3);
|
emit_simd_arith_nonds(0x6F, dst, src, VEX_SIMD_F3);
|
||||||
@ -2286,6 +2291,38 @@ void Assembler::pcmpestri(XMMRegister dst, XMMRegister src, int imm8) {
|
|||||||
emit_int8(imm8);
|
emit_int8(imm8);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Assembler::pextrd(Register dst, XMMRegister src, int imm8) {
|
||||||
|
assert(VM_Version::supports_sse4_1(), "");
|
||||||
|
int encode = simd_prefix_and_encode(as_XMMRegister(dst->encoding()), xnoreg, src, VEX_SIMD_66, VEX_OPCODE_0F_3A, false);
|
||||||
|
emit_int8(0x16);
|
||||||
|
emit_int8((unsigned char)(0xC0 | encode));
|
||||||
|
emit_int8(imm8);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Assembler::pextrq(Register dst, XMMRegister src, int imm8) {
|
||||||
|
assert(VM_Version::supports_sse4_1(), "");
|
||||||
|
int encode = simd_prefix_and_encode(as_XMMRegister(dst->encoding()), xnoreg, src, VEX_SIMD_66, VEX_OPCODE_0F_3A, true);
|
||||||
|
emit_int8(0x16);
|
||||||
|
emit_int8((unsigned char)(0xC0 | encode));
|
||||||
|
emit_int8(imm8);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Assembler::pinsrd(XMMRegister dst, Register src, int imm8) {
|
||||||
|
assert(VM_Version::supports_sse4_1(), "");
|
||||||
|
int encode = simd_prefix_and_encode(dst, dst, as_XMMRegister(src->encoding()), VEX_SIMD_66, VEX_OPCODE_0F_3A, false);
|
||||||
|
emit_int8(0x22);
|
||||||
|
emit_int8((unsigned char)(0xC0 | encode));
|
||||||
|
emit_int8(imm8);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Assembler::pinsrq(XMMRegister dst, Register src, int imm8) {
|
||||||
|
assert(VM_Version::supports_sse4_1(), "");
|
||||||
|
int encode = simd_prefix_and_encode(dst, dst, as_XMMRegister(src->encoding()), VEX_SIMD_66, VEX_OPCODE_0F_3A, true);
|
||||||
|
emit_int8(0x22);
|
||||||
|
emit_int8((unsigned char)(0xC0 | encode));
|
||||||
|
emit_int8(imm8);
|
||||||
|
}
|
||||||
|
|
||||||
void Assembler::pmovzxbw(XMMRegister dst, Address src) {
|
void Assembler::pmovzxbw(XMMRegister dst, Address src) {
|
||||||
assert(VM_Version::supports_sse4_1(), "");
|
assert(VM_Version::supports_sse4_1(), "");
|
||||||
InstructionMark im(this);
|
InstructionMark im(this);
|
||||||
@ -3691,6 +3728,16 @@ void Assembler::vpbroadcastd(XMMRegister dst, XMMRegister src) {
|
|||||||
emit_int8((unsigned char)(0xC0 | encode));
|
emit_int8((unsigned char)(0xC0 | encode));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Carry-Less Multiplication Quadword
|
||||||
|
void Assembler::vpclmulqdq(XMMRegister dst, XMMRegister nds, XMMRegister src, int mask) {
|
||||||
|
assert(VM_Version::supports_avx() && VM_Version::supports_clmul(), "");
|
||||||
|
bool vector256 = false;
|
||||||
|
int encode = vex_prefix_and_encode(dst, nds, src, VEX_SIMD_66, vector256, VEX_OPCODE_0F_3A);
|
||||||
|
emit_int8(0x44);
|
||||||
|
emit_int8((unsigned char)(0xC0 | encode));
|
||||||
|
emit_int8((unsigned char)mask);
|
||||||
|
}
|
||||||
|
|
||||||
void Assembler::vzeroupper() {
|
void Assembler::vzeroupper() {
|
||||||
assert(VM_Version::supports_avx(), "");
|
assert(VM_Version::supports_avx(), "");
|
||||||
(void)vex_prefix_and_encode(xmm0, xmm0, xmm0, VEX_SIMD_NONE);
|
(void)vex_prefix_and_encode(xmm0, xmm0, xmm0, VEX_SIMD_NONE);
|
||||||
|
@ -1266,6 +1266,7 @@ private:
|
|||||||
|
|
||||||
// Move Aligned Double Quadword
|
// Move Aligned Double Quadword
|
||||||
void movdqa(XMMRegister dst, XMMRegister src);
|
void movdqa(XMMRegister dst, XMMRegister src);
|
||||||
|
void movdqa(XMMRegister dst, Address src);
|
||||||
|
|
||||||
// Move Unaligned Double Quadword
|
// Move Unaligned Double Quadword
|
||||||
void movdqu(Address dst, XMMRegister src);
|
void movdqu(Address dst, XMMRegister src);
|
||||||
@ -1404,6 +1405,14 @@ private:
|
|||||||
void pcmpestri(XMMRegister xmm1, XMMRegister xmm2, int imm8);
|
void pcmpestri(XMMRegister xmm1, XMMRegister xmm2, int imm8);
|
||||||
void pcmpestri(XMMRegister xmm1, Address src, int imm8);
|
void pcmpestri(XMMRegister xmm1, Address src, int imm8);
|
||||||
|
|
||||||
|
// SSE 4.1 extract
|
||||||
|
void pextrd(Register dst, XMMRegister src, int imm8);
|
||||||
|
void pextrq(Register dst, XMMRegister src, int imm8);
|
||||||
|
|
||||||
|
// SSE 4.1 insert
|
||||||
|
void pinsrd(XMMRegister dst, Register src, int imm8);
|
||||||
|
void pinsrq(XMMRegister dst, Register src, int imm8);
|
||||||
|
|
||||||
// SSE4.1 packed move
|
// SSE4.1 packed move
|
||||||
void pmovzxbw(XMMRegister dst, XMMRegister src);
|
void pmovzxbw(XMMRegister dst, XMMRegister src);
|
||||||
void pmovzxbw(XMMRegister dst, Address src);
|
void pmovzxbw(XMMRegister dst, Address src);
|
||||||
@ -1764,6 +1773,9 @@ private:
|
|||||||
// duplicate 4-bytes integer data from src into 8 locations in dest
|
// duplicate 4-bytes integer data from src into 8 locations in dest
|
||||||
void vpbroadcastd(XMMRegister dst, XMMRegister src);
|
void vpbroadcastd(XMMRegister dst, XMMRegister src);
|
||||||
|
|
||||||
|
// Carry-Less Multiplication Quadword
|
||||||
|
void vpclmulqdq(XMMRegister dst, XMMRegister nds, XMMRegister src, int mask);
|
||||||
|
|
||||||
// AVX instruction which is used to clear upper 128 bits of YMM registers and
|
// AVX instruction which is used to clear upper 128 bits of YMM registers and
|
||||||
// to avoid transaction penalty between AVX and SSE states. There is no
|
// to avoid transaction penalty between AVX and SSE states. There is no
|
||||||
// penalty if legacy SSE instructions are encoded using VEX prefix because
|
// penalty if legacy SSE instructions are encoded using VEX prefix because
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -3512,6 +3512,22 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) {
|
|||||||
__ bind(*stub->continuation());
|
__ bind(*stub->continuation());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LIR_Assembler::emit_updatecrc32(LIR_OpUpdateCRC32* op) {
|
||||||
|
assert(op->crc()->is_single_cpu(), "crc must be register");
|
||||||
|
assert(op->val()->is_single_cpu(), "byte value must be register");
|
||||||
|
assert(op->result_opr()->is_single_cpu(), "result must be register");
|
||||||
|
Register crc = op->crc()->as_register();
|
||||||
|
Register val = op->val()->as_register();
|
||||||
|
Register res = op->result_opr()->as_register();
|
||||||
|
|
||||||
|
assert_different_registers(val, crc, res);
|
||||||
|
|
||||||
|
__ lea(res, ExternalAddress(StubRoutines::crc_table_addr()));
|
||||||
|
__ notl(crc); // ~crc
|
||||||
|
__ update_byte_crc32(crc, val, res);
|
||||||
|
__ notl(crc); // ~crc
|
||||||
|
__ mov(res, crc);
|
||||||
|
}
|
||||||
|
|
||||||
void LIR_Assembler::emit_lock(LIR_OpLock* op) {
|
void LIR_Assembler::emit_lock(LIR_OpLock* op) {
|
||||||
Register obj = op->obj_opr()->as_register(); // may not be an oop
|
Register obj = op->obj_opr()->as_register(); // may not be an oop
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -932,6 +932,81 @@ void LIRGenerator::do_ArrayCopy(Intrinsic* x) {
|
|||||||
__ arraycopy(src.result(), src_pos.result(), dst.result(), dst_pos.result(), length.result(), tmp, expected_type, flags, info); // does add_safepoint
|
__ arraycopy(src.result(), src_pos.result(), dst.result(), dst_pos.result(), length.result(), tmp, expected_type, flags, info); // does add_safepoint
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LIRGenerator::do_update_CRC32(Intrinsic* x) {
|
||||||
|
assert(UseCRC32Intrinsics, "need AVX and LCMUL instructions support");
|
||||||
|
// Make all state_for calls early since they can emit code
|
||||||
|
LIR_Opr result = rlock_result(x);
|
||||||
|
int flags = 0;
|
||||||
|
switch (x->id()) {
|
||||||
|
case vmIntrinsics::_updateCRC32: {
|
||||||
|
LIRItem crc(x->argument_at(0), this);
|
||||||
|
LIRItem val(x->argument_at(1), this);
|
||||||
|
crc.load_item();
|
||||||
|
val.load_item();
|
||||||
|
__ update_crc32(crc.result(), val.result(), result);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case vmIntrinsics::_updateBytesCRC32:
|
||||||
|
case vmIntrinsics::_updateByteBufferCRC32: {
|
||||||
|
bool is_updateBytes = (x->id() == vmIntrinsics::_updateBytesCRC32);
|
||||||
|
|
||||||
|
LIRItem crc(x->argument_at(0), this);
|
||||||
|
LIRItem buf(x->argument_at(1), this);
|
||||||
|
LIRItem off(x->argument_at(2), this);
|
||||||
|
LIRItem len(x->argument_at(3), this);
|
||||||
|
buf.load_item();
|
||||||
|
off.load_nonconstant();
|
||||||
|
|
||||||
|
LIR_Opr index = off.result();
|
||||||
|
int offset = is_updateBytes ? arrayOopDesc::base_offset_in_bytes(T_BYTE) : 0;
|
||||||
|
if(off.result()->is_constant()) {
|
||||||
|
index = LIR_OprFact::illegalOpr;
|
||||||
|
offset += off.result()->as_jint();
|
||||||
|
}
|
||||||
|
LIR_Opr base_op = buf.result();
|
||||||
|
|
||||||
|
#ifndef _LP64
|
||||||
|
if (!is_updateBytes) { // long b raw address
|
||||||
|
base_op = new_register(T_INT);
|
||||||
|
__ convert(Bytecodes::_l2i, buf.result(), base_op);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
if (index->is_valid()) {
|
||||||
|
LIR_Opr tmp = new_register(T_LONG);
|
||||||
|
__ convert(Bytecodes::_i2l, index, tmp);
|
||||||
|
index = tmp;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
LIR_Address* a = new LIR_Address(base_op,
|
||||||
|
index,
|
||||||
|
LIR_Address::times_1,
|
||||||
|
offset,
|
||||||
|
T_BYTE);
|
||||||
|
BasicTypeList signature(3);
|
||||||
|
signature.append(T_INT);
|
||||||
|
signature.append(T_ADDRESS);
|
||||||
|
signature.append(T_INT);
|
||||||
|
CallingConvention* cc = frame_map()->c_calling_convention(&signature);
|
||||||
|
const LIR_Opr result_reg = result_register_for(x->type());
|
||||||
|
|
||||||
|
LIR_Opr addr = new_pointer_register();
|
||||||
|
__ leal(LIR_OprFact::address(a), addr);
|
||||||
|
|
||||||
|
crc.load_item_force(cc->at(0));
|
||||||
|
__ move(addr, cc->at(1));
|
||||||
|
len.load_item_force(cc->at(2));
|
||||||
|
|
||||||
|
__ call_runtime_leaf(StubRoutines::updateBytesCRC32(), getThreadTemp(), result_reg, cc->args());
|
||||||
|
__ move(result_reg, result);
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default: {
|
||||||
|
ShouldNotReachHere();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// _i2l, _i2f, _i2d, _l2i, _l2f, _l2d, _f2i, _f2l, _f2d, _d2i, _d2l, _d2f
|
// _i2l, _i2f, _i2d, _l2i, _l2f, _l2d, _f2i, _f2l, _f2d, _d2i, _d2l, _d2f
|
||||||
// _i2b, _i2c, _i2s
|
// _i2b, _i2c, _i2s
|
||||||
|
@ -51,6 +51,7 @@ define_pd_global(intx, ReservedCodeCacheSize, 32*M );
|
|||||||
define_pd_global(bool, ProfileInterpreter, false);
|
define_pd_global(bool, ProfileInterpreter, false);
|
||||||
define_pd_global(intx, CodeCacheExpansionSize, 32*K );
|
define_pd_global(intx, CodeCacheExpansionSize, 32*K );
|
||||||
define_pd_global(uintx, CodeCacheMinBlockLength, 1);
|
define_pd_global(uintx, CodeCacheMinBlockLength, 1);
|
||||||
|
define_pd_global(uintx, CodeCacheMinimumUseSpace, 400*K);
|
||||||
define_pd_global(uintx, MetaspaceSize, 12*M );
|
define_pd_global(uintx, MetaspaceSize, 12*M );
|
||||||
define_pd_global(bool, NeverActAsServerClassMachine, true );
|
define_pd_global(bool, NeverActAsServerClassMachine, true );
|
||||||
define_pd_global(uint64_t,MaxRAM, 1ULL*G);
|
define_pd_global(uint64_t,MaxRAM, 1ULL*G);
|
||||||
|
@ -86,6 +86,7 @@ define_pd_global(bool, OptoBundling, false);
|
|||||||
|
|
||||||
define_pd_global(intx, ReservedCodeCacheSize, 48*M);
|
define_pd_global(intx, ReservedCodeCacheSize, 48*M);
|
||||||
define_pd_global(uintx, CodeCacheMinBlockLength, 4);
|
define_pd_global(uintx, CodeCacheMinBlockLength, 4);
|
||||||
|
define_pd_global(uintx, CodeCacheMinimumUseSpace, 400*K);
|
||||||
|
|
||||||
// Heap related flags
|
// Heap related flags
|
||||||
define_pd_global(uintx,MetaspaceSize, ScaleForWordSize(16*M));
|
define_pd_global(uintx,MetaspaceSize, ScaleForWordSize(16*M));
|
||||||
|
@ -96,6 +96,9 @@ define_pd_global(uintx, CMSYoungGenPerWorker, 64*M); // default max size of CMS
|
|||||||
product(intx, UseAVX, 99, \
|
product(intx, UseAVX, 99, \
|
||||||
"Highest supported AVX instructions set on x86/x64") \
|
"Highest supported AVX instructions set on x86/x64") \
|
||||||
\
|
\
|
||||||
|
product(bool, UseCLMUL, false, \
|
||||||
|
"Control whether CLMUL instructions can be used on x86/x64") \
|
||||||
|
\
|
||||||
diagnostic(bool, UseIncDec, true, \
|
diagnostic(bool, UseIncDec, true, \
|
||||||
"Use INC, DEC instructions on x86") \
|
"Use INC, DEC instructions on x86") \
|
||||||
\
|
\
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -39,6 +39,8 @@
|
|||||||
address generate_empty_entry(void);
|
address generate_empty_entry(void);
|
||||||
address generate_accessor_entry(void);
|
address generate_accessor_entry(void);
|
||||||
address generate_Reference_get_entry();
|
address generate_Reference_get_entry();
|
||||||
|
address generate_CRC32_update_entry();
|
||||||
|
address generate_CRC32_updateBytes_entry(AbstractInterpreter::MethodKind kind);
|
||||||
void lock_method(void);
|
void lock_method(void);
|
||||||
void generate_stack_overflow_check(void);
|
void generate_stack_overflow_check(void);
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -2794,6 +2794,15 @@ void MacroAssembler::movdqu(XMMRegister dst, AddressLiteral src) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MacroAssembler::movdqa(XMMRegister dst, AddressLiteral src) {
|
||||||
|
if (reachable(src)) {
|
||||||
|
Assembler::movdqa(dst, as_Address(src));
|
||||||
|
} else {
|
||||||
|
lea(rscratch1, src);
|
||||||
|
Assembler::movdqa(dst, Address(rscratch1, 0));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MacroAssembler::movsd(XMMRegister dst, AddressLiteral src) {
|
void MacroAssembler::movsd(XMMRegister dst, AddressLiteral src) {
|
||||||
if (reachable(src)) {
|
if (reachable(src)) {
|
||||||
Assembler::movsd(dst, as_Address(src));
|
Assembler::movsd(dst, as_Address(src));
|
||||||
@ -6388,6 +6397,193 @@ void MacroAssembler::encode_iso_array(Register src, Register dst, Register len,
|
|||||||
bind(L_done);
|
bind(L_done);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Emits code to update CRC-32 with a byte value according to constants in table
|
||||||
|
*
|
||||||
|
* @param [in,out]crc Register containing the crc.
|
||||||
|
* @param [in]val Register containing the byte to fold into the CRC.
|
||||||
|
* @param [in]table Register containing the table of crc constants.
|
||||||
|
*
|
||||||
|
* uint32_t crc;
|
||||||
|
* val = crc_table[(val ^ crc) & 0xFF];
|
||||||
|
* crc = val ^ (crc >> 8);
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
void MacroAssembler::update_byte_crc32(Register crc, Register val, Register table) {
|
||||||
|
xorl(val, crc);
|
||||||
|
andl(val, 0xFF);
|
||||||
|
shrl(crc, 8); // unsigned shift
|
||||||
|
xorl(crc, Address(table, val, Address::times_4, 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fold 128-bit data chunk
|
||||||
|
*/
|
||||||
|
void MacroAssembler::fold_128bit_crc32(XMMRegister xcrc, XMMRegister xK, XMMRegister xtmp, Register buf, int offset) {
|
||||||
|
vpclmulhdq(xtmp, xK, xcrc); // [123:64]
|
||||||
|
vpclmulldq(xcrc, xK, xcrc); // [63:0]
|
||||||
|
vpxor(xcrc, xcrc, Address(buf, offset), false /* vector256 */);
|
||||||
|
pxor(xcrc, xtmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
void MacroAssembler::fold_128bit_crc32(XMMRegister xcrc, XMMRegister xK, XMMRegister xtmp, XMMRegister xbuf) {
|
||||||
|
vpclmulhdq(xtmp, xK, xcrc);
|
||||||
|
vpclmulldq(xcrc, xK, xcrc);
|
||||||
|
pxor(xcrc, xbuf);
|
||||||
|
pxor(xcrc, xtmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 8-bit folds to compute 32-bit CRC
|
||||||
|
*
|
||||||
|
* uint64_t xcrc;
|
||||||
|
* timesXtoThe32[xcrc & 0xFF] ^ (xcrc >> 8);
|
||||||
|
*/
|
||||||
|
void MacroAssembler::fold_8bit_crc32(XMMRegister xcrc, Register table, XMMRegister xtmp, Register tmp) {
|
||||||
|
movdl(tmp, xcrc);
|
||||||
|
andl(tmp, 0xFF);
|
||||||
|
movdl(xtmp, Address(table, tmp, Address::times_4, 0));
|
||||||
|
psrldq(xcrc, 1); // unsigned shift one byte
|
||||||
|
pxor(xcrc, xtmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* uint32_t crc;
|
||||||
|
* timesXtoThe32[crc & 0xFF] ^ (crc >> 8);
|
||||||
|
*/
|
||||||
|
void MacroAssembler::fold_8bit_crc32(Register crc, Register table, Register tmp) {
|
||||||
|
movl(tmp, crc);
|
||||||
|
andl(tmp, 0xFF);
|
||||||
|
shrl(crc, 8);
|
||||||
|
xorl(crc, Address(table, tmp, Address::times_4, 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param crc register containing existing CRC (32-bit)
|
||||||
|
* @param buf register pointing to input byte buffer (byte*)
|
||||||
|
* @param len register containing number of bytes
|
||||||
|
* @param table register that will contain address of CRC table
|
||||||
|
* @param tmp scratch register
|
||||||
|
*/
|
||||||
|
void MacroAssembler::kernel_crc32(Register crc, Register buf, Register len, Register table, Register tmp) {
|
||||||
|
assert_different_registers(crc, buf, len, table, tmp, rax);
|
||||||
|
|
||||||
|
Label L_tail, L_tail_restore, L_tail_loop, L_exit, L_align_loop, L_aligned;
|
||||||
|
Label L_fold_tail, L_fold_128b, L_fold_512b, L_fold_512b_loop, L_fold_tail_loop;
|
||||||
|
|
||||||
|
lea(table, ExternalAddress(StubRoutines::crc_table_addr()));
|
||||||
|
notl(crc); // ~crc
|
||||||
|
cmpl(len, 16);
|
||||||
|
jcc(Assembler::less, L_tail);
|
||||||
|
|
||||||
|
// Align buffer to 16 bytes
|
||||||
|
movl(tmp, buf);
|
||||||
|
andl(tmp, 0xF);
|
||||||
|
jccb(Assembler::zero, L_aligned);
|
||||||
|
subl(tmp, 16);
|
||||||
|
addl(len, tmp);
|
||||||
|
|
||||||
|
align(4);
|
||||||
|
BIND(L_align_loop);
|
||||||
|
movsbl(rax, Address(buf, 0)); // load byte with sign extension
|
||||||
|
update_byte_crc32(crc, rax, table);
|
||||||
|
increment(buf);
|
||||||
|
incrementl(tmp);
|
||||||
|
jccb(Assembler::less, L_align_loop);
|
||||||
|
|
||||||
|
BIND(L_aligned);
|
||||||
|
movl(tmp, len); // save
|
||||||
|
shrl(len, 4);
|
||||||
|
jcc(Assembler::zero, L_tail_restore);
|
||||||
|
|
||||||
|
// Fold crc into first bytes of vector
|
||||||
|
movdqa(xmm1, Address(buf, 0));
|
||||||
|
movdl(rax, xmm1);
|
||||||
|
xorl(crc, rax);
|
||||||
|
pinsrd(xmm1, crc, 0);
|
||||||
|
addptr(buf, 16);
|
||||||
|
subl(len, 4); // len > 0
|
||||||
|
jcc(Assembler::less, L_fold_tail);
|
||||||
|
|
||||||
|
movdqa(xmm2, Address(buf, 0));
|
||||||
|
movdqa(xmm3, Address(buf, 16));
|
||||||
|
movdqa(xmm4, Address(buf, 32));
|
||||||
|
addptr(buf, 48);
|
||||||
|
subl(len, 3);
|
||||||
|
jcc(Assembler::lessEqual, L_fold_512b);
|
||||||
|
|
||||||
|
// Fold total 512 bits of polynomial on each iteration,
|
||||||
|
// 128 bits per each of 4 parallel streams.
|
||||||
|
movdqu(xmm0, ExternalAddress(StubRoutines::x86::crc_by128_masks_addr() + 32));
|
||||||
|
|
||||||
|
align(32);
|
||||||
|
BIND(L_fold_512b_loop);
|
||||||
|
fold_128bit_crc32(xmm1, xmm0, xmm5, buf, 0);
|
||||||
|
fold_128bit_crc32(xmm2, xmm0, xmm5, buf, 16);
|
||||||
|
fold_128bit_crc32(xmm3, xmm0, xmm5, buf, 32);
|
||||||
|
fold_128bit_crc32(xmm4, xmm0, xmm5, buf, 48);
|
||||||
|
addptr(buf, 64);
|
||||||
|
subl(len, 4);
|
||||||
|
jcc(Assembler::greater, L_fold_512b_loop);
|
||||||
|
|
||||||
|
// Fold 512 bits to 128 bits.
|
||||||
|
BIND(L_fold_512b);
|
||||||
|
movdqu(xmm0, ExternalAddress(StubRoutines::x86::crc_by128_masks_addr() + 16));
|
||||||
|
fold_128bit_crc32(xmm1, xmm0, xmm5, xmm2);
|
||||||
|
fold_128bit_crc32(xmm1, xmm0, xmm5, xmm3);
|
||||||
|
fold_128bit_crc32(xmm1, xmm0, xmm5, xmm4);
|
||||||
|
|
||||||
|
// Fold the rest of 128 bits data chunks
|
||||||
|
BIND(L_fold_tail);
|
||||||
|
addl(len, 3);
|
||||||
|
jccb(Assembler::lessEqual, L_fold_128b);
|
||||||
|
movdqu(xmm0, ExternalAddress(StubRoutines::x86::crc_by128_masks_addr() + 16));
|
||||||
|
|
||||||
|
BIND(L_fold_tail_loop);
|
||||||
|
fold_128bit_crc32(xmm1, xmm0, xmm5, buf, 0);
|
||||||
|
addptr(buf, 16);
|
||||||
|
decrementl(len);
|
||||||
|
jccb(Assembler::greater, L_fold_tail_loop);
|
||||||
|
|
||||||
|
// Fold 128 bits in xmm1 down into 32 bits in crc register.
|
||||||
|
BIND(L_fold_128b);
|
||||||
|
movdqu(xmm0, ExternalAddress(StubRoutines::x86::crc_by128_masks_addr()));
|
||||||
|
vpclmulqdq(xmm2, xmm0, xmm1, 0x1);
|
||||||
|
vpand(xmm3, xmm0, xmm2, false /* vector256 */);
|
||||||
|
vpclmulqdq(xmm0, xmm0, xmm3, 0x1);
|
||||||
|
psrldq(xmm1, 8);
|
||||||
|
psrldq(xmm2, 4);
|
||||||
|
pxor(xmm0, xmm1);
|
||||||
|
pxor(xmm0, xmm2);
|
||||||
|
|
||||||
|
// 8 8-bit folds to compute 32-bit CRC.
|
||||||
|
for (int j = 0; j < 4; j++) {
|
||||||
|
fold_8bit_crc32(xmm0, table, xmm1, rax);
|
||||||
|
}
|
||||||
|
movdl(crc, xmm0); // mov 32 bits to general register
|
||||||
|
for (int j = 0; j < 4; j++) {
|
||||||
|
fold_8bit_crc32(crc, table, rax);
|
||||||
|
}
|
||||||
|
|
||||||
|
BIND(L_tail_restore);
|
||||||
|
movl(len, tmp); // restore
|
||||||
|
BIND(L_tail);
|
||||||
|
andl(len, 0xf);
|
||||||
|
jccb(Assembler::zero, L_exit);
|
||||||
|
|
||||||
|
// Fold the rest of bytes
|
||||||
|
align(4);
|
||||||
|
BIND(L_tail_loop);
|
||||||
|
movsbl(rax, Address(buf, 0)); // load byte with sign extension
|
||||||
|
update_byte_crc32(crc, rax, table);
|
||||||
|
increment(buf);
|
||||||
|
decrementl(len);
|
||||||
|
jccb(Assembler::greater, L_tail_loop);
|
||||||
|
|
||||||
|
BIND(L_exit);
|
||||||
|
notl(crc); // ~c
|
||||||
|
}
|
||||||
|
|
||||||
#undef BIND
|
#undef BIND
|
||||||
#undef BLOCK_COMMENT
|
#undef BLOCK_COMMENT
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -899,6 +899,11 @@ public:
|
|||||||
void movdqu(XMMRegister dst, XMMRegister src) { Assembler::movdqu(dst, src); }
|
void movdqu(XMMRegister dst, XMMRegister src) { Assembler::movdqu(dst, src); }
|
||||||
void movdqu(XMMRegister dst, AddressLiteral src);
|
void movdqu(XMMRegister dst, AddressLiteral src);
|
||||||
|
|
||||||
|
// Move Aligned Double Quadword
|
||||||
|
void movdqa(XMMRegister dst, Address src) { Assembler::movdqa(dst, src); }
|
||||||
|
void movdqa(XMMRegister dst, XMMRegister src) { Assembler::movdqa(dst, src); }
|
||||||
|
void movdqa(XMMRegister dst, AddressLiteral src);
|
||||||
|
|
||||||
void movsd(XMMRegister dst, XMMRegister src) { Assembler::movsd(dst, src); }
|
void movsd(XMMRegister dst, XMMRegister src) { Assembler::movsd(dst, src); }
|
||||||
void movsd(Address dst, XMMRegister src) { Assembler::movsd(dst, src); }
|
void movsd(Address dst, XMMRegister src) { Assembler::movsd(dst, src); }
|
||||||
void movsd(XMMRegister dst, Address src) { Assembler::movsd(dst, src); }
|
void movsd(XMMRegister dst, Address src) { Assembler::movsd(dst, src); }
|
||||||
@ -1027,6 +1032,16 @@ public:
|
|||||||
Assembler::vinsertf128h(dst, nds, src);
|
Assembler::vinsertf128h(dst, nds, src);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Carry-Less Multiplication Quadword
|
||||||
|
void vpclmulldq(XMMRegister dst, XMMRegister nds, XMMRegister src) {
|
||||||
|
// 0x00 - multiply lower 64 bits [0:63]
|
||||||
|
Assembler::vpclmulqdq(dst, nds, src, 0x00);
|
||||||
|
}
|
||||||
|
void vpclmulhdq(XMMRegister dst, XMMRegister nds, XMMRegister src) {
|
||||||
|
// 0x11 - multiply upper 64 bits [64:127]
|
||||||
|
Assembler::vpclmulqdq(dst, nds, src, 0x11);
|
||||||
|
}
|
||||||
|
|
||||||
// Data
|
// Data
|
||||||
|
|
||||||
void cmov32( Condition cc, Register dst, Address src);
|
void cmov32( Condition cc, Register dst, Address src);
|
||||||
@ -1143,6 +1158,16 @@ public:
|
|||||||
XMMRegister tmp1, XMMRegister tmp2, XMMRegister tmp3,
|
XMMRegister tmp1, XMMRegister tmp2, XMMRegister tmp3,
|
||||||
XMMRegister tmp4, Register tmp5, Register result);
|
XMMRegister tmp4, Register tmp5, Register result);
|
||||||
|
|
||||||
|
// CRC32 code for java.util.zip.CRC32::updateBytes() instrinsic.
|
||||||
|
void update_byte_crc32(Register crc, Register val, Register table);
|
||||||
|
void kernel_crc32(Register crc, Register buf, Register len, Register table, Register tmp);
|
||||||
|
// Fold 128-bit data chunk
|
||||||
|
void fold_128bit_crc32(XMMRegister xcrc, XMMRegister xK, XMMRegister xtmp, Register buf, int offset);
|
||||||
|
void fold_128bit_crc32(XMMRegister xcrc, XMMRegister xK, XMMRegister xtmp, XMMRegister xbuf);
|
||||||
|
// Fold 8-bit data
|
||||||
|
void fold_8bit_crc32(Register crc, Register table, Register tmp);
|
||||||
|
void fold_8bit_crc32(XMMRegister crc, Register table, XMMRegister xtmp, Register tmp);
|
||||||
|
|
||||||
#undef VIRTUAL
|
#undef VIRTUAL
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -2713,6 +2713,59 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
return start;
|
return start;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Arguments:
|
||||||
|
*
|
||||||
|
* Inputs:
|
||||||
|
* rsp(4) - int crc
|
||||||
|
* rsp(8) - byte* buf
|
||||||
|
* rsp(12) - int length
|
||||||
|
*
|
||||||
|
* Ouput:
|
||||||
|
* rax - int crc result
|
||||||
|
*/
|
||||||
|
address generate_updateBytesCRC32() {
|
||||||
|
assert(UseCRC32Intrinsics, "need AVX and CLMUL instructions");
|
||||||
|
|
||||||
|
__ align(CodeEntryAlignment);
|
||||||
|
StubCodeMark mark(this, "StubRoutines", "updateBytesCRC32");
|
||||||
|
|
||||||
|
address start = __ pc();
|
||||||
|
|
||||||
|
const Register crc = rdx; // crc
|
||||||
|
const Register buf = rsi; // source java byte array address
|
||||||
|
const Register len = rcx; // length
|
||||||
|
const Register table = rdi; // crc_table address (reuse register)
|
||||||
|
const Register tmp = rbx;
|
||||||
|
assert_different_registers(crc, buf, len, table, tmp, rax);
|
||||||
|
|
||||||
|
BLOCK_COMMENT("Entry:");
|
||||||
|
__ enter(); // required for proper stackwalking of RuntimeStub frame
|
||||||
|
__ push(rsi);
|
||||||
|
__ push(rdi);
|
||||||
|
__ push(rbx);
|
||||||
|
|
||||||
|
Address crc_arg(rbp, 8 + 0);
|
||||||
|
Address buf_arg(rbp, 8 + 4);
|
||||||
|
Address len_arg(rbp, 8 + 8);
|
||||||
|
|
||||||
|
// Load up:
|
||||||
|
__ movl(crc, crc_arg);
|
||||||
|
__ movptr(buf, buf_arg);
|
||||||
|
__ movl(len, len_arg);
|
||||||
|
|
||||||
|
__ kernel_crc32(crc, buf, len, table, tmp);
|
||||||
|
|
||||||
|
__ movl(rax, crc);
|
||||||
|
__ pop(rbx);
|
||||||
|
__ pop(rdi);
|
||||||
|
__ pop(rsi);
|
||||||
|
__ leave(); // required for proper stackwalking of RuntimeStub frame
|
||||||
|
__ ret(0);
|
||||||
|
|
||||||
|
return start;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// Information about frame layout at time of blocking runtime call.
|
// Information about frame layout at time of blocking runtime call.
|
||||||
@ -2887,6 +2940,12 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
|
|
||||||
// Build this early so it's available for the interpreter
|
// Build this early so it's available for the interpreter
|
||||||
StubRoutines::_throw_StackOverflowError_entry = generate_throw_exception("StackOverflowError throw_exception", CAST_FROM_FN_PTR(address, SharedRuntime::throw_StackOverflowError));
|
StubRoutines::_throw_StackOverflowError_entry = generate_throw_exception("StackOverflowError throw_exception", CAST_FROM_FN_PTR(address, SharedRuntime::throw_StackOverflowError));
|
||||||
|
|
||||||
|
if (UseCRC32Intrinsics) {
|
||||||
|
// set table address before stub generation which use it
|
||||||
|
StubRoutines::_crc_table_adr = (address)StubRoutines::x86::_crc_table;
|
||||||
|
StubRoutines::_updateBytesCRC32 = generate_updateBytesCRC32();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -3584,7 +3584,45 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
return start;
|
return start;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Arguments:
|
||||||
|
*
|
||||||
|
* Inputs:
|
||||||
|
* c_rarg0 - int crc
|
||||||
|
* c_rarg1 - byte* buf
|
||||||
|
* c_rarg2 - int length
|
||||||
|
*
|
||||||
|
* Ouput:
|
||||||
|
* rax - int crc result
|
||||||
|
*/
|
||||||
|
address generate_updateBytesCRC32() {
|
||||||
|
assert(UseCRC32Intrinsics, "need AVX and CLMUL instructions");
|
||||||
|
|
||||||
|
__ align(CodeEntryAlignment);
|
||||||
|
StubCodeMark mark(this, "StubRoutines", "updateBytesCRC32");
|
||||||
|
|
||||||
|
address start = __ pc();
|
||||||
|
// Win64: rcx, rdx, r8, r9 (c_rarg0, c_rarg1, ...)
|
||||||
|
// Unix: rdi, rsi, rdx, rcx, r8, r9 (c_rarg0, c_rarg1, ...)
|
||||||
|
// rscratch1: r10
|
||||||
|
const Register crc = c_rarg0; // crc
|
||||||
|
const Register buf = c_rarg1; // source java byte array address
|
||||||
|
const Register len = c_rarg2; // length
|
||||||
|
const Register table = c_rarg3; // crc_table address (reuse register)
|
||||||
|
const Register tmp = r11;
|
||||||
|
assert_different_registers(crc, buf, len, table, tmp, rax);
|
||||||
|
|
||||||
|
BLOCK_COMMENT("Entry:");
|
||||||
|
__ enter(); // required for proper stackwalking of RuntimeStub frame
|
||||||
|
|
||||||
|
__ kernel_crc32(crc, buf, len, table, tmp);
|
||||||
|
|
||||||
|
__ movl(rax, crc);
|
||||||
|
__ leave(); // required for proper stackwalking of RuntimeStub frame
|
||||||
|
__ ret(0);
|
||||||
|
|
||||||
|
return start;
|
||||||
|
}
|
||||||
|
|
||||||
#undef __
|
#undef __
|
||||||
#define __ masm->
|
#define __ masm->
|
||||||
@ -3736,6 +3774,11 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
CAST_FROM_FN_PTR(address,
|
CAST_FROM_FN_PTR(address,
|
||||||
SharedRuntime::
|
SharedRuntime::
|
||||||
throw_StackOverflowError));
|
throw_StackOverflowError));
|
||||||
|
if (UseCRC32Intrinsics) {
|
||||||
|
// set table address before stub generation which use it
|
||||||
|
StubRoutines::_crc_table_adr = (address)StubRoutines::x86::_crc_table;
|
||||||
|
StubRoutines::_updateBytesCRC32 = generate_updateBytesCRC32();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void generate_all() {
|
void generate_all() {
|
||||||
|
130
hotspot/src/cpu/x86/vm/stubRoutines_x86.cpp
Normal file
130
hotspot/src/cpu/x86/vm/stubRoutines_x86.cpp
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "precompiled.hpp"
|
||||||
|
#include "runtime/deoptimization.hpp"
|
||||||
|
#include "runtime/frame.inline.hpp"
|
||||||
|
#include "runtime/stubRoutines.hpp"
|
||||||
|
#include "runtime/thread.inline.hpp"
|
||||||
|
|
||||||
|
// Implementation of the platform-specific part of StubRoutines - for
|
||||||
|
// a description of how to extend it, see the stubRoutines.hpp file.
|
||||||
|
|
||||||
|
address StubRoutines::x86::_verify_mxcsr_entry = NULL;
|
||||||
|
address StubRoutines::x86::_key_shuffle_mask_addr = NULL;
|
||||||
|
|
||||||
|
uint64_t StubRoutines::x86::_crc_by128_masks[] =
|
||||||
|
{
|
||||||
|
/* The fields in this structure are arranged so that they can be
|
||||||
|
* picked up two at a time with 128-bit loads.
|
||||||
|
*
|
||||||
|
* Because of flipped bit order for this CRC polynomials
|
||||||
|
* the constant for X**N is left-shifted by 1. This is because
|
||||||
|
* a 64 x 64 polynomial multiply produces a 127-bit result
|
||||||
|
* but the highest term is always aligned to bit 0 in the container.
|
||||||
|
* Pre-shifting by one fixes this, at the cost of potentially making
|
||||||
|
* the 32-bit constant no longer fit in a 32-bit container (thus the
|
||||||
|
* use of uint64_t, though this is also the size used by the carry-
|
||||||
|
* less multiply instruction.
|
||||||
|
*
|
||||||
|
* In addition, the flipped bit order and highest-term-at-least-bit
|
||||||
|
* multiply changes the constants used. The 96-bit result will be
|
||||||
|
* aligned to the high-term end of the target 128-bit container,
|
||||||
|
* not the low-term end; that is, instead of a 512-bit or 576-bit fold,
|
||||||
|
* instead it is a 480 (=512-32) or 544 (=512+64-32) bit fold.
|
||||||
|
*
|
||||||
|
* This cause additional problems in the 128-to-64-bit reduction; see the
|
||||||
|
* code for details. By storing a mask in the otherwise unused half of
|
||||||
|
* a 128-bit constant, bits can be cleared before multiplication without
|
||||||
|
* storing and reloading. Note that staying on a 128-bit datapath means
|
||||||
|
* that some data is uselessly stored and some unused data is intersected
|
||||||
|
* with an irrelevant constant.
|
||||||
|
*/
|
||||||
|
|
||||||
|
((uint64_t) 0xffffffffUL), /* low of K_M_64 */
|
||||||
|
((uint64_t) 0xb1e6b092U << 1), /* high of K_M_64 */
|
||||||
|
((uint64_t) 0xba8ccbe8U << 1), /* low of K_160_96 */
|
||||||
|
((uint64_t) 0x6655004fU << 1), /* high of K_160_96 */
|
||||||
|
((uint64_t) 0xaa2215eaU << 1), /* low of K_544_480 */
|
||||||
|
((uint64_t) 0xe3720acbU << 1) /* high of K_544_480 */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* crc_table[] from jdk/src/share/native/java/util/zip/zlib-1.2.5/crc32.h
|
||||||
|
*/
|
||||||
|
juint StubRoutines::x86::_crc_table[] =
|
||||||
|
{
|
||||||
|
0x00000000UL, 0x77073096UL, 0xee0e612cUL, 0x990951baUL, 0x076dc419UL,
|
||||||
|
0x706af48fUL, 0xe963a535UL, 0x9e6495a3UL, 0x0edb8832UL, 0x79dcb8a4UL,
|
||||||
|
0xe0d5e91eUL, 0x97d2d988UL, 0x09b64c2bUL, 0x7eb17cbdUL, 0xe7b82d07UL,
|
||||||
|
0x90bf1d91UL, 0x1db71064UL, 0x6ab020f2UL, 0xf3b97148UL, 0x84be41deUL,
|
||||||
|
0x1adad47dUL, 0x6ddde4ebUL, 0xf4d4b551UL, 0x83d385c7UL, 0x136c9856UL,
|
||||||
|
0x646ba8c0UL, 0xfd62f97aUL, 0x8a65c9ecUL, 0x14015c4fUL, 0x63066cd9UL,
|
||||||
|
0xfa0f3d63UL, 0x8d080df5UL, 0x3b6e20c8UL, 0x4c69105eUL, 0xd56041e4UL,
|
||||||
|
0xa2677172UL, 0x3c03e4d1UL, 0x4b04d447UL, 0xd20d85fdUL, 0xa50ab56bUL,
|
||||||
|
0x35b5a8faUL, 0x42b2986cUL, 0xdbbbc9d6UL, 0xacbcf940UL, 0x32d86ce3UL,
|
||||||
|
0x45df5c75UL, 0xdcd60dcfUL, 0xabd13d59UL, 0x26d930acUL, 0x51de003aUL,
|
||||||
|
0xc8d75180UL, 0xbfd06116UL, 0x21b4f4b5UL, 0x56b3c423UL, 0xcfba9599UL,
|
||||||
|
0xb8bda50fUL, 0x2802b89eUL, 0x5f058808UL, 0xc60cd9b2UL, 0xb10be924UL,
|
||||||
|
0x2f6f7c87UL, 0x58684c11UL, 0xc1611dabUL, 0xb6662d3dUL, 0x76dc4190UL,
|
||||||
|
0x01db7106UL, 0x98d220bcUL, 0xefd5102aUL, 0x71b18589UL, 0x06b6b51fUL,
|
||||||
|
0x9fbfe4a5UL, 0xe8b8d433UL, 0x7807c9a2UL, 0x0f00f934UL, 0x9609a88eUL,
|
||||||
|
0xe10e9818UL, 0x7f6a0dbbUL, 0x086d3d2dUL, 0x91646c97UL, 0xe6635c01UL,
|
||||||
|
0x6b6b51f4UL, 0x1c6c6162UL, 0x856530d8UL, 0xf262004eUL, 0x6c0695edUL,
|
||||||
|
0x1b01a57bUL, 0x8208f4c1UL, 0xf50fc457UL, 0x65b0d9c6UL, 0x12b7e950UL,
|
||||||
|
0x8bbeb8eaUL, 0xfcb9887cUL, 0x62dd1ddfUL, 0x15da2d49UL, 0x8cd37cf3UL,
|
||||||
|
0xfbd44c65UL, 0x4db26158UL, 0x3ab551ceUL, 0xa3bc0074UL, 0xd4bb30e2UL,
|
||||||
|
0x4adfa541UL, 0x3dd895d7UL, 0xa4d1c46dUL, 0xd3d6f4fbUL, 0x4369e96aUL,
|
||||||
|
0x346ed9fcUL, 0xad678846UL, 0xda60b8d0UL, 0x44042d73UL, 0x33031de5UL,
|
||||||
|
0xaa0a4c5fUL, 0xdd0d7cc9UL, 0x5005713cUL, 0x270241aaUL, 0xbe0b1010UL,
|
||||||
|
0xc90c2086UL, 0x5768b525UL, 0x206f85b3UL, 0xb966d409UL, 0xce61e49fUL,
|
||||||
|
0x5edef90eUL, 0x29d9c998UL, 0xb0d09822UL, 0xc7d7a8b4UL, 0x59b33d17UL,
|
||||||
|
0x2eb40d81UL, 0xb7bd5c3bUL, 0xc0ba6cadUL, 0xedb88320UL, 0x9abfb3b6UL,
|
||||||
|
0x03b6e20cUL, 0x74b1d29aUL, 0xead54739UL, 0x9dd277afUL, 0x04db2615UL,
|
||||||
|
0x73dc1683UL, 0xe3630b12UL, 0x94643b84UL, 0x0d6d6a3eUL, 0x7a6a5aa8UL,
|
||||||
|
0xe40ecf0bUL, 0x9309ff9dUL, 0x0a00ae27UL, 0x7d079eb1UL, 0xf00f9344UL,
|
||||||
|
0x8708a3d2UL, 0x1e01f268UL, 0x6906c2feUL, 0xf762575dUL, 0x806567cbUL,
|
||||||
|
0x196c3671UL, 0x6e6b06e7UL, 0xfed41b76UL, 0x89d32be0UL, 0x10da7a5aUL,
|
||||||
|
0x67dd4accUL, 0xf9b9df6fUL, 0x8ebeeff9UL, 0x17b7be43UL, 0x60b08ed5UL,
|
||||||
|
0xd6d6a3e8UL, 0xa1d1937eUL, 0x38d8c2c4UL, 0x4fdff252UL, 0xd1bb67f1UL,
|
||||||
|
0xa6bc5767UL, 0x3fb506ddUL, 0x48b2364bUL, 0xd80d2bdaUL, 0xaf0a1b4cUL,
|
||||||
|
0x36034af6UL, 0x41047a60UL, 0xdf60efc3UL, 0xa867df55UL, 0x316e8eefUL,
|
||||||
|
0x4669be79UL, 0xcb61b38cUL, 0xbc66831aUL, 0x256fd2a0UL, 0x5268e236UL,
|
||||||
|
0xcc0c7795UL, 0xbb0b4703UL, 0x220216b9UL, 0x5505262fUL, 0xc5ba3bbeUL,
|
||||||
|
0xb2bd0b28UL, 0x2bb45a92UL, 0x5cb36a04UL, 0xc2d7ffa7UL, 0xb5d0cf31UL,
|
||||||
|
0x2cd99e8bUL, 0x5bdeae1dUL, 0x9b64c2b0UL, 0xec63f226UL, 0x756aa39cUL,
|
||||||
|
0x026d930aUL, 0x9c0906a9UL, 0xeb0e363fUL, 0x72076785UL, 0x05005713UL,
|
||||||
|
0x95bf4a82UL, 0xe2b87a14UL, 0x7bb12baeUL, 0x0cb61b38UL, 0x92d28e9bUL,
|
||||||
|
0xe5d5be0dUL, 0x7cdcefb7UL, 0x0bdbdf21UL, 0x86d3d2d4UL, 0xf1d4e242UL,
|
||||||
|
0x68ddb3f8UL, 0x1fda836eUL, 0x81be16cdUL, 0xf6b9265bUL, 0x6fb077e1UL,
|
||||||
|
0x18b74777UL, 0x88085ae6UL, 0xff0f6a70UL, 0x66063bcaUL, 0x11010b5cUL,
|
||||||
|
0x8f659effUL, 0xf862ae69UL, 0x616bffd3UL, 0x166ccf45UL, 0xa00ae278UL,
|
||||||
|
0xd70dd2eeUL, 0x4e048354UL, 0x3903b3c2UL, 0xa7672661UL, 0xd06016f7UL,
|
||||||
|
0x4969474dUL, 0x3e6e77dbUL, 0xaed16a4aUL, 0xd9d65adcUL, 0x40df0b66UL,
|
||||||
|
0x37d83bf0UL, 0xa9bcae53UL, 0xdebb9ec5UL, 0x47b2cf7fUL, 0x30b5ffe9UL,
|
||||||
|
0xbdbdf21cUL, 0xcabac28aUL, 0x53b39330UL, 0x24b4a3a6UL, 0xbad03605UL,
|
||||||
|
0xcdd70693UL, 0x54de5729UL, 0x23d967bfUL, 0xb3667a2eUL, 0xc4614ab8UL,
|
||||||
|
0x5d681b02UL, 0x2a6f2b94UL, 0xb40bbe37UL, 0xc30c8ea1UL, 0x5a05df1bUL,
|
||||||
|
0x2d02ef8dUL
|
||||||
|
};
|
45
hotspot/src/cpu/x86/vm/stubRoutines_x86.hpp
Normal file
45
hotspot/src/cpu/x86/vm/stubRoutines_x86.hpp
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef CPU_X86_VM_STUBROUTINES_X86_HPP
|
||||||
|
#define CPU_X86_VM_STUBROUTINES_X86_HPP
|
||||||
|
|
||||||
|
// This file holds the platform specific parts of the StubRoutines
|
||||||
|
// definition. See stubRoutines.hpp for a description on how to
|
||||||
|
// extend it.
|
||||||
|
|
||||||
|
private:
|
||||||
|
static address _verify_mxcsr_entry;
|
||||||
|
// shuffle mask for fixing up 128-bit words consisting of big-endian 32-bit integers
|
||||||
|
static address _key_shuffle_mask_addr;
|
||||||
|
// masks and table for CRC32
|
||||||
|
static uint64_t _crc_by128_masks[];
|
||||||
|
static juint _crc_table[];
|
||||||
|
|
||||||
|
public:
|
||||||
|
static address verify_mxcsr_entry() { return _verify_mxcsr_entry; }
|
||||||
|
static address key_shuffle_mask_addr() { return _key_shuffle_mask_addr; }
|
||||||
|
static address crc_by128_masks_addr() { return (address)_crc_by128_masks; }
|
||||||
|
|
||||||
|
#endif // CPU_X86_VM_STUBROUTINES_X86_32_HPP
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,6 +31,4 @@
|
|||||||
// Implementation of the platform-specific part of StubRoutines - for
|
// Implementation of the platform-specific part of StubRoutines - for
|
||||||
// a description of how to extend it, see the stubRoutines.hpp file.
|
// a description of how to extend it, see the stubRoutines.hpp file.
|
||||||
|
|
||||||
address StubRoutines::x86::_verify_mxcsr_entry = NULL;
|
|
||||||
address StubRoutines::x86::_verify_fpu_cntrl_wrd_entry = NULL;
|
address StubRoutines::x86::_verify_fpu_cntrl_wrd_entry = NULL;
|
||||||
address StubRoutines::x86::_key_shuffle_mask_addr = NULL;
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -39,15 +39,12 @@ class x86 {
|
|||||||
friend class VMStructs;
|
friend class VMStructs;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static address _verify_mxcsr_entry;
|
|
||||||
static address _verify_fpu_cntrl_wrd_entry;
|
static address _verify_fpu_cntrl_wrd_entry;
|
||||||
// shuffle mask for fixing up 128-bit words consisting of big-endian 32-bit integers
|
|
||||||
static address _key_shuffle_mask_addr;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static address verify_mxcsr_entry() { return _verify_mxcsr_entry; }
|
|
||||||
static address verify_fpu_cntrl_wrd_entry() { return _verify_fpu_cntrl_wrd_entry; }
|
static address verify_fpu_cntrl_wrd_entry() { return _verify_fpu_cntrl_wrd_entry; }
|
||||||
static address key_shuffle_mask_addr() { return _key_shuffle_mask_addr; }
|
|
||||||
|
# include "stubRoutines_x86.hpp"
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -34,8 +34,6 @@
|
|||||||
address StubRoutines::x86::_get_previous_fp_entry = NULL;
|
address StubRoutines::x86::_get_previous_fp_entry = NULL;
|
||||||
address StubRoutines::x86::_get_previous_sp_entry = NULL;
|
address StubRoutines::x86::_get_previous_sp_entry = NULL;
|
||||||
|
|
||||||
address StubRoutines::x86::_verify_mxcsr_entry = NULL;
|
|
||||||
|
|
||||||
address StubRoutines::x86::_f2i_fixup = NULL;
|
address StubRoutines::x86::_f2i_fixup = NULL;
|
||||||
address StubRoutines::x86::_f2l_fixup = NULL;
|
address StubRoutines::x86::_f2l_fixup = NULL;
|
||||||
address StubRoutines::x86::_d2i_fixup = NULL;
|
address StubRoutines::x86::_d2i_fixup = NULL;
|
||||||
@ -45,4 +43,3 @@ address StubRoutines::x86::_float_sign_flip = NULL;
|
|||||||
address StubRoutines::x86::_double_sign_mask = NULL;
|
address StubRoutines::x86::_double_sign_mask = NULL;
|
||||||
address StubRoutines::x86::_double_sign_flip = NULL;
|
address StubRoutines::x86::_double_sign_flip = NULL;
|
||||||
address StubRoutines::x86::_mxcsr_std = NULL;
|
address StubRoutines::x86::_mxcsr_std = NULL;
|
||||||
address StubRoutines::x86::_key_shuffle_mask_addr = NULL;
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -42,7 +42,6 @@ class x86 {
|
|||||||
private:
|
private:
|
||||||
static address _get_previous_fp_entry;
|
static address _get_previous_fp_entry;
|
||||||
static address _get_previous_sp_entry;
|
static address _get_previous_sp_entry;
|
||||||
static address _verify_mxcsr_entry;
|
|
||||||
|
|
||||||
static address _f2i_fixup;
|
static address _f2i_fixup;
|
||||||
static address _f2l_fixup;
|
static address _f2l_fixup;
|
||||||
@ -54,8 +53,6 @@ class x86 {
|
|||||||
static address _double_sign_mask;
|
static address _double_sign_mask;
|
||||||
static address _double_sign_flip;
|
static address _double_sign_flip;
|
||||||
static address _mxcsr_std;
|
static address _mxcsr_std;
|
||||||
// shuffle mask for fixing up 128-bit words consisting of big-endian 32-bit integers
|
|
||||||
static address _key_shuffle_mask_addr;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@ -69,11 +66,6 @@ class x86 {
|
|||||||
return _get_previous_sp_entry;
|
return _get_previous_sp_entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
static address verify_mxcsr_entry()
|
|
||||||
{
|
|
||||||
return _verify_mxcsr_entry;
|
|
||||||
}
|
|
||||||
|
|
||||||
static address f2i_fixup()
|
static address f2i_fixup()
|
||||||
{
|
{
|
||||||
return _f2i_fixup;
|
return _f2i_fixup;
|
||||||
@ -119,7 +111,7 @@ class x86 {
|
|||||||
return _mxcsr_std;
|
return _mxcsr_std;
|
||||||
}
|
}
|
||||||
|
|
||||||
static address key_shuffle_mask_addr() { return _key_shuffle_mask_addr; }
|
# include "stubRoutines_x86.hpp"
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -868,6 +868,120 @@ address InterpreterGenerator::generate_Reference_get_entry(void) {
|
|||||||
return generate_accessor_entry();
|
return generate_accessor_entry();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method entry for static native methods:
|
||||||
|
* int java.util.zip.CRC32.update(int crc, int b)
|
||||||
|
*/
|
||||||
|
address InterpreterGenerator::generate_CRC32_update_entry() {
|
||||||
|
if (UseCRC32Intrinsics) {
|
||||||
|
address entry = __ pc();
|
||||||
|
|
||||||
|
// rbx,: Method*
|
||||||
|
// rsi: senderSP must preserved for slow path, set SP to it on fast path
|
||||||
|
// rdx: scratch
|
||||||
|
// rdi: scratch
|
||||||
|
|
||||||
|
Label slow_path;
|
||||||
|
// If we need a safepoint check, generate full interpreter entry.
|
||||||
|
ExternalAddress state(SafepointSynchronize::address_of_state());
|
||||||
|
__ cmp32(ExternalAddress(SafepointSynchronize::address_of_state()),
|
||||||
|
SafepointSynchronize::_not_synchronized);
|
||||||
|
__ jcc(Assembler::notEqual, slow_path);
|
||||||
|
|
||||||
|
// We don't generate local frame and don't align stack because
|
||||||
|
// we call stub code and there is no safepoint on this path.
|
||||||
|
|
||||||
|
// Load parameters
|
||||||
|
const Register crc = rax; // crc
|
||||||
|
const Register val = rdx; // source java byte value
|
||||||
|
const Register tbl = rdi; // scratch
|
||||||
|
|
||||||
|
// Arguments are reversed on java expression stack
|
||||||
|
__ movl(val, Address(rsp, wordSize)); // byte value
|
||||||
|
__ movl(crc, Address(rsp, 2*wordSize)); // Initial CRC
|
||||||
|
|
||||||
|
__ lea(tbl, ExternalAddress(StubRoutines::crc_table_addr()));
|
||||||
|
__ notl(crc); // ~crc
|
||||||
|
__ update_byte_crc32(crc, val, tbl);
|
||||||
|
__ notl(crc); // ~crc
|
||||||
|
// result in rax
|
||||||
|
|
||||||
|
// _areturn
|
||||||
|
__ pop(rdi); // get return address
|
||||||
|
__ mov(rsp, rsi); // set sp to sender sp
|
||||||
|
__ jmp(rdi);
|
||||||
|
|
||||||
|
// generate a vanilla native entry as the slow path
|
||||||
|
__ bind(slow_path);
|
||||||
|
|
||||||
|
(void) generate_native_entry(false);
|
||||||
|
|
||||||
|
return entry;
|
||||||
|
}
|
||||||
|
return generate_native_entry(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method entry for static native methods:
|
||||||
|
* int java.util.zip.CRC32.updateBytes(int crc, byte[] b, int off, int len)
|
||||||
|
* int java.util.zip.CRC32.updateByteBuffer(int crc, long buf, int off, int len)
|
||||||
|
*/
|
||||||
|
address InterpreterGenerator::generate_CRC32_updateBytes_entry(AbstractInterpreter::MethodKind kind) {
|
||||||
|
if (UseCRC32Intrinsics) {
|
||||||
|
address entry = __ pc();
|
||||||
|
|
||||||
|
// rbx,: Method*
|
||||||
|
// rsi: senderSP must preserved for slow path, set SP to it on fast path
|
||||||
|
// rdx: scratch
|
||||||
|
// rdi: scratch
|
||||||
|
|
||||||
|
Label slow_path;
|
||||||
|
// If we need a safepoint check, generate full interpreter entry.
|
||||||
|
ExternalAddress state(SafepointSynchronize::address_of_state());
|
||||||
|
__ cmp32(ExternalAddress(SafepointSynchronize::address_of_state()),
|
||||||
|
SafepointSynchronize::_not_synchronized);
|
||||||
|
__ jcc(Assembler::notEqual, slow_path);
|
||||||
|
|
||||||
|
// We don't generate local frame and don't align stack because
|
||||||
|
// we call stub code and there is no safepoint on this path.
|
||||||
|
|
||||||
|
// Load parameters
|
||||||
|
const Register crc = rax; // crc
|
||||||
|
const Register buf = rdx; // source java byte array address
|
||||||
|
const Register len = rdi; // length
|
||||||
|
|
||||||
|
// Arguments are reversed on java expression stack
|
||||||
|
__ movl(len, Address(rsp, wordSize)); // Length
|
||||||
|
// Calculate address of start element
|
||||||
|
if (kind == Interpreter::java_util_zip_CRC32_updateByteBuffer) {
|
||||||
|
__ movptr(buf, Address(rsp, 3*wordSize)); // long buf
|
||||||
|
__ addptr(buf, Address(rsp, 2*wordSize)); // + offset
|
||||||
|
__ movl(crc, Address(rsp, 5*wordSize)); // Initial CRC
|
||||||
|
} else {
|
||||||
|
__ movptr(buf, Address(rsp, 3*wordSize)); // byte[] array
|
||||||
|
__ addptr(buf, arrayOopDesc::base_offset_in_bytes(T_BYTE)); // + header size
|
||||||
|
__ addptr(buf, Address(rsp, 2*wordSize)); // + offset
|
||||||
|
__ movl(crc, Address(rsp, 4*wordSize)); // Initial CRC
|
||||||
|
}
|
||||||
|
|
||||||
|
__ super_call_VM_leaf(CAST_FROM_FN_PTR(address, StubRoutines::updateBytesCRC32()), crc, buf, len);
|
||||||
|
// result in rax
|
||||||
|
|
||||||
|
// _areturn
|
||||||
|
__ pop(rdi); // get return address
|
||||||
|
__ mov(rsp, rsi); // set sp to sender sp
|
||||||
|
__ jmp(rdi);
|
||||||
|
|
||||||
|
// generate a vanilla native entry as the slow path
|
||||||
|
__ bind(slow_path);
|
||||||
|
|
||||||
|
(void) generate_native_entry(false);
|
||||||
|
|
||||||
|
return entry;
|
||||||
|
}
|
||||||
|
return generate_native_entry(false);
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Interpreter stub for calling a native method. (asm interpreter)
|
// Interpreter stub for calling a native method. (asm interpreter)
|
||||||
// This sets up a somewhat different looking stack for calling the native method
|
// This sets up a somewhat different looking stack for calling the native method
|
||||||
@ -1501,15 +1615,16 @@ address AbstractInterpreterGenerator::generate_method_entry(AbstractInterpreter:
|
|||||||
// determine code generation flags
|
// determine code generation flags
|
||||||
bool synchronized = false;
|
bool synchronized = false;
|
||||||
address entry_point = NULL;
|
address entry_point = NULL;
|
||||||
|
InterpreterGenerator* ig_this = (InterpreterGenerator*)this;
|
||||||
|
|
||||||
switch (kind) {
|
switch (kind) {
|
||||||
case Interpreter::zerolocals : break;
|
case Interpreter::zerolocals : break;
|
||||||
case Interpreter::zerolocals_synchronized: synchronized = true; break;
|
case Interpreter::zerolocals_synchronized: synchronized = true; break;
|
||||||
case Interpreter::native : entry_point = ((InterpreterGenerator*)this)->generate_native_entry(false); break;
|
case Interpreter::native : entry_point = ig_this->generate_native_entry(false); break;
|
||||||
case Interpreter::native_synchronized : entry_point = ((InterpreterGenerator*)this)->generate_native_entry(true); break;
|
case Interpreter::native_synchronized : entry_point = ig_this->generate_native_entry(true); break;
|
||||||
case Interpreter::empty : entry_point = ((InterpreterGenerator*)this)->generate_empty_entry(); break;
|
case Interpreter::empty : entry_point = ig_this->generate_empty_entry(); break;
|
||||||
case Interpreter::accessor : entry_point = ((InterpreterGenerator*)this)->generate_accessor_entry(); break;
|
case Interpreter::accessor : entry_point = ig_this->generate_accessor_entry(); break;
|
||||||
case Interpreter::abstract : entry_point = ((InterpreterGenerator*)this)->generate_abstract_entry(); break;
|
case Interpreter::abstract : entry_point = ig_this->generate_abstract_entry(); break;
|
||||||
|
|
||||||
case Interpreter::java_lang_math_sin : // fall thru
|
case Interpreter::java_lang_math_sin : // fall thru
|
||||||
case Interpreter::java_lang_math_cos : // fall thru
|
case Interpreter::java_lang_math_cos : // fall thru
|
||||||
@ -1519,9 +1634,15 @@ address AbstractInterpreterGenerator::generate_method_entry(AbstractInterpreter:
|
|||||||
case Interpreter::java_lang_math_log10 : // fall thru
|
case Interpreter::java_lang_math_log10 : // fall thru
|
||||||
case Interpreter::java_lang_math_sqrt : // fall thru
|
case Interpreter::java_lang_math_sqrt : // fall thru
|
||||||
case Interpreter::java_lang_math_pow : // fall thru
|
case Interpreter::java_lang_math_pow : // fall thru
|
||||||
case Interpreter::java_lang_math_exp : entry_point = ((InterpreterGenerator*)this)->generate_math_entry(kind); break;
|
case Interpreter::java_lang_math_exp : entry_point = ig_this->generate_math_entry(kind); break;
|
||||||
case Interpreter::java_lang_ref_reference_get
|
case Interpreter::java_lang_ref_reference_get
|
||||||
: entry_point = ((InterpreterGenerator*)this)->generate_Reference_get_entry(); break;
|
: entry_point = ig_this->generate_Reference_get_entry(); break;
|
||||||
|
case Interpreter::java_util_zip_CRC32_update
|
||||||
|
: entry_point = ig_this->generate_CRC32_update_entry(); break;
|
||||||
|
case Interpreter::java_util_zip_CRC32_updateBytes
|
||||||
|
: // fall thru
|
||||||
|
case Interpreter::java_util_zip_CRC32_updateByteBuffer
|
||||||
|
: entry_point = ig_this->generate_CRC32_updateBytes_entry(kind); break;
|
||||||
default:
|
default:
|
||||||
fatal(err_msg("unexpected method kind: %d", kind));
|
fatal(err_msg("unexpected method kind: %d", kind));
|
||||||
break;
|
break;
|
||||||
@ -1529,7 +1650,7 @@ address AbstractInterpreterGenerator::generate_method_entry(AbstractInterpreter:
|
|||||||
|
|
||||||
if (entry_point) return entry_point;
|
if (entry_point) return entry_point;
|
||||||
|
|
||||||
return ((InterpreterGenerator*)this)->generate_normal_entry(synchronized);
|
return ig_this->generate_normal_entry(synchronized);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -840,6 +840,117 @@ address InterpreterGenerator::generate_Reference_get_entry(void) {
|
|||||||
return generate_accessor_entry();
|
return generate_accessor_entry();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method entry for static native methods:
|
||||||
|
* int java.util.zip.CRC32.update(int crc, int b)
|
||||||
|
*/
|
||||||
|
address InterpreterGenerator::generate_CRC32_update_entry() {
|
||||||
|
if (UseCRC32Intrinsics) {
|
||||||
|
address entry = __ pc();
|
||||||
|
|
||||||
|
// rbx,: Method*
|
||||||
|
// rsi: senderSP must preserved for slow path, set SP to it on fast path
|
||||||
|
// rdx: scratch
|
||||||
|
// rdi: scratch
|
||||||
|
|
||||||
|
Label slow_path;
|
||||||
|
// If we need a safepoint check, generate full interpreter entry.
|
||||||
|
ExternalAddress state(SafepointSynchronize::address_of_state());
|
||||||
|
__ cmp32(ExternalAddress(SafepointSynchronize::address_of_state()),
|
||||||
|
SafepointSynchronize::_not_synchronized);
|
||||||
|
__ jcc(Assembler::notEqual, slow_path);
|
||||||
|
|
||||||
|
// We don't generate local frame and don't align stack because
|
||||||
|
// we call stub code and there is no safepoint on this path.
|
||||||
|
|
||||||
|
// Load parameters
|
||||||
|
const Register crc = rax; // crc
|
||||||
|
const Register val = rdx; // source java byte value
|
||||||
|
const Register tbl = rdi; // scratch
|
||||||
|
|
||||||
|
// Arguments are reversed on java expression stack
|
||||||
|
__ movl(val, Address(rsp, wordSize)); // byte value
|
||||||
|
__ movl(crc, Address(rsp, 2*wordSize)); // Initial CRC
|
||||||
|
|
||||||
|
__ lea(tbl, ExternalAddress(StubRoutines::crc_table_addr()));
|
||||||
|
__ notl(crc); // ~crc
|
||||||
|
__ update_byte_crc32(crc, val, tbl);
|
||||||
|
__ notl(crc); // ~crc
|
||||||
|
// result in rax
|
||||||
|
|
||||||
|
// _areturn
|
||||||
|
__ pop(rdi); // get return address
|
||||||
|
__ mov(rsp, rsi); // set sp to sender sp
|
||||||
|
__ jmp(rdi);
|
||||||
|
|
||||||
|
// generate a vanilla native entry as the slow path
|
||||||
|
__ bind(slow_path);
|
||||||
|
|
||||||
|
(void) generate_native_entry(false);
|
||||||
|
|
||||||
|
return entry;
|
||||||
|
}
|
||||||
|
return generate_native_entry(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method entry for static native methods:
|
||||||
|
* int java.util.zip.CRC32.updateBytes(int crc, byte[] b, int off, int len)
|
||||||
|
* int java.util.zip.CRC32.updateByteBuffer(int crc, long buf, int off, int len)
|
||||||
|
*/
|
||||||
|
address InterpreterGenerator::generate_CRC32_updateBytes_entry(AbstractInterpreter::MethodKind kind) {
|
||||||
|
if (UseCRC32Intrinsics) {
|
||||||
|
address entry = __ pc();
|
||||||
|
|
||||||
|
// rbx,: Method*
|
||||||
|
// r13: senderSP must preserved for slow path, set SP to it on fast path
|
||||||
|
|
||||||
|
Label slow_path;
|
||||||
|
// If we need a safepoint check, generate full interpreter entry.
|
||||||
|
ExternalAddress state(SafepointSynchronize::address_of_state());
|
||||||
|
__ cmp32(ExternalAddress(SafepointSynchronize::address_of_state()),
|
||||||
|
SafepointSynchronize::_not_synchronized);
|
||||||
|
__ jcc(Assembler::notEqual, slow_path);
|
||||||
|
|
||||||
|
// We don't generate local frame and don't align stack because
|
||||||
|
// we call stub code and there is no safepoint on this path.
|
||||||
|
|
||||||
|
// Load parameters
|
||||||
|
const Register crc = c_rarg0; // crc
|
||||||
|
const Register buf = c_rarg1; // source java byte array address
|
||||||
|
const Register len = c_rarg2; // length
|
||||||
|
|
||||||
|
// Arguments are reversed on java expression stack
|
||||||
|
__ movl(len, Address(rsp, wordSize)); // Length
|
||||||
|
// Calculate address of start element
|
||||||
|
if (kind == Interpreter::java_util_zip_CRC32_updateByteBuffer) {
|
||||||
|
__ movptr(buf, Address(rsp, 3*wordSize)); // long buf
|
||||||
|
__ addptr(buf, Address(rsp, 2*wordSize)); // + offset
|
||||||
|
__ movl(crc, Address(rsp, 5*wordSize)); // Initial CRC
|
||||||
|
} else {
|
||||||
|
__ movptr(buf, Address(rsp, 3*wordSize)); // byte[] array
|
||||||
|
__ addptr(buf, arrayOopDesc::base_offset_in_bytes(T_BYTE)); // + header size
|
||||||
|
__ addptr(buf, Address(rsp, 2*wordSize)); // + offset
|
||||||
|
__ movl(crc, Address(rsp, 4*wordSize)); // Initial CRC
|
||||||
|
}
|
||||||
|
|
||||||
|
__ super_call_VM_leaf(CAST_FROM_FN_PTR(address, StubRoutines::updateBytesCRC32()), crc, buf, len);
|
||||||
|
// result in rax
|
||||||
|
|
||||||
|
// _areturn
|
||||||
|
__ pop(rdi); // get return address
|
||||||
|
__ mov(rsp, r13); // set sp to sender sp
|
||||||
|
__ jmp(rdi);
|
||||||
|
|
||||||
|
// generate a vanilla native entry as the slow path
|
||||||
|
__ bind(slow_path);
|
||||||
|
|
||||||
|
(void) generate_native_entry(false);
|
||||||
|
|
||||||
|
return entry;
|
||||||
|
}
|
||||||
|
return generate_native_entry(false);
|
||||||
|
}
|
||||||
|
|
||||||
// Interpreter stub for calling a native method. (asm interpreter)
|
// Interpreter stub for calling a native method. (asm interpreter)
|
||||||
// This sets up a somewhat different looking stack for calling the
|
// This sets up a somewhat different looking stack for calling the
|
||||||
@ -1510,15 +1621,16 @@ address AbstractInterpreterGenerator::generate_method_entry(
|
|||||||
// determine code generation flags
|
// determine code generation flags
|
||||||
bool synchronized = false;
|
bool synchronized = false;
|
||||||
address entry_point = NULL;
|
address entry_point = NULL;
|
||||||
|
InterpreterGenerator* ig_this = (InterpreterGenerator*)this;
|
||||||
|
|
||||||
switch (kind) {
|
switch (kind) {
|
||||||
case Interpreter::zerolocals : break;
|
case Interpreter::zerolocals : break;
|
||||||
case Interpreter::zerolocals_synchronized: synchronized = true; break;
|
case Interpreter::zerolocals_synchronized: synchronized = true; break;
|
||||||
case Interpreter::native : entry_point = ((InterpreterGenerator*)this)->generate_native_entry(false); break;
|
case Interpreter::native : entry_point = ig_this->generate_native_entry(false); break;
|
||||||
case Interpreter::native_synchronized : entry_point = ((InterpreterGenerator*)this)->generate_native_entry(true); break;
|
case Interpreter::native_synchronized : entry_point = ig_this->generate_native_entry(true); break;
|
||||||
case Interpreter::empty : entry_point = ((InterpreterGenerator*)this)->generate_empty_entry(); break;
|
case Interpreter::empty : entry_point = ig_this->generate_empty_entry(); break;
|
||||||
case Interpreter::accessor : entry_point = ((InterpreterGenerator*)this)->generate_accessor_entry(); break;
|
case Interpreter::accessor : entry_point = ig_this->generate_accessor_entry(); break;
|
||||||
case Interpreter::abstract : entry_point = ((InterpreterGenerator*)this)->generate_abstract_entry(); break;
|
case Interpreter::abstract : entry_point = ig_this->generate_abstract_entry(); break;
|
||||||
|
|
||||||
case Interpreter::java_lang_math_sin : // fall thru
|
case Interpreter::java_lang_math_sin : // fall thru
|
||||||
case Interpreter::java_lang_math_cos : // fall thru
|
case Interpreter::java_lang_math_cos : // fall thru
|
||||||
@ -1528,9 +1640,15 @@ address AbstractInterpreterGenerator::generate_method_entry(
|
|||||||
case Interpreter::java_lang_math_log10 : // fall thru
|
case Interpreter::java_lang_math_log10 : // fall thru
|
||||||
case Interpreter::java_lang_math_sqrt : // fall thru
|
case Interpreter::java_lang_math_sqrt : // fall thru
|
||||||
case Interpreter::java_lang_math_pow : // fall thru
|
case Interpreter::java_lang_math_pow : // fall thru
|
||||||
case Interpreter::java_lang_math_exp : entry_point = ((InterpreterGenerator*)this)->generate_math_entry(kind); break;
|
case Interpreter::java_lang_math_exp : entry_point = ig_this->generate_math_entry(kind); break;
|
||||||
case Interpreter::java_lang_ref_reference_get
|
case Interpreter::java_lang_ref_reference_get
|
||||||
: entry_point = ((InterpreterGenerator*)this)->generate_Reference_get_entry(); break;
|
: entry_point = ig_this->generate_Reference_get_entry(); break;
|
||||||
|
case Interpreter::java_util_zip_CRC32_update
|
||||||
|
: entry_point = ig_this->generate_CRC32_update_entry(); break;
|
||||||
|
case Interpreter::java_util_zip_CRC32_updateBytes
|
||||||
|
: // fall thru
|
||||||
|
case Interpreter::java_util_zip_CRC32_updateByteBuffer
|
||||||
|
: entry_point = ig_this->generate_CRC32_updateBytes_entry(kind); break;
|
||||||
default:
|
default:
|
||||||
fatal(err_msg("unexpected method kind: %d", kind));
|
fatal(err_msg("unexpected method kind: %d", kind));
|
||||||
break;
|
break;
|
||||||
@ -1540,8 +1658,7 @@ address AbstractInterpreterGenerator::generate_method_entry(
|
|||||||
return entry_point;
|
return entry_point;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ((InterpreterGenerator*) this)->
|
return ig_this->generate_normal_entry(synchronized);
|
||||||
generate_normal_entry(synchronized);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// These should never be compiled since the interpreter will prefer
|
// These should never be compiled since the interpreter will prefer
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -446,6 +446,7 @@ void VM_Version::get_processor_features() {
|
|||||||
(supports_avx() ? ", avx" : ""),
|
(supports_avx() ? ", avx" : ""),
|
||||||
(supports_avx2() ? ", avx2" : ""),
|
(supports_avx2() ? ", avx2" : ""),
|
||||||
(supports_aes() ? ", aes" : ""),
|
(supports_aes() ? ", aes" : ""),
|
||||||
|
(supports_clmul() ? ", clmul" : ""),
|
||||||
(supports_erms() ? ", erms" : ""),
|
(supports_erms() ? ", erms" : ""),
|
||||||
(supports_mmx_ext() ? ", mmxext" : ""),
|
(supports_mmx_ext() ? ", mmxext" : ""),
|
||||||
(supports_3dnow_prefetch() ? ", 3dnowpref" : ""),
|
(supports_3dnow_prefetch() ? ", 3dnowpref" : ""),
|
||||||
@ -489,6 +490,27 @@ void VM_Version::get_processor_features() {
|
|||||||
FLAG_SET_DEFAULT(UseAES, false);
|
FLAG_SET_DEFAULT(UseAES, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Use CLMUL instructions if available.
|
||||||
|
if (supports_clmul()) {
|
||||||
|
if (FLAG_IS_DEFAULT(UseCLMUL)) {
|
||||||
|
UseCLMUL = true;
|
||||||
|
}
|
||||||
|
} else if (UseCLMUL) {
|
||||||
|
if (!FLAG_IS_DEFAULT(UseCLMUL))
|
||||||
|
warning("CLMUL instructions not available on this CPU (AVX may also be required)");
|
||||||
|
FLAG_SET_DEFAULT(UseCLMUL, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (UseCLMUL && (UseAVX > 0) && (UseSSE > 2)) {
|
||||||
|
if (FLAG_IS_DEFAULT(UseCRC32Intrinsics)) {
|
||||||
|
UseCRC32Intrinsics = true;
|
||||||
|
}
|
||||||
|
} else if (UseCRC32Intrinsics) {
|
||||||
|
if (!FLAG_IS_DEFAULT(UseCRC32Intrinsics))
|
||||||
|
warning("CRC32 Intrinsics requires AVX and CLMUL instructions (not available on this CPU)");
|
||||||
|
FLAG_SET_DEFAULT(UseCRC32Intrinsics, false);
|
||||||
|
}
|
||||||
|
|
||||||
// The AES intrinsic stubs require AES instruction support (of course)
|
// The AES intrinsic stubs require AES instruction support (of course)
|
||||||
// but also require sse3 mode for instructions it use.
|
// but also require sse3 mode for instructions it use.
|
||||||
if (UseAES && (UseSSE > 2)) {
|
if (UseAES && (UseSSE > 2)) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -61,7 +61,8 @@ public:
|
|||||||
uint32_t value;
|
uint32_t value;
|
||||||
struct {
|
struct {
|
||||||
uint32_t sse3 : 1,
|
uint32_t sse3 : 1,
|
||||||
: 2,
|
clmul : 1,
|
||||||
|
: 1,
|
||||||
monitor : 1,
|
monitor : 1,
|
||||||
: 1,
|
: 1,
|
||||||
vmx : 1,
|
vmx : 1,
|
||||||
@ -249,7 +250,8 @@ protected:
|
|||||||
CPU_AVX = (1 << 17),
|
CPU_AVX = (1 << 17),
|
||||||
CPU_AVX2 = (1 << 18),
|
CPU_AVX2 = (1 << 18),
|
||||||
CPU_AES = (1 << 19),
|
CPU_AES = (1 << 19),
|
||||||
CPU_ERMS = (1 << 20) // enhanced 'rep movsb/stosb' instructions
|
CPU_ERMS = (1 << 20), // enhanced 'rep movsb/stosb' instructions
|
||||||
|
CPU_CLMUL = (1 << 21) // carryless multiply for CRC
|
||||||
} cpuFeatureFlags;
|
} cpuFeatureFlags;
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
@ -429,6 +431,8 @@ protected:
|
|||||||
result |= CPU_AES;
|
result |= CPU_AES;
|
||||||
if (_cpuid_info.sef_cpuid7_ebx.bits.erms != 0)
|
if (_cpuid_info.sef_cpuid7_ebx.bits.erms != 0)
|
||||||
result |= CPU_ERMS;
|
result |= CPU_ERMS;
|
||||||
|
if (_cpuid_info.std_cpuid1_ecx.bits.clmul != 0)
|
||||||
|
result |= CPU_CLMUL;
|
||||||
|
|
||||||
// AMD features.
|
// AMD features.
|
||||||
if (is_amd()) {
|
if (is_amd()) {
|
||||||
@ -555,6 +559,7 @@ public:
|
|||||||
static bool supports_tsc() { return (_cpuFeatures & CPU_TSC) != 0; }
|
static bool supports_tsc() { return (_cpuFeatures & CPU_TSC) != 0; }
|
||||||
static bool supports_aes() { return (_cpuFeatures & CPU_AES) != 0; }
|
static bool supports_aes() { return (_cpuFeatures & CPU_AES) != 0; }
|
||||||
static bool supports_erms() { return (_cpuFeatures & CPU_ERMS) != 0; }
|
static bool supports_erms() { return (_cpuFeatures & CPU_ERMS) != 0; }
|
||||||
|
static bool supports_clmul() { return (_cpuFeatures & CPU_CLMUL) != 0; }
|
||||||
|
|
||||||
// Intel features
|
// Intel features
|
||||||
static bool is_intel_family_core() { return is_intel() &&
|
static bool is_intel_family_core() { return is_intel() &&
|
||||||
|
@ -58,6 +58,8 @@ define_pd_global(intx, ReservedCodeCacheSize, 32*M );
|
|||||||
define_pd_global(bool, ProfileInterpreter, false);
|
define_pd_global(bool, ProfileInterpreter, false);
|
||||||
define_pd_global(intx, CodeCacheExpansionSize, 32*K );
|
define_pd_global(intx, CodeCacheExpansionSize, 32*K );
|
||||||
define_pd_global(uintx, CodeCacheMinBlockLength, 1 );
|
define_pd_global(uintx, CodeCacheMinBlockLength, 1 );
|
||||||
|
define_pd_global(uintx, CodeCacheMinimumUseSpace, 200*K);
|
||||||
|
|
||||||
define_pd_global(uintx, MetaspaceSize, 12*M );
|
define_pd_global(uintx, MetaspaceSize, 12*M );
|
||||||
define_pd_global(bool, NeverActAsServerClassMachine, true );
|
define_pd_global(bool, NeverActAsServerClassMachine, true );
|
||||||
define_pd_global(uint64_t, MaxRAM, 1ULL*G);
|
define_pd_global(uint64_t, MaxRAM, 1ULL*G);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -3461,6 +3461,14 @@ bool GraphBuilder::try_inline_intrinsics(ciMethod* callee) {
|
|||||||
preserves_state = true;
|
preserves_state = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case vmIntrinsics::_updateCRC32:
|
||||||
|
case vmIntrinsics::_updateBytesCRC32:
|
||||||
|
case vmIntrinsics::_updateByteBufferCRC32:
|
||||||
|
if (!UseCRC32Intrinsics) return false;
|
||||||
|
cantrap = false;
|
||||||
|
preserves_state = true;
|
||||||
|
break;
|
||||||
|
|
||||||
case vmIntrinsics::_loadFence :
|
case vmIntrinsics::_loadFence :
|
||||||
case vmIntrinsics::_storeFence:
|
case vmIntrinsics::_storeFence:
|
||||||
case vmIntrinsics::_fullFence :
|
case vmIntrinsics::_fullFence :
|
||||||
|
@ -430,6 +430,11 @@ LIR_OpArrayCopy::LIR_OpArrayCopy(LIR_Opr src, LIR_Opr src_pos, LIR_Opr dst, LIR_
|
|||||||
_stub = new ArrayCopyStub(this);
|
_stub = new ArrayCopyStub(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LIR_OpUpdateCRC32::LIR_OpUpdateCRC32(LIR_Opr crc, LIR_Opr val, LIR_Opr res)
|
||||||
|
: LIR_Op(lir_updatecrc32, res, NULL)
|
||||||
|
, _crc(crc)
|
||||||
|
, _val(val) {
|
||||||
|
}
|
||||||
|
|
||||||
//-------------------verify--------------------------
|
//-------------------verify--------------------------
|
||||||
|
|
||||||
@ -876,6 +881,20 @@ void LIR_OpVisitState::visit(LIR_Op* op) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// LIR_OpUpdateCRC32
|
||||||
|
case lir_updatecrc32: {
|
||||||
|
assert(op->as_OpUpdateCRC32() != NULL, "must be");
|
||||||
|
LIR_OpUpdateCRC32* opUp = (LIR_OpUpdateCRC32*)op;
|
||||||
|
|
||||||
|
assert(opUp->_crc->is_valid(), "used"); do_input(opUp->_crc); do_temp(opUp->_crc);
|
||||||
|
assert(opUp->_val->is_valid(), "used"); do_input(opUp->_val); do_temp(opUp->_val);
|
||||||
|
assert(opUp->_result->is_valid(), "used"); do_output(opUp->_result);
|
||||||
|
assert(opUp->_info == NULL, "no info for LIR_OpUpdateCRC32");
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// LIR_OpLock
|
// LIR_OpLock
|
||||||
case lir_lock:
|
case lir_lock:
|
||||||
case lir_unlock: {
|
case lir_unlock: {
|
||||||
@ -1056,6 +1075,10 @@ void LIR_OpArrayCopy::emit_code(LIR_Assembler* masm) {
|
|||||||
masm->emit_code_stub(stub());
|
masm->emit_code_stub(stub());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LIR_OpUpdateCRC32::emit_code(LIR_Assembler* masm) {
|
||||||
|
masm->emit_updatecrc32(this);
|
||||||
|
}
|
||||||
|
|
||||||
void LIR_Op0::emit_code(LIR_Assembler* masm) {
|
void LIR_Op0::emit_code(LIR_Assembler* masm) {
|
||||||
masm->emit_op0(this);
|
masm->emit_op0(this);
|
||||||
}
|
}
|
||||||
@ -1763,6 +1786,8 @@ const char * LIR_Op::name() const {
|
|||||||
case lir_dynamic_call: s = "dynamic"; break;
|
case lir_dynamic_call: s = "dynamic"; break;
|
||||||
// LIR_OpArrayCopy
|
// LIR_OpArrayCopy
|
||||||
case lir_arraycopy: s = "arraycopy"; break;
|
case lir_arraycopy: s = "arraycopy"; break;
|
||||||
|
// LIR_OpUpdateCRC32
|
||||||
|
case lir_updatecrc32: s = "updatecrc32"; break;
|
||||||
// LIR_OpLock
|
// LIR_OpLock
|
||||||
case lir_lock: s = "lock"; break;
|
case lir_lock: s = "lock"; break;
|
||||||
case lir_unlock: s = "unlock"; break;
|
case lir_unlock: s = "unlock"; break;
|
||||||
@ -1815,6 +1840,13 @@ void LIR_OpArrayCopy::print_instr(outputStream* out) const {
|
|||||||
tmp()->print(out); out->print(" ");
|
tmp()->print(out); out->print(" ");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// LIR_OpUpdateCRC32
|
||||||
|
void LIR_OpUpdateCRC32::print_instr(outputStream* out) const {
|
||||||
|
crc()->print(out); out->print(" ");
|
||||||
|
val()->print(out); out->print(" ");
|
||||||
|
result_opr()->print(out); out->print(" ");
|
||||||
|
}
|
||||||
|
|
||||||
// LIR_OpCompareAndSwap
|
// LIR_OpCompareAndSwap
|
||||||
void LIR_OpCompareAndSwap::print_instr(outputStream* out) const {
|
void LIR_OpCompareAndSwap::print_instr(outputStream* out) const {
|
||||||
addr()->print(out); out->print(" ");
|
addr()->print(out); out->print(" ");
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -877,6 +877,7 @@ class LIR_OpCall;
|
|||||||
class LIR_OpJavaCall;
|
class LIR_OpJavaCall;
|
||||||
class LIR_OpRTCall;
|
class LIR_OpRTCall;
|
||||||
class LIR_OpArrayCopy;
|
class LIR_OpArrayCopy;
|
||||||
|
class LIR_OpUpdateCRC32;
|
||||||
class LIR_OpLock;
|
class LIR_OpLock;
|
||||||
class LIR_OpTypeCheck;
|
class LIR_OpTypeCheck;
|
||||||
class LIR_OpCompareAndSwap;
|
class LIR_OpCompareAndSwap;
|
||||||
@ -982,6 +983,9 @@ enum LIR_Code {
|
|||||||
, begin_opArrayCopy
|
, begin_opArrayCopy
|
||||||
, lir_arraycopy
|
, lir_arraycopy
|
||||||
, end_opArrayCopy
|
, end_opArrayCopy
|
||||||
|
, begin_opUpdateCRC32
|
||||||
|
, lir_updatecrc32
|
||||||
|
, end_opUpdateCRC32
|
||||||
, begin_opLock
|
, begin_opLock
|
||||||
, lir_lock
|
, lir_lock
|
||||||
, lir_unlock
|
, lir_unlock
|
||||||
@ -1137,6 +1141,7 @@ class LIR_Op: public CompilationResourceObj {
|
|||||||
virtual LIR_Op2* as_Op2() { return NULL; }
|
virtual LIR_Op2* as_Op2() { return NULL; }
|
||||||
virtual LIR_Op3* as_Op3() { return NULL; }
|
virtual LIR_Op3* as_Op3() { return NULL; }
|
||||||
virtual LIR_OpArrayCopy* as_OpArrayCopy() { return NULL; }
|
virtual LIR_OpArrayCopy* as_OpArrayCopy() { return NULL; }
|
||||||
|
virtual LIR_OpUpdateCRC32* as_OpUpdateCRC32() { return NULL; }
|
||||||
virtual LIR_OpTypeCheck* as_OpTypeCheck() { return NULL; }
|
virtual LIR_OpTypeCheck* as_OpTypeCheck() { return NULL; }
|
||||||
virtual LIR_OpCompareAndSwap* as_OpCompareAndSwap() { return NULL; }
|
virtual LIR_OpCompareAndSwap* as_OpCompareAndSwap() { return NULL; }
|
||||||
virtual LIR_OpProfileCall* as_OpProfileCall() { return NULL; }
|
virtual LIR_OpProfileCall* as_OpProfileCall() { return NULL; }
|
||||||
@ -1293,6 +1298,25 @@ public:
|
|||||||
void print_instr(outputStream* out) const PRODUCT_RETURN;
|
void print_instr(outputStream* out) const PRODUCT_RETURN;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// LIR_OpUpdateCRC32
|
||||||
|
class LIR_OpUpdateCRC32: public LIR_Op {
|
||||||
|
friend class LIR_OpVisitState;
|
||||||
|
|
||||||
|
private:
|
||||||
|
LIR_Opr _crc;
|
||||||
|
LIR_Opr _val;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
LIR_OpUpdateCRC32(LIR_Opr crc, LIR_Opr val, LIR_Opr res);
|
||||||
|
|
||||||
|
LIR_Opr crc() const { return _crc; }
|
||||||
|
LIR_Opr val() const { return _val; }
|
||||||
|
|
||||||
|
virtual void emit_code(LIR_Assembler* masm);
|
||||||
|
virtual LIR_OpUpdateCRC32* as_OpUpdateCRC32() { return this; }
|
||||||
|
void print_instr(outputStream* out) const PRODUCT_RETURN;
|
||||||
|
};
|
||||||
|
|
||||||
// --------------------------------------------------
|
// --------------------------------------------------
|
||||||
// LIR_Op0
|
// LIR_Op0
|
||||||
@ -2212,6 +2236,8 @@ class LIR_List: public CompilationResourceObj {
|
|||||||
|
|
||||||
void arraycopy(LIR_Opr src, LIR_Opr src_pos, LIR_Opr dst, LIR_Opr dst_pos, LIR_Opr length, LIR_Opr tmp, ciArrayKlass* expected_type, int flags, CodeEmitInfo* info) { append(new LIR_OpArrayCopy(src, src_pos, dst, dst_pos, length, tmp, expected_type, flags, info)); }
|
void arraycopy(LIR_Opr src, LIR_Opr src_pos, LIR_Opr dst, LIR_Opr dst_pos, LIR_Opr length, LIR_Opr tmp, ciArrayKlass* expected_type, int flags, CodeEmitInfo* info) { append(new LIR_OpArrayCopy(src, src_pos, dst, dst_pos, length, tmp, expected_type, flags, info)); }
|
||||||
|
|
||||||
|
void update_crc32(LIR_Opr crc, LIR_Opr val, LIR_Opr res) { append(new LIR_OpUpdateCRC32(crc, val, res)); }
|
||||||
|
|
||||||
void fpop_raw() { append(new LIR_Op0(lir_fpop_raw)); }
|
void fpop_raw() { append(new LIR_Op0(lir_fpop_raw)); }
|
||||||
|
|
||||||
void instanceof(LIR_Opr result, LIR_Opr object, ciKlass* klass, LIR_Opr tmp1, LIR_Opr tmp2, LIR_Opr tmp3, bool fast_check, CodeEmitInfo* info_for_patch, ciMethod* profiled_method, int profiled_bci);
|
void instanceof(LIR_Opr result, LIR_Opr object, ciKlass* klass, LIR_Opr tmp1, LIR_Opr tmp2, LIR_Opr tmp3, bool fast_check, CodeEmitInfo* info_for_patch, ciMethod* profiled_method, int profiled_bci);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -195,6 +195,7 @@ class LIR_Assembler: public CompilationResourceObj {
|
|||||||
void emit_opBranch(LIR_OpBranch* op);
|
void emit_opBranch(LIR_OpBranch* op);
|
||||||
void emit_opLabel(LIR_OpLabel* op);
|
void emit_opLabel(LIR_OpLabel* op);
|
||||||
void emit_arraycopy(LIR_OpArrayCopy* op);
|
void emit_arraycopy(LIR_OpArrayCopy* op);
|
||||||
|
void emit_updatecrc32(LIR_OpUpdateCRC32* op);
|
||||||
void emit_opConvert(LIR_OpConvert* op);
|
void emit_opConvert(LIR_OpConvert* op);
|
||||||
void emit_alloc_obj(LIR_OpAllocObj* op);
|
void emit_alloc_obj(LIR_OpAllocObj* op);
|
||||||
void emit_alloc_array(LIR_OpAllocArray* op);
|
void emit_alloc_array(LIR_OpAllocArray* op);
|
||||||
|
@ -2994,6 +2994,12 @@ void LIRGenerator::do_Intrinsic(Intrinsic* x) {
|
|||||||
do_Reference_get(x);
|
do_Reference_get(x);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case vmIntrinsics::_updateCRC32:
|
||||||
|
case vmIntrinsics::_updateBytesCRC32:
|
||||||
|
case vmIntrinsics::_updateByteBufferCRC32:
|
||||||
|
do_update_CRC32(x);
|
||||||
|
break;
|
||||||
|
|
||||||
default: ShouldNotReachHere(); break;
|
default: ShouldNotReachHere(); break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -247,6 +247,7 @@ class LIRGenerator: public InstructionVisitor, public BlockClosure {
|
|||||||
void do_NIOCheckIndex(Intrinsic* x);
|
void do_NIOCheckIndex(Intrinsic* x);
|
||||||
void do_FPIntrinsics(Intrinsic* x);
|
void do_FPIntrinsics(Intrinsic* x);
|
||||||
void do_Reference_get(Intrinsic* x);
|
void do_Reference_get(Intrinsic* x);
|
||||||
|
void do_update_CRC32(Intrinsic* x);
|
||||||
|
|
||||||
void do_UnsafePrefetch(UnsafePrefetch* x, bool is_store);
|
void do_UnsafePrefetch(UnsafePrefetch* x, bool is_store);
|
||||||
|
|
||||||
|
@ -299,6 +299,7 @@ const char* Runtime1::name_for_address(address entry) {
|
|||||||
#ifdef TRACE_HAVE_INTRINSICS
|
#ifdef TRACE_HAVE_INTRINSICS
|
||||||
FUNCTION_CASE(entry, TRACE_TIME_METHOD);
|
FUNCTION_CASE(entry, TRACE_TIME_METHOD);
|
||||||
#endif
|
#endif
|
||||||
|
FUNCTION_CASE(entry, StubRoutines::updateBytesCRC32());
|
||||||
|
|
||||||
#undef FUNCTION_CASE
|
#undef FUNCTION_CASE
|
||||||
|
|
||||||
|
@ -771,6 +771,17 @@
|
|||||||
do_name( decrypt_name, "decrypt") \
|
do_name( decrypt_name, "decrypt") \
|
||||||
do_signature(byteArray_int_int_byteArray_int_signature, "([BII[BI)V") \
|
do_signature(byteArray_int_int_byteArray_int_signature, "([BII[BI)V") \
|
||||||
\
|
\
|
||||||
|
/* support for java.util.zip */ \
|
||||||
|
do_class(java_util_zip_CRC32, "java/util/zip/CRC32") \
|
||||||
|
do_intrinsic(_updateCRC32, java_util_zip_CRC32, update_name, int2_int_signature, F_SN) \
|
||||||
|
do_name( update_name, "update") \
|
||||||
|
do_intrinsic(_updateBytesCRC32, java_util_zip_CRC32, updateBytes_name, updateBytes_signature, F_SN) \
|
||||||
|
do_name( updateBytes_name, "updateBytes") \
|
||||||
|
do_signature(updateBytes_signature, "(I[BII)I") \
|
||||||
|
do_intrinsic(_updateByteBufferCRC32, java_util_zip_CRC32, updateByteBuffer_name, updateByteBuffer_signature, F_SN) \
|
||||||
|
do_name( updateByteBuffer_name, "updateByteBuffer") \
|
||||||
|
do_signature(updateByteBuffer_signature, "(IJII)I") \
|
||||||
|
\
|
||||||
/* support for sun.misc.Unsafe */ \
|
/* support for sun.misc.Unsafe */ \
|
||||||
do_class(sun_misc_Unsafe, "sun/misc/Unsafe") \
|
do_class(sun_misc_Unsafe, "sun/misc/Unsafe") \
|
||||||
\
|
\
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -102,6 +102,9 @@ class AbstractInterpreter: AllStatic {
|
|||||||
java_lang_math_pow, // implementation of java.lang.Math.pow (x,y)
|
java_lang_math_pow, // implementation of java.lang.Math.pow (x,y)
|
||||||
java_lang_math_exp, // implementation of java.lang.Math.exp (x)
|
java_lang_math_exp, // implementation of java.lang.Math.exp (x)
|
||||||
java_lang_ref_reference_get, // implementation of java.lang.ref.Reference.get()
|
java_lang_ref_reference_get, // implementation of java.lang.ref.Reference.get()
|
||||||
|
java_util_zip_CRC32_update, // implementation of java.util.zip.CRC32.update()
|
||||||
|
java_util_zip_CRC32_updateBytes, // implementation of java.util.zip.CRC32.updateBytes()
|
||||||
|
java_util_zip_CRC32_updateByteBuffer, // implementation of java.util.zip.CRC32.updateByteBuffer()
|
||||||
number_of_method_entries,
|
number_of_method_entries,
|
||||||
invalid = -1
|
invalid = -1
|
||||||
};
|
};
|
||||||
|
@ -1581,7 +1581,7 @@ run:
|
|||||||
#define ARRAY_LOADTO32(T, T2, format, stackRes, extra) \
|
#define ARRAY_LOADTO32(T, T2, format, stackRes, extra) \
|
||||||
{ \
|
{ \
|
||||||
ARRAY_INTRO(-2); \
|
ARRAY_INTRO(-2); \
|
||||||
extra; \
|
(void)extra; \
|
||||||
SET_ ## stackRes(*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)), \
|
SET_ ## stackRes(*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)), \
|
||||||
-2); \
|
-2); \
|
||||||
UPDATE_PC_AND_TOS_AND_CONTINUE(1, -1); \
|
UPDATE_PC_AND_TOS_AND_CONTINUE(1, -1); \
|
||||||
@ -1592,7 +1592,7 @@ run:
|
|||||||
{ \
|
{ \
|
||||||
ARRAY_INTRO(-2); \
|
ARRAY_INTRO(-2); \
|
||||||
SET_ ## stackRes(*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)), -1); \
|
SET_ ## stackRes(*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)), -1); \
|
||||||
extra; \
|
(void)extra; \
|
||||||
UPDATE_PC_AND_CONTINUE(1); \
|
UPDATE_PC_AND_CONTINUE(1); \
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1617,7 +1617,7 @@ run:
|
|||||||
#define ARRAY_STOREFROM32(T, T2, format, stackSrc, extra) \
|
#define ARRAY_STOREFROM32(T, T2, format, stackSrc, extra) \
|
||||||
{ \
|
{ \
|
||||||
ARRAY_INTRO(-3); \
|
ARRAY_INTRO(-3); \
|
||||||
extra; \
|
(void)extra; \
|
||||||
*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)) = stackSrc( -1); \
|
*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)) = stackSrc( -1); \
|
||||||
UPDATE_PC_AND_TOS_AND_CONTINUE(1, -3); \
|
UPDATE_PC_AND_TOS_AND_CONTINUE(1, -3); \
|
||||||
}
|
}
|
||||||
@ -1626,7 +1626,7 @@ run:
|
|||||||
#define ARRAY_STOREFROM64(T, T2, stackSrc, extra) \
|
#define ARRAY_STOREFROM64(T, T2, stackSrc, extra) \
|
||||||
{ \
|
{ \
|
||||||
ARRAY_INTRO(-4); \
|
ARRAY_INTRO(-4); \
|
||||||
extra; \
|
(void)extra; \
|
||||||
*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)) = stackSrc( -1); \
|
*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)) = stackSrc( -1); \
|
||||||
UPDATE_PC_AND_TOS_AND_CONTINUE(1, -4); \
|
UPDATE_PC_AND_TOS_AND_CONTINUE(1, -4); \
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -195,6 +195,17 @@ AbstractInterpreter::MethodKind AbstractInterpreter::method_kind(methodHandle m)
|
|||||||
return kind;
|
return kind;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef CC_INTERP
|
||||||
|
if (UseCRC32Intrinsics && m->is_native()) {
|
||||||
|
// Use optimized stub code for CRC32 native methods.
|
||||||
|
switch (m->intrinsic_id()) {
|
||||||
|
case vmIntrinsics::_updateCRC32 : return java_util_zip_CRC32_update;
|
||||||
|
case vmIntrinsics::_updateBytesCRC32 : return java_util_zip_CRC32_updateBytes;
|
||||||
|
case vmIntrinsics::_updateByteBufferCRC32 : return java_util_zip_CRC32_updateByteBuffer;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// Native method?
|
// Native method?
|
||||||
// Note: This test must come _before_ the test for intrinsic
|
// Note: This test must come _before_ the test for intrinsic
|
||||||
// methods. See also comments below.
|
// methods. See also comments below.
|
||||||
@ -297,6 +308,9 @@ void AbstractInterpreter::print_method_kind(MethodKind kind) {
|
|||||||
case java_lang_math_sqrt : tty->print("java_lang_math_sqrt" ); break;
|
case java_lang_math_sqrt : tty->print("java_lang_math_sqrt" ); break;
|
||||||
case java_lang_math_log : tty->print("java_lang_math_log" ); break;
|
case java_lang_math_log : tty->print("java_lang_math_log" ); break;
|
||||||
case java_lang_math_log10 : tty->print("java_lang_math_log10" ); break;
|
case java_lang_math_log10 : tty->print("java_lang_math_log10" ); break;
|
||||||
|
case java_util_zip_CRC32_update : tty->print("java_util_zip_CRC32_update"); break;
|
||||||
|
case java_util_zip_CRC32_updateBytes : tty->print("java_util_zip_CRC32_updateBytes"); break;
|
||||||
|
case java_util_zip_CRC32_updateByteBuffer : tty->print("java_util_zip_CRC32_updateByteBuffer"); break;
|
||||||
default:
|
default:
|
||||||
if (kind >= method_handle_invoke_FIRST &&
|
if (kind >= method_handle_invoke_FIRST &&
|
||||||
kind <= method_handle_invoke_LAST) {
|
kind <= method_handle_invoke_LAST) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -373,6 +373,12 @@ void TemplateInterpreterGenerator::generate_all() {
|
|||||||
method_entry(java_lang_math_pow )
|
method_entry(java_lang_math_pow )
|
||||||
method_entry(java_lang_ref_reference_get)
|
method_entry(java_lang_ref_reference_get)
|
||||||
|
|
||||||
|
if (UseCRC32Intrinsics) {
|
||||||
|
method_entry(java_util_zip_CRC32_update)
|
||||||
|
method_entry(java_util_zip_CRC32_updateBytes)
|
||||||
|
method_entry(java_util_zip_CRC32_updateByteBuffer)
|
||||||
|
}
|
||||||
|
|
||||||
initialize_method_handle_entries();
|
initialize_method_handle_entries();
|
||||||
|
|
||||||
// all native method kinds (must be one contiguous block)
|
// all native method kinds (must be one contiguous block)
|
||||||
|
@ -933,6 +933,7 @@ void ConnectionGraph::process_call_arguments(CallNode *call) {
|
|||||||
(call->as_CallLeaf()->_name != NULL &&
|
(call->as_CallLeaf()->_name != NULL &&
|
||||||
(strcmp(call->as_CallLeaf()->_name, "g1_wb_pre") == 0 ||
|
(strcmp(call->as_CallLeaf()->_name, "g1_wb_pre") == 0 ||
|
||||||
strcmp(call->as_CallLeaf()->_name, "g1_wb_post") == 0 ||
|
strcmp(call->as_CallLeaf()->_name, "g1_wb_post") == 0 ||
|
||||||
|
strcmp(call->as_CallLeaf()->_name, "updateBytesCRC32") == 0 ||
|
||||||
strcmp(call->as_CallLeaf()->_name, "aescrypt_encryptBlock") == 0 ||
|
strcmp(call->as_CallLeaf()->_name, "aescrypt_encryptBlock") == 0 ||
|
||||||
strcmp(call->as_CallLeaf()->_name, "aescrypt_decryptBlock") == 0 ||
|
strcmp(call->as_CallLeaf()->_name, "aescrypt_decryptBlock") == 0 ||
|
||||||
strcmp(call->as_CallLeaf()->_name, "cipherBlockChaining_encryptAESCrypt") == 0 ||
|
strcmp(call->as_CallLeaf()->_name, "cipherBlockChaining_encryptAESCrypt") == 0 ||
|
||||||
|
@ -3332,9 +3332,14 @@ AllocateNode* AllocateNode::Ideal_allocation(Node* ptr, PhaseTransform* phase) {
|
|||||||
if (ptr == NULL) { // reduce dumb test in callers
|
if (ptr == NULL) { // reduce dumb test in callers
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
ptr = ptr->uncast(); // strip a raw-to-oop cast
|
if (ptr->is_CheckCastPP()) { // strip only one raw-to-oop cast
|
||||||
|
ptr = ptr->in(1);
|
||||||
if (ptr == NULL) return NULL;
|
if (ptr == NULL) return NULL;
|
||||||
|
}
|
||||||
|
// Return NULL for allocations with several casts:
|
||||||
|
// j.l.reflect.Array.newInstance(jobject, jint)
|
||||||
|
// Object.clone()
|
||||||
|
// to keep more precise type from last cast.
|
||||||
if (ptr->is_Proj()) {
|
if (ptr->is_Proj()) {
|
||||||
Node* allo = ptr->in(0);
|
Node* allo = ptr->in(0);
|
||||||
if (allo != NULL && allo->is_Allocate()) {
|
if (allo != NULL && allo->is_Allocate()) {
|
||||||
|
@ -291,6 +291,9 @@ class LibraryCallKit : public GraphKit {
|
|||||||
Node* inline_cipherBlockChaining_AESCrypt_predicate(bool decrypting);
|
Node* inline_cipherBlockChaining_AESCrypt_predicate(bool decrypting);
|
||||||
Node* get_key_start_from_aescrypt_object(Node* aescrypt_object);
|
Node* get_key_start_from_aescrypt_object(Node* aescrypt_object);
|
||||||
bool inline_encodeISOArray();
|
bool inline_encodeISOArray();
|
||||||
|
bool inline_updateCRC32();
|
||||||
|
bool inline_updateBytesCRC32();
|
||||||
|
bool inline_updateByteBufferCRC32();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -488,6 +491,12 @@ CallGenerator* Compile::make_vm_intrinsic(ciMethod* m, bool is_virtual) {
|
|||||||
is_predicted = true;
|
is_predicted = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case vmIntrinsics::_updateCRC32:
|
||||||
|
case vmIntrinsics::_updateBytesCRC32:
|
||||||
|
case vmIntrinsics::_updateByteBufferCRC32:
|
||||||
|
if (!UseCRC32Intrinsics) return NULL;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
assert(id <= vmIntrinsics::LAST_COMPILER_INLINE, "caller responsibility");
|
assert(id <= vmIntrinsics::LAST_COMPILER_INLINE, "caller responsibility");
|
||||||
assert(id != vmIntrinsics::_Object_init && id != vmIntrinsics::_invoke, "enum out of order?");
|
assert(id != vmIntrinsics::_Object_init && id != vmIntrinsics::_invoke, "enum out of order?");
|
||||||
@ -807,6 +816,13 @@ bool LibraryCallKit::try_to_inline() {
|
|||||||
case vmIntrinsics::_encodeISOArray:
|
case vmIntrinsics::_encodeISOArray:
|
||||||
return inline_encodeISOArray();
|
return inline_encodeISOArray();
|
||||||
|
|
||||||
|
case vmIntrinsics::_updateCRC32:
|
||||||
|
return inline_updateCRC32();
|
||||||
|
case vmIntrinsics::_updateBytesCRC32:
|
||||||
|
return inline_updateBytesCRC32();
|
||||||
|
case vmIntrinsics::_updateByteBufferCRC32:
|
||||||
|
return inline_updateByteBufferCRC32();
|
||||||
|
|
||||||
default:
|
default:
|
||||||
// If you get here, it may be that someone has added a new intrinsic
|
// If you get here, it may be that someone has added a new intrinsic
|
||||||
// to the list in vmSymbols.hpp without implementing it here.
|
// to the list in vmSymbols.hpp without implementing it here.
|
||||||
@ -5360,6 +5376,117 @@ bool LibraryCallKit::inline_encodeISOArray() {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculate CRC32 for byte.
|
||||||
|
* int java.util.zip.CRC32.update(int crc, int b)
|
||||||
|
*/
|
||||||
|
bool LibraryCallKit::inline_updateCRC32() {
|
||||||
|
assert(UseCRC32Intrinsics, "need AVX and LCMUL instructions support");
|
||||||
|
assert(callee()->signature()->size() == 2, "update has 2 parameters");
|
||||||
|
// no receiver since it is static method
|
||||||
|
Node* crc = argument(0); // type: int
|
||||||
|
Node* b = argument(1); // type: int
|
||||||
|
|
||||||
|
/*
|
||||||
|
* int c = ~ crc;
|
||||||
|
* b = timesXtoThe32[(b ^ c) & 0xFF];
|
||||||
|
* b = b ^ (c >>> 8);
|
||||||
|
* crc = ~b;
|
||||||
|
*/
|
||||||
|
|
||||||
|
Node* M1 = intcon(-1);
|
||||||
|
crc = _gvn.transform(new (C) XorINode(crc, M1));
|
||||||
|
Node* result = _gvn.transform(new (C) XorINode(crc, b));
|
||||||
|
result = _gvn.transform(new (C) AndINode(result, intcon(0xFF)));
|
||||||
|
|
||||||
|
Node* base = makecon(TypeRawPtr::make(StubRoutines::crc_table_addr()));
|
||||||
|
Node* offset = _gvn.transform(new (C) LShiftINode(result, intcon(0x2)));
|
||||||
|
Node* adr = basic_plus_adr(top(), base, ConvI2X(offset));
|
||||||
|
result = make_load(control(), adr, TypeInt::INT, T_INT);
|
||||||
|
|
||||||
|
crc = _gvn.transform(new (C) URShiftINode(crc, intcon(8)));
|
||||||
|
result = _gvn.transform(new (C) XorINode(crc, result));
|
||||||
|
result = _gvn.transform(new (C) XorINode(result, M1));
|
||||||
|
set_result(result);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculate CRC32 for byte[] array.
|
||||||
|
* int java.util.zip.CRC32.updateBytes(int crc, byte[] buf, int off, int len)
|
||||||
|
*/
|
||||||
|
bool LibraryCallKit::inline_updateBytesCRC32() {
|
||||||
|
assert(UseCRC32Intrinsics, "need AVX and LCMUL instructions support");
|
||||||
|
assert(callee()->signature()->size() == 4, "updateBytes has 4 parameters");
|
||||||
|
// no receiver since it is static method
|
||||||
|
Node* crc = argument(0); // type: int
|
||||||
|
Node* src = argument(1); // type: oop
|
||||||
|
Node* offset = argument(2); // type: int
|
||||||
|
Node* length = argument(3); // type: int
|
||||||
|
|
||||||
|
const Type* src_type = src->Value(&_gvn);
|
||||||
|
const TypeAryPtr* top_src = src_type->isa_aryptr();
|
||||||
|
if (top_src == NULL || top_src->klass() == NULL) {
|
||||||
|
// failed array check
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Figure out the size and type of the elements we will be copying.
|
||||||
|
BasicType src_elem = src_type->isa_aryptr()->klass()->as_array_klass()->element_type()->basic_type();
|
||||||
|
if (src_elem != T_BYTE) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 'src_start' points to src array + scaled offset
|
||||||
|
Node* src_start = array_element_address(src, offset, src_elem);
|
||||||
|
|
||||||
|
// We assume that range check is done by caller.
|
||||||
|
// TODO: generate range check (offset+length < src.length) in debug VM.
|
||||||
|
|
||||||
|
// Call the stub.
|
||||||
|
address stubAddr = StubRoutines::updateBytesCRC32();
|
||||||
|
const char *stubName = "updateBytesCRC32";
|
||||||
|
|
||||||
|
Node* call = make_runtime_call(RC_LEAF|RC_NO_FP, OptoRuntime::updateBytesCRC32_Type(),
|
||||||
|
stubAddr, stubName, TypePtr::BOTTOM,
|
||||||
|
crc, src_start, length);
|
||||||
|
Node* result = _gvn.transform(new (C) ProjNode(call, TypeFunc::Parms));
|
||||||
|
set_result(result);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculate CRC32 for ByteBuffer.
|
||||||
|
* int java.util.zip.CRC32.updateByteBuffer(int crc, long buf, int off, int len)
|
||||||
|
*/
|
||||||
|
bool LibraryCallKit::inline_updateByteBufferCRC32() {
|
||||||
|
assert(UseCRC32Intrinsics, "need AVX and LCMUL instructions support");
|
||||||
|
assert(callee()->signature()->size() == 5, "updateByteBuffer has 4 parameters and one is long");
|
||||||
|
// no receiver since it is static method
|
||||||
|
Node* crc = argument(0); // type: int
|
||||||
|
Node* src = argument(1); // type: long
|
||||||
|
Node* offset = argument(3); // type: int
|
||||||
|
Node* length = argument(4); // type: int
|
||||||
|
|
||||||
|
src = ConvL2X(src); // adjust Java long to machine word
|
||||||
|
Node* base = _gvn.transform(new (C) CastX2PNode(src));
|
||||||
|
offset = ConvI2X(offset);
|
||||||
|
|
||||||
|
// 'src_start' points to src array + scaled offset
|
||||||
|
Node* src_start = basic_plus_adr(top(), base, offset);
|
||||||
|
|
||||||
|
// Call the stub.
|
||||||
|
address stubAddr = StubRoutines::updateBytesCRC32();
|
||||||
|
const char *stubName = "updateBytesCRC32";
|
||||||
|
|
||||||
|
Node* call = make_runtime_call(RC_LEAF|RC_NO_FP, OptoRuntime::updateBytesCRC32_Type(),
|
||||||
|
stubAddr, stubName, TypePtr::BOTTOM,
|
||||||
|
crc, src_start, length);
|
||||||
|
Node* result = _gvn.transform(new (C) ProjNode(call, TypeFunc::Parms));
|
||||||
|
set_result(result);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
//----------------------------inline_reference_get----------------------------
|
//----------------------------inline_reference_get----------------------------
|
||||||
// public T java.lang.ref.Reference.get();
|
// public T java.lang.ref.Reference.get();
|
||||||
bool LibraryCallKit::inline_reference_get() {
|
bool LibraryCallKit::inline_reference_get() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -829,6 +829,28 @@ const TypeFunc* OptoRuntime::aescrypt_block_Type() {
|
|||||||
return TypeFunc::make(domain, range);
|
return TypeFunc::make(domain, range);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* int updateBytesCRC32(int crc, byte* b, int len)
|
||||||
|
*/
|
||||||
|
const TypeFunc* OptoRuntime::updateBytesCRC32_Type() {
|
||||||
|
// create input type (domain)
|
||||||
|
int num_args = 3;
|
||||||
|
int argcnt = num_args;
|
||||||
|
const Type** fields = TypeTuple::fields(argcnt);
|
||||||
|
int argp = TypeFunc::Parms;
|
||||||
|
fields[argp++] = TypeInt::INT; // crc
|
||||||
|
fields[argp++] = TypePtr::NOTNULL; // src
|
||||||
|
fields[argp++] = TypeInt::INT; // len
|
||||||
|
assert(argp == TypeFunc::Parms+argcnt, "correct decoding");
|
||||||
|
const TypeTuple* domain = TypeTuple::make(TypeFunc::Parms+argcnt, fields);
|
||||||
|
|
||||||
|
// result type needed
|
||||||
|
fields = TypeTuple::fields(1);
|
||||||
|
fields[TypeFunc::Parms+0] = TypeInt::INT; // crc result
|
||||||
|
const TypeTuple* range = TypeTuple::make(TypeFunc::Parms+1, fields);
|
||||||
|
return TypeFunc::make(domain, range);
|
||||||
|
}
|
||||||
|
|
||||||
// for cipherBlockChaining calls of aescrypt encrypt/decrypt, four pointers and a length, returning void
|
// for cipherBlockChaining calls of aescrypt encrypt/decrypt, four pointers and a length, returning void
|
||||||
const TypeFunc* OptoRuntime::cipherBlockChaining_aescrypt_Type() {
|
const TypeFunc* OptoRuntime::cipherBlockChaining_aescrypt_Type() {
|
||||||
// create input type (domain)
|
// create input type (domain)
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -284,6 +284,8 @@ private:
|
|||||||
static const TypeFunc* aescrypt_block_Type();
|
static const TypeFunc* aescrypt_block_Type();
|
||||||
static const TypeFunc* cipherBlockChaining_aescrypt_Type();
|
static const TypeFunc* cipherBlockChaining_aescrypt_Type();
|
||||||
|
|
||||||
|
static const TypeFunc* updateBytesCRC32_Type();
|
||||||
|
|
||||||
// leaf on stack replacement interpreter accessor types
|
// leaf on stack replacement interpreter accessor types
|
||||||
static const TypeFunc* osr_end_Type();
|
static const TypeFunc* osr_end_Type();
|
||||||
|
|
||||||
|
@ -1137,7 +1137,12 @@ JVM_ENTRY(jobject, MHN_resolve_Mem(JNIEnv *env, jobject igcls, jobject mname_jh,
|
|||||||
if (VerifyMethodHandles && caller_jh != NULL &&
|
if (VerifyMethodHandles && caller_jh != NULL &&
|
||||||
java_lang_invoke_MemberName::clazz(mname()) != NULL) {
|
java_lang_invoke_MemberName::clazz(mname()) != NULL) {
|
||||||
Klass* reference_klass = java_lang_Class::as_Klass(java_lang_invoke_MemberName::clazz(mname()));
|
Klass* reference_klass = java_lang_Class::as_Klass(java_lang_invoke_MemberName::clazz(mname()));
|
||||||
if (reference_klass != NULL) {
|
if (reference_klass != NULL && reference_klass->oop_is_objArray()) {
|
||||||
|
reference_klass = ObjArrayKlass::cast(reference_klass)->bottom_klass();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reflection::verify_class_access can only handle instance classes.
|
||||||
|
if (reference_klass != NULL && reference_klass->oop_is_instance()) {
|
||||||
// Emulate LinkResolver::check_klass_accessability.
|
// Emulate LinkResolver::check_klass_accessability.
|
||||||
Klass* caller = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(caller_jh));
|
Klass* caller = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(caller_jh));
|
||||||
if (!Reflection::verify_class_access(caller,
|
if (!Reflection::verify_class_access(caller,
|
||||||
|
@ -2221,11 +2221,24 @@ bool Arguments::check_vm_args_consistency() {
|
|||||||
status = false;
|
status = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ReservedCodeCacheSize < InitialCodeCacheSize) {
|
// Check lower bounds of the code cache
|
||||||
|
// Template Interpreter code is approximately 3X larger in debug builds.
|
||||||
|
uint min_code_cache_size = (CodeCacheMinimumUseSpace DEBUG_ONLY(* 3)) + CodeCacheMinimumFreeSpace;
|
||||||
|
if (InitialCodeCacheSize < (uintx)os::vm_page_size()) {
|
||||||
jio_fprintf(defaultStream::error_stream(),
|
jio_fprintf(defaultStream::error_stream(),
|
||||||
"Invalid ReservedCodeCacheSize: %dK. Should be greater than InitialCodeCacheSize=%dK\n",
|
"Invalid InitialCodeCacheSize=%dK. Must be at least %dK.\n", InitialCodeCacheSize/K,
|
||||||
|
os::vm_page_size()/K);
|
||||||
|
status = false;
|
||||||
|
} else if (ReservedCodeCacheSize < InitialCodeCacheSize) {
|
||||||
|
jio_fprintf(defaultStream::error_stream(),
|
||||||
|
"Invalid ReservedCodeCacheSize: %dK. Must be at least InitialCodeCacheSize=%dK.\n",
|
||||||
ReservedCodeCacheSize/K, InitialCodeCacheSize/K);
|
ReservedCodeCacheSize/K, InitialCodeCacheSize/K);
|
||||||
status = false;
|
status = false;
|
||||||
|
} else if (ReservedCodeCacheSize < min_code_cache_size) {
|
||||||
|
jio_fprintf(defaultStream::error_stream(),
|
||||||
|
"Invalid ReservedCodeCacheSize=%dK. Must be at least %uK.\n", ReservedCodeCacheSize/K,
|
||||||
|
min_code_cache_size/K);
|
||||||
|
status = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
@ -2626,10 +2639,20 @@ jint Arguments::parse_each_vm_init_arg(const JavaVMInitArgs* args,
|
|||||||
// -Xoss
|
// -Xoss
|
||||||
} else if (match_option(option, "-Xoss", &tail)) {
|
} else if (match_option(option, "-Xoss", &tail)) {
|
||||||
// HotSpot does not have separate native and Java stacks, ignore silently for compatibility
|
// HotSpot does not have separate native and Java stacks, ignore silently for compatibility
|
||||||
// -Xmaxjitcodesize
|
} else if (match_option(option, "-XX:CodeCacheExpansionSize=", &tail)) {
|
||||||
|
julong long_CodeCacheExpansionSize = 0;
|
||||||
|
ArgsRange errcode = parse_memory_size(tail, &long_CodeCacheExpansionSize, os::vm_page_size());
|
||||||
|
if (errcode != arg_in_range) {
|
||||||
|
jio_fprintf(defaultStream::error_stream(),
|
||||||
|
"Invalid argument: %s. Must be at least %luK.\n", option->optionString,
|
||||||
|
os::vm_page_size()/K);
|
||||||
|
return JNI_EINVAL;
|
||||||
|
}
|
||||||
|
FLAG_SET_CMDLINE(uintx, CodeCacheExpansionSize, (uintx)long_CodeCacheExpansionSize);
|
||||||
} else if (match_option(option, "-Xmaxjitcodesize", &tail) ||
|
} else if (match_option(option, "-Xmaxjitcodesize", &tail) ||
|
||||||
match_option(option, "-XX:ReservedCodeCacheSize=", &tail)) {
|
match_option(option, "-XX:ReservedCodeCacheSize=", &tail)) {
|
||||||
julong long_ReservedCodeCacheSize = 0;
|
julong long_ReservedCodeCacheSize = 0;
|
||||||
|
|
||||||
ArgsRange errcode = parse_memory_size(tail, &long_ReservedCodeCacheSize, 1);
|
ArgsRange errcode = parse_memory_size(tail, &long_ReservedCodeCacheSize, 1);
|
||||||
if (errcode != arg_in_range) {
|
if (errcode != arg_in_range) {
|
||||||
jio_fprintf(defaultStream::error_stream(),
|
jio_fprintf(defaultStream::error_stream(),
|
||||||
|
@ -645,6 +645,9 @@ class CommandLineFlags {
|
|||||||
product(bool, UseAESIntrinsics, false, \
|
product(bool, UseAESIntrinsics, false, \
|
||||||
"use intrinsics for AES versions of crypto") \
|
"use intrinsics for AES versions of crypto") \
|
||||||
\
|
\
|
||||||
|
product(bool, UseCRC32Intrinsics, false, \
|
||||||
|
"use intrinsics for java.util.zip.CRC32") \
|
||||||
|
\
|
||||||
develop(bool, TraceCallFixup, false, \
|
develop(bool, TraceCallFixup, false, \
|
||||||
"traces all call fixups") \
|
"traces all call fixups") \
|
||||||
\
|
\
|
||||||
@ -3161,6 +3164,9 @@ class CommandLineFlags {
|
|||||||
product_pd(uintx, InitialCodeCacheSize, \
|
product_pd(uintx, InitialCodeCacheSize, \
|
||||||
"Initial code cache size (in bytes)") \
|
"Initial code cache size (in bytes)") \
|
||||||
\
|
\
|
||||||
|
develop_pd(uintx, CodeCacheMinimumUseSpace, \
|
||||||
|
"Minimum code cache size (in bytes) required to start VM.") \
|
||||||
|
\
|
||||||
product_pd(uintx, ReservedCodeCacheSize, \
|
product_pd(uintx, ReservedCodeCacheSize, \
|
||||||
"Reserved code cache size (in bytes) - maximum code cache size") \
|
"Reserved code cache size (in bytes) - maximum code cache size") \
|
||||||
\
|
\
|
||||||
|
@ -458,7 +458,7 @@ bool Reflection::verify_class_access(Klass* current_class, Klass* new_class, boo
|
|||||||
// doesn't have a classloader.
|
// doesn't have a classloader.
|
||||||
if ((current_class == NULL) ||
|
if ((current_class == NULL) ||
|
||||||
(current_class == new_class) ||
|
(current_class == new_class) ||
|
||||||
(InstanceKlass::cast(new_class)->is_public()) ||
|
(new_class->is_public()) ||
|
||||||
is_same_class_package(current_class, new_class)) {
|
is_same_class_package(current_class, new_class)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -125,6 +125,9 @@ address StubRoutines::_aescrypt_decryptBlock = NULL;
|
|||||||
address StubRoutines::_cipherBlockChaining_encryptAESCrypt = NULL;
|
address StubRoutines::_cipherBlockChaining_encryptAESCrypt = NULL;
|
||||||
address StubRoutines::_cipherBlockChaining_decryptAESCrypt = NULL;
|
address StubRoutines::_cipherBlockChaining_decryptAESCrypt = NULL;
|
||||||
|
|
||||||
|
address StubRoutines::_updateBytesCRC32 = NULL;
|
||||||
|
address StubRoutines::_crc_table_adr = NULL;
|
||||||
|
|
||||||
double (* StubRoutines::_intrinsic_log )(double) = NULL;
|
double (* StubRoutines::_intrinsic_log )(double) = NULL;
|
||||||
double (* StubRoutines::_intrinsic_log10 )(double) = NULL;
|
double (* StubRoutines::_intrinsic_log10 )(double) = NULL;
|
||||||
double (* StubRoutines::_intrinsic_exp )(double) = NULL;
|
double (* StubRoutines::_intrinsic_exp )(double) = NULL;
|
||||||
|
@ -204,6 +204,9 @@ class StubRoutines: AllStatic {
|
|||||||
static address _cipherBlockChaining_encryptAESCrypt;
|
static address _cipherBlockChaining_encryptAESCrypt;
|
||||||
static address _cipherBlockChaining_decryptAESCrypt;
|
static address _cipherBlockChaining_decryptAESCrypt;
|
||||||
|
|
||||||
|
static address _updateBytesCRC32;
|
||||||
|
static address _crc_table_adr;
|
||||||
|
|
||||||
// These are versions of the java.lang.Math methods which perform
|
// These are versions of the java.lang.Math methods which perform
|
||||||
// the same operations as the intrinsic version. They are used for
|
// the same operations as the intrinsic version. They are used for
|
||||||
// constant folding in the compiler to ensure equivalence. If the
|
// constant folding in the compiler to ensure equivalence. If the
|
||||||
@ -342,6 +345,9 @@ class StubRoutines: AllStatic {
|
|||||||
static address cipherBlockChaining_encryptAESCrypt() { return _cipherBlockChaining_encryptAESCrypt; }
|
static address cipherBlockChaining_encryptAESCrypt() { return _cipherBlockChaining_encryptAESCrypt; }
|
||||||
static address cipherBlockChaining_decryptAESCrypt() { return _cipherBlockChaining_decryptAESCrypt; }
|
static address cipherBlockChaining_decryptAESCrypt() { return _cipherBlockChaining_decryptAESCrypt; }
|
||||||
|
|
||||||
|
static address updateBytesCRC32() { return _updateBytesCRC32; }
|
||||||
|
static address crc_table_addr() { return _crc_table_adr; }
|
||||||
|
|
||||||
static address select_fill_function(BasicType t, bool aligned, const char* &name);
|
static address select_fill_function(BasicType t, bool aligned, const char* &name);
|
||||||
|
|
||||||
static address zero_aligned_words() { return _zero_aligned_words; }
|
static address zero_aligned_words() { return _zero_aligned_words; }
|
||||||
|
132
hotspot/test/compiler/7088419/CRCTest.java
Normal file
132
hotspot/test/compiler/7088419/CRCTest.java
Normal file
@ -0,0 +1,132 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
@test
|
||||||
|
@bug 7088419
|
||||||
|
@run main CRCTest
|
||||||
|
@summary Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32 and java.util.zip.Adler32
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.nio.ByteBuffer;
|
||||||
|
import java.util.zip.CRC32;
|
||||||
|
import java.util.zip.Checksum;
|
||||||
|
|
||||||
|
public class CRCTest {
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
|
||||||
|
byte[] b = initializedBytes(4096 * 4096);
|
||||||
|
|
||||||
|
{
|
||||||
|
CRC32 crc1 = new CRC32();
|
||||||
|
CRC32 crc2 = new CRC32();
|
||||||
|
CRC32 crc3 = new CRC32();
|
||||||
|
CRC32 crc4 = new CRC32();
|
||||||
|
|
||||||
|
crc1.update(b, 0, b.length);
|
||||||
|
updateSerial(crc2, b, 0, b.length);
|
||||||
|
updateDirect(crc3, b, 0, b.length);
|
||||||
|
updateSerialSlow(crc4, b, 0, b.length);
|
||||||
|
|
||||||
|
check(crc1, crc2);
|
||||||
|
check(crc3, crc4);
|
||||||
|
check(crc1, crc3);
|
||||||
|
|
||||||
|
crc1.update(17);
|
||||||
|
crc2.update(17);
|
||||||
|
crc3.update(17);
|
||||||
|
crc4.update(17);
|
||||||
|
|
||||||
|
crc1.update(b, 1, b.length-2);
|
||||||
|
updateSerial(crc2, b, 1, b.length-2);
|
||||||
|
updateDirect(crc3, b, 1, b.length-2);
|
||||||
|
updateSerialSlow(crc4, b, 1, b.length-2);
|
||||||
|
|
||||||
|
check(crc1, crc2);
|
||||||
|
check(crc3, crc4);
|
||||||
|
check(crc1, crc3);
|
||||||
|
|
||||||
|
report("finished huge crc", crc1, crc2, crc3, crc4);
|
||||||
|
|
||||||
|
for (int i = 0; i < 256; i++) {
|
||||||
|
for (int j = 0; j < 256; j += 1) {
|
||||||
|
crc1.update(b, i, j);
|
||||||
|
updateSerial(crc2, b, i, j);
|
||||||
|
updateDirect(crc3, b, i, j);
|
||||||
|
updateSerialSlow(crc4, b, i, j);
|
||||||
|
|
||||||
|
check(crc1, crc2);
|
||||||
|
check(crc3, crc4);
|
||||||
|
check(crc1, crc3);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
report("finished small survey crc", crc1, crc2, crc3, crc4);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void report(String s, Checksum crc1, Checksum crc2,
|
||||||
|
Checksum crc3, Checksum crc4) {
|
||||||
|
System.out.println(s + ", crc1 = " + crc1.getValue() +
|
||||||
|
", crc2 = " + crc2.getValue()+
|
||||||
|
", crc3 = " + crc3.getValue()+
|
||||||
|
", crc4 = " + crc4.getValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void check(Checksum crc1, Checksum crc2) throws Exception {
|
||||||
|
if (crc1.getValue() != crc2.getValue()) {
|
||||||
|
String s = "value 1 = " + crc1.getValue() + ", value 2 = " + crc2.getValue();
|
||||||
|
System.err.println(s);
|
||||||
|
throw new Exception(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static byte[] initializedBytes(int M) {
|
||||||
|
byte[] bytes = new byte[M];
|
||||||
|
for (int i = 0; i < bytes.length; i++) {
|
||||||
|
bytes[i] = (byte) i;
|
||||||
|
}
|
||||||
|
return bytes;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void updateSerial(Checksum crc, byte[] b, int start, int length) {
|
||||||
|
for (int i = 0; i < length; i++)
|
||||||
|
crc.update(b[i+start]);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void updateSerialSlow(Checksum crc, byte[] b, int start, int length) {
|
||||||
|
for (int i = 0; i < length; i++)
|
||||||
|
crc.update(b[i+start]);
|
||||||
|
crc.getValue();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void updateDirect(CRC32 crc3, byte[] b, int start, int length) {
|
||||||
|
ByteBuffer buf = ByteBuffer.allocateDirect(length);
|
||||||
|
buf.put(b, start, length);
|
||||||
|
buf.flip();
|
||||||
|
crc3.update(buf);
|
||||||
|
}
|
||||||
|
}
|
45
hotspot/test/runtime/8001071/Test8001071.java
Normal file
45
hotspot/test/runtime/8001071/Test8001071.java
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import sun.misc.Unsafe;
|
||||||
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
|
@SuppressWarnings("sunapi")
|
||||||
|
public class Test8001071 {
|
||||||
|
public static Unsafe unsafe;
|
||||||
|
|
||||||
|
static {
|
||||||
|
try {
|
||||||
|
Field f = Unsafe.class.getDeclaredField("theUnsafe");
|
||||||
|
f.setAccessible(true);
|
||||||
|
unsafe = (Unsafe) f.get(null);
|
||||||
|
} catch ( Exception e ) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String args[]) {
|
||||||
|
unsafe.getObject(new Test8001071(), Short.MAX_VALUE);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
63
hotspot/test/runtime/8001071/Test8001071.sh
Normal file
63
hotspot/test/runtime/8001071/Test8001071.sh
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
|
||||||
|
## @test
|
||||||
|
## @bug 8001071
|
||||||
|
## @summary Add simple range check into VM implemenation of Unsafe access methods
|
||||||
|
## @compile Test8001071.java
|
||||||
|
## @run shell Test8001071.sh
|
||||||
|
## @author filipp.zhinkin@oracle.com
|
||||||
|
|
||||||
|
VERSION=`${TESTJAVA}/bin/java ${TESTVMOPTS} -version 2>&1`
|
||||||
|
|
||||||
|
if [ -n "`echo $VERSION | grep debug`" -o -n "`echo $VERSION | grep jvmg`" ]; then
|
||||||
|
echo "Build type check passed"
|
||||||
|
echo "Continue testing"
|
||||||
|
else
|
||||||
|
echo "Fastdebug build is required for this test"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
${TESTJAVA}/bin/java -cp ${TESTCLASSES} ${TESTVMOPTS} Test8001071 2>&1
|
||||||
|
|
||||||
|
HS_ERR_FILE=hs_err_pid*.log
|
||||||
|
|
||||||
|
if [ ! -f $HS_ERR_FILE ]
|
||||||
|
then
|
||||||
|
echo "hs_err_pid log file was not found"
|
||||||
|
echo "Test failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
grep "assert(byte_offset < p_size) failed: Unsafe access: offset.*> object's size.*" $HS_ERR_FILE
|
||||||
|
|
||||||
|
if [ "0" = "$?" ];
|
||||||
|
then
|
||||||
|
echo "Range check assertion failed as expected"
|
||||||
|
echo "Test passed"
|
||||||
|
exit 0
|
||||||
|
else
|
||||||
|
echo "Range check assertion was not failed"
|
||||||
|
echo "Test failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
Loading…
x
Reference in New Issue
Block a user