Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
7c7bbc3f
D
dragonwell8_hotspot
项目概览
openanolis
/
dragonwell8_hotspot
通知
2
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_hotspot
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
7c7bbc3f
编写于
1月 09, 2010
作者:
N
never
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6909839: missing unsigned compare cases for some cmoves in sparc.ad
Reviewed-by: kvn, jrose
上级
b993c798
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
348 addition
and
3 deletion
+348
-3
src/cpu/sparc/vm/sparc.ad
src/cpu/sparc/vm/sparc.ad
+66
-3
test/compiler/6909839/Test6909839.java
test/compiler/6909839/Test6909839.java
+282
-0
未找到文件。
src/cpu/sparc/vm/sparc.ad
浏览文件 @
7c7bbc3f
//
//
// Copyright 1998-20
09
Sun Microsystems, Inc. All Rights Reserved.
// Copyright 1998-20
10
Sun Microsystems, Inc. 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
...
@@ -6668,7 +6668,7 @@ instruct cmovII_imm(cmpOp cmp, flagsReg icc, iRegI dst, immI11 src) %{
...
@@ -6668,7 +6668,7 @@ instruct cmovII_imm(cmpOp cmp, flagsReg icc, iRegI dst, immI11 src) %{
ins_pipe(ialu_imm);
ins_pipe(ialu_imm);
%}
%}
instruct cmovII
_U
_reg(cmpOpU cmp, flagsRegU icc, iRegI dst, iRegI src) %{
instruct cmovII
u
_reg(cmpOpU cmp, flagsRegU icc, iRegI dst, iRegI src) %{
match(Set dst (CMoveI (Binary cmp icc) (Binary dst src)));
match(Set dst (CMoveI (Binary cmp icc) (Binary dst src)));
ins_cost(150);
ins_cost(150);
size(4);
size(4);
...
@@ -6677,7 +6677,7 @@ instruct cmovII_U_reg(cmpOpU cmp, flagsRegU icc, iRegI dst, iRegI src) %{
...
@@ -6677,7 +6677,7 @@ instruct cmovII_U_reg(cmpOpU cmp, flagsRegU icc, iRegI dst, iRegI src) %{
ins_pipe(ialu_reg);
ins_pipe(ialu_reg);
%}
%}
instruct cmovII
_U
_imm(cmpOpU cmp, flagsRegU icc, iRegI dst, immI11 src) %{
instruct cmovII
u
_imm(cmpOpU cmp, flagsRegU icc, iRegI dst, immI11 src) %{
match(Set dst (CMoveI (Binary cmp icc) (Binary dst src)));
match(Set dst (CMoveI (Binary cmp icc) (Binary dst src)));
ins_cost(140);
ins_cost(140);
size(4);
size(4);
...
@@ -6723,6 +6723,16 @@ instruct cmovNI_reg(cmpOp cmp, flagsReg icc, iRegN dst, iRegN src) %{
...
@@ -6723,6 +6723,16 @@ instruct cmovNI_reg(cmpOp cmp, flagsReg icc, iRegN dst, iRegN src) %{
ins_pipe(ialu_reg);
ins_pipe(ialu_reg);
%}
%}
// This instruction also works with CmpN so we don't need cmovNN_reg.
instruct cmovNIu_reg(cmpOpU cmp, flagsRegU icc, iRegN dst, iRegN src) %{
match(Set dst (CMoveN (Binary cmp icc) (Binary dst src)));
ins_cost(150);
size(4);
format %{ "MOV$cmp $icc,$src,$dst" %}
ins_encode( enc_cmov_reg(cmp,dst,src, (Assembler::icc)) );
ins_pipe(ialu_reg);
%}
instruct cmovNF_reg(cmpOpF cmp, flagsRegF fcc, iRegN dst, iRegN src) %{
instruct cmovNF_reg(cmpOpF cmp, flagsRegF fcc, iRegN dst, iRegN src) %{
match(Set dst (CMoveN (Binary cmp fcc) (Binary dst src)));
match(Set dst (CMoveN (Binary cmp fcc) (Binary dst src)));
ins_cost(150);
ins_cost(150);
...
@@ -6760,6 +6770,16 @@ instruct cmovPI_reg(cmpOp cmp, flagsReg icc, iRegP dst, iRegP src) %{
...
@@ -6760,6 +6770,16 @@ instruct cmovPI_reg(cmpOp cmp, flagsReg icc, iRegP dst, iRegP src) %{
ins_pipe(ialu_reg);
ins_pipe(ialu_reg);
%}
%}
instruct cmovPIu_reg(cmpOpU cmp, flagsRegU icc, iRegP dst, iRegP src) %{
match(Set dst (CMoveP (Binary cmp icc) (Binary dst src)));
ins_cost(150);
size(4);
format %{ "MOV$cmp $icc,$src,$dst\t! ptr" %}
ins_encode( enc_cmov_reg(cmp,dst,src, (Assembler::icc)) );
ins_pipe(ialu_reg);
%}
instruct cmovPI_imm(cmpOp cmp, flagsReg icc, iRegP dst, immP0 src) %{
instruct cmovPI_imm(cmpOp cmp, flagsReg icc, iRegP dst, immP0 src) %{
match(Set dst (CMoveP (Binary cmp icc) (Binary dst src)));
match(Set dst (CMoveP (Binary cmp icc) (Binary dst src)));
ins_cost(140);
ins_cost(140);
...
@@ -6770,6 +6790,16 @@ instruct cmovPI_imm(cmpOp cmp, flagsReg icc, iRegP dst, immP0 src) %{
...
@@ -6770,6 +6790,16 @@ instruct cmovPI_imm(cmpOp cmp, flagsReg icc, iRegP dst, immP0 src) %{
ins_pipe(ialu_imm);
ins_pipe(ialu_imm);
%}
%}
instruct cmovPIu_imm(cmpOpU cmp, flagsRegU icc, iRegP dst, immP0 src) %{
match(Set dst (CMoveP (Binary cmp icc) (Binary dst src)));
ins_cost(140);
size(4);
format %{ "MOV$cmp $icc,$src,$dst\t! ptr" %}
ins_encode( enc_cmov_imm(cmp,dst,src, (Assembler::icc)) );
ins_pipe(ialu_imm);
%}
instruct cmovPF_reg(cmpOpF cmp, flagsRegF fcc, iRegP dst, iRegP src) %{
instruct cmovPF_reg(cmpOpF cmp, flagsRegF fcc, iRegP dst, iRegP src) %{
match(Set dst (CMoveP (Binary cmp fcc) (Binary dst src)));
match(Set dst (CMoveP (Binary cmp fcc) (Binary dst src)));
ins_cost(150);
ins_cost(150);
...
@@ -6809,6 +6839,17 @@ instruct cmovFI_reg(cmpOp cmp, flagsReg icc, regF dst, regF src) %{
...
@@ -6809,6 +6839,17 @@ instruct cmovFI_reg(cmpOp cmp, flagsReg icc, regF dst, regF src) %{
ins_pipe(int_conditional_float_move);
ins_pipe(int_conditional_float_move);
%}
%}
instruct cmovFIu_reg(cmpOpU cmp, flagsRegU icc, regF dst, regF src) %{
match(Set dst (CMoveF (Binary cmp icc) (Binary dst src)));
ins_cost(150);
size(4);
format %{ "FMOVS$cmp $icc,$src,$dst" %}
opcode(0x101);
ins_encode( enc_cmovf_reg(cmp,dst,src, (Assembler::icc)) );
ins_pipe(int_conditional_float_move);
%}
// Conditional move,
// Conditional move,
instruct cmovFF_reg(cmpOpF cmp, flagsRegF fcc, regF dst, regF src) %{
instruct cmovFF_reg(cmpOpF cmp, flagsRegF fcc, regF dst, regF src) %{
match(Set dst (CMoveF (Binary cmp fcc) (Binary dst src)));
match(Set dst (CMoveF (Binary cmp fcc) (Binary dst src)));
...
@@ -6842,6 +6883,17 @@ instruct cmovDI_reg(cmpOp cmp, flagsReg icc, regD dst, regD src) %{
...
@@ -6842,6 +6883,17 @@ instruct cmovDI_reg(cmpOp cmp, flagsReg icc, regD dst, regD src) %{
ins_pipe(int_conditional_double_move);
ins_pipe(int_conditional_double_move);
%}
%}
instruct cmovDIu_reg(cmpOpU cmp, flagsRegU icc, regD dst, regD src) %{
match(Set dst (CMoveD (Binary cmp icc) (Binary dst src)));
ins_cost(150);
size(4);
format %{ "FMOVD$cmp $icc,$src,$dst" %}
opcode(0x102);
ins_encode( enc_cmovf_reg(cmp,dst,src, (Assembler::icc)) );
ins_pipe(int_conditional_double_move);
%}
// Conditional move,
// Conditional move,
instruct cmovDF_reg(cmpOpF cmp, flagsRegF fcc, regD dst, regD src) %{
instruct cmovDF_reg(cmpOpF cmp, flagsRegF fcc, regD dst, regD src) %{
match(Set dst (CMoveD (Binary cmp fcc) (Binary dst src)));
match(Set dst (CMoveD (Binary cmp fcc) (Binary dst src)));
...
@@ -6881,6 +6933,17 @@ instruct cmovLI_reg(cmpOp cmp, flagsReg icc, iRegL dst, iRegL src) %{
...
@@ -6881,6 +6933,17 @@ instruct cmovLI_reg(cmpOp cmp, flagsReg icc, iRegL dst, iRegL src) %{
%}
%}
instruct cmovLIu_reg(cmpOpU cmp, flagsRegU icc, iRegL dst, iRegL src) %{
match(Set dst (CMoveL (Binary cmp icc) (Binary dst src)));
ins_cost(150);
size(4);
format %{ "MOV$cmp $icc,$src,$dst\t! long" %}
ins_encode( enc_cmov_reg(cmp,dst,src, (Assembler::icc)) );
ins_pipe(ialu_reg);
%}
instruct cmovLF_reg(cmpOpF cmp, flagsRegF fcc, iRegL dst, iRegL src) %{
instruct cmovLF_reg(cmpOpF cmp, flagsRegF fcc, iRegL dst, iRegL src) %{
match(Set dst (CMoveL (Binary cmp fcc) (Binary dst src)));
match(Set dst (CMoveL (Binary cmp fcc) (Binary dst src)));
ins_cost(150);
ins_cost(150);
...
...
test/compiler/6909839/Test6909839.java
0 → 100644
浏览文件 @
7c7bbc3f
/*
* Copyright 2010 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*
*/
/**
* @test
* @bug 6909839
* @summary missing unsigned compare cases for some cmoves in sparc.ad
*
* @run main/othervm -XX:+AggressiveOpts -Xbatch Test6909839
*/
public
class
Test6909839
{
public
static
void
main
(
String
[]
args
)
{
testi
();
testi
();
testi
();
testui
();
testui
();
testui
();
testdi
();
testdi
();
testdi
();
testfi
();
testfi
();
testfi
();
testl
();
testl
();
testl
();
testul
();
testul
();
testul
();
testdl
();
testdl
();
testdl
();
testfl
();
testfl
();
testfl
();
testf
();
testf
();
testf
();
testuf
();
testuf
();
testuf
();
testdf
();
testdf
();
testdf
();
testff
();
testff
();
testff
();
testd
();
testd
();
testd
();
testud
();
testud
();
testud
();
testdd
();
testdd
();
testdd
();
testfd
();
testfd
();
testfd
();
testp
();
testp
();
testp
();
testup
();
testup
();
testup
();
testdp
();
testdp
();
testdp
();
testfp
();
testfp
();
testfp
();
}
static
void
testui
()
{
int
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
((
v
>=
1
&&
v
<
3
)
?
1
:
2
);
}
System
.
out
.
println
(
total
);
}
static
void
testdi
()
{
int
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
(
v
>
1.0
)
?
1
:
2
;
}
System
.
out
.
println
(
total
);
}
static
void
testfi
()
{
int
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
(
v
>
1.0f
)
?
1
:
2
;
}
System
.
out
.
println
(
total
);
}
static
void
testi
()
{
int
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
total
+=
(
i
%
4
!=
0
)
?
1
:
2
;
}
System
.
out
.
println
(
total
);
}
static
void
testul
()
{
long
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
((
v
>=
1
&&
v
<
3
)
?
1L
:
2L
);
}
System
.
out
.
println
(
total
);
}
static
void
testdl
()
{
long
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
(
v
>
1.0
)
?
1L
:
2L
;
}
System
.
out
.
println
(
total
);
}
static
void
testfl
()
{
long
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
(
v
>
1.0f
)
?
1L
:
2L
;
}
System
.
out
.
println
(
total
);
}
static
void
testl
()
{
long
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
total
+=
(
i
%
4
!=
0
)
?
1L
:
2L
;
}
System
.
out
.
println
(
total
);
}
static
void
testuf
()
{
float
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
((
v
>=
1
&&
v
<
3
)
?
1.0f
:
2.0f
);
}
System
.
out
.
println
(
total
);
}
static
void
testdf
()
{
float
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
(
v
>
0.0
)
?
1.0f
:
2.0f
;
}
System
.
out
.
println
(
total
);
}
static
void
testff
()
{
float
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
(
v
>
0.0f
)
?
1.0f
:
2.0f
;
}
System
.
out
.
println
(
total
);
}
static
void
testf
()
{
float
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
total
+=
(
i
%
4
!=
0
)
?
1.0f
:
2.0f
;
}
System
.
out
.
println
(
total
);
}
static
void
testud
()
{
double
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
((
v
>=
1
&&
v
<
3
)
?
1.0d
:
2.0d
);
}
System
.
out
.
println
(
total
);
}
static
void
testdd
()
{
double
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
(
v
>
1.0
)
?
1.0d
:
2.0d
;
}
System
.
out
.
println
(
total
);
}
static
void
testfd
()
{
double
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
(
v
>
1.0f
)
?
1.0d
:
2.0d
;
}
System
.
out
.
println
(
total
);
}
static
void
testd
()
{
double
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
total
+=
(
i
%
4
!=
0
)
?
1.0d
:
2.0d
;
}
System
.
out
.
println
(
total
);
}
static
void
testp
()
{
Object
a
=
new
Object
();
Object
b
=
new
Object
();;
int
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
total
+=
((
i
%
4
!=
0
)
?
a
:
b
).
hashCode
();
}
System
.
out
.
println
(
total
);
}
static
void
testup
()
{
Object
a
=
new
Object
();
Object
b
=
new
Object
();;
int
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
((
v
>=
1
&&
v
<
3
)
?
a
:
b
).
hashCode
();
}
System
.
out
.
println
(
total
);
}
static
void
testdp
()
{
Object
a
=
new
Object
();
Object
b
=
new
Object
();;
int
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
((
v
>
1.0
)
?
a
:
b
).
hashCode
();
}
System
.
out
.
println
(
total
);
}
static
void
testfp
()
{
Object
a
=
new
Object
();
Object
b
=
new
Object
();;
int
total
=
0
;
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
v
=
i
%
4
;
total
+=
((
v
>
1.0f
)
?
a
:
b
).
hashCode
();
}
System
.
out
.
println
(
total
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录