|  | ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py | 
|  | ; NOTE: clwb is available in Skylake Server, not available in the newer | 
|  | ; NOTE: Cannon Lake arch, but available again in the newer Ice Lake arch. | 
|  | ; RUN: llc < %s -mtriple=i686-apple-darwin -mattr=clwb | FileCheck %s | 
|  | ; RUN: llc < %s -mtriple=i686-apple-darwin -mcpu=skx | FileCheck %s | 
|  | ; RUN: not llc < %s -mtriple=i686-apple-darwin -mcpu=cannonlake 2>&1 | FileCheck %s --check-prefix=CNL | 
|  | ; RUN: llc < %s -mtriple=i686-apple-darwin -mcpu=icelake-client | FileCheck %s | 
|  | ; RUN: llc < %s -mtriple=i686-apple-darwin -mcpu=icelake-server | FileCheck %s | 
|  |  | 
|  | ; CNL: LLVM ERROR: Cannot select: intrinsic %llvm.x86.clwb | 
|  |  | 
|  | define void @clwb(i8* %p) nounwind { | 
|  | ; CHECK-LABEL: clwb: | 
|  | ; CHECK:       ## %bb.0: | 
|  | ; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %eax | 
|  | ; CHECK-NEXT:    clwb (%eax) | 
|  | ; CHECK-NEXT:    retl | 
|  | tail call void @llvm.x86.clwb(i8* %p) | 
|  | ret void | 
|  | } | 
|  | declare void @llvm.x86.clwb(i8*) nounwind |