Home | History | Annotate | Download | only in drd
      1 /*
      2   This file is part of drd, a thread error detector.
      3 
      4   Copyright (C) 2006-2017 Bart Van Assche <bvanassche (at) acm.org>.
      5 
      6   This program is free software; you can redistribute it and/or
      7   modify it under the terms of the GNU General Public License as
      8   published by the Free Software Foundation; either version 2 of the
      9   License, or (at your option) any later version.
     10 
     11   This program is distributed in the hope that it will be useful, but
     12   WITHOUT ANY WARRANTY; without even the implied warranty of
     13   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     14   General Public License for more details.
     15 
     16   You should have received a copy of the GNU General Public License
     17   along with this program; if not, write to the Free Software
     18   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
     19   02111-1307, USA.
     20 
     21   The GNU General Public License is contained in the file COPYING.
     22 */
     23 
     24 #include <stdint.h>
     25 #include <stdio.h>
     26 #include "pub_tool_clreq.h"
     27 #include "drd.h"
     28 #include "pub_tool_redir.h"
     29 
     30 /*
     31  * On Mac OS X shared library functions are lazily bound. The binding mechanism
     32  * uses self-modifying code. Intercept fastBindLazySymbol() in order to suppress
     33  * the data accesses involved in this mechanism.
     34  *
     35  * See also the Mac OS X ABI Dynamic Loader Reference (http://developer.apple.com/library/mac/#documentation/DeveloperTools/Reference/MachOReference/Reference/reference.html#//apple_ref/c/func/dyld_stub_binding_helper).
     36  * See also the dyld_stub_binder() source code (http://www.opensource.apple.com/source/dyld/dyld-132.13/src/dyld_stub_binder.s).
     37  * See also the dyld::fastBindLazySymbol() source code (http://opensource.apple.com/source/dyld/dyld-132.13/src/dyld.cpp).
     38  */
     39 void* VG_WRAP_FUNCTION_ZZ(dyld, ZuZZN4dyld18fastBindLazySymbolEPP11ImageLoaderm)
     40      (void** imageLoaderCache, uintptr_t lazyBindingInfoOffset);
     41 void* VG_WRAP_FUNCTION_ZZ(dyld, ZuZZN4dyld18fastBindLazySymbolEPP11ImageLoaderm)
     42      (void** imageLoaderCache, uintptr_t lazyBindingInfoOffset)
     43 {
     44    void* res;
     45    OrigFn fn;
     46 
     47    VALGRIND_GET_ORIG_FN(fn);
     48 
     49    ANNOTATE_IGNORE_READS_AND_WRITES_BEGIN();
     50    CALL_FN_W_WW(res, fn, imageLoaderCache, lazyBindingInfoOffset);
     51    ANNOTATE_IGNORE_READS_AND_WRITES_END();
     52 
     53    return res;
     54 }
     55