File: cpuintrinsics_tests.cpp

package info (click to toggle)
intel-compute-runtime 22.43.24595.41-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 57,740 kB
  • sloc: cpp: 631,142; lisp: 3,515; sh: 470; makefile: 76; python: 21
file content (38 lines) | stat: -rw-r--r-- 1,160 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/*
 * Copyright (C) 2020-2022 Intel Corporation
 *
 * SPDX-License-Identifier: MIT
 *
 */

#include "shared/source/utilities/cpuintrinsics.h"

#include "gtest/gtest.h"

#include <atomic>
#include <cstdint>

namespace CpuIntrinsicsTests {
extern std::atomic<uintptr_t> lastClFlushedPtr;
extern std::atomic<uint32_t> pauseCounter;
extern std::atomic<uint32_t> sfenceCounter;
} // namespace CpuIntrinsicsTests

TEST(CpuIntrinsicsTest, whenClFlushIsCalledThenExpectToPassPtrToSystemCall) {
    uintptr_t flushAddr = 0x1234;
    void const *ptr = reinterpret_cast<void const *>(flushAddr);
    NEO::CpuIntrinsics::clFlush(ptr);
    EXPECT_EQ(flushAddr, CpuIntrinsicsTests::lastClFlushedPtr);
}

TEST(CpuIntrinsicsTest, whenPauseCalledThenExpectToIncreaseCounter) {
    uint32_t oldCount = CpuIntrinsicsTests::pauseCounter.load();
    NEO::CpuIntrinsics::pause();
    EXPECT_EQ(oldCount + 1, CpuIntrinsicsTests::pauseCounter);
}

TEST(CpuIntrinsicsTest, whenSfenceCalledThenExpectToIncreaseCounter) {
    uint32_t oldCount = CpuIntrinsicsTests::sfenceCounter.load();
    NEO::CpuIntrinsics::sfence();
    EXPECT_EQ(oldCount + 1, CpuIntrinsicsTests::sfenceCounter);
}