linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* Re: [PATCH v4] powerpc: Avoid code patching freed init sections
       [not found] <20180914011411.3184-1-mikey__14553.8904158913$1536887645$gmane$org@neuling.org>
@ 2018-10-02 21:35 ` Andreas Schwab
  2018-10-03  1:57   ` Michael Neuling
  2018-10-03  3:20   ` Michael Ellerman
       [not found] ` <871s98av6p.fsf__4781.35763337395$1538516654$gmane$org@igel.home>
  1 sibling, 2 replies; 7+ messages in thread
From: Andreas Schwab @ 2018-10-02 21:35 UTC (permalink / raw)
  To: Michael Neuling
  Cc: Michal Suchánek, linuxppc-dev, Haren Myneni, Nicholas Piggin

On Sep 14 2018, Michael Neuling <mikey@neuling.org> wrote:

> This stops us from doing code patching in init sections after they've
> been freed.

This breaks booting on PowerBook6,7, crashing very early.

Andreas.

-- 
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510  2552 DF73 E780 A9DA AEC1
"And now for something completely different."

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [PATCH] powerpc: use PTRRELOC during early init
       [not found] ` <871s98av6p.fsf__4781.35763337395$1538516654$gmane$org@igel.home>
@ 2018-10-02 22:33   ` Andreas Schwab
  2018-10-03  6:22     ` Christophe LEROY
  0 siblings, 1 reply; 7+ messages in thread
From: Andreas Schwab @ 2018-10-02 22:33 UTC (permalink / raw)
  To: Michael Neuling
  Cc: Michal Suchánek, linuxppc-dev, Nicholas Piggin, Haren Myneni

This fixes a crash on powerpc32 when using global data during early init
without relocating its address.

Fixes: 51c3c62b58 (powerpc: Avoid code patching freed init sections)
Signed-off-by: Andreas Schwab <schwab@linux-m68k.org>
---
 arch/powerpc/lib/code-patching.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/arch/powerpc/lib/code-patching.c b/arch/powerpc/lib/code-patching.c
index 6ae2777c22..6192fdae36 100644
--- a/arch/powerpc/lib/code-patching.c
+++ b/arch/powerpc/lib/code-patching.c
@@ -29,7 +29,7 @@ static int __patch_instruction(unsigned int *exec_addr, unsigned int instr,
 	int err;
 
 	/* Make sure we aren't patching a freed init section */
-	if (init_mem_is_free && init_section_contains(exec_addr, 4)) {
+	if (*PTRRELOC(&init_mem_is_free) && init_section_contains(exec_addr, 4)) {
 		pr_debug("Skipping init section patching addr: 0x%px\n", exec_addr);
 		return 0;
 	}
-- 
2.19.0

-- 
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510  2552 DF73 E780 A9DA AEC1
"And now for something completely different."

^ permalink raw reply related	[flat|nested] 7+ messages in thread

* Re: [PATCH v4] powerpc: Avoid code patching freed init sections
  2018-10-02 21:35 ` [PATCH v4] powerpc: Avoid code patching freed init sections Andreas Schwab
@ 2018-10-03  1:57   ` Michael Neuling
  2018-10-03  3:20   ` Michael Ellerman
  1 sibling, 0 replies; 7+ messages in thread
From: Michael Neuling @ 2018-10-03  1:57 UTC (permalink / raw)
  To: Andreas Schwab, Christophe Leroy
  Cc: Michal Suchánek, linuxppc-dev, Haren Myneni, Nicholas Piggin

On Tue, 2018-10-02 at 23:35 +0200, Andreas Schwab wrote:
> On Sep 14 2018, Michael Neuling <mikey@neuling.org> wrote:
> 
> > This stops us from doing code patching in init sections after they've
> > been freed.
> 
> This breaks booting on PowerBook6,7, crashing very early.

Sorry, Can you try?

http://patchwork.ozlabs.org/patch/977195/

Mikey

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v4] powerpc: Avoid code patching freed init sections
  2018-10-02 21:35 ` [PATCH v4] powerpc: Avoid code patching freed init sections Andreas Schwab
  2018-10-03  1:57   ` Michael Neuling
@ 2018-10-03  3:20   ` Michael Ellerman
  2018-10-03  5:42     ` Christophe LEROY
  1 sibling, 1 reply; 7+ messages in thread
From: Michael Ellerman @ 2018-10-03  3:20 UTC (permalink / raw)
  To: Andreas Schwab, Michael Neuling
  Cc: Michal Suchánek, linuxppc-dev, Haren Myneni, Nicholas Piggin

Andreas Schwab <schwab@linux-m68k.org> writes:

> On Sep 14 2018, Michael Neuling <mikey@neuling.org> wrote:
>
>> This stops us from doing code patching in init sections after they've
>> been freed.
>
> This breaks booting on PowerBook6,7, crashing very early.

Crud, sorry.

My CI setup tests with the mac99 qemu model, but that boots happily, not
sure why.

