Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
04db4ba3
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看板
提交
04db4ba3
编写于
5月 03, 2011
作者:
N
never
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
f5b81499
dd23e248
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
58 addition
and
6 deletion
+58
-6
src/share/vm/opto/library_call.cpp
src/share/vm/opto/library_call.cpp
+5
-6
test/compiler/7041100/Test7041100.java
test/compiler/7041100/Test7041100.java
+53
-0
未找到文件。
src/share/vm/opto/library_call.cpp
浏览文件 @
04db4ba3
...
@@ -867,12 +867,10 @@ Node* LibraryCallKit::make_string_method_node(int opcode, Node* str1, Node* cnt1
...
@@ -867,12 +867,10 @@ Node* LibraryCallKit::make_string_method_node(int opcode, Node* str1, Node* cnt1
Node
*
str1_offset
=
make_load
(
no_ctrl
,
str1_offseta
,
TypeInt
::
INT
,
T_INT
,
string_type
->
add_offset
(
offset_offset
));
Node
*
str1_offset
=
make_load
(
no_ctrl
,
str1_offseta
,
TypeInt
::
INT
,
T_INT
,
string_type
->
add_offset
(
offset_offset
));
Node
*
str1_start
=
array_element_address
(
str1_value
,
str1_offset
,
T_CHAR
);
Node
*
str1_start
=
array_element_address
(
str1_value
,
str1_offset
,
T_CHAR
);
// Pin loads from String::equals() argument since it could be NULL.
Node
*
str2_ctrl
=
(
opcode
==
Op_StrEquals
)
?
control
()
:
no_ctrl
;
Node
*
str2_valuea
=
basic_plus_adr
(
str2
,
str2
,
value_offset
);
Node
*
str2_valuea
=
basic_plus_adr
(
str2
,
str2
,
value_offset
);
Node
*
str2_value
=
make_load
(
str2
_ctrl
,
str2_valuea
,
value_type
,
T_OBJECT
,
string_type
->
add_offset
(
value_offset
));
Node
*
str2_value
=
make_load
(
no
_ctrl
,
str2_valuea
,
value_type
,
T_OBJECT
,
string_type
->
add_offset
(
value_offset
));
Node
*
str2_offseta
=
basic_plus_adr
(
str2
,
str2
,
offset_offset
);
Node
*
str2_offseta
=
basic_plus_adr
(
str2
,
str2
,
offset_offset
);
Node
*
str2_offset
=
make_load
(
str2
_ctrl
,
str2_offseta
,
TypeInt
::
INT
,
T_INT
,
string_type
->
add_offset
(
offset_offset
));
Node
*
str2_offset
=
make_load
(
no
_ctrl
,
str2_offseta
,
TypeInt
::
INT
,
T_INT
,
string_type
->
add_offset
(
offset_offset
));
Node
*
str2_start
=
array_element_address
(
str2_value
,
str2_offset
,
T_CHAR
);
Node
*
str2_start
=
array_element_address
(
str2_value
,
str2_offset
,
T_CHAR
);
Node
*
result
=
NULL
;
Node
*
result
=
NULL
;
...
@@ -1012,14 +1010,15 @@ bool LibraryCallKit::inline_string_equals() {
...
@@ -1012,14 +1010,15 @@ bool LibraryCallKit::inline_string_equals() {
if
(
!
stopped
())
{
if
(
!
stopped
())
{
// Properly cast the argument to String
// Properly cast the argument to String
argument
=
_gvn
.
transform
(
new
(
C
,
2
)
CheckCastPPNode
(
control
(),
argument
,
string_type
));
argument
=
_gvn
.
transform
(
new
(
C
,
2
)
CheckCastPPNode
(
control
(),
argument
,
string_type
));
// This path is taken only when argument's type is String:NotNull.
argument
=
cast_not_null
(
argument
,
false
);
// Get counts for string and argument
// Get counts for string and argument
Node
*
receiver_cnta
=
basic_plus_adr
(
receiver
,
receiver
,
count_offset
);
Node
*
receiver_cnta
=
basic_plus_adr
(
receiver
,
receiver
,
count_offset
);
receiver_cnt
=
make_load
(
no_ctrl
,
receiver_cnta
,
TypeInt
::
INT
,
T_INT
,
string_type
->
add_offset
(
count_offset
));
receiver_cnt
=
make_load
(
no_ctrl
,
receiver_cnta
,
TypeInt
::
INT
,
T_INT
,
string_type
->
add_offset
(
count_offset
));
// Pin load from argument string since it could be NULL.
Node
*
argument_cnta
=
basic_plus_adr
(
argument
,
argument
,
count_offset
);
Node
*
argument_cnta
=
basic_plus_adr
(
argument
,
argument
,
count_offset
);
argument_cnt
=
make_load
(
control
()
,
argument_cnta
,
TypeInt
::
INT
,
T_INT
,
string_type
->
add_offset
(
count_offset
));
argument_cnt
=
make_load
(
no_ctrl
,
argument_cnta
,
TypeInt
::
INT
,
T_INT
,
string_type
->
add_offset
(
count_offset
));
// Check for receiver count != argument count
// Check for receiver count != argument count
Node
*
cmp
=
_gvn
.
transform
(
new
(
C
,
3
)
CmpINode
(
receiver_cnt
,
argument_cnt
)
);
Node
*
cmp
=
_gvn
.
transform
(
new
(
C
,
3
)
CmpINode
(
receiver_cnt
,
argument_cnt
)
);
...
...
test/compiler/7041100/Test7041100.java
0 → 100644
浏览文件 @
04db4ba3
/*
* Copyright (c) 2011, 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 7041100
* @summary The load in String.equals intrinsic executed before null check
*
* @run main/othervm -Xbatch Test7041100 abc def
*/
public
class
Test7041100
{
static
String
n
=
null
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
for
(
int
i
=
0
;
i
<
10000
;
i
++)
{
stringEQ
(
args
[
0
],
args
[
1
]);
stringEQ
(
args
[
0
],
args
[
0
]);
stringEQ
(
args
[
0
],
n
);
stringEQ
(
n
,
args
[
0
]);
}
}
public
static
boolean
stringEQ
(
String
a
,
String
b
)
{
if
(
a
==
b
)
return
true
;
if
(
a
==
null
||
b
==
null
)
return
false
;
else
return
a
.
equals
(
b
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录