blob: eab3d357692d6b0b7ce32b3fe70f31d8903a3f41 [file] [log] [blame]
Daniel Dunbard7f7d082010-06-29 22:00:45 +00001// RUN: %clang_cc1 -triple x86_64 -emit-llvm -o - %s | FileCheck %s
2
3// Check that we don't generate unnecessary reloads.
4//
5// CHECK: define void @f0()
6// CHECK: [[x_0:%.*]] = alloca i32, align 4
7// CHECK-NEXT: [[y_0:%.*]] = alloca i32, align 4
8// CHECK-NEXT: store i32 1, i32* [[x_0]]
9// CHECK-NEXT: store i32 1, i32* [[x_0]]
10// CHECK-NEXT: store i32 1, i32* [[y_0]]
11// CHECK: }
12void f0() {
13 int x, y;
14 x = 1;
15 y = (x = 1);
16}
17
18// Check that we do generate reloads for volatile access.
19//
20// CHECK: define void @f1()
21// CHECK: [[x_1:%.*]] = alloca i32, align 4
22// CHECK-NEXT: [[y_1:%.*]] = alloca i32, align 4
23// CHECK-NEXT: volatile store i32 1, i32* [[x_1]]
24// CHECK-NEXT: volatile store i32 1, i32* [[x_1]]
25// CHECK-NEXT: [[tmp_1:%.*]] = volatile load i32* [[x_1]]
26// CHECK-NEXT: volatile store i32 [[tmp_1]], i32* [[y_1]]
27// CHECK: }
28void f1() {
29 volatile int x, y;
30 x = 1;
31 y = (x = 1);
32}