|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
1 | 2 | ; RUN: llc < %s -mcpu=corei7 -mtriple=i686-- -verify-machineinstrs | FileCheck %s
|
2 | 3 |
|
3 | 4 | ; 64-bit load/store on x86-32
|
4 | 5 | ; FIXME: The generated code can be substantially improved.
|
5 | 6 |
|
6 | 7 | define void @test1(i64* %ptr, i64 %val1) {
|
7 |
| -; CHECK-LABEL: test1 |
8 |
| -; CHECK: lock cmpxchg8b |
9 |
| -; CHECK-NEXT: jne |
| 8 | +; CHECK-LABEL: test1: |
| 9 | +; CHECK: # %bb.0: |
| 10 | +; CHECK-NEXT: pushl %ebx |
| 11 | +; CHECK-NEXT: .cfi_def_cfa_offset 8 |
| 12 | +; CHECK-NEXT: pushl %esi |
| 13 | +; CHECK-NEXT: .cfi_def_cfa_offset 12 |
| 14 | +; CHECK-NEXT: .cfi_offset %esi, -12 |
| 15 | +; CHECK-NEXT: .cfi_offset %ebx, -8 |
| 16 | +; CHECK-NEXT: movl {{[0-9]+}}(%esp), %ecx |
| 17 | +; CHECK-NEXT: movl {{[0-9]+}}(%esp), %ebx |
| 18 | +; CHECK-NEXT: movl {{[0-9]+}}(%esp), %esi |
| 19 | +; CHECK-NEXT: movl (%esi), %eax |
| 20 | +; CHECK-NEXT: movl 4(%esi), %edx |
| 21 | +; CHECK-NEXT: .p2align 4, 0x90 |
| 22 | +; CHECK-NEXT: .LBB0_1: # %atomicrmw.start |
| 23 | +; CHECK-NEXT: # =>This Inner Loop Header: Depth=1 |
| 24 | +; CHECK-NEXT: lock cmpxchg8b (%esi) |
| 25 | +; CHECK-NEXT: jne .LBB0_1 |
| 26 | +; CHECK-NEXT: # %bb.2: # %atomicrmw.end |
| 27 | +; CHECK-NEXT: popl %esi |
| 28 | +; CHECK-NEXT: .cfi_def_cfa_offset 8 |
| 29 | +; CHECK-NEXT: popl %ebx |
| 30 | +; CHECK-NEXT: .cfi_def_cfa_offset 4 |
| 31 | +; CHECK-NEXT: retl |
10 | 32 | store atomic i64 %val1, i64* %ptr seq_cst, align 8
|
11 | 33 | ret void
|
12 | 34 | }
|
13 | 35 |
|
14 | 36 | define i64 @test2(i64* %ptr) {
|
15 |
| -; CHECK-LABEL: test2 |
16 |
| -; CHECK: lock cmpxchg8b |
| 37 | +; CHECK-LABEL: test2: |
| 38 | +; CHECK: # %bb.0: |
| 39 | +; CHECK-NEXT: pushl %ebx |
| 40 | +; CHECK-NEXT: .cfi_def_cfa_offset 8 |
| 41 | +; CHECK-NEXT: pushl %esi |
| 42 | +; CHECK-NEXT: .cfi_def_cfa_offset 12 |
| 43 | +; CHECK-NEXT: .cfi_offset %esi, -12 |
| 44 | +; CHECK-NEXT: .cfi_offset %ebx, -8 |
| 45 | +; CHECK-NEXT: movl {{[0-9]+}}(%esp), %esi |
| 46 | +; CHECK-NEXT: xorl %eax, %eax |
| 47 | +; CHECK-NEXT: xorl %edx, %edx |
| 48 | +; CHECK-NEXT: xorl %ecx, %ecx |
| 49 | +; CHECK-NEXT: xorl %ebx, %ebx |
| 50 | +; CHECK-NEXT: lock cmpxchg8b (%esi) |
| 51 | +; CHECK-NEXT: popl %esi |
| 52 | +; CHECK-NEXT: .cfi_def_cfa_offset 8 |
| 53 | +; CHECK-NEXT: popl %ebx |
| 54 | +; CHECK-NEXT: .cfi_def_cfa_offset 4 |
| 55 | +; CHECK-NEXT: retl |
17 | 56 | %val = load atomic i64, i64* %ptr seq_cst, align 8
|
18 | 57 | ret i64 %val
|
19 | 58 | }
|
0 commit comments