Replacing the private implementations of SwapValue with calls to sys::swapByteOrder()

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@210980 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Artyom Skrobov
2014-06-14 13:49:57 +00:00
parent ab22d95481
commit f6b4b10c29
2 changed files with 120 additions and 130 deletions

View File

@ -43,201 +43,196 @@ struct section_base {
char segname[16]; char segname[16];
}; };
template<typename T>
static void SwapValue(T &Value) {
Value = sys::getSwappedBytes(Value);
}
template<typename T> template<typename T>
static void SwapStruct(T &Value); static void SwapStruct(T &Value);
template<> template<>
void SwapStruct(MachO::any_relocation_info &H) { void SwapStruct(MachO::any_relocation_info &H) {
SwapValue(H.r_word0); sys::swapByteOrder(H.r_word0);
SwapValue(H.r_word1); sys::swapByteOrder(H.r_word1);
} }
template<> template<>
void SwapStruct(MachO::load_command &L) { void SwapStruct(MachO::load_command &L) {
SwapValue(L.cmd); sys::swapByteOrder(L.cmd);
SwapValue(L.cmdsize); sys::swapByteOrder(L.cmdsize);
} }
template<> template<>
void SwapStruct(nlist_base &S) { void SwapStruct(nlist_base &S) {
SwapValue(S.n_strx); sys::swapByteOrder(S.n_strx);
SwapValue(S.n_desc); sys::swapByteOrder(S.n_desc);
} }
template<> template<>
void SwapStruct(MachO::section &S) { void SwapStruct(MachO::section &S) {
SwapValue(S.addr); sys::swapByteOrder(S.addr);
SwapValue(S.size); sys::swapByteOrder(S.size);
SwapValue(S.offset); sys::swapByteOrder(S.offset);
SwapValue(S.align); sys::swapByteOrder(S.align);
SwapValue(S.reloff); sys::swapByteOrder(S.reloff);
SwapValue(S.nreloc); sys::swapByteOrder(S.nreloc);
SwapValue(S.flags); sys::swapByteOrder(S.flags);
SwapValue(S.reserved1); sys::swapByteOrder(S.reserved1);
SwapValue(S.reserved2); sys::swapByteOrder(S.reserved2);
} }
template<> template<>
void SwapStruct(MachO::section_64 &S) { void SwapStruct(MachO::section_64 &S) {
SwapValue(S.addr); sys::swapByteOrder(S.addr);
SwapValue(S.size); sys::swapByteOrder(S.size);
SwapValue(S.offset); sys::swapByteOrder(S.offset);
SwapValue(S.align); sys::swapByteOrder(S.align);
SwapValue(S.reloff); sys::swapByteOrder(S.reloff);
SwapValue(S.nreloc); sys::swapByteOrder(S.nreloc);
SwapValue(S.flags); sys::swapByteOrder(S.flags);
SwapValue(S.reserved1); sys::swapByteOrder(S.reserved1);
SwapValue(S.reserved2); sys::swapByteOrder(S.reserved2);
SwapValue(S.reserved3); sys::swapByteOrder(S.reserved3);
} }
template<> template<>
void SwapStruct(MachO::nlist &S) { void SwapStruct(MachO::nlist &S) {
SwapValue(S.n_strx); sys::swapByteOrder(S.n_strx);
SwapValue(S.n_desc); sys::swapByteOrder(S.n_desc);
SwapValue(S.n_value); sys::swapByteOrder(S.n_value);
} }
template<> template<>
void SwapStruct(MachO::nlist_64 &S) { void SwapStruct(MachO::nlist_64 &S) {
SwapValue(S.n_strx); sys::swapByteOrder(S.n_strx);
SwapValue(S.n_desc); sys::swapByteOrder(S.n_desc);
SwapValue(S.n_value); sys::swapByteOrder(S.n_value);
} }
template<> template<>
void SwapStruct(MachO::mach_header &H) { void SwapStruct(MachO::mach_header &H) {
SwapValue(H.magic); sys::swapByteOrder(H.magic);
SwapValue(H.cputype); sys::swapByteOrder(H.cputype);
SwapValue(H.cpusubtype); sys::swapByteOrder(H.cpusubtype);
SwapValue(H.filetype); sys::swapByteOrder(H.filetype);
SwapValue(H.ncmds); sys::swapByteOrder(H.ncmds);
SwapValue(H.sizeofcmds); sys::swapByteOrder(H.sizeofcmds);
SwapValue(H.flags); sys::swapByteOrder(H.flags);
} }
template<> template<>
void SwapStruct(MachO::mach_header_64 &H) { void SwapStruct(MachO::mach_header_64 &H) {
SwapValue(H.magic); sys::swapByteOrder(H.magic);
SwapValue(H.cputype); sys::swapByteOrder(H.cputype);
SwapValue(H.cpusubtype); sys::swapByteOrder(H.cpusubtype);
SwapValue(H.filetype); sys::swapByteOrder(H.filetype);
SwapValue(H.ncmds); sys::swapByteOrder(H.ncmds);
SwapValue(H.sizeofcmds); sys::swapByteOrder(H.sizeofcmds);
SwapValue(H.flags); sys::swapByteOrder(H.flags);
SwapValue(H.reserved); sys::swapByteOrder(H.reserved);
} }
template<> template<>
void SwapStruct(MachO::symtab_command &C) { void SwapStruct(MachO::symtab_command &C) {
SwapValue(C.cmd); sys::swapByteOrder(C.cmd);
SwapValue(C.cmdsize); sys::swapByteOrder(C.cmdsize);
SwapValue(C.symoff); sys::swapByteOrder(C.symoff);
SwapValue(C.nsyms); sys::swapByteOrder(C.nsyms);
SwapValue(C.stroff); sys::swapByteOrder(C.stroff);
SwapValue(C.strsize); sys::swapByteOrder(C.strsize);
} }
template<> template<>
void SwapStruct(MachO::dysymtab_command &C) { void SwapStruct(MachO::dysymtab_command &C) {
SwapValue(C.cmd); sys::swapByteOrder(C.cmd);
SwapValue(C.cmdsize); sys::swapByteOrder(C.cmdsize);
SwapValue(C.ilocalsym); sys::swapByteOrder(C.ilocalsym);
SwapValue(C.nlocalsym); sys::swapByteOrder(C.nlocalsym);
SwapValue(C.iextdefsym); sys::swapByteOrder(C.iextdefsym);
SwapValue(C.nextdefsym); sys::swapByteOrder(C.nextdefsym);
SwapValue(C.iundefsym); sys::swapByteOrder(C.iundefsym);
SwapValue(C.nundefsym); sys::swapByteOrder(C.nundefsym);
SwapValue(C.tocoff); sys::swapByteOrder(C.tocoff);
SwapValue(C.ntoc); sys::swapByteOrder(C.ntoc);
SwapValue(C.modtaboff); sys::swapByteOrder(C.modtaboff);
SwapValue(C.nmodtab); sys::swapByteOrder(C.nmodtab);
SwapValue(C.extrefsymoff); sys::swapByteOrder(C.extrefsymoff);
SwapValue(C.nextrefsyms); sys::swapByteOrder(C.nextrefsyms);
SwapValue(C.indirectsymoff); sys::swapByteOrder(C.indirectsymoff);
SwapValue(C.nindirectsyms); sys::swapByteOrder(C.nindirectsyms);
SwapValue(C.extreloff); sys::swapByteOrder(C.extreloff);
SwapValue(C.nextrel); sys::swapByteOrder(C.nextrel);
SwapValue(C.locreloff); sys::swapByteOrder(C.locreloff);
SwapValue(C.nlocrel); sys::swapByteOrder(C.nlocrel);
} }
template<> template<>
void SwapStruct(MachO::linkedit_data_command &C) { void SwapStruct(MachO::linkedit_data_command &C) {
SwapValue(C.cmd); sys::swapByteOrder(C.cmd);
SwapValue(C.cmdsize); sys::swapByteOrder(C.cmdsize);
SwapValue(C.dataoff); sys::swapByteOrder(C.dataoff);
SwapValue(C.datasize); sys::swapByteOrder(C.datasize);
} }
template<> template<>
void SwapStruct(MachO::segment_command &C) { void SwapStruct(MachO::segment_command &C) {
SwapValue(C.cmd); sys::swapByteOrder(C.cmd);
SwapValue(C.cmdsize); sys::swapByteOrder(C.cmdsize);
SwapValue(C.vmaddr); sys::swapByteOrder(C.vmaddr);
SwapValue(C.vmsize); sys::swapByteOrder(C.vmsize);
SwapValue(C.fileoff); sys::swapByteOrder(C.fileoff);
SwapValue(C.filesize); sys::swapByteOrder(C.filesize);
SwapValue(C.maxprot); sys::swapByteOrder(C.maxprot);
SwapValue(C.initprot); sys::swapByteOrder(C.initprot);
SwapValue(C.nsects); sys::swapByteOrder(C.nsects);
SwapValue(C.flags); sys::swapByteOrder(C.flags);
} }
template<> template<>
void SwapStruct(MachO::segment_command_64 &C) { void SwapStruct(MachO::segment_command_64 &C) {
SwapValue(C.cmd); sys::swapByteOrder(C.cmd);
SwapValue(C.cmdsize); sys::swapByteOrder(C.cmdsize);
SwapValue(C.vmaddr); sys::swapByteOrder(C.vmaddr);
SwapValue(C.vmsize); sys::swapByteOrder(C.vmsize);
SwapValue(C.fileoff); sys::swapByteOrder(C.fileoff);
SwapValue(C.filesize); sys::swapByteOrder(C.filesize);
SwapValue(C.maxprot); sys::swapByteOrder(C.maxprot);
SwapValue(C.initprot); sys::swapByteOrder(C.initprot);
SwapValue(C.nsects); sys::swapByteOrder(C.nsects);
SwapValue(C.flags); sys::swapByteOrder(C.flags);
} }
template<> template<>
void SwapStruct(uint32_t &C) { void SwapStruct(uint32_t &C) {
SwapValue(C); sys::swapByteOrder(C);
} }
template<> template<>
void SwapStruct(MachO::linker_options_command &C) { void SwapStruct(MachO::linker_options_command &C) {
SwapValue(C.cmd); sys::swapByteOrder(C.cmd);
SwapValue(C.cmdsize); sys::swapByteOrder(C.cmdsize);
SwapValue(C.count); sys::swapByteOrder(C.count);
} }
template<> template<>
void SwapStruct(MachO::version_min_command&C) { void SwapStruct(MachO::version_min_command&C) {
SwapValue(C.cmd); sys::swapByteOrder(C.cmd);
SwapValue(C.cmdsize); sys::swapByteOrder(C.cmdsize);
SwapValue(C.version); sys::swapByteOrder(C.version);
SwapValue(C.reserved); sys::swapByteOrder(C.reserved);
} }
template<> template<>
void SwapStruct(MachO::dylib_command&C) { void SwapStruct(MachO::dylib_command&C) {
SwapValue(C.cmd); sys::swapByteOrder(C.cmd);
SwapValue(C.cmdsize); sys::swapByteOrder(C.cmdsize);
SwapValue(C.dylib.name); sys::swapByteOrder(C.dylib.name);
SwapValue(C.dylib.timestamp); sys::swapByteOrder(C.dylib.timestamp);
SwapValue(C.dylib.current_version); sys::swapByteOrder(C.dylib.current_version);
SwapValue(C.dylib.compatibility_version); sys::swapByteOrder(C.dylib.compatibility_version);
} }
template<> template<>
void SwapStruct(MachO::data_in_code_entry &C) { void SwapStruct(MachO::data_in_code_entry &C) {
SwapValue(C.offset); sys::swapByteOrder(C.offset);
SwapValue(C.length); sys::swapByteOrder(C.length);
SwapValue(C.kind); sys::swapByteOrder(C.kind);
} }
template<typename T> template<typename T>

View File

@ -22,27 +22,22 @@
using namespace llvm; using namespace llvm;
using namespace object; using namespace object;
template<typename T>
static void SwapValue(T &Value) {
Value = sys::getSwappedBytes(Value);
}
template<typename T> template<typename T>
static void SwapStruct(T &Value); static void SwapStruct(T &Value);
template<> template<>
void SwapStruct(MachO::fat_header &H) { void SwapStruct(MachO::fat_header &H) {
SwapValue(H.magic); sys::swapByteOrder(H.magic);
SwapValue(H.nfat_arch); sys::swapByteOrder(H.nfat_arch);
} }
template<> template<>
void SwapStruct(MachO::fat_arch &H) { void SwapStruct(MachO::fat_arch &H) {
SwapValue(H.cputype); sys::swapByteOrder(H.cputype);
SwapValue(H.cpusubtype); sys::swapByteOrder(H.cpusubtype);
SwapValue(H.offset); sys::swapByteOrder(H.offset);
SwapValue(H.size); sys::swapByteOrder(H.size);
SwapValue(H.align); sys::swapByteOrder(H.align);
} }
template<typename T> template<typename T>