Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
92f8f750
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看板
提交
92f8f750
编写于
12月 12, 2013
作者:
A
anoll
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
29a8feb1
de53f6db
变更
8
显示空白变更内容
内联
并排
Showing
8 changed file
with
100 addition
and
27 deletion
+100
-27
src/share/vm/code/compiledIC.cpp
src/share/vm/code/compiledIC.cpp
+2
-2
src/share/vm/code/nmethod.cpp
src/share/vm/code/nmethod.cpp
+7
-7
src/share/vm/code/nmethod.hpp
src/share/vm/code/nmethod.hpp
+8
-7
src/share/vm/opto/memnode.cpp
src/share/vm/opto/memnode.cpp
+5
-0
src/share/vm/runtime/sharedRuntime.cpp
src/share/vm/runtime/sharedRuntime.cpp
+23
-5
test/compiler/7141637/SpreadNullArg.java
test/compiler/7141637/SpreadNullArg.java
+8
-4
test/compiler/reflection/ArrayNewInstanceOfVoid.java
test/compiler/reflection/ArrayNewInstanceOfVoid.java
+44
-0
test/compiler/regalloc/C1ObjectSpillInLogicOp.java
test/compiler/regalloc/C1ObjectSpillInLogicOp.java
+3
-2
未找到文件。
src/share/vm/code/compiledIC.cpp
浏览文件 @
92f8f750
...
...
@@ -418,7 +418,7 @@ void CompiledIC::compute_monomorphic_entry(methodHandle method,
TRAPS
)
{
nmethod
*
method_code
=
method
->
code
();
address
entry
=
NULL
;
if
(
method_code
!=
NULL
)
{
if
(
method_code
!=
NULL
&&
method_code
->
is_in_use
()
)
{
// Call to compiled code
if
(
static_bound
||
is_optimized
)
{
entry
=
method_code
->
verified_entry_point
();
...
...
@@ -545,7 +545,7 @@ void CompiledStaticCall::set(const StaticCallInfo& info) {
void
CompiledStaticCall
::
compute_entry
(
methodHandle
m
,
StaticCallInfo
&
info
)
{
nmethod
*
m_code
=
m
->
code
();
info
.
_callee
=
m
;
if
(
m_code
!=
NULL
)
{
if
(
m_code
!=
NULL
&&
m_code
->
is_in_use
()
)
{
info
.
_to_interpreter
=
false
;
info
.
_entry
=
m_code
->
verified_entry_point
();
}
else
{
...
...
src/share/vm/code/nmethod.cpp
浏览文件 @
92f8f750
...
...
@@ -459,7 +459,7 @@ const char* nmethod::compile_kind() const {
// Fill in default values for various flag fields
void
nmethod
::
init_defaults
()
{
_state
=
aliv
e
;
_state
=
in_us
e
;
_marked_for_reclamation
=
0
;
_has_flushed_dependencies
=
0
;
_has_unsafe_access
=
0
;
...
...
@@ -2393,8 +2393,8 @@ void nmethod::verify() {
void
nmethod
::
verify_interrupt_point
(
address
call_site
)
{
// Verify IC only when nmethod installation is finished.
bool
is_installed
=
(
method
()
->
code
()
==
this
)
// nmethod is in state '
aliv
e' and installed
||
!
this
->
is_in_use
();
// nmethod is installed, but not in '
aliv
e' state
bool
is_installed
=
(
method
()
->
code
()
==
this
)
// nmethod is in state '
in_us
e' and installed
||
!
this
->
is_in_use
();
// nmethod is installed, but not in '
in_us
e' state
if
(
is_installed
)
{
Thread
*
cur
=
Thread
::
current
();
if
(
CompiledIC_lock
->
owner
()
==
cur
||
...
...
src/share/vm/code/nmethod.hpp
浏览文件 @
92f8f750
...
...
@@ -184,11 +184,12 @@ class nmethod : public CodeBlob {
bool
_oops_are_stale
;
// indicates that it's no longer safe to access oops section
#endif
enum
{
alive
=
0
,
not_entrant
=
1
,
// uncommon trap has happened but activations may still exist
zombie
=
2
,
unloaded
=
3
};
enum
{
in_use
=
0
,
// executable nmethod
not_entrant
=
1
,
// marked for deoptimization but activations may still exist,
// will be transformed to zombie when all activations are gone
zombie
=
2
,
// no activations exist, nmethod is ready for purge
unloaded
=
3
};
// there should be no activations, should not be called,
// will be transformed to zombie immediately
jbyte
_scavenge_root_state
;
...
...
@@ -407,8 +408,8 @@ class nmethod : public CodeBlob {
address
verified_entry_point
()
const
{
return
_verified_entry_point
;
}
// if klass is correct
// flag accessing and manipulation
bool
is_in_use
()
const
{
return
_state
==
aliv
e
;
}
bool
is_alive
()
const
{
return
_state
==
aliv
e
||
_state
==
not_entrant
;
}
bool
is_in_use
()
const
{
return
_state
==
in_us
e
;
}
bool
is_alive
()
const
{
return
_state
==
in_us
e
||
_state
==
not_entrant
;
}
bool
is_not_entrant
()
const
{
return
_state
==
not_entrant
;
}
bool
is_zombie
()
const
{
return
_state
==
zombie
;
}
bool
is_unloaded
()
const
{
return
_state
==
unloaded
;
}
...
...
src/share/vm/opto/memnode.cpp
浏览文件 @
92f8f750
...
...
@@ -2071,6 +2071,11 @@ const Type *LoadNode::klass_value_common( PhaseTransform *phase ) const {
if
(
t
!=
NULL
)
{
// constant oop => constant klass
if
(
offset
==
java_lang_Class
::
array_klass_offset_in_bytes
())
{
if
(
t
->
is_void
())
{
// We cannot create a void array. Since void is a primitive type return null
// klass. Users of this result need to do a null check on the returned klass.
return
TypePtr
::
NULL_PTR
;
}
return
TypeKlassPtr
::
make
(
ciArrayKlass
::
make
(
t
));
}
if
(
!
t
->
is_klass
())
{
...
...
src/share/vm/runtime/sharedRuntime.cpp
浏览文件 @
92f8f750
...
...
@@ -1178,12 +1178,12 @@ methodHandle SharedRuntime::resolve_sub_helper(JavaThread *thread,
CodeBlob
*
caller_cb
=
caller_frame
.
cb
();
guarantee
(
caller_cb
!=
NULL
&&
caller_cb
->
is_nmethod
(),
"must be called from nmethod"
);
nmethod
*
caller_nm
=
caller_cb
->
as_nmethod_or_null
();
// make sure caller is not getting deoptimized
// and removed before we are done with it.
// CLEANUP - with lazy deopt shouldn't need this lock
nmethodLocker
caller_lock
(
caller_nm
);
// determine call info & receiver
// note: a) receiver is NULL for static calls
// b) an exception is thrown if receiver is NULL for non-static calls
...
...
@@ -1198,6 +1198,11 @@ methodHandle SharedRuntime::resolve_sub_helper(JavaThread *thread,
(
!
is_virtual
&&
invoke_code
==
Bytecodes
::
_invokedynamic
)
||
(
is_virtual
&&
invoke_code
!=
Bytecodes
::
_invokestatic
),
"inconsistent bytecode"
);
// We do not patch the call site if the caller nmethod has been made non-entrant.
if
(
!
caller_nm
->
is_in_use
())
{
return
callee_method
;
}
#ifndef PRODUCT
// tracing/debugging/statistics
int
*
addr
=
(
is_optimized
)
?
(
&
_resolve_opt_virtual_ctr
)
:
...
...
@@ -1237,6 +1242,10 @@ methodHandle SharedRuntime::resolve_sub_helper(JavaThread *thread,
// Make sure the callee nmethod does not get deoptimized and removed before
// we are done patching the code.
nmethod
*
callee_nm
=
callee_method
->
code
();
if
(
callee_nm
!=
NULL
&&
!
callee_nm
->
is_in_use
())
{
// Patch call site to C2I adapter if callee nmethod is deoptimized or unloaded.
callee_nm
=
NULL
;
}
nmethodLocker
nl_callee
(
callee_nm
);
#ifdef ASSERT
address
dest_entry_point
=
callee_nm
==
NULL
?
0
:
callee_nm
->
entry_point
();
// used below
...
...
@@ -1258,15 +1267,24 @@ methodHandle SharedRuntime::resolve_sub_helper(JavaThread *thread,
{
MutexLocker
ml_patch
(
CompiledIC_lock
);
// Lock blocks for safepoint during which both nmethods can change state.
// Now that we are ready to patch if the Method* was redefined then
// don't update call site and let the caller retry.
if
(
!
callee_method
->
is_old
())
{
// Don't update call site if caller nmethod has been made non-entrant
// as it is a waste of time.
// Don't update call site if callee nmethod was unloaded or deoptimized.
// Don't update call site if callee nmethod was replaced by an other nmethod
// which may happen when multiply alive nmethod (tiered compilation)
// will be supported.
if
(
!
callee_method
->
is_old
()
&&
caller_nm
->
is_in_use
()
&&
(
callee_nm
==
NULL
||
callee_nm
->
is_in_use
()
&&
(
callee_method
->
code
()
==
callee_nm
)))
{
#ifdef ASSERT
// We must not try to patch to jump to an already unloaded method.
if
(
dest_entry_point
!=
0
)
{
assert
(
CodeCache
::
find_blob
(
dest_entry_point
)
!=
NULL
,
"should not unload nmethod while locked"
);
CodeBlob
*
cb
=
CodeCache
::
find_blob
(
dest_entry_point
);
assert
((
cb
!=
NULL
)
&&
cb
->
is_nmethod
()
&&
(((
nmethod
*
)
cb
)
==
callee_nm
),
"should not call unloaded nmethod"
);
}
#endif
if
(
is_virtual
)
{
...
...
test/compiler/7141637/SpreadNullArg.java
浏览文件 @
92f8f750
...
...
@@ -46,13 +46,17 @@ public class SpreadNullArg {
mh_spread_target
=
MethodHandles
.
lookup
().
findStatic
(
SpreadNullArg
.
class
,
"target_spread_arg"
,
mt_ref_arg
);
result
=
(
int
)
mh_spreadInvoker
.
invokeExact
(
mh_spread_target
,
(
Object
[])
null
);
}
catch
(
NullPointerException
e
)
{
// Expected exception - do nothing!
}
catch
(
Throwable
e
)
{
throw
new
Error
(
"Expected IllegalArgumentException was not thrown"
);
}
catch
(
IllegalArgumentException
e
)
{
System
.
out
.
println
(
"Expected exception : "
+
e
);
}
catch
(
Throwable
e
)
{
throw
new
Error
(
e
);
}
if
(
result
!=
42
)
throw
new
Error
(
"Expected NullPointerException was not thrown"
);
if
(
result
!=
42
)
{
throw
new
Error
(
"result ["
+
result
+
"] != 42 : Expected IllegalArgumentException was not thrown?"
);
}
}
public
static
int
target_spread_arg
(
Integer
i1
)
{
...
...
test/compiler/reflection/ArrayNewInstanceOfVoid.java
0 → 100644
浏览文件 @
92f8f750
/*
* Copyright (c) 2013, 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 8029366
* @summary ShouldNotReachHere error when creating an array with component type of void
*/
public
class
ArrayNewInstanceOfVoid
{
public
static
void
main
(
String
[]
args
)
{
for
(
int
i
=
0
;
i
<
100_000
;
i
++)
{
test
();
}
}
private
static
void
test
()
{
try
{
java
.
lang
.
reflect
.
Array
.
newInstance
(
void
.
class
,
2
);
}
catch
(
IllegalArgumentException
e
)
{
// expected
}
}
}
test/compiler/regalloc/C1ObjectSpillInLogicOp.java
浏览文件 @
92f8f750
...
...
@@ -34,8 +34,9 @@
*/
import
java.util.concurrent.atomic.*
;
class
C1ObjectSpillInLogicOp
{
static
public
void
main
(
String
[]
args
)
{
public
class
C1ObjectSpillInLogicOp
{
public
static
void
main
(
String
[]
args
)
{
AtomicReferenceArray
<
Integer
>
x
=
new
AtomicReferenceArray
(
128
);
Integer
y
=
new
Integer
(
0
);
for
(
int
i
=
0
;
i
<
50000
;
i
++)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录