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

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

?? dl-runtime.c

?? KPIT GNU Tools is a set of GNU development tools for Renesas microcontrollers.
?? C
字號:
/* On-demand PLT fixup for shared objects.   Copyright (C) 1995-1999, 2000, 2001 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.  */#include <alloca.h>#include <stdlib.h>#include <unistd.h>#include <ldsodefs.h>#include "dynamic-link.h"#ifndef __attribute_used__#define __attribute_used__#endif#if !defined ELF_MACHINE_NO_RELA || ELF_MACHINE_NO_REL# define PLTREL  ElfW(Rela)#else# define PLTREL  ElfW(Rel)#endif#ifndef VERSYMIDX# define VERSYMIDX(sym)	(DT_NUM + DT_THISPROCNUM + DT_VERSIONTAGIDX (sym))#endif/* This function is called through a special trampoline from the PLT the   first time each PLT entry is called.  We must perform the relocation   specified in the PLT of the given shared object, and return the resolved   function address to the trampoline, which will restart the original call   to that address.  Future calls will bounce directly from the PLT to the   function.  */#ifndef ELF_MACHINE_NO_PLTstatic ElfW(Addr) __attribute__ ((regparm (2), used))fixup (# ifdef ELF_MACHINE_RUNTIME_FIXUP_ARGS        ELF_MACHINE_RUNTIME_FIXUP_ARGS,# endif	/* GKM FIXME: Fix trampoline to pass bounds so we can do	   without the `__unbounded' qualifier.  */       struct link_map *__unbounded l, ElfW(Word) reloc_offset){  const ElfW(Sym) *const symtab    = (const void *) D_PTR (l, l_info[DT_SYMTAB]);  const char *strtab = (const void *) D_PTR (l, l_info[DT_STRTAB]);  const PLTREL *const reloc    = (const void *) (D_PTR (l, l_info[DT_JMPREL]) + reloc_offset);  const ElfW(Sym) *sym = &symtab[ELFW(R_SYM) (reloc->r_info)];  void *const rel_addr = (void *)(l->l_addr + reloc->r_offset);  lookup_t result;  ElfW(Addr) value;  /* The use of `alloca' here looks ridiculous but it helps.  The goal is     to prevent the function from being inlined and thus optimized out.     There is no official way to do this so we use this trick.  gcc never     inlines functions which use `alloca'.  */  alloca (sizeof (int));  /* Sanity check that we're really looking at a PLT relocation.  */  assert (ELFW(R_TYPE)(reloc->r_info) == ELF_MACHINE_JMP_SLOT);   /* Look up the target symbol.  If the normal lookup rules are not      used don't look in the global scope.  */  if (__builtin_expect (ELFW(ST_VISIBILITY) (sym->st_other), 0) == 0)    {      switch (l->l_info[VERSYMIDX (DT_VERSYM)] != NULL)	{	default:	  {	    const ElfW(Half) *vernum =	      (const void *) D_PTR (l, l_info[VERSYMIDX (DT_VERSYM)]);	    ElfW(Half) ndx = vernum[ELFW(R_SYM) (reloc->r_info)];	    const struct r_found_version *version = &l->l_versions[ndx];	    if (version->hash != 0)	      {		result = _dl_lookup_versioned_symbol (strtab + sym->st_name,						      l, &sym, l->l_scope,						      version,						      ELF_RTYPE_CLASS_PLT, 0);		break;	      }	  }	case 0:	  result = _dl_lookup_symbol (strtab + sym->st_name, l, &sym,				      l->l_scope, ELF_RTYPE_CLASS_PLT, 0);	}      /* Currently result contains the base load address (or link map)	 of the object that defines sym.  Now add in the symbol	 offset.  */      value = (sym ? LOOKUP_VALUE_ADDRESS (result) + sym->st_value : 0);    }  else    {      /* We already found the symbol.  The module (and therefore its load	 address) is also known.  */      value = l->l_addr + sym->st_value;#ifdef DL_LOOKUP_RETURNS_MAP      result = l;#endif    }  /* And now perhaps the relocation addend.  */  value = elf_machine_plt_value (l, reloc, value);  /* Finally, fix up the plt itself.  */  if (__builtin_expect (_dl_bind_not, 0))    return value;  return elf_machine_fixup_plt (l, result, reloc, rel_addr, value);}#endif#if !defined PROF && !defined ELF_MACHINE_NO_PLT && !__BOUNDED_POINTERS__static ElfW(Addr) __attribute__ ((regparm (3), used))profile_fixup (#ifdef ELF_MACHINE_RUNTIME_FIXUP_ARGS       ELF_MACHINE_RUNTIME_FIXUP_ARGS,#endif       struct link_map *l, ElfW(Word) reloc_offset, ElfW(Addr) retaddr){  void (*mcount_fct) (ElfW(Addr), ElfW(Addr)) = _dl_mcount;  ElfW(Addr) *resultp;  lookup_t result;  ElfW(Addr) value;  /* The use of `alloca' here looks ridiculous but it helps.  The goal is     to prevent the function from being inlined, and thus optimized out.     There is no official way to do this so we use this trick.  gcc never     inlines functions which use `alloca'.  */  alloca (sizeof (int));  /* This is the address in the array where we store the result of previous     relocations.  */  resultp = &l->l_reloc_result[reloc_offset / sizeof (PLTREL)];  value = *resultp;  if (value == 0)    {      /* This is the first time we have to relocate this object.  */      const ElfW(Sym) *const symtab	= (const void *) D_PTR (l, l_info[DT_SYMTAB]);      const char *strtab = (const void *) D_PTR (l, l_info[DT_STRTAB]);      const PLTREL *const reloc	= (const void *) (D_PTR (l, l_info[DT_JMPREL]) + reloc_offset);      const ElfW(Sym) *sym = &symtab[ELFW(R_SYM) (reloc->r_info)];      /* Sanity check that we're really looking at a PLT relocation.  */      assert (ELFW(R_TYPE)(reloc->r_info) == ELF_MACHINE_JMP_SLOT);      /* Look up the target symbol.  If the symbol is marked STV_PROTECTED	 don't look in the global scope.  */      if (__builtin_expect (ELFW(ST_VISIBILITY) (sym->st_other), 0) == 0)	{	  switch (l->l_info[VERSYMIDX (DT_VERSYM)] != NULL)	    {	    default:	      {		const ElfW(Half) *vernum =		  (const void *) D_PTR (l,l_info[VERSYMIDX (DT_VERSYM)]);		ElfW(Half) ndx = vernum[ELFW(R_SYM) (reloc->r_info)];		const struct r_found_version *version = &l->l_versions[ndx];		if (version->hash != 0)		  {		    result = _dl_lookup_versioned_symbol(strtab + sym->st_name,							 l, &sym, l->l_scope,							 version,							 ELF_RTYPE_CLASS_PLT,							 0);		    break;		  }	      }	    case 0:	      result = _dl_lookup_symbol (strtab + sym->st_name, l, &sym,					  l->l_scope, ELF_RTYPE_CLASS_PLT, 0);	    }	  /* Currently result contains the base load address (or link map)	     of the object that defines sym.  Now add in the symbol	     offset.  */	  value = (sym ? LOOKUP_VALUE_ADDRESS (result) + sym->st_value : 0);	}      else	{	  /* We already found the symbol.  The module (and therefore its load	     address) is also known.  */	  value = l->l_addr + sym->st_value;#ifdef DL_LOOKUP_RETURNS_MAP	  result = l;#endif	}      /* And now perhaps the relocation addend.  */      value = elf_machine_plt_value (l, reloc, value);      /* Store the result for later runs.  */      if (__builtin_expect (! _dl_bind_not, 1))	*resultp = value;    }  (*mcount_fct) (retaddr, value);  return value;}#endif /* PROF && ELF_MACHINE_NO_PLT *//* This macro is defined in dl-machine.h to define the entry point called   by the PLT.  The `fixup' function above does the real work, but a little   more twiddling is needed to get the stack right and jump to the address   finally resolved.  */ELF_MACHINE_RUNTIME_TRAMPOLINE

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕制服丝袜成人av| 国产精品66部| 亚洲精品乱码久久久久久黑人| 久久久久久夜精品精品免费| 精品久久久久99| 久久婷婷色综合| 国产亚洲精品精华液| 久久精品免费在线观看| 久久久久久久免费视频了| 久久综合999| 国产亚洲一二三区| 久久久久久久久久久久久夜| 久久综合狠狠综合久久综合88| 久久精品视频在线免费观看| 日本一区二区三区电影| 国产精品乱码人人做人人爱 | 久久美女高清视频| 久久日韩粉嫩一区二区三区| 国产日产亚洲精品系列| 国产精品国产三级国产有无不卡 | 亚洲卡通动漫在线| 亚洲国产日韩综合久久精品| 亚洲成人一区在线| 欧美久久一区二区| 日韩精品一区二| 国产欧美一区二区精品性| 国产精品国产a| 亚洲综合视频网| 免费成人av在线| 国产黄色91视频| 色综合久久久久综合体桃花网| 欧美在线观看18| 3atv一区二区三区| 久久久三级国产网站| 日韩毛片在线免费观看| 午夜视频在线观看一区二区| 久久99精品国产.久久久久久| 国产美女在线观看一区| 色综合久久天天| 欧美v日韩v国产v| 亚洲色图视频网| 美女尤物国产一区| 99精品久久久久久| 制服丝袜亚洲播放| 中文字幕久久午夜不卡| 亚洲高清免费在线| 国产在线不卡一区| 91成人免费电影| 精品久久人人做人人爽| 日韩理论片一区二区| 理论片日本一区| 色综合天天天天做夜夜夜夜做| 欧美一区二区成人6969| 自拍偷拍亚洲激情| 久久超级碰视频| 91黄色免费看| 欧美激情在线看| 青青青伊人色综合久久| hitomi一区二区三区精品| 欧美一区二区三区四区久久| 国产精品久久毛片av大全日韩| 日韩精品电影一区亚洲| 成人av在线网| 日韩精品一区二区三区swag| 一区二区三区精品视频在线| 国产不卡视频在线播放| 欧美一区二区精品| 一区二区三区成人在线视频| 国产黄色91视频| 日韩午夜精品电影| 亚洲一区二区视频| 99久久精品国产精品久久| 久久伊人蜜桃av一区二区| 亚洲成人一区二区| 一本色道综合亚洲| 欧美高清在线精品一区| 老司机免费视频一区二区三区| 在线免费观看视频一区| 国产精品萝li| 国产精品99精品久久免费| 欧美成人一级视频| 日本视频在线一区| 欧美日韩精品三区| 亚洲综合色噜噜狠狠| 97国产精品videossex| 国产不卡视频在线观看| 精品国产一区二区三区av性色 | 成人午夜电影网站| 日韩欧美电影在线| 日韩av网站在线观看| 欧美日韩精品专区| 亚洲乱码中文字幕| 91网站在线观看视频| 成人免费一区二区三区视频| 国产suv精品一区二区三区| 日韩精品专区在线影院观看| 日韩av午夜在线观看| 9191成人精品久久| 日韩av在线发布| 欧美一级一区二区| 日韩高清在线不卡| 欧美一区二区三区日韩视频| 日韩国产精品大片| 欧美一区二区三区在线电影| 美女任你摸久久 | 亚洲男同性视频| 成av人片一区二区| 中文字幕佐山爱一区二区免费| a美女胸又www黄视频久久| 国产亚洲人成网站| 国产iv一区二区三区| 国产清纯白嫩初高生在线观看91 | 欧洲精品中文字幕| 亚洲综合久久久久| 欧美色男人天堂| 亚洲国产wwwccc36天堂| 欧美日韩国产成人在线免费| 午夜电影网亚洲视频| 日韩欧美一区在线| 国内精品国产成人| 中文字幕av一区二区三区免费看 | 91亚洲精品乱码久久久久久蜜桃| 成人免费观看av| 亚洲人成网站精品片在线观看 | 国产精品美女久久久久高潮| eeuss鲁片一区二区三区在线看| 综合婷婷亚洲小说| 欧美性受xxxx| 另类成人小视频在线| 国产欧美精品区一区二区三区| 91污在线观看| 日韩高清在线一区| 国产日产欧美一区二区视频| 91免费视频网址| 午夜视频在线观看一区| 久久综合久久99| 日本韩国欧美国产| 久久精品国产澳门| 国产精品你懂的在线欣赏| 欧美又粗又大又爽| 精品一二三四区| 自拍av一区二区三区| 欧美一区二区三区婷婷月色| 国产99精品在线观看| 亚洲国产精品久久人人爱蜜臀| 日韩免费看网站| caoporn国产精品| 日本亚洲三级在线| 中文字幕一区二区三区在线播放 | 欧美va亚洲va香蕉在线| av在线一区二区三区| 男女男精品视频| 国产精品不卡在线| 欧美精品国产精品| 欧美激情自拍偷拍| 欧美日韩中文另类| 国产成人av一区二区三区在线| 一级中文字幕一区二区| 精品国产网站在线观看| 日本高清不卡视频| 国产老女人精品毛片久久| 亚洲国产成人av网| 国产精品免费人成网站| 日韩免费高清电影| 欧美丝袜自拍制服另类| 久久国产精品99久久人人澡| 亚洲激情中文1区| 久久新电视剧免费观看| 欧美剧在线免费观看网站 | 久久久久久久国产精品影院| 91成人国产精品| 成人精品亚洲人成在线| 麻豆成人av在线| 一级精品视频在线观看宜春院 | 舔着乳尖日韩一区| 国产精品久久久久精k8| 久久女同精品一区二区| 884aa四虎影成人精品一区| 成人app在线| 国产精品538一区二区在线| 日av在线不卡| 图片区日韩欧美亚洲| 亚洲激情欧美激情| 国产精品美女久久久久久久 | 国产嫩草影院久久久久| 日韩午夜在线影院| 777亚洲妇女| 欧美日韩在线亚洲一区蜜芽| 99国产精品久| 粉嫩嫩av羞羞动漫久久久| 精品一区二区影视| 免费精品视频在线| 日本欧美在线看| 男女性色大片免费观看一区二区 | 免费在线看成人av| 亚洲激情校园春色| 一区二区三区四区视频精品免费 | 91麻豆精东视频| 成人h动漫精品一区二区| 国产传媒久久文化传媒|