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
5941f2b7
Commit
5941f2b7
authored
Nov 22, 2017
by
Teng Qin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Do not keep Loader instances around
parent
977d0649
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
16 additions
and
19 deletions
+16
-19
src/cc/bpf_module.cc
src/cc/bpf_module.cc
+12
-10
src/cc/bpf_module.h
src/cc/bpf_module.h
+1
-2
src/cc/frontends/clang/loader.cc
src/cc/frontends/clang/loader.cc
+2
-6
src/cc/frontends/clang/loader.h
src/cc/frontends/clang/loader.h
+1
-1
No files found.
src/cc/bpf_module.cc
View file @
5941f2b7
...
@@ -101,6 +101,7 @@ class MyMemoryManager : public SectionMemoryManager {
...
@@ -101,6 +101,7 @@ class MyMemoryManager : public SectionMemoryManager {
BPFModule
::
BPFModule
(
unsigned
flags
,
TableStorage
*
ts
)
BPFModule
::
BPFModule
(
unsigned
flags
,
TableStorage
*
ts
)
:
flags_
(
flags
),
:
flags_
(
flags
),
used_b_loader_
(
false
),
ctx_
(
new
LLVMContext
),
ctx_
(
new
LLVMContext
),
id_
(
std
::
to_string
((
uintptr_t
)
this
)),
id_
(
std
::
to_string
((
uintptr_t
)
this
)),
ts_
(
ts
)
{
ts_
(
ts
)
{
...
@@ -464,9 +465,9 @@ unique_ptr<ExecutionEngine> BPFModule::finalize_rw(unique_ptr<Module> m) {
...
@@ -464,9 +465,9 @@ unique_ptr<ExecutionEngine> BPFModule::finalize_rw(unique_ptr<Module> m) {
// load an entire c file as a module
// load an entire c file as a module
int
BPFModule
::
load_cfile
(
const
string
&
file
,
bool
in_memory
,
const
char
*
cflags
[],
int
ncflags
)
{
int
BPFModule
::
load_cfile
(
const
string
&
file
,
bool
in_memory
,
const
char
*
cflags
[],
int
ncflags
)
{
clang_loader_
=
ebpf
::
make_unique
<
ClangLoader
>
(
&*
ctx_
,
flags_
);
ClangLoader
clang_loader
(
&*
ctx_
,
flags_
);
if
(
clang_loader
_
->
parse
(
&
mod_
,
*
ts_
,
file
,
in_memory
,
cflags
,
ncflags
,
id_
,
if
(
clang_loader
.
parse
(
&
mod_
,
*
ts_
,
file
,
in_memory
,
cflags
,
ncflags
,
id_
,
*
func_src_
,
mod_src_
))
*
func_src_
,
mod_src_
))
return
-
1
;
return
-
1
;
return
0
;
return
0
;
}
}
...
@@ -477,9 +478,9 @@ int BPFModule::load_cfile(const string &file, bool in_memory, const char *cflags
...
@@ -477,9 +478,9 @@ int BPFModule::load_cfile(const string &file, bool in_memory, const char *cflags
// Load in a pre-built list of functions into the initial Module object, then
// Load in a pre-built list of functions into the initial Module object, then
// build an ExecutionEngine.
// build an ExecutionEngine.
int
BPFModule
::
load_includes
(
const
string
&
text
)
{
int
BPFModule
::
load_includes
(
const
string
&
text
)
{
clang_loader_
=
ebpf
::
make_unique
<
ClangLoader
>
(
&*
ctx_
,
flags_
);
ClangLoader
clang_loader
(
&*
ctx_
,
flags_
);
if
(
clang_loader
_
->
parse
(
&
mod_
,
*
ts_
,
text
,
true
,
nullptr
,
0
,
""
,
*
func_src_
,
if
(
clang_loader
.
parse
(
&
mod_
,
*
ts_
,
text
,
true
,
nullptr
,
0
,
""
,
*
func_src_
,
mod_src_
))
mod_src_
))
return
-
1
;
return
-
1
;
return
0
;
return
0
;
}
}
...
@@ -816,7 +817,7 @@ const char * BPFModule::table_name(size_t id) const {
...
@@ -816,7 +817,7 @@ const char * BPFModule::table_name(size_t id) const {
}
}
const
char
*
BPFModule
::
table_key_desc
(
size_t
id
)
const
{
const
char
*
BPFModule
::
table_key_desc
(
size_t
id
)
const
{
if
(
b_loader_
)
return
nullptr
;
if
(
used_
b_loader_
)
return
nullptr
;
if
(
id
>=
tables_
.
size
())
if
(
id
>=
tables_
.
size
())
return
nullptr
;
return
nullptr
;
return
tables_
[
id
]
->
key_desc
.
c_str
();
return
tables_
[
id
]
->
key_desc
.
c_str
();
...
@@ -827,7 +828,7 @@ const char * BPFModule::table_key_desc(const string &name) const {
...
@@ -827,7 +828,7 @@ const char * BPFModule::table_key_desc(const string &name) const {
}
}
const
char
*
BPFModule
::
table_leaf_desc
(
size_t
id
)
const
{
const
char
*
BPFModule
::
table_leaf_desc
(
size_t
id
)
const
{
if
(
b_loader_
)
return
nullptr
;
if
(
used_
b_loader_
)
return
nullptr
;
if
(
id
>=
tables_
.
size
())
if
(
id
>=
tables_
.
size
())
return
nullptr
;
return
nullptr
;
return
tables_
[
id
]
->
leaf_desc
.
c_str
();
return
tables_
[
id
]
->
leaf_desc
.
c_str
();
...
@@ -932,8 +933,9 @@ int BPFModule::load_b(const string &filename, const string &proto_filename) {
...
@@ -932,8 +933,9 @@ int BPFModule::load_b(const string &filename, const string &proto_filename) {
if
(
int
rc
=
load_includes
(
helpers_h
->
second
))
if
(
int
rc
=
load_includes
(
helpers_h
->
second
))
return
rc
;
return
rc
;
b_loader_
.
reset
(
new
BLoader
(
flags_
));
BLoader
b_loader
(
flags_
);
if
(
int
rc
=
b_loader_
->
parse
(
&*
mod_
,
filename
,
proto_filename
,
*
ts_
,
id_
))
used_b_loader_
=
true
;
if
(
int
rc
=
b_loader
.
parse
(
&*
mod_
,
filename
,
proto_filename
,
*
ts_
,
id_
))
return
rc
;
return
rc
;
if
(
int
rc
=
annotate
())
if
(
int
rc
=
annotate
())
return
rc
;
return
rc
;
...
...
src/cc/bpf_module.h
View file @
5941f2b7
...
@@ -120,14 +120,13 @@ class BPFModule {
...
@@ -120,14 +120,13 @@ class BPFModule {
private:
private:
unsigned
flags_
;
// 0x1 for printing
unsigned
flags_
;
// 0x1 for printing
bool
used_b_loader_
;
std
::
string
filename_
;
std
::
string
filename_
;
std
::
string
proto_filename_
;
std
::
string
proto_filename_
;
std
::
unique_ptr
<
llvm
::
LLVMContext
>
ctx_
;
std
::
unique_ptr
<
llvm
::
LLVMContext
>
ctx_
;
std
::
unique_ptr
<
llvm
::
ExecutionEngine
>
engine_
;
std
::
unique_ptr
<
llvm
::
ExecutionEngine
>
engine_
;
std
::
unique_ptr
<
llvm
::
ExecutionEngine
>
rw_engine_
;
std
::
unique_ptr
<
llvm
::
ExecutionEngine
>
rw_engine_
;
std
::
unique_ptr
<
llvm
::
Module
>
mod_
;
std
::
unique_ptr
<
llvm
::
Module
>
mod_
;
std
::
unique_ptr
<
BLoader
>
b_loader_
;
std
::
unique_ptr
<
ClangLoader
>
clang_loader_
;
std
::
unique_ptr
<
FuncSource
>
func_src_
;
std
::
unique_ptr
<
FuncSource
>
func_src_
;
std
::
map
<
std
::
string
,
std
::
tuple
<
uint8_t
*
,
uintptr_t
>>
sections_
;
std
::
map
<
std
::
string
,
std
::
tuple
<
uint8_t
*
,
uintptr_t
>>
sections_
;
std
::
vector
<
TableDesc
*>
tables_
;
std
::
vector
<
TableDesc
*>
tables_
;
...
...
src/cc/frontends/clang/loader.cc
View file @
5941f2b7
...
@@ -64,15 +64,11 @@ using std::vector;
...
@@ -64,15 +64,11 @@ using std::vector;
namespace
ebpf
{
namespace
ebpf
{
map
<
string
,
unique_ptr
<
llvm
::
MemoryBuffer
>>
ClangLoader
::
remapped_files_
;
ClangLoader
::
ClangLoader
(
llvm
::
LLVMContext
*
ctx
,
unsigned
flags
)
ClangLoader
::
ClangLoader
(
llvm
::
LLVMContext
*
ctx
,
unsigned
flags
)
:
ctx_
(
ctx
),
flags_
(
flags
)
:
ctx_
(
ctx
),
flags_
(
flags
)
{
{
if
(
remapped_files_
.
empty
())
{
for
(
auto
f
:
ExportedFiles
::
headers
())
for
(
auto
f
:
ExportedFiles
::
headers
())
remapped_files_
[
f
.
first
]
=
llvm
::
MemoryBuffer
::
getMemBuffer
(
f
.
second
);
remapped_files_
[
f
.
first
]
=
llvm
::
MemoryBuffer
::
getMemBuffer
(
f
.
second
);
}
}
}
ClangLoader
::~
ClangLoader
()
{}
ClangLoader
::~
ClangLoader
()
{}
...
...
src/cc/frontends/clang/loader.h
View file @
5941f2b7
...
@@ -66,7 +66,7 @@ class ClangLoader {
...
@@ -66,7 +66,7 @@ class ClangLoader {
std
::
string
&
mod_src
,
bool
use_internal_bpfh
);
std
::
string
&
mod_src
,
bool
use_internal_bpfh
);
private:
private:
st
atic
st
d
::
map
<
std
::
string
,
std
::
unique_ptr
<
llvm
::
MemoryBuffer
>>
remapped_files_
;
std
::
map
<
std
::
string
,
std
::
unique_ptr
<
llvm
::
MemoryBuffer
>>
remapped_files_
;
llvm
::
LLVMContext
*
ctx_
;
llvm
::
LLVMContext
*
ctx_
;
unsigned
flags_
;
unsigned
flags_
;
};
};
...
...
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