I am trying to generate a call graph of called functions starting from an (ARM)ELF file. Currently I call objdump
, parse the output for call instructions, and recursively repeat.
However, I noticed a function got outputted twice: in my final disassembly (which I keep track of for debugging purposes) I see
[alessandro@commodoroII ~]$ arm-none-eabi-objdump --disassemble=__aeabi_dsub /home/alessandro/tesi/validation_working_area/taffo_benchmarks/bench_cholesky_core2_1_100_100.elf
/home/alessandro/tesi/validation_working_area/taffo_benchmarks/bench_cholesky_core2_1_100_100.elf: file format elf32-littlearm
Disassembly of section .text:
08000688 <__aeabi_dsub>:
8000688: f083 4300 eor.w r3, r3, #2147483648 @ 0x80000000
0800068c <__adddf3>:
800068c: b530 push {r4, r5, lr}
800068e: ea4f 0441 mov.w r4, r1, lsl #1
8000692: ea4f 0543 mov.w r5, r3, lsl #1
8000696: ea94 0f05 teq r4, r5
800069a: bf08 it eq
800069c: ea90 0f02 teqeq r0, r2
80006a0: bf1f itttt ne
80006a2: ea54 0c00 orrsne.w ip, r4, r0
80006a6: ea55 0c02 orrsne.w ip, r5, r2
80006aa: ea7f 5c64 mvnsne.w ip, r4, asr #21
80006ae: ea7f 5c65 mvnsne.w ip, r5, asr #21
80006b2: f000 80e2 beq.w 800087a <__adddf3+0x1ee>
80006b6: ea4f 5454 mov.w r4, r4, lsr #21
80006ba: ebd4 5555 rsbs r5, r4, r5, lsr #21
80006be: bfb8 it lt
80006c0: 426d neglt r5, r5
80006c2: dd0c ble.n 80006de <__adddf3+0x52>
80006c4: 442c add r4, r5
80006c6: ea80 0202 eor.w r2, r0, r2
80006ca: ea81 0303 eor.w r3, r1, r3
80006ce: ea82 0000 eor.w r0, r2, r0
80006d2: ea83 0101 eor.w r1, r3, r1
80006d6: ea80 0202 eor.w r2, r0, r2
80006da: ea81 0303 eor.w r3, r1, r3
80006de: 2d36 cmp r5, #54 @ 0x36
80006e0: bf88 it hi
80006e2: bd30 pophi {r4, r5, pc}
80006e4: f011 4f00 tst.w r1, #2147483648 @ 0x80000000
80006e8: ea4f 3101 mov.w r1, r1, lsl #12
80006ec: f44f 1c80 mov.w ip, #1048576 @ 0x100000
80006f0: ea4c 3111 orr.w r1, ip, r1, lsr #12
80006f4: d002 beq.n 80006fc <__adddf3+0x70>
80006f6: 4240 negs r0, r0
80006f8: eb61 0141 sbc.w r1, r1, r1, lsl #1
80006fc: f013 4f00 tst.w r3, #2147483648 @ 0x80000000
8000700: ea4f 3303 mov.w r3, r3, lsl #12
8000704: ea4c 3313 orr.w r3, ip, r3, lsr #12
8000708: d002 beq.n 8000710 <__adddf3+0x84>
800070a: 4252 negs r2, r2
800070c: eb63 0343 sbc.w r3, r3, r3, lsl #1
8000710: ea94 0f05 teq r4, r5
8000714: f000 80a7 beq.w 8000866 <__adddf3+0x1da>
8000718: f1a4 0401 sub.w r4, r4, #1
800071c: f1d5 0e20 rsbs lr, r5, #32
8000720: db0d blt.n 800073e <__adddf3+0xb2>
8000722: fa02 fc0e lsl.w ip, r2, lr
8000726: fa22 f205 lsr.w r2, r2, r5
800072a: 1880 adds r0, r0, r2
800072c: f141 0100 adc.w r1, r1, #0
8000730: fa03 f20e lsl.w r2, r3, lr
8000734: 1880 adds r0, r0, r2
8000736: fa43 f305 asr.w r3, r3, r5
800073a: 4159 adcs r1, r3
800073c: e00e b.n 800075c <__adddf3+0xd0>
800073e: f1a5 0520 sub.w r5, r5, #32
8000742: f10e 0e20 add.w lr, lr, #32
8000746: 2a01 cmp r2, #1
8000748: fa03 fc0e lsl.w ip, r3, lr
800074c: bf28 it cs
800074e: f04c 0c02 orrcs.w ip, ip, #2
8000752: fa43 f305 asr.w r3, r3, r5
8000756: 18c0 adds r0, r0, r3
8000758: eb51 71e3 adcs.w r1, r1, r3, asr #31
800075c: f001 4500 and.w r5, r1, #2147483648 @ 0x80000000
8000760: d507 bpl.n 8000772 <__adddf3+0xe6>
8000762: f04f 0e00 mov.w lr, #0
8000766: f1dc 0c00 rsbs ip, ip, #0
800076a: eb7e 0000 sbcs.w r0, lr, r0
800076e: eb6e 0101 sbc.w r1, lr, r1
8000772: f5b1 1f80 cmp.w r1, #1048576 @ 0x100000
8000776: d31b bcc.n 80007b0 <__adddf3+0x124>
8000778: f5b1 1f00 cmp.w r1, #2097152 @ 0x200000
800077c: d30c bcc.n 8000798 <__adddf3+0x10c>
800077e: 0849 lsrs r1, r1, #1
8000780: ea5f 0030 movs.w r0, r0, rrx
8000784: ea4f 0c3c mov.w ip, ip, rrx
8000788: f104 0401 add.w r4, r4, #1
800078c: ea4f 5244 mov.w r2, r4, lsl #21
8000790: f512 0f80 cmn.w r2, #4194304 @ 0x400000
8000794: f080 809a bcs.w 80008cc <__adddf3+0x240>
8000798: f1bc 4f00 cmp.w ip, #2147483648 @ 0x80000000
800079c: bf08 it eq
800079e: ea5f 0c50 movseq.w ip, r0, lsr #1
80007a2: f150 0000 adcs.w r0, r0, #0
80007a6: eb41 5104 adc.w r1, r1, r4, lsl #20
80007aa: ea41 0105 orr.w r1, r1, r5
80007ae: bd30 pop {r4, r5, pc}
80007b0: ea5f 0c4c movs.w ip, ip, lsl #1
80007b4: 4140 adcs r0, r0
80007b6: eb41 0101 adc.w r1, r1, r1
80007ba: 3c01 subs r4, #1
80007bc: bf28 it cs
80007be: f5b1 1f80 cmpcs.w r1, #1048576 @ 0x100000
80007c2: d2e9 bcs.n 8000798 <__adddf3+0x10c>
80007c4: f091 0f00 teq r1, #0
80007c8: bf04 itt eq
80007ca: 4601 moveq r1, r0
80007cc: 2000 moveq r0, #0
80007ce: fab1 f381 clz r3, r1
80007d2: bf08 it eq
80007d4: 3320 addeq r3, #32
80007d6: f1a3 030b sub.w r3, r3, #11
80007da: f1b3 0220 subs.w r2, r3, #32
80007de: da0c bge.n 80007fa <__adddf3+0x16e>
80007e0: 320c adds r2, #12
80007e2: dd08 ble.n 80007f6 <__adddf3+0x16a>
80007e4: f102 0c14 add.w ip, r2, #20
80007e8: f1c2 020c rsb r2, r2, #12
80007ec: fa01 f00c lsl.w r0, r1, ip
80007f0: fa21 f102 lsr.w r1, r1, r2
80007f4: e00c b.n 8000810 <__adddf3+0x184>
80007f6: f102 0214 add.w r2, r2, #20
80007fa: bfd8 it le
80007fc: f1c2 0c20 rsble ip, r2, #32
8000800: fa01 f102 lsl.w r1, r1, r2
8000804: fa20 fc0c lsr.w ip, r0, ip
8000808: bfdc itt le
800080a: ea41 010c orrle.w r1, r1, ip
800080e: 4090 lslle r0, r2
8000810: 1ae4 subs r4, r4, r3
8000812: bfa2 ittt ge
8000814: eb01 5104 addge.w r1, r1, r4, lsl #20
8000818: 4329 orrge r1, r5
800081a: bd30 popge {r4, r5, pc}
800081c: ea6f 0404 mvn.w r4, r4
8000820: 3c1f subs r4, #31
8000822: da1c bge.n 800085e <__adddf3+0x1d2>
8000824: 340c adds r4, #12
8000826: dc0e bgt.n 8000846 <__adddf3+0x1ba>
8000828: f104 0414 add.w r4, r4, #20
800082c: f1c4 0220 rsb r2, r4, #32
8000830: fa20 f004 lsr.w r0, r0, r4
8000834: fa01 f302 lsl.w r3, r1, r2
8000838: ea40 0003 orr.w r0, r0, r3
800083c: fa21 f304 lsr.w r3, r1, r4
8000840: ea45 0103 orr.w r1, r5, r3
8000844: bd30 pop {r4, r5, pc}
8000846: f1c4 040c rsb r4, r4, #12
800084a: f1c4 0220 rsb r2, r4, #32
800084e: fa20 f002 lsr.w r0, r0, r2
8000852: fa01 f304 lsl.w r3, r1, r4
8000856: ea40 0003 orr.w r0, r0, r3
800085a: 4629 mov r1, r5
800085c: bd30 pop {r4, r5, pc}
800085e: fa21 f004 lsr.w r0, r1, r4
8000862: 4629 mov r1, r5
8000864: bd30 pop {r4, r5, pc}
8000866: f094 0f00 teq r4, #0
800086a: f483 1380 eor.w r3, r3, #1048576 @ 0x100000
800086e: bf06 itte eq
8000870: f481 1180 eoreq.w r1, r1, #1048576 @ 0x100000
8000874: 3401 addeq r4, #1
8000876: 3d01 subne r5, #1
8000878: e74e b.n 8000718 <__adddf3+0x8c>
800087a: ea7f 5c64 mvns.w ip, r4, asr #21
800087e: bf18 it ne
8000880: ea7f 5c65 mvnsne.w ip, r5, asr #21
8000884: d029 beq.n 80008da <__adddf3+0x24e>
8000886: ea94 0f05 teq r4, r5
800088a: bf08 it eq
800088c: ea90 0f02 teqeq r0, r2
8000890: d005 beq.n 800089e <__adddf3+0x212>
8000892: ea54 0c00 orrs.w ip, r4, r0
8000896: bf04 itt eq
8000898: 4619 moveq r1, r3
800089a: 4610 moveq r0, r2
800089c: bd30 pop {r4, r5, pc}
800089e: ea91 0f03 teq r1, r3
80008a2: bf1e ittt ne
80008a4: 2100 movne r1, #0
80008a6: 2000 movne r0, #0
80008a8: bd30 popne {r4, r5, pc}
80008aa: ea5f 5c54 movs.w ip, r4, lsr #21
80008ae: d105 bne.n 80008bc <__adddf3+0x230>
80008b0: 0040 lsls r0, r0, #1
80008b2: 4149 adcs r1, r1
80008b4: bf28 it cs
80008b6: f041 4100 orrcs.w r1, r1, #2147483648 @ 0x80000000
80008ba: bd30 pop {r4, r5, pc}
80008bc: f514 0480 adds.w r4, r4, #4194304 @ 0x400000
80008c0: bf3c itt cc
80008c2: f501 1180 addcc.w r1, r1, #1048576 @ 0x100000
80008c6: bd30 popcc {r4, r5, pc}
80008c8: f001 4500 and.w r5, r1, #2147483648 @ 0x80000000
80008cc: f045 41fe orr.w r1, r5, #2130706432 @ 0x7f000000
80008d0: f441 0170 orr.w r1, r1, #15728640 @ 0xf00000
80008d4: f04f 0000 mov.w r0, #0
80008d8: bd30 pop {r4, r5, pc}
80008da: ea7f 5c64 mvns.w ip, r4, asr #21
80008de: bf1a itte ne
80008e0: 4619 movne r1, r3
80008e2: 4610 movne r0, r2
80008e4: ea7f 5c65 mvnseq.w ip, r5, asr #21
80008e8: bf1c itt ne
80008ea: 460b movne r3, r1
80008ec: 4602 movne r2, r0
80008ee: ea50 3401 orrs.w r4, r0, r1, lsl #12
80008f2: bf06 itte eq
80008f4: ea52 3503 orrseq.w r5, r2, r3, lsl #12
80008f8: ea91 0f03 teqeq r1, r3
80008fc: f441 2100 orrne.w r1, r1, #524288 @ 0x80000
8000900: bd30 pop {r4, r5, pc}
As you see, objdump
thinks the function __aeabi_dsub
doesn't end when __adddf3
starts, and (erroneously) includes the latter in the disassembly. Basically, I end up with __adddf3
included twice.
objdump
does this?Thanks!
EDIT: What I mean is that I'd like objdump
to stop at the next label, which should be default behavior, according to Michael Kerrisk's man page:
-d
--disassemble
--disassemble=symbol
Display the assembler mnemonics for the machine instructions
from the input file. This option only disassembles those
sections which are expected to contain instructions. If the
optional symbol argument is given, then display the assembler
mnemonics starting at symbol. If symbol is a function name
then disassembly will stop at the end of the function,
otherwise it will stop when the next symbol is encountered.
If there are no matches for symbol then nothing will be
displayed.
Regardless of whether the label correspond to actual functions or not, for the purpose of the analysis I'm doing I'm interested in tracing the call relationship of these pieces of code, assuming they behave as functions.
EDIT 2: disassembling with GDB, I see:
[alessandro@commodoroII src]$ arm-none-eabi-gdb -batch -ex 'file /home/alessandro/tesi/validation_working_area/taffo_benchmarks/bench_cholesky_core2_1_100_100.elf' -ex 'disassemble __aeabi_dsub'
Dump of assembler code for function __aeabi_dsub:
0x08000689 <-1>: eor.w r3, r3, #2147483648 @ 0x80000000
0x0800068d <-1>: push {r4, r5, lr}
0x0800068f <+1>: mov.w r4, r1, lsl #1
0x08000693 <+5>: mov.w r5, r3, lsl #1
0x08000697 <+9>: teq r4, r5
0x0800069b <+13>: it eq
0x0800069d <+15>: teqeq r0, r2
0x080006a1 <+19>: itttt ne
0x080006a3 <+21>: orrsne.w r12, r4, r0
0x080006a7 <+25>: orrsne.w r12, r5, r2
0x080006ab <+29>: mvnsne.w r12, r4, asr #21
0x080006af <+33>: mvnsne.w r12, r5, asr #21
0x080006b3 <+37>: beq.w 0x800087a <__aeabi_dadd+493>
0x080006b7 <+41>: mov.w r4, r4, lsr #21
0x080006bb <+45>: rsbs r5, r4, r5, lsr #21
0x080006bf <+49>: it lt
0x080006c1 <+51>: neglt r5, r5
0x080006c3 <+53>: ble.n 0x80006de <__aeabi_dadd+81>
0x080006c5 <+55>: add r4, r5
0x080006c7 <+57>: eor.w r2, r0, r2
0x080006cb <+61>: eor.w r3, r1, r3
0x080006cf <+65>: eor.w r0, r2, r0
0x080006d3 <+69>: eor.w r1, r3, r1
0x080006d7 <+73>: eor.w r2, r0, r2
0x080006db <+77>: eor.w r3, r1, r3
0x080006df <+81>: cmp r5, #54 @ 0x36
0x080006e1 <+83>: it hi
0x080006e3 <+85>: pophi {r4, r5, pc}
0x080006e5 <+87>: tst.w r1, #2147483648 @ 0x80000000
0x080006e9 <+91>: mov.w r1, r1, lsl #12
0x080006ed <+95>: mov.w r12, #1048576 @ 0x100000
0x080006f1 <+99>: orr.w r1, r12, r1, lsr #12
0x080006f5 <+103>: beq.n 0x80006fc <__aeabi_dadd+111>
0x080006f7 <+105>: negs r0, r0
0x080006f9 <+107>: sbc.w r1, r1, r1, lsl #1
0x080006fd <+111>: tst.w r3, #2147483648 @ 0x80000000
0x08000701 <+115>: mov.w r3, r3, lsl #12
0x08000705 <+119>: orr.w r3, r12, r3, lsr #12
0x08000709 <+123>: beq.n 0x8000710 <__aeabi_dadd+131>
0x0800070b <+125>: negs r2, r2
0x0800070d <+127>: sbc.w r3, r3, r3, lsl #1
0x08000711 <+131>: teq r4, r5
0x08000715 <+135>: beq.w 0x8000866 <__aeabi_dadd+473>
0x08000719 <+139>: sub.w r4, r4, #1
0x0800071d <+143>: rsbs lr, r5, #32
0x08000721 <+147>: blt.n 0x800073e <__aeabi_dadd+177>
0x08000723 <+149>: lsl.w r12, r2, lr
0x08000727 <+153>: lsr.w r2, r2, r5
0x0800072b <+157>: adds r0, r0, r2
0x0800072d <+159>: adc.w r1, r1, #0
0x08000731 <+163>: lsl.w r2, r3, lr
0x08000735 <+167>: adds r0, r0, r2
0x08000737 <+169>: asr.w r3, r3, r5
0x0800073b <+173>: adcs r1, r3
0x0800073d <+175>: b.n 0x800075c <__aeabi_dadd+207>
0x0800073f <+177>: sub.w r5, r5, #32
0x08000743 <+181>: add.w lr, lr, #32
0x08000747 <+185>: cmp r2, #1
0x08000749 <+187>: lsl.w r12, r3, lr
0x0800074d <+191>: it cs
0x0800074f <+193>: orrcs.w r12, r12, #2
0x08000753 <+197>: asr.w r3, r3, r5
0x08000757 <+201>: adds r0, r0, r3
0x08000759 <+203>: adcs.w r1, r1, r3, asr #31
0x0800075d <+207>: and.w r5, r1, #2147483648 @ 0x80000000
0x08000761 <+211>: bpl.n 0x8000772 <__aeabi_dadd+229>
0x08000763 <+213>: mov.w lr, #0
0x08000767 <+217>: rsbs r12, r12, #0
0x0800076b <+221>: sbcs.w r0, lr, r0
0x0800076f <+225>: sbc.w r1, lr, r1
0x08000773 <+229>: cmp.w r1, #1048576 @ 0x100000
0x08000777 <+233>: bcc.n 0x80007b0 <__aeabi_dadd+291>
0x08000779 <+235>: cmp.w r1, #2097152 @ 0x200000
0x0800077d <+239>: bcc.n 0x8000798 <__aeabi_dadd+267>
0x0800077f <+241>: lsrs r1, r1, #1
0x08000781 <+243>: movs.w r0, r0, rrx
0x08000785 <+247>: mov.w r12, r12, rrx
0x08000789 <+251>: add.w r4, r4, #1
0x0800078d <+255>: mov.w r2, r4, lsl #21
0x08000791 <+259>: cmn.w r2, #4194304 @ 0x400000
0x08000795 <+263>: bcs.w 0x80008cc <__aeabi_dadd+575>
0x08000799 <+267>: cmp.w r12, #2147483648 @ 0x80000000
0x0800079d <+271>: it eq
0x0800079f <+273>: movseq.w r12, r0, lsr #1
0x080007a3 <+277>: adcs.w r0, r0, #0
0x080007a7 <+281>: adc.w r1, r1, r4, lsl #20
0x080007ab <+285>: orr.w r1, r1, r5
0x080007af <+289>: pop {r4, r5, pc}
0x080007b1 <+291>: movs.w r12, r12, lsl #1
0x080007b5 <+295>: adcs r0, r0
0x080007b7 <+297>: adc.w r1, r1, r1
0x080007bb <+301>: subs r4, #1
0x080007bd <+303>: it cs
0x080007bf <+305>: cmpcs.w r1, #1048576 @ 0x100000
0x080007c3 <+309>: bcs.n 0x8000798 <__aeabi_dadd+267>
0x080007c5 <+311>: teq r1, #0
0x080007c9 <+315>: itt eq
0x080007cb <+317>: moveq r1, r0
0x080007cd <+319>: moveq r0, #0
0x080007cf <+321>: clz r3, r1
0x080007d3 <+325>: it eq
0x080007d5 <+327>: addeq r3, #32
0x080007d7 <+329>: sub.w r3, r3, #11
0x080007db <+333>: subs.w r2, r3, #32
0x080007df <+337>: bge.n 0x80007fa <__aeabi_dadd+365>
0x080007e1 <+339>: adds r2, #12
0x080007e3 <+341>: ble.n 0x80007f6 <__aeabi_dadd+361>
0x080007e5 <+343>: add.w r12, r2, #20
0x080007e9 <+347>: rsb r2, r2, #12
0x080007ed <+351>: lsl.w r0, r1, r12
0x080007f1 <+355>: lsr.w r1, r1, r2
0x080007f5 <+359>: b.n 0x8000810 <__aeabi_dadd+387>
0x080007f7 <+361>: add.w r2, r2, #20
0x080007fb <+365>: it le
0x080007fd <+367>: rsble r12, r2, #32
0x08000801 <+371>: lsl.w r1, r1, r2
0x08000805 <+375>: lsr.w r12, r0, r12
0x08000809 <+379>: itt le
0x0800080b <+381>: orrle.w r1, r1, r12
0x0800080f <+385>: lslle r0, r2
0x08000811 <+387>: subs r4, r4, r3
0x08000813 <+389>: ittt ge
0x08000815 <+391>: addge.w r1, r1, r4, lsl #20
0x08000819 <+395>: orrge r1, r5
0x0800081b <+397>: popge {r4, r5, pc}
0x0800081d <+399>: mvn.w r4, r4
0x08000821 <+403>: subs r4, #31
0x08000823 <+405>: bge.n 0x800085e <__aeabi_dadd+465>
0x08000825 <+407>: adds r4, #12
0x08000827 <+409>: bgt.n 0x8000846 <__aeabi_dadd+441>
0x08000829 <+411>: add.w r4, r4, #20
0x0800082d <+415>: rsb r2, r4, #32
0x08000831 <+419>: lsr.w r0, r0, r4
0x08000835 <+423>: lsl.w r3, r1, r2
0x08000839 <+427>: orr.w r0, r0, r3
0x0800083d <+431>: lsr.w r3, r1, r4
0x08000841 <+435>: orr.w r1, r5, r3
0x08000845 <+439>: pop {r4, r5, pc}
0x08000847 <+441>: rsb r4, r4, #12
0x0800084b <+445>: rsb r2, r4, #32
0x0800084f <+449>: lsr.w r0, r0, r2
0x08000853 <+453>: lsl.w r3, r1, r4
0x08000857 <+457>: orr.w r0, r0, r3
0x0800085b <+461>: mov r1, r5
0x0800085d <+463>: pop {r4, r5, pc}
0x0800085f <+465>: lsr.w r0, r1, r4
0x08000863 <+469>: mov r1, r5
0x08000865 <+471>: pop {r4, r5, pc}
0x08000867 <+473>: teq r4, #0
0x0800086b <+477>: eor.w r3, r3, #1048576 @ 0x100000
0x0800086f <+481>: itte eq
0x08000871 <+483>: eoreq.w r1, r1, #1048576 @ 0x100000
0x08000875 <+487>: addeq r4, #1
0x08000877 <+489>: subne r5, #1
0x08000879 <+491>: b.n 0x8000718 <__aeabi_dadd+139>
0x0800087b <+493>: mvns.w r12, r4, asr #21
0x0800087f <+497>: it ne
0x08000881 <+499>: mvnsne.w r12, r5, asr #21
0x08000885 <+503>: beq.n 0x80008da <__aeabi_dadd+589>
0x08000887 <+505>: teq r4, r5
0x0800088b <+509>: it eq
0x0800088d <+511>: teqeq r0, r2
0x08000891 <+515>: beq.n 0x800089e <__aeabi_dadd+529>
0x08000893 <+517>: orrs.w r12, r4, r0
0x08000897 <+521>: itt eq
0x08000899 <+523>: moveq r1, r3
0x0800089b <+525>: moveq r0, r2
0x0800089d <+527>: pop {r4, r5, pc}
0x0800089f <+529>: teq r1, r3
0x080008a3 <+533>: ittt ne
0x080008a5 <+535>: movne r1, #0
0x080008a7 <+537>: movne r0, #0
0x080008a9 <+539>: popne {r4, r5, pc}
0x080008ab <+541>: movs.w r12, r4, lsr #21
0x080008af <+545>: bne.n 0x80008bc <__aeabi_dadd+559>
0x080008b1 <+547>: lsls r0, r0, #1
0x080008b3 <+549>: adcs r1, r1
0x080008b5 <+551>: it cs
0x080008b7 <+553>: orrcs.w r1, r1, #2147483648 @ 0x80000000
0x080008bb <+557>: pop {r4, r5, pc}
0x080008bd <+559>: adds.w r4, r4, #4194304 @ 0x400000
0x080008c1 <+563>: itt cc
0x080008c3 <+565>: addcc.w r1, r1, #1048576 @ 0x100000
0x080008c7 <+569>: popcc {r4, r5, pc}
0x080008c9 <+571>: and.w r5, r1, #2147483648 @ 0x80000000
0x080008cd <+575>: orr.w r1, r5, #2130706432 @ 0x7f000000
0x080008d1 <+579>: orr.w r1, r1, #15728640 @ 0xf00000
0x080008d5 <+583>: mov.w r0, #0
0x080008d9 <+587>: pop {r4, r5, pc}
0x080008db <+589>: mvns.w r12, r4, asr #21
0x080008df <+593>: itte ne
0x080008e1 <+595>: movne r1, r3
0x080008e3 <+597>: movne r0, r2
0x080008e5 <+599>: mvnseq.w r12, r5, asr #21
0x080008e9 <+603>: itt ne
0x080008eb <+605>: movne r3, r1
0x080008ed <+607>: movne r2, r0
0x080008ef <+609>: orrs.w r4, r0, r1, lsl #12
0x080008f3 <+613>: itte eq
0x080008f5 <+615>: orrseq.w r5, r2, r3, lsl #12
0x080008f9 <+619>: teqeq r1, r3
0x080008fd <+623>: orrne.w r1, r1, #524288 @ 0x80000
0x08000901 <+627>: pop {r4, r5, pc}
End of assembler dump.
where the first instructions are listed with a negative offset from the symbol(?)
Note on solution: artless noise's solution provides the context about why this is probably the expected behaviour. What I need to do here is not best practice, so I guess I'd need some convoluted usage of strip
and objdump
to make it work. Beside their answer, I managed to get what I need by dumping all the disassembly with objdump -j .text -D <file>
and writing a program that manually follows the calls
If you step back and think at a higher level,
Replace aeabi_dsub shows that this just the opposite of faddd3
.
That is
double faddd3(double a, double b) { return a + b;}
double aeabi_dsub(double a, double b) { return a - b; }
This is another implementation,
double aeabi_dsub(double a, double b) { return faddd3(a,-b); }
So all the aeabi_dsub
shim is doing is to flip the sign of 'b' so that the routines are equivalent. What you are asking is that the disassembly of aeabi_dsub
would only show,
<__aeabi_dsub>: f083 4300 eor.w r3, r3, #0x80000000
That is technically correct from your design needs, but if someone wanted to know what the actual routine did, they need to see the body of faddd3
as well. Using objdump --disassemble
as a means of seeing what a routine is doing is the primary goal of this flag. You are using it in a way that is abnormal.
The project cally.py will parse objects compiled with -fdump-rtl-expand
. You pass all objects and a root function and it generates a graph for you.
A sample *nix command I use is,
./cally.py --caller main `find . -name *.expand` | dot -Grankdir=LR -Tpng -o full_call_graph.png
See also: