Loading...
--- dyld/dyld-360.21/src/dyldAPIs.cpp
+++ dyld/dyld-239.3/src/dyldAPIs.cpp
@@ -70,7 +70,6 @@
#define DEPRECATED_APIS_SUPPORTED 1
#endif
-static bool sDynamicInterposing = false;
#if DEPRECATED_APIS_SUPPORTED
static char sLastErrorFilePath[1024];
@@ -101,7 +100,7 @@
static void client_dyld_lookup_and_bind(const char* symbolName, void** address, NSModule* module);
static bool client_NSIsSymbolNameDefined(const char* symbolName);
#endif // DEPRECATED_APIS_SUPPORTED
-#if SUPPORT_ZERO_COST_EXCEPTIONS
+#if !__arm__
static bool client_dyld_find_unwind_sections(void* addr, dyld_unwind_sections* info);
#endif
@@ -135,25 +134,24 @@
{"__dyld_dyld_register_image_state_change_handler", (void*)dyld_register_image_state_change_handler },
{"__dyld_register_thread_helpers", (void*)registerThreadHelpers },
{"__dyld_fork_child", (void*)_dyld_fork_child },
+ {"__dyld_moninit", (void*)_dyld_moninit },
{"__dyld_make_delayed_module_initializer_calls", (void*)_dyld_make_delayed_module_initializer_calls },
{"__dyld_get_all_image_infos", (void*)_dyld_get_all_image_infos },
-#if SUPPORT_ZERO_COST_EXCEPTIONS
+#if !__arm__
{"__dyld_find_unwind_sections", (void*)client_dyld_find_unwind_sections },
#endif
-#if __i386__ || __x86_64__ || __arm__ || __arm64__
+#if __i386__ || __x86_64__ || __arm__
{"__dyld_fast_stub_entry", (void*)dyld::fastBindLazySymbol },
#endif
{"__dyld_image_path_containing_address", (void*)dyld_image_path_containing_address },
+#if __IPHONE_OS_VERSION_MIN_REQUIRED
{"__dyld_shared_cache_some_image_overridden", (void*)dyld_shared_cache_some_image_overridden },
+#endif
{"__dyld_process_is_restricted", (void*)dyld::processIsRestricted },
- {"__dyld_dynamic_interpose", (void*)dyld_dynamic_interpose },
-#if DYLD_SHARED_CACHE_SUPPORT
- {"__dyld_shared_cache_file_path", (void*)dyld::getStandardSharedCacheFilePath },
-#endif
- {"__dyld_get_image_header_containing_address", (void*)dyld_image_header_containing_address },
// deprecated
#if DEPRECATED_APIS_SUPPORTED
+ {"__dyld_get_image_header_containing_address", (void*)_dyld_get_image_header_containing_address },
{"__dyld_lookup_and_bind", (void*)client_dyld_lookup_and_bind },
{"__dyld_lookup_and_bind_with_hint", (void*)_dyld_lookup_and_bind_with_hint },
{"__dyld_lookup_and_bind_fully", (void*)_dyld_lookup_and_bind_fully },
@@ -285,7 +283,7 @@
dyld::log("%s(...)\n", __func__);
const char* exePath = dyld::getExecutablePath();
if(*bufsize < strlen(exePath) + 1){
- *bufsize = (uint32_t)(strlen(exePath) + 1);
+ *bufsize = strlen(exePath) + 1;
return -1;
}
strcpy(buf, exePath);
@@ -344,7 +342,7 @@
return NULL;
}
-const struct mach_header * dyld_image_header_containing_address(const void* address)
+const struct mach_header * _dyld_get_image_header_containing_address(const void* address)
{
if ( dyld::gLogAPIs )
dyld::log("%s(%p)\n", __func__, address);
@@ -1116,19 +1114,7 @@
ImageLoader* image = NSModuleToImageLoader(module);
if ( image == NULL )
return false;
- dyld::runImageStaticTerminators(image);
- if ( (dyld::gLibSystemHelpers != NULL) && (dyld::gLibSystemHelpers->version >= 13) ) {
- __cxa_range_t ranges[image->segmentCount()];
- int rangeCount = 0;
- for (unsigned int j=0; j < image->segmentCount(); ++j) {
- if ( !image->segExecutable(j) )
- continue;
- ranges[rangeCount].addr = (const void*)image->segActualLoadAddress(j);
- ranges[rangeCount].length = image->segSize(j);
- ++rangeCount;
- }
- (*dyld::gLibSystemHelpers->cxa_finalize_ranges)(ranges, rangeCount);
- }
+ dyld::runImageTerminators(image);
dyld::removeImage(image);
if ( (options & NSUNLINKMODULE_OPTION_KEEP_MEMORY_MAPPED) != 0 )
@@ -1209,6 +1195,27 @@
dyld::gProcessInfo->systemOrderFlag = 0;
}
+typedef void (*MonitorProc)(char *lowpc, char *highpc);
+
+static void monInitCallback(ImageLoader* image, void* userData)
+{
+ MonitorProc proc = (MonitorProc)userData;
+ void* start;
+ size_t length;
+ if ( image->getSectionContent("__TEXT", "__text", &start, &length) ) {
+ proc((char*)start, (char*)start+length);
+ }
+}
+
+//
+// _dyld_moninit is called from profiling runtime routine moninit().
+// dyld calls back with the range of each __TEXT/__text section in every
+// linked image.
+//
+void _dyld_moninit(MonitorProc proc)
+{
+ dyld::forEachImageDo(&monInitCallback, (void*)proc);
+}
#if DEPRECATED_APIS_SUPPORTED
// returns true if prebinding was used in main executable
@@ -1243,13 +1250,13 @@
#endif // DEPRECATED_APIS_SUPPORTED
-int _dyld_func_lookup(const char* name, void** address)
+bool lookupDyldFunction(const char* name, uintptr_t* address)
{
for (const dyld_func* p = dyld_funcs; p->name != NULL; ++p) {
if ( strcmp(p->name, name) == 0 ) {
if( p->implementation == unimplemented )
dyld::log("unimplemented dyld function: %s\n", p->name);
- *address = p->implementation;
+ *address = (uintptr_t)p->implementation;
return true;
}
}
@@ -1265,7 +1272,7 @@
// let gdb know it is safe to run code in inferior that might call malloc()
dyld::gProcessInfo->libSystemInitialized = true;
-#if !SUPPORT_ZERO_COST_EXCEPTIONS
+#if __arm__
if ( helpers->version >= 5 ) {
// create key use by dyld exception handling
pthread_key_t key;
@@ -1420,16 +1427,15 @@
void* result = NULL;
ImageLoader* image = NULL;
std::vector<const char*> rpathsFromCallerImage;
- ImageLoader::RPathChain callersRPaths(NULL, &rpathsFromCallerImage);
try {
void* callerAddress = __builtin_return_address(1); // note layers: 1: real client, 0: libSystem glue
ImageLoader* callerImage = dyld::findImageContainingAddress(callerAddress);
- if ( (mode & RTLD_NOLOAD) == 0 ) {
- // for dlopen, use rpath from caller image and from main executable
- if ( callerImage != NULL )
- callerImage->getRPaths(dyld::gLinkContext, rpathsFromCallerImage);
- if ( callerImage != dyld::mainExecutable() )
- dyld::mainExecutable()->getRPaths(dyld::gLinkContext, rpathsFromCallerImage);
+ // for dlopen, use rpath from caller image and from main executable
+ if ( callerImage != NULL )
+ callerImage->getRPaths(dyld::gLinkContext, rpathsFromCallerImage);
+ ImageLoader::RPathChain callersRPaths(NULL, &rpathsFromCallerImage);
+ if ( callerImage != dyld::mainExecutable() ) {
+ dyld::mainExecutable()->getRPaths(dyld::gLinkContext, rpathsFromCallerImage);
}
const bool leafName = (strchr(path, '/') == NULL);
@@ -1738,13 +1744,7 @@
if ( sym != NULL ) {
CRSetCrashLogMessage(NULL);
- ImageLoader* callerImage = NULL;
- if ( sDynamicInterposing ) {
- // only take time to look up caller, if dynamic interposing in use
- void* callerAddress = __builtin_return_address(1); // note layers: 1: real client, 0: libSystem glue
- callerImage = dyld::findImageContainingAddress(callerAddress);
- }
- return (void*)image->getExportedSymbolAddress(sym, dyld::gLinkContext, callerImage);
+ return (void*)image->getExportedSymbolAddress(sym, dyld::gLinkContext);
}
const char* str = dyld::mkstringf("dlsym(%p, %s): symbol not found", handle, symbolName);
dlerrorSet(str);
@@ -1771,7 +1771,7 @@
return dyld::gProcessInfo;
}
-#if SUPPORT_ZERO_COST_EXCEPTIONS
+#if !__arm__
static bool client_dyld_find_unwind_sections(void* addr, dyld_unwind_sections* info)
{
//if ( dyld::gLogAPIs )
@@ -1811,6 +1811,7 @@
+#if __IPHONE_OS_VERSION_MIN_REQUIRED
bool dyld_shared_cache_some_image_overridden()
{
#if DYLD_SHARED_CACHE_SUPPORT
@@ -1819,32 +1820,7 @@
return true;
#endif
}
-
-
-void dyld_dynamic_interpose(const struct mach_header* mh, const struct dyld_interpose_tuple array[], size_t count)
-{
- if ( mh == NULL )
- return;
- if ( array == NULL )
- return;
- if ( count == 0 )
- return;
- ImageLoader* image = dyld::findImageByMachHeader(mh);
- if ( image == NULL )
- return;
-
- // make pass at bound references in this image and update them
- dyld::gLinkContext.dynamicInterposeArray = array;
- dyld::gLinkContext.dynamicInterposeCount = count;
- image->dynamicInterpose(dyld::gLinkContext);
- dyld::gLinkContext.dynamicInterposeArray = NULL;
- dyld::gLinkContext.dynamicInterposeCount = 0;
-
- // leave interposing info so any future (lazy) binding will get it too
- image->addDynamicInterposingTuples(array, count);
-
- sDynamicInterposing = true;
-}
-
-
-
+#endif
+
+
+