make license handling easier

This commit is contained in:
2025-09-09 00:19:53 +05:30
parent d6ba30805e
commit 03404bb164
4 changed files with 35 additions and 21 deletions

View File

@ -28,10 +28,7 @@ def hello_again(ctx: c_void_p) -> c_int64:
ts = bpf_ktime_get_ns() ts = bpf_ktime_get_ns()
return c_int64(0) return c_int64(0)
# @bpf @bpf
# @bpfglobal @bpfglobal
# def LICENSE() -> str: def LICENSE() -> str:
# return "GPL" return "GPL"
LICENSE = "GPL"

View File

@ -12,6 +12,8 @@ def get_probe_string(func_node):
# For helper functions, we return "helper" # For helper functions, we return "helper"
for decorator in func_node.decorator_list: for decorator in func_node.decorator_list:
if isinstance(decorator, ast.Name) and decorator.id == "bpfglobal":
return None
if isinstance(decorator, ast.Call) and isinstance(decorator.func, ast.Name): if isinstance(decorator, ast.Call) and isinstance(decorator.func, ast.Name):
if decorator.func.id == "section" and len(decorator.args) == 1: if decorator.func.id == "section" and len(decorator.args) == 1:
arg = decorator.args[0] arg = decorator.args[0]
@ -134,7 +136,9 @@ def process_bpf_chunk(func_node, module, return_type, map_sym_tab):
param = func.args[0] param = func.args[0]
param.add_attribute("nocapture") param.add_attribute("nocapture")
func.section = get_probe_string(func_node) probe_string = get_probe_string(func_node)
if probe_string is not None:
func.section = probe_string
block = func.append_basic_block(name="entry") block = func.append_basic_block(name="entry")
builder = ir.IRBuilder(block) builder = ir.IRBuilder(block)
@ -151,6 +155,9 @@ def func_proc(tree, module, chunks, map_sym_tab):
if isinstance(decorator, ast.Name) and decorator.id == "map": if isinstance(decorator, ast.Name) and decorator.id == "map":
is_global = True is_global = True
break break
elif isinstance(decorator, ast.Name) and decorator.id == "bpfglobal":
is_global = True
break
if is_global: if is_global:
continue continue
func_type = get_probe_string(func_node) func_type = get_probe_string(func_node)

View File

@ -18,20 +18,28 @@ def emit_license(module: ir.Module, license_str: str):
return gvar return gvar
def license_processing(tree, module): def license_processing(tree, module):
"""Process the LICENSE assignment in the given AST tree and return the section name""" """Process the LICENSE function decorated with @bpf and @bpfglobal and return the section name"""
count = 0 count = 0
for node in tree.body: for node in tree.body:
if isinstance(node, ast.Assign): if isinstance(node, ast.FunctionDef) and node.name == "LICENSE":
for target in node.targets: # check decorators
if isinstance(target, ast.Name) and target.id == "LICENSE": decorators = [dec.id for dec in node.decorator_list if isinstance(dec, ast.Name)]
if count == 0: if "bpf" in decorators and "bpfglobal" in decorators:
count += 1 if count == 0:
if isinstance(node.value, ast.Constant) and isinstance(node.value.value, str): count += 1
emit_license(module, node.value.value) # check function body has a return string
return "LICENSE" if (
else: len(node.body) == 1
print("ERROR: LICENSE must be a string literal") and isinstance(node.body[0], ast.Return)
return None and isinstance(node.body[0].value, ast.Constant)
and isinstance(node.body[0].value.value, str)
):
emit_license(module, node.body[0].value.value)
return "LICENSE"
else: else:
print("ERROR: LICENSE already assigned") print("ERROR: LICENSE() must return a string literal")
return None return None
else:
print("ERROR: LICENSE already defined")
return None
return None

View File

@ -14,6 +14,8 @@ def ctypes_to_ir(ctype: str):
"c_float": ir.FloatType(), "c_float": ir.FloatType(),
"c_double": ir.DoubleType(), "c_double": ir.DoubleType(),
"c_void_p": ir.IntType(64), "c_void_p": ir.IntType(64),
# Not so sure about this one
"str": ir.PointerType(ir.IntType(8))
} }
if ctype in mapping: if ctype in mapping:
return mapping[ctype] return mapping[ctype]