/* * loader.h: prototypes for linux-user guest binary loader * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, see . */ #ifndef LINUX_USER_LOADER_H #define LINUX_USER_LOADER_H typedef struct { const void *cache; unsigned int cache_size; int fd; } ImageSource; /** * imgsrc_read: Read from ImageSource * @dst: destination for read * @offset: offset within file for read * @len: size of the read * @img: ImageSource to read from * @errp: Error details. * * Read into @dst, using the cache when possible. */ bool imgsrc_read(void *dst, off_t offset, size_t len, const ImageSource *img, Error **errp); /** * imgsrc_read_alloc: Read from ImageSource * @offset: offset within file for read * @size: size of the read * @img: ImageSource to read from * @errp: Error details. * * Read into newly allocated memory, using the cache when possible. */ void *imgsrc_read_alloc(off_t offset, size_t len, const ImageSource *img, Error **errp); /** * imgsrc_mmap: Map from ImageSource * * If @src has a file descriptor, pass on to target_mmap. Otherwise, * this is "mapping" from a host buffer, which resolves to memcpy. * Therefore, flags must be MAP_PRIVATE | MAP_FIXED; the argument is * retained for clarity. */ abi_long imgsrc_mmap(abi_ulong start, abi_ulong len, int prot, int flags, const ImageSource *src, abi_ulong offset); /* * Read a good amount of data initially, to hopefully get all the * program headers loaded. */ #define BPRM_BUF_SIZE 1024 /* * This structure is used to hold the arguments that are * used when loading binaries. */ struct linux_binprm { char buf[BPRM_BUF_SIZE] __attribute__((aligned)); ImageSource src; abi_ulong p; int e_uid, e_gid; int argc, envc; char **argv; char **envp; char *filename; /* Name of binary */ int (*core_dump)(int, const CPUArchState *); /* coredump routine */ }; abi_ulong loader_build_argptr(int envc, int argc, abi_ulong sp, abi_ulong stringp, int push_ptr); int loader_exec(int fdexec, const char *filename, char **argv, char **envp, struct image_info *infop, struct linux_binprm *); uint32_t get_elf_eflags(int fd); int load_elf_binary(struct linux_binprm *bprm, struct image_info *info); int load_flt_binary(struct linux_binprm *bprm, struct image_info *info); abi_long memcpy_to_target(abi_ulong dest, const void *src, unsigned long len); extern unsigned long guest_stack_size; /* Note that Elf32 and Elf64 use uint32_t for e_flags. */ const char *get_elf_cpu_model(uint32_t eflags); abi_ulong get_elf_hwcap(CPUState *cs); abi_ulong get_elf_hwcap2(CPUState *cs); const char *elf_hwcap_str(uint32_t bit); const char *elf_hwcap2_str(uint32_t bit); const char *get_elf_platform(CPUState *cs); const char *get_elf_base_platform(CPUState *cs); bool init_guest_commpage(void); struct target_elf_gregset_t; void elf_core_copy_regs(struct target_elf_gregset_t *, const CPUArchState *); typedef struct { const uint8_t *image; const uint32_t *relocs; unsigned image_size; unsigned reloc_count; unsigned sigreturn_ofs; unsigned rt_sigreturn_ofs; } VdsoImageInfo; /* Note that both Elf32_Word and Elf64_Word are uint32_t. */ const VdsoImageInfo *get_vdso_image_info(uint32_t elf_flags); bool arch_parse_elf_property(uint32_t pr_type, uint32_t pr_datasz, const uint32_t *data, struct image_info *info, Error **errp); #endif /* LINUX_USER_LOADER_H */