#include <linux/module.h>
 #include <linux/types.h>
 #include <linux/io.h>
+#include <linux/mm.h>
 #include "nfit_test.h"
 
 static LIST_HEAD(iomap_head);
 }
 EXPORT_SYMBOL(nfit_test_teardown);
 
-static struct nfit_test_resource *get_nfit_res(resource_size_t resource)
+static struct nfit_test_resource *__get_nfit_res(resource_size_t resource)
 {
        struct iomap_ops *ops;
 
        return NULL;
 }
 
-void __iomem *__nfit_test_ioremap(resource_size_t offset, unsigned long size,
-               void __iomem *(*fallback_fn)(resource_size_t, unsigned long))
+static struct nfit_test_resource *get_nfit_res(resource_size_t resource)
 {
-       struct nfit_test_resource *nfit_res;
+       struct nfit_test_resource *res;
 
        rcu_read_lock();
-       nfit_res = get_nfit_res(offset);
+       res = __get_nfit_res(resource);
        rcu_read_unlock();
+
+       return res;
+}
+
+void __iomem *__nfit_test_ioremap(resource_size_t offset, unsigned long size,
+               void __iomem *(*fallback_fn)(resource_size_t, unsigned long))
+{
+       struct nfit_test_resource *nfit_res = get_nfit_res(offset);
+
        if (nfit_res)
                return (void __iomem *) nfit_res->buf + offset
                        - nfit_res->res->start;
 void __iomem *__wrap_devm_ioremap_nocache(struct device *dev,
                resource_size_t offset, unsigned long size)
 {
-       struct nfit_test_resource *nfit_res;
+       struct nfit_test_resource *nfit_res = get_nfit_res(offset);
 
-       rcu_read_lock();
-       nfit_res = get_nfit_res(offset);
-       rcu_read_unlock();
        if (nfit_res)
                return (void __iomem *) nfit_res->buf + offset
                        - nfit_res->res->start;
 void *__wrap_devm_memremap(struct device *dev, resource_size_t offset,
                size_t size, unsigned long flags)
 {
-       struct nfit_test_resource *nfit_res;
+       struct nfit_test_resource *nfit_res = get_nfit_res(offset);
 
-       rcu_read_lock();
-       nfit_res = get_nfit_res(offset);
-       rcu_read_unlock();
        if (nfit_res)
                return nfit_res->buf + offset - nfit_res->res->start;
        return devm_memremap(dev, offset, size, flags);
                struct percpu_ref *ref, struct vmem_altmap *altmap)
 {
        resource_size_t offset = res->start;
-       struct nfit_test_resource *nfit_res;
+       struct nfit_test_resource *nfit_res = get_nfit_res(offset);
 
-       rcu_read_lock();
-       nfit_res = get_nfit_res(offset);
-       rcu_read_unlock();
        if (nfit_res)
                return nfit_res->buf + offset - nfit_res->res->start;
        return devm_memremap_pages(dev, res, ref, altmap);
 
 pfn_t __wrap_phys_to_pfn_t(dma_addr_t addr, unsigned long flags)
 {
-       struct nfit_test_resource *nfit_res;
+       struct nfit_test_resource *nfit_res = get_nfit_res(addr);
 
-       rcu_read_lock();
-       nfit_res = get_nfit_res(addr);
-       rcu_read_unlock();
        if (nfit_res)
                flags &= ~PFN_MAP;
         return phys_to_pfn_t(addr, flags);
 void *__wrap_devm_memremap_pages(struct device *dev, struct resource *res)
 {
        resource_size_t offset = res->start;
-       struct nfit_test_resource *nfit_res;
+       struct nfit_test_resource *nfit_res = get_nfit_res(offset);
 
-       rcu_read_lock();
-       nfit_res = get_nfit_res(offset);
-       rcu_read_unlock();
        if (nfit_res)
                return nfit_res->buf + offset - nfit_res->res->start;
        return devm_memremap_pages(dev, res);
 void *__wrap_memremap(resource_size_t offset, size_t size,
                unsigned long flags)
 {
-       struct nfit_test_resource *nfit_res;
+       struct nfit_test_resource *nfit_res = get_nfit_res(offset);
 
-       rcu_read_lock();
-       nfit_res = get_nfit_res(offset);
-       rcu_read_unlock();
        if (nfit_res)
                return nfit_res->buf + offset - nfit_res->res->start;
        return memremap(offset, size, flags);
 
 void __wrap_devm_memunmap(struct device *dev, void *addr)
 {
-       struct nfit_test_resource *nfit_res;
+       struct nfit_test_resource *nfit_res = get_nfit_res((long) addr);
 
-       rcu_read_lock();
-       nfit_res = get_nfit_res((unsigned long) addr);
-       rcu_read_unlock();
        if (nfit_res)
                return;
        return devm_memunmap(dev, addr);
 
 void __wrap_iounmap(volatile void __iomem *addr)
 {
-       struct nfit_test_resource *nfit_res;
-
-       rcu_read_lock();
-       nfit_res = get_nfit_res((unsigned long) addr);
-       rcu_read_unlock();
+       struct nfit_test_resource *nfit_res = get_nfit_res((long) addr);
        if (nfit_res)
                return;
        return iounmap(addr);
 
 void __wrap_memunmap(void *addr)
 {
-       struct nfit_test_resource *nfit_res;
+       struct nfit_test_resource *nfit_res = get_nfit_res((long) addr);
 
-       rcu_read_lock();
-       nfit_res = get_nfit_res((unsigned long) addr);
-       rcu_read_unlock();
        if (nfit_res)
                return;
        return memunmap(addr);
        struct nfit_test_resource *nfit_res;
 
        if (parent == &iomem_resource) {
-               rcu_read_lock();
                nfit_res = get_nfit_res(start);
-               rcu_read_unlock();
                if (nfit_res) {
                        struct resource *res = nfit_res->res + 1;
 
        struct nfit_test_resource *nfit_res;
 
        if (parent == &iomem_resource) {
-               rcu_read_lock();
                nfit_res = get_nfit_res(start);
-               rcu_read_unlock();
                if (nfit_res) {
                        struct resource *res = nfit_res->res + 1;