LLVM获取函数传入参数的具体值

%call = call i8* @malloc(i64 12)

比如有这么一段IR,我想要得到malloc中的参数12:

void TableBuilder::extract_info(const CallInst *ins_ptr) {
    auto fn = ins_ptr->getCalledFunction();
    errs() << ins_ptr->getNumOperands() << "\n";
    if (fn) {
        if (fn->getName() == "malloc") {
            for (auto arg = ins_ptr->arg_begin(); arg != ins_ptr->arg_end(); ++ arg) {
                if (auto val = dyn_cast<ConstantInt>(arg)) {
                    errs() << val->getZExtValue() << "\n";
                }
            }
        }
    }
}

注意这里要用CallInst指针,而不能用Function*,这里被坑了好久。。。

上一篇:嵌入式100题(017):malloc的底层实现


下一篇:关于内存泄露和内存溢出以及C语言为什么要用malloc开辟内存空间