亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dl-machine.h

?? glibc2.5版源代碼
?? H
?? 第 1 頁 / 共 2 頁
字號:
/* Machine-dependent ELF dynamic relocation inline functions.  Sparc64 version.   Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006	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, write to the Free   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA   02111-1307 USA.  */#ifndef dl_machine_h#define dl_machine_h#define ELF_MACHINE_NAME "sparc64"#include <string.h>#include <sys/param.h>#include <ldsodefs.h>#include <sysdep.h>#ifndef VALIDX# define VALIDX(tag) (DT_NUM + DT_THISPROCNUM + DT_VERSIONTAGNUM \		      + DT_EXTRANUM + DT_VALTAGIDX (tag))#endif#define ELF64_R_TYPE_ID(info)	((info) & 0xff)#define ELF64_R_TYPE_DATA(info) ((info) >> 8)/* Return nonzero iff ELF header is compatible with the running host.  */static inline intelf_machine_matches_host (const Elf64_Ehdr *ehdr){  return ehdr->e_machine == EM_SPARCV9;}/* We have to do this because elf_machine_{dynamic,load_address} can be   invoked from functions that have no GOT references, and thus the compiler   has no obligation to load the PIC register.  */#define LOAD_PIC_REG(PIC_REG)	\do {	Elf64_Addr tmp;		\	__asm("sethi %%hi(_GLOBAL_OFFSET_TABLE_-4), %1\n\t" \	      "rd %%pc, %0\n\t" \	      "add %1, %%lo(_GLOBAL_OFFSET_TABLE_+4), %1\n\t" \	      "add %0, %1, %0" \	      : "=r" (PIC_REG), "=r" (tmp)); \} while (0)/* Return the link-time address of _DYNAMIC.  Conveniently, this is the   first element of the GOT.  This must be inlined in a function which   uses global data.  */static inline Elf64_Addrelf_machine_dynamic (void){  register Elf64_Addr *elf_pic_register __asm__("%l7");  LOAD_PIC_REG (elf_pic_register);  return *elf_pic_register;}/* Return the run-time load address of the shared object.  */static inline Elf64_Addrelf_machine_load_address (void){  register Elf32_Addr *pc __asm ("%o7");  register Elf64_Addr *got __asm ("%l7");  __asm ("sethi %%hi(_GLOBAL_OFFSET_TABLE_-4), %1\n\t"         "call 1f\n\t"         " add %1, %%lo(_GLOBAL_OFFSET_TABLE_+4), %1\n\t"         "call _DYNAMIC\n\t"         "call _GLOBAL_OFFSET_TABLE_\n"         "1:\tadd %1, %0, %1\n\t" : "=r" (pc), "=r" (got));  /* got is now l_addr + _GLOBAL_OFFSET_TABLE_     *got is _DYNAMIC     pc[2]*4 is l_addr + _DYNAMIC - (long)pc - 8     pc[3]*4 is l_addr + _GLOBAL_OFFSET_TABLE_ - (long)pc - 12  */  return (Elf64_Addr) got - *got + (Elf32_Sword) ((pc[2] - pc[3]) * 4) - 4;}/* We have 4 cases to handle.  And we code different code sequences   for each one.  I love V9 code models...  */static inline void __attribute__ ((always_inline))sparc64_fixup_plt (struct link_map *map, const Elf64_Rela *reloc,		   Elf64_Addr *reloc_addr, Elf64_Addr value,		   Elf64_Addr high, int t){  unsigned int *insns = (unsigned int *) reloc_addr;  Elf64_Addr plt_vaddr = (Elf64_Addr) reloc_addr;  Elf64_Sxword disp = value - plt_vaddr;  /* Now move plt_vaddr up to the call instruction.  */  plt_vaddr += ((t + 1) * 4);  /* PLT entries .PLT32768 and above look always the same.  */  if (__builtin_expect (high, 0) != 0)    {      *reloc_addr = value - map->l_addr;    }  /* Near destination.  */  else if (disp >= -0x800000 && disp < 0x800000)    {      /* As this is just one instruction, it is thread safe and so	 we can avoid the unnecessary sethi FOO, %g1.	 b,a target  */      insns[0] = 0x30800000 | ((disp >> 2) & 0x3fffff);      __asm __volatile ("flush %0" : : "r" (insns));    }  /* 32-bit Sparc style, the target is in the lower 32-bits of     address space.  */  else if (insns += t, (value >> 32) == 0)    {      /* sethi	%hi(target), %g1	 jmpl	%g1 + %lo(target), %g0  */      insns[1] = 0x81c06000 | (value & 0x3ff);      __asm __volatile ("flush %0 + 4" : : "r" (insns));      insns[0] = 0x03000000 | ((unsigned int)(value >> 10));      __asm __volatile ("flush %0" : : "r" (insns));    }  /* We can also get somewhat simple sequences if the distance between     the target and the PLT entry is within +/- 2GB.  */  else if ((plt_vaddr > value	    && ((plt_vaddr - value) >> 31) == 0)	   || (value > plt_vaddr	       && ((value - plt_vaddr) >> 31) == 0))    {      unsigned int displacement;      if (plt_vaddr > value)	displacement = (0 - (plt_vaddr - value));      else	displacement = value - plt_vaddr;      /* mov	%o7, %g1	 call	displacement	  mov	%g1, %o7  */      insns[2] = 0x9e100001;      __asm __volatile ("flush %0 + 8" : : "r" (insns));      insns[1] = 0x40000000 | (displacement >> 2);      __asm __volatile ("flush %0 + 4" : : "r" (insns));      insns[0] = 0x8210000f;      __asm __volatile ("flush %0" : : "r" (insns));    }  /* Worst case, ho hum...  */  else    {      unsigned int high32 = (value >> 32);      unsigned int low32 = (unsigned int) value;      /* ??? Some tricks can be stolen from the sparc64 egcs backend	     constant formation code I wrote.  -DaveM  */      if (__builtin_expect (high32 & 0x3ff, 0))	{	  /* sethi	%hh(value), %g1	     sethi	%lm(value), %g5	     or		%g1, %hm(value), %g1	     or		%g5, %lo(value), %g5	     sllx	%g1, 32, %g1	     jmpl	%g1 + %g5, %g0	      nop  */	  insns[5] = 0x81c04005;	  __asm __volatile ("flush %0 + 20" : : "r" (insns));	  insns[4] = 0x83287020;	  __asm __volatile ("flush %0 + 16" : : "r" (insns));	  insns[3] = 0x8a116000 | (low32 & 0x3ff);	  __asm __volatile ("flush %0 + 12" : : "r" (insns));	  insns[2] = 0x82106000 | (high32 & 0x3ff);	}      else	{	  /* sethi	%hh(value), %g1	     sethi	%lm(value), %g5	     sllx	%g1, 32, %g1	     or		%g5, %lo(value), %g5	     jmpl	%g1 + %g5, %g0	      nop  */	  insns[4] = 0x81c04005;	  __asm __volatile ("flush %0 + 16" : : "r" (insns));	  insns[3] = 0x8a116000 | (low32 & 0x3ff);	  __asm __volatile ("flush %0 + 12" : : "r" (insns));	  insns[2] = 0x83287020;	}      __asm __volatile ("flush %0 + 8" : : "r" (insns));      insns[1] = 0x0b000000 | (low32 >> 10);      __asm __volatile ("flush %0 + 4" : : "r" (insns));      insns[0] = 0x03000000 | (high32 >> 10);      __asm __volatile ("flush %0" : : "r" (insns));    }}static inline Elf64_Addr __attribute__ ((always_inline))elf_machine_fixup_plt (struct link_map *map, lookup_t t,		       const Elf64_Rela *reloc,		       Elf64_Addr *reloc_addr, Elf64_Addr value){  sparc64_fixup_plt (map, reloc, reloc_addr, value + reloc->r_addend,		     reloc->r_addend, 1);  return value;}/* Return the final value of a plt relocation.  */static inline Elf64_Addrelf_machine_plt_value (struct link_map *map, const Elf64_Rela *reloc,		       Elf64_Addr value){  /* Don't add addend here, but in elf_machine_fixup_plt instead.     value + reloc->r_addend is the value which should actually be     stored into .plt data slot.  */  return value;}/* ELF_RTYPE_CLASS_PLT iff TYPE describes relocation of a PLT entry, so   PLT entries should not be allowed to define the value.   ELF_RTYPE_CLASS_NOCOPY iff TYPE should not be allowed to resolve to one   of the main executable's symbols, as for a COPY reloc.  */#if defined USE_TLS && (!defined RTLD_BOOTSTRAP || USE___THREAD)# define elf_machine_type_class(type) \  ((((type) == R_SPARC_JMP_SLOT						      \     || ((type) >= R_SPARC_TLS_GD_HI22 && (type) <= R_SPARC_TLS_TPOFF64))     \    * ELF_RTYPE_CLASS_PLT)						      \   | (((type) == R_SPARC_COPY) * ELF_RTYPE_CLASS_COPY))#else# define elf_machine_type_class(type) \  ((((type) == R_SPARC_JMP_SLOT) * ELF_RTYPE_CLASS_PLT)	\   | (((type) == R_SPARC_COPY) * ELF_RTYPE_CLASS_COPY))#endif/* A reloc type used for ld.so cmdline arg lookups to reject PLT entries.  */#define ELF_MACHINE_JMP_SLOT	R_SPARC_JMP_SLOT/* The SPARC never uses Elf64_Rel relocations.  */#define ELF_MACHINE_NO_REL 1/* The SPARC overlaps DT_RELA and DT_PLTREL.  */#define ELF_MACHINE_PLTREL_OVERLAP 1/* Set up the loaded object described by L so its unrelocated PLT   entries will jump to the on-demand fixup code in dl-runtime.c.  */static inline intelf_machine_runtime_setup (struct link_map *l, int lazy, int profile){  if (l->l_info[DT_JMPREL] && lazy)    {      extern void _dl_runtime_resolve_0 (void);      extern void _dl_runtime_resolve_1 (void);      extern void _dl_runtime_profile_0 (void);      extern void _dl_runtime_profile_1 (void);      Elf64_Addr res0_addr, res1_addr;      unsigned int *plt = (void *) D_PTR (l, l_info[DT_PLTGOT]);      if (__builtin_expect(profile, 0))	{	  res0_addr = (Elf64_Addr) &_dl_runtime_profile_0;	  res1_addr = (Elf64_Addr) &_dl_runtime_profile_1;	  if (GLRO(dl_profile) != NULL	      && _dl_name_match_p (GLRO(dl_profile), l))	    GL(dl_profile_map) = l;	}      else	{	  res0_addr = (Elf64_Addr) &_dl_runtime_resolve_0;	  res1_addr = (Elf64_Addr) &_dl_runtime_resolve_1;	}      /* PLT0 looks like:         sethi	%uhi(_dl_runtime_{resolve,profile}_0), %g4	 sethi	%hi(_dl_runtime_{resolve,profile}_0), %g5	 or	%g4, %ulo(_dl_runtime_{resolve,profile}_0), %g4	 or	%g5, %lo(_dl_runtime_{resolve,profile}_0), %g5	 sllx	%g4, 32, %g4	 add	%g4, %g5, %g5	 jmpl	%g5, %g4	  nop       */      plt[0] = 0x09000000 | (res0_addr >> (64 - 22));      plt[1] = 0x0b000000 | ((res0_addr >> 10) & 0x003fffff);      plt[2] = 0x88112000 | ((res0_addr >> 32) & 0x3ff);      plt[3] = 0x8a116000 | (res0_addr & 0x3ff);      plt[4] = 0x89293020;      plt[5] = 0x8a010005;      plt[6] = 0x89c14000;      plt[7] = 0x01000000;      /* PLT1 looks like:         sethi	%uhi(_dl_runtime_{resolve,profile}_1), %g4	 sethi	%hi(_dl_runtime_{resolve,profile}_1), %g5	 or	%g4, %ulo(_dl_runtime_{resolve,profile}_1), %g4	 or	%g5, %lo(_dl_runtime_{resolve,profile}_1), %g5	 sllx	%g4, 32, %g4	 add	%g4, %g5, %g5	 jmpl	%g5, %g4	  nop       */      plt[8] = 0x09000000 | (res1_addr >> (64 - 22));      plt[9] = 0x0b000000 | ((res1_addr >> 10) & 0x003fffff);      plt[10] = 0x88112000 | ((res1_addr >> 32) & 0x3ff);      plt[11] = 0x8a116000 | (res1_addr & 0x3ff);      plt[12] = 0x89293020;      plt[13] = 0x8a010005;      plt[14] = 0x89c14000;      plt[15] = 0x01000000;      /* Now put the magic cookie at the beginning of .PLT2	 Entry .PLT3 is unused by this implementation.  */      *((struct link_map **)(&plt[16])) = l;      if (__builtin_expect (l->l_info[VALIDX(DT_GNU_PRELINKED)] != NULL, 0)	  || __builtin_expect (l->l_info [VALIDX (DT_GNU_LIBLISTSZ)] != NULL, 0))	{	  /* Need to reinitialize .plt to undo prelinking.  */	  Elf64_Rela *rela = (Elf64_Rela *) D_PTR (l, l_info[DT_JMPREL]);	  Elf64_Rela *relaend	    = (Elf64_Rela *) ((char *) rela			      + l->l_info[DT_PLTRELSZ]->d_un.d_val);	  /* prelink must ensure there are no R_SPARC_NONE relocs left	     in .rela.plt.  */	  while (rela < relaend)	    {	      if (__builtin_expect (rela->r_addend, 0) != 0)		{                  Elf64_Addr slot = ((rela->r_offset + 0x400				      - (Elf64_Addr) plt)				     / 0x1400) * 0x1400				    + (Elf64_Addr) plt - 0x400;		  /* ldx [%o7 + X], %g1  */		  unsigned int first_ldx = *(unsigned int *)(slot + 12);		  Elf64_Addr ptr = slot + (first_ldx & 0xfff) + 4;		  *(Elf64_Addr *) rela->r_offset		    = (Elf64_Addr) plt		      - (slot + ((rela->r_offset - ptr) / 8) * 24 + 4);		  ++rela;		  continue;		}	      *(unsigned int *) rela->r_offset		= 0x03000000 | (rela->r_offset - (Elf64_Addr) plt);	      *(unsigned int *) (rela->r_offset + 4)		= 0x30680000 | ((((Elf64_Addr) plt + 32				  - rela->r_offset - 4) >> 2) & 0x7ffff);	      __asm __volatile ("flush %0" : : "r" (rela->r_offset));	      __asm __volatile ("flush %0+4" : : "r" (rela->r_offset));	      ++rela;	    }	}    }  return lazy;}/* The PLT uses Elf64_Rela relocs.  */#define elf_machine_relplt elf_machine_rela

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www久久精品| 亚洲欧美激情在线| 中文字幕在线不卡国产视频| 欧美日韩电影在线| 国产欧美一区视频| 三级精品在线观看| 97精品国产97久久久久久久久久久久| 91精品国产乱| 亚洲综合色在线| 成人免费高清在线观看| 日韩欧美123| 五月天中文字幕一区二区| 欧美激情在线免费观看| 蜜桃精品视频在线| 欧美日韩国产另类一区| 亚洲男人天堂av网| voyeur盗摄精品| 久久久精品免费免费| 精品一区二区免费| 日韩一级片在线播放| 亚洲超碰97人人做人人爱| 一区二区三区免费| 92国产精品观看| 国产精品免费丝袜| 成人三级伦理片| 久久综合给合久久狠狠狠97色69| 天天影视色香欲综合网老头| 视频一区在线播放| 欧美日韩亚洲另类| 丝袜美腿一区二区三区| 欧美日韩国产电影| 日本午夜一区二区| 日韩欧美黄色影院| 久久99精品一区二区三区| 日韩视频永久免费| 久久国产精品无码网站| 精品国产一二三| 久久精品人人做人人综合| 精品在线免费视频| 久久久久久99久久久精品网站| 卡一卡二国产精品| 337p粉嫩大胆色噜噜噜噜亚洲 | 欧美日韩亚洲综合在线 | 色综合久久99| 亚洲黄色小视频| 亚洲一区二区精品视频| 欧美精品一二三四| 青青青爽久久午夜综合久久午夜| 日韩午夜在线观看| 国产一区二区三区四区五区美女 | 欧美日韩一区二区在线观看| 丝袜美腿亚洲一区二区图片| 日韩精品一区二区在线| 国产福利91精品一区| 国产精品久久久久影院色老大| 97久久精品人人做人人爽50路| 一区二区高清在线| 六月丁香婷婷色狠狠久久| 国产亚洲精久久久久久| 色婷婷亚洲一区二区三区| 日韩精品电影在线| 久久综合色天天久久综合图片| 国产成人精品午夜视频免费| 日韩理论片在线| 日韩欧美国产三级电影视频| 成人性生交大片免费看在线播放| 亚洲一区中文日韩| 精品国产sm最大网站| 亚洲视频你懂的| 91麻豆精品国产自产在线| 国产不卡视频一区| 亚洲成人久久影院| 国产情人综合久久777777| 欧美体内she精视频| 国产激情偷乱视频一区二区三区| 一区二区三区在线观看网站| 国产美女久久久久| 亚洲国产另类av| 久久久久久毛片| 欧美精品久久99久久在免费线| 国产一区999| 青青草国产成人av片免费| 综合网在线视频| 久久久蜜臀国产一区二区| 欧美日韩美女一区二区| 不卡的电视剧免费网站有什么| 日韩三级视频在线观看| 色老头久久综合| 顶级嫩模精品视频在线看| 日本不卡高清视频| 亚洲国产精品欧美一二99| 欧美激情一区二区三区| 欧美videos大乳护士334| 欧美午夜精品一区二区蜜桃| 成人国产视频在线观看| 国产在线视频不卡二| 三级亚洲高清视频| 亚洲va韩国va欧美va| 色呦呦一区二区三区| 国产a精品视频| 精品在线播放免费| 久久精品国产成人一区二区三区| 亚洲成在线观看| 一区二区三区四区五区视频在线观看| 成人小视频免费观看| 国产精品一区2区| 精品一区二区三区视频在线观看 | 91精品欧美福利在线观看| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 99久久久久久| 成人av在线资源| 国产1区2区3区精品美女| 国产一区二区三区在线观看免费 | 国产免费成人在线视频| 久久男人中文字幕资源站| 日韩欧美成人激情| 成人久久18免费网站麻豆| 成人免费看的视频| av亚洲精华国产精华精| 91官网在线观看| 91视频在线看| 日本黄色一区二区| 欧美性大战久久久久久久| 亚洲国产另类av| 午夜影院久久久| 人人爽香蕉精品| 国内精品国产三级国产a久久| 久久成人羞羞网站| 国产伦精品一区二区三区免费迷 | 首页国产欧美日韩丝袜| 久久精工是国产品牌吗| 国产精品一区免费视频| 成人免费观看视频| 欧美亚男人的天堂| 欧美一区二区视频网站| 国产成人精品午夜视频免费| 91一区二区在线| 在线观看免费成人| 日韩午夜激情电影| 中文字幕乱码一区二区免费| 亚洲色图在线播放| 日本免费新一区视频| 亚洲人妖av一区二区| 首页欧美精品中文字幕| 国产福利不卡视频| 欧美体内she精高潮| 精品国产乱码久久久久久浪潮| 欧美激情在线免费观看| 亚洲综合清纯丝袜自拍| 国产精品久久午夜| 日韩高清电影一区| 成人永久aaa| 日韩欧美自拍偷拍| 日韩一区欧美一区| 九色|91porny| 欧美亚洲国产一卡| 国产欧美精品在线观看| 欧美日韩1234| 中文字幕精品一区| 视频一区视频二区在线观看| 白白色亚洲国产精品| 91精品婷婷国产综合久久| 亚洲女人小视频在线观看| 激情欧美一区二区| 一二三区精品视频| 国产成人三级在线观看| 欧美色视频一区| 国产精品国产三级国产a| 看国产成人h片视频| 欧美三级电影网| 国产精品国产三级国产aⅴ原创| 天天射综合影视| 91黄视频在线| 国产精品久久久久影院色老大 | 9191久久久久久久久久久| 国产女人18毛片水真多成人如厕 | 欧美在线不卡视频| 国产欧美日韩不卡免费| 狂野欧美性猛交blacked| 欧美日韩第一区日日骚| 一区二区三区精品| 国产91精品欧美| 福利电影一区二区| 日韩免费观看2025年上映的电影 | 亚洲色图清纯唯美| 成人午夜激情影院| 日本一区二区久久| 国产精品一区二区三区四区| 欧美日韩1区2区| 6080亚洲精品一区二区| 亚洲综合久久久久| 欧美亚洲丝袜传媒另类| 日韩伦理免费电影| 91老师国产黑色丝袜在线| 欧美高清在线一区| av高清不卡在线| 亚洲欧洲一区二区在线播放| 一区二区成人在线视频 | 亚洲成人午夜电影| 欧美网站大全在线观看|