这是一个简单的C程序:
struct S {char c; short arr[16]; char dummy2;};
extern struct S A[20];
extern short* p;
int main() {
p = &A[10].arr[6];
return 0;
}
这是LLVM IR:
%struct.S = type { i8, [16 x i16], i8 }
@A = external global [20 x %struct.S]
@p = external global i16*
; Function Attrs: nounwind
define i32 @main() #0 {
entry:
store i16* getelementptr inbounds ([20 x %struct.S]* @A, i64 0, i64 10, i32 1, i64 6), i16** @p, align 8, !tbaa !1
ret i32 0
}
如何计算getelementptr添加到@A
的字节偏移量?
我可以轻松地循环并打印出GEP:
auto& P = *GEP.getPointerOperand();
Out << "GEP(";
GEP.getType()->print(Out); // return type
Out << ", ";
P.printAsOperand(Out); // base
for (auto i=0U; i<GEP.getNumIndices(); i++) {
Out << ", ";
GEP.getOperand(i+1)->printAsOperand(Out); // index i
}
Out << ")\n";
打印:
GEP(i16*, [20 x %struct.S]* @A, i64 0, i64 10, i32 1, i64 6)
假设 all 索引是常量整数,你如何确定相对于基指针的字节偏移量?
答案 0 :(得分:1)
你能使用ptrtoint指令并减去它们吗?