[AArch64][NFC] NFC for const vector as Instruction operand (#116790)
[llvm-project.git] / llvm / test / Transforms / RewriteStatepointsForGC / base-atomicrmw.ll
blob9d33a5760ce61955c95882fd32cfd4ab826f8286
1 ; RUN: opt < %s -passes=rewrite-statepoints-for-gc -S 2>&1 | FileCheck %s
3 define ptr addrspace(1) @test(ptr %a, ptr addrspace(1) %b) gc "statepoint-example" {
4 ; CHECK-LABEL: @test
5 ; CHECK-NEXT:    [[RES:%.*]] = atomicrmw xchg ptr %a, ptr addrspace(1) %b seq_cst
6 ; CHECK-NEXT:    [[STATEPOINT_TOKEN:%.*]] = call token (i64, i32, ptr, i32, i32, ...) @llvm.experimental.gc.statepoint.p0(i64 2882400000, i32 0, ptr elementtype(void ()) @foo, i32 0, i32 0, i32 0, i32 0) [ "gc-live"(ptr addrspace(1) [[RES]]) ]
7 ; CHECK-NEXT:    [[RES_RELOCATED:%.*]] = call coldcc ptr addrspace(1) @llvm.experimental.gc.relocate.p1(token [[STATEPOINT_TOKEN]], i32 0, i32 0)
8 ; CHECK-NEXT:    ret ptr addrspace(1) [[RES_RELOCATED]]
9   %res = atomicrmw xchg ptr %a, ptr addrspace(1) %b seq_cst
10   call void @foo()
11   ret ptr addrspace(1) %res
14 declare void @foo()