Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
9afdb690
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看板
提交
9afdb690
编写于
10月 25, 2018
作者:
K
kevinw
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
c1eb9665
008e0463
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
207 addition
and
6 deletion
+207
-6
src/share/vm/classfile/verificationType.cpp
src/share/vm/classfile/verificationType.cpp
+2
-2
src/share/vm/opto/cfgnode.cpp
src/share/vm/opto/cfgnode.cpp
+1
-0
src/share/vm/opto/coalesce.cpp
src/share/vm/opto/coalesce.cpp
+29
-3
src/share/vm/opto/machnode.cpp
src/share/vm/opto/machnode.cpp
+1
-0
src/share/vm/opto/matcher.cpp
src/share/vm/opto/matcher.cpp
+3
-0
src/share/vm/utilities/exceptions.hpp
src/share/vm/utilities/exceptions.hpp
+1
-1
test/compiler/c2/SubsumingLoadsCauseFlagSpill.java
test/compiler/c2/SubsumingLoadsCauseFlagSpill.java
+72
-0
test/compiler/gcbarriers/TestMembarDependencies.java
test/compiler/gcbarriers/TestMembarDependencies.java
+98
-0
未找到文件。
src/share/vm/classfile/verificationType.cpp
浏览文件 @
9afdb690
/*
* Copyright (c) 2003, 201
7
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2003, 201
8
, 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
...
...
@@ -99,7 +99,7 @@ bool VerificationType::is_reference_assignable_from(
VerificationType
comp_from
=
from
.
get_component
(
context
,
CHECK_false
);
if
(
!
comp_this
.
is_bogus
()
&&
!
comp_from
.
is_bogus
())
{
return
comp_this
.
is_assignable_from
(
comp_from
,
context
,
from_field_is_protected
,
CHECK_false
);
from_field_is_protected
,
THREAD
);
}
}
return
false
;
...
...
src/share/vm/opto/cfgnode.cpp
浏览文件 @
9afdb690
...
...
@@ -2016,6 +2016,7 @@ const RegMask &PhiNode::out_RegMask() const {
uint
ideal_reg
=
_type
->
ideal_reg
();
assert
(
ideal_reg
!=
Node
::
NotAMachineReg
,
"invalid type at Phi"
);
if
(
ideal_reg
==
0
)
return
RegMask
::
Empty
;
assert
(
ideal_reg
!=
Op_RegFlags
,
"flags register is not spillable"
);
return
*
(
Compile
::
current
()
->
matcher
()
->
idealreg2spillmask
[
ideal_reg
]);
}
...
...
src/share/vm/opto/coalesce.cpp
浏览文件 @
9afdb690
...
...
@@ -25,6 +25,7 @@
#include "precompiled.hpp"
#include "memory/allocation.inline.hpp"
#include "opto/block.hpp"
#include "opto/c2compiler.hpp"
#include "opto/cfgnode.hpp"
#include "opto/chaitin.hpp"
#include "opto/coalesce.hpp"
...
...
@@ -292,7 +293,18 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) {
// Copy any flags as well
_phc
.
clone_projs
(
pred
,
pred
->
end_idx
(),
m
,
copy
,
_phc
.
_lrg_map
);
}
else
{
const
RegMask
*
rm
=
C
->
matcher
()
->
idealreg2spillmask
[
m
->
ideal_reg
()];
int
ireg
=
m
->
ideal_reg
();
if
(
ireg
==
0
||
ireg
==
Op_RegFlags
)
{
if
(
C
->
subsume_loads
())
{
C
->
record_failure
(
C2Compiler
::
retry_no_subsuming_loads
());
}
else
{
assert
(
false
,
err_msg
(
"attempted to spill a non-spillable item: %d: %s, ireg = %d"
,
m
->
_idx
,
m
->
Name
(),
ireg
));
C
->
record_method_not_compilable
(
"attempted to spill a non-spillable item"
);
}
return
;
}
const
RegMask
*
rm
=
C
->
matcher
()
->
idealreg2spillmask
[
ireg
];
copy
=
new
(
C
)
MachSpillCopyNode
(
m
,
*
rm
,
*
rm
);
// Find a good place to insert. Kinda tricky, use a subroutine
insert_copy_with_overlap
(
pred
,
copy
,
phi_name
,
src_name
);
...
...
@@ -326,7 +338,14 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) {
b
->
insert_node
(
copy
,
l
++
);
l
+=
_phc
.
clone_projs
(
b
,
l
,
m
,
copy
,
_phc
.
_lrg_map
);
}
else
{
const
RegMask
*
rm
=
C
->
matcher
()
->
idealreg2spillmask
[
m
->
ideal_reg
()];
int
ireg
=
m
->
ideal_reg
();
if
(
ireg
==
0
||
ireg
==
Op_RegFlags
)
{
assert
(
false
,
err_msg
(
"attempted to spill a non-spillable item: %d: %s, ireg = %d"
,
m
->
_idx
,
m
->
Name
(),
ireg
));
C
->
record_method_not_compilable
(
"attempted to spill a non-spillable item"
);
return
;
}
const
RegMask
*
rm
=
C
->
matcher
()
->
idealreg2spillmask
[
ireg
];
copy
=
new
(
C
)
MachSpillCopyNode
(
m
,
*
rm
,
*
rm
);
// Insert the copy in the basic block, just before us
b
->
insert_node
(
copy
,
l
++
);
...
...
@@ -373,7 +392,14 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) {
if
(
k
<
b
->
_num_succs
)
continue
;
// Live out; do not pre-split
// Split the lrg at this use
const
RegMask
*
rm
=
C
->
matcher
()
->
idealreg2spillmask
[
inp
->
ideal_reg
()];
int
ireg
=
inp
->
ideal_reg
();
if
(
ireg
==
0
||
ireg
==
Op_RegFlags
)
{
assert
(
false
,
err_msg
(
"attempted to spill a non-spillable item: %d: %s, ireg = %d"
,
inp
->
_idx
,
inp
->
Name
(),
ireg
));
C
->
record_method_not_compilable
(
"attempted to spill a non-spillable item"
);
return
;
}
const
RegMask
*
rm
=
C
->
matcher
()
->
idealreg2spillmask
[
ireg
];
Node
*
copy
=
new
(
C
)
MachSpillCopyNode
(
inp
,
*
rm
,
*
rm
);
// Insert the copy in the use-def chain
n
->
set_req
(
inpidx
,
copy
);
...
...
src/share/vm/opto/machnode.cpp
浏览文件 @
9afdb690
...
...
@@ -619,6 +619,7 @@ const RegMask &MachSafePointNode::in_RegMask( uint idx ) const {
}
// Values outside the domain represent debug info
assert
(
in
(
idx
)
->
ideal_reg
()
!=
Op_RegFlags
,
"flags register is not spillable"
);
return
*
Compile
::
current
()
->
matcher
()
->
idealreg2spillmask
[
in
(
idx
)
->
ideal_reg
()];
}
...
...
src/share/vm/opto/matcher.cpp
浏览文件 @
9afdb690
...
...
@@ -95,6 +95,7 @@ Matcher::Matcher()
idealreg2spillmask
[
Op_VecD
]
=
NULL
;
idealreg2spillmask
[
Op_VecX
]
=
NULL
;
idealreg2spillmask
[
Op_VecY
]
=
NULL
;
idealreg2spillmask
[
Op_RegFlags
]
=
NULL
;
idealreg2debugmask
[
Op_RegI
]
=
NULL
;
idealreg2debugmask
[
Op_RegN
]
=
NULL
;
...
...
@@ -106,6 +107,7 @@ Matcher::Matcher()
idealreg2debugmask
[
Op_VecD
]
=
NULL
;
idealreg2debugmask
[
Op_VecX
]
=
NULL
;
idealreg2debugmask
[
Op_VecY
]
=
NULL
;
idealreg2debugmask
[
Op_RegFlags
]
=
NULL
;
idealreg2mhdebugmask
[
Op_RegI
]
=
NULL
;
idealreg2mhdebugmask
[
Op_RegN
]
=
NULL
;
...
...
@@ -117,6 +119,7 @@ Matcher::Matcher()
idealreg2mhdebugmask
[
Op_VecD
]
=
NULL
;
idealreg2mhdebugmask
[
Op_VecX
]
=
NULL
;
idealreg2mhdebugmask
[
Op_VecY
]
=
NULL
;
idealreg2mhdebugmask
[
Op_RegFlags
]
=
NULL
;
debug_only
(
_mem_node
=
NULL
;)
// Ideal memory node consumed by mach node
}
...
...
src/share/vm/utilities/exceptions.hpp
浏览文件 @
9afdb690
...
...
@@ -201,7 +201,7 @@ class Exceptions {
//
// CAUTION: make sure that the function call using a CHECK macro is not the only statement of a
// conditional branch w/o enclosing {} braces, since the CHECK macros expand into several state-
// ments!
// ments!
Also make sure it is not used on a function call that is part of a return statement!
#define PENDING_EXCEPTION (((ThreadShadow*)THREAD)->pending_exception())
#define HAS_PENDING_EXCEPTION (((ThreadShadow*)THREAD)->has_pending_exception())
...
...
test/compiler/c2/SubsumingLoadsCauseFlagSpill.java
0 → 100644
浏览文件 @
9afdb690
/*
* Copyright (c) 2018, Red Hat, 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 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 8209639
* @summary assert failure in coalesce.cpp: attempted to spill a non-spillable item
*
* @run main/othervm -XX:-BackgroundCompilation -XX:CompileCommand=dontinline,SubsumingLoadsCauseFlagSpill::not_inlined -Xmx1024m SubsumingLoadsCauseFlagSpill
*
*/
public
class
SubsumingLoadsCauseFlagSpill
{
private
static
Object
field
;
private
static
boolean
do_throw
;
private
static
volatile
boolean
barrier
;
public
static
void
main
(
String
[]
args
)
{
for
(
int
i
=
0
;
i
<
20_000
;
i
++)
{
do_throw
=
true
;
field
=
null
;
test
(
0
);
do_throw
=
false
;
field
=
new
Object
();
test
(
0
);
}
}
private
static
float
test
(
float
f
)
{
Object
v
=
null
;
try
{
not_inlined
();
v
=
field
;
}
catch
(
MyException
me
)
{
v
=
field
;
barrier
=
true
;
}
if
(
v
==
null
)
{
return
f
*
f
;
}
return
f
;
}
private
static
void
not_inlined
()
throws
MyException
{
if
(
do_throw
)
{
throw
new
MyException
();
}
}
private
static
class
MyException
extends
Throwable
{
}
}
test/compiler/gcbarriers/TestMembarDependencies.java
0 → 100644
浏览文件 @
9afdb690
/*
* Copyright (c) 2017, 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 TestMembarDependencies
* @bug 8172850
* @summary Tests correct scheduling of memory loads around MembarVolatile emitted by GC barriers.
* @library /testlibrary
* @run driver compiler.membars.TestMembarDependencies
*/
package
compiler.membars
;
import
com.oracle.java.testlibrary.*
;
public
class
TestMembarDependencies
{
private
static
TestMembarDependencies
f1
;
private
static
TestMembarDependencies
f2
;
public
static
void
main
(
String
args
[])
throws
Throwable
{
if
(
args
.
length
==
0
)
{
// For debugging, add "-XX:+TraceOptoPipelining"
OutputAnalyzer
oa
=
ProcessTools
.
executeTestJvm
(
"-XX:+IgnoreUnrecognizedVMOptions"
,
"-XX:-TieredCompilation"
,
"-XX:-BackgroundCompilation"
,
"-XX:+PrintOpto"
,
"-XX:CompileCommand=compileonly,compiler.membars.TestMembarDependencies::test*"
,
"-XX:CompileCommand=dontinline,compiler.membars.TestMembarDependencies::test_m1"
,
TestMembarDependencies
.
class
.
getName
(),
"run"
);
// C2 should not crash or bail out from compilation
oa
.
shouldHaveExitValue
(
0
);
oa
.
shouldNotMatch
(
"Bailout: Recompile without subsuming loads"
);
System
.
out
.
println
(
oa
.
getOutput
());
}
else
{
f2
=
new
TestMembarDependencies
();
// Trigger compilation of test1 and test2
for
(
int
i
=
0
;
i
<
10_000
;
++
i
)
{
f2
.
test1
(
f2
);
f2
.
test2
(
f2
);
}
}
}
public
void
test_m1
()
{
}
public
void
test_m2
()
{
}
public
void
test1
(
TestMembarDependencies
obj
)
{
// Try/catch/finally is used to create a CFG block without a test + jmpCon
// allowing GCM to schedule the testN_mem_reg0 instruction into that block.
try
{
// Method call defines memory state that is then
// used by subsequent instructions/blocks (see below).
test_m1
();
}
catch
(
Exception
e
)
{
}
finally
{
// Oop write to field emits a GC post-barrier with a MembarVolatile
// which has a wide memory effect (kills all memory). This creates an
// anti-dependency on all surrounding memory loads.
f1
=
obj
;
}
// The empty method m2 is inlined but the null check of f2 remains. It is encoded
// as CmpN(LoadN(MEM), NULL) where MEM is the memory after the call to test_m1().
// This is matched to testN_mem_reg0 on x86 which is scheduled before the barrier
// in the try/catch block due to the anti-dependency on the MembarVolatile.
// C2 crashes in the register allocator when trying to spill the flag register
// to keep the result of the testN instruction live from the try/catch block
// until it is here.
f2
.
test_m2
();
}
public
void
test2
(
TestMembarDependencies
obj
)
{
// Same as test1 but without try/catch/finally.
// This causes C2 to bail out in block local scheduling because testN_mem_reg0 is
// scheduled into a block that already contains another test + jmpCon instruction.
test_m1
();
f1
=
obj
;
f2
.
test_m2
();
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录