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
65c23528
Commit
65c23528
authored
Nov 27, 2017
by
yonghong-song
Committed by
GitHub
Nov 27, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1457 from palmtenor/loader
Do not keep Loader instances around
parents
c32b845d
5941f2b7
Changes
4
Show 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 @
65c23528
...
@@ -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,8 +465,8 @@ unique_ptr<ExecutionEngine> BPFModule::finalize_rw(unique_ptr<Module> m) {
...
@@ -464,8 +465,8 @@ 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,8 +478,8 @@ int BPFModule::load_cfile(const string &file, bool in_memory, const char *cflags
...
@@ -477,8 +478,8 @@ 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 @
65c23528
...
@@ -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 @
65c23528
...
@@ -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 @
65c23528
...
@@ -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