提交 f823a539 编写于 作者: R roland

7174532: jdk/test/java/lang/Math/WorstCaseTests.java failing on x86

Summary: increase precision on x86 for the steps of the computation of exp and pow.
Reviewed-by: kvn
上级 91f85dd2
master
Tags不可用
无相关合并请求
...@@ -6927,21 +6927,42 @@ void MacroAssembler::pow_exp_core_encoding() { ...@@ -6927,21 +6927,42 @@ void MacroAssembler::pow_exp_core_encoding() {
addptr(rsp,sizeof(jdouble)); addptr(rsp,sizeof(jdouble));
} }
void MacroAssembler::increase_precision() {
subptr(rsp, BytesPerWord);
fnstcw(Address(rsp, 0));
movl(rax, Address(rsp, 0));
orl(rax, 0x300);
push(rax);
fldcw(Address(rsp, 0));
pop(rax);
}
void MacroAssembler::restore_precision() {
fldcw(Address(rsp, 0));
addptr(rsp, BytesPerWord);
}
void MacroAssembler::fast_pow() { void MacroAssembler::fast_pow() {
// computes X^Y = 2^(Y * log2(X)) // computes X^Y = 2^(Y * log2(X))
// if fast computation is not possible, result is NaN. Requires // if fast computation is not possible, result is NaN. Requires
// fallback from user of this macro. // fallback from user of this macro.
// increase precision for intermediate steps of the computation
increase_precision();
fyl2x(); // Stack: (Y*log2(X)) ... fyl2x(); // Stack: (Y*log2(X)) ...
pow_exp_core_encoding(); // Stack: exp(X) ... pow_exp_core_encoding(); // Stack: exp(X) ...
restore_precision();
} }
void MacroAssembler::fast_exp() { void MacroAssembler::fast_exp() {
// computes exp(X) = 2^(X * log2(e)) // computes exp(X) = 2^(X * log2(e))
// if fast computation is not possible, result is NaN. Requires // if fast computation is not possible, result is NaN. Requires
// fallback from user of this macro. // fallback from user of this macro.
// increase precision for intermediate steps of the computation
increase_precision();
fldl2e(); // Stack: log2(e) X ... fldl2e(); // Stack: log2(e) X ...
fmulp(1); // Stack: (X*log2(e)) ... fmulp(1); // Stack: (X*log2(e)) ...
pow_exp_core_encoding(); // Stack: exp(X) ... pow_exp_core_encoding(); // Stack: exp(X) ...
restore_precision();
} }
void MacroAssembler::pow_or_exp(bool is_exp, int num_fpu_regs_in_use) { void MacroAssembler::pow_or_exp(bool is_exp, int num_fpu_regs_in_use) {
......
...@@ -2395,6 +2395,8 @@ class MacroAssembler: public Assembler { ...@@ -2395,6 +2395,8 @@ class MacroAssembler: public Assembler {
// runtime call. // runtime call.
void fast_pow(); void fast_pow();
void fast_exp(); void fast_exp();
void increase_precision();
void restore_precision();
// computes exp(x). Fallback to runtime call included. // computes exp(x). Fallback to runtime call included.
void exp_with_fallback(int num_fpu_regs_in_use) { pow_or_exp(true, num_fpu_regs_in_use); } void exp_with_fallback(int num_fpu_regs_in_use) { pow_or_exp(true, num_fpu_regs_in_use); }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
反馈
建议
客服 返回
顶部