Lines Matching full:ef

63 #define VECTX_HANDLE(ef) (ef)->vctx  argument
65 #define VECTX_HANDLE(ef) (ef)->fd argument
68 static int __elfN(obj_loadimage)(struct preloaded_file *mp, elf_file_t ef,
70 static int __elfN(obj_lookup_set)(struct preloaded_file *mp, elf_file_t ef,
72 static int __elfN(obj_reloc_ptr)(struct preloaded_file *mp, elf_file_t ef,
75 elf_file_t ef);
76 static Elf_Addr __elfN(obj_symaddr)(struct elf_file *ef, Elf_Size symidx);
88 struct elf_file ef; in __elfN() local
94 bzero(&ef, sizeof(struct elf_file)); in __elfN()
101 if ((ef.fd = open(filename, O_RDONLY)) == -1) in __elfN()
107 ef.vctx = vectx_open(ef.fd, filename, 0L, NULL, &verror, __func__); in __elfN()
110 close(ef.fd); in __elfN()
111 free(ef.vctx); in __elfN()
117 hdr = &ef.hdr; in __elfN()
118 bytes_read = VECTX_READ(VECTX_HANDLE(&ef), hdr, sizeof(*hdr)); in __elfN()
146 if (verify_file(ef.fd, filename, bytes_read, VE_MUST, __func__) < 0) { in __elfN()
178 fp->f_size = __elfN(obj_loadimage)(fp, &ef, dest); in __elfN()
196 if (!err && ef.vctx) { in __elfN()
199 verror = vectx_close(ef.vctx, VE_MUST, __func__); in __elfN()
206 close(ef.fd); in __elfN()
207 if (ef.e_shdr != NULL) in __elfN()
208 free(ef.e_shdr); in __elfN()
218 __elfN(obj_loadimage)(struct preloaded_file *fp, elf_file_t ef, uint64_t off) in __elfN()
227 hdr = &ef->hdr; in __elfN()
228 ef->off = (vm_offset_t)off; in __elfN()
232 shdr = alloc_pread(VECTX_HANDLE(ef), (off_t)hdr->e_shoff, shdrbytes); in __elfN()
238 ef->e_shdr = shdr; in __elfN()
273 ef->symtabindex = i; in __elfN()
282 lastaddr = roundup(lastaddr, shdr[ef->symtabindex].sh_addralign); in __elfN()
283 shdr[ef->symtabindex].sh_addr = (Elf_Addr)lastaddr; in __elfN()
284 lastaddr += shdr[ef->symtabindex].sh_size; in __elfN()
286 symstrindex = shdr[ef->symtabindex].sh_link; in __elfN()
304 ef->shstrindex = hdr->e_shstrndx; in __elfN()
305 lastaddr = roundup(lastaddr, shdr[ef->shstrindex].sh_addralign); in __elfN()
306 shdr[ef->shstrindex].sh_addr = (Elf_Addr)lastaddr; in __elfN()
307 lastaddr += shdr[ef->shstrindex].sh_size; in __elfN()
353 if (kern_pread(VECTX_HANDLE(ef), (vm_offset_t)cshdr->sh_addr, in __elfN()
363 res = __elfN(obj_parse_modmetadata)(fp, ef); in __elfN()
389 __elfN(obj_parse_modmetadata)(struct preloaded_file *fp, elf_file_t ef) in __elfN()
401 if (__elfN(obj_lookup_set)(fp, ef, "modmetadata_set", &p, &p_stop, in __elfN()
408 error = __elfN(obj_reloc_ptr)(fp, ef, p, &v, sizeof(v)); in __elfN()
413 error = __elfN(obj_reloc_ptr)(fp, ef, v, &md64, sizeof(md64)); in __elfN()
422 error = __elfN(obj_reloc_ptr)(fp, ef, v, &md, sizeof(md)); in __elfN()
461 __elfN(obj_lookup_set)(struct preloaded_file *fp, elf_file_t ef, in __elfN()
470 hdr = &ef->hdr; in __elfN()
471 shdr = ef->e_shdr; in __elfN()
472 shstrtab = shdr[ef->shstrindex].sh_addr; in __elfN()
499 __elfN(obj_reloc_ptr)(struct preloaded_file *mp, elf_file_t ef, Elf_Addr p, in __elfN()
510 hdr = &ef->hdr; in __elfN()
511 shdr = ef->e_shdr; in __elfN()
531 error = __elfN(reloc)(ef, __elfN(obj_symaddr), in __elfN()
544 error = __elfN(reloc)(ef, __elfN(obj_symaddr), in __elfN()
557 __elfN(obj_symaddr)(struct elf_file *ef, Elf_Size symidx) in __elfN()
562 if (symidx >= ef->e_shdr[ef->symtabindex].sh_size / sizeof(Elf_Sym)) in __elfN()
564 COPYOUT(ef->e_shdr[ef->symtabindex].sh_addr + symidx * sizeof(Elf_Sym), in __elfN()
566 if (sym.st_shndx == SHN_UNDEF || sym.st_shndx >= ef->hdr.e_shnum) in __elfN()
568 base = ef->e_shdr[sym.st_shndx].sh_addr; in __elfN()