Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
90b375d7
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看板
提交
90b375d7
编写于
1月 25, 2012
作者:
K
kvn
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
a84cdab8
19602226
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
28 addition
and
21 deletion
+28
-21
src/share/vm/opto/block.hpp
src/share/vm/opto/block.hpp
+3
-3
src/share/vm/opto/gcm.cpp
src/share/vm/opto/gcm.cpp
+2
-2
src/share/vm/opto/lcm.cpp
src/share/vm/opto/lcm.cpp
+23
-16
未找到文件。
src/share/vm/opto/block.hpp
浏览文件 @
90b375d7
...
...
@@ -284,13 +284,13 @@ class Block : public CFGElement {
// helper function that adds caller save registers to MachProjNode
void
add_call_kills
(
MachProjNode
*
proj
,
RegMask
&
regs
,
const
char
*
save_policy
,
bool
exclude_soe
);
// Schedule a call next in the block
uint
sched_call
(
Matcher
&
matcher
,
Block_Array
&
bbs
,
uint
node_cnt
,
Node_List
&
worklist
,
int
*
ready_cnt
,
MachCallNode
*
mcall
,
VectorSet
&
next_call
);
uint
sched_call
(
Matcher
&
matcher
,
Block_Array
&
bbs
,
uint
node_cnt
,
Node_List
&
worklist
,
GrowableArray
<
int
>
&
ready_cnt
,
MachCallNode
*
mcall
,
VectorSet
&
next_call
);
// Perform basic-block local scheduling
Node
*
select
(
PhaseCFG
*
cfg
,
Node_List
&
worklist
,
int
*
ready_cnt
,
VectorSet
&
next_call
,
uint
sched_slot
);
Node
*
select
(
PhaseCFG
*
cfg
,
Node_List
&
worklist
,
GrowableArray
<
int
>
&
ready_cnt
,
VectorSet
&
next_call
,
uint
sched_slot
);
void
set_next_call
(
Node
*
n
,
VectorSet
&
next_call
,
Block_Array
&
bbs
);
void
needed_for_next_call
(
Node
*
this_call
,
VectorSet
&
next_call
,
Block_Array
&
bbs
);
bool
schedule_local
(
PhaseCFG
*
cfg
,
Matcher
&
m
,
int
*
ready_cnt
,
VectorSet
&
next_call
);
bool
schedule_local
(
PhaseCFG
*
cfg
,
Matcher
&
m
,
GrowableArray
<
int
>
&
ready_cnt
,
VectorSet
&
next_call
);
// Cleanup if any code lands between a Call and his Catch
void
call_catch_cleanup
(
Block_Array
&
bbs
);
// Detect implicit-null-check opportunities. Basically, find NULL checks
...
...
src/share/vm/opto/gcm.cpp
浏览文件 @
90b375d7
...
...
@@ -1344,8 +1344,8 @@ void PhaseCFG::GlobalCodeMotion( Matcher &matcher, uint unique, Node_List &proj_
// Schedule locally. Right now a simple topological sort.
// Later, do a real latency aware scheduler.
int
*
ready_cnt
=
NEW_RESOURCE_ARRAY
(
int
,
C
->
unique
()
);
memset
(
ready_cnt
,
-
1
,
C
->
unique
()
*
sizeof
(
int
)
);
uint
max_idx
=
C
->
unique
(
);
GrowableArray
<
int
>
ready_cnt
(
max_idx
,
max_idx
,
-
1
);
visited
.
Clear
();
for
(
i
=
0
;
i
<
_num_blocks
;
i
++
)
{
if
(
!
_blocks
[
i
]
->
schedule_local
(
this
,
matcher
,
ready_cnt
,
visited
))
{
...
...
src/share/vm/opto/lcm.cpp
浏览文件 @
90b375d7
...
...
@@ -404,7 +404,7 @@ void Block::implicit_null_check(PhaseCFG *cfg, Node *proj, Node *val, int allowe
// remaining cases (most), choose the instruction with the greatest latency
// (that is, the most number of pseudo-cycles required to the end of the
// routine). If there is a tie, choose the instruction with the most inputs.
Node
*
Block
::
select
(
PhaseCFG
*
cfg
,
Node_List
&
worklist
,
int
*
ready_cnt
,
VectorSet
&
next_call
,
uint
sched_slot
)
{
Node
*
Block
::
select
(
PhaseCFG
*
cfg
,
Node_List
&
worklist
,
GrowableArray
<
int
>
&
ready_cnt
,
VectorSet
&
next_call
,
uint
sched_slot
)
{
// If only a single entry on the stack, use it
uint
cnt
=
worklist
.
size
();
...
...
@@ -465,7 +465,7 @@ Node *Block::select(PhaseCFG *cfg, Node_List &worklist, int *ready_cnt, VectorSe
// More than this instruction pending for successor to be ready,
// don't choose this if other opportunities are ready
if
(
ready_cnt
[
use
->
_idx
]
>
1
)
if
(
ready_cnt
.
at
(
use
->
_idx
)
>
1
)
n_choice
=
1
;
}
...
...
@@ -565,7 +565,7 @@ void Block::add_call_kills(MachProjNode *proj, RegMask& regs, const char* save_p
//------------------------------sched_call-------------------------------------
uint
Block
::
sched_call
(
Matcher
&
matcher
,
Block_Array
&
bbs
,
uint
node_cnt
,
Node_List
&
worklist
,
int
*
ready_cnt
,
MachCallNode
*
mcall
,
VectorSet
&
next_call
)
{
uint
Block
::
sched_call
(
Matcher
&
matcher
,
Block_Array
&
bbs
,
uint
node_cnt
,
Node_List
&
worklist
,
GrowableArray
<
int
>
&
ready_cnt
,
MachCallNode
*
mcall
,
VectorSet
&
next_call
)
{
RegMask
regs
;
// Schedule all the users of the call right now. All the users are
...
...
@@ -574,8 +574,9 @@ uint Block::sched_call( Matcher &matcher, Block_Array &bbs, uint node_cnt, Node_
for
(
DUIterator_Fast
imax
,
i
=
mcall
->
fast_outs
(
imax
);
i
<
imax
;
i
++
)
{
Node
*
n
=
mcall
->
fast_out
(
i
);
assert
(
n
->
is_MachProj
(),
""
);
--
ready_cnt
[
n
->
_idx
];
assert
(
!
ready_cnt
[
n
->
_idx
],
""
);
int
n_cnt
=
ready_cnt
.
at
(
n
->
_idx
)
-
1
;
ready_cnt
.
at_put
(
n
->
_idx
,
n_cnt
);
assert
(
n_cnt
==
0
,
""
);
// Schedule next to call
_nodes
.
map
(
node_cnt
++
,
n
);
// Collect defined registers
...
...
@@ -590,7 +591,9 @@ uint Block::sched_call( Matcher &matcher, Block_Array &bbs, uint node_cnt, Node_
Node
*
m
=
n
->
fast_out
(
j
);
// Get user
if
(
bbs
[
m
->
_idx
]
!=
this
)
continue
;
if
(
m
->
is_Phi
()
)
continue
;
if
(
!--
ready_cnt
[
m
->
_idx
]
)
int
m_cnt
=
ready_cnt
.
at
(
m
->
_idx
)
-
1
;
ready_cnt
.
at_put
(
m
->
_idx
,
m_cnt
);
if
(
m_cnt
==
0
)
worklist
.
push
(
m
);
}
...
...
@@ -655,7 +658,7 @@ uint Block::sched_call( Matcher &matcher, Block_Array &bbs, uint node_cnt, Node_
//------------------------------schedule_local---------------------------------
// Topological sort within a block. Someday become a real scheduler.
bool
Block
::
schedule_local
(
PhaseCFG
*
cfg
,
Matcher
&
matcher
,
int
*
ready_cnt
,
VectorSet
&
next_call
)
{
bool
Block
::
schedule_local
(
PhaseCFG
*
cfg
,
Matcher
&
matcher
,
GrowableArray
<
int
>
&
ready_cnt
,
VectorSet
&
next_call
)
{
// Already "sorted" are the block start Node (as the first entry), and
// the block-ending Node and any trailing control projections. We leave
// these alone. PhiNodes and ParmNodes are made to follow the block start
...
...
@@ -695,7 +698,7 @@ bool Block::schedule_local(PhaseCFG *cfg, Matcher &matcher, int *ready_cnt, Vect
if
(
m
&&
cfg
->
_bbs
[
m
->
_idx
]
==
this
&&
!
m
->
is_top
()
)
local
++
;
// One more block-local input
}
ready_cnt
[
n
->
_idx
]
=
local
;
// Count em up
ready_cnt
.
at_put
(
n
->
_idx
,
local
)
;
// Count em up
#ifdef ASSERT
if
(
UseConcMarkSweepGC
||
UseG1GC
)
{
...
...
@@ -729,7 +732,7 @@ bool Block::schedule_local(PhaseCFG *cfg, Matcher &matcher, int *ready_cnt, Vect
}
}
for
(
uint
i2
=
i
;
i2
<
_nodes
.
size
();
i2
++
)
// Trailing guys get zapped count
ready_cnt
[
_nodes
[
i2
]
->
_idx
]
=
0
;
ready_cnt
.
at_put
(
_nodes
[
i2
]
->
_idx
,
0
)
;
// All the prescheduled guys do not hold back internal nodes
uint
i3
;
...
...
@@ -737,8 +740,10 @@ bool Block::schedule_local(PhaseCFG *cfg, Matcher &matcher, int *ready_cnt, Vect
Node
*
n
=
_nodes
[
i3
];
// Get pre-scheduled
for
(
DUIterator_Fast
jmax
,
j
=
n
->
fast_outs
(
jmax
);
j
<
jmax
;
j
++
)
{
Node
*
m
=
n
->
fast_out
(
j
);
if
(
cfg
->
_bbs
[
m
->
_idx
]
==
this
)
// Local-block user
ready_cnt
[
m
->
_idx
]
--
;
// Fix ready count
if
(
cfg
->
_bbs
[
m
->
_idx
]
==
this
)
{
// Local-block user
int
m_cnt
=
ready_cnt
.
at
(
m
->
_idx
)
-
1
;
ready_cnt
.
at_put
(
m
->
_idx
,
m_cnt
);
// Fix ready count
}
}
}
...
...
@@ -747,7 +752,7 @@ bool Block::schedule_local(PhaseCFG *cfg, Matcher &matcher, int *ready_cnt, Vect
Node_List
worklist
;
for
(
uint
i4
=
i3
;
i4
<
node_cnt
;
i4
++
)
{
// Put ready guys on worklist
Node
*
m
=
_nodes
[
i4
];
if
(
!
ready_cnt
[
m
->
_idx
]
)
{
// Zero ready count?
if
(
!
ready_cnt
.
at
(
m
->
_idx
)
)
{
// Zero ready count?
if
(
m
->
is_iteratively_computed
())
{
// Push induction variable increments last to allow other uses
// of the phi to be scheduled first. The select() method breaks
...
...
@@ -775,14 +780,14 @@ bool Block::schedule_local(PhaseCFG *cfg, Matcher &matcher, int *ready_cnt, Vect
for
(
uint
j
=
0
;
j
<
_nodes
.
size
();
j
++
)
{
Node
*
n
=
_nodes
[
j
];
int
idx
=
n
->
_idx
;
tty
->
print
(
"# ready cnt:%3d "
,
ready_cnt
[
idx
]
);
tty
->
print
(
"# ready cnt:%3d "
,
ready_cnt
.
at
(
idx
)
);
tty
->
print
(
"latency:%3d "
,
cfg
->
_node_latency
->
at_grow
(
idx
));
tty
->
print
(
"%4d: %s
\n
"
,
idx
,
n
->
Name
());
}
}
#endif
uint
max_idx
=
matcher
.
C
->
unique
();
uint
max_idx
=
(
uint
)
ready_cnt
.
length
();
// Pull from worklist and schedule
while
(
worklist
.
size
()
)
{
// Worklist is not ready
...
...
@@ -840,11 +845,13 @@ bool Block::schedule_local(PhaseCFG *cfg, Matcher &matcher, int *ready_cnt, Vect
Node
*
m
=
n
->
fast_out
(
i5
);
// Get user
if
(
cfg
->
_bbs
[
m
->
_idx
]
!=
this
)
continue
;
if
(
m
->
is_Phi
()
)
continue
;
if
(
m
->
_idx
>
max_idx
)
{
// new node, skip it
if
(
m
->
_idx
>
=
max_idx
)
{
// new node, skip it
assert
(
m
->
is_MachProj
()
&&
n
->
is_Mach
()
&&
n
->
as_Mach
()
->
has_call
(),
"unexpected node types"
);
continue
;
}
if
(
!--
ready_cnt
[
m
->
_idx
]
)
int
m_cnt
=
ready_cnt
.
at
(
m
->
_idx
)
-
1
;
ready_cnt
.
at_put
(
m
->
_idx
,
m_cnt
);
if
(
m_cnt
==
0
)
worklist
.
push
(
m
);
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录