blob: 18c9efaceed06f1fe6a9492f1058c70829b65e7f [file] [log] [blame]
Joseph Huber25fe33d2022-03-25 11:02:29 -04001#include "llvm/Object/OffloadBinary.h"
2
3#include "llvm/Testing/Support/Error.h"
4#include "gtest/gtest.h"
5#include <random>
6
Joseph Huberde1fe202022-06-01 15:28:34 -04007using namespace llvm;
8using namespace llvm::object;
9
Joseph Huber25fe33d2022-03-25 11:02:29 -040010TEST(OffloadingTest, checkOffloadingBinary) {
11 // Create random data to fill the image.
12 std::mt19937 Rng(std::random_device{}());
13 std::uniform_int_distribution<uint64_t> SizeDist(0, 256);
14 std::uniform_int_distribution<uint16_t> KindDist(0);
15 std::uniform_int_distribution<uint16_t> BinaryDist(
16 std::numeric_limits<uint8_t>::min(), std::numeric_limits<uint8_t>::max());
17 std::uniform_int_distribution<int16_t> StringDist('!', '~');
18 std::vector<uint8_t> Image(SizeDist(Rng));
19 std::generate(Image.begin(), Image.end(), [&]() { return BinaryDist(Rng); });
20 std::vector<std::pair<std::string, std::string>> Strings(SizeDist(Rng));
21 for (auto &KeyAndValue : Strings) {
22 std::string Key(SizeDist(Rng), '\0');
23 std::string Value(SizeDist(Rng), '\0');
24
25 std::generate(Key.begin(), Key.end(), [&]() { return StringDist(Rng); });
26 std::generate(Value.begin(), Value.end(),
27 [&]() { return StringDist(Rng); });
28
29 KeyAndValue = std::make_pair(Key, Value);
30 }
31
32 // Create the image.
Fangrui Songd7680af2023-02-04 12:34:55 -080033 MapVector<StringRef, StringRef> StringData;
Joseph Huber25fe33d2022-03-25 11:02:29 -040034 for (auto &KeyAndValue : Strings)
35 StringData[KeyAndValue.first] = KeyAndValue.second;
Joseph Huberde1fe202022-06-01 15:28:34 -040036 std::unique_ptr<MemoryBuffer> ImageData = MemoryBuffer::getMemBuffer(
37 {reinterpret_cast<char *>(Image.data()), Image.size()}, "", false);
Joseph Huber25fe33d2022-03-25 11:02:29 -040038
Joseph Huberde1fe202022-06-01 15:28:34 -040039 OffloadBinary::OffloadingImage Data;
40 Data.TheImageKind = static_cast<ImageKind>(KindDist(Rng));
41 Data.TheOffloadKind = static_cast<OffloadKind>(KindDist(Rng));
Joseph Huber25fe33d2022-03-25 11:02:29 -040042 Data.Flags = KindDist(Rng);
43 Data.StringData = StringData;
Joseph Huber549f7dd2022-06-06 13:08:01 -040044 Data.Image = std::move(ImageData);
Joseph Huber25fe33d2022-03-25 11:02:29 -040045
Fangrui Songe6edb792023-09-01 09:19:25 -070046 auto BinaryBuffer =
47 MemoryBuffer::getMemBufferCopy(OffloadBinary::write(Data));
Joseph Huberde1fe202022-06-01 15:28:34 -040048 auto BinaryOrErr = OffloadBinary::create(*BinaryBuffer);
Joseph Huber25fe33d2022-03-25 11:02:29 -040049 if (!BinaryOrErr)
50 FAIL();
51
52 // Make sure we get the same data out.
53 auto &Binary = **BinaryOrErr;
54 ASSERT_EQ(Data.TheImageKind, Binary.getImageKind());
55 ASSERT_EQ(Data.TheOffloadKind, Binary.getOffloadKind());
56 ASSERT_EQ(Data.Flags, Binary.getFlags());
57
58 for (auto &KeyAndValue : Strings)
59 ASSERT_TRUE(StringData[KeyAndValue.first] ==
60 Binary.getString(KeyAndValue.first));
61
Joseph Huber549f7dd2022-06-06 13:08:01 -040062 EXPECT_TRUE(Data.Image->getBuffer() == Binary.getImage());
Joseph Huber25fe33d2022-03-25 11:02:29 -040063
64 // Ensure the size and alignment of the data is correct.
Joseph Huberde1fe202022-06-01 15:28:34 -040065 EXPECT_TRUE(Binary.getSize() % OffloadBinary::getAlignment() == 0);
Joseph Huber25fe33d2022-03-25 11:02:29 -040066 EXPECT_TRUE(Binary.getSize() == BinaryBuffer->getBuffer().size());
67}