From 89415800361b94cb9e8b231f59ea55a84313fcd8 Mon Sep 17 00:00:00 2001 From: JF Bastien Date: Thu, 10 Dec 2015 20:24:34 +0000 Subject: [PATCH] EarlyCSE: add tests Summary: As a follow-up to rL255054 I wasn't able to convince myself that the code did what I thought, so I wrote more tests. Reviewers: reames Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D15371 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@255295 91177308-0d34-0410-b5e6-96231b3b80d8 --- test/Transforms/EarlyCSE/atomics.ll | 78 +++++++++++++++++++++++++---- 1 file changed, 68 insertions(+), 10 deletions(-) diff --git a/test/Transforms/EarlyCSE/atomics.ll b/test/Transforms/EarlyCSE/atomics.ll index f08220fd42d..ea85a86fa91 100644 --- a/test/Transforms/EarlyCSE/atomics.ll +++ b/test/Transforms/EarlyCSE/atomics.ll @@ -29,12 +29,12 @@ define i32 @test14(i1 %B, i32* %P1) { %b = load atomic i32, i32* %P1 unordered, align 4 %res = sub i32 %a, %b ret i32 %res - ; CHECK: load atomic i32, i32* %P1 - ; CHECK: ret i32 0 + ; CHECK: load atomic i32, i32* %P1 seq_cst + ; CHECK-NEXT: ret i32 0 } ; CHECK-LABEL: @test15( -; implementation restiction: can't forward to stonger +; implementation restriction: can't forward to stonger ; than unordered define i32 @test15(i1 %B, i32* %P1, i32* %P2) { %a = load atomic i32, i32* %P1 seq_cst, align 4 @@ -60,8 +60,8 @@ define i32 @test16(i1 %B, i32* %P1, i32* %P2) { } ; Can't DSE across a full fence -define void @test17(i1 %B, i32* %P1, i32* %P2) { -; CHECK-LABEL: @test17 +define void @fence_seq_cst_store(i1 %B, i32* %P1, i32* %P2) { +; CHECK-LABEL: @fence_seq_cst_store ; CHECK: store ; CHECK: store atomic ; CHECK: store @@ -71,20 +71,68 @@ define void @test17(i1 %B, i32* %P1, i32* %P2) { ret void } +; Can't DSE across a full fence +define void @fence_seq_cst(i1 %B, i32* %P1, i32* %P2) { +; CHECK-LABEL: @fence_seq_cst +; CHECK: store +; CHECK: fence seq_cst +; CHECK: store + store i32 0, i32* %P1, align 4 + fence seq_cst + store i32 0, i32* %P1, align 4 + ret void +} + +; Can't DSE across a full fence +define void @fence_asm_sideeffect(i1 %B, i32* %P1, i32* %P2) { +; CHECK-LABEL: @fence_asm_sideeffect +; CHECK: store +; CHECK: call void asm sideeffect +; CHECK: store + store i32 0, i32* %P1, align 4 + call void asm sideeffect "", ""() + store i32 0, i32* %P1, align 4 + ret void +} + +; Can't DSE across a full fence +define void @fence_asm_memory(i1 %B, i32* %P1, i32* %P2) { +; CHECK-LABEL: @fence_asm_memory +; CHECK: store +; CHECK: call void asm +; CHECK: store + store i32 0, i32* %P1, align 4 + call void asm "", "~{memory}"() + store i32 0, i32* %P1, align 4 + ret void +} + ; Can't remove a volatile load -define i32 @test18(i1 %B, i32* %P1, i32* %P2) { +define i32 @volatile_load(i1 %B, i32* %P1, i32* %P2) { %a = load i32, i32* %P1, align 4 %b = load volatile i32, i32* %P1, align 4 %res = sub i32 %a, %b ret i32 %res - ; CHECK-LABEL: @test18 + ; CHECK-LABEL: @volatile_load ; CHECK: load i32, i32* %P1 ; CHECK: load volatile i32, i32* %P1 } +; Can't remove redundant volatile loads +define i32 @redundant_volatile_load(i1 %B, i32* %P1, i32* %P2) { + %a = load volatile i32, i32* %P1, align 4 + %b = load volatile i32, i32* %P1, align 4 + %res = sub i32 %a, %b + ret i32 %res + ; CHECK-LABEL: @redundant_volatile_load + ; CHECK: load volatile i32, i32* %P1 + ; CHECK: load volatile i32, i32* %P1 + ; CHECK: sub +} + ; Can't DSE a volatile store -define void @test19(i1 %B, i32* %P1, i32* %P2) { -; CHECK-LABEL: @test19 +define void @volatile_store(i1 %B, i32* %P1, i32* %P2) { +; CHECK-LABEL: @volatile_store ; CHECK: store volatile ; CHECK: store store volatile i32 0, i32* %P1, align 4 @@ -92,7 +140,17 @@ define void @test19(i1 %B, i32* %P1, i32* %P2) { ret void } -; Can value forward from volailes +; Can't DSE a redundant volatile store +define void @redundant_volatile_store(i1 %B, i32* %P1, i32* %P2) { +; CHECK-LABEL: @redundant_volatile_store +; CHECK: store volatile +; CHECK: store volatile + store volatile i32 0, i32* %P1, align 4 + store volatile i32 0, i32* %P1, align 4 + ret void +} + +; Can value forward from volatiles define i32 @test20(i1 %B, i32* %P1, i32* %P2) { %a = load volatile i32, i32* %P1, align 4 %b = load i32, i32* %P1, align 4 -- 2.34.1