| ; Test floating-point control register intrinsics. | 
 | ; | 
 | ; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s | 
 |  | 
 | declare void @llvm.s390.sfpc(i32) | 
 | declare i32 @llvm.s390.efpc() | 
 |  | 
 | ; SFPC. | 
 | define void @test_sfpc(i32 %fpc) { | 
 | ; CHECK-LABEL: test_sfpc: | 
 | ; CHECK: sfpc %r2 | 
 | ; CHECK: br %r14 | 
 |   call void @llvm.s390.sfpc(i32 %fpc) | 
 |   ret void | 
 | } | 
 |  | 
 | ; EFPC. | 
 | define i32 @test_efpc() { | 
 | ; CHECK-LABEL: test_efpc: | 
 | ; CHECK: efpc %r2 | 
 | ; CHECK: br %r14 | 
 |   %res = call i32 @llvm.s390.efpc() | 
 |   ret i32 %res | 
 | } | 
 |  | 
 | ; LFPC. | 
 | define void @test_lfpc1(ptr %ptr) { | 
 | ; CHECK-LABEL: test_lfpc1: | 
 | ; CHECK: lfpc 0(%r2) | 
 | ; CHECK: br %r14 | 
 |   %fpc = load i32, ptr %ptr | 
 |   call void @llvm.s390.sfpc(i32 %fpc) | 
 |   ret void | 
 | } | 
 |  | 
 | ; LFPC with offset. | 
 | define void @test_lfpc2(ptr %ptr) { | 
 | ; CHECK-LABEL: test_lfpc2: | 
 | ; CHECK: lfpc 4092(%r2) | 
 | ; CHECK: br %r14 | 
 |   %ptr1 = getelementptr i32, ptr %ptr, i32 1023 | 
 |   %fpc = load i32, ptr %ptr1 | 
 |   call void @llvm.s390.sfpc(i32 %fpc) | 
 |   ret void | 
 | } | 
 |  | 
 | ; STFPC. | 
 | define void @test_stfpc1(ptr %ptr) { | 
 | ; CHECK-LABEL: test_stfpc1: | 
 | ; CHECK: stfpc 0(%r2) | 
 | ; CHECK: br %r14 | 
 |   %fpc = call i32 @llvm.s390.efpc() | 
 |   store i32 %fpc, ptr %ptr | 
 |   ret void | 
 | } | 
 |  | 
 | ; STFPC with offset. | 
 | define void @test_stfpc2(ptr %ptr) { | 
 | ; CHECK-LABEL: test_stfpc2: | 
 | ; CHECK: stfpc 4092(%r2) | 
 | ; CHECK: br %r14 | 
 |   %fpc = call i32 @llvm.s390.efpc() | 
 |   %ptr1 = getelementptr i32, ptr %ptr, i32 1023 | 
 |   store i32 %fpc, ptr %ptr1 | 
 |   ret void | 
 | } | 
 |  |