Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
e137cb82
MegEngine
项目概览
MegEngine 天元
/
MegEngine
1 年多 前同步成功
通知
404
Star
4705
Fork
582
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
MegEngine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
e137cb82
编写于
12月 01, 2022
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(debug): format gdb script
GitOrigin-RevId: 280fa872656bd418cb4656f5498686efaf63e01a
上级
9166844f
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
127 addition
and
76 deletion
+127
-76
scripts/gdb/commands.py
scripts/gdb/commands.py
+47
-18
scripts/gdb/pretty_printers.py
scripts/gdb/pretty_printers.py
+65
-44
scripts/gdb/xmethods.py
scripts/gdb/xmethods.py
+15
-14
未找到文件。
scripts/gdb/commands.py
浏览文件 @
e137cb82
import
sys
import
gdb
import
re
import
subprocess
import
sys
import
gdb
_demangle_cache
=
{}
def
demangle
(
name
):
if
name
not
in
_demangle_cache
:
_demangle_cache
[
name
]
=
subprocess
.
run
([
'c++filt'
,
"-t"
,
name
],
stdout
=
subprocess
.
PIPE
).
stdout
return
_demangle_cache
[
name
].
decode
(
'utf-8'
).
strip
()
_demangle_cache
[
name
]
=
subprocess
.
run
(
[
"c++filt"
,
"-t"
,
name
],
stdout
=
subprocess
.
PIPE
).
stdout
return
_demangle_cache
[
name
].
decode
(
"utf-8"
).
strip
()
def
dynamic_cast
(
val
):
...
...
@@ -52,11 +53,21 @@ def shared_ptr_deref(ptr):
def
get_type_name
(
type_index
):
return
gdb
.
lookup_global_symbol
(
"mgb::imperative::debug::get_type_name(std::type_index const&)"
).
value
()(
type_index
).
string
()
return
(
gdb
.
lookup_global_symbol
(
"mgb::imperative::debug::get_type_name(std::type_index const&)"
)
.
value
()(
type_index
)
.
string
()
)
mge_apply_transform_pattern
=
re
.
compile
(
r
"^(.*)::apply_transform\(mgb::imperative::Operator const&, mgb::imperative::Span<mgb::imperative::ValueRef>\)$"
)
mge_op_fallback_pattern
=
re
.
compile
(
r
"^(.*)::fallback\(mgb::imperative::Span<mgb::imperative::ValueRef>\) const$"
)
mge_apply_transform_pattern
=
re
.
compile
(
r
"^(.*)::apply_transform\(mgb::imperative::Operator const&, mgb::imperative::Span<mgb::imperative::ValueRef>\)$"
)
mge_op_fallback_pattern
=
re
.
compile
(
r
"^(.*)::fallback\(mgb::imperative::Span<mgb::imperative::ValueRef>\) const$"
)
def
is_mge_frame
(
frame
):
...
...
@@ -66,11 +77,15 @@ def is_mge_frame(frame):
matcher
=
mge_apply_transform_pattern
.
match
(
function
.
name
)
if
matcher
:
typename
=
matcher
.
group
(
1
)
return
is_subclass_of
(
gdb
.
lookup_type
(
typename
),
gdb
.
lookup_type
(
"mgb::imperative::Transform"
))
return
is_subclass_of
(
gdb
.
lookup_type
(
typename
),
gdb
.
lookup_type
(
"mgb::imperative::Transform"
)
)
matcher
=
mge_op_fallback_pattern
.
match
(
function
.
name
)
if
matcher
:
typename
=
matcher
.
group
(
1
)
return
is_subclass_of
(
gdb
.
lookup_type
(
typename
),
gdb
.
lookup_type
(
"mgb::imperative::Operator"
))
return
is_subclass_of
(
gdb
.
lookup_type
(
typename
),
gdb
.
lookup_type
(
"mgb::imperative::Operator"
)
)
return
False
...
...
@@ -84,18 +99,24 @@ def count_frame_level(frame):
def
print_mge_frame
(
frame
):
function
=
frame
.
function
()
op
=
eval_on_val
(
dynamic_cast
(
frame
.
read_var
(
"op"
)),
".to_string().c_str()"
).
string
()
op
=
eval_on_val
(
dynamic_cast
(
frame
.
read_var
(
"op"
)),
".to_string().c_str()"
).
string
()
inputs
=
str
(
frame
.
read_var
(
"inputs"
))
matcher
=
mge_apply_transform_pattern
.
match
(
function
.
name
)
if
matcher
:
name
=
matcher
.
group
(
1
)
else
:
name
=
mge_op_fallback_pattern
.
match
(
function
.
name
).
group
(
1
)
#TODO: span
#
TODO: span
sal
=
frame
.
find_sal
()
filename
=
sal
.
symtab
.
filename
line
=
sal
.
line
print
(
"#{} {} apply {} on {}, file: {}:{}"
.
format
(
count_frame_level
(
frame
),
name
,
op
,
inputs
,
filename
,
line
))
print
(
"#{} {} apply {} on {}, file: {}:{}"
.
format
(
count_frame_level
(
frame
),
name
,
op
,
inputs
,
filename
,
line
)
)
class
MegengineBacktrace
(
gdb
.
Command
):
...
...
@@ -118,7 +139,9 @@ class MegengineBreakApply(gdb.Command):
super
().
__init__
(
"mge-brk-apply"
,
gdb
.
COMMAND_USER
)
def
invoke
(
self
,
arg
,
from_tty
):
gdb
.
Breakpoint
(
"mgb::imperative::apply(mgb::imperative::Operator const&, mgb::imperative::Span<mgb::imperative::ValueRef>)"
)
gdb
.
Breakpoint
(
"mgb::imperative::apply(mgb::imperative::Operator const&, mgb::imperative::Span<mgb::imperative::ValueRef>)"
)
class
MegengineWatch
(
gdb
.
Command
):
...
...
@@ -126,7 +149,9 @@ class MegengineWatch(gdb.Command):
super
().
__init__
(
"mge-watch"
,
gdb
.
COMMAND_USER
)
def
invoke
(
self
,
arg
,
from_tty
):
watch
=
gdb
.
lookup_global_symbol
(
"mgb::imperative::debug::watch_value(mgb::imperative::ValueRef)"
).
value
()
watch
=
gdb
.
lookup_global_symbol
(
"mgb::imperative::debug::watch_value(mgb::imperative::ValueRef)"
).
value
()
value
=
gdb
.
parse_and_eval
(
arg
)
watch
(
value
)
print
(
"watching {}"
.
format
(
str
(
value
)))
...
...
@@ -176,7 +201,9 @@ class MegengineInfo(gdb.Command):
def
invoke
(
self
,
arg
,
from_tty
):
if
arg
==
"opr"
:
registered_oprs
=
gdb
.
lookup_global_symbol
(
"mgb::imperative::Operator::registered_types()"
).
value
()()
registered_oprs
=
gdb
.
lookup_global_symbol
(
"mgb::imperative::Operator::registered_types()"
).
value
()()
size
=
vector_size
(
registered_oprs
)
for
i
in
range
(
size
):
registered_opr
=
vector_item
(
registered_oprs
,
i
)
...
...
@@ -184,7 +211,9 @@ class MegengineInfo(gdb.Command):
name
=
get_type_name
(
registered_opr
)
print
(
"{}: {}"
.
format
(
i
,
demangle
(
name
)))
elif
arg
==
"trf"
:
dispatch_context
=
gdb
.
lookup_global_symbol
(
"mgb::imperative::Transform::get_context()"
).
value
()()
dispatch_context
=
gdb
.
lookup_global_symbol
(
"mgb::imperative::Transform::get_context()"
).
value
()()
transformations
=
dispatch_context
[
"transformations"
]
size
=
vector_size
(
transformations
)
for
i
in
range
(
size
):
...
...
scripts/gdb/pretty_printers.py
浏览文件 @
e137cb82
import
sys
import
gdb
import
gdb.printing
import
gdb.types
...
...
@@ -21,38 +22,40 @@ def eval_on_val(val, eval_str):
class
SmallVectorPrinter
:
def
__init__
(
self
,
val
):
t
=
val
.
type
.
template_argument
(
0
)
self
.
begin
=
val
[
'm_begin_ptr'
].
cast
(
t
.
pointer
())
self
.
end
=
val
[
'm_end_ptr'
].
cast
(
t
.
pointer
())
self
.
begin
=
val
[
"m_begin_ptr"
].
cast
(
t
.
pointer
())
self
.
end
=
val
[
"m_end_ptr"
].
cast
(
t
.
pointer
())
self
.
size
=
self
.
end
-
self
.
begin
self
.
capacity
=
val
[
'm_capacity_ptr'
].
cast
(
t
.
pointer
())
-
val
[
'm_begin_ptr'
].
cast
(
t
.
pointer
())
self
.
capacity
=
val
[
"m_capacity_ptr"
].
cast
(
t
.
pointer
())
-
val
[
"m_begin_ptr"
].
cast
(
t
.
pointer
())
def
to_string
(
self
):
return
'SmallVector of Size {}'
.
format
(
self
.
size
)
return
"SmallVector of Size {}"
.
format
(
self
.
size
)
def
display_hint
(
self
):
return
'array'
return
"array"
def
children
(
self
):
for
i
in
range
(
self
.
size
):
yield
"[{}]"
.
format
(
i
),
(
self
.
begin
+
i
).
dereference
()
yield
"[{}]"
.
format
(
i
),
(
self
.
begin
+
i
).
dereference
()
class
MaybePrinter
:
def
__init__
(
self
,
val
):
self
.
val
=
val
[
'm_ptr'
]
self
.
val
=
val
[
"m_ptr"
]
def
to_string
(
self
):
if
self
.
val
:
return
'Some {}'
.
format
(
self
.
val
)
return
"Some {}"
.
format
(
self
.
val
)
else
:
return
'None'
return
"None"
def
display_hint
(
self
):
return
'array'
return
"array"
def
children
(
self
):
if
self
.
val
:
yield
'[0]'
,
self
.
val
.
dereference
()
yield
"[0]"
,
self
.
val
.
dereference
()
class
ToStringPrinter
:
...
...
@@ -81,16 +84,16 @@ class HandlePrinter:
def
to_string
(
self
):
if
self
.
val
:
return
'Handle of TensorInfo at {}'
.
format
(
self
.
val
)
return
"Handle of TensorInfo at {}"
.
format
(
self
.
val
)
else
:
return
'Empty Handle'
return
"Empty Handle"
def
display_hint
(
self
):
return
'array'
return
"array"
def
children
(
self
):
if
self
.
val
:
yield
'[0]'
,
self
.
val
.
dereference
()
yield
"[0]"
,
self
.
val
.
dereference
()
def
print_small_tensor
(
device_nd
):
...
...
@@ -124,17 +127,17 @@ def print_small_tensor(device_nd):
class
LogicalTensorDescPrinter
:
def
__init__
(
self
,
val
):
self
.
layout
=
val
[
'layout'
]
self
.
comp_node
=
val
[
'comp_node'
]
self
.
value
=
val
[
'value'
]
self
.
layout
=
val
[
"layout"
]
self
.
comp_node
=
val
[
"comp_node"
]
self
.
value
=
val
[
"value"
]
def
to_string
(
self
):
return
'LogicalTensorDesc'
return
"LogicalTensorDesc"
def
children
(
self
):
yield
'layout'
,
self
.
layout
yield
'comp_node'
,
self
.
comp_node
yield
'value'
,
print_small_tensor
(
self
.
value
)
yield
"layout"
,
self
.
layout
yield
"comp_node"
,
self
.
comp_node
yield
"value"
,
print_small_tensor
(
self
.
value
)
class
OpDefPrinter
:
...
...
@@ -145,49 +148,67 @@ class OpDefPrinter:
return
self
.
val
.
dynamic_type
.
name
def
children
(
self
):
concrete_val
=
self
.
val
.
address
.
cast
(
self
.
val
.
dynamic_type
.
pointer
()).
dereference
()
concrete_val
=
self
.
val
.
address
.
cast
(
self
.
val
.
dynamic_type
.
pointer
()
).
dereference
()
for
field
in
concrete_val
.
type
.
fields
():
if
field
.
is_base_class
or
field
.
artificial
:
continue
if
field
.
name
==
'sm_typeinfo'
:
if
field
.
name
==
"sm_typeinfo"
:
continue
yield
field
.
name
,
concrete_val
[
field
.
name
]
class
SpanPrinter
:
def
__init__
(
self
,
val
):
self
.
begin
=
val
[
'm_begin'
]
self
.
end
=
val
[
'm_end'
]
self
.
begin
=
val
[
"m_begin"
]
self
.
end
=
val
[
"m_end"
]
self
.
size
=
self
.
end
-
self
.
begin
def
to_string
(
self
):
return
'Span of Size {}'
.
format
(
self
.
size
)
return
"Span of Size {}"
.
format
(
self
.
size
)
def
display_hint
(
self
):
return
'array'
return
"array"
def
children
(
self
):
for
i
in
range
(
self
.
size
):
yield
"[{}]"
.
format
(
i
),
(
self
.
begin
+
i
).
dereference
()
yield
"[{}]"
.
format
(
i
),
(
self
.
begin
+
i
).
dereference
()
if
sys
.
version_info
.
major
>
2
:
pp
=
gdb
.
printing
.
RegexpCollectionPrettyPrinter
(
"MegEngine"
)
# megdnn
pp
.
add_printer
(
'megdnn::SmallVectorImpl'
,
'^megdnn::SmallVector(Impl)?<.*>$'
,
SmallVectorPrinter
)
pp
.
add_printer
(
'megdnn::TensorLayout'
,
'^megdnn::TensorLayout$'
,
ToStringPrinter
)
pp
.
add_printer
(
'megdnn::TensorShape'
,
'^megdnn::TensorShape$'
,
ToStringPrinter
)
# megbrain
pp
.
add_printer
(
'mgb::CompNode'
,
'^mgb::CompNode$'
,
ToStringPrinter
)
pp
.
add_printer
(
'mgb::Maybe'
,
'^mgb::Maybe<.*>$'
,
MaybePrinter
)
# imperative
pp
.
add_printer
(
'mgb::imperative::LogicalTensorDesc'
,
'^mgb::imperative::LogicalTensorDesc$'
,
LogicalTensorDescPrinter
)
pp
.
add_printer
(
'mgb::imperative::OpDef'
,
'^mgb::imperative::OpDef$'
,
OpDefPrinter
)
pp
.
add_printer
(
'mgb::imperative::Subgraph'
,
'^mgb::imperative::Subgraph$'
,
ReprPrinter
)
pp
.
add_printer
(
'mgb::imperative::EncodedSubgraph'
,
'^mgb::imperative::EncodedSubgraph$'
,
ReprPrinter
)
# imperative dispatch
pp
.
add_printer
(
'mgb::imperative::ValueRef'
,
'^mgb::imperative::ValueRef$'
,
ToStringPrinter
)
pp
.
add_printer
(
'mgb::imperative::Span'
,
'^mgb::imperative::Span<.*>$'
,
SpanPrinter
)
# megdnn
pp
.
add_printer
(
"megdnn::SmallVectorImpl"
,
"^megdnn::SmallVector(Impl)?<.*>$"
,
SmallVectorPrinter
,
)
pp
.
add_printer
(
"megdnn::TensorLayout"
,
"^megdnn::TensorLayout$"
,
ToStringPrinter
)
pp
.
add_printer
(
"megdnn::TensorShape"
,
"^megdnn::TensorShape$"
,
ToStringPrinter
)
# megbrain
pp
.
add_printer
(
"mgb::CompNode"
,
"^mgb::CompNode$"
,
ToStringPrinter
)
pp
.
add_printer
(
"mgb::Maybe"
,
"^mgb::Maybe<.*>$"
,
MaybePrinter
)
# imperative
pp
.
add_printer
(
"mgb::imperative::LogicalTensorDesc"
,
"^mgb::imperative::LogicalTensorDesc$"
,
LogicalTensorDescPrinter
,
)
pp
.
add_printer
(
"mgb::imperative::OpDef"
,
"^mgb::imperative::OpDef$"
,
OpDefPrinter
)
pp
.
add_printer
(
"mgb::imperative::Subgraph"
,
"^mgb::imperative::Subgraph$"
,
ReprPrinter
)
pp
.
add_printer
(
"mgb::imperative::EncodedSubgraph"
,
"^mgb::imperative::EncodedSubgraph$"
,
ReprPrinter
,
)
# imperative dispatch
pp
.
add_printer
(
"mgb::imperative::ValueRef"
,
"^mgb::imperative::ValueRef$"
,
ToStringPrinter
)
pp
.
add_printer
(
"mgb::imperative::Span"
,
"^mgb::imperative::Span<.*>$"
,
SpanPrinter
)
gdb
.
printing
.
register_pretty_printer
(
gdb
.
current_objfile
(),
pp
)
else
:
print
(
"skip import pretty printers"
)
...
...
scripts/gdb/xmethods.py
浏览文件 @
e137cb82
import
sys
import
re
import
sys
import
gdb
import
gdb.types
...
...
@@ -11,13 +11,13 @@ class SmallVectorImplWorker_at(gdb.xmethod.XMethodWorker):
self
.
t
=
t
def
get_arg_types
(
self
):
return
gdb
.
lookup_type
(
'int'
)
return
gdb
.
lookup_type
(
"int"
)
def
get_result_type
(
self
,
*
args
):
return
self
.
t
def
__call__
(
self
,
obj
,
i
):
return
(
obj
[
'm_begin_ptr'
].
cast
(
self
.
t
.
pointer
())
+
i
).
dereference
()
return
(
obj
[
"m_begin_ptr"
].
cast
(
self
.
t
.
pointer
())
+
i
).
dereference
()
class
SmallVectorImplWorker_size
(
gdb
.
xmethod
.
XMethodWorker
):
...
...
@@ -28,24 +28,25 @@ class SmallVectorImplWorker_size(gdb.xmethod.XMethodWorker):
return
None
def
get_result_type
(
self
,
*
args
):
return
gdb
.
lookup_type
(
'int'
)
return
gdb
.
lookup_type
(
"int"
)
def
__call__
(
self
,
obj
):
return
obj
[
'm_end_ptr'
].
cast
(
self
.
t
.
pointer
())
-
obj
[
'm_begin_ptr'
].
cast
(
self
.
t
.
pointer
())
return
obj
[
"m_end_ptr"
].
cast
(
self
.
t
.
pointer
())
-
obj
[
"m_begin_ptr"
].
cast
(
self
.
t
.
pointer
()
)
class
SmallVectorImplMatcher
(
gdb
.
xmethod
.
XMethodMatcher
):
def
__init__
(
self
):
super
().
__init__
(
'SmallVectorImplMatcher'
)
super
().
__init__
(
"SmallVectorImplMatcher"
)
def
match
(
self
,
class_type
,
method_name
):
if
re
.
match
(
'^megdnn::SmallVector(Impl)?<.*>'
,
class_type
.
tag
):
if
method_name
==
'at'
:
if
re
.
match
(
"^megdnn::SmallVector(Impl)?<.*>"
,
class_type
.
tag
):
if
method_name
==
"at"
:
return
SmallVectorImplWorker_at
(
class_type
.
template_argument
(
0
))
if
method_name
==
'operator[]'
:
if
method_name
==
"operator[]"
:
return
SmallVectorImplWorker_at
(
class_type
.
template_argument
(
0
))
if
method_name
==
'size'
:
if
method_name
==
"size"
:
return
SmallVectorImplWorker_size
(
class_type
.
template_argument
(
0
))
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录