Auto sync2gitlab import of bpftrace-0.16.0-1.el8.src.rpm
This commit is contained in:
parent
b18d750a5f
commit
072c2f2c39
2
.gitignore
vendored
2
.gitignore
vendored
@ -1,2 +1,4 @@
|
|||||||
/bpftrace-0.12.1.tar.gz
|
/bpftrace-0.12.1.tar.gz
|
||||||
/bpftrace-0.13.1.tar.gz
|
/bpftrace-0.13.1.tar.gz
|
||||||
|
/bpftrace-0.16.0.tar.gz
|
||||||
|
/cereal-1.3.2.tar.gz
|
||||||
|
@ -1,834 +0,0 @@
|
|||||||
From fed7014be999f6437ebfd8a6465a76f459be0e1b Mon Sep 17 00:00:00 2001
|
|
||||||
From: Viktor Malik <viktor.malik@gmail.com>
|
|
||||||
Date: Mon, 10 Jan 2022 16:41:05 +0100
|
|
||||||
Subject: [PATCH 6/6] Fix LLVM 13 warnings
|
|
||||||
|
|
||||||
Since LLVM 13, CreateGEP and CreateLoad require explicit types.
|
|
||||||
---
|
|
||||||
src/ast/codegen_llvm.cpp | 265 ++++++++++++++++++++++++---------------
|
|
||||||
src/ast/irbuilderbpf.cpp | 56 +++++----
|
|
||||||
2 files changed, 200 insertions(+), 121 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/ast/codegen_llvm.cpp b/src/ast/codegen_llvm.cpp
|
|
||||||
index d30327a2..0bd23276 100644
|
|
||||||
--- a/src/ast/codegen_llvm.cpp
|
|
||||||
+++ b/src/ast/codegen_llvm.cpp
|
|
||||||
@@ -224,9 +224,10 @@ void CodegenLLVM::visit(Builtin &builtin)
|
|
||||||
// LLVM optimization is possible to transform `(uint64*)ctx` into
|
|
||||||
// `(uint8*)ctx`, but sometimes this causes invalid context access.
|
|
||||||
// Mark every context acess to supporess any LLVM optimization.
|
|
||||||
- expr_ = b_.CreateLoad(b_.getInt64Ty(),
|
|
||||||
- b_.CreateGEP(ctx, b_.getInt64(offset)),
|
|
||||||
- builtin.ident);
|
|
||||||
+ expr_ = b_.CreateLoad(
|
|
||||||
+ b_.getInt64Ty(),
|
|
||||||
+ b_.CreateGEP(b_.getInt64Ty(), ctx, b_.getInt64(offset)),
|
|
||||||
+ builtin.ident);
|
|
||||||
// LLVM 7.0 <= does not have CreateLoad(*Ty, *Ptr, isVolatile, Name),
|
|
||||||
// so call setVolatile() manually
|
|
||||||
dyn_cast<LoadInst>(expr_)->setVolatile(true);
|
|
||||||
@@ -249,16 +250,17 @@ void CodegenLLVM::visit(Builtin &builtin)
|
|
||||||
|
|
||||||
int arg_num = atoi(builtin.ident.substr(4).c_str());
|
|
||||||
Value *ctx = b_.CreatePointerCast(ctx_, b_.getInt64Ty()->getPointerTo());
|
|
||||||
- Value *sp = b_.CreateLoad(b_.getInt64Ty(),
|
|
||||||
- b_.CreateGEP(ctx, b_.getInt64(sp_offset)),
|
|
||||||
- "reg_sp");
|
|
||||||
+ Value *sp = b_.CreateLoad(
|
|
||||||
+ b_.getInt64Ty(),
|
|
||||||
+ b_.CreateGEP(b_.getInt64Ty(), ctx, b_.getInt64(sp_offset)),
|
|
||||||
+ "reg_sp");
|
|
||||||
dyn_cast<LoadInst>(sp)->setVolatile(true);
|
|
||||||
AllocaInst *dst = b_.CreateAllocaBPF(builtin.type, builtin.ident);
|
|
||||||
Value *src = b_.CreateAdd(sp,
|
|
||||||
b_.getInt64((arg_num + arch::arg_stack_offset()) *
|
|
||||||
sizeof(uintptr_t)));
|
|
||||||
b_.CreateProbeRead(ctx_, dst, 8, src, builtin.type.GetAS(), builtin.loc);
|
|
||||||
- expr_ = b_.CreateLoad(dst);
|
|
||||||
+ expr_ = b_.CreateLoad(b_.GetType(builtin.type), dst);
|
|
||||||
b_.CreateLifetimeEnd(dst);
|
|
||||||
}
|
|
||||||
else if (builtin.ident == "probe")
|
|
||||||
@@ -526,8 +528,12 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
b_.CREATE_MEMSET(buf, b_.getInt8(0), bpftrace_.strlen_, 1);
|
|
||||||
auto arg0 = call.vargs->front();
|
|
||||||
auto scoped_del = accept(call.vargs->front());
|
|
||||||
- b_.CreateProbeReadStr(
|
|
||||||
- ctx_, buf, b_.CreateLoad(strlen), expr_, arg0->type.GetAS(), call.loc);
|
|
||||||
+ b_.CreateProbeReadStr(ctx_,
|
|
||||||
+ buf,
|
|
||||||
+ b_.CreateLoad(b_.getInt64Ty(), strlen),
|
|
||||||
+ expr_,
|
|
||||||
+ arg0->type.GetAS(),
|
|
||||||
+ call.loc);
|
|
||||||
b_.CreateLifetimeEnd(strlen);
|
|
||||||
|
|
||||||
expr_ = buf;
|
|
||||||
@@ -569,12 +575,14 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
false);
|
|
||||||
AllocaInst *buf = b_.CreateAllocaBPF(buf_struct, "buffer");
|
|
||||||
|
|
||||||
- Value *buf_len_offset = b_.CreateGEP(buf,
|
|
||||||
+ Value *buf_len_offset = b_.CreateGEP(buf_struct,
|
|
||||||
+ buf,
|
|
||||||
{ b_.getInt32(0), b_.getInt32(0) });
|
|
||||||
length = b_.CreateIntCast(length, buf_struct->getElementType(0), false);
|
|
||||||
b_.CreateStore(length, buf_len_offset);
|
|
||||||
|
|
||||||
- Value *buf_data_offset = b_.CreateGEP(buf,
|
|
||||||
+ Value *buf_data_offset = b_.CreateGEP(buf_struct,
|
|
||||||
+ buf,
|
|
||||||
{ b_.getInt32(0), b_.getInt32(1) });
|
|
||||||
b_.CREATE_MEMSET(buf_data_offset,
|
|
||||||
b_.GetIntSameSize(0, elements.at(0)),
|
|
||||||
@@ -664,14 +672,14 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
b_.SetInsertPoint(notzero);
|
|
||||||
b_.CreateStore(b_.getInt64(asyncactionint(AsyncAction::join)), perfdata);
|
|
||||||
b_.CreateStore(b_.getInt64(join_id_),
|
|
||||||
- b_.CreateGEP(perfdata, b_.getInt64(8)));
|
|
||||||
+ b_.CreateGEP(b_.getInt8Ty(), perfdata, b_.getInt64(8)));
|
|
||||||
join_id_++;
|
|
||||||
AllocaInst *arr = b_.CreateAllocaBPF(b_.getInt64Ty(), call.func + "_r0");
|
|
||||||
b_.CreateProbeRead(ctx_, arr, 8, expr_, addrspace, call.loc);
|
|
||||||
b_.CreateProbeReadStr(ctx_,
|
|
||||||
b_.CreateAdd(perfdata, b_.getInt64(8 + 8)),
|
|
||||||
bpftrace_.join_argsize_,
|
|
||||||
- b_.CreateLoad(arr),
|
|
||||||
+ b_.CreateLoad(b_.getInt64Ty(), arr),
|
|
||||||
addrspace,
|
|
||||||
call.loc);
|
|
||||||
|
|
||||||
@@ -679,14 +687,18 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
{
|
|
||||||
// argi
|
|
||||||
b_.CreateStore(b_.CreateAdd(expr_, b_.getInt64(8 * i)), first);
|
|
||||||
- b_.CreateProbeRead(
|
|
||||||
- ctx_, second, 8, b_.CreateLoad(first), addrspace, call.loc);
|
|
||||||
+ b_.CreateProbeRead(ctx_,
|
|
||||||
+ second,
|
|
||||||
+ 8,
|
|
||||||
+ b_.CreateLoad(b_.getInt64Ty(), first),
|
|
||||||
+ addrspace,
|
|
||||||
+ call.loc);
|
|
||||||
b_.CreateProbeReadStr(
|
|
||||||
ctx_,
|
|
||||||
b_.CreateAdd(perfdata,
|
|
||||||
b_.getInt64(8 + 8 + i * bpftrace_.join_argsize_)),
|
|
||||||
bpftrace_.join_argsize_,
|
|
||||||
- b_.CreateLoad(second),
|
|
||||||
+ b_.CreateLoad(b_.getInt64Ty(), second),
|
|
||||||
addrspace,
|
|
||||||
call.loc);
|
|
||||||
}
|
|
||||||
@@ -729,7 +741,9 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
|
|
||||||
AllocaInst *buf = b_.CreateAllocaBPF(inet_struct, "inet");
|
|
||||||
|
|
||||||
- Value *af_offset = b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(0) });
|
|
||||||
+ Value *af_offset = b_.CreateGEP(inet_struct,
|
|
||||||
+ buf,
|
|
||||||
+ { b_.getInt64(0), b_.getInt32(0) });
|
|
||||||
Value *af_type;
|
|
||||||
|
|
||||||
auto inet = call.vargs->at(0);
|
|
||||||
@@ -752,7 +766,9 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
}
|
|
||||||
b_.CreateStore(af_type, af_offset);
|
|
||||||
|
|
||||||
- Value *inet_offset = b_.CreateGEP(buf, {b_.getInt32(0), b_.getInt32(1)});
|
|
||||||
+ Value *inet_offset = b_.CreateGEP(inet_struct,
|
|
||||||
+ buf,
|
|
||||||
+ { b_.getInt32(0), b_.getInt32(1) });
|
|
||||||
b_.CREATE_MEMSET(inet_offset, b_.getInt8(0), 16, 1);
|
|
||||||
|
|
||||||
auto scoped_del = accept(inet);
|
|
||||||
@@ -785,9 +801,10 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
}
|
|
||||||
|
|
||||||
Value *ctx = b_.CreatePointerCast(ctx_, b_.getInt64Ty()->getPointerTo());
|
|
||||||
- expr_ = b_.CreateLoad(b_.getInt64Ty(),
|
|
||||||
- b_.CreateGEP(ctx, b_.getInt64(offset)),
|
|
||||||
- call.func + "_" + reg_name);
|
|
||||||
+ expr_ = b_.CreateLoad(
|
|
||||||
+ b_.getInt64Ty(),
|
|
||||||
+ b_.CreateGEP(b_.getInt64Ty(), ctx, b_.getInt64(offset)),
|
|
||||||
+ call.func + "_" + reg_name);
|
|
||||||
dyn_cast<LoadInst>(expr_)->setVolatile(true);
|
|
||||||
}
|
|
||||||
else if (call.func == "printf")
|
|
||||||
@@ -812,8 +829,10 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
auto scoped_del = accept(&arg);
|
|
||||||
|
|
||||||
// and store it to data area
|
|
||||||
- Value *offset = b_.CreateGEP(
|
|
||||||
- data, { b_.getInt64(0), b_.getInt64((i - 1) * ptr_size) });
|
|
||||||
+ Value *offset = b_.CreateGEP(b_.GetType(data_type),
|
|
||||||
+ data,
|
|
||||||
+ { b_.getInt64(0),
|
|
||||||
+ b_.getInt64((i - 1) * ptr_size) });
|
|
||||||
b_.CreateStore(expr_, offset);
|
|
||||||
|
|
||||||
// keep the expression alive, so it's still there
|
|
||||||
@@ -901,7 +920,9 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
AllocaInst *buf = b_.CreateAllocaBPF(event_struct,
|
|
||||||
call.func + "_" + map.ident);
|
|
||||||
|
|
||||||
- auto aa_ptr = b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(0) });
|
|
||||||
+ auto aa_ptr = b_.CreateGEP(event_struct,
|
|
||||||
+ buf,
|
|
||||||
+ { b_.getInt64(0), b_.getInt32(0) });
|
|
||||||
if (call.func == "clear")
|
|
||||||
b_.CreateStore(b_.GetIntSameSize(asyncactionint(AsyncAction::clear),
|
|
||||||
elements.at(0)),
|
|
||||||
@@ -912,7 +933,9 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
aa_ptr);
|
|
||||||
|
|
||||||
auto id = bpftrace_.maps[map.ident].value()->id;
|
|
||||||
- auto *ident_ptr = b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(1) });
|
|
||||||
+ auto *ident_ptr = b_.CreateGEP(event_struct,
|
|
||||||
+ buf,
|
|
||||||
+ { b_.getInt64(0), b_.getInt32(1) });
|
|
||||||
b_.CreateStore(b_.GetIntSameSize(id, elements.at(1)), ident_ptr);
|
|
||||||
|
|
||||||
b_.CreatePerfEventOutput(ctx_, buf, getStructSize(event_struct));
|
|
||||||
@@ -928,12 +951,13 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
|
|
||||||
AllocaInst *buf = b_.CreateAllocaBPF(time_struct, call.func + "_t");
|
|
||||||
|
|
||||||
- b_.CreateStore(b_.GetIntSameSize(asyncactionint(AsyncAction::time),
|
|
||||||
- elements.at(0)),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ b_.GetIntSameSize(asyncactionint(AsyncAction::time), elements.at(0)),
|
|
||||||
+ b_.CreateGEP(time_struct, buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
|
|
||||||
- b_.CreateStore(b_.GetIntSameSize(time_id_, elements.at(1)),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ b_.GetIntSameSize(time_id_, elements.at(1)),
|
|
||||||
+ b_.CreateGEP(time_struct, buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
|
|
||||||
time_id_++;
|
|
||||||
b_.CreatePerfEventOutput(ctx_, buf, getStructSize(time_struct));
|
|
||||||
@@ -948,13 +972,15 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
true);
|
|
||||||
|
|
||||||
AllocaInst *buf = b_.CreateAllocaBPF(strftime_struct, call.func + "_args");
|
|
||||||
- b_.CreateStore(b_.GetIntSameSize(strftime_id_, elements.at(0)),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ b_.GetIntSameSize(strftime_id_, elements.at(0)),
|
|
||||||
+ b_.CreateGEP(strftime_struct, buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
strftime_id_++;
|
|
||||||
Expression *arg = call.vargs->at(1);
|
|
||||||
auto scoped_del = accept(arg);
|
|
||||||
- b_.CreateStore(expr_,
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ expr_,
|
|
||||||
+ b_.CreateGEP(strftime_struct, buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
expr_ = buf;
|
|
||||||
}
|
|
||||||
else if (call.func == "kstack" || call.func == "ustack")
|
|
||||||
@@ -1068,11 +1094,12 @@ void CodegenLLVM::visit(Call &call)
|
|
||||||
AllocaInst *buf = b_.CreateAllocaBPF(unwatch_struct, "unwatch");
|
|
||||||
size_t struct_size = datalayout().getTypeAllocSize(unwatch_struct);
|
|
||||||
|
|
||||||
- b_.CreateStore(b_.getInt64(asyncactionint(AsyncAction::watchpoint_detach)),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ b_.getInt64(asyncactionint(AsyncAction::watchpoint_detach)),
|
|
||||||
+ b_.CreateGEP(unwatch_struct, buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
b_.CreateStore(
|
|
||||||
b_.CreateIntCast(expr_, b_.getInt64Ty(), false /* unsigned */),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
+ b_.CreateGEP(unwatch_struct, buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
b_.CreatePerfEventOutput(ctx_, buf, struct_size);
|
|
||||||
b_.CreateLifetimeEnd(buf);
|
|
||||||
expr_ = nullptr;
|
|
||||||
@@ -1102,7 +1129,8 @@ void CodegenLLVM::visit(Variable &var)
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
- expr_ = b_.CreateLoad(variables_[var.ident]);
|
|
||||||
+ auto *var_alloca = variables_[var.ident];
|
|
||||||
+ expr_ = b_.CreateLoad(var_alloca->getType()->getElementType(), var_alloca);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1379,13 +1407,15 @@ void CodegenLLVM::visit(Unop &unop)
|
|
||||||
if (unop.is_post_op)
|
|
||||||
expr_ = oldval;
|
|
||||||
else
|
|
||||||
- expr_ = b_.CreateLoad(newval);
|
|
||||||
+ expr_ = b_.CreateLoad(b_.GetType(map.type), newval);
|
|
||||||
b_.CreateLifetimeEnd(newval);
|
|
||||||
}
|
|
||||||
else if (unop.expr->is_variable)
|
|
||||||
{
|
|
||||||
Variable &var = static_cast<Variable&>(*unop.expr);
|
|
||||||
- Value *oldval = b_.CreateLoad(variables_[var.ident]);
|
|
||||||
+ Value *oldval = b_.CreateLoad(
|
|
||||||
+ variables_[var.ident]->getType()->getElementType(),
|
|
||||||
+ variables_[var.ident]);
|
|
||||||
Value *newval;
|
|
||||||
if (is_increment)
|
|
||||||
newval = b_.CreateAdd(oldval, b_.getInt64(1));
|
|
||||||
@@ -1411,9 +1441,10 @@ void CodegenLLVM::visit(Unop &unop)
|
|
||||||
: type.GetSize();
|
|
||||||
auto as = type.GetAS();
|
|
||||||
|
|
||||||
- AllocaInst *dst = b_.CreateAllocaBPF(SizedType(type.type, size), "deref");
|
|
||||||
+ auto dst_type = SizedType(type.type, size);
|
|
||||||
+ AllocaInst *dst = b_.CreateAllocaBPF(dst_type, "deref");
|
|
||||||
b_.CreateProbeRead(ctx_, dst, size, expr_, as, unop.loc);
|
|
||||||
- expr_ = b_.CreateIntCast(b_.CreateLoad(dst),
|
|
||||||
+ expr_ = b_.CreateIntCast(b_.CreateLoad(b_.GetType(dst_type), dst),
|
|
||||||
b_.getInt64Ty(),
|
|
||||||
type.IsSigned());
|
|
||||||
b_.CreateLifetimeEnd(dst);
|
|
||||||
@@ -1434,7 +1465,7 @@ void CodegenLLVM::visit(Unop &unop)
|
|
||||||
int size = unop.type.IsIntegerTy() ? et->GetIntBitWidth() / 8 : 8;
|
|
||||||
AllocaInst *dst = b_.CreateAllocaBPF(*et, "deref");
|
|
||||||
b_.CreateProbeRead(ctx_, dst, size, expr_, type.GetAS(), unop.loc);
|
|
||||||
- expr_ = b_.CreateIntCast(b_.CreateLoad(dst),
|
|
||||||
+ expr_ = b_.CreateIntCast(b_.CreateLoad(b_.GetType(*et), dst),
|
|
||||||
b_.getInt64Ty(),
|
|
||||||
unop.type.IsSigned());
|
|
||||||
b_.CreateLifetimeEnd(dst);
|
|
||||||
@@ -1492,7 +1523,7 @@ void CodegenLLVM::visit(Ternary &ternary)
|
|
||||||
b_.CreateBr(done);
|
|
||||||
|
|
||||||
b_.SetInsertPoint(done);
|
|
||||||
- expr_ = b_.CreateLoad(result);
|
|
||||||
+ expr_ = b_.CreateLoad(b_.GetType(ternary.type), result);
|
|
||||||
}
|
|
||||||
else if (ternary.type.IsStringTy())
|
|
||||||
{
|
|
||||||
@@ -1549,7 +1580,8 @@ void CodegenLLVM::visit(FieldAccess &acc)
|
|
||||||
}
|
|
||||||
else if (type.IsTupleTy())
|
|
||||||
{
|
|
||||||
- Value *src = b_.CreateGEP(expr_,
|
|
||||||
+ Value *src = b_.CreateGEP(b_.GetType(type),
|
|
||||||
+ expr_,
|
|
||||||
{ b_.getInt32(0), b_.getInt32(acc.index) });
|
|
||||||
SizedType &elem_type = type.GetFields()[acc.index].type;
|
|
||||||
|
|
||||||
@@ -1596,10 +1628,12 @@ void CodegenLLVM::visit(FieldAccess &acc)
|
|
||||||
if (field.is_bitfield)
|
|
||||||
{
|
|
||||||
Value *raw;
|
|
||||||
+ auto field_type = b_.GetType(field.type);
|
|
||||||
if (type.IsCtxAccess())
|
|
||||||
- raw = b_.CreateLoad(
|
|
||||||
- b_.CreateIntToPtr(src, b_.GetType(field.type)->getPointerTo()),
|
|
||||||
- true);
|
|
||||||
+ raw = b_.CreateLoad(field_type,
|
|
||||||
+ b_.CreateIntToPtr(src,
|
|
||||||
+ field_type->getPointerTo()),
|
|
||||||
+ true);
|
|
||||||
else
|
|
||||||
{
|
|
||||||
AllocaInst *dst = b_.CreateAllocaBPF(field.type,
|
|
||||||
@@ -1610,7 +1644,7 @@ void CodegenLLVM::visit(FieldAccess &acc)
|
|
||||||
b_.CREATE_MEMSET(dst, b_.getInt8(0), field.type.GetSize(), 1);
|
|
||||||
b_.CreateProbeRead(
|
|
||||||
ctx_, dst, field.bitfield.read_bytes, src, type.GetAS(), acc.loc);
|
|
||||||
- raw = b_.CreateLoad(dst);
|
|
||||||
+ raw = b_.CreateLoad(field_type, dst);
|
|
||||||
b_.CreateLifetimeEnd(dst);
|
|
||||||
}
|
|
||||||
size_t rshiftbits;
|
|
||||||
@@ -1638,7 +1672,8 @@ void CodegenLLVM::visit(FieldAccess &acc)
|
|
||||||
// offset which we add to the start of the tracepoint struct.
|
|
||||||
expr_ = b_.CreateLoad(
|
|
||||||
b_.getInt32Ty(),
|
|
||||||
- b_.CreateGEP(b_.CreatePointerCast(ctx_,
|
|
||||||
+ b_.CreateGEP(b_.getInt32Ty(),
|
|
||||||
+ b_.CreatePointerCast(ctx_,
|
|
||||||
b_.getInt32Ty()->getPointerTo()),
|
|
||||||
b_.getInt64(field.offset / 4)));
|
|
||||||
expr_ = b_.CreateIntCast(expr_, b_.getInt64Ty(), false);
|
|
||||||
@@ -1757,7 +1792,9 @@ void CodegenLLVM::visit(Tuple &tuple)
|
|
||||||
Expression *elem = tuple.elems->at(i);
|
|
||||||
auto scoped_del = accept(elem);
|
|
||||||
|
|
||||||
- Value *dst = b_.CreateGEP(buf, { b_.getInt32(0), b_.getInt32(i) });
|
|
||||||
+ Value *dst = b_.CreateGEP(tuple_ty,
|
|
||||||
+ buf,
|
|
||||||
+ { b_.getInt32(0), b_.getInt32(i) });
|
|
||||||
|
|
||||||
if (onStack(elem->type))
|
|
||||||
b_.CREATE_MEMCPY(dst, expr_, elem->type.GetSize(), 1);
|
|
||||||
@@ -2357,6 +2394,7 @@ std::tuple<Value *, CodegenLLVM::ScopedExprDeleter> CodegenLLVM::getMapKey(
|
|
||||||
size += expr->type.GetSize();
|
|
||||||
}
|
|
||||||
key = b_.CreateAllocaBPF(size, map.ident + "_key");
|
|
||||||
+ auto *key_type = ArrayType::get(b_.getInt8Ty(), size);
|
|
||||||
|
|
||||||
int offset = 0;
|
|
||||||
// Construct a map key in the stack
|
|
||||||
@@ -2364,7 +2402,8 @@ std::tuple<Value *, CodegenLLVM::ScopedExprDeleter> CodegenLLVM::getMapKey(
|
|
||||||
{
|
|
||||||
auto scoped_del = accept(expr);
|
|
||||||
Value *offset_val = b_.CreateGEP(
|
|
||||||
- key, { b_.getInt64(0), b_.getInt64(offset) });
|
|
||||||
+ key_type, key,
|
|
||||||
+ { b_.getInt64(0), b_.getInt64(offset) });
|
|
||||||
|
|
||||||
if (onStack(expr->type))
|
|
||||||
b_.CREATE_MEMCPY(offset_val, expr_, expr->type.GetSize(), 1);
|
|
||||||
@@ -2417,18 +2456,19 @@ AllocaInst *CodegenLLVM::getHistMapKey(Map &map, Value *log2)
|
|
||||||
size += expr->type.GetSize();
|
|
||||||
}
|
|
||||||
key = b_.CreateAllocaBPF(size, map.ident + "_key");
|
|
||||||
+ auto *key_type = ArrayType::get(b_.getInt8Ty(), size);
|
|
||||||
|
|
||||||
int offset = 0;
|
|
||||||
for (Expression *expr : *map.vargs) {
|
|
||||||
auto scoped_del = accept(expr);
|
|
||||||
- Value *offset_val = b_.CreateGEP(key, {b_.getInt64(0), b_.getInt64(offset)});
|
|
||||||
+ Value *offset_val = b_.CreateGEP(key_type, key, {b_.getInt64(0), b_.getInt64(offset)});
|
|
||||||
if (shouldBeOnStackAlready(expr->type))
|
|
||||||
b_.CREATE_MEMCPY(offset_val, expr_, expr->type.GetSize(), 1);
|
|
||||||
else
|
|
||||||
b_.CreateStore(expr_, offset_val);
|
|
||||||
offset += expr->type.GetSize();
|
|
||||||
}
|
|
||||||
- Value *offset_val = b_.CreateGEP(key, {b_.getInt64(0), b_.getInt64(offset)});
|
|
||||||
+ Value *offset_val = b_.CreateGEP(key_type, key, {b_.getInt64(0), b_.getInt64(offset)});
|
|
||||||
b_.CreateStore(log2, offset_val);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
@@ -2475,7 +2515,7 @@ Value *CodegenLLVM::createLogicalAnd(Binop &binop)
|
|
||||||
b_.CreateBr(merge_block);
|
|
||||||
|
|
||||||
b_.SetInsertPoint(merge_block);
|
|
||||||
- return b_.CreateLoad(result);
|
|
||||||
+ return b_.CreateLoad(b_.getInt64Ty(), result);
|
|
||||||
}
|
|
||||||
|
|
||||||
Value *CodegenLLVM::createLogicalOr(Binop &binop)
|
|
||||||
@@ -2514,7 +2554,7 @@ Value *CodegenLLVM::createLogicalOr(Binop &binop)
|
|
||||||
b_.CreateBr(merge_block);
|
|
||||||
|
|
||||||
b_.SetInsertPoint(merge_block);
|
|
||||||
- return b_.CreateLoad(result);
|
|
||||||
+ return b_.CreateLoad(b_.getInt64Ty(), result);
|
|
||||||
}
|
|
||||||
|
|
||||||
Function *CodegenLLVM::createLog2Function()
|
|
||||||
@@ -2558,34 +2598,37 @@ Function *CodegenLLVM::createLog2Function()
|
|
||||||
// test for less than zero
|
|
||||||
BasicBlock *is_less_than_zero = BasicBlock::Create(module_->getContext(), "hist.is_less_than_zero", log2_func);
|
|
||||||
BasicBlock *is_not_less_than_zero = BasicBlock::Create(module_->getContext(), "hist.is_not_less_than_zero", log2_func);
|
|
||||||
- b_.CreateCondBr(b_.CreateICmpSLT(b_.CreateLoad(n_alloc), b_.getInt64(0)),
|
|
||||||
+ b_.CreateCondBr(b_.CreateICmpSLT(b_.CreateLoad(b_.getInt64Ty(), n_alloc),
|
|
||||||
+ b_.getInt64(0)),
|
|
||||||
is_less_than_zero,
|
|
||||||
is_not_less_than_zero);
|
|
||||||
b_.SetInsertPoint(is_less_than_zero);
|
|
||||||
- createRet(b_.CreateLoad(result));
|
|
||||||
+ createRet(b_.CreateLoad(b_.getInt64Ty(), result));
|
|
||||||
b_.SetInsertPoint(is_not_less_than_zero);
|
|
||||||
|
|
||||||
// test for equal to zero
|
|
||||||
BasicBlock *is_zero = BasicBlock::Create(module_->getContext(), "hist.is_zero", log2_func);
|
|
||||||
BasicBlock *is_not_zero = BasicBlock::Create(module_->getContext(), "hist.is_not_zero", log2_func);
|
|
||||||
- b_.CreateCondBr(b_.CreateICmpEQ(b_.CreateLoad(n_alloc), b_.getInt64(0)),
|
|
||||||
+ b_.CreateCondBr(b_.CreateICmpEQ(b_.CreateLoad(b_.getInt64Ty(), n_alloc),
|
|
||||||
+ b_.getInt64(0)),
|
|
||||||
is_zero,
|
|
||||||
is_not_zero);
|
|
||||||
b_.SetInsertPoint(is_zero);
|
|
||||||
b_.CreateStore(b_.getInt64(1), result);
|
|
||||||
- createRet(b_.CreateLoad(result));
|
|
||||||
+ createRet(b_.CreateLoad(b_.getInt64Ty(), result));
|
|
||||||
b_.SetInsertPoint(is_not_zero);
|
|
||||||
|
|
||||||
// power-of-2 index, offset by +2
|
|
||||||
b_.CreateStore(b_.getInt64(2), result);
|
|
||||||
for (int i = 4; i >= 0; i--)
|
|
||||||
{
|
|
||||||
- Value *n = b_.CreateLoad(n_alloc);
|
|
||||||
+ Value *n = b_.CreateLoad(b_.getInt64Ty(), n_alloc);
|
|
||||||
Value *shift = b_.CreateShl(b_.CreateIntCast(b_.CreateICmpSGE(b_.CreateIntCast(n, b_.getInt64Ty(), false), b_.getInt64(1 << (1<<i))), b_.getInt64Ty(), false), i);
|
|
||||||
b_.CreateStore(b_.CreateLShr(n, shift), n_alloc);
|
|
||||||
- b_.CreateStore(b_.CreateAdd(b_.CreateLoad(result), shift), result);
|
|
||||||
+ b_.CreateStore(b_.CreateAdd(b_.CreateLoad(b_.getInt64Ty(), result), shift),
|
|
||||||
+ result);
|
|
||||||
}
|
|
||||||
- createRet(b_.CreateLoad(result));
|
|
||||||
+ createRet(b_.CreateLoad(b_.getInt64Ty(), result));
|
|
||||||
b_.restoreIP(ip);
|
|
||||||
return module_->getFunction("log2");
|
|
||||||
}
|
|
||||||
@@ -2635,8 +2678,8 @@ Function *CodegenLLVM::createLinearFunction()
|
|
||||||
|
|
||||||
// algorithm
|
|
||||||
{
|
|
||||||
- Value *min = b_.CreateLoad(min_alloc);
|
|
||||||
- Value *val = b_.CreateLoad(value_alloc);
|
|
||||||
+ Value *min = b_.CreateLoad(b_.getInt64Ty(), min_alloc);
|
|
||||||
+ Value *val = b_.CreateLoad(b_.getInt64Ty(), value_alloc);
|
|
||||||
cmp = b_.CreateICmpSLT(val, min);
|
|
||||||
}
|
|
||||||
BasicBlock *lt_min = BasicBlock::Create(module_->getContext(), "lhist.lt_min", linear_func);
|
|
||||||
@@ -2648,8 +2691,8 @@ Function *CodegenLLVM::createLinearFunction()
|
|
||||||
|
|
||||||
b_.SetInsertPoint(ge_min);
|
|
||||||
{
|
|
||||||
- Value *max = b_.CreateLoad(max_alloc);
|
|
||||||
- Value *val = b_.CreateLoad(value_alloc);
|
|
||||||
+ Value *max = b_.CreateLoad(b_.getInt64Ty(), max_alloc);
|
|
||||||
+ Value *val = b_.CreateLoad(b_.getInt64Ty(), value_alloc);
|
|
||||||
cmp = b_.CreateICmpSGT(val, max);
|
|
||||||
}
|
|
||||||
BasicBlock *le_max = BasicBlock::Create(module_->getContext(), "lhist.le_max", linear_func);
|
|
||||||
@@ -2658,22 +2701,22 @@ Function *CodegenLLVM::createLinearFunction()
|
|
||||||
|
|
||||||
b_.SetInsertPoint(gt_max);
|
|
||||||
{
|
|
||||||
- Value *step = b_.CreateLoad(step_alloc);
|
|
||||||
- Value *min = b_.CreateLoad(min_alloc);
|
|
||||||
- Value *max = b_.CreateLoad(max_alloc);
|
|
||||||
+ Value *step = b_.CreateLoad(b_.getInt64Ty(), step_alloc);
|
|
||||||
+ Value *min = b_.CreateLoad(b_.getInt64Ty(), min_alloc);
|
|
||||||
+ Value *max = b_.CreateLoad(b_.getInt64Ty(), max_alloc);
|
|
||||||
Value *div = b_.CreateUDiv(b_.CreateSub(max, min), step);
|
|
||||||
b_.CreateStore(b_.CreateAdd(div, b_.getInt64(1)), result_alloc);
|
|
||||||
- createRet(b_.CreateLoad(result_alloc));
|
|
||||||
+ createRet(b_.CreateLoad(b_.getInt64Ty(), result_alloc));
|
|
||||||
}
|
|
||||||
|
|
||||||
b_.SetInsertPoint(le_max);
|
|
||||||
{
|
|
||||||
- Value *step = b_.CreateLoad(step_alloc);
|
|
||||||
- Value *min = b_.CreateLoad(min_alloc);
|
|
||||||
- Value *val = b_.CreateLoad(value_alloc);
|
|
||||||
+ Value *step = b_.CreateLoad(b_.getInt64Ty(), step_alloc);
|
|
||||||
+ Value *min = b_.CreateLoad(b_.getInt64Ty(), min_alloc);
|
|
||||||
+ Value *val = b_.CreateLoad(b_.getInt64Ty(), value_alloc);
|
|
||||||
Value *div3 = b_.CreateUDiv(b_.CreateSub(val, min), step);
|
|
||||||
b_.CreateStore(b_.CreateAdd(div3, b_.getInt64(1)), result_alloc);
|
|
||||||
- createRet(b_.CreateLoad(result_alloc));
|
|
||||||
+ createRet(b_.CreateLoad(b_.getInt64Ty(), result_alloc));
|
|
||||||
}
|
|
||||||
|
|
||||||
b_.restoreIP(ip);
|
|
||||||
@@ -2711,14 +2754,18 @@ void CodegenLLVM::createFormatStringCall(Call &call, int &id, CallArgs &call_arg
|
|
||||||
// as the struct is not packed we need to memset it.
|
|
||||||
b_.CREATE_MEMSET(fmt_args, b_.getInt8(0), struct_size, 1);
|
|
||||||
|
|
||||||
- Value *id_offset = b_.CreateGEP(fmt_args, {b_.getInt32(0), b_.getInt32(0)});
|
|
||||||
+ Value *id_offset = b_.CreateGEP(fmt_struct,
|
|
||||||
+ fmt_args,
|
|
||||||
+ { b_.getInt32(0), b_.getInt32(0) });
|
|
||||||
b_.CreateStore(b_.getInt64(id + asyncactionint(async_action)), id_offset);
|
|
||||||
|
|
||||||
for (size_t i=1; i<call.vargs->size(); i++)
|
|
||||||
{
|
|
||||||
Expression &arg = *call.vargs->at(i);
|
|
||||||
auto scoped_del = accept(&arg);
|
|
||||||
- Value *offset = b_.CreateGEP(fmt_args, {b_.getInt32(0), b_.getInt32(i)});
|
|
||||||
+ Value *offset = b_.CreateGEP(fmt_struct,
|
|
||||||
+ fmt_args,
|
|
||||||
+ { b_.getInt32(0), b_.getInt32(i) });
|
|
||||||
if (needMemcpy(arg.type))
|
|
||||||
b_.CREATE_MEMCPY(offset, expr_, arg.type.GetSize(), 1);
|
|
||||||
else if (arg.type.IsIntegerTy() && arg.type.GetSize() < 8)
|
|
||||||
@@ -2758,10 +2805,12 @@ void CodegenLLVM::generateWatchpointSetupProbe(
|
|
||||||
// Pull out function argument
|
|
||||||
Value *ctx = func->arg_begin();
|
|
||||||
int offset = arch::arg_offset(arg_num);
|
|
||||||
- Value *addr = b_.CreateLoad(
|
|
||||||
- b_.getInt64Ty(),
|
|
||||||
- b_.CreateGEP(ctx, b_.getInt64(offset * sizeof(uintptr_t))),
|
|
||||||
- "arg" + std::to_string(arg_num));
|
|
||||||
+ Value *arg = b_.CreateGEP(b_.getInt8Ty(),
|
|
||||||
+ ctx,
|
|
||||||
+ b_.getInt64(offset * sizeof(uintptr_t)));
|
|
||||||
+ Value *addr = b_.CreateLoad(b_.getInt64Ty(),
|
|
||||||
+ arg,
|
|
||||||
+ "arg" + std::to_string(arg_num));
|
|
||||||
|
|
||||||
// Tell userspace to setup the real watchpoint
|
|
||||||
auto elements = AsyncEvent::Watchpoint().asLLVMType(b_);
|
|
||||||
@@ -2772,12 +2821,16 @@ void CodegenLLVM::generateWatchpointSetupProbe(
|
|
||||||
size_t struct_size = datalayout().getTypeAllocSize(watchpoint_struct);
|
|
||||||
|
|
||||||
// Fill in perf event struct
|
|
||||||
- b_.CreateStore(b_.getInt64(asyncactionint(AsyncAction::watchpoint_attach)),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
- b_.CreateStore(b_.getInt64(watchpoint_id_),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ b_.getInt64(asyncactionint(AsyncAction::watchpoint_attach)),
|
|
||||||
+ b_.CreateGEP(watchpoint_struct, buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ b_.getInt64(watchpoint_id_),
|
|
||||||
+ b_.CreateGEP(watchpoint_struct, buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
watchpoint_id_++;
|
|
||||||
- b_.CreateStore(addr, b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(2) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ addr,
|
|
||||||
+ b_.CreateGEP(watchpoint_struct, buf, { b_.getInt64(0), b_.getInt32(2) }));
|
|
||||||
b_.CreatePerfEventOutput(ctx, buf, struct_size);
|
|
||||||
b_.CreateLifetimeEnd(buf);
|
|
||||||
|
|
||||||
@@ -2796,11 +2849,14 @@ void CodegenLLVM::createPrintMapCall(Call &call)
|
|
||||||
call.func + "_" + map.ident);
|
|
||||||
|
|
||||||
// store asyncactionid:
|
|
||||||
- b_.CreateStore(b_.getInt64(asyncactionint(AsyncAction::print)),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ b_.getInt64(asyncactionint(AsyncAction::print)),
|
|
||||||
+ b_.CreateGEP(print_struct, buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
|
|
||||||
auto id = bpftrace_.maps[map.ident].value()->id;
|
|
||||||
- auto *ident_ptr = b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(1) });
|
|
||||||
+ auto *ident_ptr = b_.CreateGEP(print_struct,
|
|
||||||
+ buf,
|
|
||||||
+ { b_.getInt64(0), b_.getInt32(1) });
|
|
||||||
b_.CreateStore(b_.GetIntSameSize(id, elements.at(1)), ident_ptr);
|
|
||||||
|
|
||||||
// top, div
|
|
||||||
@@ -2812,14 +2868,16 @@ void CodegenLLVM::createPrintMapCall(Call &call)
|
|
||||||
auto scoped_del = accept(call.vargs->at(arg_idx));
|
|
||||||
|
|
||||||
b_.CreateStore(b_.CreateIntCast(expr_, elements.at(arg_idx), false),
|
|
||||||
- b_.CreateGEP(buf,
|
|
||||||
+ b_.CreateGEP(print_struct,
|
|
||||||
+ buf,
|
|
||||||
{ b_.getInt64(0), b_.getInt32(arg_idx + 1) }));
|
|
||||||
}
|
|
||||||
|
|
||||||
for (; arg_idx < 3; arg_idx++)
|
|
||||||
{
|
|
||||||
b_.CreateStore(b_.GetIntSameSize(0, elements.at(arg_idx)),
|
|
||||||
- b_.CreateGEP(buf,
|
|
||||||
+ b_.CreateGEP(print_struct,
|
|
||||||
+ buf,
|
|
||||||
{ b_.getInt64(0), b_.getInt32(arg_idx + 1) }));
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -2844,15 +2902,19 @@ void CodegenLLVM::createPrintNonMapCall(Call &call, int &id)
|
|
||||||
size_t struct_size = datalayout().getTypeAllocSize(print_struct);
|
|
||||||
|
|
||||||
// Store asyncactionid:
|
|
||||||
- b_.CreateStore(b_.getInt64(asyncactionint(AsyncAction::print_non_map)),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ b_.getInt64(asyncactionint(AsyncAction::print_non_map)),
|
|
||||||
+ b_.CreateGEP(print_struct, buf, { b_.getInt64(0), b_.getInt32(0) }));
|
|
||||||
|
|
||||||
// Store print id
|
|
||||||
- b_.CreateStore(b_.getInt64(id),
|
|
||||||
- b_.CreateGEP(buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
+ b_.CreateStore(
|
|
||||||
+ b_.getInt64(id),
|
|
||||||
+ b_.CreateGEP(print_struct, buf, { b_.getInt64(0), b_.getInt32(1) }));
|
|
||||||
|
|
||||||
// Store content
|
|
||||||
- Value *content_offset = b_.CreateGEP(buf, { b_.getInt32(0), b_.getInt32(2) });
|
|
||||||
+ Value *content_offset = b_.CreateGEP(print_struct,
|
|
||||||
+ buf,
|
|
||||||
+ { b_.getInt32(0), b_.getInt32(2) });
|
|
||||||
b_.CREATE_MEMSET(content_offset, b_.getInt8(0), arg.type.GetSize(), 1);
|
|
||||||
if (needMemcpy(arg.type))
|
|
||||||
{
|
|
||||||
@@ -3023,7 +3085,9 @@ void CodegenLLVM::readDatastructElemFromStack(Value *src_data,
|
|
||||||
src_data = b_.CreateIntToPtr(src_data,
|
|
||||||
b_.GetType(data_type)->getPointerTo());
|
|
||||||
|
|
||||||
- Value *src = b_.CreateGEP(src_data, { b_.getInt32(0), index });
|
|
||||||
+ Value *src = b_.CreateGEP(b_.GetType(data_type),
|
|
||||||
+ src_data,
|
|
||||||
+ { b_.getInt32(0), index });
|
|
||||||
|
|
||||||
// It may happen that the result pointer type is not correct, in such case
|
|
||||||
// do a typecast
|
|
||||||
@@ -3034,7 +3098,7 @@ void CodegenLLVM::readDatastructElemFromStack(Value *src_data,
|
|
||||||
if (elem_type.IsIntegerTy() || elem_type.IsPtrTy())
|
|
||||||
{
|
|
||||||
// Load the correct type from src
|
|
||||||
- expr_ = b_.CreateLoad(src, true);
|
|
||||||
+ expr_ = b_.CreateLoad(b_.GetType(elem_type), src, true);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
@@ -3101,7 +3165,8 @@ void CodegenLLVM::probereadDatastructElem(Value *src_data,
|
|
||||||
// Read data onto stack
|
|
||||||
if (data_type.IsCtxAccess())
|
|
||||||
{
|
|
||||||
- expr_ = b_.CreateLoad(b_.CreateIntToPtr(src, dst_type->getPointerTo()),
|
|
||||||
+ expr_ = b_.CreateLoad(dst_type,
|
|
||||||
+ b_.CreateIntToPtr(src, dst_type->getPointerTo()),
|
|
||||||
true);
|
|
||||||
expr_ = b_.CreateIntCast(expr_, b_.getInt64Ty(), elem_type.IsSigned());
|
|
||||||
|
|
||||||
@@ -3132,7 +3197,7 @@ void CodegenLLVM::probereadDatastructElem(Value *src_data,
|
|
||||||
AllocaInst *dst = b_.CreateAllocaBPF(elem_type, temp_name);
|
|
||||||
b_.CreateProbeRead(
|
|
||||||
ctx_, dst, elem_type.GetSize(), src, data_type.GetAS(), loc);
|
|
||||||
- expr_ = b_.CreateIntCast(b_.CreateLoad(dst),
|
|
||||||
+ expr_ = b_.CreateIntCast(b_.CreateLoad(b_.GetType(elem_type), dst),
|
|
||||||
b_.getInt64Ty(),
|
|
||||||
elem_type.IsSigned());
|
|
||||||
b_.CreateLifetimeEnd(dst);
|
|
||||||
diff --git a/src/ast/irbuilderbpf.cpp b/src/ast/irbuilderbpf.cpp
|
|
||||||
index ab1464d3..59771e91 100644
|
|
||||||
--- a/src/ast/irbuilderbpf.cpp
|
|
||||||
+++ b/src/ast/irbuilderbpf.cpp
|
|
||||||
@@ -94,8 +94,8 @@ AllocaInst *IRBuilderBPF::CreateUSym(llvm::Value *val)
|
|
||||||
Value *pid = CreateLShr(CreateGetPidTgid(), 32);
|
|
||||||
|
|
||||||
// The extra 0 here ensures the type of addr_offset will be int64
|
|
||||||
- Value *addr_offset = CreateGEP(buf, { getInt64(0), getInt32(0) });
|
|
||||||
- Value *pid_offset = CreateGEP(buf, { getInt64(0), getInt32(1) });
|
|
||||||
+ Value *addr_offset = CreateGEP(usym_t, buf, { getInt64(0), getInt32(0) });
|
|
||||||
+ Value *pid_offset = CreateGEP(usym_t, buf, { getInt64(0), getInt32(1) });
|
|
||||||
|
|
||||||
CreateStore(val, addr_offset);
|
|
||||||
CreateStore(pid, pid_offset);
|
|
||||||
@@ -401,7 +401,8 @@ Value *IRBuilderBPF::CreateMapLookupElem(Value *ctx,
|
|
||||||
if (needMemcpy(type))
|
|
||||||
return value;
|
|
||||||
|
|
||||||
- Value *ret = CreateLoad(value);
|
|
||||||
+ // value is a pointer to i64
|
|
||||||
+ Value *ret = CreateLoad(getInt64Ty(), value);
|
|
||||||
CreateLifetimeEnd(value);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
@@ -621,7 +622,10 @@ Value *IRBuilderBPF::CreateUSDTReadArgument(Value *ctx,
|
|
||||||
// bpftrace's args are internally represented as 64 bit integers. However,
|
|
||||||
// the underlying argument (of the target program) may be less than 64
|
|
||||||
// bits. So we must be careful to zero out unused bits.
|
|
||||||
- Value* reg = CreateGEP(ctx, getInt64(offset * sizeof(uintptr_t)), "load_register");
|
|
||||||
+ Value *reg = CreateGEP(getInt8Ty(),
|
|
||||||
+ ctx,
|
|
||||||
+ getInt64(offset * sizeof(uintptr_t)),
|
|
||||||
+ "load_register");
|
|
||||||
AllocaInst *dst = CreateAllocaBPF(builtin.type, builtin.ident);
|
|
||||||
Value *index_offset = nullptr;
|
|
||||||
if (argument->valid & BCC_USDT_ARGUMENT_INDEX_REGISTER_NAME)
|
|
||||||
@@ -632,7 +636,8 @@ Value *IRBuilderBPF::CreateUSDTReadArgument(Value *ctx,
|
|
||||||
LOG(FATAL) << "offset for register " << argument->index_register_name
|
|
||||||
<< " not known";
|
|
||||||
}
|
|
||||||
- index_offset = CreateGEP(ctx,
|
|
||||||
+ index_offset = CreateGEP(getInt8Ty(),
|
|
||||||
+ ctx,
|
|
||||||
getInt64(ioffset * sizeof(uintptr_t)),
|
|
||||||
"load_register");
|
|
||||||
index_offset = CreateLoad(getInt64Ty(), index_offset);
|
|
||||||
@@ -754,7 +759,7 @@ Value *IRBuilderBPF::CreateStrncmp(Value *ctx __attribute__((unused)),
|
|
||||||
"strcmp.loop",
|
|
||||||
parent);
|
|
||||||
|
|
||||||
- auto *ptr = CreateGEP(val, { getInt32(0), getInt32(i) });
|
|
||||||
+ auto *ptr = CreateGEP(valp->getElementType(), val, { getInt32(0), getInt32(i) });
|
|
||||||
Value *l = CreateLoad(getInt8Ty(), ptr);
|
|
||||||
Value *r = getInt8(c_str[i]);
|
|
||||||
Value *cmp = CreateICmpNE(l, r, "strcmp.cmp");
|
|
||||||
@@ -767,7 +772,8 @@ Value *IRBuilderBPF::CreateStrncmp(Value *ctx __attribute__((unused)),
|
|
||||||
CreateBr(str_ne);
|
|
||||||
|
|
||||||
SetInsertPoint(str_ne);
|
|
||||||
- Value *result = CreateLoad(store);
|
|
||||||
+ // store is a pointer to bool (i1 *)
|
|
||||||
+ Value *result = CreateLoad(getInt1Ty(), store);
|
|
||||||
CreateLifetimeEnd(store);
|
|
||||||
result = CreateIntCast(result, getInt64Ty(), false);
|
|
||||||
return result;
|
|
||||||
@@ -817,9 +823,11 @@ Value *IRBuilderBPF::CreateStrncmp(Value *ctx,
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
+ auto *val1p = dyn_cast<PointerType>(val1->getType());
|
|
||||||
+ auto *val2p = dyn_cast<PointerType>(val2->getType());
|
|
||||||
#ifndef NDEBUG
|
|
||||||
- PointerType *val1p = cast<PointerType>(val1->getType());
|
|
||||||
- PointerType *val2p = cast<PointerType>(val2->getType());
|
|
||||||
+ assert(val1p);
|
|
||||||
+ assert(val2p);
|
|
||||||
|
|
||||||
assert(val1p->getElementType()->isArrayTy() &&
|
|
||||||
val1p->getElementType()->getArrayElementType() == getInt8Ty());
|
|
||||||
@@ -852,11 +860,11 @@ Value *IRBuilderBPF::CreateStrncmp(Value *ctx,
|
|
||||||
"strcmp.loop_null_cmp",
|
|
||||||
parent);
|
|
||||||
|
|
||||||
- auto *ptr1 = CreateGEP(val1, { getInt32(0), getInt32(i) });
|
|
||||||
+ auto *ptr1 = CreateGEP(val1p->getElementType(), val1, { getInt32(0), getInt32(i) });
|
|
||||||
CreateProbeRead(ctx, val_l, 1, ptr1, as1, loc);
|
|
||||||
Value *l = CreateLoad(getInt8Ty(), val_l);
|
|
||||||
|
|
||||||
- auto *ptr2 = CreateGEP(val2, { getInt32(0), getInt32(i) });
|
|
||||||
+ auto *ptr2 = CreateGEP(val2p->getElementType(), val2, { getInt32(0), getInt32(i) });
|
|
||||||
CreateProbeRead(ctx, val_r, 1, ptr2, as2, loc);
|
|
||||||
Value *r = CreateLoad(getInt8Ty(), val_r);
|
|
||||||
|
|
||||||
@@ -878,7 +886,8 @@ Value *IRBuilderBPF::CreateStrncmp(Value *ctx,
|
|
||||||
CreateBr(str_ne);
|
|
||||||
SetInsertPoint(str_ne);
|
|
||||||
|
|
||||||
- Value *result = CreateLoad(store);
|
|
||||||
+ // store is a pointer to bool (i1 *)
|
|
||||||
+ Value *result = CreateLoad(getInt1Ty(), store);
|
|
||||||
CreateLifetimeEnd(store);
|
|
||||||
CreateLifetimeEnd(val_l);
|
|
||||||
CreateLifetimeEnd(val_r);
|
|
||||||
@@ -1107,7 +1116,7 @@ Value *IRBuilderBPF::CreatKFuncArg(Value *ctx,
|
|
||||||
{
|
|
||||||
ctx = CreatePointerCast(ctx, getInt64Ty()->getPointerTo());
|
|
||||||
Value *expr = CreateLoad(getInt64Ty(),
|
|
||||||
- CreateGEP(ctx, getInt64(type.kfarg_idx)),
|
|
||||||
+ CreateGEP(getInt64Ty(), ctx, getInt64(type.kfarg_idx)),
|
|
||||||
name);
|
|
||||||
|
|
||||||
// LLVM 7.0 <= does not have CreateLoad(*Ty, *Ptr, isVolatile, Name),
|
|
||||||
@@ -1161,12 +1170,15 @@ void IRBuilderBPF::CreateHelperError(Value *ctx,
|
|
||||||
elements,
|
|
||||||
true);
|
|
||||||
AllocaInst *buf = CreateAllocaBPF(helper_error_struct, "helper_error_t");
|
|
||||||
- CreateStore(GetIntSameSize(asyncactionint(AsyncAction::helper_error),
|
|
||||||
- elements.at(0)),
|
|
||||||
- CreateGEP(buf, { getInt64(0), getInt32(0) }));
|
|
||||||
- CreateStore(GetIntSameSize(error_id, elements.at(1)),
|
|
||||||
- CreateGEP(buf, { getInt64(0), getInt32(1) }));
|
|
||||||
- CreateStore(return_value, CreateGEP(buf, { getInt64(0), getInt32(2) }));
|
|
||||||
+ CreateStore(
|
|
||||||
+ GetIntSameSize(asyncactionint(AsyncAction::helper_error), elements.at(0)),
|
|
||||||
+ CreateGEP(helper_error_struct, buf, { getInt64(0), getInt32(0) }));
|
|
||||||
+ CreateStore(
|
|
||||||
+ GetIntSameSize(error_id, elements.at(1)),
|
|
||||||
+ CreateGEP(helper_error_struct, buf, { getInt64(0), getInt32(1) }));
|
|
||||||
+ CreateStore(
|
|
||||||
+ return_value,
|
|
||||||
+ CreateGEP(helper_error_struct, buf, { getInt64(0), getInt32(2) }));
|
|
||||||
|
|
||||||
auto &layout = module_.getDataLayout();
|
|
||||||
auto struct_size = layout.getTypeAllocSize(helper_error_struct);
|
|
||||||
@@ -1256,11 +1268,13 @@ void IRBuilderBPF::CreateSeqPrintf(Value *ctx,
|
|
||||||
|
|
||||||
ctx = CreatePointerCast(ctx, getInt8Ty()->getPointerTo());
|
|
||||||
Value *meta = CreateLoad(getInt64Ty()->getPointerTo(),
|
|
||||||
- CreateGEP(ctx, getInt64(0)),
|
|
||||||
+ CreateGEP(getInt8Ty(), ctx, getInt64(0)),
|
|
||||||
"meta");
|
|
||||||
dyn_cast<LoadInst>(meta)->setVolatile(true);
|
|
||||||
|
|
||||||
- Value *seq = CreateLoad(getInt64Ty(), CreateGEP(meta, getInt64(0)), "seq");
|
|
||||||
+ Value *seq = CreateLoad(getInt64Ty(),
|
|
||||||
+ CreateGEP(getInt64Ty(), meta, getInt64(0)),
|
|
||||||
+ "seq");
|
|
||||||
|
|
||||||
CallInst *call = createCall(seq_printf_func,
|
|
||||||
{ seq, fmt, fmt_size, data, data_len },
|
|
||||||
--
|
|
||||||
2.35.3
|
|
||||||
|
|
@ -1,42 +0,0 @@
|
|||||||
From 2ca4b80fcd54300eecdb500a81f411571bfd38ba Mon Sep 17 00:00:00 2001
|
|
||||||
From: Yucong Sun <sunyucong@gmail.com>
|
|
||||||
Date: Thu, 21 Oct 2021 14:43:38 -0700
|
|
||||||
Subject: [PATCH 5/6] Fix compile under llvm14 (trunk)
|
|
||||||
|
|
||||||
---
|
|
||||||
CMakeLists.txt | 2 +-
|
|
||||||
src/bpforc.h | 4 ++++
|
|
||||||
2 files changed, 5 insertions(+), 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
|
||||||
index 3beeb027..3cfae6cb 100644
|
|
||||||
--- a/CMakeLists.txt
|
|
||||||
+++ b/CMakeLists.txt
|
|
||||||
@@ -159,7 +159,7 @@ else()
|
|
||||||
find_package(LLVM REQUIRED)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
- if((${LLVM_VERSION_MAJOR} VERSION_LESS 6) OR (${LLVM_VERSION_MAJOR} VERSION_GREATER 12))
|
|
||||||
+ if((${LLVM_VERSION_MAJOR} VERSION_LESS 6) OR (${LLVM_VERSION_MAJOR} VERSION_GREATER 14))
|
|
||||||
message(SEND_ERROR "Unsupported LLVM version found: ${LLVM_INCLUDE_DIRS}")
|
|
||||||
message(SEND_ERROR "Specify an LLVM major version using LLVM_REQUESTED_VERSION=<major version>")
|
|
||||||
endif()
|
|
||||||
diff --git a/src/bpforc.h b/src/bpforc.h
|
|
||||||
index cc6a1c97..a0e5c9b8 100644
|
|
||||||
--- a/src/bpforc.h
|
|
||||||
+++ b/src/bpforc.h
|
|
||||||
@@ -14,7 +14,11 @@
|
|
||||||
#include <llvm/ExecutionEngine/Orc/RTDyldObjectLinkingLayer.h>
|
|
||||||
#include <llvm/ExecutionEngine/SectionMemoryManager.h>
|
|
||||||
#include <llvm/Support/Error.h>
|
|
||||||
+#if LLVM_VERSION_MAJOR < 14
|
|
||||||
#include <llvm/Support/TargetRegistry.h>
|
|
||||||
+#else
|
|
||||||
+#include <llvm/MC/TargetRegistry.h>
|
|
||||||
+#endif
|
|
||||||
#include <llvm/Target/TargetMachine.h>
|
|
||||||
|
|
||||||
#ifdef LLVM_ORC_V2
|
|
||||||
--
|
|
||||||
2.35.3
|
|
||||||
|
|
@ -1,39 +0,0 @@
|
|||||||
From 0e79852bfd9d8f8efd0091abc7e15b964c79cc0d Mon Sep 17 00:00:00 2001
|
|
||||||
From: Jerome Marchand <jmarchan@redhat.com>
|
|
||||||
Date: Wed, 23 Mar 2022 09:47:25 +0100
|
|
||||||
Subject: [PATCH 3/6] Fix libbtf 0.6.0 build
|
|
||||||
|
|
||||||
Libbtf 0.6.0 introduced a new version of btf_dump__new(). The new
|
|
||||||
version is btf_dump__new_v0_6_0() while the old version was renamed
|
|
||||||
btf_dump__new_deprecated(). btf_dump__new() is now overloaded,
|
|
||||||
unfortunately the macro doesn't work on cpp, at least with LLVM 12.
|
|
||||||
Let's call btf_dump__new_deprecated() explicitely when it's defined.
|
|
||||||
|
|
||||||
Signed-off-by: Jerome Marchand <jmarchan@redhat.com>
|
|
||||||
---
|
|
||||||
src/btf.cpp | 9 +++++++++
|
|
||||||
1 file changed, 9 insertions(+)
|
|
||||||
|
|
||||||
diff --git a/src/btf.cpp b/src/btf.cpp
|
|
||||||
index a5a5e2c0..fccf0a00 100644
|
|
||||||
--- a/src/btf.cpp
|
|
||||||
+++ b/src/btf.cpp
|
|
||||||
@@ -24,6 +24,15 @@
|
|
||||||
#pragma GCC diagnostic pop
|
|
||||||
#include <bpf/libbpf.h>
|
|
||||||
|
|
||||||
+/*
|
|
||||||
+ * Since libbtf 0.6, btf_dump__new() has been overloaded and now can design
|
|
||||||
+ * either btf_dump__new_v0_6_0() or btf_dump__new_deprecated(), which is the
|
|
||||||
+ * same as btf_dump__new() for libbtf < 0.6, and the one we still use.
|
|
||||||
+ */
|
|
||||||
+#if LIBBPF_MAJOR_VERSION == 0 && LIBBPF_MINOR_VERSION >= 6
|
|
||||||
+#define btf_dump__new(a1, a2, a3, a4) btf_dump__new_deprecated(a1, a2, a3, a4)
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
#include "bpftrace.h"
|
|
||||||
|
|
||||||
namespace bpftrace {
|
|
||||||
--
|
|
||||||
2.35.3
|
|
||||||
|
|
@ -1,56 +0,0 @@
|
|||||||
From 7b66256d1025883e3fd911424f8497779eca52ca Mon Sep 17 00:00:00 2001
|
|
||||||
From: Jerome Marchand <jmarchan@redhat.com>
|
|
||||||
Date: Tue, 11 Jun 2019 16:41:59 +0200
|
|
||||||
Subject: [PATCH 1/6] RHEL 8 fixes
|
|
||||||
|
|
||||||
Fixes the following RHEL 8 specific issues:
|
|
||||||
- library path in gethostlatency and threadsnoop
|
|
||||||
---
|
|
||||||
tools/gethostlatency.bt | 12 ++++++------
|
|
||||||
tools/threadsnoop.bt | 2 +-
|
|
||||||
2 files changed, 7 insertions(+), 7 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/tools/gethostlatency.bt b/tools/gethostlatency.bt
|
|
||||||
index 9f4ec31e..dd389c6f 100755
|
|
||||||
--- a/tools/gethostlatency.bt
|
|
||||||
+++ b/tools/gethostlatency.bt
|
|
||||||
@@ -26,17 +26,17 @@ BEGIN
|
|
||||||
"HOST");
|
|
||||||
}
|
|
||||||
|
|
||||||
-uprobe:/lib/x86_64-linux-gnu/libc.so.6:getaddrinfo,
|
|
||||||
-uprobe:/lib/x86_64-linux-gnu/libc.so.6:gethostbyname,
|
|
||||||
-uprobe:/lib/x86_64-linux-gnu/libc.so.6:gethostbyname2
|
|
||||||
+uprobe:/lib64/libc.so.6:getaddrinfo,
|
|
||||||
+uprobe:/lib64/libc.so.6:gethostbyname,
|
|
||||||
+uprobe:/lib64/libc.so.6:gethostbyname2
|
|
||||||
{
|
|
||||||
@start[tid] = nsecs;
|
|
||||||
@name[tid] = arg0;
|
|
||||||
}
|
|
||||||
|
|
||||||
-uretprobe:/lib/x86_64-linux-gnu/libc.so.6:getaddrinfo,
|
|
||||||
-uretprobe:/lib/x86_64-linux-gnu/libc.so.6:gethostbyname,
|
|
||||||
-uretprobe:/lib/x86_64-linux-gnu/libc.so.6:gethostbyname2
|
|
||||||
+uretprobe:/lib64/libc.so.6:getaddrinfo,
|
|
||||||
+uretprobe:/lib64/libc.so.6:gethostbyname,
|
|
||||||
+uretprobe:/lib64/libc.so.6:gethostbyname2
|
|
||||||
/@start[tid]/
|
|
||||||
{
|
|
||||||
$latms = (nsecs - @start[tid]) / 1e6;
|
|
||||||
diff --git a/tools/threadsnoop.bt b/tools/threadsnoop.bt
|
|
||||||
index 3824bc6d..ab52bc48 100755
|
|
||||||
--- a/tools/threadsnoop.bt
|
|
||||||
+++ b/tools/threadsnoop.bt
|
|
||||||
@@ -18,7 +18,7 @@ BEGIN
|
|
||||||
printf("%-10s %-6s %-16s %s\n", "TIME(ms)", "PID", "COMM", "FUNC");
|
|
||||||
}
|
|
||||||
|
|
||||||
-uprobe:/lib/x86_64-linux-gnu/libpthread.so.0:pthread_create
|
|
||||||
+uprobe:/usr/lib64/libpthread.so.0:pthread_create
|
|
||||||
{
|
|
||||||
printf("%-10u %-6d %-16s %s\n", elapsed / 1e6, pid, comm,
|
|
||||||
usym(arg2));
|
|
||||||
--
|
|
||||||
2.35.3
|
|
||||||
|
|
@ -1,129 +0,0 @@
|
|||||||
From 44fab4dd2201ee4a470248b4e3f8b2aa51c90a53 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Khem Raj <raj.khem@gmail.com>
|
|
||||||
Date: Sat, 4 Sep 2021 17:28:17 -0700
|
|
||||||
Subject: [PATCH 2/6] orc: Fix build with clang >= 13
|
|
||||||
|
|
||||||
Fixes errors like
|
|
||||||
src/ast/bpforc/bpforcv2.cpp:3:9: error: constructor for 'bpftrace::BpfOrc' must explicitly initialize the member 'ES' which does not have a default constructor
|
|
||||||
BpfOrc::BpfOrc(TargetMachine *TM, DataLayout DL)
|
|
||||||
^
|
|
||||||
|
|
||||||
Fixes https://github.com/iovisor/bpftrace/issues/1963
|
|
||||||
|
|
||||||
Signed-off-by: Khem Raj <raj.khem@gmail.com>
|
|
||||||
---
|
|
||||||
src/bpforc.h | 23 ++++++++++++++++++++++-
|
|
||||||
src/bpforcv2.cpp | 23 +++++++++++++++--------
|
|
||||||
2 files changed, 37 insertions(+), 9 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/bpforc.h b/src/bpforc.h
|
|
||||||
index c333a651..cc6a1c97 100644
|
|
||||||
--- a/src/bpforc.h
|
|
||||||
+++ b/src/bpforc.h
|
|
||||||
@@ -20,6 +20,9 @@
|
|
||||||
#ifdef LLVM_ORC_V2
|
|
||||||
#include <llvm/ExecutionEngine/Orc/Core.h>
|
|
||||||
#include <llvm/ExecutionEngine/Orc/JITTargetMachineBuilder.h>
|
|
||||||
+#if LLVM_VERSION_MAJOR >= 13
|
|
||||||
+#include <llvm/ExecutionEngine/Orc/ExecutorProcessControl.h>
|
|
||||||
+#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <optional>
|
|
||||||
@@ -71,8 +74,12 @@ class BpfOrc
|
|
||||||
std::unique_ptr<TargetMachine> TM;
|
|
||||||
DataLayout DL;
|
|
||||||
#if LLVM_VERSION_MAJOR >= 7
|
|
||||||
+#ifdef LLVM_ORC_V2
|
|
||||||
+ std::unique_ptr<ExecutionSession> ES;
|
|
||||||
+#else // LLVM_ORC_V1
|
|
||||||
ExecutionSession ES;
|
|
||||||
#endif
|
|
||||||
+#endif
|
|
||||||
#if LLVM_VERSION_MAJOR >= 7 && LLVM_VERSION_MAJOR < 12
|
|
||||||
std::shared_ptr<SymbolResolver> Resolver;
|
|
||||||
#endif
|
|
||||||
@@ -97,7 +104,21 @@ class BpfOrc
|
|
||||||
#endif
|
|
||||||
|
|
||||||
public:
|
|
||||||
+#if LLVM_VERSION_MAJOR >= 13
|
|
||||||
+ ~BpfOrc()
|
|
||||||
+ {
|
|
||||||
+ if (auto Err = ES->endSession())
|
|
||||||
+ ES->reportError(std::move(Err));
|
|
||||||
+ }
|
|
||||||
+#endif
|
|
||||||
+#ifdef LLVM_ORC_V2
|
|
||||||
+ BpfOrc(TargetMachine *TM,
|
|
||||||
+ DataLayout DL,
|
|
||||||
+ std::unique_ptr<ExecutionSession> ES);
|
|
||||||
+#else
|
|
||||||
BpfOrc(TargetMachine *TM, DataLayout DL);
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
void compile(std::unique_ptr<Module> M);
|
|
||||||
|
|
||||||
/* Helper for creating a orc object, responsible for creating internal objects
|
|
||||||
@@ -130,7 +151,7 @@ class BpfOrc
|
|
||||||
#ifdef LLVM_ORC_V2
|
|
||||||
Expected<JITEvaluatedSymbol> lookup(StringRef Name)
|
|
||||||
{
|
|
||||||
- return ES.lookup({ &MainJD }, Mangle(Name.str()));
|
|
||||||
+ return ES->lookup({ &MainJD }, Mangle(Name.str()));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
diff --git a/src/bpforcv2.cpp b/src/bpforcv2.cpp
|
|
||||||
index 9876625b..3e6684e4 100644
|
|
||||||
--- a/src/bpforcv2.cpp
|
|
||||||
+++ b/src/bpforcv2.cpp
|
|
||||||
@@ -1,21 +1,23 @@
|
|
||||||
// Included by bpforc.cpp
|
|
||||||
|
|
||||||
-BpfOrc::BpfOrc(TargetMachine *TM, DataLayout DL)
|
|
||||||
+BpfOrc::BpfOrc(TargetMachine *TM,
|
|
||||||
+ DataLayout DL,
|
|
||||||
+ std::unique_ptr<ExecutionSession> ES)
|
|
||||||
: TM(std::move(TM)),
|
|
||||||
DL(std::move(DL)),
|
|
||||||
- ObjectLayer(ES,
|
|
||||||
+ ES(std::move(ES)),
|
|
||||||
+ ObjectLayer(*(this->ES),
|
|
||||||
[this]() {
|
|
||||||
return std::make_unique<MemoryManager>(sections_);
|
|
||||||
}),
|
|
||||||
- CompileLayer(ES,
|
|
||||||
+ CompileLayer(*this->ES,
|
|
||||||
ObjectLayer,
|
|
||||||
std::make_unique<SimpleCompiler>(*this->TM)),
|
|
||||||
- Mangle(ES, this->DL),
|
|
||||||
+ Mangle(*this->ES, this->DL),
|
|
||||||
CTX(std::make_unique<LLVMContext>()),
|
|
||||||
- MainJD(cantFail(ES.createJITDylib("<main>")))
|
|
||||||
+ MainJD(cantFail(this->ES->createJITDylib("<main>")))
|
|
||||||
{
|
|
||||||
}
|
|
||||||
-
|
|
||||||
LLVMContext &BpfOrc::getContext()
|
|
||||||
{
|
|
||||||
return *CTX.getContext();
|
|
||||||
@@ -34,8 +36,13 @@ std::unique_ptr<BpfOrc> BpfOrc::Create()
|
|
||||||
// return unique_ptrs
|
|
||||||
auto DL = cantFail(JTMB.getDefaultDataLayoutForTarget());
|
|
||||||
auto TM = cantFail(JTMB.createTargetMachine());
|
|
||||||
-
|
|
||||||
- return std::make_unique<BpfOrc>(TM.release(), std::move(DL));
|
|
||||||
+#if LLVM_VERSION_MAJOR >= 13
|
|
||||||
+ auto EPC = SelfExecutorProcessControl::Create();
|
|
||||||
+ auto ES = std::make_unique<ExecutionSession>(std::move(*EPC));
|
|
||||||
+#else
|
|
||||||
+ auto ES = std::make_unique<ExecutionSession>();
|
|
||||||
+#endif
|
|
||||||
+ return std::make_unique<BpfOrc>(TM.release(), std::move(DL), std::move(ES));
|
|
||||||
}
|
|
||||||
|
|
||||||
void BpfOrc::compile(std::unique_ptr<Module> M)
|
|
||||||
--
|
|
||||||
2.35.3
|
|
||||||
|
|
@ -0,0 +1,457 @@
|
|||||||
|
From dfc1f92653707c8d11bdb3be98e68f8297b9bc71 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Viktor Malik <viktor.malik@gmail.com>
|
||||||
|
Date: Mon, 10 Oct 2022 14:26:38 +0200
|
||||||
|
Subject: [PATCH] IR builder: get rid of getPointerElementType calls
|
||||||
|
|
||||||
|
Usage of Value::getPointerElementType is deprecated and will be dropped
|
||||||
|
in LLVM 16 [1].
|
||||||
|
|
||||||
|
There are several places where we use this method:
|
||||||
|
- function (value) calls - the called function type is usually
|
||||||
|
available, so just pass it to createCall, the only exception is
|
||||||
|
CreateProbeReadStr which must have been refactored
|
||||||
|
- getting the type of alloca instruction - there is a dedicated
|
||||||
|
AllocaInst::getAllocatedType method that can be used instead
|
||||||
|
- strncmp - pass sizes of the strings to CreateStrncmp to be able to get
|
||||||
|
the correct string type (which is array of uint8)
|
||||||
|
|
||||||
|
[1] https://llvm.org/docs/OpaquePointers.html
|
||||||
|
---
|
||||||
|
src/ast/irbuilderbpf.cpp | 143 ++++++++++++--------------------
|
||||||
|
src/ast/irbuilderbpf.h | 23 +++--
|
||||||
|
src/ast/passes/codegen_llvm.cpp | 30 +++++--
|
||||||
|
3 files changed, 86 insertions(+), 110 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/ast/irbuilderbpf.cpp b/src/ast/irbuilderbpf.cpp
|
||||||
|
index d49883f7..4036b2df 100644
|
||||||
|
--- a/src/ast/irbuilderbpf.cpp
|
||||||
|
+++ b/src/ast/irbuilderbpf.cpp
|
||||||
|
@@ -288,17 +288,16 @@ CallInst *IRBuilderBPF::CreateHelperCall(libbpf::bpf_func_id func_id,
|
||||||
|
Constant *helper_func = ConstantExpr::getCast(Instruction::IntToPtr,
|
||||||
|
getInt64(func_id),
|
||||||
|
helper_ptr_type);
|
||||||
|
- return createCall(helper_func, args, Name);
|
||||||
|
+ return createCall(helper_type, helper_func, args, Name);
|
||||||
|
}
|
||||||
|
|
||||||
|
-CallInst *IRBuilderBPF::createCall(Value *callee,
|
||||||
|
+CallInst *IRBuilderBPF::createCall(FunctionType *callee_type,
|
||||||
|
+ Value *callee,
|
||||||
|
ArrayRef<Value *> args,
|
||||||
|
const Twine &Name)
|
||||||
|
{
|
||||||
|
#if LLVM_VERSION_MAJOR >= 11
|
||||||
|
- auto *calleePtrType = cast<PointerType>(callee->getType());
|
||||||
|
- auto *calleeType = cast<FunctionType>(calleePtrType->getPointerElementType());
|
||||||
|
- return CreateCall(calleeType, callee, args, Name);
|
||||||
|
+ return CreateCall(callee_type, callee, args, Name);
|
||||||
|
#else
|
||||||
|
return CreateCall(callee, args, Name);
|
||||||
|
#endif
|
||||||
|
@@ -307,7 +306,7 @@ CallInst *IRBuilderBPF::createCall(Value *callee,
|
||||||
|
CallInst *IRBuilderBPF::CreateBpfPseudoCallId(int mapid)
|
||||||
|
{
|
||||||
|
Function *pseudo_func = module_.getFunction("llvm.bpf.pseudo");
|
||||||
|
- return createCall(pseudo_func,
|
||||||
|
+ return CreateCall(pseudo_func,
|
||||||
|
{ getInt64(BPF_PSEUDO_MAP_FD), getInt64(mapid) },
|
||||||
|
"pseudo");
|
||||||
|
}
|
||||||
|
@@ -346,7 +345,8 @@ CallInst *IRBuilderBPF::createMapLookup(int mapid, Value *key)
|
||||||
|
Instruction::IntToPtr,
|
||||||
|
getInt64(libbpf::BPF_FUNC_map_lookup_elem),
|
||||||
|
lookup_func_ptr_type);
|
||||||
|
- return createCall(lookup_func, { map_ptr, key }, "lookup_elem");
|
||||||
|
+ return createCall(
|
||||||
|
+ lookup_func_type, lookup_func, { map_ptr, key }, "lookup_elem");
|
||||||
|
}
|
||||||
|
|
||||||
|
CallInst *IRBuilderBPF::CreateGetJoinMap(Value *ctx, const location &loc)
|
||||||
|
@@ -397,8 +397,7 @@ Value *IRBuilderBPF::CreateMapLookupElem(Value *ctx,
|
||||||
|
CREATE_MEMCPY(value, call, type.GetSize(), 1);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
- assert(value->getType()->isPointerTy() &&
|
||||||
|
- (value->getType()->getPointerElementType() == getInt64Ty()));
|
||||||
|
+ assert(value->getAllocatedType() == getInt64Ty());
|
||||||
|
// createMapLookup returns an u8*
|
||||||
|
auto *cast = CreatePointerCast(call, value->getType(), "cast");
|
||||||
|
CreateStore(CreateLoad(getInt64Ty(), cast), value);
|
||||||
|
@@ -448,7 +447,8 @@ void IRBuilderBPF::CreateMapUpdateElem(Value *ctx,
|
||||||
|
Instruction::IntToPtr,
|
||||||
|
getInt64(libbpf::BPF_FUNC_map_update_elem),
|
||||||
|
update_func_ptr_type);
|
||||||
|
- CallInst *call = createCall(update_func,
|
||||||
|
+ CallInst *call = createCall(update_func_type,
|
||||||
|
+ update_func,
|
||||||
|
{ map_ptr, key, val, flags },
|
||||||
|
"update_elem");
|
||||||
|
CreateHelperErrorCond(ctx, call, libbpf::BPF_FUNC_map_update_elem, loc);
|
||||||
|
@@ -472,7 +472,8 @@ void IRBuilderBPF::CreateMapDeleteElem(Value *ctx,
|
||||||
|
Instruction::IntToPtr,
|
||||||
|
getInt64(libbpf::BPF_FUNC_map_delete_elem),
|
||||||
|
delete_func_ptr_type);
|
||||||
|
- CallInst *call = createCall(delete_func, { map_ptr, key }, "delete_elem");
|
||||||
|
+ CallInst *call = createCall(
|
||||||
|
+ delete_func_type, delete_func, { map_ptr, key }, "delete_elem");
|
||||||
|
CreateHelperErrorCond(ctx, call, libbpf::BPF_FUNC_map_delete_elem, loc);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -508,72 +509,53 @@ void IRBuilderBPF::CreateProbeRead(Value *ctx,
|
||||||
|
Constant *proberead_func = ConstantExpr::getCast(Instruction::IntToPtr,
|
||||||
|
getInt64(read_fn),
|
||||||
|
proberead_func_ptr_type);
|
||||||
|
- CallInst *call = createCall(proberead_func,
|
||||||
|
+ CallInst *call = createCall(proberead_func_type,
|
||||||
|
+ proberead_func,
|
||||||
|
{ dst, size, src },
|
||||||
|
probeReadHelperName(read_fn));
|
||||||
|
CreateHelperErrorCond(ctx, call, read_fn, loc);
|
||||||
|
}
|
||||||
|
|
||||||
|
-Constant *IRBuilderBPF::createProbeReadStrFn(llvm::Type *dst,
|
||||||
|
- llvm::Type *src,
|
||||||
|
- AddrSpace as)
|
||||||
|
-{
|
||||||
|
- assert(src && (src->isIntegerTy() || src->isPointerTy()));
|
||||||
|
- // int bpf_probe_read_str(void *dst, int size, const void *unsafe_ptr)
|
||||||
|
- FunctionType *probereadstr_func_type = FunctionType::get(
|
||||||
|
- getInt64Ty(), { dst, getInt32Ty(), src }, false);
|
||||||
|
- PointerType *probereadstr_func_ptr_type = PointerType::get(
|
||||||
|
- probereadstr_func_type, 0);
|
||||||
|
- return ConstantExpr::getCast(Instruction::IntToPtr,
|
||||||
|
- getInt64(selectProbeReadHelper(as, true)),
|
||||||
|
- probereadstr_func_ptr_type);
|
||||||
|
-}
|
||||||
|
-
|
||||||
|
CallInst *IRBuilderBPF::CreateProbeReadStr(Value *ctx,
|
||||||
|
- AllocaInst *dst,
|
||||||
|
+ Value *dst,
|
||||||
|
size_t size,
|
||||||
|
Value *src,
|
||||||
|
AddrSpace as,
|
||||||
|
const location &loc)
|
||||||
|
{
|
||||||
|
- assert(ctx && ctx->getType() == getInt8PtrTy());
|
||||||
|
return CreateProbeReadStr(ctx, dst, getInt32(size), src, as, loc);
|
||||||
|
}
|
||||||
|
|
||||||
|
CallInst *IRBuilderBPF::CreateProbeReadStr(Value *ctx,
|
||||||
|
Value *dst,
|
||||||
|
- size_t size,
|
||||||
|
- Value *src,
|
||||||
|
- AddrSpace as,
|
||||||
|
- const location &loc)
|
||||||
|
-{
|
||||||
|
- assert(ctx && ctx->getType() == getInt8PtrTy());
|
||||||
|
- Constant *fn = createProbeReadStrFn(dst->getType(), src->getType(), as);
|
||||||
|
- auto read_fn = selectProbeReadHelper(as, true);
|
||||||
|
- CallInst *call = createCall(fn,
|
||||||
|
- { dst, getInt32(size), src },
|
||||||
|
- probeReadHelperName(read_fn));
|
||||||
|
- CreateHelperErrorCond(ctx, call, read_fn, loc);
|
||||||
|
- return call;
|
||||||
|
-}
|
||||||
|
-
|
||||||
|
-CallInst *IRBuilderBPF::CreateProbeReadStr(Value *ctx,
|
||||||
|
- AllocaInst *dst,
|
||||||
|
llvm::Value *size,
|
||||||
|
Value *src,
|
||||||
|
AddrSpace as,
|
||||||
|
const location &loc)
|
||||||
|
{
|
||||||
|
assert(ctx && ctx->getType() == getInt8PtrTy());
|
||||||
|
- assert(dst && dst->getAllocatedType()->isArrayTy() &&
|
||||||
|
- dst->getAllocatedType()->getArrayElementType() == getInt8Ty());
|
||||||
|
assert(size && size->getType()->isIntegerTy());
|
||||||
|
+ if (auto *dst_alloca = dyn_cast<AllocaInst>(dst))
|
||||||
|
+ {
|
||||||
|
+ assert(dst_alloca->getAllocatedType()->isArrayTy() &&
|
||||||
|
+ dst_alloca->getAllocatedType()->getArrayElementType() ==
|
||||||
|
+ getInt8Ty());
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- auto *size_i32 = CreateIntCast(size, getInt32Ty(), false);
|
||||||
|
+ auto *size_i32 = size;
|
||||||
|
+ if (size_i32->getType()->getScalarSizeInBits() != 32)
|
||||||
|
+ size_i32 = CreateIntCast(size_i32, getInt32Ty(), false);
|
||||||
|
|
||||||
|
- Constant *fn = createProbeReadStrFn(dst->getType(), src->getType(), as);
|
||||||
|
auto read_fn = selectProbeReadHelper(as, true);
|
||||||
|
- CallInst *call = createCall(fn,
|
||||||
|
+ // int bpf_probe_read_str(void *dst, int size, const void *unsafe_ptr)
|
||||||
|
+ FunctionType *probereadstr_func_type = FunctionType::get(
|
||||||
|
+ getInt64Ty(), { dst->getType(), getInt32Ty(), src->getType() }, false);
|
||||||
|
+ PointerType *probereadstr_func_ptr_type = PointerType::get(
|
||||||
|
+ probereadstr_func_type, 0);
|
||||||
|
+ Constant *probereadstr_callee = ConstantExpr::getCast(
|
||||||
|
+ Instruction::IntToPtr, getInt64(read_fn), probereadstr_func_ptr_type);
|
||||||
|
+ CallInst *call = createCall(probereadstr_func_type,
|
||||||
|
+ probereadstr_callee,
|
||||||
|
{ dst, size_i32, src },
|
||||||
|
probeReadHelperName(read_fn));
|
||||||
|
CreateHelperErrorCond(ctx, call, read_fn, loc);
|
||||||
|
@@ -732,8 +714,10 @@ Value *IRBuilderBPF::CreateUSDTReadArgument(Value *ctx,
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
-Value *IRBuilderBPF::CreateStrncmp(Value *val1,
|
||||||
|
- Value *val2,
|
||||||
|
+Value *IRBuilderBPF::CreateStrncmp(Value *str1,
|
||||||
|
+ uint64_t str1_size,
|
||||||
|
+ Value *str2,
|
||||||
|
+ uint64_t str2_size,
|
||||||
|
uint64_t n,
|
||||||
|
bool inverse)
|
||||||
|
{
|
||||||
|
@@ -762,40 +746,21 @@ Value *IRBuilderBPF::CreateStrncmp(Value *val1,
|
||||||
|
// Check if the compared strings are literals.
|
||||||
|
// If so, we can avoid storing the literal in memory.
|
||||||
|
std::optional<std::string> literal1;
|
||||||
|
- if (auto constString1 = dyn_cast<ConstantDataArray>(val1))
|
||||||
|
+ if (auto constString1 = dyn_cast<ConstantDataArray>(str1))
|
||||||
|
literal1 = constString1->getAsString();
|
||||||
|
- else if (isa<ConstantAggregateZero>(val1))
|
||||||
|
+ else if (isa<ConstantAggregateZero>(str1))
|
||||||
|
literal1 = "";
|
||||||
|
else
|
||||||
|
literal1 = std::nullopt;
|
||||||
|
|
||||||
|
std::optional<std::string> literal2;
|
||||||
|
- if (auto constString2 = dyn_cast<ConstantDataArray>(val2))
|
||||||
|
+ if (auto constString2 = dyn_cast<ConstantDataArray>(str2))
|
||||||
|
literal2 = constString2->getAsString();
|
||||||
|
- else if (isa<ConstantAggregateZero>(val2))
|
||||||
|
+ else if (isa<ConstantAggregateZero>(str2))
|
||||||
|
literal2 = "";
|
||||||
|
else
|
||||||
|
literal2 = std::nullopt;
|
||||||
|
|
||||||
|
- auto *val1p = dyn_cast<PointerType>(val1->getType());
|
||||||
|
- auto *val2p = dyn_cast<PointerType>(val2->getType());
|
||||||
|
-#ifndef NDEBUG
|
||||||
|
- if (!literal1)
|
||||||
|
- {
|
||||||
|
- assert(val1p);
|
||||||
|
- assert(val1p->getPointerElementType()->isArrayTy() &&
|
||||||
|
- val1p->getPointerElementType()->getArrayElementType() ==
|
||||||
|
- getInt8Ty());
|
||||||
|
- }
|
||||||
|
- if (!literal2)
|
||||||
|
- {
|
||||||
|
- assert(val2p);
|
||||||
|
- assert(val2p->getPointerElementType()->isArrayTy() &&
|
||||||
|
- val2p->getPointerElementType()->getArrayElementType() ==
|
||||||
|
- getInt8Ty());
|
||||||
|
- }
|
||||||
|
-#endif
|
||||||
|
-
|
||||||
|
Function *parent = GetInsertBlock()->getParent();
|
||||||
|
AllocaInst *store = CreateAllocaBPF(getInt1Ty(), "strcmp.result");
|
||||||
|
BasicBlock *str_ne = BasicBlock::Create(module_.getContext(),
|
||||||
|
@@ -822,8 +787,8 @@ Value *IRBuilderBPF::CreateStrncmp(Value *val1,
|
||||||
|
l = getInt8(literal1->c_str()[i]);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
- auto *ptr_l = CreateGEP(val1p->getPointerElementType(),
|
||||||
|
- val1,
|
||||||
|
+ auto *ptr_l = CreateGEP(ArrayType::get(getInt8Ty(), str1_size),
|
||||||
|
+ str1,
|
||||||
|
{ getInt32(0), getInt32(i) });
|
||||||
|
l = CreateLoad(getInt8Ty(), ptr_l);
|
||||||
|
}
|
||||||
|
@@ -833,8 +798,8 @@ Value *IRBuilderBPF::CreateStrncmp(Value *val1,
|
||||||
|
r = getInt8(literal2->c_str()[i]);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
- auto *ptr_r = CreateGEP(val2p->getPointerElementType(),
|
||||||
|
- val2,
|
||||||
|
+ auto *ptr_r = CreateGEP(ArrayType::get(getInt8Ty(), str2_size),
|
||||||
|
+ str2,
|
||||||
|
{ getInt32(0), getInt32(i) });
|
||||||
|
r = CreateLoad(getInt8Ty(), ptr_r);
|
||||||
|
}
|
||||||
|
@@ -994,11 +959,9 @@ void IRBuilderBPF::CreateGetCurrentComm(Value *ctx,
|
||||||
|
size_t size,
|
||||||
|
const location &loc)
|
||||||
|
{
|
||||||
|
- assert(buf->getType()->getPointerElementType()->isArrayTy() &&
|
||||||
|
- buf->getType()->getPointerElementType()->getArrayNumElements() >=
|
||||||
|
- size &&
|
||||||
|
- buf->getType()->getPointerElementType()->getArrayElementType() ==
|
||||||
|
- getInt8Ty());
|
||||||
|
+ assert(buf->getAllocatedType()->isArrayTy() &&
|
||||||
|
+ buf->getAllocatedType()->getArrayNumElements() >= size &&
|
||||||
|
+ buf->getAllocatedType()->getArrayElementType() == getInt8Ty());
|
||||||
|
|
||||||
|
// long bpf_get_current_comm(char *buf, int size_of_buf)
|
||||||
|
// Return: 0 on success or negative error
|
||||||
|
@@ -1077,7 +1040,7 @@ void IRBuilderBPF::CreateSignal(Value *ctx, Value *sig, const location &loc)
|
||||||
|
Instruction::IntToPtr,
|
||||||
|
getInt64(libbpf::BPF_FUNC_send_signal),
|
||||||
|
signal_func_ptr_type);
|
||||||
|
- CallInst *call = createCall(signal_func, { sig }, "signal");
|
||||||
|
+ CallInst *call = createCall(signal_func_type, signal_func, { sig }, "signal");
|
||||||
|
CreateHelperErrorCond(ctx, call, libbpf::BPF_FUNC_send_signal, loc);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -1091,7 +1054,7 @@ void IRBuilderBPF::CreateOverrideReturn(Value *ctx, Value *rc)
|
||||||
|
Constant *override_func = ConstantExpr::getCast(Instruction::IntToPtr,
|
||||||
|
getInt64(libbpf::BPF_FUNC_override_return),
|
||||||
|
override_func_ptr_type);
|
||||||
|
- createCall(override_func, { ctx, rc }, "override");
|
||||||
|
+ createCall(override_func_type, override_func, { ctx, rc }, "override");
|
||||||
|
}
|
||||||
|
|
||||||
|
CallInst *IRBuilderBPF::CreateSkbOutput(Value *skb,
|
||||||
|
@@ -1126,7 +1089,8 @@ CallInst *IRBuilderBPF::CreateSkbOutput(Value *skb,
|
||||||
|
Instruction::IntToPtr,
|
||||||
|
getInt64(libbpf::BPF_FUNC_skb_output),
|
||||||
|
skb_output_func_ptr_type);
|
||||||
|
- CallInst *call = createCall(skb_output_func,
|
||||||
|
+ CallInst *call = createCall(skb_output_func_type,
|
||||||
|
+ skb_output_func,
|
||||||
|
{ skb, map_ptr, flags, data, size_val },
|
||||||
|
"skb_output");
|
||||||
|
return call;
|
||||||
|
@@ -1320,7 +1284,8 @@ void IRBuilderBPF::CreateSeqPrintf(Value *ctx,
|
||||||
|
CreateGEP(getInt64Ty(), meta, getInt64(0)),
|
||||||
|
"seq");
|
||||||
|
|
||||||
|
- CallInst *call = createCall(seq_printf_func,
|
||||||
|
+ CallInst *call = createCall(seq_printf_func_type,
|
||||||
|
+ seq_printf_func,
|
||||||
|
{ seq, fmt, fmt_size, data, data_len },
|
||||||
|
"seq_printf");
|
||||||
|
CreateHelperErrorCond(ctx, call, libbpf::BPF_FUNC_seq_printf, loc);
|
||||||
|
diff --git a/src/ast/irbuilderbpf.h b/src/ast/irbuilderbpf.h
|
||||||
|
index e124911b..c9ffb545 100644
|
||||||
|
--- a/src/ast/irbuilderbpf.h
|
||||||
|
+++ b/src/ast/irbuilderbpf.h
|
||||||
|
@@ -90,17 +90,11 @@ public:
|
||||||
|
AddrSpace as,
|
||||||
|
const location &loc);
|
||||||
|
CallInst *CreateProbeReadStr(Value *ctx,
|
||||||
|
- AllocaInst *dst,
|
||||||
|
+ Value *dst,
|
||||||
|
llvm::Value *size,
|
||||||
|
Value *src,
|
||||||
|
AddrSpace as,
|
||||||
|
const location &loc);
|
||||||
|
- CallInst *CreateProbeReadStr(Value *ctx,
|
||||||
|
- AllocaInst *dst,
|
||||||
|
- size_t size,
|
||||||
|
- Value *src,
|
||||||
|
- AddrSpace as,
|
||||||
|
- const location &loc);
|
||||||
|
CallInst *CreateProbeReadStr(Value *ctx,
|
||||||
|
Value *dst,
|
||||||
|
size_t size,
|
||||||
|
@@ -115,7 +109,12 @@ public:
|
||||||
|
pid_t pid,
|
||||||
|
AddrSpace as,
|
||||||
|
const location &loc);
|
||||||
|
- Value *CreateStrncmp(Value *val1, Value *val2, uint64_t n, bool inverse);
|
||||||
|
+ Value *CreateStrncmp(Value *str1,
|
||||||
|
+ uint64_t str1_size,
|
||||||
|
+ Value *str2,
|
||||||
|
+ uint64_t str2_size,
|
||||||
|
+ uint64_t n,
|
||||||
|
+ bool inverse);
|
||||||
|
CallInst *CreateGetNs(bool boot_time, const location &loc);
|
||||||
|
CallInst *CreateGetPidTgid(const location &loc);
|
||||||
|
CallInst *CreateGetCurrentCgroupId(const location &loc);
|
||||||
|
@@ -131,7 +130,10 @@ public:
|
||||||
|
ArrayRef<Value *> args,
|
||||||
|
const Twine &Name,
|
||||||
|
const location *loc = nullptr);
|
||||||
|
- CallInst *createCall(Value *callee, ArrayRef<Value *> args, const Twine &Name);
|
||||||
|
+ CallInst *createCall(FunctionType *callee_type,
|
||||||
|
+ Value *callee,
|
||||||
|
+ ArrayRef<Value *> args,
|
||||||
|
+ const Twine &Name);
|
||||||
|
void CreateGetCurrentComm(Value *ctx, AllocaInst *buf, size_t size, const location& loc);
|
||||||
|
void CreatePerfEventOutput(Value *ctx,
|
||||||
|
Value *data,
|
||||||
|
@@ -185,9 +187,6 @@ private:
|
||||||
|
AddrSpace as,
|
||||||
|
const location &loc);
|
||||||
|
CallInst *createMapLookup(int mapid, Value *key);
|
||||||
|
- Constant *createProbeReadStrFn(llvm::Type *dst,
|
||||||
|
- llvm::Type *src,
|
||||||
|
- AddrSpace as);
|
||||||
|
libbpf::bpf_func_id selectProbeReadHelper(AddrSpace as, bool str);
|
||||||
|
|
||||||
|
std::map<std::string, StructType *> structs_;
|
||||||
|
diff --git a/src/ast/passes/codegen_llvm.cpp b/src/ast/passes/codegen_llvm.cpp
|
||||||
|
index a818ca0b..2b888087 100644
|
||||||
|
--- a/src/ast/passes/codegen_llvm.cpp
|
||||||
|
+++ b/src/ast/passes/codegen_llvm.cpp
|
||||||
|
@@ -1133,8 +1133,12 @@ void CodegenLLVM::visit(Call &call)
|
||||||
|
auto left_string = getString(left_arg);
|
||||||
|
auto right_string = getString(right_arg);
|
||||||
|
|
||||||
|
- expr_ = b_.CreateStrncmp(
|
||||||
|
- left_string.first, right_string.first, size, false);
|
||||||
|
+ expr_ = b_.CreateStrncmp(left_string.first,
|
||||||
|
+ left_string.second,
|
||||||
|
+ right_string.first,
|
||||||
|
+ right_string.second,
|
||||||
|
+ size,
|
||||||
|
+ false);
|
||||||
|
}
|
||||||
|
else if (call.func == "override")
|
||||||
|
{
|
||||||
|
@@ -1269,8 +1273,7 @@ void CodegenLLVM::visit(Variable &var)
|
||||||
|
else
|
||||||
|
{
|
||||||
|
auto *var_alloca = variables_[var.ident];
|
||||||
|
- expr_ = b_.CreateLoad(var_alloca->getType()->getPointerElementType(),
|
||||||
|
- var_alloca);
|
||||||
|
+ expr_ = b_.CreateLoad(var_alloca->getAllocatedType(), var_alloca);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -1310,7 +1313,12 @@ void CodegenLLVM::binop_string(Binop &binop)
|
||||||
|
auto right_string = getString(binop.right);
|
||||||
|
|
||||||
|
size_t len = std::min(left_string.second, right_string.second);
|
||||||
|
- expr_ = b_.CreateStrncmp(left_string.first, right_string.first, len, inverse);
|
||||||
|
+ expr_ = b_.CreateStrncmp(left_string.first,
|
||||||
|
+ left_string.second,
|
||||||
|
+ right_string.first,
|
||||||
|
+ right_string.second,
|
||||||
|
+ len,
|
||||||
|
+ inverse);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CodegenLLVM::binop_buf(Binop &binop)
|
||||||
|
@@ -1334,7 +1342,12 @@ void CodegenLLVM::binop_buf(Binop &binop)
|
||||||
|
|
||||||
|
size_t len = std::min(binop.left->type.GetSize(),
|
||||||
|
binop.right->type.GetSize());
|
||||||
|
- expr_ = b_.CreateStrncmp(left_string, right_string, len, inverse);
|
||||||
|
+ expr_ = b_.CreateStrncmp(left_string,
|
||||||
|
+ binop.left->type.GetSize(),
|
||||||
|
+ right_string,
|
||||||
|
+ binop.right->type.GetSize(),
|
||||||
|
+ len,
|
||||||
|
+ inverse);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CodegenLLVM::binop_int(Binop &binop)
|
||||||
|
@@ -3528,9 +3541,8 @@ void CodegenLLVM::createIncDec(Unop &unop)
|
||||||
|
else if (unop.expr->is_variable)
|
||||||
|
{
|
||||||
|
Variable &var = static_cast<Variable &>(*unop.expr);
|
||||||
|
- Value *oldval = b_.CreateLoad(
|
||||||
|
- variables_[var.ident]->getType()->getPointerElementType(),
|
||||||
|
- variables_[var.ident]);
|
||||||
|
+ Value *oldval = b_.CreateLoad(variables_[var.ident]->getAllocatedType(),
|
||||||
|
+ variables_[var.ident]);
|
||||||
|
Value *newval;
|
||||||
|
if (is_increment)
|
||||||
|
newval = b_.CreateAdd(oldval, b_.GetIntSameSize(step, oldval));
|
||||||
|
--
|
||||||
|
2.38.1
|
||||||
|
|
@ -0,0 +1,82 @@
|
|||||||
|
From 7e813d0e3048f52781199384a120f5e5cbad22ae Mon Sep 17 00:00:00 2001
|
||||||
|
From: Viktor Malik <viktor.malik@gmail.com>
|
||||||
|
Date: Mon, 5 Dec 2022 13:31:25 +0100
|
||||||
|
Subject: [PATCH] RHEL8: remove not existing attachpoints from tools
|
||||||
|
|
||||||
|
tools/bio* attempt to attach each probe to multiple kprobes to cover all
|
||||||
|
possible systems. Remove probes which do not exist in RHEL8 to remove
|
||||||
|
unnecessary warnings.
|
||||||
|
---
|
||||||
|
tools/biolatency.bt | 6 ++----
|
||||||
|
tools/biostacks.bt | 4 +---
|
||||||
|
tools/old/biosnoop.bt | 6 ++----
|
||||||
|
3 files changed, 5 insertions(+), 11 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/tools/biolatency.bt b/tools/biolatency.bt
|
||||||
|
index d5af1f29..4ea910b4 100755
|
||||||
|
--- a/tools/biolatency.bt
|
||||||
|
+++ b/tools/biolatency.bt
|
||||||
|
@@ -16,14 +16,12 @@ BEGIN
|
||||||
|
printf("Tracing block device I/O... Hit Ctrl-C to end.\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
-kprobe:blk_account_io_start,
|
||||||
|
-kprobe:__blk_account_io_start
|
||||||
|
+kprobe:blk_account_io_start
|
||||||
|
{
|
||||||
|
@start[arg0] = nsecs;
|
||||||
|
}
|
||||||
|
|
||||||
|
-kprobe:blk_account_io_done,
|
||||||
|
-kprobe:__blk_account_io_done
|
||||||
|
+kprobe:blk_account_io_done
|
||||||
|
/@start[arg0]/
|
||||||
|
{
|
||||||
|
@usecs = hist((nsecs - @start[arg0]) / 1000);
|
||||||
|
diff --git a/tools/biostacks.bt b/tools/biostacks.bt
|
||||||
|
index 1bc9f819..80d8cb9e 100755
|
||||||
|
--- a/tools/biostacks.bt
|
||||||
|
+++ b/tools/biostacks.bt
|
||||||
|
@@ -18,14 +18,12 @@ BEGIN
|
||||||
|
printf("Tracing block I/O with init stacks. Hit Ctrl-C to end.\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
-kprobe:blk_account_io_start,
|
||||||
|
-kprobe:__blk_account_io_start
|
||||||
|
+kprobe:blk_account_io_start
|
||||||
|
{
|
||||||
|
@reqstack[arg0] = kstack;
|
||||||
|
@reqts[arg0] = nsecs;
|
||||||
|
}
|
||||||
|
|
||||||
|
-kprobe:blk_start_request,
|
||||||
|
kprobe:blk_mq_start_request
|
||||||
|
/@reqts[arg0]/
|
||||||
|
{
|
||||||
|
diff --git a/tools/old/biosnoop.bt b/tools/old/biosnoop.bt
|
||||||
|
index 1a99643a..327251e3 100755
|
||||||
|
--- a/tools/old/biosnoop.bt
|
||||||
|
+++ b/tools/old/biosnoop.bt
|
||||||
|
@@ -22,8 +22,7 @@ BEGIN
|
||||||
|
printf("%-12s %-7s %-16s %-6s %7s\n", "TIME(ms)", "DISK", "COMM", "PID", "LAT(ms)");
|
||||||
|
}
|
||||||
|
|
||||||
|
-kprobe:blk_account_io_start,
|
||||||
|
-kprobe:__blk_account_io_start
|
||||||
|
+kprobe:blk_account_io_start
|
||||||
|
{
|
||||||
|
@start[arg0] = nsecs;
|
||||||
|
@iopid[arg0] = pid;
|
||||||
|
@@ -31,8 +30,7 @@ kprobe:__blk_account_io_start
|
||||||
|
@disk[arg0] = ((struct request *)arg0)->rq_disk->disk_name;
|
||||||
|
}
|
||||||
|
|
||||||
|
-kprobe:blk_account_io_done,
|
||||||
|
-kprobe:__blk_account_io_done
|
||||||
|
+kprobe:blk_account_io_done
|
||||||
|
/@start[arg0] != 0 && @iopid[arg0] != 0 && @iocomm[arg0] != ""/
|
||||||
|
|
||||||
|
{
|
||||||
|
--
|
||||||
|
2.38.1
|
||||||
|
|
@ -0,0 +1,173 @@
|
|||||||
|
From e661f2a043f8b6548e0bb3e0cc5992d7c0ff3b0f Mon Sep 17 00:00:00 2001
|
||||||
|
From: Rong Tao <rongtao@cestc.cn>
|
||||||
|
Date: Sat, 1 Oct 2022 16:15:27 +0800
|
||||||
|
Subject: [PATCH] tcpdrop: Fix: ERROR: Error attaching probe: 'kprobe:tcp_drop'
|
||||||
|
|
||||||
|
kernel commit 8fbf195798b5('tcp_drop() is no longer needed.') remove
|
||||||
|
the kprobe:tcp_drop, bcc commit 16eab39171eb('Add
|
||||||
|
tracepoint:skb:kfree_skb if no tcp_drop() kprobe.') already fix this
|
||||||
|
problem.
|
||||||
|
|
||||||
|
CI old kernel is too old and not support the 'reason' field, move the
|
||||||
|
old tools/tcpdrop.bt into tools/old/tcpdrop.bt and set the CI to use
|
||||||
|
it.
|
||||||
|
|
||||||
|
Since 5.17 support trace_kfree_skb(skb, ..., reason) 'reason' field.
|
||||||
|
Since 5.19 remove tcp_drop() function.
|
||||||
|
|
||||||
|
ERROR log:
|
||||||
|
|
||||||
|
$ sudo ./tcpdrop.bt
|
||||||
|
./tcpdrop.bt:49-51: WARNING: tcp_drop is not traceable (either non-existing, inlined, or marked as "notrace"); attaching to it will likely fail
|
||||||
|
Attaching 3 probes...
|
||||||
|
cannot attach kprobe, probe entry may not exist
|
||||||
|
ERROR: Error attaching probe: 'kprobe:tcp_drop'
|
||||||
|
|
||||||
|
Link: https://github.com/iovisor/bpftrace/pull/2379
|
||||||
|
Signed-off-by: Rong Tao <rongtao@cestc.cn>
|
||||||
|
---
|
||||||
|
tools/old/tcpdrop.bt | 85 ++++++++++++++++++++++++++++++++++++++++++++
|
||||||
|
tools/tcpdrop.bt | 22 ++++++------
|
||||||
|
2 files changed, 97 insertions(+), 10 deletions(-)
|
||||||
|
create mode 100755 tools/old/tcpdrop.bt
|
||||||
|
|
||||||
|
diff --git a/tools/old/tcpdrop.bt b/tools/old/tcpdrop.bt
|
||||||
|
new file mode 100755
|
||||||
|
index 00000000..685a5f6a
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/tools/old/tcpdrop.bt
|
||||||
|
@@ -0,0 +1,85 @@
|
||||||
|
+#!/usr/bin/env bpftrace
|
||||||
|
+/*
|
||||||
|
+ * tcpdrop.bt Trace TCP kernel-dropped packets/segments.
|
||||||
|
+ * For Linux, uses bpftrace and eBPF.
|
||||||
|
+ *
|
||||||
|
+ * USAGE: tcpdrop.bt
|
||||||
|
+ *
|
||||||
|
+ * This is a bpftrace version of the bcc tool of the same name.
|
||||||
|
+ * It is limited to ipv4 addresses, and cannot show tcp flags.
|
||||||
|
+ *
|
||||||
|
+ * This provides information such as packet details, socket state, and kernel
|
||||||
|
+ * stack trace for packets/segments that were dropped via tcp_drop().
|
||||||
|
+
|
||||||
|
+ * WARNING: this script attaches to the tcp_drop kprobe which is likely inlined
|
||||||
|
+ * on newer kernels and not replaced by anything else, therefore
|
||||||
|
+ * the script will stop working
|
||||||
|
+ *
|
||||||
|
+ * For Linux <= 5.18.
|
||||||
|
+ *
|
||||||
|
+ * Copyright (c) 2018 Dale Hamel.
|
||||||
|
+ * Licensed under the Apache License, Version 2.0 (the "License")
|
||||||
|
+ *
|
||||||
|
+ * 23-Nov-2018 Dale Hamel created this.
|
||||||
|
+ */
|
||||||
|
+
|
||||||
|
+#ifndef BPFTRACE_HAVE_BTF
|
||||||
|
+#include <linux/socket.h>
|
||||||
|
+#include <net/sock.h>
|
||||||
|
+#else
|
||||||
|
+#include <sys/socket.h>
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+BEGIN
|
||||||
|
+{
|
||||||
|
+ printf("Tracing tcp drops. Hit Ctrl-C to end.\n");
|
||||||
|
+ printf("%-8s %-8s %-16s %-21s %-21s %-8s\n", "TIME", "PID", "COMM", "SADDR:SPORT", "DADDR:DPORT", "STATE");
|
||||||
|
+
|
||||||
|
+ // See https://github.com/torvalds/linux/blob/master/include/net/tcp_states.h
|
||||||
|
+ @tcp_states[1] = "ESTABLISHED";
|
||||||
|
+ @tcp_states[2] = "SYN_SENT";
|
||||||
|
+ @tcp_states[3] = "SYN_RECV";
|
||||||
|
+ @tcp_states[4] = "FIN_WAIT1";
|
||||||
|
+ @tcp_states[5] = "FIN_WAIT2";
|
||||||
|
+ @tcp_states[6] = "TIME_WAIT";
|
||||||
|
+ @tcp_states[7] = "CLOSE";
|
||||||
|
+ @tcp_states[8] = "CLOSE_WAIT";
|
||||||
|
+ @tcp_states[9] = "LAST_ACK";
|
||||||
|
+ @tcp_states[10] = "LISTEN";
|
||||||
|
+ @tcp_states[11] = "CLOSING";
|
||||||
|
+ @tcp_states[12] = "NEW_SYN_RECV";
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+kprobe:tcp_drop
|
||||||
|
+{
|
||||||
|
+ $sk = ((struct sock *) arg0);
|
||||||
|
+ $inet_family = $sk->__sk_common.skc_family;
|
||||||
|
+
|
||||||
|
+ if ($inet_family == AF_INET || $inet_family == AF_INET6) {
|
||||||
|
+ if ($inet_family == AF_INET) {
|
||||||
|
+ $daddr = ntop($sk->__sk_common.skc_daddr);
|
||||||
|
+ $saddr = ntop($sk->__sk_common.skc_rcv_saddr);
|
||||||
|
+ } else {
|
||||||
|
+ $daddr = ntop($sk->__sk_common.skc_v6_daddr.in6_u.u6_addr8);
|
||||||
|
+ $saddr = ntop($sk->__sk_common.skc_v6_rcv_saddr.in6_u.u6_addr8);
|
||||||
|
+ }
|
||||||
|
+ $lport = $sk->__sk_common.skc_num;
|
||||||
|
+ $dport = $sk->__sk_common.skc_dport;
|
||||||
|
+
|
||||||
|
+ // Destination port is big endian, it must be flipped
|
||||||
|
+ $dport = bswap($dport);
|
||||||
|
+
|
||||||
|
+ $state = $sk->__sk_common.skc_state;
|
||||||
|
+ $statestr = @tcp_states[$state];
|
||||||
|
+
|
||||||
|
+ time("%H:%M:%S ");
|
||||||
|
+ printf("%-8d %-16s ", pid, comm);
|
||||||
|
+ printf("%39s:%-6d %39s:%-6d %-10s\n", $saddr, $lport, $daddr, $dport, $statestr);
|
||||||
|
+ printf("%s\n", kstack);
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+END
|
||||||
|
+{
|
||||||
|
+ clear(@tcp_states);
|
||||||
|
+}
|
||||||
|
diff --git a/tools/tcpdrop.bt b/tools/tcpdrop.bt
|
||||||
|
index 3450a533..bb31107f 100755
|
||||||
|
--- a/tools/tcpdrop.bt
|
||||||
|
+++ b/tools/tcpdrop.bt
|
||||||
|
@@ -9,16 +9,15 @@
|
||||||
|
* It is limited to ipv4 addresses, and cannot show tcp flags.
|
||||||
|
*
|
||||||
|
* This provides information such as packet details, socket state, and kernel
|
||||||
|
- * stack trace for packets/segments that were dropped via tcp_drop().
|
||||||
|
-
|
||||||
|
- * WARNING: this script attaches to the tcp_drop kprobe which is likely inlined
|
||||||
|
- * on newer kernels and not replaced by anything else, therefore
|
||||||
|
- * the script will stop working
|
||||||
|
-
|
||||||
|
+ * stack trace for packets/segments that were dropped via kfree_skb.
|
||||||
|
+ *
|
||||||
|
+ * For Linux 5.17+ (see tools/old for script for lower versions).
|
||||||
|
+ *
|
||||||
|
* Copyright (c) 2018 Dale Hamel.
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License")
|
||||||
|
-
|
||||||
|
+ *
|
||||||
|
* 23-Nov-2018 Dale Hamel created this.
|
||||||
|
+ * 01-Oct-2022 Rong Tao use tracepoint:skb:kfree_skb
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef BPFTRACE_HAVE_BTF
|
||||||
|
@@ -48,12 +47,15 @@ BEGIN
|
||||||
|
@tcp_states[12] = "NEW_SYN_RECV";
|
||||||
|
}
|
||||||
|
|
||||||
|
-kprobe:tcp_drop
|
||||||
|
+tracepoint:skb:kfree_skb
|
||||||
|
{
|
||||||
|
- $sk = ((struct sock *) arg0);
|
||||||
|
+ $reason = args->reason;
|
||||||
|
+ $skb = (struct sk_buff *)args->skbaddr;
|
||||||
|
+ $sk = ((struct sock *) $skb->sk);
|
||||||
|
$inet_family = $sk->__sk_common.skc_family;
|
||||||
|
|
||||||
|
- if ($inet_family == AF_INET || $inet_family == AF_INET6) {
|
||||||
|
+ if ($reason > SKB_DROP_REASON_NOT_SPECIFIED &&
|
||||||
|
+ ($inet_family == AF_INET || $inet_family == AF_INET6)) {
|
||||||
|
if ($inet_family == AF_INET) {
|
||||||
|
$daddr = ntop($sk->__sk_common.skc_daddr);
|
||||||
|
$saddr = ntop($sk->__sk_common.skc_rcv_saddr);
|
||||||
|
--
|
||||||
|
2.38.1
|
||||||
|
|
@ -0,0 +1,27 @@
|
|||||||
|
From 31a42a47b90f97a2a8c2446101c0007cf09288bc Mon Sep 17 00:00:00 2001
|
||||||
|
From: Viktor Malik <viktor.malik@gmail.com>
|
||||||
|
Date: Mon, 5 Dec 2022 11:57:24 +0100
|
||||||
|
Subject: [PATCH] tools/old/mdflush.bt: fix BPFTRACE_HAVE_BTF macro
|
||||||
|
|
||||||
|
The correct macro to use is called BPFTRACE_HAVE_BTF, not
|
||||||
|
__BPFTRACE_HAVE_BTF.
|
||||||
|
---
|
||||||
|
tools/old/mdflush.bt | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/tools/old/mdflush.bt b/tools/old/mdflush.bt
|
||||||
|
index 921c8f1b..23c7dd51 100755
|
||||||
|
--- a/tools/old/mdflush.bt
|
||||||
|
+++ b/tools/old/mdflush.bt
|
||||||
|
@@ -15,7 +15,7 @@
|
||||||
|
* 08-Sep-2018 Brendan Gregg Created this.
|
||||||
|
*/
|
||||||
|
|
||||||
|
-#ifndef __BPFTRACE_HAVE_BTF
|
||||||
|
+#ifndef BPFTRACE_HAVE_BTF
|
||||||
|
#include <linux/genhd.h>
|
||||||
|
#include <linux/bio.h>
|
||||||
|
#endif
|
||||||
|
--
|
||||||
|
2.38.1
|
||||||
|
|
@ -1,19 +1,24 @@
|
|||||||
%bcond_without llvm_static
|
%bcond_without llvm_static
|
||||||
|
|
||||||
Name: bpftrace
|
Name: bpftrace
|
||||||
Version: 0.13.1
|
Version: 0.16.0
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
Summary: High-level tracing language for Linux eBPF
|
Summary: High-level tracing language for Linux eBPF
|
||||||
License: ASL 2.0
|
License: ASL 2.0
|
||||||
|
|
||||||
|
%define cereal_version 1.3.2
|
||||||
|
|
||||||
URL: https://github.com/iovisor/bpftrace
|
URL: https://github.com/iovisor/bpftrace
|
||||||
Source0: %{url}/archive/v%{version}/%{name}-%{version}.tar.gz
|
Source0: %{url}/archive/v%{version}/%{name}-%{version}.tar.gz
|
||||||
Patch0: %{name}-%{version}-RHEL-8-fixes.patch
|
# Cereal is a header-only serialization library which is not packaged into
|
||||||
Patch1: %{name}-%{version}-orc-Fix-build-with-clang-13.patch
|
# RHEL8, so we download it manually. This is ok to do as it is only necessary
|
||||||
Patch2: %{name}-%{version}-Fix-libbtf-0.6.0-build.patch
|
# for build.
|
||||||
Patch3: %{name}-%{version}-Fix-compile-under-llvm14-trunk.patch
|
Source1: https://github.com/USCiLab/cereal/archive/v%{cereal_version}/cereal-%{cereal_version}.tar.gz
|
||||||
Patch4: %{name}-%{version}-Fix-LLVM-13-warnings.patch
|
|
||||||
|
|
||||||
|
Patch0: %{name}-%{version}-IR-builder-get-rid-of-getPointerElementType-calls.patch
|
||||||
|
Patch1: %{name}-%{version}-tools-old-mdflush.bt-fix-BPFTRACE_HAVE_BTF-macro.patch
|
||||||
|
Patch2: %{name}-%{version}-tcpdrop-Fix-ERROR-Error-attaching-probe-kprobe-tcp_d.patch
|
||||||
|
Patch3: %{name}-%{version}-RHEL8-remove-not-existing-attachpoints-from-tools.patch
|
||||||
Patch10: %{name}-%{version}-RHEL-8-aarch64-fixes-statsnoop-and-opensnoop.patch
|
Patch10: %{name}-%{version}-RHEL-8-aarch64-fixes-statsnoop-and-opensnoop.patch
|
||||||
|
|
||||||
# Arches will be included as upstream support is added and dependencies are
|
# Arches will be included as upstream support is added and dependencies are
|
||||||
@ -51,7 +56,7 @@ and predecessor tracers such as DTrace and SystemTap
|
|||||||
|
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%autosetup -N
|
%autosetup -N -a 1
|
||||||
%autopatch -p1 -M 9
|
%autopatch -p1 -M 9
|
||||||
|
|
||||||
%ifarch aarch64
|
%ifarch aarch64
|
||||||
@ -59,6 +64,9 @@ and predecessor tracers such as DTrace and SystemTap
|
|||||||
%endif
|
%endif
|
||||||
|
|
||||||
%build
|
%build
|
||||||
|
# Set CPATH so that CMake finds the cereal headers
|
||||||
|
CPATH=$PWD/cereal-%{cereal_version}/include:$CPATH
|
||||||
|
export CPATH
|
||||||
%cmake . \
|
%cmake . \
|
||||||
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
|
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
|
||||||
-DBUILD_TESTING:BOOL=OFF \
|
-DBUILD_TESTING:BOOL=OFF \
|
||||||
@ -79,6 +87,11 @@ and predecessor tracers such as DTrace and SystemTap
|
|||||||
find %{buildroot}%{_datadir}/%{name}/tools -type f -exec \
|
find %{buildroot}%{_datadir}/%{name}/tools -type f -exec \
|
||||||
sed -i -e '1s=^#!/usr/bin/env %{name}\([0-9.]\+\)\?$=#!%{_bindir}/%{name}=' {} \;
|
sed -i -e '1s=^#!/usr/bin/env %{name}\([0-9.]\+\)\?$=#!%{_bindir}/%{name}=' {} \;
|
||||||
|
|
||||||
|
# Some tools require old versions for RHEL8
|
||||||
|
cp %{buildroot}/%{_datadir}/%{name}/tools/old/biosnoop.bt %{buildroot}/%{_datadir}/%{name}/tools
|
||||||
|
cp %{buildroot}/%{_datadir}/%{name}/tools/old/mdflush.bt %{buildroot}/%{_datadir}/%{name}/tools
|
||||||
|
|
||||||
|
|
||||||
%files
|
%files
|
||||||
%doc README.md CONTRIBUTING-TOOLS.md
|
%doc README.md CONTRIBUTING-TOOLS.md
|
||||||
%doc docs/reference_guide.md docs/tutorial_one_liners.md
|
%doc docs/reference_guide.md docs/tutorial_one_liners.md
|
||||||
@ -86,18 +99,22 @@ find %{buildroot}%{_datadir}/%{name}/tools -type f -exec \
|
|||||||
%dir %{_datadir}/%{name}
|
%dir %{_datadir}/%{name}
|
||||||
%dir %{_datadir}/%{name}/tools
|
%dir %{_datadir}/%{name}/tools
|
||||||
%dir %{_datadir}/%{name}/tools/doc
|
%dir %{_datadir}/%{name}/tools/doc
|
||||||
|
%dir %{_datadir}/%{name}/tools/old
|
||||||
%{_bindir}/%{name}
|
%{_bindir}/%{name}
|
||||||
|
%{_bindir}/%{name}-aotrt
|
||||||
%{_mandir}/man8/*
|
%{_mandir}/man8/*
|
||||||
%attr(0755,-,-) %{_datadir}/%{name}/tools/*.bt
|
%attr(0755,-,-) %{_datadir}/%{name}/tools/*.bt
|
||||||
%{_datadir}/%{name}/tools/doc/*.txt
|
%{_datadir}/%{name}/tools/doc/*.txt
|
||||||
# tcp_drop() is inlined on ppc64
|
# Do not include old versions of tools.
|
||||||
%ifarch %{power64}
|
# Those that are needed were already installed as normal tools.
|
||||||
%exclude %{_datadir}/%{name}/tools/tcpdrop.bt
|
%exclude %{_datadir}/%{name}/tools/old
|
||||||
%exclude %{_datadir}/%{name}/tools/doc/tcpdrop_example.txt
|
|
||||||
%exclude %{_mandir}/man8/tcpdrop.8.gz
|
|
||||||
%endif
|
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Nov 30 2022 Viktor Malik <vmalik@redhat.com> - 0.16.0-1
|
||||||
|
- Rebase on bpftrace 0.16.0
|
||||||
|
- Rebuild for LLVM15
|
||||||
|
- Download the cereal library (not packaged into RHEL8)
|
||||||
|
|
||||||
* Thu Jun 02 2022 Jerome Marchand <jmarchan@redhat.com> - 0.13.1-1
|
* Thu Jun 02 2022 Jerome Marchand <jmarchan@redhat.com> - 0.13.1-1
|
||||||
- Rebase on bpftrace 0.13.1
|
- Rebase on bpftrace 0.13.1
|
||||||
- Rebuild on LLVM14
|
- Rebuild on LLVM14
|
||||||
|
3
sources
3
sources
@ -1 +1,2 @@
|
|||||||
SHA512 (bpftrace-0.13.1.tar.gz) = fa810067023ddd6cbf2fd4c7c46138dd756eb9b3e37d00d049017f201f71c6a69ac2eb261619eb7e83356dc43fa1a0ed4d78b40f2ff36d76caa15e5c754ab224
|
SHA512 (bpftrace-0.16.0.tar.gz) = 52ca4fea4e2f8d2cbf0f9f1bc69af0ee3408201f019006dd2e838b9458cfc01761eba3df24c39e05cf93220d85d0cecc69bb44ec72f9f44cec0eb94479bff734
|
||||||
|
SHA512 (cereal-1.3.2.tar.gz) = 98d306d6292789129675f1c5c5aedcb90cfcc1029c4482893a8f9b23f3c9755e5ed4762d7a528f215345cae6392e87cd8d89467115b6f031b41c8673d6b4b109
|
||||||
|
Loading…
Reference in New Issue
Block a user