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 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
/*
* Copyright (C) 2020-2025 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#include "shared/source/utilities/cpuintrinsics.h"
#if defined(_WIN32)
#include <immintrin.h>
#include <intrin.h>
#pragma intrinsic(__rdtsc)
#else
#if defined(__ARM_ARCH)
extern "C" uint64_t __rdtsc();
#else
#include <immintrin.h>
#include <x86intrin.h>
#endif
#endif
#if defined(__ARM_ARCH)
#include <sse2neon.h>
#else
#include <emmintrin.h>
#endif
namespace NEO {
namespace CpuIntrinsics {
void clFlush(void const *ptr) {
_mm_clflush(ptr);
}
void clFlushOpt(void *ptr) {
#ifdef SUPPORTS_CLFLUSHOPT
_mm_clflushopt(ptr);
#else
_mm_clflush(ptr);
#endif
}
void sfence() {
_mm_sfence();
}
void mfence() {
_mm_mfence();
}
void pause() {
_mm_pause();
}
uint8_t tpause(uint32_t control, uint64_t counter) {
#ifdef SUPPORTS_WAITPKG
return _tpause(control, counter);
#else
return 0;
#endif
}
unsigned char umwait(unsigned int ctrl, uint64_t counter) {
#ifdef SUPPORTS_WAITPKG
return _umwait(ctrl, counter);
#else
return 0;
#endif
}
void umonitor(void *a) {
#ifdef SUPPORTS_WAITPKG
_umonitor(a);
#endif
}
uint64_t rdtsc() {
return __rdtsc();
}
} // namespace CpuIntrinsics
} // namespace NEO
|