forked from OSchip/llvm-project
				
			[CGP, x86] update test checks; NFC
This was auto-generated using an older version of the script, and that version does not work with phis, so if we enable expansion it will go bad. llvm-svn: 307267
This commit is contained in:
		
							parent
							
								
									6e50d93afc
								
							
						
					
					
						commit
						0c37b19331
					
				| 
						 | 
					@ -1,3 +1,4 @@
 | 
				
			||||||
 | 
					; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
 | 
				
			||||||
; RUN: opt -S -codegenprepare -mtriple=i686-unknown-unknown   -data-layout=e-m:o-p:32:32-f64:32:64-f80:128-n8:16:32-S128 < %s | FileCheck %s --check-prefix=ALL --check-prefix=X32
 | 
					; RUN: opt -S -codegenprepare -mtriple=i686-unknown-unknown   -data-layout=e-m:o-p:32:32-f64:32:64-f80:128-n8:16:32-S128 < %s | FileCheck %s --check-prefix=ALL --check-prefix=X32
 | 
				
			||||||
; RUN: opt -S -codegenprepare -mtriple=x86_64-unknown-unknown -data-layout=e-m:o-i64:64-f80:128-n8:16:32:64-S128         < %s | FileCheck %s --check-prefix=ALL --check-prefix=X64
 | 
					; RUN: opt -S -codegenprepare -mtriple=x86_64-unknown-unknown -data-layout=e-m:o-i64:64-f80:128-n8:16:32:64-S128         < %s | FileCheck %s --check-prefix=ALL --check-prefix=X64
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -5,8 +6,8 @@ declare i32 @memcmp(i8* nocapture, i8* nocapture, i64)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp2(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp2(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp2(
 | 
					; ALL-LABEL: @cmp2(
 | 
				
			||||||
; ALL-NEXT:    [[TMP1:%.*]] = bitcast i8* %x to i16*
 | 
					; ALL-NEXT:    [[TMP1:%.*]] = bitcast i8* [[X:%.*]] to i16*
 | 
				
			||||||
; ALL-NEXT:    [[TMP2:%.*]] = bitcast i8* %y to i16*
 | 
					; ALL-NEXT:    [[TMP2:%.*]] = bitcast i8* [[Y:%.*]] to i16*
 | 
				
			||||||
; ALL-NEXT:    [[TMP3:%.*]] = load i16, i16* [[TMP1]]
 | 
					; ALL-NEXT:    [[TMP3:%.*]] = load i16, i16* [[TMP1]]
 | 
				
			||||||
; ALL-NEXT:    [[TMP4:%.*]] = load i16, i16* [[TMP2]]
 | 
					; ALL-NEXT:    [[TMP4:%.*]] = load i16, i16* [[TMP2]]
 | 
				
			||||||
; ALL-NEXT:    [[TMP5:%.*]] = call i16 @llvm.bswap.i16(i16 [[TMP3]])
 | 
					; ALL-NEXT:    [[TMP5:%.*]] = call i16 @llvm.bswap.i16(i16 [[TMP3]])
 | 
				
			||||||
| 
						 | 
					@ -23,7 +24,7 @@ define i32 @cmp2(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp3(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp3(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp3(
 | 
					; ALL-LABEL: @cmp3(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 3)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 3)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 3)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 3)
 | 
				
			||||||
| 
						 | 
					@ -32,8 +33,8 @@ define i32 @cmp3(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp4(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp4(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp4(
 | 
					; ALL-LABEL: @cmp4(
 | 
				
			||||||
; ALL-NEXT:    [[TMP1:%.*]] = bitcast i8* %x to i32*
 | 
					; ALL-NEXT:    [[TMP1:%.*]] = bitcast i8* [[X:%.*]] to i32*
 | 
				
			||||||
; ALL-NEXT:    [[TMP2:%.*]] = bitcast i8* %y to i32*
 | 
					; ALL-NEXT:    [[TMP2:%.*]] = bitcast i8* [[Y:%.*]] to i32*
 | 
				
			||||||
; ALL-NEXT:    [[TMP3:%.*]] = load i32, i32* [[TMP1]]
 | 
					; ALL-NEXT:    [[TMP3:%.*]] = load i32, i32* [[TMP1]]
 | 
				
			||||||
; ALL-NEXT:    [[TMP4:%.*]] = load i32, i32* [[TMP2]]
 | 
					; ALL-NEXT:    [[TMP4:%.*]] = load i32, i32* [[TMP2]]
 | 
				
			||||||
; ALL-NEXT:    [[TMP5:%.*]] = call i32 @llvm.bswap.i32(i32 [[TMP3]])
 | 
					; ALL-NEXT:    [[TMP5:%.*]] = call i32 @llvm.bswap.i32(i32 [[TMP3]])
 | 
				
			||||||
| 
						 | 
					@ -50,7 +51,7 @@ define i32 @cmp4(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp5(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp5(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp5(
 | 
					; ALL-LABEL: @cmp5(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 5)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 5)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 5)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 5)
 | 
				
			||||||
| 
						 | 
					@ -59,7 +60,7 @@ define i32 @cmp5(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp6(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp6(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp6(
 | 
					; ALL-LABEL: @cmp6(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 6)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 6)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 6)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 6)
 | 
				
			||||||
| 
						 | 
					@ -68,7 +69,7 @@ define i32 @cmp6(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp7(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp7(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp7(
 | 
					; ALL-LABEL: @cmp7(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 7)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 7)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 7)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 7)
 | 
				
			||||||
| 
						 | 
					@ -77,12 +78,12 @@ define i32 @cmp7(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp8(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp8(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; X32-LABEL: @cmp8(
 | 
					; X32-LABEL: @cmp8(
 | 
				
			||||||
; X32-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 8)
 | 
					; X32-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 8)
 | 
				
			||||||
; X32-NEXT:    ret i32 [[CALL]]
 | 
					; X32-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
; X64-LABEL: @cmp8(
 | 
					; X64-LABEL: @cmp8(
 | 
				
			||||||
; X64-NEXT:    [[TMP1:%.*]] = bitcast i8* %x to i64*
 | 
					; X64-NEXT:    [[TMP1:%.*]] = bitcast i8* [[X:%.*]] to i64*
 | 
				
			||||||
; X64-NEXT:    [[TMP2:%.*]] = bitcast i8* %y to i64*
 | 
					; X64-NEXT:    [[TMP2:%.*]] = bitcast i8* [[Y:%.*]] to i64*
 | 
				
			||||||
; X64-NEXT:    [[TMP3:%.*]] = load i64, i64* [[TMP1]]
 | 
					; X64-NEXT:    [[TMP3:%.*]] = load i64, i64* [[TMP1]]
 | 
				
			||||||
; X64-NEXT:    [[TMP4:%.*]] = load i64, i64* [[TMP2]]
 | 
					; X64-NEXT:    [[TMP4:%.*]] = load i64, i64* [[TMP2]]
 | 
				
			||||||
; X64-NEXT:    [[TMP5:%.*]] = call i64 @llvm.bswap.i64(i64 [[TMP3]])
 | 
					; X64-NEXT:    [[TMP5:%.*]] = call i64 @llvm.bswap.i64(i64 [[TMP3]])
 | 
				
			||||||
| 
						 | 
					@ -99,7 +100,7 @@ define i32 @cmp8(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp9(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp9(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp9(
 | 
					; ALL-LABEL: @cmp9(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 9)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 9)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 9)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 9)
 | 
				
			||||||
| 
						 | 
					@ -108,7 +109,7 @@ define i32 @cmp9(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp10(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp10(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp10(
 | 
					; ALL-LABEL: @cmp10(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 10)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 10)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 10)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 10)
 | 
				
			||||||
| 
						 | 
					@ -117,7 +118,7 @@ define i32 @cmp10(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp11(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp11(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp11(
 | 
					; ALL-LABEL: @cmp11(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 11)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 11)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 11)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 11)
 | 
				
			||||||
| 
						 | 
					@ -126,7 +127,7 @@ define i32 @cmp11(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp12(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp12(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp12(
 | 
					; ALL-LABEL: @cmp12(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 12)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 12)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 12)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 12)
 | 
				
			||||||
| 
						 | 
					@ -135,7 +136,7 @@ define i32 @cmp12(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp13(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp13(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp13(
 | 
					; ALL-LABEL: @cmp13(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 13)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 13)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 13)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 13)
 | 
				
			||||||
| 
						 | 
					@ -144,7 +145,7 @@ define i32 @cmp13(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp14(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp14(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp14(
 | 
					; ALL-LABEL: @cmp14(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 14)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 14)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 14)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 14)
 | 
				
			||||||
| 
						 | 
					@ -153,7 +154,7 @@ define i32 @cmp14(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp15(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp15(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp15(
 | 
					; ALL-LABEL: @cmp15(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 15)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 15)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 15)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 15)
 | 
				
			||||||
| 
						 | 
					@ -162,7 +163,7 @@ define i32 @cmp15(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp16(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp16(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp16(
 | 
					; ALL-LABEL: @cmp16(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 16)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 16)
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CALL]]
 | 
					; ALL-NEXT:    ret i32 [[CALL]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 16)
 | 
					  %call = tail call i32 @memcmp(i8* %x, i8* %y, i64 16)
 | 
				
			||||||
| 
						 | 
					@ -171,8 +172,8 @@ define i32 @cmp16(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq2(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq2(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq2(
 | 
					; ALL-LABEL: @cmp_eq2(
 | 
				
			||||||
; ALL-NEXT:    [[TMP1:%.*]] = bitcast i8* %x to i16*
 | 
					; ALL-NEXT:    [[TMP1:%.*]] = bitcast i8* [[X:%.*]] to i16*
 | 
				
			||||||
; ALL-NEXT:    [[TMP2:%.*]] = bitcast i8* %y to i16*
 | 
					; ALL-NEXT:    [[TMP2:%.*]] = bitcast i8* [[Y:%.*]] to i16*
 | 
				
			||||||
; ALL-NEXT:    [[TMP3:%.*]] = load i16, i16* [[TMP1]]
 | 
					; ALL-NEXT:    [[TMP3:%.*]] = load i16, i16* [[TMP1]]
 | 
				
			||||||
; ALL-NEXT:    [[TMP4:%.*]] = load i16, i16* [[TMP2]]
 | 
					; ALL-NEXT:    [[TMP4:%.*]] = load i16, i16* [[TMP2]]
 | 
				
			||||||
; ALL-NEXT:    [[TMP5:%.*]] = icmp ne i16 [[TMP3]], [[TMP4]]
 | 
					; ALL-NEXT:    [[TMP5:%.*]] = icmp ne i16 [[TMP3]], [[TMP4]]
 | 
				
			||||||
| 
						 | 
					@ -189,7 +190,7 @@ define i32 @cmp_eq2(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq3(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq3(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq3(
 | 
					; ALL-LABEL: @cmp_eq3(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 3)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 3)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -202,8 +203,8 @@ define i32 @cmp_eq3(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq4(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq4(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq4(
 | 
					; ALL-LABEL: @cmp_eq4(
 | 
				
			||||||
; ALL-NEXT:    [[TMP1:%.*]] = bitcast i8* %x to i32*
 | 
					; ALL-NEXT:    [[TMP1:%.*]] = bitcast i8* [[X:%.*]] to i32*
 | 
				
			||||||
; ALL-NEXT:    [[TMP2:%.*]] = bitcast i8* %y to i32*
 | 
					; ALL-NEXT:    [[TMP2:%.*]] = bitcast i8* [[Y:%.*]] to i32*
 | 
				
			||||||
; ALL-NEXT:    [[TMP3:%.*]] = load i32, i32* [[TMP1]]
 | 
					; ALL-NEXT:    [[TMP3:%.*]] = load i32, i32* [[TMP1]]
 | 
				
			||||||
; ALL-NEXT:    [[TMP4:%.*]] = load i32, i32* [[TMP2]]
 | 
					; ALL-NEXT:    [[TMP4:%.*]] = load i32, i32* [[TMP2]]
 | 
				
			||||||
; ALL-NEXT:    [[TMP5:%.*]] = icmp ne i32 [[TMP3]], [[TMP4]]
 | 
					; ALL-NEXT:    [[TMP5:%.*]] = icmp ne i32 [[TMP3]], [[TMP4]]
 | 
				
			||||||
| 
						 | 
					@ -220,7 +221,7 @@ define i32 @cmp_eq4(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq5(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq5(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq5(
 | 
					; ALL-LABEL: @cmp_eq5(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 5)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 5)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -233,7 +234,7 @@ define i32 @cmp_eq5(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq6(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq6(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq6(
 | 
					; ALL-LABEL: @cmp_eq6(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 6)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 6)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -246,7 +247,7 @@ define i32 @cmp_eq6(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq7(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq7(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq7(
 | 
					; ALL-LABEL: @cmp_eq7(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 7)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 7)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -259,14 +260,14 @@ define i32 @cmp_eq7(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq8(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq8(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; X32-LABEL: @cmp_eq8(
 | 
					; X32-LABEL: @cmp_eq8(
 | 
				
			||||||
; X32-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 8)
 | 
					; X32-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 8)
 | 
				
			||||||
; X32-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; X32-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; X32-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; X32-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; X32-NEXT:    ret i32 [[CONV]]
 | 
					; X32-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
;
 | 
					;
 | 
				
			||||||
; X64-LABEL: @cmp_eq8(
 | 
					; X64-LABEL: @cmp_eq8(
 | 
				
			||||||
; X64-NEXT:    [[TMP1:%.*]] = bitcast i8* %x to i64*
 | 
					; X64-NEXT:    [[TMP1:%.*]] = bitcast i8* [[X:%.*]] to i64*
 | 
				
			||||||
; X64-NEXT:    [[TMP2:%.*]] = bitcast i8* %y to i64*
 | 
					; X64-NEXT:    [[TMP2:%.*]] = bitcast i8* [[Y:%.*]] to i64*
 | 
				
			||||||
; X64-NEXT:    [[TMP3:%.*]] = load i64, i64* [[TMP1]]
 | 
					; X64-NEXT:    [[TMP3:%.*]] = load i64, i64* [[TMP1]]
 | 
				
			||||||
; X64-NEXT:    [[TMP4:%.*]] = load i64, i64* [[TMP2]]
 | 
					; X64-NEXT:    [[TMP4:%.*]] = load i64, i64* [[TMP2]]
 | 
				
			||||||
; X64-NEXT:    [[TMP5:%.*]] = icmp ne i64 [[TMP3]], [[TMP4]]
 | 
					; X64-NEXT:    [[TMP5:%.*]] = icmp ne i64 [[TMP3]], [[TMP4]]
 | 
				
			||||||
| 
						 | 
					@ -283,7 +284,7 @@ define i32 @cmp_eq8(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq9(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq9(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq9(
 | 
					; ALL-LABEL: @cmp_eq9(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 9)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 9)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -296,7 +297,7 @@ define i32 @cmp_eq9(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq10(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq10(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq10(
 | 
					; ALL-LABEL: @cmp_eq10(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 10)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 10)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -309,7 +310,7 @@ define i32 @cmp_eq10(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq11(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq11(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq11(
 | 
					; ALL-LABEL: @cmp_eq11(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 11)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 11)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -322,7 +323,7 @@ define i32 @cmp_eq11(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq12(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq12(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq12(
 | 
					; ALL-LABEL: @cmp_eq12(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 12)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 12)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -335,7 +336,7 @@ define i32 @cmp_eq12(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq13(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq13(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq13(
 | 
					; ALL-LABEL: @cmp_eq13(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 13)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 13)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -348,7 +349,7 @@ define i32 @cmp_eq13(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq14(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq14(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq14(
 | 
					; ALL-LABEL: @cmp_eq14(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 14)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 14)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -361,7 +362,7 @@ define i32 @cmp_eq14(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq15(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq15(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq15(
 | 
					; ALL-LABEL: @cmp_eq15(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 15)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 15)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					@ -374,7 +375,7 @@ define i32 @cmp_eq15(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define i32 @cmp_eq16(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
					define i32 @cmp_eq16(i8* nocapture readonly %x, i8* nocapture readonly %y)  {
 | 
				
			||||||
; ALL-LABEL: @cmp_eq16(
 | 
					; ALL-LABEL: @cmp_eq16(
 | 
				
			||||||
; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* %x, i8* %y, i64 16)
 | 
					; ALL-NEXT:    [[CALL:%.*]] = tail call i32 @memcmp(i8* [[X:%.*]], i8* [[Y:%.*]], i64 16)
 | 
				
			||||||
; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
					; ALL-NEXT:    [[CMP:%.*]] = icmp eq i32 [[CALL]], 0
 | 
				
			||||||
; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
					; ALL-NEXT:    [[CONV:%.*]] = zext i1 [[CMP]] to i32
 | 
				
			||||||
; ALL-NEXT:    ret i32 [[CONV]]
 | 
					; ALL-NEXT:    ret i32 [[CONV]]
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue