summaryrefslogtreecommitdiff
path: root/test/CodeGen/X86/atomic-pointer.ll
blob: ec3e6c3a8c1901ce7ddf182e3ba1d002871f9249 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
; RUN: llc < %s -mtriple=i686-none-linux -verify-machineinstrs | FileCheck %s

define i32* @test_atomic_ptr_load(i32** %a0) {
; CHECK: test_atomic_ptr_load
; CHECK: movl
; CHECK: movl
; CHECK: ret
0:
  %0 = load atomic i32** %a0 seq_cst, align 4
  ret i32* %0
}

define void @test_atomic_ptr_store(i32* %a0, i32** %a1) {
; CHECK: test_atomic_ptr_store
; CHECK: movl
; CHECK: movl
; CHECK: xchgl
; CHECK: ret
0:
  store atomic i32* %a0, i32** %a1 seq_cst, align 4
  ret void
}