| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005 | diff --git a/Makeconfig b/Makeconfigindex 1908f27..cf34ba1 100644--- a/Makeconfig+++ b/Makeconfig@@ -775,7 +775,8 @@ endif	# $(+cflags) == "" # current directory. +includes = -I$(..)include $(if $(subdir),$(objpfx:%/=-I%)) \ 	    $(+sysdep-includes) $(includes) \-	    $(patsubst %/,-I%,$(..)) $(libio-include) -I. $(sysincludes)+	    $(patsubst %/,-I%,$(..)) $(libio-include) -I. $(sysincludes) \+	    -I$(common-objpfx)../shim/include  # Since libio has several internal header files, we use a -I instead # of many little headers in the include directory.@@ -1033,7 +1034,7 @@ all-subdirs = csu assert ctype locale intl catgets math setjmp signal	    \ 	      grp pwd posix io termios resource misc socket sysvipc gmon    \ 	      gnulib iconv iconvdata wctype manual shadow gshadow po argp   \ 	      crypt localedata timezone rt conform debug		    \-	      $(add-on-subdirs) dlfcn elf+	      $(add-on-subdirs) dlfcn elf libos  ifndef avoid-generated # sysd-sorted itself will contain rules making the sysd-sorted targetdiff --git a/Makefile b/Makefileindex 51d4690..d72c4b0 100644--- a/Makefile+++ b/Makefile@@ -177,6 +177,8 @@ $(inst_includedir)/gnu/stubs.h: $(+force) install-others-nosubdir: $(installed-stubs) endif +# For Graphene+CFLAGS-syscalldb.c = -fPIC  # Since stubs.h is never needed when building the library, we simplify the # hairy installation process by producing it in place only as the last partdiff --git a/Versions.def b/Versions.defindex 759c754..e1a270e 100644--- a/Versions.def+++ b/Versions.def@@ -41,6 +41,7 @@ libc {   GCC_3.0 %endif   GLIBC_PRIVATE+  SHIM } libcrypt {   GLIBC_2.0@@ -50,6 +51,7 @@ libdl {   GLIBC_2.1   GLIBC_2.3.3   GLIBC_2.3.4+  SHIM } libm {   GLIBC_2.0@@ -108,6 +110,7 @@ libpthread {   GLIBC_2.18   GLIBC_2.19   GLIBC_PRIVATE+  SHIM } libresolv {   GLIBC_2.0@@ -135,6 +138,7 @@ ld {   GLIBC_2.3   GLIBC_2.4   GLIBC_PRIVATE+  SHIM } libthread_db {   GLIBC_2.1.3@@ -148,3 +152,6 @@ libanl { libcidn {   GLIBC_PRIVATE }+liblibos {+  GLIBC_2.12+}diff --git a/configure b/configureindex fc023d0..b71c1f9 100755--- a/configure+++ b/configure@@ -630,7 +630,8 @@ SED MAKEINFO MSGFMT MAKE-LD+LD_GOLD+LD_BFD AS OBJCOPY OBJDUMP@@ -4593,17 +4594,22 @@ if test $ac_verc_fail = yes; then   AS=: critic_missing="$critic_missing as" fi -for ac_prog in $LD+LD_BFD=+LD_GOLD=+ld_is_gold="`$LD --version | sed -n 's/^GNU \(gold\).*$/\1/p'`"+if test -z "$ld_is_gold"; then+  LD_BFD=$LD+  for ac_prog in $LD_BFD do   # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; }-if ${ac_cv_prog_LD+:} false; then :+if ${ac_cv_prog_LD_BFD+:} false; then :   $as_echo_n "(cached) " >&6 else-  if test -n "$LD"; then-  ac_cv_prog_LD="$LD" # Let the user override the test.+  if test -n "$LD_BFD"; then+  ac_cv_prog_LD_BFD="$LD_BFD" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH@@ -4612,7 +4618,7 @@ do   test -z "$as_dir" && as_dir=.     for ac_exec_ext in '' $ac_executable_extensions; do   if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then-    ac_cv_prog_LD="$ac_prog"+    ac_cv_prog_LD_BFD="$ac_prog"     $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5     break 2   fi@@ -4622,26 +4628,26 @@ IFS=$as_save_IFS  fi fi-LD=$ac_cv_prog_LD-if test -n "$LD"; then-  { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LD" >&5-$as_echo "$LD" >&6; }+LD_BFD=$ac_cv_prog_LD_BFD+if test -n "$LD_BFD"; then+  { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LD_BFD" >&5+$as_echo "$LD_BFD" >&6; } else   { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 $as_echo "no" >&6; } fi  -  test -n "$LD" && break+  test -n "$LD_BFD" && break done -if test -z "$LD"; then+if test -z "$LD_BFD"; then   ac_verc_fail=yes else   # Found it, now check the version.-  { $as_echo "$as_me:${as_lineno-$LINENO}: checking version of $LD" >&5-$as_echo_n "checking version of $LD... " >&6; }-  ac_prog_version=`$LD --version 2>&1 | sed -n 's/^.*GNU ld.* \([0-9][0-9]*\.[0-9.]*\).*$/\1/p'`+  { $as_echo "$as_me:${as_lineno-$LINENO}: checking version of $LD_BFD" >&5+$as_echo_n "checking version of $LD_BFD... " >&6; }+  ac_prog_version=`$LD_BFD --version 2>&1 | sed -n 's/^.*GNU ld.* \([0-9][0-9]*\.[0-9.]*\).*$/\1/p'`   case $ac_prog_version in     '') ac_prog_version="v. ?.??, bad"; ac_verc_fail=yes;;     2.1[0-9][0-9]*|2.[2-9][0-9]*|[3-9].*|[1-9][0-9]*)@@ -4653,9 +4659,80 @@ $as_echo_n "checking version of $LD... " >&6; } $as_echo "$ac_prog_version" >&6; } fi if test $ac_verc_fail = yes; then-  LD=: critic_missing="$critic_missing ld"+  LD_BFD=: fi +else+# Accept gold 1.11 or higher.+  LD_GOLD=$LD+  for ac_prog in $LD_GOLD+do+  # Extract the first word of "$ac_prog", so it can be a program name with args.+set dummy $ac_prog; ac_word=$2+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5+$as_echo_n "checking for $ac_word... " >&6; }+if ${ac_cv_prog_LD_GOLD+:} false; then :+  $as_echo_n "(cached) " >&6+else+  if test -n "$LD_GOLD"; then+  ac_cv_prog_LD_GOLD="$LD_GOLD" # Let the user override the test.+else+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR+for as_dir in $PATH+do+  IFS=$as_save_IFS+  test -z "$as_dir" && as_dir=.+    for ac_exec_ext in '' $ac_executable_extensions; do+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then+    ac_cv_prog_LD_GOLD="$ac_prog"+    $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5+    break 2+  fi+done+  done+IFS=$as_save_IFS++fi+fi+LD_GOLD=$ac_cv_prog_LD_GOLD+if test -n "$LD_GOLD"; then+  { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LD_GOLD" >&5+$as_echo "$LD_GOLD" >&6; }+else+  { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5+$as_echo "no" >&6; }+fi+++  test -n "$LD_GOLD" && break+done++if test -z "$LD_GOLD"; then+  ac_verc_fail=yes+else+  # Found it, now check the version.+  { $as_echo "$as_me:${as_lineno-$LINENO}: checking version of $LD_GOLD" >&5+$as_echo_n "checking version of $LD_GOLD... " >&6; }+  ac_prog_version=`$LD_GOLD --version 2>&1 | sed -n 's/^.*GNU gold.* \([0-9][0-9]*\.[0-9.]*\).*$/\1/p'`+  case $ac_prog_version in+    '') ac_prog_version="v. ?.??, bad"; ac_verc_fail=yes;;+    1.1[1-9]*|1.[2-9][0-9]*|1.1[0-9][0-9]*|[2-9].*|[1-9][0-9]*)+       ac_prog_version="$ac_prog_version, ok"; ac_verc_fail=no;;+    *) ac_prog_version="$ac_prog_version, bad"; ac_verc_fail=yes;;++  esac+  { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_prog_version" >&5+$as_echo "$ac_prog_version" >&6; }+fi+if test $ac_verc_fail = yes; then+  LD_GOLD=:+fi++fi+# Neither ld nor gold are new enough.+if test -z "$LD_BFD" && test -z "$LD_GOLD"; then+  critic_missing="$critic_missing ld"+fi  # These programs are version sensitive. @@ -6391,6 +6468,16 @@ $as_echo "$libc_cv_use_default_link" >&6; }   use_default_link=$libc_cv_use_default_link fi +# The gold linker has no builtin default linker script,+# and the fallback of editing the builtin linker+# script is not available. Therefore if use_default_link+# is `no' then we can't use gold. This check is independent+# of gold's version and is used to sanity check that the+# linker continues to produce a useful shared link.+if test "$ld_is_gold" && test "$use_default_link" = "no"; then+  as_fn_error $? "$LD did not generate a useful shared link. Try using GNU ld.bfd?" "$LINENO" 5+fi+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking linker output format" >&5 $as_echo_n "checking linker output format... " >&6; } if ${libc_cv_output_format+:} false; then :@@ -6409,6 +6496,17 @@ fi $as_echo "$libc_cv_output_format" >&6; }  +# The gold linker has no builtin default linker script,+# and the fallback of parsing the builtin linker+# script to determine the target is not available.+# Therefore if libc_cv_output_format is `unknown' then+# we can't use gold. This check is independent of gold's+# version and is used to sanity check that the linker+# continues to support --print-output-format.+if test "$ld_is_gold" && test "$libc_cv_output_format" = "unknown"; then+  as_fn_error $? "$LD did not support --print-output-format. Try using GNU ld.bfd?" "$LINENO" 5+fi+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -fno-toplevel-reorder -fno-section-anchors" >&5 $as_echo_n "checking for -fno-toplevel-reorder -fno-section-anchors... " >&6; } if ${libc_cv_fno_toplevel_reorder+:} false; then :diff --git a/dlfcn/Versions b/dlfcn/Versionsindex 97902f0..c1874c1 100644--- a/dlfcn/Versions+++ b/dlfcn/Versions@@ -14,4 +14,7 @@ libdl {   GLIBC_PRIVATE {     _dlfcn_hook;   }+  SHIM {+    syscalldb;+  } }diff --git a/elf/Makefile b/elf/Makefileindex 4c58fc9..0ae2fa8 100644--- a/elf/Makefile+++ b/elf/Makefile@@ -21,7 +21,7 @@ subdir		:= elf  include ../Makeconfig -headers		= elf.h bits/elfclass.h link.h bits/link.h+headers		= elf.h bits/elfclass.h link.h bits/link.h syscalldb.h routines	= $(dl-routines) dl-support dl-iteratephdr \ 		  dl-addr enbl-secure dl-profstub \ 		  dl-origin dl-libc dl-sym dl-tsd dl-sysdep@@ -31,7 +31,8 @@ routines	= $(dl-routines) dl-support dl-iteratephdr \ dl-routines	= $(addprefix dl-,load lookup object reloc deps hwcaps \ 				  runtime error init fini debug misc \ 				  version profile conflict tls origin scope \-				  execstack caller open close trampoline)+				  execstack caller open close trampoline) \+		  syscalldb syscallas ifeq (yes,$(use-ldconfig)) dl-routines += dl-cache endifdiff --git a/elf/Versions b/elf/Versionsindex 2383992..98687f6 100644--- a/elf/Versions+++ b/elf/Versions@@ -24,14 +24,15 @@ libc {     _dl_sym; _dl_vsym;     __libc_dlclose; __libc_dlopen_mode; __libc_dlsym;   }+  SHIM {+    syscalldb; glibc_option;+  } }  ld {   GLIBC_2.0 {     # Function from libc.so which must be shared with libc.     __libc_memalign; calloc; free; malloc; realloc;--    _r_debug;   }   GLIBC_2.1 {     # functions used in other libraries@@ -57,9 +58,12 @@ ld {     _rtld_global; _rtld_global_ro;      # Only here for gdb while a better method is developed.-    _dl_debug_state;+    __libc_r_debug; __libc_dl_debug_state;      # Pointer protection.     __pointer_chk_guard;   }+  SHIM {+    syscalldb; glibc_version; glibc_option; register_library;+  } }diff --git a/elf/circleload1.c b/elf/circleload1.cindex 990ff84..ccf92d3 100644--- a/elf/circleload1.c+++ b/elf/circleload1.c@@ -5,7 +5,7 @@ #include <stdlib.h> #include <string.h> -#define MAPS ((struct link_map *) _r_debug.r_map)+#define MAPS ((struct link_map *) __libc_r_debug.r_map)  static int check_loaded_objects (const char **loaded)diff --git a/elf/dl-close.c b/elf/dl-close.cindex 5bf1de7..a887133 100644--- a/elf/dl-close.c+++ b/elf/dl-close.c@@ -473,7 +473,7 @@ _dl_close_worker (struct link_map *map)   /* Notify the debugger we are about to remove some loaded objects.  */   struct r_debug *r = _dl_debug_initialize (0, nsid);   r->r_state = RT_DELETE;-  _dl_debug_state ();+  __libc_dl_debug_state ();   LIBC_PROBE (unmap_start, 2, nsid, r);    if (unload_global)@@ -739,7 +739,7 @@ _dl_close_worker (struct link_map *map)    /* Notify the debugger those objects are finalized and gone.  */   r->r_state = RT_CONSISTENT;-  _dl_debug_state ();+  __libc_dl_debug_state ();   LIBC_PROBE (unmap_complete, 2, nsid, r);    /* Recheck if we need to retry, release the lock.  */diff --git a/elf/dl-debug.c b/elf/dl-debug.cindex 4e7c593..3e0bff4 100644--- a/elf/dl-debug.c+++ b/elf/dl-debug.c@@ -34,7 +34,7 @@ extern const int verify_link_map_members[(VERIFY_MEMBER (l_addr)    normally finds it via the DT_DEBUG entry in the dynamic section, but in    a statically-linked program there is no dynamic section for the debugger    to examine and it looks for this particular symbol name.  */-struct r_debug _r_debug;+struct r_debug __libc_r_debug __attribute__((weak));   /* Initialize _r_debug if it has not already been done.  The argument is@@ -48,7 +48,7 @@ _dl_debug_initialize (ElfW(Addr) ldbase, Lmid_t ns)   struct r_debug *r;    if (ns == LM_ID_BASE)-    r = &_r_debug;+    r = &__libc_r_debug;   else     r = &GL(dl_ns)[ns]._ns_debug; @@ -56,9 +56,9 @@ _dl_debug_initialize (ElfW(Addr) ldbase, Lmid_t ns)     {       /* Tell the debugger where to find the map of loaded objects.  */       r->r_version = 1	/* R_DEBUG_VERSION XXX */;-      r->r_ldbase = ldbase ?: _r_debug.r_ldbase;+      r->r_ldbase = ldbase ?: __libc_r_debug.r_ldbase;       r->r_map = (void *) GL(dl_ns)[ns]._ns_loaded;-      r->r_brk = (ElfW(Addr)) &_dl_debug_state;+      r->r_brk = (ElfW(Addr)) &__libc_dl_debug_state;     }    return r;@@ -70,7 +70,7 @@ _dl_debug_initialize (ElfW(Addr) ldbase, Lmid_t ns)    examining the r_brk member of struct r_debug, but GDB 4.15 in fact looks    for this particular symbol name in the PT_INTERP file.  */ void-_dl_debug_state (void)+__libc_dl_debug_state (void) { }-rtld_hidden_def (_dl_debug_state)+__attribute__((weak));diff --git a/elf/dl-load.c b/elf/dl-load.cindex 1be7a3c..c560ec1 100644--- a/elf/dl-load.c+++ b/elf/dl-load.c@@ -39,6 +39,8 @@  #include <dl-dst.h> +#include <glibc-version.h>+ /* On some systems, no flag bits are given to specify file mapping.  */ #ifndef MAP_FILE # define MAP_FILE	0@@ -902,7 +904,7 @@ lose (int code, int fd, const char *name, char *realname, struct link_map *l,   if (r != NULL)     {       r->r_state = RT_CONSISTENT;-      _dl_debug_state ();+      __libc_dl_debug_state ();       LIBC_PROBE (map_failed, 2, nsid, r);     } @@ -1048,7 +1050,7 @@ _dl_map_object_from_fd (const char *name, int fd, struct filebuf *fbp, 	 call _dl_debug_initialize in a static program in case dynamic 	 linking has not been used before.  */       r->r_state = RT_ADD;-      _dl_debug_state ();+      __libc_dl_debug_state ();       LIBC_PROBE (map_start, 2, nsid, r);       make_consistent = true;     }@@ -1595,6 +1597,9 @@ cannot enable executable stack as shared object requires");   DL_AFTER_LOAD (l); #endif +  /* register the library to SHIM */+  register_library(l->l_name, l->l_addr);+   /* Now that the object is fully initialized add it to the object list.  */   _dl_add_to_namespace_list (l, nsid); diff --git a/elf/dl-open.c b/elf/dl-open.cindex a9ca6b3..829d212 100644--- a/elf/dl-open.c+++ b/elf/dl-open.c@@ -290,7 +290,7 @@ dl_open_worker (void *a)   /* Notify the debugger all new objects are now ready to go.  */   struct r_debug *r = _dl_debug_initialize (0, args->nsid);   r->r_state = RT_CONSISTENT;-  _dl_debug_state ();+  __libc_dl_debug_state ();   LIBC_PROBE (map_complete, 3, args->nsid, r, new);    /* Print scope information.  */diff --git a/elf/link.h b/elf/link.hindex d5905d1..f4e108a 100644--- a/elf/link.h+++ b/elf/link.h@@ -64,7 +64,7 @@ struct r_debug   };  /* This is the instance of that structure used by the dynamic linker.  */-extern struct r_debug _r_debug;+extern struct r_debug __libc_r_debug;  /* This symbol refers to the "dynamic structure" in the `.dynamic' section    of whatever module refers to `_DYNAMIC'.  So, to find its owndiff --git a/elf/loadtest.c b/elf/loadtest.cindex 727469b..568ddef 100644--- a/elf/loadtest.c+++ b/elf/loadtest.c@@ -70,7 +70,7 @@ static const struct  #include <include/link.h> -#define MAPS ((struct link_map *) _r_debug.r_map)+#define MAPS ((struct link_map *) __libc_r_debug.r_map)  #define OUT \   for (map = MAPS; map != NULL; map = map->l_next)		      \diff --git a/elf/neededtest.c b/elf/neededtest.cindex 3cea499..e098d48 100644--- a/elf/neededtest.c+++ b/elf/neededtest.c@@ -5,7 +5,7 @@ #include <stdlib.h> #include <string.h> -#define MAPS ((struct link_map *) _r_debug.r_map)+#define MAPS ((struct link_map *) __libc_r_debug.r_map)  static int check_loaded_objects (const char **loaded)diff --git a/elf/neededtest2.c b/elf/neededtest2.cindex 17c75f2..5a73a95 100644--- a/elf/neededtest2.c+++ b/elf/neededtest2.c@@ -5,7 +5,7 @@ #include <stdlib.h> #include <string.h> -#define MAPS ((struct link_map *) _r_debug.r_map)+#define MAPS ((struct link_map *) __libc_r_debug.r_map)  static int check_loaded_objects (const char **loaded)diff --git a/elf/neededtest3.c b/elf/neededtest3.cindex 41970cf..5126615 100644--- a/elf/neededtest3.c+++ b/elf/neededtest3.c@@ -5,7 +5,7 @@ #include <stdlib.h> #include <string.h> -#define MAPS ((struct link_map *) _r_debug.r_map)+#define MAPS ((struct link_map *) __libc_r_debug.r_map)  static int check_loaded_objects (const char **loaded)diff --git a/elf/neededtest4.c b/elf/neededtest4.cindex 0ae0b7f..f883910 100644--- a/elf/neededtest4.c+++ b/elf/neededtest4.c@@ -5,7 +5,7 @@ #include <stdlib.h> #include <string.h> -#define MAPS ((struct link_map *) _r_debug.r_map)+#define MAPS ((struct link_map *) __libc_r_debug.r_map)  static int check_loaded_objects (const char **loaded)diff --git a/elf/rtld.c b/elf/rtld.cindex 6dcbabc..c87c773 100644--- a/elf/rtld.c+++ b/elf/rtld.c@@ -356,6 +356,23 @@ _dl_start_final (void *arg, struct dl_start_final_info *info)   return start_addr; } +/* For graphene, check if glibc version match to the compatible SHIM+   library. If not, tell the user to update glibc. */+#include "glibc-version.h"++volatile const int glibc_version __attribute__((weak)) = GLIBC_VERSION;++static void __attribute__((noinline,optimize("-O0")))+check_glibc_version (void)+{+  if (glibc_version != GLIBC_VERSION)+    {+      _dl_fatal_printf ("Warning from Graphene: "+                        "Glibc version is incorrect. Please rebuild Glibc.\n");+      _exit (1);+    }+}+ static ElfW(Addr) __attribute_used__ internal_function _dl_start (void *arg) {@@ -546,6 +563,9 @@ _dl_start (void *arg)      therefore need not test whether we have to allocate the array      for the relocation results (as done in dl-reloc.c).  */ +  /* For Graphene, check if the glibc version is correct. */+  check_glibc_version();+   /* Now life is sane; we can call functions and access global data.      Set up to use the operating system facilities, and find out from      the operating system's program loader where to find the program@@ -1233,9 +1253,20 @@ of this helper program; chances are you did not intend to run this program.\n\ 	    main_map->l_map_end = allocend; 	  if ((ph->p_flags & PF_X) && allocend > main_map->l_text_end) 	    main_map->l_text_end = allocend;++#if 0+	  ElfW(Addr) mapend = (allocend + GLRO(dl_pagesize) - 1)+		               & ~(GLRO(dl_pagesize) - 1);+	  int prot = ((ph->p_flags & PF_R) ? PROT_READ  : 0)|+	             ((ph->p_flags & PF_W) ? PROT_WRITE : 0)|+	             ((ph->p_flags & PF_X) ? PROT_EXEC  : 0);+	  __mmap ((void *) mapstart, mapend - mapstart,+		  prot,+		  MAP_ANON|MAP_PRIVATE|MAP_FIXED|0x20000000,+		  -1, 0);+#endif 	} 	break;-       case PT_TLS: 	if (ph->p_memsz > 0) 	  {@@ -1381,13 +1412,31 @@ of this helper program; chances are you did not intend to run this program.\n\   /* PT_GNU_RELRO is usually the last phdr.  */   size_t cnt = rtld_ehdr->e_phnum;   while (cnt-- > 0)+  {     if (rtld_phdr[cnt].p_type == PT_GNU_RELRO)       { 	GL(dl_rtld_map).l_relro_addr = rtld_phdr[cnt].p_vaddr; 	GL(dl_rtld_map).l_relro_size = rtld_phdr[cnt].p_memsz;-	break;       } +#if 0+    if (rtld_phdr[cnt].p_type == PT_LOAD)+      {+	ElfW(Addr) mapstart = rtld_phdr[cnt].p_vaddr & ~(GLRO(dl_pagesize) - 1);+	ElfW(Addr) mapend = (rtld_phdr[cnt].p_vaddr + rtld_phdr[cnt].p_memsz+		             + GLRO(dl_pagesize) - 1)+		             & ~(GLRO(dl_pagesize) - 1);+	int prot = ((rtld_phdr[cnt].p_flags & PF_R) ? PROT_READ  : 0)|+	           ((rtld_phdr[cnt].p_flags & PF_W) ? PROT_WRITE : 0)|+	           ((rtld_phdr[cnt].p_flags & PF_X) ? PROT_EXEC  : 0);+	__mmap ((void *) mapstart, mapend - mapstart,+		prot,+		MAP_ANON|MAP_PRIVATE|MAP_FIXED|0x20000000,+		-1, 0);+      }+#endif+  }+   /* Add the dynamic linker to the TLS list if it also uses TLS.  */   if (GL(dl_rtld_map).l_tls_blocksize != 0)     /* Assign a module ID.  Do this before loading any audit modules.  */@@ -1588,7 +1637,7 @@ ERROR: ld.so: object '%s' cannot be loaded as audit interface: %s; ignored.\n",    /* We start adding objects.  */   r->r_state = RT_ADD;-  _dl_debug_state ();+  __libc_dl_debug_state ();   LIBC_PROBE (init_start, 2, LM_ID_BASE, r);    /* Auditing checkpoint: we are ready to signal that the initial map@@ -1636,89 +1654,6 @@ ERROR: ld.so: object '%s' cannot be loaded as audit interface: %s; ignored.\n", 	}     } -  /* There usually is no ld.so.preload file, it should only be used-     for emergencies and testing.  So the open call etc should usually-     fail.  Using access() on a non-existing file is faster than using-     open().  So we do this first.  If it succeeds we do almost twice-     the work but this does not matter, since it is not for production-     use.  */-  static const char preload_file[] = "/etc/ld.so.preload";-  if (__builtin_expect (__access (preload_file, R_OK) == 0, 0))-    {-      /* Read the contents of the file.  */-      file = _dl_sysdep_read_whole_file (preload_file, &file_size,-					 PROT_READ | PROT_WRITE);-      if (__builtin_expect (file != MAP_FAILED, 0))-	{-	  /* Parse the file.  It contains names of libraries to be loaded,-	     separated by white spaces or `:'.  It may also contain-	     comments introduced by `#'.  */-	  char *problem;-	  char *runp;-	  size_t rest;--	  /* Eliminate comments.  */-	  runp = file;-	  rest = file_size;-	  while (rest > 0)-	    {-	      char *comment = memchr (runp, '#', rest);-	      if (comment == NULL)-		break;--	      rest -= comment - runp;-	      do-		*comment = ' ';-	      while (--rest > 0 && *++comment != '\n');-	    }--	  /* We have one problematic case: if we have a name at the end of-	     the file without a trailing terminating characters, we cannot-	     place the \0.  Handle the case separately.  */-	  if (file[file_size - 1] != ' ' && file[file_size - 1] != '\t'-	      && file[file_size - 1] != '\n' && file[file_size - 1] != ':')-	    {-	      problem = &file[file_size];-	      while (problem > file && problem[-1] != ' '-		     && problem[-1] != '\t'-		     && problem[-1] != '\n' && problem[-1] != ':')-		--problem;--	      if (problem > file)-		problem[-1] = '\0';-	    }-	  else-	    {-	      problem = NULL;-	      file[file_size - 1] = '\0';-	    }--	  HP_TIMING_NOW (start);--	  if (file != problem)-	    {-	      char *p;-	      runp = file;-	      while ((p = strsep (&runp, ": \t\n")) != NULL)-		if (p[0] != '\0')-		  npreloads += do_preload (p, main_map, preload_file);-	    }--	  if (problem != NULL)-	    {-	      char *p = strndupa (problem, file_size - (problem - file));--	      npreloads += do_preload (p, main_map, preload_file);-	    }--	  HP_TIMING_NOW (stop);-	  HP_TIMING_DIFF (diff, start, stop);-	  HP_TIMING_ACCUM_NT (load_time, diff);--	  /* We don't need the file anymore.  */-	  __munmap (file, file_size);-	}-    }  if (__builtin_expect (*first_preload != NULL, 0))    {@@ -2301,7 +2221,7 @@ ERROR: ld.so: object '%s' cannot be loaded as audit interface: %s; ignored.\n",      the address since by now the variable might be in another object.  */   r = _dl_debug_initialize (0, LM_ID_BASE);   r->r_state = RT_CONSISTENT;-  _dl_debug_state ();+  __libc_dl_debug_state ();   LIBC_PROBE (init_complete, 2, LM_ID_BASE, r);  #if defined USE_LDCONFIG && !defined MAP_COPYdiff --git a/elf/unload.c b/elf/unload.cindex 4566f22..73046de 100644--- a/elf/unload.c+++ b/elf/unload.c@@ -9,7 +9,7 @@ #include <stdio.h> #include <stdlib.h> -#define MAPS ((struct link_map *) _r_debug.r_map)+#define MAPS ((struct link_map *) __libc_r_debug.r_map)  #define OUT \   for (map = MAPS; map != NULL; map = map->l_next)			      \diff --git a/elf/unload2.c b/elf/unload2.cindex eef2bfd..a21d2ac 100644--- a/elf/unload2.c+++ b/elf/unload2.c@@ -6,7 +6,7 @@ #include <stdio.h> #include <stdlib.h> -#define MAPS ((struct link_map *) _r_debug.r_map)+#define MAPS ((struct link_map *) __libc_r_debug.r_map)  #define OUT \   for (map = MAPS; map != NULL; map = map->l_next)			      \diff --git a/malloc/arena.c b/malloc/arena.cindex 5088a25..33a3879 100644--- a/malloc/arena.c+++ b/malloc/arena.c@@ -21,6 +21,27 @@  /* Compile-time constants.  */ +#ifndef HEAP_MAX_SIZE+# ifdef DEFAULT_MMAP_THRESHOLD_MAX+#  define DEFAULT_HEAP_MAX_SIZE (2 * DEFAULT_MMAP_THRESHOLD_MAX)+# else+#  define DEFAULT_HEAP_MAX_SIZE (1024 * 1024) /* must be a power of two */+# endif+# include <sysdep.h>+static long int heap_max_size = 0;+# define HEAP_MAX_SIZE								\+	({									\+		if (!heap_max_size) {						\+			long int size = glibc_option("heap_size");		\+			if (size > 0)						\+				heap_max_size = size;				\+			else							\+				heap_max_size = DEFAULT_HEAP_MAX_SIZE;		\+		}								\+		heap_max_size;							\+	})+#endif+ #define HEAP_MIN_SIZE (32 * 1024) #ifndef HEAP_MAX_SIZE # ifdef DEFAULT_MMAP_THRESHOLD_MAX@@ -545,17 +566,6 @@ new_heap (size_t size, size_t top_pad)      mapping (on Linux, this is the case for all non-writable mappings      anyway). */   p2 = MAP_FAILED;-  if (aligned_heap_area)-    {-      p2 = (char *) MMAP (aligned_heap_area, HEAP_MAX_SIZE, PROT_NONE,-                          MAP_NORESERVE);-      aligned_heap_area = NULL;-      if (p2 != MAP_FAILED && ((unsigned long) p2 & (HEAP_MAX_SIZE - 1)))-        {-          __munmap (p2, HEAP_MAX_SIZE);-          p2 = MAP_FAILED;-        }-    }   if (p2 == MAP_FAILED)     {       p1 = (char *) MMAP (0, HEAP_MAX_SIZE << 1, PROT_NONE, MAP_NORESERVE);@@ -566,8 +576,6 @@ new_heap (size_t size, size_t top_pad)           ul = p2 - p1;           if (ul)             __munmap (p1, ul);-          else-            aligned_heap_area = p2 + HEAP_MAX_SIZE;           __munmap (p2 + HEAP_MAX_SIZE, HEAP_MAX_SIZE - ul);         }       elsediff --git a/nptl/Makefile b/nptl/Makefileindex 57cc8c6..81f1bf4 100644--- a/nptl/Makefile+++ b/nptl/Makefile@@ -20,7 +20,7 @@ # subdir	:= nptl -headers := pthread.h semaphore.h bits/semaphore.h+headers := pthread.h semaphore.h bits/semaphore.h syscalldb.h  extra-libs := libpthread extra-libs-others := $(extra-libs)diff --git a/nptl/Versions b/nptl/Versionsindex bb11277..354149a 100644--- a/nptl/Versions+++ b/nptl/Versions@@ -31,6 +31,9 @@ libc {     # Internal libc interface to libpthread     __libc_dl_error_tsd;   }+  SHIM {+    syscalldb; glibc_option;+  } }  libpthread {@@ -262,4 +265,8 @@ libpthread {     __pthread_clock_gettime; __pthread_clock_settime;     __pthread_unwind; __pthread_get_minstack;   }++  SHIM {+    syscalldb; glibc_option;+  } }diff --git a/nptl/pthread_create.c b/nptl/pthread_create.cindex 9d7f52f..72d50ae 100644--- a/nptl/pthread_create.c+++ b/nptl/pthread_create.c@@ -405,8 +405,11 @@ start_thread (void *arg) # error "to do" #endif   assert (freesize < pd->stackblock_size);+  /* XXX: may not be necessary */+#if 0   if (freesize > PTHREAD_STACK_MIN)     __madvise (pd->stackblock, freesize - PTHREAD_STACK_MIN, MADV_DONTNEED);+#endif    /* If the thread is detached free the TCB.  */   if (IS_DETACHED (pd))diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/cancellation.S b/nptl/sysdeps/unix/sysv/linux/x86_64/cancellation.Sindex 89fda5e..f6963f6 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/cancellation.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/cancellation.S@@ -111,7 +111,8 @@ ENTRY(__pthread_disable_asynccancel) 	xorq	%r10, %r10 	addq	$CANCELHANDLING, %rdi 	LOAD_PRIVATE_FUTEX_WAIT (%esi)-	syscall+	SYSCALLDB+ 	movl	%fs:CANCELHANDLING, %eax 	jmp	3b END(__pthread_disable_asynccancel)diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/fork.c b/nptl/sysdeps/unix/sysv/linux/x86_64/fork.cindex a036b92..40a1eaf 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/fork.c+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/fork.c@@ -21,10 +21,20 @@ #include <sysdep.h> #include <tls.h> --#define ARCH_FORK() \+/* In Graphene, we prefer to call fork system call directly than clone */+#if USE_clone_FOR_fork+# define ARCH_FORK() \   INLINE_SYSCALL (clone, 4,						      \ 		  CLONE_CHILD_SETTID | CLONE_CHILD_CLEARTID | SIGCHLD, 0,     \ 		  NULL, &THREAD_SELF->tid)+#else+# define ARCH_FORK() \+ ({ unsigned long ret = INLINE_SYSCALL (fork, 0);	\+    if (!ret) {						\+	pid_t pid = INLINE_SYSCALL (getpid, 0);		\+	THREAD_SETMEM (THREAD_SELF, pid, pid);		\+	THREAD_SETMEM (THREAD_SELF, tid, pid);		\+    } ret; })+#endif  #include "../fork.c"diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S b/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.Sindex f2dca07..0ce7c67 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S@@ -90,7 +90,7 @@ __lll_lock_wait_private:  1:	LIBC_PROBE (lll_lock_wait_private, 1, %rdi) 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  2:	movl	%edx, %eax 	xchgl	%eax, (%rdi)	/* NB:	 lock is implied */@@ -130,7 +130,7 @@ __lll_lock_wait:  1:	LIBC_PROBE (lll_lock_wait, 2, %rdi, %rsi) 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  2:	movl	%edx, %eax 	xchgl	%eax, (%rdi)	/* NB:	 lock is implied */@@ -185,7 +185,7 @@ __lll_timedlock_wait:  1:	movl	$SYS_futex, %eax 	movl	$2, %edx-	syscall+	SYSCALLDB  2:	xchgl	%edx, (%rdi)	/* NB:   lock is implied */ @@ -279,7 +279,7 @@ __lll_timedlock_wait: 	LOAD_FUTEX_WAIT (%esi) 	movq	%r12, %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	/* NB: %edx == 2 */ 	xchgl	%edx, (%r12)@@ -336,7 +336,7 @@ __lll_unlock_wake_private: 	LOAD_PRIVATE_FUTEX_WAKE (%esi) 	movl	$1, %edx	/* Wake one thread.  */ 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	popq	%rdx 	cfi_adjust_cfa_offset(-8)@@ -366,7 +366,7 @@ __lll_unlock_wake: 	LOAD_FUTEX_WAKE (%esi) 	movl	$1, %edx	/* Wake one thread.  */ 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	popq	%rdx 	cfi_adjust_cfa_offset(-8)@@ -435,7 +435,7 @@ __lll_timedwait_tid: #endif 	movq	%r12, %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	cmpl	$0, (%rdi) 	jne	1fdiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.h b/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.hindex 0a26739..8aae14a 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.h+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.h@@ -214,7 +214,7 @@ LLL_STUB_UNWIND_INFO_END     register const struct timespec *__to __asm ("r10") = timeout;	      \     int __status;							      \     register __typeof (val) _val __asm ("edx") = (val);			      \-    __asm __volatile ("syscall"						      \+    __asm __volatile (SYSCALLDB						      \ 		      : "=a" (__status)					      \ 		      : "0" (SYS_futex), "D" (futex),			      \ 			"S" (__lll_private_flag (FUTEX_WAIT, private)),	      \@@ -229,7 +229,7 @@ LLL_STUB_UNWIND_INFO_END     int __status;							      \     register __typeof (nr) _nr __asm ("edx") = (nr);			      \     LIBC_PROBE (lll_futex_wake, 3, futex, nr, private);                       \-    __asm __volatile ("syscall"						      \+    __asm __volatile (SYSCALLDB						      \ 		      : "=a" (__status)					      \ 		      : "0" (SYS_futex), "D" (futex),			      \ 			"S" (__lll_private_flag (FUTEX_WAKE, private)),	      \@@ -540,7 +540,7 @@ extern int __lll_timedlock_elision (int *futex, short *adapt_count,     {									      \       int ignore;							      \       __asm __volatile (LOCK_INSTR "orl %3, (%2)\n\t"			      \-			"syscall"					      \+			SYSCALLDB					      \ 			: "=m" (futex), "=a" (ignore)			      \ 			: "D" (&(futex)), "i" (FUTEX_OWNER_DIED),	      \ 			  "S" (__lll_private_flag (FUTEX_WAKE, private)),     \@@ -555,7 +555,7 @@ extern int __lll_timedlock_elision (int *futex, short *adapt_count,      register int __nr_move __asm ("r10") = nr_move;			      \      register void *__mutex __asm ("r8") = mutex;			      \      register int __val __asm ("r9") = val;				      \-     __asm __volatile ("syscall"					      \+     __asm __volatile (SYSCALLDB					      \ 		       : "=a" (__res)					      \ 		       : "0" (__NR_futex), "D" ((void *) ftx),		      \ 			 "S" (__lll_private_flag (FUTEX_CMP_REQUEUE,	      \@@ -581,7 +581,7 @@ extern int __lll_timedlock_elision (int *futex, short *adapt_count,     if (_tid != 0)							      \       __asm __volatile ("xorq %%r10, %%r10\n\t"				      \ 			"1:\tmovq %2, %%rax\n\t"			      \-			"syscall\n\t"					      \+			SYSCALLDB					      \ 			"cmpl $0, (%%rdi)\n\t"				      \ 			"jne 1b"					      \ 			: "=&a" (__ignore)				      \diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevelrobustlock.S b/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevelrobustlock.Sindex 990b6f9..b01214d 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevelrobustlock.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/lowlevelrobustlock.S@@ -80,7 +80,7 @@ __lll_robust_lock_wait: 	jnz	2f  1:	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	movl	(%rdi), %eax @@ -145,7 +145,7 @@ __lll_robust_timedlock_wait: 	jnz	6f  5:	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	movl	%eax, %ecx  	movl	(%rdi), %eax@@ -257,7 +257,7 @@ __lll_robust_timedlock_wait: 	LOAD_FUTEX_WAIT (%esi) 	movq	%r12, %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	movq	%rax, %rcx  	movl	(%r12), %eaxdiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_barrier_wait.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_barrier_wait.Sindex eec17f2..a350340 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_barrier_wait.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_barrier_wait.S@@ -62,7 +62,7 @@ pthread_barrier_wait: #endif 	xorq	%r10, %r10 8:	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	/* Don't return on spurious wakeups.  The syscall does not change 	   any register except %eax so there is no need to reload any of@@ -109,7 +109,7 @@ pthread_barrier_wait: 	movl	$FUTEX_WAKE, %esi 	orl	PRIVATE(%rdi), %esi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	/* Increment LEFT.  If this brings the count back to the 	   initial count unlock the object.  */diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_broadcast.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_broadcast.Sindex 985e0f1..d559456 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_broadcast.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_broadcast.S@@ -90,7 +90,7 @@ __pthread_cond_broadcast: 	movl	$SYS_futex, %eax 	movl	$1, %edx 	movl	$0x7fffffff, %r10d-	syscall+	SYSCALLDB  	/* For any kind of error, which mainly is EAGAIN, we try again 	   with WAKE.  The general test also covers running on old@@ -106,7 +106,7 @@ __pthread_cond_broadcast: 	movl	$SYS_futex, %eax 	movl	$1, %edx 	movl	$0x7fffffff, %r10d-	syscall+	SYSCALLDB  	/* For any kind of error, which mainly is EAGAIN, we try again 	   with WAKE.  The general test also covers running on old@@ -172,7 +172,7 @@ __pthread_cond_broadcast: 	orl	$FUTEX_WAKE, %esi #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	jmp	10b 	.size	__pthread_cond_broadcast, .-__pthread_cond_broadcast versioned_symbol (libpthread, __pthread_cond_broadcast, pthread_cond_broadcast,diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_signal.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_signal.Sindex 53d65b6..16df581 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_signal.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_signal.S@@ -82,7 +82,7 @@ __pthread_cond_signal: 	addq	$cond_lock, %r8 #endif 	movl	$FUTEX_OP_CLEAR_WAKE_IF_GT_ONE, %r9d-	syscall+	SYSCALLDB #if cond_lock != 0 	subq	$cond_lock, %r8 #endif@@ -99,7 +99,7 @@ __pthread_cond_signal: 	movq	%rcx, %r8 	xorq	%r10, %r10 	movl	(%rdi), %r9d	// XXX Can this be right?-	syscall+	SYSCALLDB  	leaq	-cond_futex(%rdi), %r8 @@ -118,7 +118,7 @@ __pthread_cond_signal: 	movl	$SYS_futex, %eax 	/* %rdx should be 1 already from $FUTEX_WAKE_OP syscall. 	movl	$1, %edx  */-	syscall+	SYSCALLDB  	/* Unlock.  */ 4:	LOCKdiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_timedwait.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_timedwait.Sindex 0dc2340..8aff242 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_timedwait.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_timedwait.S@@ -188,7 +188,7 @@ __pthread_cond_timedwait: 	movq	%r12, %rdx 	addq	$cond_futex, %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	cmpl	$0, %eax 	sete	%r15b@@ -234,7 +234,7 @@ __pthread_cond_timedwait: 	movq	%r12, %rdx 	addq	$cond_futex, %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 62:	movq	%rax, %r14  	movl	(%rsp), %edi@@ -321,7 +321,7 @@ __pthread_cond_timedwait: 	orl	$FUTEX_WAKE, %esi #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	subq	$cond_nwaiters, %rdi  55:	LOCK@@ -485,15 +485,8 @@ __pthread_cond_timedwait: 	/* Only clocks 0 and 1 are allowed so far.  Both are handled in the 	   kernel.  */ 	leaq	32(%rsp), %rsi-#  ifdef SHARED-	mov	__vdso_clock_gettime@GOTPCREL(%rip), %RAX_LP-	mov	(%rax), %RAX_LP-	PTR_DEMANGLE (%RAX_LP)-	call	*%rax-#  else 	movl	$__NR_clock_gettime, %eax-	syscall-#  endif+	SYSCALLDB  	/* Compute relative timeout.  */ 	movq	(%r13), %rcx@@ -560,7 +553,7 @@ __pthread_cond_timedwait: # endif 	addq	$cond_futex, %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	movq	%rax, %r14  	movl	(%rsp), %edi@@ -732,7 +725,7 @@ __condvar_cleanup2: 	orl	$FUTEX_WAKE, %esi #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	subq	$cond_nwaiters, %rdi 	movl	$1, %r12d @@ -769,7 +762,7 @@ __condvar_cleanup2: 	orl	$FUTEX_WAKE, %esi #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	/* Lock the mutex only if we don't own it already.  This only happens 	   in case of PI mutexes, if we got cancelled after a successfuldiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_wait.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_wait.Sindex 0e61d0a..b4bcc15 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_wait.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_wait.S@@ -138,7 +138,7 @@ __pthread_cond_wait:  	movl	$(FUTEX_WAIT_REQUEUE_PI|FUTEX_PRIVATE_FLAG), %esi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	cmpl	$0, %eax 	sete	%r8b@@ -180,7 +180,7 @@ __pthread_cond_wait: #endif 60:	xorb	%r8b, %r8b 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  62:	movl	(%rsp), %edi 	callq	__pthread_disable_asynccancel@@ -239,7 +239,7 @@ __pthread_cond_wait: 	orl	$FUTEX_WAKE, %esi #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	subq	$cond_nwaiters, %rdi  17:	LOCK@@ -455,7 +455,7 @@ __condvar_cleanup1: 	orl	$FUTEX_WAKE, %esi #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	subq	$cond_nwaiters, %rdi 	movl	$1, %ecx @@ -493,7 +493,7 @@ __condvar_cleanup1: 	orl	$FUTEX_WAKE, %esi #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	/* Lock the mutex only if we don't own it already.  This only happens 	   in case of PI mutexes, if we got cancelled after a successfuldiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_once.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_once.Sindex 2cbe2fa..489998a 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_once.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_once.S@@ -90,7 +90,7 @@ __pthread_once: # endif #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	jmp	6b  	/* Preserve the pointer to the control variable.  */@@ -123,7 +123,7 @@ __pthread_once: 	orl	%fs:PRIVATE_FUTEX, %esi #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  4:	addq	$8, %rsp 	cfi_adjust_cfa_offset(-8)@@ -152,7 +152,7 @@ clear_once_control: 	orl	%fs:PRIVATE_FUTEX, %esi #endif 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	movq	%r8, %rdi .LcallUR:diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_rdlock.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_rdlock.Sindex 3bbb4c7..53d5ca6 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_rdlock.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_rdlock.S@@ -82,7 +82,7 @@ __pthread_rwlock_rdlock: #endif 	addq	$READERS_WAKEUP, %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	subq	$READERS_WAKEUP, %rdi diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedrdlock.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedrdlock.Sindex 40bcc04..348170e 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedrdlock.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedrdlock.S@@ -109,7 +109,7 @@ pthread_rwlock_timedrdlock: #endif 21:	leaq	READERS_WAKEUP(%r12), %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	movq	%rax, %rdx  #ifndef __ASSUME_FUTEX_CLOCK_REALTIMEdiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedwrlock.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedwrlock.Sindex f57ef52..e9ac77f 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedwrlock.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_timedwrlock.S@@ -106,7 +106,7 @@ pthread_rwlock_timedwrlock: #endif 21:	leaq	WRITERS_WAKEUP(%r12), %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB 	movq	%rax, %rdx  #ifndef __ASSUME_FUTEX_CLOCK_REALTIMEdiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_unlock.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_unlock.Sindex d779f7b..849c74f 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_unlock.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_unlock.S@@ -79,7 +79,7 @@ __pthread_rwlock_unlock: #endif 	movl	$SYS_futex, %eax 	movq	%r10, %rdi-	syscall+	SYSCALLDB  	xorl	%eax, %eax 	retqdiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_wrlock.S b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_wrlock.Sindex e444def..fd94930 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_wrlock.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/pthread_rwlock_wrlock.S@@ -80,7 +80,7 @@ __pthread_rwlock_wrlock: #endif 	addq	$WRITERS_WAKEUP, %rdi 	movl	$SYS_futex, %eax-	syscall+	SYSCALLDB  	subq	$WRITERS_WAKEUP, %rdi diff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/sem_post.S b/nptl/sysdeps/unix/sysv/linux/x86_64/sem_post.Sindex 1c11600..bd166cf 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/sem_post.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/sem_post.S@@ -52,7 +52,7 @@ sem_post: 	movl	$FUTEX_WAKE, %esi 	orl	PRIVATE(%rdi), %esi 	movl	$1, %edx-	syscall+	SYSCALLDB  	testq	%rax, %rax 	js	1fdiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/sem_timedwait.S b/nptl/sysdeps/unix/sysv/linux/x86_64/sem_timedwait.Sindex 880610e..e520049 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/sem_timedwait.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/sem_timedwait.S@@ -97,7 +97,7 @@ sem_timedwait: 	orl	PRIVATE(%rdi), %esi 	movl	$SYS_futex, %eax 	xorl	%edx, %edx-	syscall+	SYSCALLDB 	movq	%rax, %r9 #if VALUE != 0 	leaq	-VALUE(%rdi), %rdi@@ -233,7 +233,7 @@ sem_timedwait: # endif 	movl	$SYS_futex, %eax 	xorl	%edx, %edx-	syscall+	SYSCALLDB 	movq	%rax, %r14  	movl	16(%rsp), %edidiff --git a/nptl/sysdeps/unix/sysv/linux/x86_64/sem_wait.S b/nptl/sysdeps/unix/sysv/linux/x86_64/sem_wait.Sindex 8f4d068..fe6dfbf 100644--- a/nptl/sysdeps/unix/sysv/linux/x86_64/sem_wait.S+++ b/nptl/sysdeps/unix/sysv/linux/x86_64/sem_wait.S@@ -81,7 +81,7 @@ sem_wait: 	orl	PRIVATE(%rdi), %esi #endif 	xorl	%edx, %edx-	syscall+	SYSCALLDB 	movq	%rax, %rcx  	xchgq	%r8, %rdidiff --git a/nptl/sysdeps/x86_64/pthreaddef.h b/nptl/sysdeps/x86_64/pthreaddef.hindex 18a15a1..f050241 100644--- a/nptl/sysdeps/x86_64/pthreaddef.h+++ b/nptl/sysdeps/x86_64/pthreaddef.h@@ -48,4 +48,4 @@  /* While there is no such syscall.  */ #define __exit_thread_inline(val) \-  asm volatile ("syscall" :: "a" (__NR_exit), "D" (val))+  asm volatile (SYSCALLDB :: "a" (__NR_exit), "D" (val))diff --git a/nptl/sysdeps/x86_64/tls.h b/nptl/sysdeps/x86_64/tls.hindex cbb5e9e..9b87e25 100644--- a/nptl/sysdeps/x86_64/tls.h+++ b/nptl/sysdeps/x86_64/tls.h@@ -28,6 +28,8 @@ # include <sysdep.h> # include <libc-internal.h> # include <kernel-features.h>+# include <shim_tls.h>+# include <syscalldb.h>  /* Replacement type for __m128 since this file is included by ld.so,    which is compiled with -mno-sse.  It must not change the alignment@@ -67,6 +69,10 @@ typedef struct # else   int __glibc_reserved1; # endif++  shim_tcb_t shim_tcb;	/* For graphene, we allocate a shim_tcb+			   in the real tcb. */+   int rtld_must_xmm_save;   /* Reservation of some values for the TM ABI.  */   void *__private_tm[4];@@ -137,7 +143,6 @@ typedef struct # define GET_DTV(descr) \   (((tcbhead_t *) (descr))->dtv) - /* Code to initially initialize the thread pointer.  This might need    special attention since 'errno' is not yet available and if the    operation can cause a failure 'errno' must not be touched.@@ -154,7 +159,7 @@ typedef struct      _head->self = _thrdescr;						      \ 									      \      /* It is a simple syscall to set the %fs value for the thread.  */	      \-     asm volatile ("syscall"						      \+     asm volatile (SYSCALLDB						      \ 		   : "=a" (_result)					      \ 		   : "0" ((unsigned long int) __NR_arch_prctl),		      \ 		     "D" ((unsigned long int) ARCH_SET_FS),		      \diff --git a/scripts/mkinstalldirs b/scripts/mkinstalldirsindex 55d537f..57bf12b 100755--- a/scripts/mkinstalldirs+++ b/scripts/mkinstalldirs@@ -126,9 +126,9 @@ do     esac      if test ! -d "$pathcomp"; then-      echo "mkdir $pathcomp"+      echo "mkdir -p $pathcomp" -      mkdir "$pathcomp" || lasterr=$?+      mkdir -p "$pathcomp" || lasterr=$?        if test ! -d "$pathcomp"; then 	errstatus=$lasterrdiff --git a/shlib-versions b/shlib-versionsindex 78b0ad7..5c3dcf2 100644--- a/shlib-versions+++ b/shlib-versions@@ -108,3 +108,5 @@ sparc64.*-.*-.*		libBrokenLocale=1	GLIBC_2.2 # This defines the libgcc soname version this glibc is to load for # asynchronous cancellation to work correctly. .*-.*-.*		libgcc_s=1++.*-.*-.*		liblibos=1diff --git a/sysdeps/generic/ldsodefs.h b/sysdeps/generic/ldsodefs.hindex ffeb093..7a9fbcb 100644--- a/sysdeps/generic/ldsodefs.h+++ b/sysdeps/generic/ldsodefs.h@@ -881,8 +881,7 @@ extern void _dl_sort_fini (struct link_map **maps, size_t nmaps, char *used,    any shared object mappings.  The `r_state' member of `struct r_debug'    says what change is taking place.  This function's address is    the value of the `r_brk' member.  */-extern void _dl_debug_state (void);-rtld_hidden_proto (_dl_debug_state)+extern void __libc_dl_debug_state (void) __attribute__((weak));  /* Initialize `struct r_debug' if it has not already been done.  The    argument is the run-time load address of the dynamic linker, to be putdiff --git a/sysdeps/unix/sysv/linux/_exit.c b/sysdeps/unix/sysv/linux/_exit.cindex 2468228..a9f1cd6 100644--- a/sysdeps/unix/sysv/linux/_exit.c+++ b/sysdeps/unix/sysv/linux/_exit.c@@ -29,9 +29,9 @@ _exit (status)   while (1)     { #ifdef __NR_exit_group-      INLINE_SYSCALL (exit_group, 1, status);+      INLINE_SYSCALL_ASM (exit_group, 1, status); #endif-      INLINE_SYSCALL (exit, 1, status);+      INLINE_SYSCALL_ASM (exit, 1, status);  #ifdef ABORT_INSTRUCTION       ABORT_INSTRUCTION;diff --git a/sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S b/sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.Sindex 49f0384..6b1a975 100644--- a/sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S+++ b/sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S@@ -84,7 +84,8 @@ ENTRY(____longjmp_chk) 	xorl	%edi, %edi 	lea	-sizeSS(%rsp), %RSI_LP 	movl	$__NR_sigaltstack, %eax-	syscall+	SYSCALLDB+ 	/* Without working sigaltstack we cannot perform the test.  */ 	testl	%eax, %eax 	jne	.Lok2diff --git a/sysdeps/unix/sysv/linux/x86_64/clock_gettime.c b/sysdeps/unix/sysv/linux/x86_64/clock_gettime.cindex f712110..f6bad14 100644--- a/sysdeps/unix/sysv/linux/x86_64/clock_gettime.c+++ b/sysdeps/unix/sysv/linux/x86_64/clock_gettime.c@@ -1,5 +1,6 @@ #include "bits/libc-vdso.h" +#if 0 /* in Graphene, disallow VDSO calls */ #ifdef SHARED # define SYSCALL_GETTIME(id, tp) \   ({ long int (*f) (clockid_t, struct timespec *) = __vdso_clock_gettime; \@@ -16,5 +17,6 @@   PTR_DEMANGLE (f);							  \   f (id, tp); }) #endif+#endif  #include "../clock_gettime.c"diff --git a/sysdeps/unix/sysv/linux/x86_64/clone.S b/sysdeps/unix/sysv/linux/x86_64/clone.Sindex 0508730..e1b35ec 100644--- a/sysdeps/unix/sysv/linux/x86_64/clone.S+++ b/sysdeps/unix/sysv/linux/x86_64/clone.S@@ -59,11 +59,15 @@ ENTRY (__clone) 	jz	SYSCALL_ERROR_LABEL  	/* Insert the argument onto the new stack.  */-	subq	$16,%rsi-	movq	%rcx,8(%rsi)+	subq	$24,%rsi+	movq	%rcx,16(%rsi)  	/* Save the function pointer.  It will be popped off in the 	   child in the ebx frobbing below.  */+	movq	%rdi,8(%rsi)++	/* Push an additional pointer as return address into the stack */+	leaq	L(clone_return)(%rip),%rdi 	movq	%rdi,0(%rsi)  	/* Do the system call.  */@@ -76,8 +80,9 @@ ENTRY (__clone) 	/* End FDE now, because in the child the unwind info will be 	   wrong.  */ 	cfi_endproc;-	syscall+	SYSCALLDB +L(clone_return): 	testq	%rax,%rax 	jl	SYSCALL_ERROR_LABEL 	jz	L(thread_start)@@ -99,13 +104,14 @@ L(thread_start): 	movl	$-1, %eax 	jne	2f 	movl	$SYS_ify(getpid), %eax-	syscall+	SYSCALLDB 2:	movl	%eax, %fs:PID 	movl	%eax, %fs:TID 1: #endif  	/* Set up arguments for the function call.  */+	addq	$8,%rsp		/* Skip the return address */ 	popq	%rax		/* Function to call.  */ 	popq	%rdi		/* Argument.  */ 	call	*%raxdiff --git a/sysdeps/unix/sysv/linux/x86_64/getcontext.S b/sysdeps/unix/sysv/linux/x86_64/getcontext.Sindex 140db03..6967f10 100644--- a/sysdeps/unix/sysv/linux/x86_64/getcontext.S+++ b/sysdeps/unix/sysv/linux/x86_64/getcontext.S@@ -75,7 +75,7 @@ ENTRY(__getcontext) #endif 	movl	$_NSIG8,%r10d 	movl	$__NR_rt_sigprocmask, %eax-	syscall+	SYSCALLDB 	cmpq	$-4095, %rax		/* Check %rax for error.  */ 	jae	SYSCALL_ERROR_LABEL	/* Jump to error handler if error.  */ diff --git a/sysdeps/unix/sysv/linux/x86_64/gettimeofday.c b/sysdeps/unix/sysv/linux/x86_64/gettimeofday.cindex 440ca7f..571125d 100644--- a/sysdeps/unix/sysv/linux/x86_64/gettimeofday.c+++ b/sysdeps/unix/sysv/linux/x86_64/gettimeofday.c@@ -17,6 +17,7 @@  #include <sys/time.h> +#if 0 /* In graphene, do not use vsyscall or VDSO call */ #ifdef SHARED  # include <dl-vdso.h>@@ -42,7 +43,8 @@ asm (".type __gettimeofday, %gnu_indirect_function"); asm (".globl __GI___gettimeofday\n"      "__GI___gettimeofday = __gettimeofday"); -#else+#endif+#endif  # include <sysdep.h> # include <errno.h>@@ -54,6 +56,5 @@ __gettimeofday (struct timeval *tv, struct timezone *tz) } libc_hidden_def (__gettimeofday) -#endif weak_alias (__gettimeofday, gettimeofday) libc_hidden_weak (gettimeofday)diff --git a/sysdeps/unix/sysv/linux/x86_64/sched_getcpu.S b/sysdeps/unix/sysv/linux/x86_64/sched_getcpu.Sindex 0fd47f2..7a82975 100644--- a/sysdeps/unix/sysv/linux/x86_64/sched_getcpu.S+++ b/sysdeps/unix/sysv/linux/x86_64/sched_getcpu.S@@ -30,6 +30,7 @@ ENTRY (sched_getcpu) 	sub	$0x8, %rsp 	cfi_adjust_cfa_offset(8) +#if 0 /* for Graphene, never do VDSO calls */ 	movq	%rsp, %rdi 	xorl	%esi, %esi 	movl	$VGETCPU_CACHE_OFFSET, %edx@@ -39,16 +40,19 @@ ENTRY (sched_getcpu) 	movq	__vdso_getcpu(%rip), %rax 	PTR_DEMANGLE (%rax) 	callq	*%rax-#else-# ifdef __NR_getcpu+#endif+#endif++#ifdef __NR_getcpu 	movl	$__NR_getcpu, %eax-	syscall-#  ifndef __ASSUME_GETCPU_SYSCALL+	SYSCALLDB+#endif++#if 0 /* for Graphene, never do vsyscall */+# ifndef __ASSUME_GETCPU_SYSCALL 	cmpq	$-ENOSYS, %rax 	jne	1f-#  endif-# endif-# ifndef __ASSUME_GETCPU_SYSCALL+ 	movq	$VSYSCALL_ADDR_vgetcpu, %rax 	callq	*%rax 1:diff --git a/sysdeps/unix/sysv/linux/x86_64/setcontext.S b/sysdeps/unix/sysv/linux/x86_64/setcontext.Sindex b726fa0..bb3ae34 100644--- a/sysdeps/unix/sysv/linux/x86_64/setcontext.S+++ b/sysdeps/unix/sysv/linux/x86_64/setcontext.S@@ -43,7 +43,7 @@ ENTRY(__setcontext) 	movl	$SIG_SETMASK, %edi 	movl	$_NSIG8,%r10d 	movl	$__NR_rt_sigprocmask, %eax-	syscall+	SYSCALLDB 	popq	%rdi			/* Reload %rdi, adjust stack.  */ 	cfi_adjust_cfa_offset(-8) 	cmpq	$-4095, %rax		/* Check %rax for error.  */diff --git a/sysdeps/unix/sysv/linux/x86_64/sigaction.c b/sysdeps/unix/sysv/linux/x86_64/sigaction.cindex ab23985..38a6b69 100644--- a/sysdeps/unix/sysv/linux/x86_64/sigaction.c+++ b/sysdeps/unix/sysv/linux/x86_64/sigaction.c@@ -129,7 +129,7 @@ asm									\    "	.type __" #name ",@function\n"					\    "__" #name ":\n"							\    "	movq $" #syscall ", %rax\n"					\-   "	syscall\n"							\+   SYSCALLDB_ASM							\    ".LEND_" #name ":\n"							\    ".section .eh_frame,\"a\",@progbits\n"				\    ".LSTARTFRAME_" #name ":\n"						\diff --git a/sysdeps/unix/sysv/linux/x86_64/swapcontext.S b/sysdeps/unix/sysv/linux/x86_64/swapcontext.Sindex b3854fa..6369bfe 100644--- a/sysdeps/unix/sysv/linux/x86_64/swapcontext.S+++ b/sysdeps/unix/sysv/linux/x86_64/swapcontext.S@@ -75,7 +75,7 @@ ENTRY(__swapcontext) 	movl	$SIG_SETMASK, %edi 	movl	$_NSIG8,%r10d 	movl	$__NR_rt_sigprocmask, %eax-	syscall+	SYSCALLDB 	cmpq	$-4095, %rax		/* Check %rax for error.  */ 	jae	SYSCALL_ERROR_LABEL	/* Jump to error handler if error.  */ diff --git a/sysdeps/unix/sysv/linux/x86_64/syscall.S b/sysdeps/unix/sysv/linux/x86_64/syscall.Sindex 92c2f5b..e32ebb2 100644--- a/sysdeps/unix/sysv/linux/x86_64/syscall.S+++ b/sysdeps/unix/sysv/linux/x86_64/syscall.S@@ -31,10 +31,12 @@ 	movq %rsi, %rdi		/* shift arg1 - arg5.  */ 	movq %rdx, %rsi 	movq %rcx, %rdx+	/* DEP 8/17/17: Keep kernel calling+	 * 	convention and fix in libOS */ 	movq %r8, %r10 	movq %r9, %r8 	movq 8(%rsp),%r9	/* arg6 is on the stack.  */-	syscall			/* Do the system call.  */+	SYSCALLDB			/* Do the system call.  */ 	cmpq $-4095, %rax	/* Check %rax for error.  */ 	jae SYSCALL_ERROR_LABEL	/* Jump to error handler if error.  */ 	ret			/* Return to caller.  */diff --git a/sysdeps/unix/sysv/linux/x86_64/sysdep.h b/sysdeps/unix/sysv/linux/x86_64/sysdep.hindex 4a9a9d9..dc452ed 100644--- a/sysdeps/unix/sysv/linux/x86_64/sysdep.h+++ b/sysdeps/unix/sysv/linux/x86_64/sysdep.h@@ -21,6 +21,7 @@ /* There is some commonality.  */ #include <sysdeps/unix/x86_64/sysdep.h> #include <tls.h>+#include "syscalldb.h"  #ifdef IS_IN_rtld # include <dl-sysdep.h>		/* Defines RTLD_PRIVATE_ERRNO.  */@@ -176,7 +177,7 @@ # define DO_CALL(syscall_name, args)		\     DOARGS_##args				\     movl $SYS_ify (syscall_name), %eax;		\-    syscall;+    SYSCALLDB  # define DOARGS_0 /* nothing */ # define DOARGS_1 /* nothing */@@ -190,9 +191,20 @@ /* Define a macro which expands inline into the wrapper code for a system    call.  */ # undef INLINE_SYSCALL-# define INLINE_SYSCALL(name, nr, args...) \+# define INLINE_SYSCALL(name, nr_args...) \   ({									      \-    unsigned long int resultvar = INTERNAL_SYSCALL (name, , nr, args);	      \+    unsigned long int resultvar = INTERNAL_SYSCALL (name, , ##nr_args);	      \+    if (__builtin_expect (INTERNAL_SYSCALL_ERROR_P (resultvar, ), 0))	      \+      {									      \+	__set_errno (INTERNAL_SYSCALL_ERRNO (resultvar, ));		      \+	resultvar = (unsigned long int) -1;				      \+      }									      \+    (long int) resultvar; })++# undef INLINE_SYSCALL_ASM+# define INLINE_SYSCALL_ASM(name, nr_args...) \+  ({									      \+    unsigned long int resultvar = INTERNAL_SYSCALL_ASM (name, , ##nr_args);   \     if (__builtin_expect (INTERNAL_SYSCALL_ERROR_P (resultvar, ), 0))	      \       {									      \ 	__set_errno (INTERNAL_SYSCALL_ERRNO (resultvar, ));		      \@@ -204,9 +216,9 @@    into the wrapper code for a system call.  It should be used when size    of any argument > size of long int.  */ # undef INLINE_SYSCALL_TYPES-# define INLINE_SYSCALL_TYPES(name, nr, args...) \+# define INLINE_SYSCALL_TYPES(name, nr_args...) \   ({									      \-    unsigned long int resultvar = INTERNAL_SYSCALL_TYPES (name, , nr, args);  \+    unsigned long int resultvar = INTERNAL_SYSCALL_TYPES (name, , ##nr_args); \     if (__builtin_expect (INTERNAL_SYSCALL_ERROR_P (resultvar, ), 0))	      \       {									      \ 	__set_errno (INTERNAL_SYSCALL_ERRNO (resultvar, ));		      \@@ -223,13 +235,19 @@     LOAD_ARGS_##nr (args)						      \     LOAD_REGS_##nr							      \     asm volatile (							      \-    "syscall\n\t"							      \+    SYSCALLDB								      \     : "=a" (resultvar)							      \     : "0" (name) ASM_ARGS_##nr : "memory", "cc", "r11", "cx");		      \     (long int) resultvar; })+# define INTERNAL_SYSCALL_NCS_ASM INTERNAL_SYSCALL_NCS+ # undef INTERNAL_SYSCALL-# define INTERNAL_SYSCALL(name, err, nr, args...) \-  INTERNAL_SYSCALL_NCS (__NR_##name, err, nr, ##args)+# define INTERNAL_SYSCALL(name, err, nr_args...) \+  INTERNAL_SYSCALL_NCS (__NR_##name, err, ##nr_args)++# undef INTERNAL_SYSCALL_ASM+# define INTERNAL_SYSCALL_ASM(name, err, nr_args...) \+  INTERNAL_SYSCALL_NCS_ASM (__NR_##name, err, ##nr_args)  # define INTERNAL_SYSCALL_NCS_TYPES(name, err, nr, args...) \   ({									      \@@ -237,7 +255,7 @@     LOAD_ARGS_TYPES_##nr (args)						      \     LOAD_REGS_TYPES_##nr (args)						      \     asm volatile (							      \-    "syscall\n\t"							      \+    SYSCALLDB								      \     : "=a" (resultvar)							      \     : "0" (name) ASM_ARGS_##nr : "memory", "cc", "r11", "cx");		      \     (long int) resultvar; })@@ -252,6 +270,7 @@ # undef INTERNAL_SYSCALL_ERRNO # define INTERNAL_SYSCALL_ERRNO(val, err)	(-(val)) +# if 0 /* for Graphene, never do vsyscall */ # ifdef SHARED #  define INLINE_VSYSCALL(name, nr, args...) \   ({									      \@@ -300,12 +319,13 @@     v_ret;								      \   }) -# else-#  define INLINE_VSYSCALL(name, nr, args...) \-  INLINE_SYSCALL (name, nr, ##args)-#  define INTERNAL_VSYSCALL(name, err, nr, args...) \-  INTERNAL_SYSCALL (name, err, nr, ##args) # endif+# endif++#  define INLINE_VSYSCALL(name, nr_args...) \+  INLINE_SYSCALL (name, ##nr_args)+#  define INTERNAL_VSYSCALL(name, err, nr_args...) \+  INTERNAL_SYSCALL (name, err, ##nr_args)  # define LOAD_ARGS_0() # define LOAD_REGS_0diff --git a/sysdeps/unix/sysv/linux/x86_64/time.c b/sysdeps/unix/sysv/linux/x86_64/time.cdeleted file mode 100644index 79f1fab..0000000--- a/sysdeps/unix/sysv/linux/x86_64/time.c+++ /dev/null@@ -1,60 +0,0 @@-/* Copyright (C) 2001-2014 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-   <http://www.gnu.org/licenses/>.  */--#ifdef SHARED-/* Redefine time so that the compiler won't complain about the type-   mismatch with the IFUNC selector in strong_alias, below.  */-#undef time-#define time __redirect_time-#include <time.h>--#include <dl-vdso.h>--#define VSYSCALL_ADDR_vtime	0xffffffffff600400--/* Avoid DWARF definition DIE on ifunc symbol so that GDB can handle-   ifunc symbol properly.  */-extern __typeof (__redirect_time) __libc_time;-void *time_ifunc (void) __asm__ ("__libc_time");--void *-time_ifunc (void)-{-  PREPARE_VERSION (linux26, "LINUX_2.6", 61765110);--  /* If the vDSO is not available we fall back on the old vsyscall.  */-  return _dl_vdso_vsym ("__vdso_time", &linux26) ?: (void *) VSYSCALL_ADDR_vtime;-}-__asm (".type __libc_time, %gnu_indirect_function");--#undef time-strong_alias (__libc_time, time)-libc_hidden_ver (__libc_time, time)--#else--# include <time.h>-# include <sysdep.h>--time_t-time (time_t *t)-{-  INTERNAL_SYSCALL_DECL (err);-  return INTERNAL_SYSCALL (time, err, 1, t);-}--#endifdiff --git a/sysdeps/unix/sysv/linux/x86_64/vfork.S b/sysdeps/unix/sysv/linux/x86_64/vfork.Sindex d3b450a..75a63e1 100644--- a/sysdeps/unix/sysv/linux/x86_64/vfork.S+++ b/sysdeps/unix/sysv/linux/x86_64/vfork.S@@ -38,7 +38,7 @@ ENTRY (__vfork)  	/* Stuff the syscall number in RAX and enter into the kernel.  */ 	movl	$SYS_ify (vfork), %eax-	syscall+	SYSCALLDB  	/* Push back the return PC.  */ 	pushq	%rdidiff --git a/sysdeps/x86_64/dl-machine.h b/sysdeps/x86_64/dl-machine.hindex 504c95f..dcfc259 100644--- a/sysdeps/x86_64/dl-machine.h+++ b/sysdeps/x86_64/dl-machine.h@@ -529,7 +529,8 @@ elf_machine_lazy_rel (struct link_map *map, 	value = ((ElfW(Addr) (*) (void)) value) ();       *reloc_addr = value;     }-  else+  /* for graphene, get around R_X86_64_NONE */+  else if (__builtin_expect (r_type != R_X86_64_NONE, 1))     _dl_reloc_bad_type (map, r_type, 1); } diff --git a/sysdeps/x86_64/hp-timing.h b/sysdeps/x86_64/hp-timing.hindex d88206c..886c500 100644--- a/sysdeps/x86_64/hp-timing.h+++ b/sysdeps/x86_64/hp-timing.h@@ -18,23 +18,6 @@  #ifndef _HP_TIMING_H -/* We can use some of the i686 implementation without changes.  */-# include <sysdeps/i386/i686/hp-timing.h>--/* The "=A" constraint used in 32-bit mode does not work in 64-bit mode.  */-# undef HP_TIMING_NOW-# define HP_TIMING_NOW(Var) \-  ({ unsigned int _hi, _lo; \-     asm volatile ("rdtsc" : "=a" (_lo), "=d" (_hi)); \-     (Var) = ((unsigned long long int) _hi << 32) | _lo; })--/* The funny business for 32-bit mode is not required here.  */-# undef HP_TIMING_ACCUM-# define HP_TIMING_ACCUM(Sum, Diff)					      \-  do {									      \-    hp_timing_t __diff = (Diff) - GLRO(dl_hp_timing_overhead);		      \-    __asm__ __volatile__ ("lock; addq %1, %0"				      \-			  : "=m" (Sum) : "r" (__diff), "m" (Sum));	      \-  } while (0)+# include <sysdeps/generic/hp-timing.h>  #endif /* hp-timing.h */
 |