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
19a48d57
Commit
19a48d57
authored
Sep 29, 2015
by
yonghong-song
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #257 from iovisor/bblanco_dev
Mask function calls from influencing probe_read
parents
4d97f7fa
74adb734
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
31 additions
and
7 deletions
+31
-7
src/cc/frontends/clang/b_frontend_action.cc
src/cc/frontends/clang/b_frontend_action.cc
+10
-7
tests/cc/test_clang.py
tests/cc/test_clang.py
+21
-0
No files found.
src/cc/frontends/clang/b_frontend_action.cc
View file @
19a48d57
...
...
@@ -94,14 +94,17 @@ bool BMapDeclVisitor::VisitBuiltinType(const BuiltinType *T) {
return
true
;
}
class
ProbeChecker
:
public
clang
::
RecursiveASTVisitor
<
ProbeChecker
>
{
class
ProbeChecker
:
public
RecursiveASTVisitor
<
ProbeChecker
>
{
public:
explicit
ProbeChecker
(
Expr
*
arg
,
const
set
<
Decl
*>
&
ptregs
)
:
needs_probe_
(
false
),
ptregs_
(
ptregs
)
{
if
(
arg
)
TraverseStmt
(
arg
);
}
bool
VisitDeclRefExpr
(
clang
::
DeclRefExpr
*
E
)
{
bool
VisitCallExpr
(
CallExpr
*
E
)
{
return
false
;
}
bool
VisitDeclRefExpr
(
DeclRefExpr
*
E
)
{
if
(
ptregs_
.
find
(
E
->
getDecl
())
!=
ptregs_
.
end
())
needs_probe_
=
true
;
return
true
;
...
...
@@ -113,10 +116,10 @@ class ProbeChecker : public clang::RecursiveASTVisitor<ProbeChecker> {
};
// Visit a piece of the AST and mark it as needing probe reads
class
ProbeSetter
:
public
clang
::
RecursiveASTVisitor
<
ProbeSetter
>
{
class
ProbeSetter
:
public
RecursiveASTVisitor
<
ProbeSetter
>
{
public:
explicit
ProbeSetter
(
set
<
Decl
*>
*
ptregs
)
:
ptregs_
(
ptregs
)
{}
bool
VisitDeclRefExpr
(
clang
::
DeclRefExpr
*
E
)
{
bool
VisitDeclRefExpr
(
DeclRefExpr
*
E
)
{
ptregs_
->
insert
(
E
->
getDecl
());
return
true
;
}
...
...
@@ -161,7 +164,7 @@ bool ProbeVisitor::VisitBinaryOperator(BinaryOperator *E) {
return
true
;
}
bool
ProbeVisitor
::
VisitUnaryOperator
(
UnaryOperator
*
E
)
{
if
(
E
->
getOpcode
()
!=
UO_Dere
f
)
if
(
E
->
getOpcode
()
==
UO_AddrO
f
)
return
true
;
if
(
memb_visited_
.
find
(
E
)
!=
memb_visited_
.
end
())
return
true
;
...
...
@@ -559,10 +562,10 @@ bool BTypeConsumer::HandleTopLevelDecl(DeclGroupRef Group) {
return
true
;
}
ProbeConsumer
::
ProbeConsumer
(
clang
::
ASTContext
&
C
,
Rewriter
&
rewriter
)
ProbeConsumer
::
ProbeConsumer
(
ASTContext
&
C
,
Rewriter
&
rewriter
)
:
visitor_
(
rewriter
)
{}
bool
ProbeConsumer
::
HandleTopLevelDecl
(
clang
::
DeclGroupRef
Group
)
{
bool
ProbeConsumer
::
HandleTopLevelDecl
(
DeclGroupRef
Group
)
{
for
(
auto
D
:
Group
)
{
if
(
FunctionDecl
*
F
=
dyn_cast
<
FunctionDecl
>
(
D
))
{
if
(
F
->
isExternallyVisible
()
&&
F
->
hasBody
())
{
...
...
tests/cc/test_clang.py
View file @
19a48d57
...
...
@@ -214,6 +214,27 @@ int kprobe__sys_open(struct pt_regs *ctx, const char *filename,
};
"""
)
def
test_task_switch
(
self
):
b
=
BPF
(
text
=
"""
#include <uapi/linux/ptrace.h>
#include <linux/sched.h>
struct key_t {
u32 prev_pid;
u32 curr_pid;
};
BPF_TABLE("hash", struct key_t, u64, stats, 1024);
int kprobe__finish_task_switch(struct pt_regs *ctx, struct task_struct *prev) {
struct key_t key = {};
u64 zero = 0, *val;
key.curr_pid = bpf_get_current_pid_tgid();
key.prev_pid = prev->pid;
val = stats.lookup_or_init(&key, &zero);
(*val)++;
return 0;
}
"""
)
if
__name__
==
"__main__"
:
main
()
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