iOS 二进制重排

发布于:2024-04-09 ⋅ 阅读:(150) ⋅ 点赞:(0)
  • 原理:减少page fault次数,将启动用到的代码都放到一个page里。

  • 操作:

  • #include <stdint.h>
    #include <stdio.h>
    #include <sanitizer/common_interface_defs.h>
    #include <dlfcn.h>
    
     void __sanitizer_cov_trace_pc_guard_init(uint32_t *start,
                                                        uint32_t *stop) {
        static uint64_t N;  // Counter for the guards.
        if (start == stop || *start) return;  // Initialize only once.
        printf("INIT: %p %p\n", start, stop);
        for (uint32_t *x = start; x < stop; x++)
            *x = ++N;  // Guards should start from 1.
    }
    
     void __sanitizer_cov_trace_pc_guard(uint32_t *guard) {
         if (!*guard) return; 
         void *PC = __builtin_return_address(0);
         Dl_info info;
         dladdr(PC, &info);
         printf("guard:%p 开始执行:%s \n", PC, info.dli_sname);
    }

  • 收集到符号信息后,可以把符号分行书写到自定义的order文件。

  • OC类函数-[+[开头可以直接写入,其他的要额外加一个下划线_,info.dli_sname会少一个下划线。

//order.order
-[ViewController viewDidLoad]
-[AppDelegate applicationSupportsSecureRestorableState:]
___29-[ViewController viewDidLoad]_block_invoke
__ZN1A4testEv
___29-[ViewController viewDidLoad]_block_invoke_2
  • 在build setting->Order file指定文件路径。

  • 注意!

  • +load因为触发时机比__sanitizer_cov_trace_pc_guard_init早,所以无法监听到,这个可以扫描mach-o文件查看哪些类有load,直接加上去。


网站公告

今日签到

点亮在社区的每一天
去签到