linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] devm_memremap: Fix error value when memremap failed
@ 2016-02-06  1:40 Toshi Kani
  2016-02-06  1:24 ` Ross Zwisler
  2016-02-06  1:49 ` Dan Williams
  0 siblings, 2 replies; 4+ messages in thread
From: Toshi Kani @ 2016-02-06  1:40 UTC (permalink / raw)
  To: akpm, dan.j.williams; +Cc: linux-nvdimm, linux-mm, linux-kernel, Toshi Kani

devm_memremap() returns an ERR_PTR() value in case of error.
However, it returns NULL when memremap() failed.  This causes
the caller, such as the pmem driver, to proceed and oops later.

Change devm_memremap() to return ERR_PTR(-ENXIO) when memremap()
failed.

Signed-off-by: Toshi Kani <toshi.kani@hpe.com>
Cc: Dan Williams <dan.j.williams@intel.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
---
 kernel/memremap.c |    4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/kernel/memremap.c b/kernel/memremap.c
index 70ee377..3427cca 100644
--- a/kernel/memremap.c
+++ b/kernel/memremap.c
@@ -136,8 +136,10 @@ void *devm_memremap(struct device *dev, resource_size_t offset,
 	if (addr) {
 		*ptr = addr;
 		devres_add(dev, ptr);
-	} else
+	} else {
 		devres_free(ptr);
+		return ERR_PTR(-ENXIO);
+	}
 
 	return addr;
 }

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>

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

end of thread, other threads:[~2016-02-06  1:52 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-02-06  1:40 [PATCH] devm_memremap: Fix error value when memremap failed Toshi Kani
2016-02-06  1:24 ` Ross Zwisler
2016-02-06  1:49 ` Dan Williams
2016-02-06  1:52   ` Dan Williams

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox