make __{enter,leave}_vx_admin noops
[linux-2.6.git] / arch / arm / kernel / module.c
index eb9240e..298363d 100644 (file)
@@ -9,8 +9,8 @@
  *
  * Module allocation method suggested by Andi Kleen.
  */
-#include <linux/config.h>
 #include <linux/module.h>
+#include <linux/moduleloader.h>
 #include <linux/kernel.h>
 #include <linux/elf.h>
 #include <linux/vmalloc.h>
@@ -35,44 +35,16 @@ extern void _etext;
 void *module_alloc(unsigned long size)
 {
        struct vm_struct *area;
-       struct page **pages;
-       unsigned int array_size, i;
 
        size = PAGE_ALIGN(size);
        if (!size)
-               goto out_null;
+               return NULL;
 
        area = __get_vm_area(size, VM_ALLOC, MODULE_START, MODULE_END);
        if (!area)
-               goto out_null;
-
-       area->nr_pages = size >> PAGE_SHIFT;
-       array_size = area->nr_pages * sizeof(struct page *);
-       area->pages = pages = kmalloc(array_size, GFP_KERNEL);
-       if (!area->pages) {
-               remove_vm_area(area->addr);
-               kfree(area);
-               goto out_null;
-       }
-
-       memset(pages, 0, array_size);
-
-       for (i = 0; i < area->nr_pages; i++) {
-               pages[i] = alloc_page(GFP_KERNEL);
-               if (unlikely(!pages[i])) {
-                       area->nr_pages = i;
-                       goto out_no_pages;
-               }
-       }
-
-       if (map_vm_area(area, PAGE_KERNEL, &pages))
-               goto out_no_pages;
-       return area->addr;
+               return NULL;
 
- out_no_pages:
-       vfree(area->addr);
- out_null:
-       return NULL;
+       return __vmalloc_area(area, GFP_KERNEL, PAGE_KERNEL);
 }
 
 void module_free(struct module *module, void *region)
@@ -128,6 +100,8 @@ apply_relocate(Elf32_Shdr *sechdrs, const char *strtab, unsigned int symindex,
                        break;
 
                case R_ARM_PC24:
+               case R_ARM_CALL:
+               case R_ARM_JUMP24:
                        offset = (*(u32 *)loc & 0x00ffffff) << 2;
                        if (offset & 0x02000000)
                                offset -= 0x04000000;