cheers

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v4] powerpc: Avoid code patching freed init sections
  2018-10-03  3:20   ` Michael Ellerman
@ 2018-10-03  5:42     ` Christophe LEROY
  0 siblings, 0 replies; 7+ messages in thread
From: Christophe LEROY @ 2018-10-03  5:42 UTC (permalink / raw)
  To: Michael Ellerman, Andreas Schwab, Michael Neuling
  Cc: Michal Suchánek, linuxppc-dev, Nicholas Piggin, Haren Myneni



Le 03/10/2018 à 05:20, Michael Ellerman a écrit :
> Andreas Schwab <schwab@linux-m68k.org> writes:
> 
>> On Sep 14 2018, Michael Neuling <mikey@neuling.org> wrote:
>>
>>> This stops us from doing code patching in init sections after they've
>>> been freed.
>>
>> This breaks booting on PowerBook6,7, crashing very early.
> 
> Crud, sorry.
> 
> My CI setup tests with the mac99 qemu model, but that boots happily, not
> sure why.

Maybe mac99 doesn't use relocation ?

The issue is that during early boot, 'init_mem_is_free' is not yet at 
its definitif address.

I sent a fix for it : https://patchwork.ozlabs.org/patch/977195/

Christophe

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH] powerpc: use PTRRELOC during early init
  2018-10-02 22:33   ` [PATCH] powerpc: use PTRRELOC during early init Andreas Schwab
@ 2018-10-03  6:22     ` Christophe LEROY
  2018-10-03 11:18       ` Andreas Schwab
  0 siblings, 1 reply; 7+ messages in thread
From: Christophe LEROY @ 2018-10-03  6:22 UTC (permalink / raw)
  To: Andreas Schwab, Michael Neuling
  Cc: Michal Suchánek, linuxppc-dev, Haren Myneni, Nicholas Piggin

Hi Andreas,

Le 03/10/2018 à 00:33, Andreas Schwab a écrit :
> This fixes a crash on powerpc32 when using global data during early init
> without relocating its address.
> 
> Fixes: 51c3c62b58 (powerpc: Avoid code patching freed init sections)
> Signed-off-by: Andreas Schwab <schwab@linux-m68k.org>
> ---
>   arch/powerpc/lib/code-patching.c | 2 +-
>   1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/arch/powerpc/lib/code-patching.c b/arch/powerpc/lib/code-patching.c
> index 6ae2777c22..6192fdae36 100644
> --- a/arch/powerpc/lib/code-patching.c
> +++ b/arch/powerpc/lib/code-patching.c
> @@ -29,7 +29,7 @@ static int __patch_instruction(unsigned int *exec_addr, unsigned int instr,
>   	int err;
>   
>   	/* Make sure we aren't patching a freed init section */
> -	if (init_mem_is_free && init_section_contains(exec_addr, 4)) {
> +	if (*PTRRELOC(&init_mem_is_free) && init_section_contains(exec_addr, 4)) {

That's not the best solution. In the past we already did our best to 
separate early use of patch_instruction() , that's how 
raw_patch_instruction() was born, see 
https://patchwork.ozlabs.org/patch/840974/

Here, it idea is similar, this test should not apply to 
raw_patch_instruction()

Did you try my proposed fix https://patchwork.ozlabs.org/patch/977195/ ?

Christophe

>   		pr_debug("Skipping init section patching addr: 0x%px\n", exec_addr);
>   		return 0;
>   	}
> 

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH] powerpc: use PTRRELOC during early init
  2018-10-03  6:22     ` Christophe LEROY
@ 2018-10-03 11:18       ` Andreas Schwab
  0 siblings, 0 replies; 7+ messages in thread
From: Andreas Schwab @ 2018-10-03 11:18 UTC (permalink / raw)
  To: Christophe LEROY
  Cc: Michael Neuling, Michal Suchánek, linuxppc-dev, Haren Myneni,
	Nicholas Piggin

On Okt 03 2018, Christophe LEROY <christophe.leroy@c-s.fr> wrote:

> Did you try my proposed fix https://patchwork.ozlabs.org/patch/977195/ ?

That works as well.

Andreas.

-- 
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510  2552 DF73 E780 A9DA AEC1
"And now for something completely different."

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2018-10-03 11:21 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <20180914011411.3184-1-mikey__14553.8904158913$1536887645$gmane$org@neuling.org>
2018-10-02 21:35 ` [PATCH v4] powerpc: Avoid code patching freed init sections Andreas Schwab
2018-10-03  1:57   ` Michael Neuling
2018-10-03  3:20   ` Michael Ellerman
2018-10-03  5:42     ` Christophe LEROY
     [not found] ` <871s98av6p.fsf__4781.35763337395$1538516654$gmane$org@igel.home>
2018-10-02 22:33   ` [PATCH] powerpc: use PTRRELOC during early init Andreas Schwab
2018-10-03  6:22     ` Christophe LEROY
2018-10-03 11:18       ` Andreas Schwab

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).