[llvm-dev] Instrument intrinsic invalid

33 views
Skip to first unread message

Jinyan via llvm-dev

unread,
Jul 19, 2020, 2:48:48 AM7/19/20
to llvm...@lists.llvm.org
Hi, I try to use llvm-dis to disassemble the result after opt, my pass will add a intrinsic after the load instruction, like following:

bool fpscan::ldAddMetadata (Instruction *Inst, StringRef c) {
std::vector<Metadata *> dataTuples;
// Add metadata in list
dataTuples.push_back(MDString::get(Inst->getContext(), c));
MDNode* N = MDNode::get(Inst->getContext(), dataTuples);

Value* meta = MetadataAsValue::get(Inst->getContext(), N);
std::vector<Value*> args;
args.push_back(meta);
IRBuilder<> Builder(Inst->getNextNode());
Builder.CreateCall(dbglabelPtr, args, "");
}

And before my pass finish, I print the IR, it shows I successfully add the intrinsic

%5 = load i32 (i32, i32)*, i32 (i32, i32)** %1, align 8, !dbg !35, !ppp.load !36
call void @llvm.dbg.label(metadata !36), !dbg !37
...
; Function Attrs: nounwind readnone speculatable willreturn
declare void @llvm.dbg.label(metadata) #1

But, when I use llvm-dis to disassemble the .bc generated by opt, it ignore the code I insert:

invalid llvm.dbg.label intrinsic variable
call void @llvm.dbg.label(metadata !36), !dbg !37
!36 = !{!"dbg1", !"dbgfromLoad"}
llvm-dis: warning: ignoring invalid debug info in test.bc

How to fix this warning ? thks

_______________________________________________
LLVM Developers mailing list
llvm...@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev

Chen, Yuanfang via llvm-dev

unread,
Jul 19, 2020, 3:19:55 AM7/19/20
to llvm...@lists.llvm.org, Jinyan
Hi,

A successfully printed module could still be invalid such as this case. The problem is that the metadata should contain a DILabel instead of a string. Try using DIBuilder::insertLabel instead.

________________________________________
From: llvm-dev <llvm-dev...@lists.llvm.org> on behalf of Jinyan via llvm-dev <llvm...@lists.llvm.org>
Sent: Saturday, July 18, 2020 11:48 PM
To: llvm...@lists.llvm.org
Subject: [llvm-dev] Instrument intrinsic invalid

Chen, Yuanfang via llvm-dev

unread,
Jul 20, 2020, 1:07:22 PM7/20/20
to Jinyan, LLVM Developers' List
Could you please elaborate on what are you trying to do? `llvm.dbg.label` is for debuginfo generation of the program being compiled, not for attaching user info and passing around.

________________________________________
From: Jinyan <phant...@zju.edu.cn>
Sent: Sunday, July 19, 2020 2:16 AM
To: Chen, Yuanfang
Subject: Re: Re: [llvm-dev] Instrument intrinsic invalid

Wow ! It seems insertLabel internal is also use builder to create, the key point in my bug is to convert the MDNode* to a DILabel*, after passing a DILAble as arg, it works, thks! I want to use llvm.dbg.label to instrument some machine instructions at the backend, but now the metadata must obey the format of DILabel, I can only pass my info in name field... Are there any existing intrinsic that can be used to pass arbitrary metadata ? Please you get me some suggestion ?


> -----Original Messages-----
> From: "Chen, Yuanfang" <Yuanfa...@sony.com>
> Sent Time: 2020-07-19 15:19:39 (Sunday)
> To: "llvm...@lists.llvm.org" <llvm...@lists.llvm.org>, Jinyan <phant...@zju.edu.cn>
> Cc:
> Subject: Re: [llvm-dev] Instrument intrinsic invalid

Reply all
Reply to author
Forward
0 new messages