struct elf_phdr *eppnt;
        unsigned long load_addr = 0;
        int load_addr_set = 0;
-       unsigned long last_bss = 0, elf_bss = 0;
-       int bss_prot = 0;
        unsigned long error = ~0UL;
        unsigned long total_size;
        int i;
                        else if (no_base && interp_elf_ex->e_type == ET_DYN)
                                load_addr = -vaddr;
 
-                       map_addr = elf_map(interpreter, load_addr + vaddr,
+                       map_addr = elf_load(interpreter, load_addr + vaddr,
                                        eppnt, elf_prot, elf_type, total_size);
                        total_size = 0;
                        error = map_addr;
                                error = -ENOMEM;
                                goto out;
                        }
-
-                       /*
-                        * Find the end of the file mapping for this phdr, and
-                        * keep track of the largest address we see for this.
-                        */
-                       k = load_addr + eppnt->p_vaddr + eppnt->p_filesz;
-                       if (k > elf_bss)
-                               elf_bss = k;
-
-                       /*
-                        * Do the same thing for the memory mapping - between
-                        * elf_bss and last_bss is the bss section.
-                        */
-                       k = load_addr + eppnt->p_vaddr + eppnt->p_memsz;
-                       if (k > last_bss) {
-                               last_bss = k;
-                               bss_prot = elf_prot;
-                       }
                }
        }
 
-       /*
-        * Now fill out the bss section: first pad the last page from
-        * the file up to the page boundary, and zero it from elf_bss
-        * up to the end of the page.
-        */
-       if (padzero(elf_bss)) {
-               error = -EFAULT;
-               goto out;
-       }
-       /*
-        * Next, align both the file and mem bss up to the page size,
-        * since this is where elf_bss was just zeroed up to, and where
-        * last_bss will end after the vm_brk_flags() below.
-        */
-       elf_bss = ELF_PAGEALIGN(elf_bss);
-       last_bss = ELF_PAGEALIGN(last_bss);
-       /* Finally, if there is still more bss to allocate, do it. */
-       if (last_bss > elf_bss) {
-               error = vm_brk_flags(elf_bss, last_bss - elf_bss,
-                               bss_prot & PROT_EXEC ? VM_EXEC : 0);
-               if (error)
-                       goto out;
-       }
-
        error = load_addr;
 out:
        return error;