From: Vladimir Mezentsev Date: Fri, 18 Apr 2025 21:00:59 +0000 (-0700) Subject: gprofng: fix 32886 wrong mapping from instruction to line number X-Git-Tag: binutils-2_45~854 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=377d832881f598eaac1baa58b66a44ab6371ff0a;p=thirdparty%2Fbinutils-gdb.git gprofng: fix 32886 wrong mapping from instruction to line number On Intel, gprofng should adjusts return addresses, including user leaf functions. gprofng/ChangeLog 2025-04-18 Vladimir Mezentsev * src/CallStack.cc (add_stack): Adjust return addresses on Intel. --- diff --git a/gprofng/src/CallStack.cc b/gprofng/src/CallStack.cc index 6df4112f943..9a3a15d64d4 100644 --- a/gprofng/src/CallStack.cc +++ b/gprofng/src/CallStack.cc @@ -527,14 +527,10 @@ CallStackP::add_stack (DataDescriptor *dDscr, long idx, FramePacket *frp, Vaddr va = frp->getFromStack (index); DbeInstr *cur_instr = experiment->map_Vaddr_to_PC (va, tstamp); -#if ARCH(Intel)// TBR? FIXUP_XXX_SPARC_LINUX: switch should be on experiment ARCH, not dbe ARCH // We need to adjust return addresses on intel - // in order to attribute inclusive metrics to - // proper call instructions. - if (experiment->exp_maj_version <= 9) - if (!leaf && cur_instr->addr != 0) - cur_instr = cur_instr->func->find_dbeinstr (0, cur_instr->addr - 1); -#endif + // in order to attribute inclusive metrics to proper instructions. + if (experiment->platform == Intel && cur_instr->addr != 0) + cur_instr = cur_instr->func->find_dbeinstr (0, cur_instr->addr - 1); // Skip PC's from PLT, update leaf and state accordingly if ((cur_instr->func->flags & FUNC_FLAG_PLT)