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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? dl-machine.h

?? glibc 庫, 不僅可以學(xué)習(xí)使用庫函數(shù),還可以學(xué)習(xí)函數(shù)的具體實(shí)現(xiàn),是提高功力的好資料
?? H
?? 第 1 頁 / 共 2 頁
字號(hào):
/* 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 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

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美一级精品久久| 国产精品久久福利| bt7086福利一区国产| 午夜久久久久久电影| 国产女人18毛片水真多成人如厕| 欧美性一二三区| 成人污视频在线观看| 日本亚洲天堂网| 亚洲精品日韩综合观看成人91| 精品国精品国产尤物美女| 在线观看不卡视频| 国产·精品毛片| 久久97超碰国产精品超碰| 一级精品视频在线观看宜春院| 中文字幕乱码亚洲精品一区| 欧美一区二区三区四区高清| 色综合色综合色综合色综合色综合| 国产一区二区三区国产| 天堂午夜影视日韩欧美一区二区| 亚洲欧美综合色| 欧美极品另类videosde| 欧美成人r级一区二区三区| 91行情网站电视在线观看高清版| 国产精品一二二区| 激情成人午夜视频| 九九**精品视频免费播放| 亚洲bdsm女犯bdsm网站| 亚洲一区在线观看免费观看电影高清| 国产欧美一区二区精品久导航 | 欧美r级在线观看| 欧美私模裸体表演在线观看| 色综合中文字幕| 成人av在线资源网| 成人中文字幕在线| 国产精品一二三四五| 国产一区二区在线观看免费| 蜜桃av一区二区| 青青草原综合久久大伊人精品 | 国产一区二区剧情av在线| 蜜桃av一区二区在线观看| 日本亚洲欧美天堂免费| 免费观看一级欧美片| 视频一区二区国产| 五月天亚洲婷婷| 视频一区二区三区中文字幕| 三级久久三级久久| 午夜私人影院久久久久| 日韩电影在线免费| 青草国产精品久久久久久| 蜜桃一区二区三区在线| 国产在线视频不卡二| 精品在线播放午夜| 国产精品一区免费视频| 国产不卡在线播放| a4yy欧美一区二区三区| 欧美自拍偷拍一区| 56国语精品自产拍在线观看| 91精品国产色综合久久ai换脸 | 欧美一区二视频| 日韩欧美一区在线| 久久蜜桃av一区精品变态类天堂| 国产日韩成人精品| 亚洲精品乱码久久久久久黑人| 一区二区三区在线视频免费| 亚洲成年人影院| 激情av综合网| 91偷拍与自偷拍精品| 在线不卡免费av| 久久美女艺术照精彩视频福利播放| 国产午夜三级一区二区三| 亚洲欧洲性图库| 亚洲va欧美va人人爽| 韩国精品久久久| 91色乱码一区二区三区| 欧美一区二区视频在线观看| 国产午夜久久久久| 怡红院av一区二区三区| 久久99热国产| 99国产欧美久久久精品| 91精品国产入口在线| 国产欧美日韩麻豆91| 亚洲小少妇裸体bbw| 精品一区二区三区久久| 成人国产精品免费| 69堂精品视频| 国产精品久久久久久久第一福利| 丝袜美腿亚洲综合| 国产麻豆精品95视频| 91久久精品日日躁夜夜躁欧美| 日韩一区二区不卡| 亚洲人被黑人高潮完整版| 久色婷婷小香蕉久久| 色诱视频网站一区| 精品国产百合女同互慰| 一区二区三区精密机械公司| 国产一区二区三区视频在线播放| 91成人免费电影| 国产女主播一区| 奇米影视一区二区三区| 97se亚洲国产综合自在线| 日韩欧美中文字幕制服| 亚洲综合色区另类av| 丁香六月久久综合狠狠色| 日韩一区二区三区三四区视频在线观看 | 91亚洲男人天堂| 日韩你懂的在线观看| 夜夜精品视频一区二区| 国产成人av一区二区三区在线观看| 欧美日韩色综合| 国产精品久久久久一区二区三区共| 美国十次了思思久久精品导航| 色女孩综合影院| 国产精品久久久久久久久免费相片| 美日韩一区二区| 欧美欧美欧美欧美首页| 亚洲精品日韩综合观看成人91| 国产高清久久久| 精品国产乱码久久久久久老虎| 亚洲一区电影777| 色综合色综合色综合| 国产精品婷婷午夜在线观看| 黄网站免费久久| 日韩久久精品一区| 日本亚洲天堂网| 欧美巨大另类极品videosbest | 久久综合九色综合欧美亚洲| 日韩电影在线一区二区| 欧美日韩国产免费一区二区| 亚洲精品va在线观看| 91麻豆精东视频| 亚洲欧美另类综合偷拍| 色综合久久天天| 亚洲精品乱码久久久久久 | 久久综合丝袜日本网| 免费精品视频在线| 日韩三级在线免费观看| 日本伊人色综合网| 日韩精品专区在线影院观看| 奇米四色…亚洲| 欧美不卡视频一区| 国产一区二区三区日韩| 欧美激情综合五月色丁香小说| 国产成人午夜高潮毛片| 中文一区二区完整视频在线观看| 国产成人综合在线播放| 欧美国产一区二区| 不卡av电影在线播放| 中文字幕在线不卡视频| 色综合久久久久| 亚洲v日本v欧美v久久精品| 欧美久久久久中文字幕| 免费成人小视频| 久久久青草青青国产亚洲免观| 国产69精品久久久久777| 亚洲欧洲美洲综合色网| 色噜噜狠狠成人中文综合| 午夜亚洲福利老司机| 精品欧美黑人一区二区三区| 国产精品一区二区黑丝| 亚洲三级在线观看| 欧美日韩一区二区在线视频| 狂野欧美性猛交blacked| 久久精品视频网| 91麻豆国产在线观看| 天天操天天干天天综合网| 精品三级av在线| av亚洲精华国产精华| 亚洲国产精品视频| 久久综合九色综合欧美亚洲| 不卡的av电影| 天堂成人免费av电影一区| 久久精品人人做人人综合| 日本道在线观看一区二区| 美女在线视频一区| 国产精品你懂的| 欧美夫妻性生活| 成人精品免费看| 日韩黄色免费电影| 国产精品区一区二区三| 欧美日韩在线一区二区| 国产一区二区三区四| 一区二区三区久久| 久久亚洲影视婷婷| 欧美视频中文一区二区三区在线观看 | 91精品国产综合久久蜜臀| 国产99久久久国产精品免费看| 一区二区三区中文免费| 精品福利二区三区| 欧美伊人久久久久久久久影院| 国产又黄又大久久| 亚洲一区二区三区四区在线免费观看 | 久久久久久亚洲综合| 欧美私模裸体表演在线观看| 国产999精品久久久久久绿帽| 亚洲国产婷婷综合在线精品| 亚洲国产精品国自产拍av| 91麻豆精品国产91久久久久| 91网站最新网址| 国产不卡在线视频| 久久国产夜色精品鲁鲁99|