Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Mach-O Mach-O

Mach-O Mach-O

A tour of Mach-O Binaries and related tools

Tommaso Piazza

February 28, 2019
Tweet

More Decks by Tommaso Piazza

Other Decks in Programming

Transcript

  1. Wait… but why? • Apps are Mach-O binaries • Binary

    frameworks • Carthage/Cocoapods errors • Got out of problems when things go south 28.02.19 Tommaso Piazza - @tmpz https://github.com/blender - let{it}swift 2 Undefined symbols for architecture x86_64: "_thisWillTotallyBeThere", referenced from: _main in trust-me-c9e7ba.o ld: symbol(s) not found for architecture x86_64 clang: error: linker command failed with exit code 1 (use -v to see invocation) dyld: Library not loaded: @rpath/Alamofire.framework/Alamofire Referenced from: /private/var/mobile/Containers/Bundle/Application/... Reason: image not found
  2. What is a Mach-O file? • Structured collection of blocks

    of bytes on disk • Used by Mach Kernels • macOS, iOS, tvOS, watchOS, GNU Hurd Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 28.02.19 3
  3. What is Mach-O used for? 28.02.19 • Executables (/bin/ls) •

    Relocatable object files ( .o) • Static libraries (.a) • Dynamic Libraries (.dylib) • Debug symbols (.dsym) • Bundles (.bundles) • Core dumps (stack traces) Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 4
  4. What about .framework(s)? 28.02.19 • Directory trees with special structure

    • Pack additional resources • Info.plist • Asset bundles • Fonts • …. • Can be static or dynamic Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 6
  5. Mach-O Format 28.02.19 Tom m aso Piazza - @ tm

    pz https://github.com /blender - let{it}swift 7 Single Architecture Multiple Architecture
  6. FAT header 28.02.19 • Multiple architectures packed in one file

    • x86_64 • armv6s • armv7 • otool –f <file> • objdump -macho -universal-headers Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift file:///Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/usr/include/mach-o/fat.h See yourself at: 8
  7. Slimming down FAT files • lipo -thin <arch_to_keep> <file_to_slim_down> -output

    <output> Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 28.02.19 9
  8. Mach-O Header • file:///Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/usr/include/mach-o/loader.h • How to identify a Mach-O

    file? Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 28.02.19 10
  9. Mach-O Header • Mach Magic number • MH_MAGIC, MH_CIGAM, MH_MAGIC_64,

    MH_CIGAM_64 • 0xfeedface , 0xcefaedfe, 0xfeedfacf , 0xcffaedfe • Indicator of Endianness and 32 of 64 bit Arch • CPU Type file:///Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/usr/include/mach/machine.h • FileType • MH_EXECUTE, MH_DYLIB, MH_DSYM, MH_OBJECT … • Read with otool –h (or objdump -macho -private-header) Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 28.02.19 11
  10. Load Commands Tom m aso Piazza - @ tm pz

    https://github.com /blender - let{it}swift 28.02.19 Contains • Information about the Data part of the file • Segments LC_SEGMENT_64 • Sections in each segment • Read with • otool -l Answers • Where is the symbol table? LC_SYMTAB, • What is the minimum version of the OS? LC_VERSION_MIN_IPHONEOS • Where is main? LC_MAIN • What libraries should be loaded? LC_LOAD_DYLIB • Where is the code signature? LC_CODE_SIGNATURE 12
  11. Symbols • LC_SYMTAB (own symbol table) • Exported symbols •

    Read with: dsymutil –symtab <file> • LC_DYSYMTAB (dynamic symbol table, AKA symbols from other files) • Can include debug symbol • strip –SxXNT <file> Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 28.02.19 13
  12. How are Mach-O files produced? 28.02.19 Tom m aso Piazza

    - @ tm pz https://github.com /blender - let{it}swift 14
  13. Compiling (2) Tom m aso Piazza - @ tm pz

    https://github.com /blender - let{it}swift 28.02.19 16 • The compiler checks your code against .h files • Name, arguments, return type • References to external (from libraries) symbols (functions, variables, constant...) left undefined • Mismatch?
  14. Static Linking Tom m aso Piazza - @ tm pz

    https://github.com /blender - let{it}swift 18 man ld • The binary fromthe linked library is copied into the final product • No binary share • Relatively simple process You may knowld for messages like... Undefined symbols for architecture x86_64: "_thisWillTotallyBeThere", referenced from: _main in trust-me-c9e7ba.o ld: symbol(s) not found for architecture x86_64 clang: error: linker command failed with exit code 1 (use -v to see invocation) 28.02.19
  15. Dynamic Linking Tom m aso Piazza - @ tm pz

    https://github.com /blender - let{it}swift 19 man dyld • The binary from the linked library is not copied into the final product • Binary share • Address of linked symbols resolved at load time (penatly) • More complex than static linking You may know dyld for messages like... dyld: Library not loaded: @rpath/Alamofire.framework/Alamofire Referenced from: /private/var/mobile/Containers/Bundle/Application/... Reason: image not found 28.02.19
  16. Demo 28.02.19 Tom m aso Piazza - @ tm pz

    https://github.com /blender - let{it}swift 20
  17. Compile & Link Recap Tom m aso Piazza - @

    tm pz https://github.com /blender - let{it}swift 28.02.19 21 swiftc –g -c Greeter.swift Colorizer.swift -module-name "Greet" swiftc -emit-module Greeter.swift Colorizer.swift -module-name "Greet" libtool -static Greeter.o Colorizer.o -o libGreeter.a swiftc -c let-it.swift -L`pwd` -I`pwd` -l`pwd` ld let-it.o -lGreeter -L`pwd` -lswiftCore \ -framework System \ -L/Library/Developer/CommandLineTools/usr/lib/swift/macosx \ -F/Library/Developer/CommandLineTools/SDKs/MacOSX.sdk/System/Library/Frameworks \ -rpath /Library/Developer/CommandLineTools/usr/lib/swift/macosx \ -o let-it-swift
  18. Party Trick nm –a <file> | grep –w “SO” Tom

    m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 28.02.19 222
  19. Thanks! 28.02.19 Tom m aso Piazza - @ tm pz

    https://github.com /blender - let{it}swift 23 @tmpz blender Carthage Rome Speakerdeck
  20. References 28.02.19 • https://www.bignerdranch.com/blog/manual-swift-understanding-the-swift-objective-c-build- pipeline/ • https://www.bignerdranch.com/blog/it-looks-like-you-are-trying-to-use-a-framework/ • https://www.iecc.com/linker/ •

    https://pewpewthespells.com/blog/static_and_dynamic_libraries.html • https://en.wikipedia.org/wiki/Object_file • https://en.wikipedia.org/wiki/Data_segment • https://developer.apple.com/library/archive/documentation/DeveloperTools/Conceptual/DynamicLib raries/100-Articles/OverviewOfDynamicLibraries.html • https://developer.apple.com/library/archive/qa/qa1118/_index.html • http://nickdesaulniers.github.io/blog/2016/11/20/static-and-dynamic-libraries/ • https://nickdesaulniers.github.io/blog/2016/08/13/object-files-and-symbols • https://www.darlinghq.org/developer-zone/mach-o-dynamic-loader/ • https://yurylapitsky.com/exploring_mac-o_binaries_nm • http://web.cse.ohio-state.edu/~reeves.92/CSE2421au12/SlidesDay52.pdf • https://blog.timac.org/2016/1018-analysis-of-the-facebook-app-for-ios/ • https://www.geeksforgeeks.org/memory-layout-of-c-program/ • https://developer.apple.com/library/archive/technotes/tn2151/_index.html • https://lldb.llvm.org/symbols.html • https://en.wikipedia.org/wiki/Dynamic_linker • https://opensource.apple.com/source/dyld/dyld-635.2/ Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 24
  21. References (2) • https://www.catswhocode.com/blog/how-to-create-a-pure-swift-module • http://iokit.racing/machotricks.pdf • https://en.wikipedia.org/wiki/Mach-O • https://lowlevelbits.org/parsing-mach-o-files/

    • http://www.m4b.io/reverse/engineering/mach/binaries/2015/03/29/mach-binaries.html • https://www.objc.io/issues/6-build-tools/mach-o-executables/ • https://en.wikipedia.org/wiki/Fat_binary • https://developer.apple.com/library/archive/documentation/DeveloperTools/Conceptual/MachOTopics/1- Articles/building_files.html • http://timetobleed.com/dynamic-symbol-table-duel-elf-vs-mach-o-round-2/ • http://www.idea2ic.com/File_Formats/MachORuntime.pdf • https://www.first.org/resources/papers/conf2016/FIRST-2016-130.pdf • http://bdunagan.com/2010/05/15/symbolification-shipping-symbols/ • https://stackoverflow.com/questions/27669766/how-to-read-mach-o-header-from-object-file • https://www.apriorit.com/dev-blog/225-dynamic-linking-mach-o • https://blog.smartdec.net/reading-ios-app-binary-files-2c9e63a381ad?gi=a704d31da280 • http://www.newosxbook.com/articles/DYLD.html • https://gcc.gnu.org/onlinedocs/gcc/Code-Gen-Options.html • https://stackoverflow.com/questions/435352/limiting-visibility-of-symbols-when-linking-shared- libraries/452955#452955 • https://stackoverflow.com/questions/22102470/link-a-static-library-to-a-shared-library-and-hide-exported- symbols • https://clang.llvm.org/docs/Modules.html#module-maps • http://timetobleed.com/tag/mach-o/ • https://reverseengineering.stackexchange.com/questions/17697/macho-remove-a-load-command-from-ios- binary • https://samhuri.net/posts/2010/01/basics-of-the-mach-o-file-format • http://www.blackhat.com/presentations/bh-dc-09/Iozzo/BlackHat-DC-09-Iozzo-Macho-on-the-fly.pdf • https://github.com/JDevlieghere/LibEBC • http://www.cilinder.be/docs/next/NeXTStep/3.3/nd/DevTools/14_MachO/MachO.htmld/index.html • http://nicolascormier.com/documentation/security/Infecting_Mach-O_Files.pdf • https://developer.apple.com/library/archive/documentation/DeveloperTools/Conceptual/DynamicLibraries/0 00-Introduction/Introduction.html • https://jameshfisher.com/2017/08/22/inspecting-mach-o-files.html Tom m aso Piazza - @ tm pz https://github.com /blender - let{it}swift 28.02.19 4