Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
ac212237
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看板
提交
ac212237
编写于
1月 28, 2014
作者:
A
amurillo
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
e9684ff4
73002c32
变更
9
隐藏空白更改
内联
并排
Showing
9 changed file
with
209 addition
and
22 deletion
+209
-22
.hgtags
.hgtags
+1
-0
make/hotspot_version
make/hotspot_version
+1
-1
src/cpu/sparc/vm/sparc.ad
src/cpu/sparc/vm/sparc.ad
+20
-11
src/cpu/x86/vm/x86_32.ad
src/cpu/x86/vm/x86_32.ad
+14
-3
src/cpu/x86/vm/x86_64.ad
src/cpu/x86/vm/x86_64.ad
+14
-3
src/share/vm/code/dependencies.cpp
src/share/vm/code/dependencies.cpp
+2
-4
test/compiler/codegen/LoadWithMask.java
test/compiler/codegen/LoadWithMask.java
+44
-0
test/compiler/codegen/LoadWithMask2.java
test/compiler/codegen/LoadWithMask2.java
+55
-0
test/compiler/inlining/DefaultAndConcreteMethodsCHA.java
test/compiler/inlining/DefaultAndConcreteMethodsCHA.java
+58
-0
未找到文件。
.hgtags
浏览文件 @
ac212237
...
...
@@ -413,3 +413,4 @@ df333ee12bba67e2e928f8ce1da37afd9bf95b48 jdk8-b124
3585183c191aa6b4d0375ea659515335e1804417 hs25-b67
df333ee12bba67e2e928f8ce1da37afd9bf95b48 jdk8-b125
c8218f1072a0370f3ce4714469ced0613ee543ab jdk8-b126
d45454002494d147c0761e6b37d8a73064f3cf92 hs25-b68
make/hotspot_version
浏览文件 @
ac212237
...
...
@@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2014
HS_MAJOR_VER=25
HS_MINOR_VER=0
HS_BUILD_NUMBER=6
7
HS_BUILD_NUMBER=6
8
JDK_MAJOR_VER=1
JDK_MINOR_VER=8
...
...
src/cpu/sparc/vm/sparc.ad
浏览文件 @
ac212237
...
...
@@ -3355,8 +3355,8 @@ operand immI16() %{
interface(CONST_INTER);
%}
// Unsigned
(positive) Integer Immediate: 13-bit
operand immU1
3
() %{
// Unsigned
Integer Immediate: 12-bit (non-negative that fits in simm13)
operand immU1
2
() %{
predicate((0 <= n->get_int()) && Assembler::is_simm13(n->get_int()));
match(ConI);
op_cost(0);
...
...
@@ -3392,6 +3392,17 @@ operand immI5() %{
interface(CONST_INTER);
%}
// Int Immediate non-negative
operand immU31()
%{
predicate(n->get_int() >= 0);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Integer Immediate: 0-bit
operand immI0() %{
predicate(n->get_int() == 0);
...
...
@@ -5720,7 +5731,6 @@ instruct loadUS2L_immI16(iRegL dst, memory mem, immI16 mask, iRegL tmp) %{
effect(TEMP dst, TEMP tmp);
ins_cost(MEMORY_REF_COST + 2*DEFAULT_COST);
size((3+1)*4); // set may use two instructions.
format %{ "LDUH $mem,$dst\t! ushort/char & 16-bit mask -> long\n\t"
"SET $mask,$tmp\n\t"
"AND $dst,$tmp,$dst" %}
...
...
@@ -5842,13 +5852,13 @@ instruct loadI2L_immI_65535(iRegL dst, indOffset13m7 mem, immI_65535 mask) %{
ins_pipe(iload_mem);
%}
// Load Integer with a 1
3
-bit mask into a Long Register
instruct loadI2L_imm
I13(iRegL dst, memory mem, immI13
mask) %{
// Load Integer with a 1
2
-bit mask into a Long Register
instruct loadI2L_imm
U12(iRegL dst, memory mem, immU12
mask) %{
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
ins_cost(MEMORY_REF_COST + DEFAULT_COST);
size(2*4);
format %{ "LDUW $mem,$dst\t! int & 1
3
-bit mask -> long\n\t"
format %{ "LDUW $mem,$dst\t! int & 1
2
-bit mask -> long\n\t"
"AND $dst,$mask,$dst" %}
ins_encode %{
Register Rdst = $dst$$Register;
...
...
@@ -5858,14 +5868,13 @@ instruct loadI2L_immI13(iRegL dst, memory mem, immI13 mask) %{
ins_pipe(iload_mem);
%}
// Load Integer with a 3
2
-bit mask into a Long Register
instruct loadI2L_imm
I(iRegL dst, memory mem, immI
mask, iRegL tmp) %{
// Load Integer with a 3
1
-bit mask into a Long Register
instruct loadI2L_imm
U31(iRegL dst, memory mem, immU31
mask, iRegL tmp) %{
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
effect(TEMP dst, TEMP tmp);
ins_cost(MEMORY_REF_COST + 2*DEFAULT_COST);
size((3+1)*4); // set may use two instructions.
format %{ "LDUW $mem,$dst\t! int & 32-bit mask -> long\n\t"
format %{ "LDUW $mem,$dst\t! int & 31-bit mask -> long\n\t"
"SET $mask,$tmp\n\t"
"AND $dst,$tmp,$dst" %}
ins_encode %{
...
...
@@ -8960,7 +8969,7 @@ instruct testL_reg_con(flagsRegL xcc, iRegL op1, immL13 con, immL0 zero) %{
ins_pipe(ialu_cconly_reg_reg);
%}
instruct compU_iReg_imm13(flagsRegU icc, iRegI op1, immU1
3
op2 ) %{
instruct compU_iReg_imm13(flagsRegU icc, iRegI op1, immU1
2
op2 ) %{
match(Set icc (CmpU op1 op2));
size(4);
...
...
src/cpu/x86/vm/x86_32.ad
浏览文件 @
ac212237
...
...
@@ -3889,6 +3889,17 @@ operand immI16() %{
interface(CONST_INTER);
%}
// Int Immediate non-negative
operand immU31()
%{
predicate(n->get_int() >= 0);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Constant for long shifts
operand immI_32() %{
predicate( n->get_int() == 32 );
...
...
@@ -6119,12 +6130,12 @@ instruct loadI2L_immI_65535(eRegL dst, memory mem, immI_65535 mask, eFlagsReg cr
ins_pipe(ialu_reg_mem);
%}
// Load Integer with 3
2
-bit mask into Long Register
instruct loadI2L_imm
I(eRegL dst, memory mem, immI
mask, eFlagsReg cr) %{
// Load Integer with 3
1
-bit mask into Long Register
instruct loadI2L_imm
U31(eRegL dst, memory mem, immU31
mask, eFlagsReg cr) %{
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
effect(KILL cr);
format %{ "MOV $dst.lo,$mem\t# int & 3
2
-bit mask -> long\n\t"
format %{ "MOV $dst.lo,$mem\t# int & 3
1
-bit mask -> long\n\t"
"XOR $dst.hi,$dst.hi\n\t"
"AND $dst.lo,$mask" %}
ins_encode %{
...
...
src/cpu/x86/vm/x86_64.ad
浏览文件 @
ac212237
...
...
@@ -3086,6 +3086,17 @@ operand immI16()
interface(CONST_INTER);
%}
// Int Immediate non-negative
operand immU31()
%{
predicate(n->get_int() >= 0);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Constant for long shifts
operand immI_32()
%{
...
...
@@ -5042,12 +5053,12 @@ instruct loadI2L_immI_65535(rRegL dst, memory mem, immI_65535 mask) %{
ins_pipe(ialu_reg_mem);
%}
// Load Integer with a 3
2
-bit mask into Long Register
instruct loadI2L_imm
I(rRegL dst, memory mem, immI
mask, rFlagsReg cr) %{
// Load Integer with a 3
1
-bit mask into Long Register
instruct loadI2L_imm
U31(rRegL dst, memory mem, immU31
mask, rFlagsReg cr) %{
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
effect(KILL cr);
format %{ "movl $dst, $mem\t# int & 3
2
-bit mask -> long\n\t"
format %{ "movl $dst, $mem\t# int & 3
1
-bit mask -> long\n\t"
"andl $dst, $mask" %}
ins_encode %{
Register Rdst = $dst$$Register;
...
...
src/share/vm/code/dependencies.cpp
浏览文件 @
ac212237
...
...
@@ -1161,11 +1161,9 @@ bool Dependencies::is_concrete_method(Method* m) {
// We could also return false if m does not yet appear to be
// executed, if the VM version supports this distinction also.
// Default methods are considered "concrete" as well.
return
!
m
->
is_abstract
()
&&
!
InstanceKlass
::
cast
(
m
->
method_holder
())
->
is_interface
();
// TODO: investigate whether default methods should be
// considered as "concrete" in this situation. For now they
// are not.
!
m
->
is_overpass
();
// error functions aren't concrete
}
...
...
test/compiler/codegen/LoadWithMask.java
0 → 100644
浏览文件 @
ac212237
/*
* Copyright (c) 2014, 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 8032207
* @summary Invalid node sizing for loadUS2L_immI16 and loadI2L_immI
* @run main/othervm -server -Xbatch -XX:-TieredCompilation -XX:CompileCommand=compileonly,LoadWithMask.foo LoadWithMask
*
*/
public
class
LoadWithMask
{
static
int
x
[]
=
new
int
[
1
];
static
long
foo
()
{
return
x
[
0
]
&
0xfff0ffff
;
}
public
static
void
main
(
String
[]
args
)
{
x
[
0
]
=
-
1
;
long
l
=
0
;
for
(
int
i
=
0
;
i
<
100000
;
++
i
)
{
l
=
foo
();
}
}
}
test/compiler/codegen/LoadWithMask2.java
0 → 100644
浏览文件 @
ac212237
/*
* Copyright (c) 2014, 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 8031743
* @summary loadI2L_immI broken for negative memory values
* @run main/othervm -server -Xbatch -XX:-TieredCompilation -XX:CompileCommand=compileonly,*.foo* LoadWithMask2
*
*/
public
class
LoadWithMask2
{
static
int
x
;
static
long
foo1
()
{
return
x
&
0xfffffffe
;
}
static
long
foo2
()
{
return
x
&
0xff000000
;
}
static
long
foo3
()
{
return
x
&
0x8abcdef1
;
}
public
static
void
main
(
String
[]
args
)
{
x
=
-
1
;
long
l
=
0
;
for
(
int
i
=
0
;
i
<
100000
;
++
i
)
{
l
=
foo1
()
&
foo2
()
&
foo3
();
}
if
(
l
>
0
)
{
System
.
out
.
println
(
"FAILED"
);
System
.
exit
(
97
);
}
System
.
out
.
println
(
"PASSED"
);
}
}
test/compiler/inlining/DefaultAndConcreteMethodsCHA.java
0 → 100644
浏览文件 @
ac212237
/*
* Copyright (c) 2014, 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 8031695
* @summary CHA ignores default methods during analysis leading to incorrect code generation
*
* @run main/othervm -Xbatch DefaultAndConcreteMethodsCHA
*/
interface
I
{
default
int
m
()
{
return
0
;
}
}
class
A
implements
I
{}
class
C
extends
A
{
}
class
D
extends
A
{
public
int
m
()
{
return
1
;
}
}
public
class
DefaultAndConcreteMethodsCHA
{
public
static
int
test
(
A
obj
)
{
return
obj
.
m
();
}
public
static
void
main
(
String
[]
args
)
{
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
int
idC
=
test
(
new
C
());
if
(
idC
!=
0
)
{
throw
new
Error
(
"C.m didn't invoke I.m: id "
+
idC
);
}
int
idD
=
test
(
new
D
());
if
(
idD
!=
1
)
{
throw
new
Error
(
"D.m didn't invoke D.m: id "
+
idD
);
}
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录