Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
f4457d55
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看板
提交
f4457d55
编写于
1月 30, 2014
作者:
A
asaha
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
36e2f728
393ed404
变更
10
显示空白变更内容
内联
并排
Showing
10 changed file
with
212 addition
and
23 deletion
+212
-23
.hgtags
.hgtags
+3
-0
THIRD_PARTY_README
THIRD_PARTY_README
+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
src/share/vm/opto/c2_globals.hpp
src/share/vm/opto/c2_globals.hpp
+1
-1
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
浏览文件 @
f4457d55
...
@@ -413,6 +413,9 @@ df333ee12bba67e2e928f8ce1da37afd9bf95b48 jdk8-b124
...
@@ -413,6 +413,9 @@ df333ee12bba67e2e928f8ce1da37afd9bf95b48 jdk8-b124
3585183c191aa6b4d0375ea659515335e1804417 hs25-b67
3585183c191aa6b4d0375ea659515335e1804417 hs25-b67
df333ee12bba67e2e928f8ce1da37afd9bf95b48 jdk8-b125
df333ee12bba67e2e928f8ce1da37afd9bf95b48 jdk8-b125
c8218f1072a0370f3ce4714469ced0613ee543ab jdk8-b126
c8218f1072a0370f3ce4714469ced0613ee543ab jdk8-b126
d45454002494d147c0761e6b37d8a73064f3cf92 hs25-b68
32f017489ba5dd1bedabb9fa1d26bcc74d0a72b6 hs25-b69
35038da7bb9ddd367a0a6bf926dfb281aee1d554 jdk8-b127
4a35ef38e2a7bc64df20c7700ba69b37e3ddb8b5 jdk8u5-b01
4a35ef38e2a7bc64df20c7700ba69b37e3ddb8b5 jdk8u5-b01
e5561d89fe8bfc79cd6c8fcc36d270cc6a49ec6e jdk8u5-b02
e5561d89fe8bfc79cd6c8fcc36d270cc6a49ec6e jdk8u5-b02
2f9eb9fcab6c42c8c84ddb44170ea33235116d84 jdk8u5-b03
2f9eb9fcab6c42c8c84ddb44170ea33235116d84 jdk8u5-b03
...
...
THIRD_PARTY_README
浏览文件 @
f4457d55
...
@@ -1400,7 +1400,7 @@ THE SOFTWARE.
...
@@ -1400,7 +1400,7 @@ THE SOFTWARE.
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
%% This notice is provided with respect to Little CMS 2.4, which may be
%% This notice is provided with respect to Little CMS 2.4, which may be
included with OpenJDK 8.
included with
JRE 8, JDK 8, and
OpenJDK 8.
--- begin of LICENSE ---
--- begin of LICENSE ---
...
...
src/cpu/sparc/vm/sparc.ad
浏览文件 @
f4457d55
...
@@ -3355,8 +3355,8 @@ operand immI16() %{
...
@@ -3355,8 +3355,8 @@ operand immI16() %{
interface(CONST_INTER);
interface(CONST_INTER);
%}
%}
// Unsigned
(positive) Integer Immediate: 13-bit
// Unsigned
Integer Immediate: 12-bit (non-negative that fits in simm13)
operand immU1
3
() %{
operand immU1
2
() %{
predicate((0 <= n->get_int()) && Assembler::is_simm13(n->get_int()));
predicate((0 <= n->get_int()) && Assembler::is_simm13(n->get_int()));
match(ConI);
match(ConI);
op_cost(0);
op_cost(0);
...
@@ -3392,6 +3392,17 @@ operand immI5() %{
...
@@ -3392,6 +3392,17 @@ operand immI5() %{
interface(CONST_INTER);
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
// Integer Immediate: 0-bit
operand immI0() %{
operand immI0() %{
predicate(n->get_int() == 0);
predicate(n->get_int() == 0);
...
@@ -5720,7 +5731,6 @@ instruct loadUS2L_immI16(iRegL dst, memory mem, immI16 mask, iRegL tmp) %{
...
@@ -5720,7 +5731,6 @@ instruct loadUS2L_immI16(iRegL dst, memory mem, immI16 mask, iRegL tmp) %{
effect(TEMP dst, TEMP tmp);
effect(TEMP dst, TEMP tmp);
ins_cost(MEMORY_REF_COST + 2*DEFAULT_COST);
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"
format %{ "LDUH $mem,$dst\t! ushort/char & 16-bit mask -> long\n\t"
"SET $mask,$tmp\n\t"
"SET $mask,$tmp\n\t"
"AND $dst,$tmp,$dst" %}
"AND $dst,$tmp,$dst" %}
...
@@ -5842,13 +5852,13 @@ instruct loadI2L_immI_65535(iRegL dst, indOffset13m7 mem, immI_65535 mask) %{
...
@@ -5842,13 +5852,13 @@ instruct loadI2L_immI_65535(iRegL dst, indOffset13m7 mem, immI_65535 mask) %{
ins_pipe(iload_mem);
ins_pipe(iload_mem);
%}
%}
// Load Integer with a 1
3
-bit mask into a Long Register
// Load Integer with a 1
2
-bit mask into a Long Register
instruct loadI2L_imm
I13(iRegL dst, memory mem, immI13
mask) %{
instruct loadI2L_imm
U12(iRegL dst, memory mem, immU12
mask) %{
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
ins_cost(MEMORY_REF_COST + DEFAULT_COST);
ins_cost(MEMORY_REF_COST + DEFAULT_COST);
size(2*4);
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" %}
"AND $dst,$mask,$dst" %}
ins_encode %{
ins_encode %{
Register Rdst = $dst$$Register;
Register Rdst = $dst$$Register;
...
@@ -5858,14 +5868,13 @@ instruct loadI2L_immI13(iRegL dst, memory mem, immI13 mask) %{
...
@@ -5858,14 +5868,13 @@ instruct loadI2L_immI13(iRegL dst, memory mem, immI13 mask) %{
ins_pipe(iload_mem);
ins_pipe(iload_mem);
%}
%}
// Load Integer with a 3
2
-bit mask into a Long Register
// Load Integer with a 3
1
-bit mask into a Long Register
instruct loadI2L_imm
I(iRegL dst, memory mem, immI
mask, iRegL tmp) %{
instruct loadI2L_imm
U31(iRegL dst, memory mem, immU31
mask, iRegL tmp) %{
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
effect(TEMP dst, TEMP tmp);
effect(TEMP dst, TEMP tmp);
ins_cost(MEMORY_REF_COST + 2*DEFAULT_COST);
ins_cost(MEMORY_REF_COST + 2*DEFAULT_COST);
size((3+1)*4); // set may use two instructions.
format %{ "LDUW $mem,$dst\t! int & 31-bit mask -> long\n\t"
format %{ "LDUW $mem,$dst\t! int & 32-bit mask -> long\n\t"
"SET $mask,$tmp\n\t"
"SET $mask,$tmp\n\t"
"AND $dst,$tmp,$dst" %}
"AND $dst,$tmp,$dst" %}
ins_encode %{
ins_encode %{
...
@@ -8960,7 +8969,7 @@ instruct testL_reg_con(flagsRegL xcc, iRegL op1, immL13 con, immL0 zero) %{
...
@@ -8960,7 +8969,7 @@ instruct testL_reg_con(flagsRegL xcc, iRegL op1, immL13 con, immL0 zero) %{
ins_pipe(ialu_cconly_reg_reg);
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));
match(Set icc (CmpU op1 op2));
size(4);
size(4);
...
...
src/cpu/x86/vm/x86_32.ad
浏览文件 @
f4457d55
...
@@ -3889,6 +3889,17 @@ operand immI16() %{
...
@@ -3889,6 +3889,17 @@ operand immI16() %{
interface(CONST_INTER);
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
// Constant for long shifts
operand immI_32() %{
operand immI_32() %{
predicate( n->get_int() == 32 );
predicate( n->get_int() == 32 );
...
@@ -6119,12 +6130,12 @@ instruct loadI2L_immI_65535(eRegL dst, memory mem, immI_65535 mask, eFlagsReg cr
...
@@ -6119,12 +6130,12 @@ instruct loadI2L_immI_65535(eRegL dst, memory mem, immI_65535 mask, eFlagsReg cr
ins_pipe(ialu_reg_mem);
ins_pipe(ialu_reg_mem);
%}
%}
// Load Integer with 3
2
-bit mask into Long Register
// Load Integer with 3
1
-bit mask into Long Register
instruct loadI2L_imm
I(eRegL dst, memory mem, immI
mask, eFlagsReg cr) %{
instruct loadI2L_imm
U31(eRegL dst, memory mem, immU31
mask, eFlagsReg cr) %{
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
effect(KILL cr);
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"
"XOR $dst.hi,$dst.hi\n\t"
"AND $dst.lo,$mask" %}
"AND $dst.lo,$mask" %}
ins_encode %{
ins_encode %{
...
...
src/cpu/x86/vm/x86_64.ad
浏览文件 @
f4457d55
...
@@ -3086,6 +3086,17 @@ operand immI16()
...
@@ -3086,6 +3086,17 @@ operand immI16()
interface(CONST_INTER);
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
// Constant for long shifts
operand immI_32()
operand immI_32()
%{
%{
...
@@ -5042,12 +5053,12 @@ instruct loadI2L_immI_65535(rRegL dst, memory mem, immI_65535 mask) %{
...
@@ -5042,12 +5053,12 @@ instruct loadI2L_immI_65535(rRegL dst, memory mem, immI_65535 mask) %{
ins_pipe(ialu_reg_mem);
ins_pipe(ialu_reg_mem);
%}
%}
// Load Integer with a 3
2
-bit mask into Long Register
// Load Integer with a 3
1
-bit mask into Long Register
instruct loadI2L_imm
I(rRegL dst, memory mem, immI
mask, rFlagsReg cr) %{
instruct loadI2L_imm
U31(rRegL dst, memory mem, immU31
mask, rFlagsReg cr) %{
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
effect(KILL cr);
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" %}
"andl $dst, $mask" %}
ins_encode %{
ins_encode %{
Register Rdst = $dst$$Register;
Register Rdst = $dst$$Register;
...
...
src/share/vm/code/dependencies.cpp
浏览文件 @
f4457d55
...
@@ -1161,11 +1161,9 @@ bool Dependencies::is_concrete_method(Method* m) {
...
@@ -1161,11 +1161,9 @@ bool Dependencies::is_concrete_method(Method* m) {
// We could also return false if m does not yet appear to be
// We could also return false if m does not yet appear to be
// executed, if the VM version supports this distinction also.
// executed, if the VM version supports this distinction also.
// Default methods are considered "concrete" as well.
return
!
m
->
is_abstract
()
&&
return
!
m
->
is_abstract
()
&&
!
InstanceKlass
::
cast
(
m
->
method_holder
())
->
is_interface
();
!
m
->
is_overpass
();
// error functions aren't concrete
// TODO: investigate whether default methods should be
// considered as "concrete" in this situation. For now they
// are not.
}
}
...
...
src/share/vm/opto/c2_globals.hpp
浏览文件 @
f4457d55
...
@@ -445,7 +445,7 @@
...
@@ -445,7 +445,7 @@
notproduct(bool, PrintEliminateLocks, false, \
notproduct(bool, PrintEliminateLocks, false, \
"Print out when locks are eliminated") \
"Print out when locks are eliminated") \
\
\
product(bool, EliminateAutoBox,
true,
\
product(bool, EliminateAutoBox,
false,
\
"Control optimizations for autobox elimination") \
"Control optimizations for autobox elimination") \
\
\
experimental(bool, UseImplicitStableValues, false, \
experimental(bool, UseImplicitStableValues, false, \
...
...
test/compiler/codegen/LoadWithMask.java
0 → 100644
浏览文件 @
f4457d55
/*
* 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
浏览文件 @
f4457d55
/*
* 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
浏览文件 @
f4457d55
/*
* 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.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录