summaryrefslogtreecommitdiffstats
path: root/lld/unittests/MachOTests
diff options
context:
space:
mode:
authorNick Kledzik <kledzik@apple.com>2014-01-08 02:52:58 +0000
committerNick Kledzik <kledzik@apple.com>2014-01-08 02:52:58 +0000
commit36baa33fc1b7da84428a64b502eb762888df2095 (patch)
treef79d057e443a45f51283541dde6d7fa389daf9ad /lld/unittests/MachOTests
parent6b6ea7ac17b0dadb8d91bf8d1fcfba496f7e1597 (diff)
downloadbcm5719-llvm-36baa33fc1b7da84428a64b502eb762888df2095.tar.gz
bcm5719-llvm-36baa33fc1b7da84428a64b502eb762888df2095.zip
[mach-o] properly extract atom content from subrange of section content
llvm-svn: 198728
Diffstat (limited to 'lld/unittests/MachOTests')
-rw-r--r--lld/unittests/MachOTests/MachONormalizedFileToAtomsTests.cpp50
1 files changed, 29 insertions, 21 deletions
diff --git a/lld/unittests/MachOTests/MachONormalizedFileToAtomsTests.cpp b/lld/unittests/MachOTests/MachONormalizedFileToAtomsTests.cpp
index 9b2859a5961..ddd5591ed08 100644
--- a/lld/unittests/MachOTests/MachONormalizedFileToAtomsTests.cpp
+++ b/lld/unittests/MachOTests/MachONormalizedFileToAtomsTests.cpp
@@ -20,42 +20,50 @@ using llvm::ErrorOr;
using namespace lld::mach_o::normalized;
using namespace llvm::MachO;
-unsigned countDefinedAtoms(const lld::File &file) {
- unsigned count = 0;
- for (const auto &d : file.defined()) {
- (void)d;
- ++count;
- }
- return count;
-}
-
TEST(ToAtomsTest, empty_obj_x86_64) {
NormalizedFile f;
f.arch = lld::MachOLinkingContext::arch_x86_64;
ErrorOr<std::unique_ptr<const lld::File>> atom_f = normalizedToAtoms(f, "");
EXPECT_FALSE(!atom_f);
- EXPECT_EQ(0U, countDefinedAtoms(**atom_f));
+ EXPECT_EQ(0U, (*atom_f)->defined().size());
}
TEST(ToAtomsTest, basic_obj_x86_64) {
NormalizedFile f;
f.arch = lld::MachOLinkingContext::arch_x86_64;
Section textSection;
- static const uint8_t contentBytes[] = { 0x55, 0x48, 0x89, 0xE5,
- 0x31, 0xC0, 0x5D, 0xC3 };
+ static const uint8_t contentBytes[] = { 0x90, 0xC3, 0xC3 };
const unsigned contentSize = sizeof(contentBytes) / sizeof(contentBytes[0]);
textSection.content.insert(textSection.content.begin(), contentBytes,
&contentBytes[contentSize]);
f.sections.push_back(textSection);
- Symbol mainSymbol;
- mainSymbol.name = "_main";
- mainSymbol.type = N_SECT;
- mainSymbol.sect = 1;
- f.globalSymbols.push_back(mainSymbol);
+ Symbol fooSymbol;
+ fooSymbol.name = "_foo";
+ fooSymbol.type = N_SECT;
+ fooSymbol.sect = 1;
+ fooSymbol.value = 0;
+ f.globalSymbols.push_back(fooSymbol);
+ Symbol barSymbol;
+ barSymbol.name = "_bar";
+ barSymbol.type = N_SECT;
+ barSymbol.sect = 1;
+ barSymbol.value = 2;
+ f.globalSymbols.push_back(barSymbol);
+
ErrorOr<std::unique_ptr<const lld::File>> atom_f = normalizedToAtoms(f, "");
EXPECT_FALSE(!atom_f);
- EXPECT_EQ(1U, countDefinedAtoms(**atom_f));
- const lld::DefinedAtom *singleAtom = *(*atom_f)->defined().begin();
- llvm::ArrayRef<uint8_t> atomContent(singleAtom->rawContent());
- EXPECT_EQ(0, memcmp(atomContent.data(), contentBytes, contentSize));
+ const lld::File &file = **atom_f;
+ EXPECT_EQ(2U, file.defined().size());
+ lld::File::defined_iterator it = file.defined().begin();
+ const lld::DefinedAtom *atom1 = *it;
+ ++it;
+ const lld::DefinedAtom *atom2 = *it;
+ EXPECT_TRUE(atom1->name().equals("_foo"));
+ EXPECT_EQ(2U, atom1->rawContent().size());
+ EXPECT_EQ(0x90, atom1->rawContent()[0]);
+ EXPECT_EQ(0xC3, atom1->rawContent()[1]);
+
+ EXPECT_TRUE(atom2->name().equals("_bar"));
+ EXPECT_EQ(1U, atom2->rawContent().size());
+ EXPECT_EQ(0xC3, atom2->rawContent()[0]);
}
OpenPOWER on IntegriCloud