Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
B
bcc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
bcc
Commits
66b8eddf
Commit
66b8eddf
authored
Oct 06, 2017
by
yonghong-song
Committed by
GitHub
Oct 06, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1377 from palmtenor/ksym_segfault
Avoid potential SEGFAULT when resolving Kernel symbols
parents
2e20494f
9c38f480
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
17 additions
and
13 deletions
+17
-13
src/cc/bcc_syms.cc
src/cc/bcc_syms.cc
+17
-13
No files found.
src/cc/bcc_syms.cc
View file @
66b8eddf
...
@@ -61,21 +61,25 @@ void KSyms::refresh() {
...
@@ -61,21 +61,25 @@ void KSyms::refresh() {
bool
KSyms
::
resolve_addr
(
uint64_t
addr
,
struct
bcc_symbol
*
sym
,
bool
demangle
)
{
bool
KSyms
::
resolve_addr
(
uint64_t
addr
,
struct
bcc_symbol
*
sym
,
bool
demangle
)
{
refresh
();
refresh
();
if
(
syms_
.
empty
())
{
std
::
vector
<
Symbol
>::
iterator
it
;
sym
->
name
=
nullptr
;
sym
->
demangle_name
=
nullptr
;
if
(
syms_
.
empty
())
sym
->
module
=
nullptr
;
goto
unknown_symbol
;
sym
->
offset
=
0x0
;
return
false
;
it
=
std
::
upper_bound
(
syms_
.
begin
(),
syms_
.
end
(),
Symbol
(
""
,
addr
));
if
(
it
!=
syms_
.
begin
())
{
it
--
;
sym
->
name
=
(
*
it
).
name
.
c_str
();
if
(
demangle
)
sym
->
demangle_name
=
sym
->
name
;
sym
->
module
=
"kernel"
;
sym
->
offset
=
addr
-
(
*
it
).
addr
;
return
true
;
}
}
auto
it
=
std
::
upper_bound
(
syms_
.
begin
(),
syms_
.
end
(),
Symbol
(
""
,
addr
))
-
1
;
unknown_symbol:
sym
->
name
=
(
*
it
).
name
.
c_str
();
memset
(
sym
,
0
,
sizeof
(
struct
bcc_symbol
));
if
(
demangle
)
return
false
;
sym
->
demangle_name
=
sym
->
name
;
sym
->
module
=
"kernel"
;
sym
->
offset
=
addr
-
(
*
it
).
addr
;
return
true
;
}
}
bool
KSyms
::
resolve_name
(
const
char
*
_unused
,
const
char
*
name
,
bool
KSyms
::
resolve_name
(
const
char
*
_unused
,
const
char
*
name
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment