Mach-O

Mach-O其实是Mach Object文件格式的缩写,是Mac以及iOS上可执行文件的格式,类似于Win上的PE(Portable Executable)格式,Linux上的elf(Executable and Linking Format)格式。

Mach-O文件

Mach-O是一种用于可执行文件目标代码动态库内核转储的文件格式。作为a.out格式的替代,Mach-O提供了更强的扩展性,并提升了符号表中信息的访问速度。

Mach-O格式的常见文件
  • 可执行文件
  • 目标文件.o
  • 库文件(.a、.dylib、Framework)
  • dyld
  • .dsym

File指令
通过 file 文件路径 查看文件类型

Mach-O文件结构

通用二进制文件(Universal Binary)
  • Apple公司提出了一种程序代码,能同时使用多种架构的二进制文件。
  • 同一个程序包中同时为多种架构提供理想的性能。
  • 因为需要存储多种代码,通用二进制应用程序通常币单一平台二进制的程序要大。
  • 但是由于两种架构有共通的非执行资源,所以并不会达到单一版本的两倍之多。
  • 而且由于执行中只调用一部分代码,运行并不会产生而外的内存消耗。

一个Mach-O中,通常存在这多种架构,为了便于分析,一般我们会拆分架构,去分析单一到架构,一来提升解析速度,二来方便分析。

  • 使用 lipo -info Mach-O 查看Mach-O文件所包含到架构
  • 使用 lipo Mach-O -thin 架构(arm64) -output 输出的文件 拆分指定架构
  • 使用 lipo -create MachO1 MachO2 -output 输出文件 合并多种架构
文件结构
文件结构
  • Header包含该二进制文件的一般信息
struct mach_header_64 {
   uint32_t magic; //包含一个值的整数,该值用于将Mach-O标识文件是32位还是64位
   cpu_type_t cputype; //指示要在其上使用文件的体系结构的整数,x86/ARM等
   cpu_subtype_t cpusubtype; //指定CPU的精确模型的整数,arm64/armv7等
   uint32_t filetype; //文件类型,比如可执行文件
   uint32_t ncmds; //loadCommands条数
   uint32_t sizeofcmds; //loadCommands的大小
   uint32_t flags; //标志位,标识二进制文件支持的功能,主要是和系统加载、链接相关
   uint32_t reserved;  //64位新增的保留位
}; //以64位体系结构为目标的目标文件的开头
  • Load commands 一张包含很多内容的表
    内容包括区域的位置、符号表、动态符号表等。
  • LC_SEGMENT_64:将文件中(32/64位)的段映射到进程地址空间中
  • LC_DYLD_INFO_ONLY:动态链接相关信息
  • LC_SYMTAB:符号地址
  • LC_DYSYMTAB:动态符号表地址
  • LC_LOAD_DYLINKER:使用的加载器,dyld加载器
  • LC_UUID:文件的UUID
  • LC_VERSION_MIN_MACOSX/LC_VERSION_MIN_IPHONEOS:支持的最低操作系统版本
  • LC_SOURCE_VERSION:源代码版本
  • LC_MAIN:设置程序主线程的入口地址和栈大小
  • LC_ENCRYPTION_INFO_64:获取加密信息
  • LC_LOAD_DYLIB:依赖库的路径,包含三方库
  • LC_FUNCTION_STARTS:函数其实地址表
  • LC_DATA_IN_CODE:定义在代码段内的非指令的表
  • LC_CODE_SIFNATURE:代码签名
  • Data通常是对象文件中最大的部分

    • 存放数据:代码、字符常量、类、方法等
    • 一般拥有多个Segment,每个Segment拥有零到多个Section。每个段都有一段虚拟地址映射到进程到地址空间。
  • Loader Info动态到链接信息

    • 一个完整的用户级Mach-O文件的末端是一系列链接信息。其中包含了动态加载器用来链接可执行文件或者依赖所需使用的符号表、字符串表等
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351