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
13ebe8e8
Commit
13ebe8e8
authored
Nov 29, 2016
by
Teng Qin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Implement StatusTuple class instead of using std::tuple
parent
f5dce2c7
Changes
13
Show whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
248 additions
and
247 deletions
+248
-247
examples/cpp/CPUDistribution.cc
examples/cpp/CPUDistribution.cc
+6
-6
examples/cpp/HelloWorld.cc
examples/cpp/HelloWorld.cc
+6
-6
examples/cpp/RandomRead.cc
examples/cpp/RandomRead.cc
+6
-6
examples/cpp/RecordMySQLQuery.cc
examples/cpp/RecordMySQLQuery.cc
+6
-6
examples/cpp/TCPSendStack.cc
examples/cpp/TCPSendStack.cc
+6
-6
src/cc/BPF.cc
src/cc/BPF.cc
+58
-56
src/cc/BPFTable.cc
src/cc/BPFTable.cc
+15
-15
src/cc/bcc_exception.h
src/cc/bcc_exception.h
+24
-24
src/cc/frontends/b/codegen_llvm.cc
src/cc/frontends/b/codegen_llvm.cc
+45
-45
src/cc/frontends/b/loader.cc
src/cc/frontends/b/loader.cc
+5
-6
src/cc/frontends/b/node.h
src/cc/frontends/b/node.h
+5
-5
src/cc/frontends/b/printer.cc
src/cc/frontends/b/printer.cc
+29
-29
src/cc/frontends/b/type_check.cc
src/cc/frontends/b/type_check.cc
+37
-37
No files found.
examples/cpp/CPUDistribution.cc
View file @
13ebe8e8
...
@@ -61,15 +61,15 @@ int task_switch_event(struct pt_regs *ctx, struct task_struct *prev) {
...
@@ -61,15 +61,15 @@ int task_switch_event(struct pt_regs *ctx, struct task_struct *prev) {
int
main
(
int
argc
,
char
**
argv
)
{
int
main
(
int
argc
,
char
**
argv
)
{
ebpf
::
BPF
bpf
;
ebpf
::
BPF
bpf
;
auto
init_res
=
bpf
.
init
(
BPF_PROGRAM
);
auto
init_res
=
bpf
.
init
(
BPF_PROGRAM
);
if
(
std
::
get
<
0
>
(
init_res
)
!=
0
)
{
if
(
init_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
init_res
)
<<
std
::
endl
;
std
::
cerr
<<
init_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
auto
attach_res
=
auto
attach_res
=
bpf
.
attach_kprobe
(
"finish_task_switch"
,
"task_switch_event"
);
bpf
.
attach_kprobe
(
"finish_task_switch"
,
"task_switch_event"
);
if
(
std
::
get
<
0
>
(
attach_res
)
!=
0
)
{
if
(
attach_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
attach_res
)
<<
std
::
endl
;
std
::
cerr
<<
attach_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
...
@@ -88,8 +88,8 @@ int main(int argc, char** argv) {
...
@@ -88,8 +88,8 @@ int main(int argc, char** argv) {
}
}
auto
detach_res
=
bpf
.
detach_kprobe
(
"finish_task_switch"
);
auto
detach_res
=
bpf
.
detach_kprobe
(
"finish_task_switch"
);
if
(
std
::
get
<
0
>
(
detach_res
)
!=
0
)
{
if
(
detach_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
detach_res
)
<<
std
::
endl
;
std
::
cerr
<<
detach_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
...
...
examples/cpp/HelloWorld.cc
View file @
13ebe8e8
...
@@ -20,8 +20,8 @@ int on_sys_clone(void *ctx) {
...
@@ -20,8 +20,8 @@ int on_sys_clone(void *ctx) {
int
main
()
{
int
main
()
{
ebpf
::
BPF
bpf
;
ebpf
::
BPF
bpf
;
auto
init_res
=
bpf
.
init
(
BPF_PROGRAM
);
auto
init_res
=
bpf
.
init
(
BPF_PROGRAM
);
if
(
std
::
get
<
0
>
(
init_res
)
!=
0
)
{
if
(
init_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
init_res
)
<<
std
::
endl
;
std
::
cerr
<<
init_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
...
@@ -29,8 +29,8 @@ int main() {
...
@@ -29,8 +29,8 @@ int main() {
std
::
string
line
;
std
::
string
line
;
auto
attach_res
=
bpf
.
attach_kprobe
(
"sys_clone"
,
"on_sys_clone"
);
auto
attach_res
=
bpf
.
attach_kprobe
(
"sys_clone"
,
"on_sys_clone"
);
if
(
std
::
get
<
0
>
(
attach_res
)
!=
0
)
{
if
(
attach_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
attach_res
)
<<
std
::
endl
;
std
::
cerr
<<
attach_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
...
@@ -39,8 +39,8 @@ int main() {
...
@@ -39,8 +39,8 @@ int main() {
std
::
cout
<<
line
<<
std
::
endl
;
std
::
cout
<<
line
<<
std
::
endl
;
// Detach the probe if we got at least one line.
// Detach the probe if we got at least one line.
auto
detach_res
=
bpf
.
detach_kprobe
(
"sys_clone"
);
auto
detach_res
=
bpf
.
detach_kprobe
(
"sys_clone"
);
if
(
std
::
get
<
0
>
(
detach_res
)
!=
0
)
{
if
(
detach_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
detach_res
)
<<
std
::
endl
;
std
::
cerr
<<
detach_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
break
;
break
;
...
...
examples/cpp/RandomRead.cc
View file @
13ebe8e8
...
@@ -70,21 +70,21 @@ void signal_handler(int s) {
...
@@ -70,21 +70,21 @@ void signal_handler(int s) {
int
main
(
int
argc
,
char
**
argv
)
{
int
main
(
int
argc
,
char
**
argv
)
{
bpf
=
new
ebpf
::
BPF
();
bpf
=
new
ebpf
::
BPF
();
auto
init_res
=
bpf
->
init
(
BPF_PROGRAM
);
auto
init_res
=
bpf
->
init
(
BPF_PROGRAM
);
if
(
std
::
get
<
0
>
(
init_res
)
!=
0
)
{
if
(
init_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
init_res
)
<<
std
::
endl
;
std
::
cerr
<<
init_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
auto
attach_res
=
auto
attach_res
=
bpf
->
attach_tracepoint
(
"random:urandom_read"
,
"on_urandom_read"
);
bpf
->
attach_tracepoint
(
"random:urandom_read"
,
"on_urandom_read"
);
if
(
std
::
get
<
0
>
(
attach_res
)
!=
0
)
{
if
(
attach_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
attach_res
)
<<
std
::
endl
;
std
::
cerr
<<
attach_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
auto
open_res
=
bpf
->
open_perf_buffer
(
"events"
,
&
handle_output
);
auto
open_res
=
bpf
->
open_perf_buffer
(
"events"
,
&
handle_output
);
if
(
std
::
get
<
0
>
(
open_res
)
!=
0
)
{
if
(
open_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
open_res
)
<<
std
::
endl
;
std
::
cerr
<<
open_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
...
...
examples/cpp/RecordMySQLQuery.cc
View file @
13ebe8e8
...
@@ -63,15 +63,15 @@ int main(int argc, char** argv) {
...
@@ -63,15 +63,15 @@ int main(int argc, char** argv) {
ebpf
::
BPF
bpf
;
ebpf
::
BPF
bpf
;
auto
init_res
=
bpf
.
init
(
BPF_PROGRAM
);
auto
init_res
=
bpf
.
init
(
BPF_PROGRAM
);
if
(
std
::
get
<
0
>
(
init_res
)
!=
0
)
{
if
(
init_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
init_res
)
<<
std
::
endl
;
std
::
cerr
<<
init_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
auto
attach_res
=
auto
attach_res
=
bpf
.
attach_uprobe
(
mysql_path
,
ALLOC_QUERY_FUNC
,
"probe_mysql_query"
);
bpf
.
attach_uprobe
(
mysql_path
,
ALLOC_QUERY_FUNC
,
"probe_mysql_query"
);
if
(
std
::
get
<
0
>
(
attach_res
)
!=
0
)
{
if
(
attach_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
attach_res
)
<<
std
::
endl
;
std
::
cerr
<<
attach_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
...
@@ -94,8 +94,8 @@ int main(int argc, char** argv) {
...
@@ -94,8 +94,8 @@ int main(int argc, char** argv) {
}
}
auto
detach_res
=
bpf
.
detach_uprobe
(
mysql_path
,
ALLOC_QUERY_FUNC
);
auto
detach_res
=
bpf
.
detach_uprobe
(
mysql_path
,
ALLOC_QUERY_FUNC
);
if
(
std
::
get
<
0
>
(
detach_res
)
!=
0
)
{
if
(
detach_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
detach_res
)
<<
std
::
endl
;
std
::
cerr
<<
detach_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
...
...
examples/cpp/TCPSendStack.cc
View file @
13ebe8e8
...
@@ -58,14 +58,14 @@ struct stack_key_t {
...
@@ -58,14 +58,14 @@ struct stack_key_t {
int
main
(
int
argc
,
char
**
argv
)
{
int
main
(
int
argc
,
char
**
argv
)
{
ebpf
::
BPF
bpf
;
ebpf
::
BPF
bpf
;
auto
init_res
=
bpf
.
init
(
BPF_PROGRAM
);
auto
init_res
=
bpf
.
init
(
BPF_PROGRAM
);
if
(
std
::
get
<
0
>
(
init_res
)
!=
0
)
{
if
(
init_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
init_res
)
<<
std
::
endl
;
std
::
cerr
<<
init_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
auto
attach_res
=
bpf
.
attach_kprobe
(
"tcp_sendmsg"
,
"on_tcp_send"
);
auto
attach_res
=
bpf
.
attach_kprobe
(
"tcp_sendmsg"
,
"on_tcp_send"
);
if
(
std
::
get
<
0
>
(
attach_res
)
!=
0
)
{
if
(
attach_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
attach_res
)
<<
std
::
endl
;
std
::
cerr
<<
attach_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
...
@@ -105,8 +105,8 @@ int main(int argc, char** argv) {
...
@@ -105,8 +105,8 @@ int main(int argc, char** argv) {
}
}
auto
detach_res
=
bpf
.
detach_kprobe
(
"tcp_sendmsg"
);
auto
detach_res
=
bpf
.
detach_kprobe
(
"tcp_sendmsg"
);
if
(
std
::
get
<
0
>
(
detach_res
)
!=
0
)
{
if
(
detach_res
.
code
(
)
!=
0
)
{
std
::
cerr
<<
std
::
get
<
1
>
(
detach_res
)
<<
std
::
endl
;
std
::
cerr
<<
detach_res
.
msg
(
)
<<
std
::
endl
;
return
1
;
return
1
;
}
}
...
...
src/cc/BPF.cc
View file @
13ebe8e8
...
@@ -54,15 +54,15 @@ StatusTuple BPF::init(const std::string& bpf_program,
...
@@ -54,15 +54,15 @@ StatusTuple BPF::init(const std::string& bpf_program,
for
(
size_t
i
=
0
;
i
<
flags_len
;
i
++
)
for
(
size_t
i
=
0
;
i
<
flags_len
;
i
++
)
flags
[
i
]
=
cflags
[
i
].
c_str
();
flags
[
i
]
=
cflags
[
i
].
c_str
();
if
(
bpf_module_
->
load_string
(
bpf_program
,
flags
,
flags_len
)
!=
0
)
if
(
bpf_module_
->
load_string
(
bpf_program
,
flags
,
flags_len
)
!=
0
)
return
mkstatus
(
-
1
,
"Unable to initialize BPF program"
);
return
StatusTuple
(
-
1
,
"Unable to initialize BPF program"
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
};
};
BPF
::~
BPF
()
{
BPF
::~
BPF
()
{
auto
res
=
detach_all
();
auto
res
=
detach_all
();
if
(
std
::
get
<
0
>
(
res
)
!=
0
)
if
(
res
.
code
(
)
!=
0
)
std
::
cerr
<<
"Failed to detach all probes on destruction: "
<<
std
::
endl
std
::
cerr
<<
"Failed to detach all probes on destruction: "
<<
std
::
endl
<<
std
::
get
<
1
>
(
res
)
<<
std
::
endl
;
<<
res
.
msg
(
)
<<
std
::
endl
;
}
}
StatusTuple
BPF
::
detach_all
()
{
StatusTuple
BPF
::
detach_all
()
{
...
@@ -71,45 +71,45 @@ StatusTuple BPF::detach_all() {
...
@@ -71,45 +71,45 @@ StatusTuple BPF::detach_all() {
for
(
auto
it
:
kprobes_
)
{
for
(
auto
it
:
kprobes_
)
{
auto
res
=
detach_kprobe_event
(
it
.
first
,
it
.
second
);
auto
res
=
detach_kprobe_event
(
it
.
first
,
it
.
second
);
if
(
std
::
get
<
0
>
(
res
)
!=
0
)
{
if
(
res
.
code
(
)
!=
0
)
{
error_msg
+=
"Failed to detach kprobe event "
+
it
.
first
+
": "
;
error_msg
+=
"Failed to detach kprobe event "
+
it
.
first
+
": "
;
error_msg
+=
std
::
get
<
1
>
(
res
)
+
"
\n
"
;
error_msg
+=
res
.
msg
(
)
+
"
\n
"
;
has_error
=
true
;
has_error
=
true
;
}
}
}
}
for
(
auto
it
:
uprobes_
)
{
for
(
auto
it
:
uprobes_
)
{
auto
res
=
detach_uprobe_event
(
it
.
first
,
it
.
second
);
auto
res
=
detach_uprobe_event
(
it
.
first
,
it
.
second
);
if
(
std
::
get
<
0
>
(
res
)
!=
0
)
{
if
(
res
.
code
(
)
!=
0
)
{
error_msg
+=
"Failed to detach uprobe event "
+
it
.
first
+
": "
;
error_msg
+=
"Failed to detach uprobe event "
+
it
.
first
+
": "
;
error_msg
+=
std
::
get
<
1
>
(
res
)
+
"
\n
"
;
error_msg
+=
res
.
msg
(
)
+
"
\n
"
;
has_error
=
true
;
has_error
=
true
;
}
}
}
}
for
(
auto
it
:
tracepoints_
)
{
for
(
auto
it
:
tracepoints_
)
{
auto
res
=
detach_tracepoint_event
(
it
.
first
,
it
.
second
);
auto
res
=
detach_tracepoint_event
(
it
.
first
,
it
.
second
);
if
(
std
::
get
<
0
>
(
res
)
!=
0
)
{
if
(
res
.
code
(
)
!=
0
)
{
error_msg
+=
"Failed to detach Tracepoint "
+
it
.
first
+
": "
;
error_msg
+=
"Failed to detach Tracepoint "
+
it
.
first
+
": "
;
error_msg
+=
std
::
get
<
1
>
(
res
)
+
"
\n
"
;
error_msg
+=
res
.
msg
(
)
+
"
\n
"
;
has_error
=
true
;
has_error
=
true
;
}
}
}
}
for
(
auto
it
:
perf_buffers_
)
{
for
(
auto
it
:
perf_buffers_
)
{
auto
res
=
it
.
second
->
close
();
auto
res
=
it
.
second
->
close
();
if
(
std
::
get
<
0
>
(
res
)
!=
0
)
{
if
(
res
.
code
(
)
!=
0
)
{
error_msg
+=
"Failed to close perf buffer "
+
it
.
first
+
": "
;
error_msg
+=
"Failed to close perf buffer "
+
it
.
first
+
": "
;
error_msg
+=
std
::
get
<
1
>
(
res
)
+
"
\n
"
;
error_msg
+=
res
.
msg
(
)
+
"
\n
"
;
has_error
=
true
;
has_error
=
true
;
}
}
delete
it
.
second
;
delete
it
.
second
;
}
}
if
(
has_error
)
if
(
has_error
)
return
mkstatus
(
-
1
,
error_msg
);
return
StatusTuple
(
-
1
,
error_msg
);
else
else
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
attach_kprobe
(
const
std
::
string
&
kernel_func
,
StatusTuple
BPF
::
attach_kprobe
(
const
std
::
string
&
kernel_func
,
...
@@ -123,7 +123,7 @@ StatusTuple BPF::attach_kprobe(const std::string& kernel_func,
...
@@ -123,7 +123,7 @@ StatusTuple BPF::attach_kprobe(const std::string& kernel_func,
std
::
string
probe_event
=
get_kprobe_event
(
kernel_func
,
attach_type
);
std
::
string
probe_event
=
get_kprobe_event
(
kernel_func
,
attach_type
);
if
(
kprobes_
.
find
(
probe_event
)
!=
kprobes_
.
end
())
{
if
(
kprobes_
.
find
(
probe_event
)
!=
kprobes_
.
end
())
{
TRY2
(
unload_func
(
probe_func
));
TRY2
(
unload_func
(
probe_func
));
return
mkstatus
(
-
1
,
"kprobe %s already attached"
,
probe_event
.
c_str
());
return
StatusTuple
(
-
1
,
"kprobe %s already attached"
,
probe_event
.
c_str
());
}
}
std
::
string
probe_event_desc
=
attach_type_prefix
(
attach_type
);
std
::
string
probe_event_desc
=
attach_type_prefix
(
attach_type
);
...
@@ -135,16 +135,16 @@ StatusTuple BPF::attach_kprobe(const std::string& kernel_func,
...
@@ -135,16 +135,16 @@ StatusTuple BPF::attach_kprobe(const std::string& kernel_func,
if
(
!
res
)
{
if
(
!
res
)
{
TRY2
(
unload_func
(
probe_func
));
TRY2
(
unload_func
(
probe_func
));
return
mkstatus
(
-
1
,
"Unable to attach %skprobe for %s using %s"
,
return
StatusTuple
(
-
1
,
"Unable to attach %skprobe for %s using %s"
,
attach_type_debug
(
attach_type
).
c_str
(),
kernel_func
.
c_str
(),
attach_type_debug
(
attach_type
)
.
c_str
(),
probe_func
.
c_str
());
kernel_func
.
c_str
(),
probe_func
.
c_str
());
}
}
open_probe_t
p
=
{};
open_probe_t
p
=
{};
p
.
reader_ptr
=
res
;
p
.
reader_ptr
=
res
;
p
.
func
=
probe_func
;
p
.
func
=
probe_func
;
kprobes_
[
probe_event
]
=
std
::
move
(
p
);
kprobes_
[
probe_event
]
=
std
::
move
(
p
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
attach_uprobe
(
const
std
::
string
&
binary_path
,
StatusTuple
BPF
::
attach_uprobe
(
const
std
::
string
&
binary_path
,
...
@@ -164,7 +164,7 @@ StatusTuple BPF::attach_uprobe(const std::string& binary_path,
...
@@ -164,7 +164,7 @@ StatusTuple BPF::attach_uprobe(const std::string& binary_path,
get_uprobe_event
(
sym
.
module
,
sym
.
offset
,
attach_type
);
get_uprobe_event
(
sym
.
module
,
sym
.
offset
,
attach_type
);
if
(
uprobes_
.
find
(
probe_event
)
!=
uprobes_
.
end
())
{
if
(
uprobes_
.
find
(
probe_event
)
!=
uprobes_
.
end
())
{
TRY2
(
unload_func
(
probe_func
));
TRY2
(
unload_func
(
probe_func
));
return
mkstatus
(
-
1
,
"uprobe %s already attached"
,
probe_event
.
c_str
());
return
StatusTuple
(
-
1
,
"uprobe %s already attached"
,
probe_event
.
c_str
());
}
}
std
::
string
probe_event_desc
=
attach_type_prefix
(
attach_type
);
std
::
string
probe_event_desc
=
attach_type_prefix
(
attach_type
);
...
@@ -177,7 +177,7 @@ StatusTuple BPF::attach_uprobe(const std::string& binary_path,
...
@@ -177,7 +177,7 @@ StatusTuple BPF::attach_uprobe(const std::string& binary_path,
if
(
!
res
)
{
if
(
!
res
)
{
TRY2
(
unload_func
(
probe_func
));
TRY2
(
unload_func
(
probe_func
));
return
mkstatus
(
return
StatusTuple
(
-
1
,
-
1
,
"Unable to attach %suprobe for binary %s symbol %s addr %lx using %s
\n
"
,
"Unable to attach %suprobe for binary %s symbol %s addr %lx using %s
\n
"
,
attach_type_debug
(
attach_type
).
c_str
(),
binary_path
.
c_str
(),
attach_type_debug
(
attach_type
).
c_str
(),
binary_path
.
c_str
(),
...
@@ -188,7 +188,7 @@ StatusTuple BPF::attach_uprobe(const std::string& binary_path,
...
@@ -188,7 +188,7 @@ StatusTuple BPF::attach_uprobe(const std::string& binary_path,
p
.
reader_ptr
=
res
;
p
.
reader_ptr
=
res
;
p
.
func
=
probe_func
;
p
.
func
=
probe_func
;
uprobes_
[
probe_event
]
=
std
::
move
(
p
);
uprobes_
[
probe_event
]
=
std
::
move
(
p
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
attach_tracepoint
(
const
std
::
string
&
tracepoint
,
StatusTuple
BPF
::
attach_tracepoint
(
const
std
::
string
&
tracepoint
,
...
@@ -199,11 +199,12 @@ StatusTuple BPF::attach_tracepoint(const std::string& tracepoint,
...
@@ -199,11 +199,12 @@ StatusTuple BPF::attach_tracepoint(const std::string& tracepoint,
TRY2
(
load_func
(
probe_func
,
BPF_PROG_TYPE_TRACEPOINT
,
probe_fd
));
TRY2
(
load_func
(
probe_func
,
BPF_PROG_TYPE_TRACEPOINT
,
probe_fd
));
if
(
tracepoints_
.
find
(
tracepoint
)
!=
tracepoints_
.
end
())
if
(
tracepoints_
.
find
(
tracepoint
)
!=
tracepoints_
.
end
())
return
mkstatus
(
-
1
,
"Tracepoint %s already attached"
,
tracepoint
.
c_str
());
return
StatusTuple
(
-
1
,
"Tracepoint %s already attached"
,
tracepoint
.
c_str
());
auto
pos
=
tracepoint
.
find
(
":"
);
auto
pos
=
tracepoint
.
find
(
":"
);
if
((
pos
==
std
::
string
::
npos
)
||
(
pos
!=
tracepoint
.
rfind
(
":"
)))
if
((
pos
==
std
::
string
::
npos
)
||
(
pos
!=
tracepoint
.
rfind
(
":"
)))
return
mkstatus
(
-
1
,
"Unable to parse Tracepoint %s"
,
tracepoint
.
c_str
());
return
StatusTuple
(
-
1
,
"Unable to parse Tracepoint %s"
,
tracepoint
.
c_str
());
std
::
string
tp_category
=
tracepoint
.
substr
(
0
,
pos
);
std
::
string
tp_category
=
tracepoint
.
substr
(
0
,
pos
);
std
::
string
tp_name
=
tracepoint
.
substr
(
pos
+
1
);
std
::
string
tp_name
=
tracepoint
.
substr
(
pos
+
1
);
...
@@ -213,7 +214,7 @@ StatusTuple BPF::attach_tracepoint(const std::string& tracepoint,
...
@@ -213,7 +214,7 @@ StatusTuple BPF::attach_tracepoint(const std::string& tracepoint,
if
(
!
res
)
{
if
(
!
res
)
{
TRY2
(
unload_func
(
probe_func
));
TRY2
(
unload_func
(
probe_func
));
return
mkstatus
(
-
1
,
"Unable to attach Tracepoint %s using %s"
,
return
StatusTuple
(
-
1
,
"Unable to attach Tracepoint %s using %s"
,
tracepoint
.
c_str
(),
probe_func
.
c_str
());
tracepoint
.
c_str
(),
probe_func
.
c_str
());
}
}
...
@@ -221,7 +222,7 @@ StatusTuple BPF::attach_tracepoint(const std::string& tracepoint,
...
@@ -221,7 +222,7 @@ StatusTuple BPF::attach_tracepoint(const std::string& tracepoint,
p
.
reader_ptr
=
res
;
p
.
reader_ptr
=
res
;
p
.
func
=
probe_func
;
p
.
func
=
probe_func
;
tracepoints_
[
tracepoint
]
=
std
::
move
(
p
);
tracepoints_
[
tracepoint
]
=
std
::
move
(
p
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
detach_kprobe
(
const
std
::
string
&
kernel_func
,
StatusTuple
BPF
::
detach_kprobe
(
const
std
::
string
&
kernel_func
,
...
@@ -230,13 +231,13 @@ StatusTuple BPF::detach_kprobe(const std::string& kernel_func,
...
@@ -230,13 +231,13 @@ StatusTuple BPF::detach_kprobe(const std::string& kernel_func,
auto
it
=
kprobes_
.
find
(
event
);
auto
it
=
kprobes_
.
find
(
event
);
if
(
it
==
kprobes_
.
end
())
if
(
it
==
kprobes_
.
end
())
return
mkstatus
(
-
1
,
"No open %skprobe for %s"
,
return
StatusTuple
(
-
1
,
"No open %skprobe for %s"
,
attach_type_debug
(
attach_type
).
c_str
(),
attach_type_debug
(
attach_type
).
c_str
(),
kernel_func
.
c_str
());
kernel_func
.
c_str
());
TRY2
(
detach_kprobe_event
(
it
->
first
,
it
->
second
));
TRY2
(
detach_kprobe_event
(
it
->
first
,
it
->
second
));
kprobes_
.
erase
(
it
);
kprobes_
.
erase
(
it
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
detach_uprobe
(
const
std
::
string
&
binary_path
,
StatusTuple
BPF
::
detach_uprobe
(
const
std
::
string
&
binary_path
,
...
@@ -248,23 +249,23 @@ StatusTuple BPF::detach_uprobe(const std::string& binary_path,
...
@@ -248,23 +249,23 @@ StatusTuple BPF::detach_uprobe(const std::string& binary_path,
std
::
string
event
=
get_uprobe_event
(
sym
.
module
,
sym
.
offset
,
attach_type
);
std
::
string
event
=
get_uprobe_event
(
sym
.
module
,
sym
.
offset
,
attach_type
);
auto
it
=
uprobes_
.
find
(
event
);
auto
it
=
uprobes_
.
find
(
event
);
if
(
it
==
uprobes_
.
end
())
if
(
it
==
uprobes_
.
end
())
return
mkstatus
(
-
1
,
"No open %suprobe for binary %s symbol %s addr %lx"
,
return
StatusTuple
(
-
1
,
"No open %suprobe for binary %s symbol %s addr %lx"
,
attach_type_debug
(
attach_type
).
c_str
(),
binary_path
.
c_str
(),
attach_type_debug
(
attach_type
)
.
c_str
(),
symbol
.
c_str
(),
symbol_addr
);
binary_path
.
c_str
(),
symbol
.
c_str
(),
symbol_addr
);
TRY2
(
detach_uprobe_event
(
it
->
first
,
it
->
second
));
TRY2
(
detach_uprobe_event
(
it
->
first
,
it
->
second
));
uprobes_
.
erase
(
it
);
uprobes_
.
erase
(
it
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
detach_tracepoint
(
const
std
::
string
&
tracepoint
)
{
StatusTuple
BPF
::
detach_tracepoint
(
const
std
::
string
&
tracepoint
)
{
auto
it
=
tracepoints_
.
find
(
tracepoint
);
auto
it
=
tracepoints_
.
find
(
tracepoint
);
if
(
it
==
tracepoints_
.
end
())
if
(
it
==
tracepoints_
.
end
())
return
mkstatus
(
-
1
,
"No open Tracepoint %s"
,
tracepoint
.
c_str
());
return
StatusTuple
(
-
1
,
"No open Tracepoint %s"
,
tracepoint
.
c_str
());
TRY2
(
detach_tracepoint_event
(
it
->
first
,
it
->
second
));
TRY2
(
detach_tracepoint_event
(
it
->
first
,
it
->
second
));
tracepoints_
.
erase
(
it
);
tracepoints_
.
erase
(
it
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
open_perf_buffer
(
const
std
::
string
&
name
,
StatusTuple
BPF
::
open_perf_buffer
(
const
std
::
string
&
name
,
...
@@ -273,15 +274,15 @@ StatusTuple BPF::open_perf_buffer(const std::string& name,
...
@@ -273,15 +274,15 @@ StatusTuple BPF::open_perf_buffer(const std::string& name,
perf_buffers_
[
name
]
=
new
BPFPerfBuffer
(
bpf_module_
.
get
(),
name
);
perf_buffers_
[
name
]
=
new
BPFPerfBuffer
(
bpf_module_
.
get
(),
name
);
auto
table
=
perf_buffers_
[
name
];
auto
table
=
perf_buffers_
[
name
];
TRY2
(
table
->
open
(
cb
,
cb_cookie
));
TRY2
(
table
->
open
(
cb
,
cb_cookie
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
close_perf_buffer
(
const
std
::
string
&
name
)
{
StatusTuple
BPF
::
close_perf_buffer
(
const
std
::
string
&
name
)
{
auto
it
=
perf_buffers_
.
find
(
name
);
auto
it
=
perf_buffers_
.
find
(
name
);
if
(
it
==
perf_buffers_
.
end
())
if
(
it
==
perf_buffers_
.
end
())
return
mkstatus
(
-
1
,
"Perf buffer for %s not open"
,
name
.
c_str
());
return
StatusTuple
(
-
1
,
"Perf buffer for %s not open"
,
name
.
c_str
());
TRY2
(
it
->
second
->
close
());
TRY2
(
it
->
second
->
close
());
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
void
BPF
::
poll_perf_buffer
(
const
std
::
string
&
name
,
int
timeout
)
{
void
BPF
::
poll_perf_buffer
(
const
std
::
string
&
name
,
int
timeout
)
{
...
@@ -295,12 +296,13 @@ StatusTuple BPF::load_func(const std::string& func_name,
...
@@ -295,12 +296,13 @@ StatusTuple BPF::load_func(const std::string& func_name,
enum
bpf_prog_type
type
,
int
&
fd
)
{
enum
bpf_prog_type
type
,
int
&
fd
)
{
if
(
funcs_
.
find
(
func_name
)
!=
funcs_
.
end
())
{
if
(
funcs_
.
find
(
func_name
)
!=
funcs_
.
end
())
{
fd
=
funcs_
[
func_name
];
fd
=
funcs_
[
func_name
];
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
uint8_t
*
func_start
=
bpf_module_
->
function_start
(
func_name
);
uint8_t
*
func_start
=
bpf_module_
->
function_start
(
func_name
);
if
(
!
func_start
)
if
(
!
func_start
)
return
mkstatus
(
-
1
,
"Can't find start of function %s"
,
func_name
.
c_str
());
return
StatusTuple
(
-
1
,
"Can't find start of function %s"
,
func_name
.
c_str
());
size_t
func_size
=
bpf_module_
->
function_size
(
func_name
);
size_t
func_size
=
bpf_module_
->
function_size
(
func_name
);
fd
=
bpf_prog_load
(
type
,
reinterpret_cast
<
struct
bpf_insn
*>
(
func_start
),
fd
=
bpf_prog_load
(
type
,
reinterpret_cast
<
struct
bpf_insn
*>
(
func_start
),
...
@@ -310,22 +312,22 @@ StatusTuple BPF::load_func(const std::string& func_name,
...
@@ -310,22 +312,22 @@ StatusTuple BPF::load_func(const std::string& func_name,
);
);
if
(
fd
<
0
)
if
(
fd
<
0
)
return
mkstatus
(
-
1
,
"Failed to load %s: %d"
,
func_name
.
c_str
(),
fd
);
return
StatusTuple
(
-
1
,
"Failed to load %s: %d"
,
func_name
.
c_str
(),
fd
);
funcs_
[
func_name
]
=
fd
;
funcs_
[
func_name
]
=
fd
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
unload_func
(
const
std
::
string
&
func_name
)
{
StatusTuple
BPF
::
unload_func
(
const
std
::
string
&
func_name
)
{
auto
it
=
funcs_
.
find
(
func_name
);
auto
it
=
funcs_
.
find
(
func_name
);
if
(
it
==
funcs_
.
end
())
if
(
it
==
funcs_
.
end
())
return
mkstatus
(
-
1
,
"Probe function %s not loaded"
,
func_name
.
c_str
());
return
StatusTuple
(
-
1
,
"Probe function %s not loaded"
,
func_name
.
c_str
());
int
res
=
close
(
it
->
second
);
int
res
=
close
(
it
->
second
);
if
(
res
!=
0
)
if
(
res
!=
0
)
return
mkstatus
(
-
1
,
"Can't close FD for %s: %d"
,
it
->
first
.
c_str
(),
res
);
return
StatusTuple
(
-
1
,
"Can't close FD for %s: %d"
,
it
->
first
.
c_str
(),
res
);
funcs_
.
erase
(
it
);
funcs_
.
erase
(
it
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
check_binary_symbol
(
const
std
::
string
&
binary_path
,
StatusTuple
BPF
::
check_binary_symbol
(
const
std
::
string
&
binary_path
,
...
@@ -334,10 +336,10 @@ StatusTuple BPF::check_binary_symbol(const std::string& binary_path,
...
@@ -334,10 +336,10 @@ StatusTuple BPF::check_binary_symbol(const std::string& binary_path,
int
res
=
bcc_resolve_symname
(
binary_path
.
c_str
(),
symbol
.
c_str
(),
int
res
=
bcc_resolve_symname
(
binary_path
.
c_str
(),
symbol
.
c_str
(),
symbol_addr
,
output
);
symbol_addr
,
output
);
if
(
res
<
0
)
if
(
res
<
0
)
return
mkstatus
(
-
1
,
return
StatusTuple
(
"Unable to find offset for binary %s symbol %s address %lx"
,
-
1
,
"Unable to find offset for binary %s symbol %s address %lx"
,
binary_path
.
c_str
(),
symbol
.
c_str
(),
symbol_addr
);
binary_path
.
c_str
(),
symbol
.
c_str
(),
symbol_addr
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
std
::
string
BPF
::
get_kprobe_event
(
const
std
::
string
&
kernel_func
,
std
::
string
BPF
::
get_kprobe_event
(
const
std
::
string
&
kernel_func
,
...
@@ -364,8 +366,8 @@ StatusTuple BPF::detach_kprobe_event(const std::string& event,
...
@@ -364,8 +366,8 @@ StatusTuple BPF::detach_kprobe_event(const std::string& event,
TRY2
(
unload_func
(
attr
.
func
));
TRY2
(
unload_func
(
attr
.
func
));
std
::
string
detach_event
=
"-:kprobes/"
+
event
;
std
::
string
detach_event
=
"-:kprobes/"
+
event
;
if
(
bpf_detach_kprobe
(
detach_event
.
c_str
())
<
0
)
if
(
bpf_detach_kprobe
(
detach_event
.
c_str
())
<
0
)
return
mkstatus
(
-
1
,
"Unable to detach kprobe %s"
,
event
.
c_str
());
return
StatusTuple
(
-
1
,
"Unable to detach kprobe %s"
,
event
.
c_str
());
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
detach_uprobe_event
(
const
std
::
string
&
event
,
StatusTuple
BPF
::
detach_uprobe_event
(
const
std
::
string
&
event
,
...
@@ -377,8 +379,8 @@ StatusTuple BPF::detach_uprobe_event(const std::string& event,
...
@@ -377,8 +379,8 @@ StatusTuple BPF::detach_uprobe_event(const std::string& event,
TRY2
(
unload_func
(
attr
.
func
));
TRY2
(
unload_func
(
attr
.
func
));
std
::
string
detach_event
=
"-:uprobes/"
+
event
;
std
::
string
detach_event
=
"-:uprobes/"
+
event
;
if
(
bpf_detach_uprobe
(
detach_event
.
c_str
())
<
0
)
if
(
bpf_detach_uprobe
(
detach_event
.
c_str
())
<
0
)
return
mkstatus
(
-
1
,
"Unable to detach uprobe %s"
,
event
.
c_str
());
return
StatusTuple
(
-
1
,
"Unable to detach uprobe %s"
,
event
.
c_str
());
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPF
::
detach_tracepoint_event
(
const
std
::
string
&
tracepoint
,
StatusTuple
BPF
::
detach_tracepoint_event
(
const
std
::
string
&
tracepoint
,
...
@@ -390,7 +392,7 @@ StatusTuple BPF::detach_tracepoint_event(const std::string& tracepoint,
...
@@ -390,7 +392,7 @@ StatusTuple BPF::detach_tracepoint_event(const std::string& tracepoint,
TRY2
(
unload_func
(
attr
.
func
));
TRY2
(
unload_func
(
attr
.
func
));
// TODO: bpf_detach_tracepoint currently does nothing.
// TODO: bpf_detach_tracepoint currently does nothing.
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
}
// namespace ebpf
}
// namespace ebpf
src/cc/BPFTable.cc
View file @
13ebe8e8
...
@@ -68,36 +68,36 @@ std::vector<std::string> BPFStackTable::get_stack_symbol(int stack_id,
...
@@ -68,36 +68,36 @@ std::vector<std::string> BPFStackTable::get_stack_symbol(int stack_id,
StatusTuple
BPFPerfBuffer
::
open_on_cpu
(
perf_reader_raw_cb
cb
,
int
cpu
,
StatusTuple
BPFPerfBuffer
::
open_on_cpu
(
perf_reader_raw_cb
cb
,
int
cpu
,
void
*
cb_cookie
)
{
void
*
cb_cookie
)
{
if
(
cpu_readers_
.
find
(
cpu
)
!=
cpu_readers_
.
end
())
if
(
cpu_readers_
.
find
(
cpu
)
!=
cpu_readers_
.
end
())
return
mkstatus
(
-
1
,
"Perf buffer already open on CPU %d"
,
cpu
);
return
StatusTuple
(
-
1
,
"Perf buffer already open on CPU %d"
,
cpu
);
auto
reader
=
auto
reader
=
static_cast
<
perf_reader
*>
(
bpf_open_perf_buffer
(
cb
,
cb_cookie
,
-
1
,
cpu
));
static_cast
<
perf_reader
*>
(
bpf_open_perf_buffer
(
cb
,
cb_cookie
,
-
1
,
cpu
));
if
(
reader
==
nullptr
)
if
(
reader
==
nullptr
)
return
mkstatus
(
-
1
,
"Unable to construct perf reader"
);
return
StatusTuple
(
-
1
,
"Unable to construct perf reader"
);
int
reader_fd
=
perf_reader_fd
(
reader
);
int
reader_fd
=
perf_reader_fd
(
reader
);
if
(
!
update
(
&
cpu
,
&
reader_fd
))
{
if
(
!
update
(
&
cpu
,
&
reader_fd
))
{
perf_reader_free
(
static_cast
<
void
*>
(
reader
));
perf_reader_free
(
static_cast
<
void
*>
(
reader
));
return
mkstatus
(
-
1
,
"Unable to open perf buffer on CPU %d: %s"
,
cpu
,
return
StatusTuple
(
-
1
,
"Unable to open perf buffer on CPU %d: %s"
,
cpu
,
strerror
(
errno
));
strerror
(
errno
));
}
}
cpu_readers_
[
cpu
]
=
static_cast
<
perf_reader
*>
(
reader
);
cpu_readers_
[
cpu
]
=
static_cast
<
perf_reader
*>
(
reader
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPFPerfBuffer
::
open
(
perf_reader_raw_cb
cb
,
void
*
cb_cookie
)
{
StatusTuple
BPFPerfBuffer
::
open
(
perf_reader_raw_cb
cb
,
void
*
cb_cookie
)
{
for
(
int
i
=
0
;
i
<
sysconf
(
_SC_NPROCESSORS_ONLN
);
i
++
)
for
(
int
i
=
0
;
i
<
sysconf
(
_SC_NPROCESSORS_ONLN
);
i
++
)
TRY2
(
open_on_cpu
(
cb
,
i
,
cb_cookie
));
TRY2
(
open_on_cpu
(
cb
,
i
,
cb_cookie
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPFPerfBuffer
::
close_on_cpu
(
int
cpu
)
{
StatusTuple
BPFPerfBuffer
::
close_on_cpu
(
int
cpu
)
{
auto
it
=
cpu_readers_
.
find
(
cpu
);
auto
it
=
cpu_readers_
.
find
(
cpu
);
if
(
it
==
cpu_readers_
.
end
())
if
(
it
==
cpu_readers_
.
end
())
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
perf_reader_free
(
static_cast
<
void
*>
(
it
->
second
));
perf_reader_free
(
static_cast
<
void
*>
(
it
->
second
));
if
(
!
remove
(
const_cast
<
int
*>
(
&
(
it
->
first
))))
if
(
!
remove
(
const_cast
<
int
*>
(
&
(
it
->
first
))))
return
mkstatus
(
-
1
,
"Unable to close perf buffer on CPU %d"
,
it
->
first
);
return
StatusTuple
(
-
1
,
"Unable to close perf buffer on CPU %d"
,
it
->
first
);
cpu_readers_
.
erase
(
it
);
cpu_readers_
.
erase
(
it
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
BPFPerfBuffer
::
close
()
{
StatusTuple
BPFPerfBuffer
::
close
()
{
...
@@ -105,15 +105,15 @@ StatusTuple BPFPerfBuffer::close() {
...
@@ -105,15 +105,15 @@ StatusTuple BPFPerfBuffer::close() {
bool
has_error
=
false
;
bool
has_error
=
false
;
for
(
int
i
=
0
;
i
<
sysconf
(
_SC_NPROCESSORS_ONLN
);
i
++
)
{
for
(
int
i
=
0
;
i
<
sysconf
(
_SC_NPROCESSORS_ONLN
);
i
++
)
{
auto
res
=
close_on_cpu
(
i
);
auto
res
=
close_on_cpu
(
i
);
if
(
std
::
get
<
0
>
(
res
)
!=
0
)
{
if
(
res
.
code
(
)
!=
0
)
{
errors
+=
"Failed to close CPU"
+
std
::
to_string
(
i
)
+
" perf buffer: "
;
errors
+=
"Failed to close CPU"
+
std
::
to_string
(
i
)
+
" perf buffer: "
;
errors
+=
std
::
get
<
1
>
(
res
)
+
"
\n
"
;
errors
+=
res
.
msg
(
)
+
"
\n
"
;
has_error
=
true
;
has_error
=
true
;
}
}
}
}
if
(
has_error
)
if
(
has_error
)
return
mkstatus
(
-
1
,
errors
);
return
StatusTuple
(
-
1
,
errors
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
void
BPFPerfBuffer
::
poll
(
int
timeout
)
{
void
BPFPerfBuffer
::
poll
(
int
timeout
)
{
...
@@ -126,9 +126,9 @@ void BPFPerfBuffer::poll(int timeout) {
...
@@ -126,9 +126,9 @@ void BPFPerfBuffer::poll(int timeout) {
BPFPerfBuffer
::~
BPFPerfBuffer
()
{
BPFPerfBuffer
::~
BPFPerfBuffer
()
{
auto
res
=
close
();
auto
res
=
close
();
if
(
std
::
get
<
0
>
(
res
)
!=
0
)
if
(
res
.
code
(
)
!=
0
)
std
::
cerr
<<
"Failed to close all perf buffer on destruction: "
std
::
cerr
<<
"Failed to close all perf buffer on destruction: "
<<
std
::
get
<
1
>
(
res
)
<<
std
::
endl
;
<<
res
.
msg
(
)
<<
std
::
endl
;
}
}
}
// namespace ebpf
}
// namespace ebpf
src/cc/bcc_exception.h
View file @
13ebe8e8
...
@@ -18,38 +18,38 @@
...
@@ -18,38 +18,38 @@
#include <cstdio>
#include <cstdio>
#include <string>
#include <string>
#include <tuple>
#undef NDEBUG
#undef NDEBUG
namespace
ebpf
{
namespace
ebpf
{
typedef
std
::
tuple
<
int
,
std
::
string
>
StatusTuple
;
class
StatusTuple
{
public:
StatusTuple
(
int
ret
)
:
ret_
(
ret
)
{}
template
<
typename
...
Args
>
StatusTuple
(
int
ret
,
const
char
*
msg
)
:
ret_
(
ret
),
msg_
(
msg
)
{}
StatusTuple
mkstatus
(
int
ret
,
const
char
*
fmt
,
Args
...
args
)
{
char
buf
[
1024
];
StatusTuple
(
int
ret
,
const
std
::
string
&
msg
)
:
ret_
(
ret
),
msg_
(
msg
)
{}
template
<
typename
...
Args
>
StatusTuple
(
int
ret
,
const
char
*
fmt
,
Args
...
args
)
:
ret_
(
ret
)
{
char
buf
[
2048
];
snprintf
(
buf
,
sizeof
(
buf
),
fmt
,
args
...);
snprintf
(
buf
,
sizeof
(
buf
),
fmt
,
args
...);
return
std
::
make_tuple
(
ret
,
std
::
string
(
buf
)
);
msg_
=
std
::
string
(
buf
);
}
}
static
inline
StatusTuple
mkstatus
(
int
ret
,
const
char
*
msg
)
{
int
code
()
{
return
ret_
;
}
return
std
::
make_tuple
(
ret
,
std
::
string
(
msg
));
}
static
inline
StatusTuple
mkstatus
(
std
::
string
msg
()
{
return
msg_
;
}
int
ret
,
const
std
::
string
&
msg
)
{
return
std
::
make_tuple
(
ret
,
msg
);
}
static
inline
StatusTuple
mkstatus
(
int
ret
)
{
private:
return
std
::
make_tuple
(
ret
,
std
::
string
());
int
ret_
;
}
std
::
string
msg_
;
};
#define TRY2(CMD) \
#define TRY2(CMD) \
do { \
do { \
StatusTuple __stp = (CMD); \
StatusTuple __stp = (CMD); \
if (
std::get<0>(__stp) != 0) {
\
if (
__stp.code() != 0) {
\
return __stp; \
return __stp; \
} \
} \
} while (0)
} while (0)
...
...
src/cc/frontends/b/codegen_llvm.cc
View file @
13ebe8e8
...
@@ -126,7 +126,7 @@ StatusTuple CodegenLLVM::visit_block_stmt_node(BlockStmtNode *n) {
...
@@ -126,7 +126,7 @@ StatusTuple CodegenLLVM::visit_block_stmt_node(BlockStmtNode *n) {
if
(
n
->
scope_
)
if
(
n
->
scope_
)
scopes_
->
pop_var
();
scopes_
->
pop_var
();
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_if_stmt_node
(
IfStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_if_stmt_node
(
IfStmtNode
*
n
)
{
...
@@ -159,7 +159,7 @@ StatusTuple CodegenLLVM::visit_if_stmt_node(IfStmtNode *n) {
...
@@ -159,7 +159,7 @@ StatusTuple CodegenLLVM::visit_if_stmt_node(IfStmtNode *n) {
B
.
SetInsertPoint
(
label_end
);
B
.
SetInsertPoint
(
label_end
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_onvalid_stmt_node
(
OnValidStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_onvalid_stmt_node
(
OnValidStmtNode
*
n
)
{
...
@@ -192,7 +192,7 @@ StatusTuple CodegenLLVM::visit_onvalid_stmt_node(OnValidStmtNode *n) {
...
@@ -192,7 +192,7 @@ StatusTuple CodegenLLVM::visit_onvalid_stmt_node(OnValidStmtNode *n) {
}
}
B
.
SetInsertPoint
(
label_end
);
B
.
SetInsertPoint
(
label_end
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_switch_stmt_node
(
SwitchStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_switch_stmt_node
(
SwitchStmtNode
*
n
)
{
...
@@ -213,7 +213,7 @@ StatusTuple CodegenLLVM::visit_switch_stmt_node(SwitchStmtNode *n) {
...
@@ -213,7 +213,7 @@ StatusTuple CodegenLLVM::visit_switch_stmt_node(SwitchStmtNode *n) {
B
.
SetInsertPoint
(
resolve_label
(
"DONE"
));
B
.
SetInsertPoint
(
resolve_label
(
"DONE"
));
label_end
->
eraseFromParent
();
label_end
->
eraseFromParent
();
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_case_stmt_node
(
CaseStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_case_stmt_node
(
CaseStmtNode
*
n
)
{
...
@@ -236,7 +236,7 @@ StatusTuple CodegenLLVM::visit_case_stmt_node(CaseStmtNode *n) {
...
@@ -236,7 +236,7 @@ StatusTuple CodegenLLVM::visit_case_stmt_node(CaseStmtNode *n) {
if
(
!
B
.
GetInsertBlock
()
->
getTerminator
())
if
(
!
B
.
GetInsertBlock
()
->
getTerminator
())
B
.
CreateBr
(
label_end
);
B
.
CreateBr
(
label_end
);
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_ident_expr_node
(
IdentExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_ident_expr_node
(
IdentExprNode
*
n
)
{
...
@@ -308,7 +308,7 @@ StatusTuple CodegenLLVM::visit_ident_expr_node(IdentExprNode *n) {
...
@@ -308,7 +308,7 @@ StatusTuple CodegenLLVM::visit_ident_expr_node(IdentExprNode *n) {
}
}
}
}
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_assign_expr_node
(
AssignExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_assign_expr_node
(
AssignExprNode
*
n
)
{
...
@@ -343,7 +343,7 @@ StatusTuple CodegenLLVM::visit_assign_expr_node(AssignExprNode *n) {
...
@@ -343,7 +343,7 @@ StatusTuple CodegenLLVM::visit_assign_expr_node(AssignExprNode *n) {
}
}
}
}
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
lookup_var
(
Node
*
n
,
const
string
&
name
,
Scopes
::
VarScope
*
scope
,
StatusTuple
CodegenLLVM
::
lookup_var
(
Node
*
n
,
const
string
&
name
,
Scopes
::
VarScope
*
scope
,
...
@@ -353,7 +353,7 @@ StatusTuple CodegenLLVM::lookup_var(Node *n, const string &name, Scopes::VarScop
...
@@ -353,7 +353,7 @@ StatusTuple CodegenLLVM::lookup_var(Node *n, const string &name, Scopes::VarScop
auto
it
=
vars_
.
find
(
*
decl
);
auto
it
=
vars_
.
find
(
*
decl
);
if
(
it
==
vars_
.
end
())
return
mkstatus_
(
n
,
"unable to find %s memory location"
,
name
.
c_str
());
if
(
it
==
vars_
.
end
())
return
mkstatus_
(
n
,
"unable to find %s memory location"
,
name
.
c_str
());
*
mem
=
it
->
second
;
*
mem
=
it
->
second
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_packet_expr_node
(
PacketExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_packet_expr_node
(
PacketExprNode
*
n
)
{
...
@@ -407,7 +407,7 @@ StatusTuple CodegenLLVM::visit_packet_expr_node(PacketExprNode *n) {
...
@@ -407,7 +407,7 @@ StatusTuple CodegenLLVM::visit_packet_expr_node(PacketExprNode *n) {
return
mkstatus_
(
n
,
"unsupported"
);
return
mkstatus_
(
n
,
"unsupported"
);
}
}
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_integer_expr_node
(
IntegerExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_integer_expr_node
(
IntegerExprNode
*
n
)
{
...
@@ -416,7 +416,7 @@ StatusTuple CodegenLLVM::visit_integer_expr_node(IntegerExprNode *n) {
...
@@ -416,7 +416,7 @@ StatusTuple CodegenLLVM::visit_integer_expr_node(IntegerExprNode *n) {
expr_
=
ConstantInt
::
get
(
mod_
->
getContext
(),
val
);
expr_
=
ConstantInt
::
get
(
mod_
->
getContext
(),
val
);
if
(
n
->
bits_
)
if
(
n
->
bits_
)
expr_
=
B
.
CreateIntCast
(
expr_
,
B
.
getIntNTy
(
n
->
bits_
),
false
);
expr_
=
B
.
CreateIntCast
(
expr_
,
B
.
getIntNTy
(
n
->
bits_
),
false
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_string_expr_node
(
StringExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_string_expr_node
(
StringExprNode
*
n
)
{
...
@@ -427,7 +427,7 @@ StatusTuple CodegenLLVM::visit_string_expr_node(StringExprNode *n) {
...
@@ -427,7 +427,7 @@ StatusTuple CodegenLLVM::visit_string_expr_node(StringExprNode *n) {
B
.
CreateMemCpy
(
ptr
,
global
,
n
->
val_
.
size
()
+
1
,
1
);
B
.
CreateMemCpy
(
ptr
,
global
,
n
->
val_
.
size
()
+
1
,
1
);
expr_
=
ptr
;
expr_
=
ptr
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_short_circuit_and
(
BinopExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
emit_short_circuit_and
(
BinopExprNode
*
n
)
{
...
@@ -454,7 +454,7 @@ StatusTuple CodegenLLVM::emit_short_circuit_and(BinopExprNode *n) {
...
@@ -454,7 +454,7 @@ StatusTuple CodegenLLVM::emit_short_circuit_and(BinopExprNode *n) {
phi
->
addIncoming
(
pop_expr
(),
label_then
);
phi
->
addIncoming
(
pop_expr
(),
label_then
);
expr_
=
phi
;
expr_
=
phi
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_short_circuit_or
(
BinopExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
emit_short_circuit_or
(
BinopExprNode
*
n
)
{
...
@@ -481,7 +481,7 @@ StatusTuple CodegenLLVM::emit_short_circuit_or(BinopExprNode *n) {
...
@@ -481,7 +481,7 @@ StatusTuple CodegenLLVM::emit_short_circuit_or(BinopExprNode *n) {
phi
->
addIncoming
(
pop_expr
(),
label_then
);
phi
->
addIncoming
(
pop_expr
(),
label_then
);
expr_
=
phi
;
expr_
=
phi
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_binop_expr_node
(
BinopExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_binop_expr_node
(
BinopExprNode
*
n
)
{
...
@@ -509,7 +509,7 @@ StatusTuple CodegenLLVM::visit_binop_expr_node(BinopExprNode *n) {
...
@@ -509,7 +509,7 @@ StatusTuple CodegenLLVM::visit_binop_expr_node(BinopExprNode *n) {
case
Tok
:
:
TLOR
:
expr_
=
B
.
CreateOr
(
lhs
,
rhs
);
break
;
case
Tok
:
:
TLOR
:
expr_
=
B
.
CreateOr
(
lhs
,
rhs
);
break
;
default:
return
mkstatus_
(
n
,
"unsupported binary operator"
);
default:
return
mkstatus_
(
n
,
"unsupported binary operator"
);
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_unop_expr_node
(
UnopExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_unop_expr_node
(
UnopExprNode
*
n
)
{
...
@@ -519,11 +519,11 @@ StatusTuple CodegenLLVM::visit_unop_expr_node(UnopExprNode *n) {
...
@@ -519,11 +519,11 @@ StatusTuple CodegenLLVM::visit_unop_expr_node(UnopExprNode *n) {
case
Tok
:
:
TCMPL
:
expr_
=
B
.
CreateNeg
(
pop_expr
());
break
;
case
Tok
:
:
TCMPL
:
expr_
=
B
.
CreateNeg
(
pop_expr
());
break
;
default:
{}
default:
{}
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_bitop_expr_node
(
BitopExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_bitop_expr_node
(
BitopExprNode
*
n
)
{
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_goto_expr_node
(
GotoExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_goto_expr_node
(
GotoExprNode
*
n
)
{
...
@@ -553,7 +553,7 @@ StatusTuple CodegenLLVM::visit_goto_expr_node(GotoExprNode *n) {
...
@@ -553,7 +553,7 @@ StatusTuple CodegenLLVM::visit_goto_expr_node(GotoExprNode *n) {
}
}
}
}
B
.
CreateBr
(
resolve_label
(
jump_label
));
B
.
CreateBr
(
resolve_label
(
jump_label
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_return_expr_node
(
ReturnExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_return_expr_node
(
ReturnExprNode
*
n
)
{
...
@@ -562,7 +562,7 @@ StatusTuple CodegenLLVM::visit_return_expr_node(ReturnExprNode *n) {
...
@@ -562,7 +562,7 @@ StatusTuple CodegenLLVM::visit_return_expr_node(ReturnExprNode *n) {
Value
*
cast_1
=
B
.
CreateIntCast
(
pop_expr
(),
parent
->
getReturnType
(),
true
);
Value
*
cast_1
=
B
.
CreateIntCast
(
pop_expr
(),
parent
->
getReturnType
(),
true
);
B
.
CreateStore
(
cast_1
,
retval_
);
B
.
CreateStore
(
cast_1
,
retval_
);
B
.
CreateBr
(
resolve_label
(
"DONE"
));
B
.
CreateBr
(
resolve_label
(
"DONE"
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_table_lookup
(
MethodCallExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
emit_table_lookup
(
MethodCallExprNode
*
n
)
{
...
@@ -605,7 +605,7 @@ StatusTuple CodegenLLVM::emit_table_lookup(MethodCallExprNode *n) {
...
@@ -605,7 +605,7 @@ StatusTuple CodegenLLVM::emit_table_lookup(MethodCallExprNode *n) {
}
else
{
}
else
{
return
mkstatus_
(
n
,
"lookup in table type %s unsupported"
,
table
->
type_id
()
->
c_str
());
return
mkstatus_
(
n
,
"lookup in table type %s unsupported"
,
table
->
type_id
()
->
c_str
());
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_table_update
(
MethodCallExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
emit_table_update
(
MethodCallExprNode
*
n
)
{
...
@@ -636,7 +636,7 @@ StatusTuple CodegenLLVM::emit_table_update(MethodCallExprNode *n) {
...
@@ -636,7 +636,7 @@ StatusTuple CodegenLLVM::emit_table_update(MethodCallExprNode *n) {
}
else
{
}
else
{
return
mkstatus_
(
n
,
"unsupported"
);
return
mkstatus_
(
n
,
"unsupported"
);
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_table_delete
(
MethodCallExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
emit_table_delete
(
MethodCallExprNode
*
n
)
{
...
@@ -663,7 +663,7 @@ StatusTuple CodegenLLVM::emit_table_delete(MethodCallExprNode *n) {
...
@@ -663,7 +663,7 @@ StatusTuple CodegenLLVM::emit_table_delete(MethodCallExprNode *n) {
}
else
{
}
else
{
return
mkstatus_
(
n
,
"unsupported"
);
return
mkstatus_
(
n
,
"unsupported"
);
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_log
(
MethodCallExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
emit_log
(
MethodCallExprNode
*
n
)
{
...
@@ -684,13 +684,13 @@ StatusTuple CodegenLLVM::emit_log(MethodCallExprNode *n) {
...
@@ -684,13 +684,13 @@ StatusTuple CodegenLLVM::emit_log(MethodCallExprNode *n) {
PointerType
::
getUnqual
(
printk_fn_type
));
PointerType
::
getUnqual
(
printk_fn_type
));
expr_
=
B
.
CreateCall
(
printk_fn
,
args
);
expr_
=
B
.
CreateCall
(
printk_fn
,
args
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_packet_rewrite_field
(
MethodCallExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
emit_packet_rewrite_field
(
MethodCallExprNode
*
n
)
{
TRY2
(
n
->
args_
[
1
]
->
accept
(
this
));
TRY2
(
n
->
args_
[
1
]
->
accept
(
this
));
TRY2
(
n
->
args_
[
0
]
->
accept
(
this
));
TRY2
(
n
->
args_
[
0
]
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_atomic_add
(
MethodCallExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
emit_atomic_add
(
MethodCallExprNode
*
n
)
{
...
@@ -701,7 +701,7 @@ StatusTuple CodegenLLVM::emit_atomic_add(MethodCallExprNode *n) {
...
@@ -701,7 +701,7 @@ StatusTuple CodegenLLVM::emit_atomic_add(MethodCallExprNode *n) {
AtomicRMWInst
*
atomic_inst
=
B
.
CreateAtomicRMW
(
AtomicRMWInst
*
atomic_inst
=
B
.
CreateAtomicRMW
(
AtomicRMWInst
::
Add
,
lhs
,
rhs
,
AtomicOrdering
::
SequentiallyConsistent
);
AtomicRMWInst
::
Add
,
lhs
,
rhs
,
AtomicOrdering
::
SequentiallyConsistent
);
atomic_inst
->
setVolatile
(
false
);
atomic_inst
->
setVolatile
(
false
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_incr_cksum
(
MethodCallExprNode
*
n
,
size_t
sz
)
{
StatusTuple
CodegenLLVM
::
emit_incr_cksum
(
MethodCallExprNode
*
n
,
size_t
sz
)
{
...
@@ -738,11 +738,11 @@ StatusTuple CodegenLLVM::emit_incr_cksum(MethodCallExprNode *n, size_t sz) {
...
@@ -738,11 +738,11 @@ StatusTuple CodegenLLVM::emit_incr_cksum(MethodCallExprNode *n, size_t sz) {
Value
*
skb_ptr8
=
B
.
CreateBitCast
(
skb_ptr
,
B
.
getInt8PtrTy
());
Value
*
skb_ptr8
=
B
.
CreateBitCast
(
skb_ptr
,
B
.
getInt8PtrTy
());
expr_
=
B
.
CreateCall
(
csum_fn
,
vector
<
Value
*>
({
skb_ptr8
,
offset
,
old_val
,
new_val
,
flags
}));
expr_
=
B
.
CreateCall
(
csum_fn
,
vector
<
Value
*>
({
skb_ptr8
,
offset
,
old_val
,
new_val
,
flags
}));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
emit_get_usec_time
(
MethodCallExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
emit_get_usec_time
(
MethodCallExprNode
*
n
)
{
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_method_call_expr_node
(
MethodCallExprNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_method_call_expr_node
(
MethodCallExprNode
*
n
)
{
...
@@ -768,7 +768,7 @@ StatusTuple CodegenLLVM::visit_method_call_expr_node(MethodCallExprNode *n) {
...
@@ -768,7 +768,7 @@ StatusTuple CodegenLLVM::visit_method_call_expr_node(MethodCallExprNode *n) {
return
mkstatus_
(
n
,
"unsupported"
);
return
mkstatus_
(
n
,
"unsupported"
);
}
}
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
/* result = lookup(key)
/* result = lookup(key)
...
@@ -874,7 +874,7 @@ StatusTuple CodegenLLVM::visit_table_index_expr_node(TableIndexExprNode *n) {
...
@@ -874,7 +874,7 @@ StatusTuple CodegenLLVM::visit_table_index_expr_node(TableIndexExprNode *n) {
}
else
{
}
else
{
expr_
=
result
;
expr_
=
result
;
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
/// on_match
/// on_match
...
@@ -907,7 +907,7 @@ StatusTuple CodegenLLVM::visit_match_decl_stmt_node(MatchDeclStmtNode *n) {
...
@@ -907,7 +907,7 @@ StatusTuple CodegenLLVM::visit_match_decl_stmt_node(MatchDeclStmtNode *n) {
}
}
B
.
SetInsertPoint
(
label_end
);
B
.
SetInsertPoint
(
label_end
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
/// on_miss
/// on_miss
...
@@ -935,7 +935,7 @@ StatusTuple CodegenLLVM::visit_miss_decl_stmt_node(MissDeclStmtNode *n) {
...
@@ -935,7 +935,7 @@ StatusTuple CodegenLLVM::visit_miss_decl_stmt_node(MissDeclStmtNode *n) {
}
}
B
.
SetInsertPoint
(
label_end
);
B
.
SetInsertPoint
(
label_end
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_failure_decl_stmt_node
(
FailureDeclStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_failure_decl_stmt_node
(
FailureDeclStmtNode
*
n
)
{
...
@@ -945,12 +945,12 @@ StatusTuple CodegenLLVM::visit_failure_decl_stmt_node(FailureDeclStmtNode *n) {
...
@@ -945,12 +945,12 @@ StatusTuple CodegenLLVM::visit_failure_decl_stmt_node(FailureDeclStmtNode *n) {
StatusTuple
CodegenLLVM
::
visit_expr_stmt_node
(
ExprStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_expr_stmt_node
(
ExprStmtNode
*
n
)
{
TRY2
(
n
->
expr_
->
accept
(
this
));
TRY2
(
n
->
expr_
->
accept
(
this
));
expr_
=
nullptr
;
expr_
=
nullptr
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_struct_variable_decl_stmt_node
(
StructVariableDeclStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_struct_variable_decl_stmt_node
(
StructVariableDeclStmtNode
*
n
)
{
if
(
n
->
struct_id_
->
name_
==
""
||
n
->
struct_id_
->
name_
[
0
]
==
'_'
)
{
if
(
n
->
struct_id_
->
name_
==
""
||
n
->
struct_id_
->
name_
[
0
]
==
'_'
)
{
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StructType
*
stype
;
StructType
*
stype
;
...
@@ -1004,12 +1004,12 @@ StatusTuple CodegenLLVM::visit_struct_variable_decl_stmt_node(StructVariableDecl
...
@@ -1004,12 +1004,12 @@ StatusTuple CodegenLLVM::visit_struct_variable_decl_stmt_node(StructVariableDecl
}
}
}
}
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_integer_variable_decl_stmt_node
(
IntegerVariableDeclStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_integer_variable_decl_stmt_node
(
IntegerVariableDeclStmtNode
*
n
)
{
if
(
!
B
.
GetInsertBlock
())
if
(
!
B
.
GetInsertBlock
())
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
// uintX var = init
// uintX var = init
AllocaInst
*
ptr_a
=
new
AllocaInst
(
B
.
getIntNTy
(
n
->
bit_width_
),
n
->
id_
->
name_
,
resolve_entry_stack
());
AllocaInst
*
ptr_a
=
new
AllocaInst
(
B
.
getIntNTy
(
n
->
bit_width_
),
n
->
id_
->
name_
,
resolve_entry_stack
());
...
@@ -1018,7 +1018,7 @@ StatusTuple CodegenLLVM::visit_integer_variable_decl_stmt_node(IntegerVariableDe
...
@@ -1018,7 +1018,7 @@ StatusTuple CodegenLLVM::visit_integer_variable_decl_stmt_node(IntegerVariableDe
// todo
// todo
if
(
!
n
->
init_
.
empty
())
if
(
!
n
->
init_
.
empty
())
TRY2
(
n
->
init_
[
0
]
->
accept
(
this
));
TRY2
(
n
->
init_
[
0
]
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_struct_decl_stmt_node
(
StructDeclStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_struct_decl_stmt_node
(
StructDeclStmtNode
*
n
)
{
...
@@ -1029,7 +1029,7 @@ StatusTuple CodegenLLVM::visit_struct_decl_stmt_node(StructDeclStmtNode *n) {
...
@@ -1029,7 +1029,7 @@ StatusTuple CodegenLLVM::visit_struct_decl_stmt_node(StructDeclStmtNode *n) {
fields
.
push_back
(
B
.
getIntNTy
((
*
it
)
->
bit_width_
));
fields
.
push_back
(
B
.
getIntNTy
((
*
it
)
->
bit_width_
));
struct_type
->
setBody
(
fields
,
n
->
is_packed
());
struct_type
->
setBody
(
fields
,
n
->
is_packed
());
structs_
[
n
]
=
struct_type
;
structs_
[
n
]
=
struct_type
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_parser_state_stmt_node
(
ParserStateStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_parser_state_stmt_node
(
ParserStateStmtNode
*
n
)
{
...
@@ -1038,12 +1038,12 @@ StatusTuple CodegenLLVM::visit_parser_state_stmt_node(ParserStateStmtNode *n) {
...
@@ -1038,12 +1038,12 @@ StatusTuple CodegenLLVM::visit_parser_state_stmt_node(ParserStateStmtNode *n) {
B
.
SetInsertPoint
(
label_entry
);
B
.
SetInsertPoint
(
label_entry
);
if
(
n
->
next_state_
)
if
(
n
->
next_state_
)
TRY2
(
n
->
next_state_
->
accept
(
this
));
TRY2
(
n
->
next_state_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_state_decl_stmt_node
(
StateDeclStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_state_decl_stmt_node
(
StateDeclStmtNode
*
n
)
{
if
(
!
n
->
id_
)
if
(
!
n
->
id_
)
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
string
jump_label
=
n
->
scoped_name
();
string
jump_label
=
n
->
scoped_name
();
BasicBlock
*
label_entry
=
resolve_label
(
jump_label
);
BasicBlock
*
label_entry
=
resolve_label
(
jump_label
);
B
.
SetInsertPoint
(
label_entry
);
B
.
SetInsertPoint
(
label_entry
);
...
@@ -1067,7 +1067,7 @@ StatusTuple CodegenLLVM::visit_state_decl_stmt_node(StateDeclStmtNode *n) {
...
@@ -1067,7 +1067,7 @@ StatusTuple CodegenLLVM::visit_state_decl_stmt_node(StateDeclStmtNode *n) {
}
}
scopes_
->
pop_state
();
scopes_
->
pop_state
();
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_table_decl_stmt_node
(
TableDeclStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_table_decl_stmt_node
(
TableDeclStmtNode
*
n
)
{
...
@@ -1107,7 +1107,7 @@ StatusTuple CodegenLLVM::visit_table_decl_stmt_node(TableDeclStmtNode *n) {
...
@@ -1107,7 +1107,7 @@ StatusTuple CodegenLLVM::visit_table_decl_stmt_node(TableDeclStmtNode *n) {
}
else
{
}
else
{
return
mkstatus_
(
n
,
"Table %s not implemented"
,
n
->
table_type_
->
name_
.
c_str
());
return
mkstatus_
(
n
,
"Table %s not implemented"
,
n
->
table_type_
->
name_
.
c_str
());
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
lookup_struct_type
(
StructDeclStmtNode
*
decl
,
StructType
**
stype
)
const
{
StatusTuple
CodegenLLVM
::
lookup_struct_type
(
StructDeclStmtNode
*
decl
,
StructType
**
stype
)
const
{
...
@@ -1116,7 +1116,7 @@ StatusTuple CodegenLLVM::lookup_struct_type(StructDeclStmtNode *decl, StructType
...
@@ -1116,7 +1116,7 @@ StatusTuple CodegenLLVM::lookup_struct_type(StructDeclStmtNode *decl, StructType
return
mkstatus_
(
decl
,
"could not find IR for type %s"
,
decl
->
id_
->
c_str
());
return
mkstatus_
(
decl
,
"could not find IR for type %s"
,
decl
->
id_
->
c_str
());
*
stype
=
struct_it
->
second
;
*
stype
=
struct_it
->
second
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
lookup_struct_type
(
VariableDeclStmtNode
*
n
,
StructType
**
stype
,
StatusTuple
CodegenLLVM
::
lookup_struct_type
(
VariableDeclStmtNode
*
n
,
StructType
**
stype
,
...
@@ -1138,7 +1138,7 @@ StatusTuple CodegenLLVM::lookup_struct_type(VariableDeclStmtNode *n, StructType
...
@@ -1138,7 +1138,7 @@ StatusTuple CodegenLLVM::lookup_struct_type(VariableDeclStmtNode *n, StructType
if
(
decl
)
if
(
decl
)
*
decl
=
type
;
*
decl
=
type
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit_func_decl_stmt_node
(
FuncDeclStmtNode
*
n
)
{
StatusTuple
CodegenLLVM
::
visit_func_decl_stmt_node
(
FuncDeclStmtNode
*
n
)
{
...
@@ -1216,7 +1216,7 @@ StatusTuple CodegenLLVM::visit_func_decl_stmt_node(FuncDeclStmtNode *n) {
...
@@ -1216,7 +1216,7 @@ StatusTuple CodegenLLVM::visit_func_decl_stmt_node(FuncDeclStmtNode *n) {
B
.
CreateRet
(
B
.
CreateLoad
(
retval_
));
B
.
CreateRet
(
B
.
CreateLoad
(
retval_
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
visit
(
Node
*
root
,
vector
<
TableDesc
>
&
tables
)
{
StatusTuple
CodegenLLVM
::
visit
(
Node
*
root
,
vector
<
TableDesc
>
&
tables
)
{
...
@@ -1248,7 +1248,7 @@ StatusTuple CodegenLLVM::visit(Node* root, vector<TableDesc> &tables) {
...
@@ -1248,7 +1248,7 @@ StatusTuple CodegenLLVM::visit(Node* root, vector<TableDesc> &tables) {
""
,
""
,
""
,
""
,
});
});
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
CodegenLLVM
::
print_header
()
{
StatusTuple
CodegenLLVM
::
print_header
()
{
...
@@ -1276,7 +1276,7 @@ StatusTuple CodegenLLVM::print_header() {
...
@@ -1276,7 +1276,7 @@ StatusTuple CodegenLLVM::print_header() {
continue
;
continue
;
TRY2
((
*
it
)
->
accept
(
this
));
TRY2
((
*
it
)
->
accept
(
this
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
int
CodegenLLVM
::
get_table_fd
(
const
string
&
name
)
const
{
int
CodegenLLVM
::
get_table_fd
(
const
string
&
name
)
const
{
...
...
src/cc/frontends/b/loader.cc
View file @
13ebe8e8
...
@@ -20,7 +20,6 @@
...
@@ -20,7 +20,6 @@
#include "loader.h"
#include "loader.h"
#include "table_desc.h"
#include "table_desc.h"
using
std
::
get
;
using
std
::
string
;
using
std
::
string
;
using
std
::
unique_ptr
;
using
std
::
unique_ptr
;
using
std
::
vector
;
using
std
::
vector
;
...
@@ -57,8 +56,8 @@ int BLoader::parse(llvm::Module *mod, const string &filename, const string &prot
...
@@ -57,8 +56,8 @@ int BLoader::parse(llvm::Module *mod, const string &filename, const string &prot
ebpf
::
cc
::
TypeCheck
type_check
(
parser_
->
scopes_
.
get
(),
proto_parser_
->
scopes_
.
get
());
ebpf
::
cc
::
TypeCheck
type_check
(
parser_
->
scopes_
.
get
(),
proto_parser_
->
scopes_
.
get
());
auto
ret
=
type_check
.
visit
(
parser_
->
root_node_
);
auto
ret
=
type_check
.
visit
(
parser_
->
root_node_
);
if
(
get
<
0
>
(
ret
)
!=
0
||
get
<
1
>
(
ret
).
size
())
{
if
(
ret
.
code
()
!=
0
||
ret
.
msg
(
).
size
())
{
fprintf
(
stderr
,
"Type error @line=%d: %s
\n
"
,
get
<
0
>
(
ret
),
get
<
1
>
(
ret
).
c_str
());
fprintf
(
stderr
,
"Type error @line=%d: %s
\n
"
,
ret
.
code
(),
ret
.
msg
(
).
c_str
());
return
-
1
;
return
-
1
;
}
}
...
@@ -66,9 +65,9 @@ int BLoader::parse(llvm::Module *mod, const string &filename, const string &prot
...
@@ -66,9 +65,9 @@ int BLoader::parse(llvm::Module *mod, const string &filename, const string &prot
codegen_
=
ebpf
::
make_unique
<
ebpf
::
cc
::
CodegenLLVM
>
(
mod
,
parser_
->
scopes_
.
get
(),
proto_parser_
->
scopes_
.
get
());
codegen_
=
ebpf
::
make_unique
<
ebpf
::
cc
::
CodegenLLVM
>
(
mod
,
parser_
->
scopes_
.
get
(),
proto_parser_
->
scopes_
.
get
());
ret
=
codegen_
->
visit
(
parser_
->
root_node_
,
**
tables
);
ret
=
codegen_
->
visit
(
parser_
->
root_node_
,
**
tables
);
if
(
get
<
0
>
(
ret
)
!=
0
||
get
<
1
>
(
ret
).
size
())
{
if
(
ret
.
code
()
!=
0
||
ret
.
msg
(
).
size
())
{
fprintf
(
stderr
,
"Codegen error @line=%d: %s
\n
"
,
get
<
0
>
(
ret
),
get
<
1
>
(
ret
).
c_str
());
fprintf
(
stderr
,
"Codegen error @line=%d: %s
\n
"
,
ret
.
code
(),
ret
.
msg
(
).
c_str
());
return
get
<
0
>
(
ret
);
return
ret
.
code
(
);
}
}
return
0
;
return
0
;
...
...
src/cc/frontends/b/node.h
View file @
13ebe8e8
...
@@ -114,20 +114,20 @@ class Node {
...
@@ -114,20 +114,20 @@ class Node {
};
};
template
<
typename
...
Args
>
template
<
typename
...
Args
>
std
::
tuple
<
int
,
std
::
string
>
mkstatus_
(
Node
*
n
,
const
char
*
fmt
,
Args
...
args
)
{
StatusTuple
mkstatus_
(
Node
*
n
,
const
char
*
fmt
,
Args
...
args
)
{
char
buf
[
1024
];
char
buf
[
2048
];
snprintf
(
buf
,
sizeof
(
buf
),
fmt
,
args
...);
snprintf
(
buf
,
sizeof
(
buf
),
fmt
,
args
...);
string
out_msg
(
buf
);
string
out_msg
(
buf
);
if
(
n
->
line_
>
0
)
if
(
n
->
line_
>
0
)
out_msg
+=
"
\n
"
+
n
->
text_
;
out_msg
+=
"
\n
"
+
n
->
text_
;
return
std
::
make_t
uple
(
n
->
line_
?
n
->
line_
:
-
1
,
out_msg
);
return
StatusT
uple
(
n
->
line_
?
n
->
line_
:
-
1
,
out_msg
);
}
}
static
inline
std
::
tuple
<
int
,
std
::
string
>
mkstatus_
(
Node
*
n
,
const
char
*
msg
)
{
static
inline
StatusTuple
mkstatus_
(
Node
*
n
,
const
char
*
msg
)
{
string
out_msg
(
msg
);
string
out_msg
(
msg
);
if
(
n
->
line_
>
0
)
if
(
n
->
line_
>
0
)
out_msg
+=
"
\n
"
+
n
->
text_
;
out_msg
+=
"
\n
"
+
n
->
text_
;
return
std
::
make_t
uple
(
n
->
line_
?
n
->
line_
:
-
1
,
out_msg
);
return
StatusT
uple
(
n
->
line_
?
n
->
line_
:
-
1
,
out_msg
);
}
}
class
StmtNode
:
public
Node
{
class
StmtNode
:
public
Node
{
...
...
src/cc/frontends/b/printer.cc
View file @
13ebe8e8
...
@@ -38,7 +38,7 @@ StatusTuple Printer::visit_block_stmt_node(BlockStmtNode* n) {
...
@@ -38,7 +38,7 @@ StatusTuple Printer::visit_block_stmt_node(BlockStmtNode* n) {
--
indent_
;
--
indent_
;
}
}
fprintf
(
out_
,
"%*s}"
,
indent_
,
""
);
fprintf
(
out_
,
"%*s}"
,
indent_
,
""
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_if_stmt_node
(
IfStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_if_stmt_node
(
IfStmtNode
*
n
)
{
...
@@ -50,7 +50,7 @@ StatusTuple Printer::visit_if_stmt_node(IfStmtNode* n) {
...
@@ -50,7 +50,7 @@ StatusTuple Printer::visit_if_stmt_node(IfStmtNode* n) {
fprintf
(
out_
,
" else "
);
fprintf
(
out_
,
" else "
);
TRY2
(
n
->
false_block_
->
accept
(
this
));
TRY2
(
n
->
false_block_
->
accept
(
this
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_onvalid_stmt_node
(
OnValidStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_onvalid_stmt_node
(
OnValidStmtNode
*
n
)
{
...
@@ -62,7 +62,7 @@ StatusTuple Printer::visit_onvalid_stmt_node(OnValidStmtNode* n) {
...
@@ -62,7 +62,7 @@ StatusTuple Printer::visit_onvalid_stmt_node(OnValidStmtNode* n) {
fprintf
(
out_
,
" else "
);
fprintf
(
out_
,
" else "
);
TRY2
(
n
->
else_block_
->
accept
(
this
));
TRY2
(
n
->
else_block_
->
accept
(
this
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_switch_stmt_node
(
SwitchStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_switch_stmt_node
(
SwitchStmtNode
*
n
)
{
...
@@ -70,7 +70,7 @@ StatusTuple Printer::visit_switch_stmt_node(SwitchStmtNode* n) {
...
@@ -70,7 +70,7 @@ StatusTuple Printer::visit_switch_stmt_node(SwitchStmtNode* n) {
TRY2
(
n
->
cond_
->
accept
(
this
));
TRY2
(
n
->
cond_
->
accept
(
this
));
fprintf
(
out_
,
") "
);
fprintf
(
out_
,
") "
);
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_case_stmt_node
(
CaseStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_case_stmt_node
(
CaseStmtNode
*
n
)
{
...
@@ -81,7 +81,7 @@ StatusTuple Printer::visit_case_stmt_node(CaseStmtNode* n) {
...
@@ -81,7 +81,7 @@ StatusTuple Printer::visit_case_stmt_node(CaseStmtNode* n) {
fprintf
(
out_
,
"default"
);
fprintf
(
out_
,
"default"
);
}
}
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_ident_expr_node
(
IdentExprNode
*
n
)
{
StatusTuple
Printer
::
visit_ident_expr_node
(
IdentExprNode
*
n
)
{
...
@@ -92,37 +92,37 @@ StatusTuple Printer::visit_ident_expr_node(IdentExprNode* n) {
...
@@ -92,37 +92,37 @@ StatusTuple Printer::visit_ident_expr_node(IdentExprNode* n) {
if
(
n
->
sub_name_
.
size
())
{
if
(
n
->
sub_name_
.
size
())
{
fprintf
(
out_
,
".%s"
,
n
->
sub_name_
.
c_str
());
fprintf
(
out_
,
".%s"
,
n
->
sub_name_
.
c_str
());
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_assign_expr_node
(
AssignExprNode
*
n
)
{
StatusTuple
Printer
::
visit_assign_expr_node
(
AssignExprNode
*
n
)
{
TRY2
(
n
->
lhs_
->
accept
(
this
));
TRY2
(
n
->
lhs_
->
accept
(
this
));
fprintf
(
out_
,
" = "
);
fprintf
(
out_
,
" = "
);
TRY2
(
n
->
rhs_
->
accept
(
this
));
TRY2
(
n
->
rhs_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_packet_expr_node
(
PacketExprNode
*
n
)
{
StatusTuple
Printer
::
visit_packet_expr_node
(
PacketExprNode
*
n
)
{
fprintf
(
out_
,
"$"
);
fprintf
(
out_
,
"$"
);
TRY2
(
n
->
id_
->
accept
(
this
));
TRY2
(
n
->
id_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_integer_expr_node
(
IntegerExprNode
*
n
)
{
StatusTuple
Printer
::
visit_integer_expr_node
(
IntegerExprNode
*
n
)
{
fprintf
(
out_
,
"%s:%zu"
,
n
->
val_
.
c_str
(),
n
->
bits_
);
fprintf
(
out_
,
"%s:%zu"
,
n
->
val_
.
c_str
(),
n
->
bits_
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_string_expr_node
(
StringExprNode
*
n
)
{
StatusTuple
Printer
::
visit_string_expr_node
(
StringExprNode
*
n
)
{
fprintf
(
out_
,
"%s"
,
n
->
val_
.
c_str
());
fprintf
(
out_
,
"%s"
,
n
->
val_
.
c_str
());
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_binop_expr_node
(
BinopExprNode
*
n
)
{
StatusTuple
Printer
::
visit_binop_expr_node
(
BinopExprNode
*
n
)
{
TRY2
(
n
->
lhs_
->
accept
(
this
));
TRY2
(
n
->
lhs_
->
accept
(
this
));
fprintf
(
out_
,
"%d"
,
n
->
op_
);
fprintf
(
out_
,
"%d"
,
n
->
op_
);
TRY2
(
n
->
rhs_
->
accept
(
this
));
TRY2
(
n
->
rhs_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_unop_expr_node
(
UnopExprNode
*
n
)
{
StatusTuple
Printer
::
visit_unop_expr_node
(
UnopExprNode
*
n
)
{
...
@@ -135,25 +135,25 @@ StatusTuple Printer::visit_unop_expr_node(UnopExprNode* n) {
...
@@ -135,25 +135,25 @@ StatusTuple Printer::visit_unop_expr_node(UnopExprNode* n) {
}
}
fprintf
(
out_
,
"%s"
,
s
);
fprintf
(
out_
,
"%s"
,
s
);
TRY2
(
n
->
expr_
->
accept
(
this
));
TRY2
(
n
->
expr_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_bitop_expr_node
(
BitopExprNode
*
n
)
{
StatusTuple
Printer
::
visit_bitop_expr_node
(
BitopExprNode
*
n
)
{
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_return_expr_node
(
ReturnExprNode
*
n
)
{
StatusTuple
Printer
::
visit_return_expr_node
(
ReturnExprNode
*
n
)
{
fprintf
(
out_
,
"return "
);
fprintf
(
out_
,
"return "
);
TRY2
(
n
->
expr_
->
accept
(
this
));
TRY2
(
n
->
expr_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_goto_expr_node
(
GotoExprNode
*
n
)
{
StatusTuple
Printer
::
visit_goto_expr_node
(
GotoExprNode
*
n
)
{
const
char
*
s
=
n
->
is_continue_
?
"continue "
:
"goto "
;
const
char
*
s
=
n
->
is_continue_
?
"continue "
:
"goto "
;
fprintf
(
out_
,
"%s"
,
s
);
fprintf
(
out_
,
"%s"
,
s
);
TRY2
(
n
->
id_
->
accept
(
this
));
TRY2
(
n
->
id_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_method_call_expr_node
(
MethodCallExprNode
*
n
)
{
StatusTuple
Printer
::
visit_method_call_expr_node
(
MethodCallExprNode
*
n
)
{
...
@@ -177,19 +177,19 @@ StatusTuple Printer::visit_method_call_expr_node(MethodCallExprNode* n) {
...
@@ -177,19 +177,19 @@ StatusTuple Printer::visit_method_call_expr_node(MethodCallExprNode* n) {
--
indent_
;
--
indent_
;
fprintf
(
out_
,
"%*s}"
,
indent_
,
""
);
fprintf
(
out_
,
"%*s}"
,
indent_
,
""
);
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_table_index_expr_node
(
TableIndexExprNode
*
n
)
{
StatusTuple
Printer
::
visit_table_index_expr_node
(
TableIndexExprNode
*
n
)
{
fprintf
(
out_
,
"%s["
,
n
->
id_
->
c_str
());
fprintf
(
out_
,
"%s["
,
n
->
id_
->
c_str
());
TRY2
(
n
->
index_
->
accept
(
this
));
TRY2
(
n
->
index_
->
accept
(
this
));
fprintf
(
out_
,
"]"
);
fprintf
(
out_
,
"]"
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_expr_stmt_node
(
ExprStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_expr_stmt_node
(
ExprStmtNode
*
n
)
{
TRY2
(
n
->
expr_
->
accept
(
this
));
TRY2
(
n
->
expr_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_struct_variable_decl_stmt_node
(
StructVariableDeclStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_struct_variable_decl_stmt_node
(
StructVariableDeclStmtNode
*
n
)
{
...
@@ -207,7 +207,7 @@ StatusTuple Printer::visit_struct_variable_decl_stmt_node(StructVariableDeclStmt
...
@@ -207,7 +207,7 @@ StatusTuple Printer::visit_struct_variable_decl_stmt_node(StructVariableDeclStmt
}
}
fprintf
(
out_
,
"}"
);
fprintf
(
out_
,
"}"
);
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_integer_variable_decl_stmt_node
(
IntegerVariableDeclStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_integer_variable_decl_stmt_node
(
IntegerVariableDeclStmtNode
*
n
)
{
...
@@ -218,7 +218,7 @@ StatusTuple Printer::visit_integer_variable_decl_stmt_node(IntegerVariableDeclSt
...
@@ -218,7 +218,7 @@ StatusTuple Printer::visit_integer_variable_decl_stmt_node(IntegerVariableDeclSt
fprintf
(
out_
,
"; "
);
fprintf
(
out_
,
"; "
);
TRY2
(
n
->
init_
[
0
]
->
accept
(
this
));
TRY2
(
n
->
init_
[
0
]
->
accept
(
this
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_struct_decl_stmt_node
(
StructDeclStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_struct_decl_stmt_node
(
StructDeclStmtNode
*
n
)
{
...
@@ -233,12 +233,12 @@ StatusTuple Printer::visit_struct_decl_stmt_node(StructDeclStmtNode* n) {
...
@@ -233,12 +233,12 @@ StatusTuple Printer::visit_struct_decl_stmt_node(StructDeclStmtNode* n) {
}
}
--
indent_
;
--
indent_
;
fprintf
(
out_
,
"%*s}"
,
indent_
,
""
);
fprintf
(
out_
,
"%*s}"
,
indent_
,
""
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_state_decl_stmt_node
(
StateDeclStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_state_decl_stmt_node
(
StateDeclStmtNode
*
n
)
{
if
(
!
n
->
id_
)
{
if
(
!
n
->
id_
)
{
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
fprintf
(
out_
,
"state "
);
fprintf
(
out_
,
"state "
);
TRY2
(
n
->
id_
->
accept
(
this
));
TRY2
(
n
->
id_
->
accept
(
this
));
...
@@ -249,11 +249,11 @@ StatusTuple Printer::visit_state_decl_stmt_node(StateDeclStmtNode* n) {
...
@@ -249,11 +249,11 @@ StatusTuple Printer::visit_state_decl_stmt_node(StateDeclStmtNode* n) {
// TRY2(n->id2_->accept(this));
// TRY2(n->id2_->accept(this));
//}
//}
//TRY2(n->block_->accept(this));
//TRY2(n->block_->accept(this));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_parser_state_stmt_node
(
ParserStateStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_parser_state_stmt_node
(
ParserStateStmtNode
*
n
)
{
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_match_decl_stmt_node
(
MatchDeclStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_match_decl_stmt_node
(
MatchDeclStmtNode
*
n
)
{
...
@@ -268,7 +268,7 @@ StatusTuple Printer::visit_match_decl_stmt_node(MatchDeclStmtNode* n) {
...
@@ -268,7 +268,7 @@ StatusTuple Printer::visit_match_decl_stmt_node(MatchDeclStmtNode* n) {
}
}
fprintf
(
out_
,
") "
);
fprintf
(
out_
,
") "
);
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_miss_decl_stmt_node
(
MissDeclStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_miss_decl_stmt_node
(
MissDeclStmtNode
*
n
)
{
...
@@ -283,7 +283,7 @@ StatusTuple Printer::visit_miss_decl_stmt_node(MissDeclStmtNode* n) {
...
@@ -283,7 +283,7 @@ StatusTuple Printer::visit_miss_decl_stmt_node(MissDeclStmtNode* n) {
}
}
fprintf
(
out_
,
") "
);
fprintf
(
out_
,
") "
);
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_failure_decl_stmt_node
(
FailureDeclStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_failure_decl_stmt_node
(
FailureDeclStmtNode
*
n
)
{
...
@@ -298,7 +298,7 @@ StatusTuple Printer::visit_failure_decl_stmt_node(FailureDeclStmtNode* n) {
...
@@ -298,7 +298,7 @@ StatusTuple Printer::visit_failure_decl_stmt_node(FailureDeclStmtNode* n) {
}
}
fprintf
(
out_
,
") "
);
fprintf
(
out_
,
") "
);
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_table_decl_stmt_node
(
TableDeclStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_table_decl_stmt_node
(
TableDeclStmtNode
*
n
)
{
...
@@ -313,7 +313,7 @@ StatusTuple Printer::visit_table_decl_stmt_node(TableDeclStmtNode* n) {
...
@@ -313,7 +313,7 @@ StatusTuple Printer::visit_table_decl_stmt_node(TableDeclStmtNode* n) {
fprintf
(
out_
,
"> "
);
fprintf
(
out_
,
"> "
);
TRY2
(
n
->
id_
->
accept
(
this
));
TRY2
(
n
->
id_
->
accept
(
this
));
fprintf
(
out_
,
"(%zu)"
,
n
->
size_
);
fprintf
(
out_
,
"(%zu)"
,
n
->
size_
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
Printer
::
visit_func_decl_stmt_node
(
FuncDeclStmtNode
*
n
)
{
StatusTuple
Printer
::
visit_func_decl_stmt_node
(
FuncDeclStmtNode
*
n
)
{
...
@@ -328,7 +328,7 @@ StatusTuple Printer::visit_func_decl_stmt_node(FuncDeclStmtNode *n) {
...
@@ -328,7 +328,7 @@ StatusTuple Printer::visit_func_decl_stmt_node(FuncDeclStmtNode *n) {
}
}
fprintf
(
out_
,
") "
);
fprintf
(
out_
,
") "
);
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
}
// namespace cc
}
// namespace cc
...
...
src/cc/frontends/b/type_check.cc
View file @
13ebe8e8
...
@@ -37,7 +37,7 @@ StatusTuple TypeCheck::visit_block_stmt_node(BlockStmtNode *n) {
...
@@ -37,7 +37,7 @@ StatusTuple TypeCheck::visit_block_stmt_node(BlockStmtNode *n) {
if
(
n
->
scope_
)
if
(
n
->
scope_
)
scopes_
->
pop_var
();
scopes_
->
pop_var
();
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_if_stmt_node
(
IfStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_if_stmt_node
(
IfStmtNode
*
n
)
{
...
@@ -48,7 +48,7 @@ StatusTuple TypeCheck::visit_if_stmt_node(IfStmtNode *n) {
...
@@ -48,7 +48,7 @@ StatusTuple TypeCheck::visit_if_stmt_node(IfStmtNode *n) {
if
(
n
->
false_block_
)
{
if
(
n
->
false_block_
)
{
TRY2
(
n
->
false_block_
->
accept
(
this
));
TRY2
(
n
->
false_block_
->
accept
(
this
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_onvalid_stmt_node
(
OnValidStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_onvalid_stmt_node
(
OnValidStmtNode
*
n
)
{
...
@@ -60,7 +60,7 @@ StatusTuple TypeCheck::visit_onvalid_stmt_node(OnValidStmtNode *n) {
...
@@ -60,7 +60,7 @@ StatusTuple TypeCheck::visit_onvalid_stmt_node(OnValidStmtNode *n) {
if
(
n
->
else_block_
)
{
if
(
n
->
else_block_
)
{
TRY2
(
n
->
else_block_
->
accept
(
this
));
TRY2
(
n
->
else_block_
->
accept
(
this
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_switch_stmt_node
(
SwitchStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_switch_stmt_node
(
SwitchStmtNode
*
n
)
{
...
@@ -71,7 +71,7 @@ StatusTuple TypeCheck::visit_switch_stmt_node(SwitchStmtNode *n) {
...
@@ -71,7 +71,7 @@ StatusTuple TypeCheck::visit_switch_stmt_node(SwitchStmtNode *n) {
for
(
auto
it
=
n
->
block_
->
stmts_
.
begin
();
it
!=
n
->
block_
->
stmts_
.
end
();
++
it
)
{
for
(
auto
it
=
n
->
block_
->
stmts_
.
begin
();
it
!=
n
->
block_
->
stmts_
.
end
();
++
it
)
{
/// @todo check for duplicates
/// @todo check for duplicates
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_case_stmt_node
(
CaseStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_case_stmt_node
(
CaseStmtNode
*
n
)
{
...
@@ -81,7 +81,7 @@ StatusTuple TypeCheck::visit_case_stmt_node(CaseStmtNode *n) {
...
@@ -81,7 +81,7 @@ StatusTuple TypeCheck::visit_case_stmt_node(CaseStmtNode *n) {
return
mkstatus_
(
n
,
"Switch condition must be a numeric type"
);
return
mkstatus_
(
n
,
"Switch condition must be a numeric type"
);
}
}
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_ident_expr_node
(
IdentExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_ident_expr_node
(
IdentExprNode
*
n
)
{
...
@@ -131,7 +131,7 @@ StatusTuple TypeCheck::visit_ident_expr_node(IdentExprNode *n) {
...
@@ -131,7 +131,7 @@ StatusTuple TypeCheck::visit_ident_expr_node(IdentExprNode *n) {
n
->
bit_width_
=
n
->
sub_decl_
->
bit_width_
;
n
->
bit_width_
=
n
->
sub_decl_
->
bit_width_
;
n
->
flags_
[
ExprNode
::
WRITE
]
=
true
;
n
->
flags_
[
ExprNode
::
WRITE
]
=
true
;
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_assign_expr_node
(
AssignExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_assign_expr_node
(
AssignExprNode
*
n
)
{
...
@@ -151,7 +151,7 @@ StatusTuple TypeCheck::visit_assign_expr_node(AssignExprNode *n) {
...
@@ -151,7 +151,7 @@ StatusTuple TypeCheck::visit_assign_expr_node(AssignExprNode *n) {
return
mkstatus_
(
n
,
"Right-hand side of assignment must be a numeric type"
);
return
mkstatus_
(
n
,
"Right-hand side of assignment must be a numeric type"
);
}
}
n
->
typeof_
=
ExprNode
::
VOID
;
n
->
typeof_
=
ExprNode
::
VOID
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_packet_expr_node
(
PacketExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_packet_expr_node
(
PacketExprNode
*
n
)
{
...
@@ -172,20 +172,20 @@ StatusTuple TypeCheck::visit_packet_expr_node(PacketExprNode *n) {
...
@@ -172,20 +172,20 @@ StatusTuple TypeCheck::visit_packet_expr_node(PacketExprNode *n) {
n
->
bit_width_
=
sub_decl
->
bit_width_
;
n
->
bit_width_
=
sub_decl
->
bit_width_
;
}
}
n
->
flags_
[
ExprNode
::
WRITE
]
=
true
;
n
->
flags_
[
ExprNode
::
WRITE
]
=
true
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_integer_expr_node
(
IntegerExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_integer_expr_node
(
IntegerExprNode
*
n
)
{
n
->
typeof_
=
ExprNode
::
INTEGER
;
n
->
typeof_
=
ExprNode
::
INTEGER
;
n
->
bit_width_
=
n
->
bits_
;
n
->
bit_width_
=
n
->
bits_
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_string_expr_node
(
StringExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_string_expr_node
(
StringExprNode
*
n
)
{
n
->
typeof_
=
ExprNode
::
STRING
;
n
->
typeof_
=
ExprNode
::
STRING
;
n
->
flags_
[
ExprNode
::
IS_REF
]
=
true
;
n
->
flags_
[
ExprNode
::
IS_REF
]
=
true
;
n
->
bit_width_
=
n
->
val_
.
size
()
<<
3
;
n
->
bit_width_
=
n
->
val_
.
size
()
<<
3
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_binop_expr_node
(
BinopExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_binop_expr_node
(
BinopExprNode
*
n
)
{
...
@@ -207,7 +207,7 @@ StatusTuple TypeCheck::visit_binop_expr_node(BinopExprNode *n) {
...
@@ -207,7 +207,7 @@ StatusTuple TypeCheck::visit_binop_expr_node(BinopExprNode *n) {
default:
default:
n
->
bit_width_
=
std
::
max
(
n
->
lhs_
->
bit_width_
,
n
->
rhs_
->
bit_width_
);
n
->
bit_width_
=
std
::
max
(
n
->
lhs_
->
bit_width_
,
n
->
rhs_
->
bit_width_
);
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_unop_expr_node
(
UnopExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_unop_expr_node
(
UnopExprNode
*
n
)
{
...
@@ -215,26 +215,26 @@ StatusTuple TypeCheck::visit_unop_expr_node(UnopExprNode *n) {
...
@@ -215,26 +215,26 @@ StatusTuple TypeCheck::visit_unop_expr_node(UnopExprNode *n) {
if
(
n
->
expr_
->
typeof_
!=
ExprNode
::
INTEGER
)
if
(
n
->
expr_
->
typeof_
!=
ExprNode
::
INTEGER
)
return
mkstatus_
(
n
,
"Unary operand must be a numeric type"
);
return
mkstatus_
(
n
,
"Unary operand must be a numeric type"
);
n
->
copy_type
(
*
n
->
expr_
);
n
->
copy_type
(
*
n
->
expr_
);
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_bitop_expr_node
(
BitopExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_bitop_expr_node
(
BitopExprNode
*
n
)
{
if
(
n
->
expr_
->
typeof_
!=
ExprNode
::
INTEGER
)
if
(
n
->
expr_
->
typeof_
!=
ExprNode
::
INTEGER
)
return
mkstatus_
(
n
,
"Bitop [] can only operate on numeric types"
);
return
mkstatus_
(
n
,
"Bitop [] can only operate on numeric types"
);
n
->
typeof_
=
ExprNode
::
INTEGER
;
n
->
typeof_
=
ExprNode
::
INTEGER
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_goto_expr_node
(
GotoExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_goto_expr_node
(
GotoExprNode
*
n
)
{
//n->id_->accept(this);
//n->id_->accept(this);
n
->
typeof_
=
ExprNode
::
VOID
;
n
->
typeof_
=
ExprNode
::
VOID
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_return_expr_node
(
ReturnExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_return_expr_node
(
ReturnExprNode
*
n
)
{
TRY2
(
n
->
expr_
->
accept
(
this
));
TRY2
(
n
->
expr_
->
accept
(
this
));
n
->
typeof_
=
ExprNode
::
VOID
;
n
->
typeof_
=
ExprNode
::
VOID
;
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
expect_method_arg
(
MethodCallExprNode
*
n
,
size_t
num
,
size_t
num_def_args
=
0
)
{
StatusTuple
TypeCheck
::
expect_method_arg
(
MethodCallExprNode
*
n
,
size_t
num
,
size_t
num_def_args
=
0
)
{
...
@@ -247,7 +247,7 @@ StatusTuple TypeCheck::expect_method_arg(MethodCallExprNode *n, size_t num, size
...
@@ -247,7 +247,7 @@ StatusTuple TypeCheck::expect_method_arg(MethodCallExprNode *n, size_t num, size
return
mkstatus_
(
n
,
"%s expected %d argument%s (%d default), %zu given"
,
n
->
id_
->
sub_name_
.
c_str
(),
return
mkstatus_
(
n
,
"%s expected %d argument%s (%d default), %zu given"
,
n
->
id_
->
sub_name_
.
c_str
(),
num
,
num
==
1
?
""
:
"s"
,
num_def_args
,
n
->
args_
.
size
());
num
,
num
==
1
?
""
:
"s"
,
num_def_args
,
n
->
args_
.
size
());
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
check_lookup_method
(
MethodCallExprNode
*
n
)
{
StatusTuple
TypeCheck
::
check_lookup_method
(
MethodCallExprNode
*
n
)
{
...
@@ -263,7 +263,7 @@ StatusTuple TypeCheck::check_lookup_method(MethodCallExprNode *n) {
...
@@ -263,7 +263,7 @@ StatusTuple TypeCheck::check_lookup_method(MethodCallExprNode *n) {
n
->
block_
->
scope_
->
add
(
"_result"
,
result
.
get
());
n
->
block_
->
scope_
->
add
(
"_result"
,
result
.
get
());
n
->
block_
->
stmts_
.
insert
(
n
->
block_
->
stmts_
.
begin
(),
move
(
result
));
n
->
block_
->
stmts_
.
insert
(
n
->
block_
->
stmts_
.
begin
(),
move
(
result
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
check_update_method
(
MethodCallExprNode
*
n
)
{
StatusTuple
TypeCheck
::
check_update_method
(
MethodCallExprNode
*
n
)
{
...
@@ -274,7 +274,7 @@ StatusTuple TypeCheck::check_update_method(MethodCallExprNode *n) {
...
@@ -274,7 +274,7 @@ StatusTuple TypeCheck::check_update_method(MethodCallExprNode *n) {
TRY2
(
expect_method_arg
(
n
,
2
));
TRY2
(
expect_method_arg
(
n
,
2
));
else
if
(
table
->
type_id
()
->
name_
==
"LPM"
)
else
if
(
table
->
type_id
()
->
name_
==
"LPM"
)
TRY2
(
expect_method_arg
(
n
,
3
));
TRY2
(
expect_method_arg
(
n
,
3
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
check_delete_method
(
MethodCallExprNode
*
n
)
{
StatusTuple
TypeCheck
::
check_delete_method
(
MethodCallExprNode
*
n
)
{
...
@@ -285,7 +285,7 @@ StatusTuple TypeCheck::check_delete_method(MethodCallExprNode *n) {
...
@@ -285,7 +285,7 @@ StatusTuple TypeCheck::check_delete_method(MethodCallExprNode *n) {
TRY2
(
expect_method_arg
(
n
,
1
));
TRY2
(
expect_method_arg
(
n
,
1
));
else
if
(
table
->
type_id
()
->
name_
==
"LPM"
)
else
if
(
table
->
type_id
()
->
name_
==
"LPM"
)
{}
{}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_method_call_expr_node
(
MethodCallExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_method_call_expr_node
(
MethodCallExprNode
*
n
)
{
...
@@ -338,7 +338,7 @@ StatusTuple TypeCheck::visit_method_call_expr_node(MethodCallExprNode *n) {
...
@@ -338,7 +338,7 @@ StatusTuple TypeCheck::visit_method_call_expr_node(MethodCallExprNode *n) {
return
mkstatus_
(
n
,
"%s does not allow trailing block statements"
,
n
->
id_
->
full_name
().
c_str
());
return
mkstatus_
(
n
,
"%s does not allow trailing block statements"
,
n
->
id_
->
full_name
().
c_str
());
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_table_index_expr_node
(
TableIndexExprNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_table_index_expr_node
(
TableIndexExprNode
*
n
)
{
...
@@ -358,12 +358,12 @@ StatusTuple TypeCheck::visit_table_index_expr_node(TableIndexExprNode *n) {
...
@@ -358,12 +358,12 @@ StatusTuple TypeCheck::visit_table_index_expr_node(TableIndexExprNode *n) {
n
->
flags_
[
ExprNode
::
IS_REF
]
=
true
;
n
->
flags_
[
ExprNode
::
IS_REF
]
=
true
;
n
->
struct_type_
=
n
->
table_
->
leaf_type_
;
n
->
struct_type_
=
n
->
table_
->
leaf_type_
;
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_expr_stmt_node
(
ExprStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_expr_stmt_node
(
ExprStmtNode
*
n
)
{
TRY2
(
n
->
expr_
->
accept
(
this
));
TRY2
(
n
->
expr_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_struct_variable_decl_stmt_node
(
StructVariableDeclStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_struct_variable_decl_stmt_node
(
StructVariableDeclStmtNode
*
n
)
{
...
@@ -398,7 +398,7 @@ StatusTuple TypeCheck::visit_struct_variable_decl_stmt_node(StructVariableDeclSt
...
@@ -398,7 +398,7 @@ StatusTuple TypeCheck::visit_struct_variable_decl_stmt_node(StructVariableDeclSt
TRY2
((
*
it
)
->
accept
(
this
));
TRY2
((
*
it
)
->
accept
(
this
));
}
}
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_integer_variable_decl_stmt_node
(
IntegerVariableDeclStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_integer_variable_decl_stmt_node
(
IntegerVariableDeclStmtNode
*
n
)
{
...
@@ -406,7 +406,7 @@ StatusTuple TypeCheck::visit_integer_variable_decl_stmt_node(IntegerVariableDecl
...
@@ -406,7 +406,7 @@ StatusTuple TypeCheck::visit_integer_variable_decl_stmt_node(IntegerVariableDecl
if
(
!
n
->
init_
.
empty
())
{
if
(
!
n
->
init_
.
empty
())
{
TRY2
(
n
->
init_
[
0
]
->
accept
(
this
));
TRY2
(
n
->
init_
[
0
]
->
accept
(
this
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_struct_decl_stmt_node
(
StructDeclStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_struct_decl_stmt_node
(
StructDeclStmtNode
*
n
)
{
...
@@ -414,16 +414,16 @@ StatusTuple TypeCheck::visit_struct_decl_stmt_node(StructDeclStmtNode *n) {
...
@@ -414,16 +414,16 @@ StatusTuple TypeCheck::visit_struct_decl_stmt_node(StructDeclStmtNode *n) {
for
(
auto
it
=
n
->
stmts_
.
begin
();
it
!=
n
->
stmts_
.
end
();
++
it
)
{
for
(
auto
it
=
n
->
stmts_
.
begin
();
it
!=
n
->
stmts_
.
end
();
++
it
)
{
TRY2
((
*
it
)
->
accept
(
this
));
TRY2
((
*
it
)
->
accept
(
this
));
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_parser_state_stmt_node
(
ParserStateStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_parser_state_stmt_node
(
ParserStateStmtNode
*
n
)
{
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_state_decl_stmt_node
(
StateDeclStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_state_decl_stmt_node
(
StateDeclStmtNode
*
n
)
{
if
(
!
n
->
id_
)
{
if
(
!
n
->
id_
)
{
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
auto
s1
=
proto_scopes_
->
top_state
()
->
lookup
(
n
->
id_
->
name_
,
true
);
auto
s1
=
proto_scopes_
->
top_state
()
->
lookup
(
n
->
id_
->
name_
,
true
);
if
(
s1
)
{
if
(
s1
)
{
...
@@ -478,7 +478,7 @@ StatusTuple TypeCheck::visit_state_decl_stmt_node(StateDeclStmtNode *n) {
...
@@ -478,7 +478,7 @@ StatusTuple TypeCheck::visit_state_decl_stmt_node(StateDeclStmtNode *n) {
scopes_
->
pop_state
();
scopes_
->
pop_state
();
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_match_decl_stmt_node
(
MatchDeclStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_match_decl_stmt_node
(
MatchDeclStmtNode
*
n
)
{
...
@@ -487,7 +487,7 @@ StatusTuple TypeCheck::visit_match_decl_stmt_node(MatchDeclStmtNode *n) {
...
@@ -487,7 +487,7 @@ StatusTuple TypeCheck::visit_match_decl_stmt_node(MatchDeclStmtNode *n) {
TRY2
((
*
it
)
->
accept
(
this
));
TRY2
((
*
it
)
->
accept
(
this
));
}
}
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_miss_decl_stmt_node
(
MissDeclStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_miss_decl_stmt_node
(
MissDeclStmtNode
*
n
)
{
...
@@ -496,7 +496,7 @@ StatusTuple TypeCheck::visit_miss_decl_stmt_node(MissDeclStmtNode *n) {
...
@@ -496,7 +496,7 @@ StatusTuple TypeCheck::visit_miss_decl_stmt_node(MissDeclStmtNode *n) {
TRY2
((
*
it
)
->
accept
(
this
));
TRY2
((
*
it
)
->
accept
(
this
));
}
}
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_failure_decl_stmt_node
(
FailureDeclStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_failure_decl_stmt_node
(
FailureDeclStmtNode
*
n
)
{
...
@@ -505,7 +505,7 @@ StatusTuple TypeCheck::visit_failure_decl_stmt_node(FailureDeclStmtNode *n) {
...
@@ -505,7 +505,7 @@ StatusTuple TypeCheck::visit_failure_decl_stmt_node(FailureDeclStmtNode *n) {
TRY2
((
*
it
)
->
accept
(
this
));
TRY2
((
*
it
)
->
accept
(
this
));
}
}
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_table_decl_stmt_node
(
TableDeclStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_table_decl_stmt_node
(
TableDeclStmtNode
*
n
)
{
...
@@ -523,7 +523,7 @@ StatusTuple TypeCheck::visit_table_decl_stmt_node(TableDeclStmtNode *n) {
...
@@ -523,7 +523,7 @@ StatusTuple TypeCheck::visit_table_decl_stmt_node(TableDeclStmtNode *n) {
}
}
if
(
n
->
policy_id
()
->
name_
!=
"AUTO"
&&
n
->
policy_id
()
->
name_
!=
"NONE"
)
if
(
n
->
policy_id
()
->
name_
!=
"AUTO"
&&
n
->
policy_id
()
->
name_
!=
"NONE"
)
return
mkstatus_
(
n
,
"Unsupported policy type %s"
,
n
->
policy_id
()
->
c_str
());
return
mkstatus_
(
n
,
"Unsupported policy type %s"
,
n
->
policy_id
()
->
c_str
());
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit_func_decl_stmt_node
(
FuncDeclStmtNode
*
n
)
{
StatusTuple
TypeCheck
::
visit_func_decl_stmt_node
(
FuncDeclStmtNode
*
n
)
{
...
@@ -538,7 +538,7 @@ StatusTuple TypeCheck::visit_func_decl_stmt_node(FuncDeclStmtNode *n) {
...
@@ -538,7 +538,7 @@ StatusTuple TypeCheck::visit_func_decl_stmt_node(FuncDeclStmtNode *n) {
scopes_
->
push_state
(
n
->
scope_
);
scopes_
->
push_state
(
n
->
scope_
);
TRY2
(
n
->
block_
->
accept
(
this
));
TRY2
(
n
->
block_
->
accept
(
this
));
scopes_
->
pop_state
();
scopes_
->
pop_state
();
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
StatusTuple
TypeCheck
::
visit
(
Node
*
root
)
{
StatusTuple
TypeCheck
::
visit
(
Node
*
root
)
{
...
@@ -549,14 +549,14 @@ StatusTuple TypeCheck::visit(Node *root) {
...
@@ -549,14 +549,14 @@ StatusTuple TypeCheck::visit(Node *root) {
// // packet data in bpf socket
// // packet data in bpf socket
// if (scopes_->top_struct()->lookup("_skbuff", true)) {
// if (scopes_->top_struct()->lookup("_skbuff", true)) {
// return
mkstatus
(-1, "_skbuff already defined");
// return
StatusTuple
(-1, "_skbuff already defined");
// }
// }
// auto skb_type = make_unique<StructDeclStmtNode>(make_unique<IdentExprNode>("_skbuff"));
// auto skb_type = make_unique<StructDeclStmtNode>(make_unique<IdentExprNode>("_skbuff"));
// scopes_->top_struct()->add("_skbuff", skb_type.get());
// scopes_->top_struct()->add("_skbuff", skb_type.get());
// b->stmts_.push_back(move(skb_type));
// b->stmts_.push_back(move(skb_type));
// if (scopes_->current_var()->lookup("skb", true)) {
// if (scopes_->current_var()->lookup("skb", true)) {
// return
mkstatus
(-1, "skb already defined");
// return
StatusTuple
(-1, "skb already defined");
// }
// }
// auto skb = make_unique<StructVariableDeclStmtNode>(make_unique<IdentExprNode>("_skbuff"),
// auto skb = make_unique<StructVariableDeclStmtNode>(make_unique<IdentExprNode>("_skbuff"),
// make_unique<IdentExprNode>("skb"));
// make_unique<IdentExprNode>("skb"));
...
@@ -577,9 +577,9 @@ StatusTuple TypeCheck::visit(Node *root) {
...
@@ -577,9 +577,9 @@ StatusTuple TypeCheck::visit(Node *root) {
for
(
auto
it
=
errors_
.
begin
();
it
!=
errors_
.
end
();
++
it
)
{
for
(
auto
it
=
errors_
.
begin
();
it
!=
errors_
.
end
();
++
it
)
{
fprintf
(
stderr
,
"%s
\n
"
,
it
->
c_str
());
fprintf
(
stderr
,
"%s
\n
"
,
it
->
c_str
());
}
}
return
mkstatus
(
-
1
,
errors_
.
begin
()
->
c_str
());
return
StatusTuple
(
-
1
,
errors_
.
begin
()
->
c_str
());
}
}
return
mkstatus
(
0
);
return
StatusTuple
(
0
);
}
}
}
// namespace cc
}
// namespace cc
...
...
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