@@ -361,6 +361,7 @@ enum {
int region_intersects(resource_size_t offset, size_t size, const char *type,
unsigned long flags);
int region_intersects_ram(resource_size_t offset, size_t size);
+int region_intersects_pmem(resource_size_t offset, size_t size);
/* Support for virtually mapped pages */
struct page *vmalloc_to_page(const void *addr);
@@ -547,6 +547,18 @@ int region_intersects_ram(resource_size_t start, size_t size)
IORESOURCE_MEM | IORESOURCE_BUSY);
}
+/*
+ * region_intersects_pmem() checks if a specified address range is
+ * persistent memory, registered as "Persistent Memory", in the
+ * iomem_resource list.
+ */
+int region_intersects_pmem(resource_size_t start, size_t size)
+{
+ return region_intersects(start, size, "Persistent Memory",
+ IORESOURCE_MEM);
+}
+EXPORT_SYMBOL_GPL(region_intersects_pmem);
+
void __weak arch_remove_reservations(struct resource *avail)
{
}
Add region_intersects_pmem(), which checks if a specified address range is persistent memory registered as "Persistent Memory" in the iomem_resource list. Note, it does not support legacy persistent memory registered as "Persistent Memory (legacy)". It can be supported by extending this function or a separate function, if necessary. This interface is exported so that it can be called from modules, such as the EINJ driver. Signed-off-by: Toshi Kani <toshi.kani@hpe.com> --- include/linux/mm.h | 1 + kernel/resource.c | 12 ++++++++++++ 2 files changed, 13 insertions(+)