/* Copyright (C) 2005-2016 Free Software Foundation, Inc. This file is part of the GNU C Library. The GNU C Library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. The GNU C Library 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 Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with the GNU C Library. If not, see . */ #ifndef _LINK_H # error "Never include directly; use instead." #endif /* Registers for entry into PLT on ARM. */ typedef struct La_arm_regs { uint32_t lr_reg[4]; uint32_t lr_sp; uint32_t lr_lr; /* Coprocessor registers used for argument passing. The data stored here depends on the coprocessors available in the system which are used for function calls in the current ABI. VFP uses eight 64-bit registers, and iWMMXt uses ten. */ uint32_t lr_coproc[42]; } La_arm_regs; /* Return values for calls from PLT on ARM. */ typedef struct La_arm_retval { /* Up to four integer registers can be used for a return value in some ABIs (APCS complex long double). */ uint32_t lrv_reg[4]; /* Any coprocessor registers which might be used to return values in the current ABI. */ uint32_t lrv_coproc[12]; } La_arm_retval; __BEGIN_DECLS extern Elf32_Addr la_arm_gnu_pltenter (Elf32_Sym *__sym, unsigned int __ndx, uintptr_t *__refcook, uintptr_t *__defcook, La_arm_regs *__regs, unsigned int *__flags, const char *__symname, long int *__framesizep); extern unsigned int la_arm_gnu_pltexit (Elf32_Sym *__sym, unsigned int __ndx, uintptr_t *__refcook, uintptr_t *__defcook, const La_arm_regs *__inregs, La_arm_retval *__outregs, const char *__symname); __END_DECLS