Home | History | Annotate | Download | only in X86
      1 ; RUN: llc -o - %s | FileCheck %s
      2 ; This tests for the problem originally reported in http://llvm.org/PR25951
      3 target triple = "i686-unknown-linux-gnu"
      4 
      5 @b = common global i8 0, align 1
      6 @c = common global i32 0, align 4
      7 @a = common global i8 0, align 1
      8 @d = common global i8 0, align 1
      9 @.str = private unnamed_addr constant [4 x i8] c"%d\0A\00", align 1
     10 
     11 ; CHECK-LABEL: func:
     12 ; This tests whether eax is properly saved/restored around the lahf/sahf
     13 ; instruction sequences.
     14 define i32 @func() {
     15 entry:
     16   %bval = load i8, i8* @b
     17   %inc = add i8 %bval, 1
     18   store i8 %inc, i8* @b
     19   %cval = load i32, i32* @c
     20   %inc1 = add nsw i32 %cval, 1
     21   store i32 %inc1, i32* @c
     22   %aval = load i8, i8* @a
     23   %inc2 = add i8 %aval, 1
     24   store i8 %inc2, i8* @a
     25 ; Copy flags produced by the incb of %inc1 to a register, need to save+restore
     26 ; eax around it. The flags will be reused by %tobool.
     27 ; CHECK: pushl %eax
     28 ; CHECK: seto %al
     29 ; CHECK: lahf
     30 ; CHECK: movl %eax, [[REG:%[a-z]+]]
     31 ; CHECK: popl %eax
     32   %cmp = icmp eq i8 %aval, %bval
     33   %conv5 = zext i1 %cmp to i8
     34   store i8 %conv5, i8* @d
     35   %tobool = icmp eq i32 %inc1, 0
     36 ; We restore flags with an 'addb, sahf' sequence, need to save+restore eax
     37 ; around it.
     38 ; CHECK: pushl %eax
     39 ; CHECK: movl [[REG]], %eax
     40 ; CHECK: addb $127, %al
     41 ; CHECK: sahf
     42 ; CHECK: popl %eax
     43   br i1 %tobool, label %if.end, label %if.then
     44 
     45 if.then:
     46   %conv6 = sext i8 %inc to i32
     47   %call = tail call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i32 %conv6)
     48   br label %if.end
     49 
     50 if.end:
     51   ret i32 0
     52 }
     53 
     54 declare i32 @printf(i8* nocapture readonly, ...)
     55