Commit 30066dcd authored by Toshi Kani's avatar Toshi Kani Committed by Greg Kroah-Hartman

devm_memremap_release(): fix memremap'd addr handling

commit 9273a8bb upstream.

The pmem driver calls devm_memremap() to map a persistent memory range.
When the pmem driver is unloaded, this memremap'd range is not released
so the kernel will leak a vma.

Fix devm_memremap_release() to handle a given memremap'd address
properly.
Signed-off-by: default avatarToshi Kani <toshi.kani@hpe.com>
Acked-by: default avatarDan Williams <dan.j.williams@intel.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Ross Zwisler <ross.zwisler@linux.intel.com>
Cc: Matthew Wilcox <willy@linux.intel.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 15db15e2
...@@ -111,7 +111,7 @@ EXPORT_SYMBOL(memunmap); ...@@ -111,7 +111,7 @@ EXPORT_SYMBOL(memunmap);
static void devm_memremap_release(struct device *dev, void *res) static void devm_memremap_release(struct device *dev, void *res)
{ {
memunmap(res); memunmap(*(void **)res);
} }
static int devm_memremap_match(struct device *dev, void *res, void *match_data) static int devm_memremap_match(struct device *dev, void *res, void *match_data)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment