1*7330f729Sjoerg /*===------------ ptwriteintrin.h - PTWRITE intrinsic --------------------=== 2*7330f729Sjoerg * 3*7330f729Sjoerg * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4*7330f729Sjoerg * See https://llvm.org/LICENSE.txt for license information. 5*7330f729Sjoerg * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6*7330f729Sjoerg * 7*7330f729Sjoerg *===-----------------------------------------------------------------------=== 8*7330f729Sjoerg */ 9*7330f729Sjoerg 10*7330f729Sjoerg #if !defined __X86INTRIN_H && !defined __IMMINTRIN_H 11*7330f729Sjoerg #error "Never use <ptwriteintrin.h> directly; include <x86intrin.h> instead." 12*7330f729Sjoerg #endif 13*7330f729Sjoerg 14*7330f729Sjoerg #ifndef __PTWRITEINTRIN_H 15*7330f729Sjoerg #define __PTWRITEINTRIN_H 16*7330f729Sjoerg 17*7330f729Sjoerg /* Define the default attributes for the functions in this file. */ 18*7330f729Sjoerg #define __DEFAULT_FN_ATTRS \ 19*7330f729Sjoerg __attribute__((__always_inline__, __nodebug__, __target__("ptwrite"))) 20*7330f729Sjoerg 21*7330f729Sjoerg static __inline__ void __DEFAULT_FN_ATTRS _ptwrite32(unsigned int __value)22*7330f729Sjoerg_ptwrite32(unsigned int __value) { 23*7330f729Sjoerg __builtin_ia32_ptwrite32(__value); 24*7330f729Sjoerg } 25*7330f729Sjoerg 26*7330f729Sjoerg #ifdef __x86_64__ 27*7330f729Sjoerg 28*7330f729Sjoerg static __inline__ void __DEFAULT_FN_ATTRS _ptwrite64(unsigned long long __value)29*7330f729Sjoerg_ptwrite64(unsigned long long __value) { 30*7330f729Sjoerg __builtin_ia32_ptwrite64(__value); 31*7330f729Sjoerg } 32*7330f729Sjoerg 33*7330f729Sjoerg #endif /* __x86_64__ */ 34*7330f729Sjoerg 35*7330f729Sjoerg #undef __DEFAULT_FN_ATTRS 36*7330f729Sjoerg 37*7330f729Sjoerg #endif /* __PTWRITEINTRIN_H */ 38