File: ppc-disable-non-volatile-cr.ll

package info (click to toggle)
llvm-toolchain-14 1%3A14.0.6-12
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 1,496,180 kB
  • sloc: cpp: 5,593,972; ansic: 986,872; asm: 585,869; python: 184,223; objc: 72,530; lisp: 31,119; f90: 27,793; javascript: 9,780; pascal: 9,762; sh: 9,482; perl: 7,468; ml: 5,432; awk: 3,523; makefile: 2,538; xml: 953; cs: 573; fortran: 567
file content (47 lines) | stat: -rw-r--r-- 1,880 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
; Note: Test option to disable use of non-volatile CR to avoid CR spilling in prologue.
; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu -ppc-disable-non-volatile-cr\
; RUN:     -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr < %s | FileCheck --check-prefix=CHECK-DISABLE %s
; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu\
; RUN:     -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr < %s | FileCheck --check-prefix=CHECK-ENABLE %s

; Function Attrs: nounwind
define dso_local signext i32 @DisableNonVolatileCR(i32 signext %a, i32 signext %b) {
; CHECK-DISABLE-LABEL: DisableNonVolatileCR:
; CHECK-DISABLE:       # %bb.0: # %entry
; CHECK-DISABLE-NOT:    mfocrf {{r[0-9]+}}
; CHECK-DISABLE-NOT:    stw {{r[0-9]+}}
; CHECK-DISABLE:        stdu r1
; CHECK-DISABLE-DAG:    mfocrf [[REG2:r[0-9]+]]
; CHECK-DISABLE-DAG:    stw [[REG2]]
; CHECK-DISABLE:        # %bb.1: # %if.then
;
; CHECK-ENABLE-LABEL: DisableNonVolatileCR:
; CHECK-ENABLE:       # %bb.0: # %entry
; CHECK-ENABLE-DAG:    mfocrf [[REG1:r[0-9]+]]
; CHECK-ENABLE-DAG:    stw [[REG1]]
; CHECK-ENABLE:        stdu r1
; CHECK-ENABLE-NOT:    mfocrf {{r[0-9]+}}
; CHECK-ENABLE-NOT:    stw {{r[0-9]+}}
; CHECK-ENABLE:        # %bb.1: # %if.then

entry:
  %cmp = icmp slt i32 %a, %b
  br i1 %cmp, label %if.then, label %if.else

if.then:                                          ; preds = %entry
  tail call void bitcast (void (...)* @fa to void ()*)()
  br label %if.end

if.else:                                          ; preds = %entry
  tail call void bitcast (void (...)* @fb to void ()*)()
  br label %if.end

if.end:                                           ; preds = %if.else, %if.then
  %conv = zext i1 %cmp to i32
  %call = tail call signext i32 @callee(i32 signext %conv)
  ret i32 %call
}

declare void @fa(...)
declare void @fb(...)
declare signext i32 @callee(i32 signext)