linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
From: "Naveen N. Rao" <naveen.n.rao@linux.vnet.ibm.com>
To: kernel test robot <lkp@intel.com>, Sathvika Vasireddy <sv@linux.ibm.com>
Cc: linux-kernel@vger.kernel.org, npiggin@gmail.com,
	oe-kbuild-all@lists.linux.dev, linuxppc-dev@lists.ozlabs.org
Subject: Re: arch/powerpc/kernel/head_85xx.o: warning: objtool: .head.text+0x1a6c: unannotated intra-function call
Date: Wed, 25 Jan 2023 12:57:35 +0530	[thread overview]
Message-ID: <1674631223.9e09lbzzb6.naveen@linux.ibm.com> (raw)
In-Reply-To: <b2273730-f885-7658-7ec4-12fb5bfc515b@linux.ibm.com>

Sathvika Vasireddy wrote:
> 
>>>> arch/powerpc/kvm/booke.o: warning: objtool: kvmppc_fill_pt_regs+0x30: unannotated intra-function call
> 
> As an attempt to fix it, I tried expanding ANNOTATE_INTRA_FUNCTION_CALL 
> macro to indicate that the branch target is valid. It then threw another 
> warning (arch/powerpc/kvm/booke.o: warning: objtool: 
> kvmppc_fill_pt_regs+0x38: intra_function_call not a direct call). The 
> below diff just removes the warnings for me, but I'm not very sure if 
> this is the best way to fix the objtool warnings seen with this 
> particular file. Please let me know if there are any better ways to fix it.
> 
> diff --git a/arch/powerpc/kvm/booke.c b/arch/powerpc/kvm/booke.c
> index 0dce93ccaadf..b6a413824b98 100644
> --- a/arch/powerpc/kvm/booke.c
> +++ b/arch/powerpc/kvm/booke.c
> @@ -917,7 +917,9 @@ static void kvmppc_fill_pt_regs(struct pt_regs *regs)
>          asm("mr %0, 1" : "=r"(r1));
>          asm("mflr %0" : "=r"(lr));
>          asm("mfmsr %0" : "=r"(msr));
> +       asm(".pushsection .discard.intra_function_calls; .long 999f; 
> .popsection; 999:");
>          asm("bl 1f; 1: mflr %0" : "=r"(ip));

I don't think you can assume that there won't be anything in between two 
asm statements. Does it work if you combine both the above asm 
statements into a single one?

Even if that works, I don't think it is good to expand the macro here.  
That asm statement looks to be trying to grab the current nip. I don't 
know enough about that code, and someone who knows more about KVM may be 
able to help, but it looks like we should be able to simply set 'ip' to 
the address of kvmppc_fill_pt_regs()?


- Naveen


       reply	other threads:[~2023-01-25  7:28 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <202301161955.38kK6ksW-lkp@intel.com>
     [not found] ` <b2273730-f885-7658-7ec4-12fb5bfc515b@linux.ibm.com>
2023-01-25  7:27   ` Naveen N. Rao [this message]
2023-01-25  8:31     ` arch/powerpc/kernel/head_85xx.o: warning: objtool: .head.text+0x1a6c: unannotated intra-function call Michael Ellerman
2023-01-26 18:05     ` Segher Boessenkool

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1674631223.9e09lbzzb6.naveen@linux.ibm.com \
    --to=naveen.n.rao@linux.vnet.ibm.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linuxppc-dev@lists.ozlabs.org \
    --cc=lkp@intel.com \
    --cc=npiggin@gmail.com \
    --cc=oe-kbuild-all@lists.linux.dev \
    --cc=sv@linux.ibm.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).