mirror of
https://github.com/varun-r-mallya/Python-BPF.git
synced 2025-12-31 21:06:25 +00:00
Fix loglevel and pylibbpf import in codegen
This commit is contained in:
@ -15,7 +15,7 @@ import os
|
|||||||
import subprocess
|
import subprocess
|
||||||
import inspect
|
import inspect
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
from pylibbpf import BpfProgram
|
from pylibbpf import BpfObject
|
||||||
import tempfile
|
import tempfile
|
||||||
from logging import Logger
|
from logging import Logger
|
||||||
import logging
|
import logging
|
||||||
@ -158,7 +158,7 @@ def _run_llc(ll_file, obj_file):
|
|||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
def compile(loglevel=logging.INFO) -> bool:
|
def compile(loglevel=logging.WARNING) -> bool:
|
||||||
# Look one level up the stack to the caller of this function
|
# Look one level up the stack to the caller of this function
|
||||||
caller_frame = inspect.stack()[1]
|
caller_frame = inspect.stack()[1]
|
||||||
caller_file = Path(caller_frame.filename).resolve()
|
caller_file = Path(caller_frame.filename).resolve()
|
||||||
@ -166,7 +166,9 @@ def compile(loglevel=logging.INFO) -> bool:
|
|||||||
ll_file = Path("/tmp") / caller_file.with_suffix(".ll").name
|
ll_file = Path("/tmp") / caller_file.with_suffix(".ll").name
|
||||||
o_file = caller_file.with_suffix(".o")
|
o_file = caller_file.with_suffix(".o")
|
||||||
|
|
||||||
compile_to_ir(str(caller_file), str(ll_file), loglevel=loglevel)
|
_, structs_sym_tab, maps_sym_tab = compile_to_ir(
|
||||||
|
str(caller_file), str(ll_file), loglevel=loglevel
|
||||||
|
)
|
||||||
|
|
||||||
if not _run_llc(ll_file, o_file):
|
if not _run_llc(ll_file, o_file):
|
||||||
logger.error("Compilation to object file failed.")
|
logger.error("Compilation to object file failed.")
|
||||||
@ -176,7 +178,7 @@ def compile(loglevel=logging.INFO) -> bool:
|
|||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
def BPF(loglevel=logging.INFO) -> BpfProgram:
|
def BPF(loglevel=logging.WARNING) -> BpfObject:
|
||||||
caller_frame = inspect.stack()[1]
|
caller_frame = inspect.stack()[1]
|
||||||
src = inspect.getsource(caller_frame.frame)
|
src = inspect.getsource(caller_frame.frame)
|
||||||
with tempfile.NamedTemporaryFile(
|
with tempfile.NamedTemporaryFile(
|
||||||
@ -194,6 +196,4 @@ def BPF(loglevel=logging.INFO) -> BpfProgram:
|
|||||||
)
|
)
|
||||||
_run_llc(str(inter.name), str(obj_file.name))
|
_run_llc(str(inter.name), str(obj_file.name))
|
||||||
|
|
||||||
return BpfProgram(
|
return BpfObject(str(obj_file.name), structs=structs_sym_tab)
|
||||||
str(obj_file.name), structs=structs_sym_tab, maps=maps_sym_tab
|
|
||||||
)
|
|
||||||
|
|||||||
Reference in New Issue
Block a user