#include "executor_address.h"
#include "gtest/gtest.h"
using namespace __orc_rt;
TEST(ExecutorAddrTest, DefaultAndNull) {
ExecutorAddr Default;
ExecutorAddr Null(0);
ExecutorAddr NonNull(1);
EXPECT_TRUE(Null.isNull());
EXPECT_EQ(Default, Null);
EXPECT_FALSE(NonNull.isNull());
EXPECT_NE(Default, NonNull);
}
TEST(ExecutorAddrTest, Ordering) {
ExecutorAddr A1(1), A2(2);
EXPECT_LE(A1, A1);
EXPECT_LT(A1, A2);
EXPECT_GT(A2, A1);
EXPECT_GE(A2, A2);
}
TEST(ExecutorAddrTest, PtrConversion) {
int X = 0;
auto XAddr = ExecutorAddr::fromPtr(&X);
int *XPtr = XAddr.toPtr<int *>();
EXPECT_EQ(XPtr, &X);
}
static void F() {}
TEST(ExecutorAddrTest, PtrConversionWithFunctionType) {
auto FAddr = ExecutorAddr::fromPtr(F);
void (*FPtr)() = FAddr.toPtr<void()>();
EXPECT_EQ(FPtr, &F);
}
TEST(ExecutorAddrTest, WrappingAndUnwrapping) {
constexpr uintptr_t RawAddr = 0x123456;
int *RawPtr = (int *)RawAddr;
constexpr uintptr_t TagOffset = 8 * (sizeof(uintptr_t) - 1);
uintptr_t TagVal = 0xA5;
uintptr_t TagBits = TagVal << TagOffset;
void *TaggedPtr = (void *)((uintptr_t)RawPtr | TagBits);
ExecutorAddr EA =
ExecutorAddr::fromPtr(TaggedPtr, ExecutorAddr::Untag(8, TagOffset));
EXPECT_EQ(EA.getValue(), RawAddr);
void *ReconstitutedTaggedPtr =
EA.toPtr<void *>(ExecutorAddr::Tag(TagVal, TagOffset));
EXPECT_EQ(TaggedPtr, ReconstitutedTaggedPtr);
}
TEST(ExecutorAddrTest, AddrRanges) {
ExecutorAddr A0(0), A1(1), A2(2), A3(3);
ExecutorAddrRange R0(A0, A1), R1(A1, A2), R2(A2, A3), R3(A0, A2), R4(A1, A3);
EXPECT_EQ(R1, ExecutorAddrRange(A1, A2));
EXPECT_EQ(R1, ExecutorAddrRange(A1, ExecutorAddrDiff(1)));
EXPECT_NE(R1, R2);
EXPECT_TRUE(R1.contains(A1));
EXPECT_FALSE(R1.contains(A0));
EXPECT_FALSE(R1.contains(A2));
EXPECT_FALSE(R1.overlaps(R0));
EXPECT_FALSE(R1.overlaps(R2));
EXPECT_TRUE(R1.overlaps(R3));
EXPECT_TRUE(R1.overlaps(R4));
}
TEST(ExecutorAddrTest, Hashable) {
uint64_t RawAddr = 0x1234567890ABCDEF;
ExecutorAddr Addr(RawAddr);
EXPECT_EQ(std::hash<uint64_t>()(RawAddr), std::hash<ExecutorAddr>()(Addr));
}