[llvm-dev] How to get absolute address of llvm-objdump

Fāng-ruì Sòng via llvm-dev llvm-dev at lists.llvm.org
Mon Dec 14 13:31:31 PST 2020


This needs an AArch64InstPrinter change. Sent https://reviews.llvm.org/D93241

adr may need a similar change as well.

On Mon, Dec 14, 2020 at 12:53 AM James Henderson
<jh7370.2008 at my.bristol.ac.uk> wrote:
>
> Hi,
>
> I thought this was something that somebody had looked at a while back, but I can't immediately find it. I've explicitly CC'ed Fangrui Song, who has made a number of disassembly improvements in the past year. He may be able to help.
>
> James
>
> On Sat, 12 Dec 2020 at 08:57, Haishan via llvm-dev <llvm-dev at lists.llvm.org> wrote:
>>
>>
>> I used llvm-objdump to dump aarch64 binary, but it prints relative address of .rodata section in adrp instruction.
>>
>> Like:
>>
>>   llvm-objdump
>>
>>   400848: 02 00 00 90   adrp    x2, #0x0
>>
>>   40084c: 42 60 29 91   add x2, x2, #0xa58
>>
>>   400850: 44 48 63 38   ldrb    w4, [x2, w3, uxtw]
>>
>>   400854: 65 00 00 10   adr x5, #0xc
>>
>>   400858: a4 88 24 8b   add x4, x5, w4, sxtb #2
>>
>>   40085c: 80 00 1f d6   br  x4
>>
>> Moreover, when debug llvm-objdump binary, this adrp MCInst express by MCExpr which Kind is MCExpr::Target, not immediate.
>>
>>
>>
>> But I used objdump tools of binutils, it prints absolute address. Such as:
>>
>>   400848:       90000002        adrp    x2, 400000 <_init-0x518>
>>
>>   40084c:       91296042        add     x2, x2, #0xa58
>>
>>   400850:       38634844        ldrb    w4, [x2,w3,uxtw]
>>
>>   400854:       10000065        adr     x5, 400860 <local+0x48>
>>
>>   400858:       8b2488a4        add     x4, x5, w4, sxtb #2
>>
>>   40085c:       d61f0080        br      x4
>>
>> So How to get absolute address with llvm MCInst?
>>
>> _______________________________________________
>> LLVM Developers mailing list
>> llvm-dev at lists.llvm.org
>> https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev



-- 
宋方睿


More information about the llvm-dev mailing list