提交 2eb26991 编写于 作者: R roland

8214206: Fix for JDK-8213419 is broken on 32-bit

Reviewed-by: mdoerr, shade
上级 e4baf3d5
...@@ -579,7 +579,7 @@ void LIR_Assembler::emit_op3(LIR_Op3* op) { ...@@ -579,7 +579,7 @@ void LIR_Assembler::emit_op3(LIR_Op3* op) {
__ and3(Rscratch, divisor - 1, Rscratch); __ and3(Rscratch, divisor - 1, Rscratch);
} }
__ add(Rdividend, Rscratch, Rscratch); __ add(Rdividend, Rscratch, Rscratch);
__ sra(Rscratch, log2_intptr(divisor), Rresult); __ sra(Rscratch, log2_int(divisor), Rresult);
return; return;
} else { } else {
if (divisor == 2) { if (divisor == 2) {
......
...@@ -294,11 +294,11 @@ void LIRGenerator::cmp_reg_mem(LIR_Condition condition, LIR_Opr reg, LIR_Opr bas ...@@ -294,11 +294,11 @@ void LIRGenerator::cmp_reg_mem(LIR_Condition condition, LIR_Opr reg, LIR_Opr bas
bool LIRGenerator::strength_reduce_multiply(LIR_Opr left, int c, LIR_Opr result, LIR_Opr tmp) { bool LIRGenerator::strength_reduce_multiply(LIR_Opr left, int c, LIR_Opr result, LIR_Opr tmp) {
assert(left != result, "should be different registers"); assert(left != result, "should be different registers");
if (is_power_of_2(c + 1)) { if (is_power_of_2(c + 1)) {
__ shift_left(left, log2_intptr(c + 1), result); __ shift_left(left, log2_int(c + 1), result);
__ sub(result, left, result); __ sub(result, left, result);
return true; return true;
} else if (is_power_of_2(c - 1)) { } else if (is_power_of_2(c - 1)) {
__ shift_left(left, log2_intptr(c - 1), result); __ shift_left(left, log2_int(c - 1), result);
__ add(result, left, result); __ add(result, left, result);
return true; return true;
} }
......
...@@ -2650,7 +2650,7 @@ void LIR_Assembler::arithmetic_idiv(LIR_Code code, LIR_Opr left, LIR_Opr right, ...@@ -2650,7 +2650,7 @@ void LIR_Assembler::arithmetic_idiv(LIR_Code code, LIR_Opr left, LIR_Opr right,
Register dreg = result->as_register(); Register dreg = result->as_register();
if (right->is_constant()) { if (right->is_constant()) {
int divisor = right->as_constant_ptr()->as_jint(); jint divisor = right->as_constant_ptr()->as_jint();
assert(divisor > 0 && is_power_of_2(divisor), "must be"); assert(divisor > 0 && is_power_of_2(divisor), "must be");
if (code == lir_idiv) { if (code == lir_idiv) {
assert(lreg == rax, "must be rax,"); assert(lreg == rax, "must be rax,");
...@@ -2662,7 +2662,7 @@ void LIR_Assembler::arithmetic_idiv(LIR_Code code, LIR_Opr left, LIR_Opr right, ...@@ -2662,7 +2662,7 @@ void LIR_Assembler::arithmetic_idiv(LIR_Code code, LIR_Opr left, LIR_Opr right,
__ andl(rdx, divisor - 1); __ andl(rdx, divisor - 1);
__ addl(lreg, rdx); __ addl(lreg, rdx);
} }
__ sarl(lreg, log2_intptr(divisor)); __ sarl(lreg, log2_jint(divisor));
move_regs(lreg, dreg); move_regs(lreg, dreg);
} else if (code == lir_irem) { } else if (code == lir_irem) {
Label done; Label done;
......
...@@ -237,12 +237,12 @@ bool LIRGenerator::strength_reduce_multiply(LIR_Opr left, int c, LIR_Opr result, ...@@ -237,12 +237,12 @@ bool LIRGenerator::strength_reduce_multiply(LIR_Opr left, int c, LIR_Opr result,
if (tmp->is_valid()) { if (tmp->is_valid()) {
if (is_power_of_2(c + 1)) { if (is_power_of_2(c + 1)) {
__ move(left, tmp); __ move(left, tmp);
__ shift_left(left, log2_intptr(c + 1), left); __ shift_left(left, log2_jint(c + 1), left);
__ sub(left, tmp, result); __ sub(left, tmp, result);
return true; return true;
} else if (is_power_of_2(c - 1)) { } else if (is_power_of_2(c - 1)) {
__ move(left, tmp); __ move(left, tmp);
__ shift_left(left, log2_intptr(c - 1), left); __ shift_left(left, log2_jint(c - 1), left);
__ add(left, tmp, result); __ add(left, tmp, result);
return true; return true;
} }
......
...@@ -131,7 +131,7 @@ static Node *transform_int_divide( PhaseGVN *phase, Node *dividend, jint divisor ...@@ -131,7 +131,7 @@ static Node *transform_int_divide( PhaseGVN *phase, Node *dividend, jint divisor
} }
// Add rounding to the shift to handle the sign bit // Add rounding to the shift to handle the sign bit
int l = log2_intptr(d-1)+1; int l = log2_jint(d-1)+1;
if (needs_rounding) { if (needs_rounding) {
// Divide-by-power-of-2 can be made into a shift, but you have to do // Divide-by-power-of-2 can be made into a shift, but you have to do
// more math for the rounding. You need to add 0 for positive // more math for the rounding. You need to add 0 for positive
......
...@@ -198,21 +198,21 @@ Node *MulINode::Ideal(PhaseGVN *phase, bool can_reshape) { ...@@ -198,21 +198,21 @@ Node *MulINode::Ideal(PhaseGVN *phase, bool can_reshape) {
Node *res = NULL; Node *res = NULL;
unsigned int bit1 = abs_con & (0-abs_con); // Extract low bit unsigned int bit1 = abs_con & (0-abs_con); // Extract low bit
if (bit1 == abs_con) { // Found a power of 2? if (bit1 == abs_con) { // Found a power of 2?
res = new (phase->C) LShiftINode(in(1), phase->intcon(log2_intptr(bit1))); res = new (phase->C) LShiftINode(in(1), phase->intcon(log2_uint(bit1)));
} else { } else {
// Check for constant with 2 bits set // Check for constant with 2 bits set
unsigned int bit2 = abs_con-bit1; unsigned int bit2 = abs_con-bit1;
bit2 = bit2 & (0-bit2); // Extract 2nd bit bit2 = bit2 & (0-bit2); // Extract 2nd bit
if (bit2 + bit1 == abs_con) { // Found all bits in con? if (bit2 + bit1 == abs_con) { // Found all bits in con?
Node *n1 = phase->transform( new (phase->C) LShiftINode(in(1), phase->intcon(log2_intptr(bit1)))); Node *n1 = phase->transform( new (phase->C) LShiftINode(in(1), phase->intcon(log2_uint(bit1))));
Node *n2 = phase->transform( new (phase->C) LShiftINode(in(1), phase->intcon(log2_intptr(bit2)))); Node *n2 = phase->transform( new (phase->C) LShiftINode(in(1), phase->intcon(log2_uint(bit2))));
res = new (phase->C) AddINode(n2, n1); res = new (phase->C) AddINode(n2, n1);
} else if (is_power_of_2(abs_con+1)) { } else if (is_power_of_2(abs_con+1)) {
// Sleezy: power-of-2 -1. Next time be generic. // Sleezy: power-of-2 -1. Next time be generic.
unsigned int temp = abs_con + 1; unsigned int temp = abs_con + 1;
Node *n1 = phase->transform(new (phase->C) LShiftINode(in(1), phase->intcon(log2_intptr(temp)))); Node *n1 = phase->transform(new (phase->C) LShiftINode(in(1), phase->intcon(log2_uint(temp))));
res = new (phase->C) SubINode(n1, in(1)); res = new (phase->C) SubINode(n1, in(1));
} else { } else {
return MulNode::Ideal(phase, can_reshape); return MulNode::Ideal(phase, can_reshape);
...@@ -444,7 +444,7 @@ Node *AndINode::Identity( PhaseTransform *phase ) { ...@@ -444,7 +444,7 @@ Node *AndINode::Identity( PhaseTransform *phase ) {
// Masking off high bits which are always zero is useless. // Masking off high bits which are always zero is useless.
const TypeInt* t1 = phase->type( in(1) )->isa_int(); const TypeInt* t1 = phase->type( in(1) )->isa_int();
if (t1 != NULL && t1->_lo >= 0) { if (t1 != NULL && t1->_lo >= 0) {
jint t1_support = right_n_bits(1 + log2_intptr(t1->_hi)); jint t1_support = right_n_bits(1 + log2_jint(t1->_hi));
if ((t1_support & con) == t1_support) if ((t1_support & con) == t1_support)
return in1; return in1;
} }
......
...@@ -47,8 +47,8 @@ void AdvancedThresholdPolicy::initialize() { ...@@ -47,8 +47,8 @@ void AdvancedThresholdPolicy::initialize() {
int count = CICompilerCount; int count = CICompilerCount;
if (CICompilerCountPerCPU) { if (CICompilerCountPerCPU) {
// Simple log n seems to grow too slowly for tiered, try something faster: log n * log log n // Simple log n seems to grow too slowly for tiered, try something faster: log n * log log n
int log_cpu = log2_intptr(os::active_processor_count()); int log_cpu = log2_int(os::active_processor_count());
int loglog_cpu = log2_intptr(MAX2(log_cpu, 1)); int loglog_cpu = log2_int(MAX2(log_cpu, 1));
count = MAX2(log_cpu * loglog_cpu, 1) * 3 / 2; count = MAX2(log_cpu * loglog_cpu, 1) * 3 / 2;
} }
......
...@@ -181,7 +181,7 @@ void NonTieredCompPolicy::initialize() { ...@@ -181,7 +181,7 @@ void NonTieredCompPolicy::initialize() {
// Example: if CICompilerCountPerCPU is true, then we get // Example: if CICompilerCountPerCPU is true, then we get
// max(log2(8)-1,1) = 2 compiler threads on an 8-way machine. // max(log2(8)-1,1) = 2 compiler threads on an 8-way machine.
// May help big-app startup time. // May help big-app startup time.
_compiler_count = MAX2(log2_intptr(os::active_processor_count())-1,1); _compiler_count = MAX2(log2_int(os::active_processor_count())-1,1);
FLAG_SET_ERGO(intx, CICompilerCount, _compiler_count); FLAG_SET_ERGO(intx, CICompilerCount, _compiler_count);
} else { } else {
_compiler_count = CICompilerCount; _compiler_count = CICompilerCount;
......
...@@ -1284,7 +1284,7 @@ char** os::split_path(const char* path, int* n) { ...@@ -1284,7 +1284,7 @@ char** os::split_path(const char* path, int* n) {
} }
void os::set_memory_serialize_page(address page) { void os::set_memory_serialize_page(address page) {
int count = log2_intptr(sizeof(class JavaThread)) - log2_intptr(64); int count = log2_intptr(sizeof(class JavaThread)) - log2_int(64);
_mem_serialize_page = (volatile int32_t *)page; _mem_serialize_page = (volatile int32_t *)page;
// We initialize the serialization page shift count here // We initialize the serialization page shift count here
// We assume a cache line size of 64 bytes // We assume a cache line size of 64 bytes
......
...@@ -139,7 +139,7 @@ void SimpleThresholdPolicy::initialize() { ...@@ -139,7 +139,7 @@ void SimpleThresholdPolicy::initialize() {
} }
int count = CICompilerCount; int count = CICompilerCount;
if (CICompilerCountPerCPU) { if (CICompilerCountPerCPU) {
count = MAX2(log2_intptr(os::active_processor_count()), 1) * 3 / 2; count = MAX2(log2_int(os::active_processor_count()), 1) * 3 / 2;
} }
set_c1_count(MAX2(count / 3, 1)); set_c1_count(MAX2(count / 3, 1));
set_c2_count(MAX2(count - c1_count(), 1)); set_c2_count(MAX2(count - c1_count(), 1));
......
...@@ -1149,8 +1149,7 @@ inline int log2_intptr(uintptr_t x) { ...@@ -1149,8 +1149,7 @@ inline int log2_intptr(uintptr_t x) {
} }
//* largest i such that 2^i <= x //* largest i such that 2^i <= x
// A negative value of 'x' will return '63' inline int log2_long(julong x) {
inline int log2_long(unsigned long x) {
int i = -1; int i = -1;
julong p = 1; julong p = 1;
while (p != 0 && p <= x) { while (p != 0 && p <= x) {
...@@ -1166,16 +1165,21 @@ inline int log2_intptr(intptr_t x) { ...@@ -1166,16 +1165,21 @@ inline int log2_intptr(intptr_t x) {
return log2_intptr((uintptr_t)x); return log2_intptr((uintptr_t)x);
} }
inline int log2_intptr(int x) { inline int log2_int(int x) {
return log2_intptr((uintptr_t)x); return log2_intptr((uintptr_t)x);
} }
inline int log2_intptr(uint x) { inline int log2_jint(jint x) {
return log2_intptr((uintptr_t)x); return log2_intptr((uintptr_t)x);
} }
inline int log2_long(jlong x) { inline int log2_uint(uint x) {
return log2_long((unsigned long)x); return log2_intptr((uintptr_t)x);
}
// A negative value of 'x' will return '63'
inline int log2_jlong(jlong x) {
return log2_long((julong)x);
} }
//* the argument must be exactly a power of 2 //* the argument must be exactly a power of 2
......
...@@ -55,7 +55,7 @@ template <MEMFLAGS F> BasicHashtableEntry<F>* BasicHashtable<F>::new_entry(unsig ...@@ -55,7 +55,7 @@ template <MEMFLAGS F> BasicHashtableEntry<F>* BasicHashtable<F>::new_entry(unsig
if (_first_free_entry + _entry_size >= _end_block) { if (_first_free_entry + _entry_size >= _end_block) {
int block_size = MIN2(512, MAX2((int)_table_size / 2, (int)_number_of_entries)); int block_size = MIN2(512, MAX2((int)_table_size / 2, (int)_number_of_entries));
int len = _entry_size * block_size; int len = _entry_size * block_size;
len = 1 << log2_intptr(len); // round down to power of 2 len = 1 << log2_int(len); // round down to power of 2
assert(len >= _entry_size, ""); assert(len >= _entry_size, "");
_first_free_entry = NEW_C_HEAP_ARRAY2(char, len, F, CURRENT_PC); _first_free_entry = NEW_C_HEAP_ARRAY2(char, len, F, CURRENT_PC);
_end_block = _first_free_entry + len; _end_block = _first_free_entry + len;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册