linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] of: Print rather than WARN'ing when overlap check fails
@ 2015-11-10  5:08 Michael Ellerman
  2015-11-10  9:28 ` Michael Ellerman
  2015-11-10  9:41 ` David Laight
  0 siblings, 2 replies; 4+ messages in thread
From: Michael Ellerman @ 2015-11-10  5:08 UTC (permalink / raw)
  To: robh+dt
  Cc: devicetree, linux-kernel, linuxppc-dev, mitchelh, frowand.list,
	grant.likely

__rmem_check_for_overlap() is called very early in boot, and on some
powerpc systems it's not safe to call WARN that early in boot.

If the overlap check fails the system will oops instead of printing a
warning. Furthermore because it's so early in boot the console is not up
and the user doesn't see the oops, they just get a dead system.

Fix it by printing an error instead of calling WARN.

Fixes: ae1add247bf8 ("of: Check for overlap in reserved memory regions")
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
---
 drivers/of/of_reserved_mem.c | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)

diff --git a/drivers/of/of_reserved_mem.c b/drivers/of/of_reserved_mem.c
index 62f467b8ccae..49703916a30e 100644
--- a/drivers/of/of_reserved_mem.c
+++ b/drivers/of/of_reserved_mem.c
@@ -226,10 +226,9 @@ static void __init __rmem_check_for_overlap(void)
 
 			this_end = this->base + this->size;
 			next_end = next->base + next->size;
-			WARN(1,
-			     "Reserved memory: OVERLAP DETECTED!\n%s (%pa--%pa) overlaps with %s (%pa--%pa)\n",
-			     this->name, &this->base, &this_end,
-			     next->name, &next->base, &next_end);
+			pr_err("Reserved memory: OVERLAP DETECTED!\n%s (%pa--%pa) overlaps with %s (%pa--%pa)\n",
+			       this->name, &this->base, &this_end,
+			       next->name, &next->base, &next_end);
 		}
 	}
 }
-- 
2.5.0

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

* Re: [PATCH] of: Print rather than WARN'ing when overlap check fails
  2015-11-10  5:08 [PATCH] of: Print rather than WARN'ing when overlap check fails Michael Ellerman
@ 2015-11-10  9:28 ` Michael Ellerman
  2015-11-10  9:41 ` David Laight
  1 sibling, 0 replies; 4+ messages in thread
From: Michael Ellerman @ 2015-11-10  9:28 UTC (permalink / raw)
  To: robh+dt
  Cc: devicetree, linux-kernel, linuxppc-dev, mitchelh, frowand.list,
	grant.likely

On Tue, 2015-11-10 at 16:08 +1100, Michael Ellerman wrote:

> __rmem_check_for_overlap() is called very early in boot, and on some
> powerpc systems it's not safe to call WARN that early in boot.
> 
> If the overlap check fails the system will oops instead of printing a
> warning. Furthermore because it's so early in boot the console is not up
> and the user doesn't see the oops, they just get a dead system.
> 
> Fix it by printing an error instead of calling WARN.
> 
> Fixes: ae1add247bf8 ("of: Check for overlap in reserved memory regions")
> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
> ---
>  drivers/of/of_reserved_mem.c | 7 +++----
>  1 file changed, 3 insertions(+), 4 deletions(-)

I forgot to say, I assume you're OK to merge this and get it to Linus soonish?
Otherwise I can stuff it in a fix branch and ask Linus to pull that. Let me
know which you'd prefer.

cheers

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

* RE: [PATCH] of: Print rather than WARN'ing when overlap check fails
  2015-11-10  5:08 [PATCH] of: Print rather than WARN'ing when overlap check fails Michael Ellerman
  2015-11-10  9:28 ` Michael Ellerman
@ 2015-11-10  9:41 ` David Laight
  2015-11-10 21:47   ` Michael Ellerman
  1 sibling, 1 reply; 4+ messages in thread
From: David Laight @ 2015-11-10  9:41 UTC (permalink / raw)
  To: 'Michael Ellerman', robh+dt@kernel.org
  Cc: devicetree@vger.kernel.org, frowand.list@gmail.com,
	linux-kernel@vger.kernel.org, linuxppc-dev@ozlabs.org,
	grant.likely@linaro.org, mitchelh@codeaurora.org

RnJvbTogTWljaGFlbCBFbGxlcm1hbg0KPiBTZW50OiAxMCBOb3ZlbWJlciAyMDE1IDA1OjA5DQo+
IF9fcm1lbV9jaGVja19mb3Jfb3ZlcmxhcCgpIGlzIGNhbGxlZCB2ZXJ5IGVhcmx5IGluIGJvb3Qs
IGFuZCBvbiBzb21lDQo+IHBvd2VycGMgc3lzdGVtcyBpdCdzIG5vdCBzYWZlIHRvIGNhbGwgV0FS
TiB0aGF0IGVhcmx5IGluIGJvb3QuDQo+IA0KPiBJZiB0aGUgb3ZlcmxhcCBjaGVjayBmYWlscyB0
aGUgc3lzdGVtIHdpbGwgb29wcyBpbnN0ZWFkIG9mIHByaW50aW5nIGENCj4gd2FybmluZy4gRnVy
dGhlcm1vcmUgYmVjYXVzZSBpdCdzIHNvIGVhcmx5IGluIGJvb3QgdGhlIGNvbnNvbGUgaXMgbm90
IHVwDQo+IGFuZCB0aGUgdXNlciBkb2Vzbid0IHNlZSB0aGUgb29wcywgdGhleSBqdXN0IGdldCBh
IGRlYWQgc3lzdGVtLg0KDQpXb3VsZG4ndCBpdCBiZSBiZXR0ZXIgdG8gYWRkIHRoZSByZXF1aXJl
ZCBjaGVja3MgdG8gV0FSTigpPw0KVGhhdCB3b3VsZCBzdG9wIHRoZSBzYW1lIHByb2JsZW0gaGFw
cGVuaW5nIGVsc2V3aGVyZS4NCg0KCURhdmlkDQoNCg==

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

* Re: [PATCH] of: Print rather than WARN'ing when overlap check fails
  2015-11-10  9:41 ` David Laight
@ 2015-11-10 21:47   ` Michael Ellerman
  0 siblings, 0 replies; 4+ messages in thread
From: Michael Ellerman @ 2015-11-10 21:47 UTC (permalink / raw)
  To: David Laight, robh+dt@kernel.org
  Cc: devicetree@vger.kernel.org, frowand.list@gmail.com,
	linux-kernel@vger.kernel.org, linuxppc-dev@ozlabs.org,
	grant.likely@linaro.org, mitchelh@codeaurora.org

On Tue, 2015-11-10 at 09:41 +0000, David Laight wrote:

> From: Michael Ellerman

> > Sent: 10 November 2015 05:09
> > __rmem_check_for_overlap() is called very early in boot, and on some
> > powerpc systems it's not safe to call WARN that early in boot.
> > 
> > If the overlap check fails the system will oops instead of printing a
> > warning. Furthermore because it's so early in boot the console is not up
> > and the user doesn't see the oops, they just get a dead system.
> 
> Wouldn't it be better to add the required checks to WARN()?

Yes obviously it would. But that's less simple than it sounds. I'm working on
it.

cheers

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

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

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-11-10  5:08 [PATCH] of: Print rather than WARN'ing when overlap check fails Michael Ellerman
2015-11-10  9:28 ` Michael Ellerman
2015-11-10  9:41 ` David Laight
2015-11-10 21:47   ` Michael Ellerman

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