xref: /llvm-project/llvm/test/CodeGen/X86/lower-ptrmask.ll (revision eb86de63d901941fba0a54eb41551456447cd789)
1; RUN: llc -mtriple=x86_64-apple-macosx -stop-after=finalize-isel %s -o - | FileCheck %s
2
3declare ptr @llvm.ptrmask.p0.i64(ptr , i64)
4
5; CHECK-LABEL: name: test1
6; CHECK:         %0:gr64 = COPY $rdi
7; CHECK-NEXT:    %1:gr64 = MOV64ri 72057594037927928
8; CHECK-NEXT:    %2:gr64 = AND64rr %0, killed %1, implicit-def dead $eflags
9; CHECK-NEXT:    $rax = COPY %2
10; CHECK-NEXT:    RET 0, $rax
11
12define ptr @test1(ptr %src) {
13  %ptr = call ptr @llvm.ptrmask.p0.i64(ptr %src, i64 72057594037927928)
14  ret ptr %ptr
15}
16
17declare <2 x ptr> @llvm.ptrmask.v2p0.v2i64(<2 x ptr>, <2 x i64>)
18
19; CHECK-LABEL: name: test3
20; CHECK: %0:vr128 = COPY $xmm0
21; CHECK-NEXT: %1:vr128 = PANDrm %0, $rip, 1, $noreg, %const.0, $noreg :: (load (s128) from constant-pool)
22; CHECK-NEXT: $xmm0 = COPY %1
23; CHECK-NEXT: RET 0, $xmm0
24
25define <2 x ptr> @test3(<2 x ptr> %src) {
26  %ptr = call <2 x ptr> @llvm.ptrmask.v2p0.v2i64(<2 x ptr> %src, <2 x i64> <i64 10000, i64 10000>)
27  ret <2 x ptr> %ptr
28}
29