diff options
author | Chris Bieneman <beanz@apple.com> | 2016-05-17 17:13:50 +0000 |
---|---|---|
committer | Chris Bieneman <beanz@apple.com> | 2016-05-17 17:13:50 +0000 |
commit | 1c0f0b242da706ee4b31b5107273476358895049 (patch) | |
tree | 7a2ac124a86774b86ba682d66460ba070840de8c /llvm/lib/ObjectYAML/MachOYAML.cpp | |
parent | ac9e15551dfccb2996708534648e6b7e8d4fee8a (diff) | |
download | bcm5719-llvm-1c0f0b242da706ee4b31b5107273476358895049.tar.gz bcm5719-llvm-1c0f0b242da706ee4b31b5107273476358895049.zip |
Revert "[obj2yaml] [yaml2obj] Support for MachO load command structures"
This reverts commit r269782 because it broke bots with -fpermissive.
llvm-svn: 269785
Diffstat (limited to 'llvm/lib/ObjectYAML/MachOYAML.cpp')
-rw-r--r-- | llvm/lib/ObjectYAML/MachOYAML.cpp | 360 |
1 files changed, 6 insertions, 354 deletions
diff --git a/llvm/lib/ObjectYAML/MachOYAML.cpp b/llvm/lib/ObjectYAML/MachOYAML.cpp index 789eacba381..af80c1645a6 100644 --- a/llvm/lib/ObjectYAML/MachOYAML.cpp +++ b/llvm/lib/ObjectYAML/MachOYAML.cpp @@ -13,9 +13,6 @@ #include "llvm/ObjectYAML/MachOYAML.h" #include "llvm/Support/Casting.h" -#include "llvm/Support/Format.h" - -#include <string.h> // For memcpy and memset. namespace llvm { @@ -23,52 +20,6 @@ MachOYAML::LoadCommand::~LoadCommand() {} namespace yaml { -void ScalarTraits<char_16>::output(const char_16 &Val, void *, - llvm::raw_ostream &Out) { - Out << Val; -} - -StringRef ScalarTraits<char_16>::input(StringRef Scalar, void *, char_16 &Val) { - size_t CopySize = 16 >= Scalar.size() ? 16 : Scalar.size(); - memcpy((void *)Val, Scalar.data(), CopySize); - - if (Scalar.size() < 16) { - memset((void *)&Val[Scalar.size()], 0, 16 - Scalar.size()); - } - - return StringRef(); -} - -bool ScalarTraits<char_16>::mustQuote(StringRef S) { return needsQuotes(S); } - -void ScalarTraits<uuid_t>::output(const uuid_t &Val, void *, - llvm::raw_ostream &Out) { - for (int Idx = 0; Idx < 16; ++Idx) { - Out << format("%02" PRIX32, Val[Idx]); - if (Idx == 3 || Idx == 5 || Idx == 7 || Idx == 9) - Out << "-"; - } -} - -StringRef ScalarTraits<uuid_t>::input(StringRef Scalar, void *, uuid_t &Val) { - size_t OutIdx = 0; - for (size_t Idx = 0; Idx < Scalar.size(); ++Idx) { - if (Scalar[Idx] == '-' || OutIdx >= 16) - continue; - unsigned long long TempInt; - if (getAsUnsignedInteger(Scalar.slice(Idx, Idx + 2), 16, TempInt)) - return "invalid number"; - if (TempInt > 0xFF) - return "out of range number"; - Val[OutIdx] = static_cast<uint8_t>(TempInt); - ++Idx; // increment idx an extra time because we're consuming 2 chars - ++OutIdx; - } - return StringRef(); -} - -bool ScalarTraits<uuid_t>::mustQuote(StringRef S) { return needsQuotes(S); } - void MappingTraits<MachOYAML::FileHeader>::mapping( IO &IO, MachOYAML::FileHeader &FileHdr) { IO.mapRequired("magic", FileHdr.magic); @@ -95,311 +46,12 @@ void MappingTraits<MachOYAML::Object>::mapping(IO &IO, IO.setContext(nullptr); } -void MappingTraits<MachOYAML::LoadCommand>::mapping( - IO &IO, MachOYAML::LoadCommand &LoadCommand) { - IO.mapRequired( - "cmd", - (MachO::LoadCommandType &)LoadCommand.load_command_data.load_command.cmd); - IO.mapRequired("cmdsize", LoadCommand.load_command_data.load_command.cmdsize); - -#define HANDLE_LOAD_COMMAND(LCName, LCValue, LCStruct) \ - case MachO::LCName: \ - MappingTraits<MachO::LCStruct>::mapping( \ - IO, LoadCommand.load_command_data.LCStruct); \ - break; - - switch (LoadCommand.load_command_data.load_command.cmd) { -#include "llvm/Support/MachO.def" - } -} - -void MappingTraits<MachO::dyld_info_command>::mapping( - IO &IO, MachO::dyld_info_command &LoadCommand) { - IO.mapRequired("rebase_off", LoadCommand.rebase_off); - IO.mapRequired("rebase_size", LoadCommand.rebase_size); - IO.mapRequired("bind_off", LoadCommand.bind_size); - IO.mapRequired("weak_bind_off", LoadCommand.weak_bind_off); - IO.mapRequired("weak_bind_size", LoadCommand.weak_bind_size); - IO.mapRequired("lazy_bind_off", LoadCommand.lazy_bind_size); - IO.mapRequired("export_off", LoadCommand.export_off); - IO.mapRequired("export_size", LoadCommand.export_size); -} - -void MappingTraits<MachO::dylib>::mapping(IO &IO, MachO::dylib &DylibStruct) { - IO.mapRequired("name", DylibStruct.name); - IO.mapRequired("timestamp", DylibStruct.timestamp); - IO.mapRequired("current_version", DylibStruct.current_version); - IO.mapRequired("compatibility_version", DylibStruct.compatibility_version); -} - -void MappingTraits<MachO::dylib_command>::mapping( - IO &IO, MachO::dylib_command &LoadCommand) { - IO.mapRequired("dylib", LoadCommand.dylib); -} - -void MappingTraits<MachO::dylinker_command>::mapping( - IO &IO, MachO::dylinker_command &LoadCommand) { - - IO.mapRequired("name", LoadCommand.name); -} - -void MappingTraits<MachO::dysymtab_command>::mapping( - IO &IO, MachO::dysymtab_command &LoadCommand) { - - IO.mapRequired("ilocalsym", LoadCommand.ilocalsym); - IO.mapRequired("nlocalsym", LoadCommand.nlocalsym); - IO.mapRequired("iextdefsym", LoadCommand.iextdefsym); - IO.mapRequired("nextdefsym", LoadCommand.nextdefsym); - IO.mapRequired("iundefsym", LoadCommand.iundefsym); - IO.mapRequired("nundefsym", LoadCommand.nundefsym); - IO.mapRequired("tocoff", LoadCommand.tocoff); - IO.mapRequired("ntoc", LoadCommand.ntoc); - IO.mapRequired("modtaboff", LoadCommand.modtaboff); - IO.mapRequired("nmodtab", LoadCommand.nmodtab); - IO.mapRequired("extrefsymoff", LoadCommand.extrefsymoff); - IO.mapRequired("nextrefsyms", LoadCommand.nextrefsyms); - IO.mapRequired("indirectsymoff", LoadCommand.indirectsymoff); - IO.mapRequired("nindirectsyms", LoadCommand.nindirectsyms); - IO.mapRequired("extreloff", LoadCommand.extreloff); - IO.mapRequired("nextrel", LoadCommand.nextrel); - IO.mapRequired("locreloff", LoadCommand.locreloff); - IO.mapRequired("nlocrel", LoadCommand.nlocrel); -} - -void MappingTraits<MachO::encryption_info_command>::mapping( - IO &IO, MachO::encryption_info_command &LoadCommand) { - - IO.mapRequired("cryptoff", LoadCommand.cryptoff); - IO.mapRequired("cryptsize", LoadCommand.cryptsize); - IO.mapRequired("cryptid", LoadCommand.cryptid); -} - -void MappingTraits<MachO::encryption_info_command_64>::mapping( - IO &IO, MachO::encryption_info_command_64 &LoadCommand) { - - IO.mapRequired("cryptoff", LoadCommand.cryptoff); - IO.mapRequired("cryptsize", LoadCommand.cryptsize); - IO.mapRequired("cryptid", LoadCommand.cryptid); - IO.mapRequired("pad", LoadCommand.pad); -} - -void MappingTraits<MachO::entry_point_command>::mapping( - IO &IO, MachO::entry_point_command &LoadCommand) { - - IO.mapRequired("entryoff", LoadCommand.entryoff); - IO.mapRequired("stacksize", LoadCommand.stacksize); -} - -void MappingTraits<MachO::fvmfile_command>::mapping( - IO &IO, MachO::fvmfile_command &LoadCommand) { - - IO.mapRequired("name", LoadCommand.name); - IO.mapRequired("header_addr", LoadCommand.header_addr); -} - -void MappingTraits<MachO::fvmlib>::mapping(IO &IO, MachO::fvmlib &FVMLib) { - IO.mapRequired("name", FVMLib.name); - IO.mapRequired("minor_version", FVMLib.minor_version); - IO.mapRequired("header_addr", FVMLib.header_addr); -} - -void MappingTraits<MachO::fvmlib_command>::mapping( - IO &IO, MachO::fvmlib_command &LoadCommand) { - - IO.mapRequired("fvmlib", LoadCommand.fvmlib); -} - -void MappingTraits<MachO::ident_command>::mapping( - IO &IO, MachO::ident_command &LoadCommand) {} - -void MappingTraits<MachO::linkedit_data_command>::mapping( - IO &IO, MachO::linkedit_data_command &LoadCommand) { - - IO.mapRequired("dataoff", LoadCommand.dataoff); - IO.mapRequired("datasize", LoadCommand.datasize); -} - -void MappingTraits<MachO::linker_option_command>::mapping( - IO &IO, MachO::linker_option_command &LoadCommand) { - - IO.mapRequired("count", LoadCommand.count); -} - -void MappingTraits<MachO::prebind_cksum_command>::mapping( - IO &IO, MachO::prebind_cksum_command &LoadCommand) { - - IO.mapRequired("cksum", LoadCommand.cksum); -} - -void MappingTraits<MachO::load_command>::mapping( - IO &IO, MachO::load_command &LoadCommand) {} - -void MappingTraits<MachO::prebound_dylib_command>::mapping( - IO &IO, MachO::prebound_dylib_command &LoadCommand) { - - IO.mapRequired("name", LoadCommand.name); - IO.mapRequired("nmodules", LoadCommand.nmodules); - IO.mapRequired("linked_modules", LoadCommand.linked_modules); -} - -void MappingTraits<MachO::routines_command>::mapping( - IO &IO, MachO::routines_command &LoadCommand) { - - IO.mapRequired("init_address", LoadCommand.init_address); - IO.mapRequired("init_module", LoadCommand.init_module); - IO.mapRequired("reserved1", LoadCommand.reserved1); - IO.mapRequired("reserved2", LoadCommand.reserved2); - IO.mapRequired("reserved3", LoadCommand.reserved3); - IO.mapRequired("reserved4", LoadCommand.reserved4); - IO.mapRequired("reserved5", LoadCommand.reserved5); - IO.mapRequired("reserved6", LoadCommand.reserved6); -} - -void MappingTraits<MachO::routines_command_64>::mapping( - IO &IO, MachO::routines_command_64 &LoadCommand) { - - IO.mapRequired("init_address", LoadCommand.init_address); - IO.mapRequired("init_module", LoadCommand.init_module); - IO.mapRequired("reserved1", LoadCommand.reserved1); - IO.mapRequired("reserved2", LoadCommand.reserved2); - IO.mapRequired("reserved3", LoadCommand.reserved3); - IO.mapRequired("reserved4", LoadCommand.reserved4); - IO.mapRequired("reserved5", LoadCommand.reserved5); - IO.mapRequired("reserved6", LoadCommand.reserved6); -} - -void MappingTraits<MachO::rpath_command>::mapping( - IO &IO, MachO::rpath_command &LoadCommand) { - - IO.mapRequired("path", LoadCommand.path); -} - -void MappingTraits<MachO::section>::mapping(IO &IO, MachO::section &Section) { - IO.mapRequired("sectname", Section.sectname); - IO.mapRequired("segname", Section.segname); - IO.mapRequired("addr", Section.addr); - IO.mapRequired("size", Section.size); - IO.mapRequired("offset", Section.offset); - IO.mapRequired("align", Section.align); - IO.mapRequired("reloff", Section.reloff); - IO.mapRequired("nreloc", Section.nreloc); - IO.mapRequired("flags", Section.flags); - IO.mapRequired("reserved1", Section.reserved1); - IO.mapRequired("reserved2", Section.reserved2); -} - -void MappingTraits<MachO::section_64>::mapping(IO &IO, - MachO::section_64 &Section) { - IO.mapRequired("sectname", Section.sectname); - IO.mapRequired("segname", Section.segname); - IO.mapRequired("addr", Section.addr); - IO.mapRequired("size", Section.size); - IO.mapRequired("offset", Section.offset); - IO.mapRequired("align", Section.align); - IO.mapRequired("reloff", Section.reloff); - IO.mapRequired("nreloc", Section.nreloc); - IO.mapRequired("flags", Section.flags); - IO.mapRequired("reserved1", Section.reserved1); - IO.mapRequired("reserved2", Section.reserved2); - IO.mapRequired("reserved3", Section.reserved3); -} - -void MappingTraits<MachO::segment_command>::mapping( - IO &IO, MachO::segment_command &LoadCommand) { - - IO.mapRequired("segname", LoadCommand.segname); - IO.mapRequired("vmaddr", LoadCommand.vmaddr); - IO.mapRequired("vmsize", LoadCommand.vmsize); - IO.mapRequired("fileoff", LoadCommand.fileoff); - IO.mapRequired("filesize", LoadCommand.filesize); - IO.mapRequired("maxprot", LoadCommand.maxprot); - IO.mapRequired("initprot", LoadCommand.initprot); - IO.mapRequired("nsects", LoadCommand.nsects); - IO.mapRequired("flags", LoadCommand.flags); -} - -void MappingTraits<MachO::segment_command_64>::mapping( - IO &IO, MachO::segment_command_64 &LoadCommand) { - - IO.mapRequired("segname", LoadCommand.segname); - IO.mapRequired("vmaddr", LoadCommand.vmaddr); - IO.mapRequired("vmsize", LoadCommand.vmsize); - IO.mapRequired("fileoff", LoadCommand.fileoff); - IO.mapRequired("filesize", LoadCommand.filesize); - IO.mapRequired("maxprot", LoadCommand.maxprot); - IO.mapRequired("initprot", LoadCommand.initprot); - IO.mapRequired("nsects", LoadCommand.nsects); - IO.mapRequired("flags", LoadCommand.flags); -} - -void MappingTraits<MachO::source_version_command>::mapping( - IO &IO, MachO::source_version_command &LoadCommand) { - - IO.mapRequired("version", LoadCommand.version); -} - -void MappingTraits<MachO::sub_client_command>::mapping( - IO &IO, MachO::sub_client_command &LoadCommand) { - - IO.mapRequired("client", LoadCommand.client); -} - -void MappingTraits<MachO::sub_framework_command>::mapping( - IO &IO, MachO::sub_framework_command &LoadCommand) { - - IO.mapRequired("umbrella", LoadCommand.umbrella); -} - -void MappingTraits<MachO::sub_library_command>::mapping( - IO &IO, MachO::sub_library_command &LoadCommand) { - - IO.mapRequired("sub_library", LoadCommand.sub_library); -} - -void MappingTraits<MachO::sub_umbrella_command>::mapping( - IO &IO, MachO::sub_umbrella_command &LoadCommand) { - - IO.mapRequired("sub_umbrella", LoadCommand.sub_umbrella); -} - -void MappingTraits<MachO::symseg_command>::mapping( - IO &IO, MachO::symseg_command &LoadCommand) { - - IO.mapRequired("offset", LoadCommand.offset); - IO.mapRequired("size", LoadCommand.size); -} - -void MappingTraits<MachO::symtab_command>::mapping( - IO &IO, MachO::symtab_command &LoadCommand) { - - IO.mapRequired("symoff", LoadCommand.symoff); - IO.mapRequired("nsyms", LoadCommand.nsyms); - IO.mapRequired("stroff", LoadCommand.stroff); - IO.mapRequired("strsize", LoadCommand.strsize); -} - -void MappingTraits<MachO::thread_command>::mapping( - IO &IO, MachO::thread_command &LoadCommand) {} - -void MappingTraits<MachO::twolevel_hints_command>::mapping( - IO &IO, MachO::twolevel_hints_command &LoadCommand) { - - IO.mapRequired("offset", LoadCommand.offset); - IO.mapRequired("nhints", LoadCommand.nhints); -} - -void MappingTraits<MachO::uuid_command>::mapping( - IO &IO, MachO::uuid_command &LoadCommand) { - - IO.mapRequired("cmdsize", LoadCommand.cmdsize); - IO.mapRequired("uuid", LoadCommand.uuid); -} - -void MappingTraits<MachO::version_min_command>::mapping( - IO &IO, MachO::version_min_command &LoadCommand) { - - IO.mapRequired("version", LoadCommand.version); - IO.mapRequired("sdk", LoadCommand.sdk); +void MappingTraits<std::unique_ptr<MachOYAML::LoadCommand>>::mapping( + IO &IO, std::unique_ptr<MachOYAML::LoadCommand> &LoadCommand) { + if (!IO.outputting()) + LoadCommand.reset(new MachOYAML::LoadCommand()); + IO.mapRequired("cmd", LoadCommand->cmd); + IO.mapRequired("cmdsize", LoadCommand->cmdsize); } } // namespace llvm::yaml |