@@ -6,6 +6,7 @@
#ifndef __ASSEMBLY__
+#include <linux/module.h>
#include <linux/spinlock.h>
#include <asm/pgtable.h>
#include <linux/xarray.h>
@@ -81,6 +82,26 @@ extern int asi_map_range(struct asi *asi, void *ptr, size_t size,
extern int asi_map(struct asi *asi, void *ptr, unsigned long size);
/*
+ * Copy the memory mapping for the current module. This is defined as a
+ * macro to ensure it is expanded in the module making the call so that
+ * THIS_MODULE has the correct value.
+ */
+#define ASI_MAP_THIS_MODULE(asi) \
+ (asi_map(asi, THIS_MODULE->core_layout.base, \
+ THIS_MODULE->core_layout.size))
+
+static inline int asi_map_module(struct asi *asi, char *module_name)
+{
+ struct module *module;
+
+ module = find_module(module_name);
+ if (!module)
+ return -ESRCH;
+
+ return asi_map(asi, module->core_layout.base, module->core_layout.size);
+}
+
+/*
* Function to exit the current isolation. This is used to abort isolation
* when a task using isolation is scheduled out.
*/
Add helper functions to easily map a module into an ASI. Signed-off-by: Alexandre Chartre <alexandre.chartre@oracle.com> --- arch/x86/include/asm/asi.h | 21 +++++++++++++++++++++ 1 files changed, 21 insertions(+), 0 deletions(-)