; RUN: llc < %s -mtriple=i686-unknown-linux-gnu -fixup-byte-word-insts=0 | \ ; RUN: FileCheck -check-prefix=CHECK -check-prefix=BWOFF %s ; RUN: llc < %s -mtriple=i686-unknown-linux-gnu -fixup-byte-word-insts=1 | \ ; RUN: FileCheck -check-prefix=CHECK -check-prefix=BWON %s ; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnu -fixup-byte-word-insts=0 | \ ; RUN: FileCheck -check-prefix=CHECK -check-prefix=BWOFF %s ; RUN: llc < %s -mtriple=i686-unknown-linux-gnu -fixup-byte-word-insts=1 | \ ; RUN: FileCheck -check-prefix=CHECK -check-prefix=BWON %s ; RUN: llc < %s -mtriple=x86_64-apple-darwin -fixup-byte-word-insts=0 | \ ; RUN: FileCheck -check-prefix=DARWIN -check-prefix=DARWIN-BWOFF %s ; RUN: llc < %s -mtriple=x86_64-apple-darwin -fixup-byte-word-insts=1 | \ ; RUN: FileCheck -check-prefix=DARWIN -check-prefix=DARWIN-BWON %s @x = common global i32 0, align 4 define zeroext i1 @unsigned_i1() { entry: %0 = load i32, ptr @x %cmp = icmp eq i32 %0, 42 ret i1 %cmp ; Unsigned i1 return values are not extended. ; CHECK-LABEL: unsigned_i1: ; CHECK: cmp ; CHECK-NEXT: sete ; CHECK-NEXT: ret } define zeroext i8 @unsigned_i8() { entry: %0 = load i32, ptr @x %cmp = icmp eq i32 %0, 42 %retval = zext i1 %cmp to i8 ret i8 %retval ; Unsigned i8 return values are not extended. ; CHECK-LABEL: unsigned_i8: ; CHECK: cmp ; CHECK-NEXT: sete ; CHECK-NEXT: ret ; Except on Darwin, for legacy reasons. ; DARWIN-LABEL: unsigned_i8: ; DARWIN: xorl ; DARWIN-NEXT: cmp ; DARWIN-NEXT: sete ; DARWIN-NEXT: ret } define signext i8 @signed_i8() { entry: %0 = load i32, ptr @x %cmp = icmp eq i32 %0, 42 %retval = zext i1 %cmp to i8 ret i8 %retval ; Signed i8 return values are not extended. ; CHECK-LABEL: signed_i8: ; CHECK: cmp ; CHECK-NEXT: sete ; CHECK-NEXT: ret ; Except on Darwin, for legacy reasons. ; DARWIN-LABEL: signed_i8: ; DARWIN: xorl ; DARWIN-NEXT: cmp ; DARWIN-NEXT: sete ; DARWIN-NEXT: ret } @a = common global i16 0 @b = common global i16 0 define zeroext i16 @unsigned_i16() { entry: %0 = load i16, ptr @a %1 = load i16, ptr @b %add = add i16 %1, %0 ret i16 %add ; i16 return values are not extended. ; CHECK-LABEL: unsigned_i16: ; BWOFF: movw ; BWON: movzwl ; CHECK-NEXT: addw ; CHECK-NEXT: ret ; Except on Darwin, for legacy reasons. ; DARWIN-LABEL: unsigned_i16: ; DARWIN-BWOFF: movw ; DARWIN-BWON: movzwl ; DARWIN-NEXT: addw ; DARWIN-NEXT: movzwl ; DARWIN-NEXT: ret } define i32 @use_i1() { entry: %0 = call i1 @unsigned_i1(); %1 = zext i1 %0 to i32 ret i32 %1 ; The high 24 bits of %eax from a function returning i1 are undefined. ; CHECK-LABEL: use_i1: ; CHECK: call ; CHECK-NEXT: movzbl ; CHECK-NEXT: {{pop|add}} ; CHECK-NEXT: .cfi_def_cfa_offset {{4|8}} ; CHECK-NEXT: ret } define i32 @use_i8() { entry: %0 = call i8 @unsigned_i8(); %1 = zext i8 %0 to i32 ret i32 %1 ; The high 24 bits of %eax from a function returning i8 are undefined. ; CHECK-LABEL: use_i8: ; CHECK: call ; CHECK-NEXT: movzbl ; CHECK-NEXT: {{pop|add}} ; CHECK-NEXT: .cfi_def_cfa_offset {{4|8}} ; CHECK-NEXT: ret } define i32 @use_i16() { entry: %0 = call i16 @unsigned_i16(); %1 = zext i16 %0 to i32 ret i32 %1 ; The high 16 bits of %eax from a function returning i16 are undefined. ; CHECK-LABEL: use_i16: ; CHECK: call ; CHECK-NEXT: movzwl ; CHECK-NEXT: {{pop|add}} ; CHECK-NEXT: .cfi_def_cfa_offset {{4|8}} ; CHECK-NEXT: ret }