From: Nicholas Nethercote Date: Sat, 23 May 2009 01:51:54 +0000 (+0000) Subject: DARWIN sync: sys_readlink layout. X-Git-Tag: svn/VALGRIND_3_5_0~612 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=63d3d86e21fec38e314eeeca767c078b82653c52;p=thirdparty%2Fvalgrind.git DARWIN sync: sys_readlink layout. git-svn-id: svn://svn.valgrind.org/valgrind/trunk@10121 --- diff --git a/coregrind/m_syswrap/syswrap-generic.c b/coregrind/m_syswrap/syswrap-generic.c index 0932172f70..0057339dd0 100644 --- a/coregrind/m_syswrap/syswrap-generic.c +++ b/coregrind/m_syswrap/syswrap-generic.c @@ -3540,8 +3540,7 @@ POST(sys_poll) PRE(sys_readlink) { - HChar name[25]; - Word saved = SYSNO; + Word saved = SYSNO; PRINT("sys_readlink ( %#lx(%s), %#lx, %llu )", ARG1,(char*)ARG1,ARG2,(ULong)ARG3); PRE_REG_READ3(long, "readlink", @@ -3549,20 +3548,26 @@ PRE(sys_readlink) PRE_MEM_RASCIIZ( "readlink(path)", ARG1 ); PRE_MEM_WRITE( "readlink(buf)", ARG2,ARG3 ); - /* - * Handle the case where readlink is looking at /proc/self/exe or - * /proc//exe. - */ - VG_(sprintf)(name, "/proc/%d/exe", VG_(getpid)()); - if (ML_(safe_to_deref)((void*)ARG1, 1) - && (VG_(strcmp)((Char *)ARG1, name) == 0 - || VG_(strcmp)((Char *)ARG1, "/proc/self/exe") == 0)) { - VG_(sprintf)(name, "/proc/self/fd/%d", VG_(cl_exec_fd)); - SET_STATUS_from_SysRes( VG_(do_syscall3)(saved, (UWord)name, - ARG2, ARG3)); - } else { - /* Normal case */ - SET_STATUS_from_SysRes( VG_(do_syscall3)(saved, ARG1, ARG2, ARG3)); + { + /* + * Handle the case where readlink is looking at /proc/self/exe or + * /proc//exe. + */ + HChar name[25]; + Char* arg1s = (Char*) ARG1; + VG_(sprintf)(name, "/proc/%d/exe", VG_(getpid)()); + if (ML_(safe_to_deref)(arg1s, 1) && + (VG_STREQ(arg1s, name) || VG_STREQ(arg1s, "/proc/self/exe")) + ) + { + VG_(sprintf)(name, "/proc/self/fd/%d", VG_(cl_exec_fd)); + SET_STATUS_from_SysRes( VG_(do_syscall3)(saved, (UWord)name, + ARG2, ARG3)); + } else + { + /* Normal case */ + SET_STATUS_from_SysRes( VG_(do_syscall3)(saved, ARG1, ARG2, ARG3)); + } } if (SUCCESS && RES > 0)