[llvm] 9511432 - [LowerTypeTests] Regenerate test checks (NFC)

Nikita Popov via llvm-commits llvm-commits at lists.llvm.org
Fri Sep 29 07:15:06 PDT 2023


Author: Nikita Popov
Date: 2023-09-29T16:14:57+02:00
New Revision: 9511432d6d60690c962603c5fd6adb6b78a1207c

URL: https://github.com/llvm/llvm-project/commit/9511432d6d60690c962603c5fd6adb6b78a1207c
DIFF: https://github.com/llvm/llvm-project/commit/9511432d6d60690c962603c5fd6adb6b78a1207c.diff

LOG: [LowerTypeTests] Regenerate test checks (NFC)

Added: 
    

Modified: 
    llvm/test/Transforms/LowerTypeTests/import.ll
    llvm/test/Transforms/LowerTypeTests/simplify.ll

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/LowerTypeTests/import.ll b/llvm/test/Transforms/LowerTypeTests/import.ll
index 812c0619a169ac1..abe85460ab5bb63 100644
--- a/llvm/test/Transforms/LowerTypeTests/import.ll
+++ b/llvm/test/Transforms/LowerTypeTests/import.ll
@@ -1,3 +1,4 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3
 ; RUN: opt -mtriple=x86_64-unknown-linux -S -passes=lowertypetests -lowertypetests-summary-action=import -lowertypetests-read-summary=%S/Inputs/import.yaml %s | FileCheck --check-prefixes=CHECK,X86 %s
 ; RUN: opt -mtriple=aarch64-unknown-linux -S -passes=lowertypetests -lowertypetests-summary-action=import -lowertypetests-read-summary=%S/Inputs/import.yaml %s | FileCheck --check-prefixes=CHECK,ARM %s
 
@@ -31,156 +32,237 @@ declare i1 @llvm.type.test(ptr %ptr, metadata %bitset) nounwind readnone
 ; X86-DAG: @__typeid_allones7_align = external hidden global [0 x i8], !absolute_symbol !0
 ; X86-DAG: @__typeid_allones7_size_m1 = external hidden global [0 x i8], !absolute_symbol !5
 
-; CHECK: define i1 @allones7(ptr [[p:%.*]])
 define i1 @allones7(ptr %p) {
-  ; CHECK-NEXT: [[pi:%.*]] = ptrtoint ptr [[p]] to i64
-  ; CHECK-NEXT: [[sub:%.*]] = sub i64 [[pi]], ptrtoint (ptr @__typeid_allones7_global_addr to i64)
-  ; X86-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], zext (i8 ptrtoint (ptr @__typeid_allones7_align to i8) to i64)
-  ; X86-NEXT: [[shl:%.*]] = shl i64 [[sub]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_allones7_align to i8)) to i64)
-  ; ARM-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], 1
-  ; ARM-NEXT: [[shl:%.*]] = shl i64 [[sub]], 63
-  ; CHECK-NEXT: [[or:%.*]] = or i64 [[lshr]], [[shl]]
-  ; X86-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], ptrtoint (ptr @__typeid_allones7_size_m1 to i64)
-  ; ARM-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], 42
-  ; CHECK-NEXT: ret i1 [[ule]]
+; X86-LABEL: define i1 @allones7(
+; X86-SAME: ptr [[P:%.*]]) {
+; X86-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; X86-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_allones7_global_addr to i64)
+; X86-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], zext (i8 ptrtoint (ptr @__typeid_allones7_align to i8) to i64)
+; X86-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_allones7_align to i8)) to i64)
+; X86-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; X86-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], ptrtoint (ptr @__typeid_allones7_size_m1 to i64)
+; X86-NEXT:    ret i1 [[TMP6]]
+;
+; ARM-LABEL: define i1 @allones7(
+; ARM-SAME: ptr [[P:%.*]]) {
+; ARM-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; ARM-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_allones7_global_addr to i64)
+; ARM-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], 1
+; ARM-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], 63
+; ARM-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; ARM-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], 42
+; ARM-NEXT:    ret i1 [[TMP6]]
+;
   %x = call i1 @llvm.type.test(ptr %p, metadata !"allones7")
   ret i1 %x
 }
 
-; CHECK: define i1 @allones32(ptr [[p:%.*]])
 define i1 @allones32(ptr %p) {
-  ; CHECK-NEXT: [[pi:%.*]] = ptrtoint ptr [[p]] to i64
-  ; CHECK-NEXT: [[sub:%.*]] = sub i64 [[pi]], ptrtoint (ptr @__typeid_allones32_global_addr to i64)
-  ; X86-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], zext (i8 ptrtoint (ptr @__typeid_allones32_align to i8) to i64)
-  ; X86-NEXT: [[shl:%.*]] = shl i64 [[sub]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_allones32_align to i8)) to i64)
-  ; ARM-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], 2
-  ; ARM-NEXT: [[shl:%.*]] = shl i64 [[sub]], 62
-  ; CHECK-NEXT: [[or:%.*]] = or i64 [[lshr]], [[shl]]
-  ; X86-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], ptrtoint (ptr @__typeid_allones32_size_m1 to i64)
-  ; ARM-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], 12345
-  ; CHECK-NEXT: ret i1 [[ule]]
+; X86-LABEL: define i1 @allones32(
+; X86-SAME: ptr [[P:%.*]]) {
+; X86-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; X86-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_allones32_global_addr to i64)
+; X86-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], zext (i8 ptrtoint (ptr @__typeid_allones32_align to i8) to i64)
+; X86-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_allones32_align to i8)) to i64)
+; X86-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; X86-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], ptrtoint (ptr @__typeid_allones32_size_m1 to i64)
+; X86-NEXT:    ret i1 [[TMP6]]
+;
+; ARM-LABEL: define i1 @allones32(
+; ARM-SAME: ptr [[P:%.*]]) {
+; ARM-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; ARM-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_allones32_global_addr to i64)
+; ARM-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], 2
+; ARM-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], 62
+; ARM-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; ARM-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], 12345
+; ARM-NEXT:    ret i1 [[TMP6]]
+;
   %x = call i1 @llvm.type.test(ptr %p, metadata !"allones32")
   ret i1 %x
 }
 
-; CHECK: define i1 @bytearray7(ptr [[p:%.*]])
 define i1 @bytearray7(ptr %p) {
-  ; CHECK-NEXT: [[pi:%.*]] = ptrtoint ptr [[p]] to i64
-  ; CHECK-NEXT: [[sub:%.*]] = sub i64 [[pi]], ptrtoint (ptr @__typeid_bytearray7_global_addr to i64)
-  ; X86-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], zext (i8 ptrtoint (ptr @__typeid_bytearray7_align to i8) to i64)
-  ; X86-NEXT: [[shl:%.*]] = shl i64 [[sub]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_bytearray7_align to i8)) to i64)
-  ; ARM-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], 3
-  ; ARM-NEXT: [[shl:%.*]] = shl i64 [[sub]], 61
-  ; CHECK-NEXT: [[or:%.*]] = or i64 [[lshr]], [[shl]]
-  ; X86-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], ptrtoint (ptr @__typeid_bytearray7_size_m1 to i64)
-  ; ARM-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], 43
-  ; CHECK-NEXT: br i1 [[ule]], label %[[t:.*]], label %[[f:.*]]
-
-  ; CHECK: [[t]]:
-  ; CHECK-NEXT: [[gep:%.*]] = getelementptr i8, ptr @__typeid_bytearray7_byte_array, i64 [[or]]
-  ; CHECK-NEXT: [[load:%.*]] = load i8, ptr [[gep]]
-  ; X86-NEXT: [[and:%.*]] = and i8 [[load]], ptrtoint (ptr @__typeid_bytearray7_bit_mask to i8)
-  ; ARM-NEXT: [[and:%.*]] = and i8 [[load]], ptrtoint (ptr inttoptr (i64 64 to ptr) to i8)
-  ; CHECK-NEXT: [[ne:%.*]] = icmp ne i8 [[and]], 0
-  ; CHECK-NEXT: br label %[[f]]
-
-  ; CHECK: [[f]]:
-  ; CHECK-NEXT: [[phi:%.*]] = phi i1 [ false, %0 ], [ [[ne]], %[[t]] ]
-  ; CHECK-NEXT: ret i1 [[phi]]
+; X86-LABEL: define i1 @bytearray7(
+; X86-SAME: ptr [[P:%.*]]) {
+; X86-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; X86-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_bytearray7_global_addr to i64)
+; X86-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], zext (i8 ptrtoint (ptr @__typeid_bytearray7_align to i8) to i64)
+; X86-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_bytearray7_align to i8)) to i64)
+; X86-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; X86-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], ptrtoint (ptr @__typeid_bytearray7_size_m1 to i64)
+; X86-NEXT:    br i1 [[TMP6]], label [[TMP7:%.*]], label [[TMP12:%.*]]
+; X86:       7:
+; X86-NEXT:    [[TMP8:%.*]] = getelementptr i8, ptr @__typeid_bytearray7_byte_array, i64 [[TMP5]]
+; X86-NEXT:    [[TMP9:%.*]] = load i8, ptr [[TMP8]], align 1
+; X86-NEXT:    [[TMP10:%.*]] = and i8 [[TMP9]], ptrtoint (ptr @__typeid_bytearray7_bit_mask to i8)
+; X86-NEXT:    [[TMP11:%.*]] = icmp ne i8 [[TMP10]], 0
+; X86-NEXT:    br label [[TMP12]]
+; X86:       12:
+; X86-NEXT:    [[TMP13:%.*]] = phi i1 [ false, [[TMP0:%.*]] ], [ [[TMP11]], [[TMP7]] ]
+; X86-NEXT:    ret i1 [[TMP13]]
+;
+; ARM-LABEL: define i1 @bytearray7(
+; ARM-SAME: ptr [[P:%.*]]) {
+; ARM-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; ARM-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_bytearray7_global_addr to i64)
+; ARM-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], 3
+; ARM-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], 61
+; ARM-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; ARM-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], 43
+; ARM-NEXT:    br i1 [[TMP6]], label [[TMP7:%.*]], label [[TMP12:%.*]]
+; ARM:       7:
+; ARM-NEXT:    [[TMP8:%.*]] = getelementptr i8, ptr @__typeid_bytearray7_byte_array, i64 [[TMP5]]
+; ARM-NEXT:    [[TMP9:%.*]] = load i8, ptr [[TMP8]], align 1
+; ARM-NEXT:    [[TMP10:%.*]] = and i8 [[TMP9]], ptrtoint (ptr inttoptr (i64 64 to ptr) to i8)
+; ARM-NEXT:    [[TMP11:%.*]] = icmp ne i8 [[TMP10]], 0
+; ARM-NEXT:    br label [[TMP12]]
+; ARM:       12:
+; ARM-NEXT:    [[TMP13:%.*]] = phi i1 [ false, [[TMP0:%.*]] ], [ [[TMP11]], [[TMP7]] ]
+; ARM-NEXT:    ret i1 [[TMP13]]
+;
   %x = call i1 @llvm.type.test(ptr %p, metadata !"bytearray7")
   ret i1 %x
 }
 
-; CHECK: define i1 @bytearray32(ptr [[p:%.*]])
 define i1 @bytearray32(ptr %p) {
-  ; CHECK-NEXT: [[pi:%.*]] = ptrtoint ptr [[p]] to i64
-  ; CHECK-NEXT: [[sub:%.*]] = sub i64 [[pi]], ptrtoint (ptr @__typeid_bytearray32_global_addr to i64)
-  ; X86-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], zext (i8 ptrtoint (ptr @__typeid_bytearray32_align to i8) to i64)
-  ; X86-NEXT: [[shl:%.*]] = shl i64 [[sub]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_bytearray32_align to i8)) to i64)
-  ; ARM-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], 4
-  ; ARM-NEXT: [[shl:%.*]] = shl i64 [[sub]], 60
-  ; CHECK-NEXT: [[or:%.*]] = or i64 [[lshr]], [[shl]]
-  ; X86-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], ptrtoint (ptr @__typeid_bytearray32_size_m1 to i64)
-  ; ARM-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], 12346
-  ; CHECK-NEXT: br i1 [[ule]], label %[[t:.*]], label %[[f:.*]]
-
-  ; CHECK: [[t]]:
-  ; CHECK-NEXT: [[gep:%.*]] = getelementptr i8, ptr @__typeid_bytearray32_byte_array, i64 [[or]]
-  ; CHECK-NEXT: [[load:%.*]] = load i8, ptr [[gep]]
-  ; X86-NEXT: [[and:%.*]] = and i8 [[load]], ptrtoint (ptr @__typeid_bytearray32_bit_mask to i8)
-  ; ARM-NEXT: [[and:%.*]] = and i8 [[load]], ptrtoint (ptr inttoptr (i64 128 to ptr) to i8)
-  ; CHECK-NEXT: [[ne:%.*]] = icmp ne i8 [[and]], 0
-  ; CHECK-NEXT: br label %[[f]]
-
-  ; CHECK: [[f]]:
-  ; CHECK-NEXT: [[phi:%.*]] = phi i1 [ false, %0 ], [ [[ne]], %[[t]] ]
-  ; CHECK-NEXT: ret i1 [[phi]]
+; X86-LABEL: define i1 @bytearray32(
+; X86-SAME: ptr [[P:%.*]]) {
+; X86-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; X86-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_bytearray32_global_addr to i64)
+; X86-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], zext (i8 ptrtoint (ptr @__typeid_bytearray32_align to i8) to i64)
+; X86-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_bytearray32_align to i8)) to i64)
+; X86-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; X86-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], ptrtoint (ptr @__typeid_bytearray32_size_m1 to i64)
+; X86-NEXT:    br i1 [[TMP6]], label [[TMP7:%.*]], label [[TMP12:%.*]]
+; X86:       7:
+; X86-NEXT:    [[TMP8:%.*]] = getelementptr i8, ptr @__typeid_bytearray32_byte_array, i64 [[TMP5]]
+; X86-NEXT:    [[TMP9:%.*]] = load i8, ptr [[TMP8]], align 1
+; X86-NEXT:    [[TMP10:%.*]] = and i8 [[TMP9]], ptrtoint (ptr @__typeid_bytearray32_bit_mask to i8)
+; X86-NEXT:    [[TMP11:%.*]] = icmp ne i8 [[TMP10]], 0
+; X86-NEXT:    br label [[TMP12]]
+; X86:       12:
+; X86-NEXT:    [[TMP13:%.*]] = phi i1 [ false, [[TMP0:%.*]] ], [ [[TMP11]], [[TMP7]] ]
+; X86-NEXT:    ret i1 [[TMP13]]
+;
+; ARM-LABEL: define i1 @bytearray32(
+; ARM-SAME: ptr [[P:%.*]]) {
+; ARM-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; ARM-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_bytearray32_global_addr to i64)
+; ARM-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], 4
+; ARM-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], 60
+; ARM-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; ARM-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], 12346
+; ARM-NEXT:    br i1 [[TMP6]], label [[TMP7:%.*]], label [[TMP12:%.*]]
+; ARM:       7:
+; ARM-NEXT:    [[TMP8:%.*]] = getelementptr i8, ptr @__typeid_bytearray32_byte_array, i64 [[TMP5]]
+; ARM-NEXT:    [[TMP9:%.*]] = load i8, ptr [[TMP8]], align 1
+; ARM-NEXT:    [[TMP10:%.*]] = and i8 [[TMP9]], ptrtoint (ptr inttoptr (i64 128 to ptr) to i8)
+; ARM-NEXT:    [[TMP11:%.*]] = icmp ne i8 [[TMP10]], 0
+; ARM-NEXT:    br label [[TMP12]]
+; ARM:       12:
+; ARM-NEXT:    [[TMP13:%.*]] = phi i1 [ false, [[TMP0:%.*]] ], [ [[TMP11]], [[TMP7]] ]
+; ARM-NEXT:    ret i1 [[TMP13]]
+;
   %x = call i1 @llvm.type.test(ptr %p, metadata !"bytearray32")
   ret i1 %x
 }
 
-; CHECK: define i1 @inline5(ptr [[p:%.*]])
 define i1 @inline5(ptr %p) {
-  ; CHECK-NEXT: [[pi:%.*]] = ptrtoint ptr [[p]] to i64
-  ; CHECK-NEXT: [[sub:%.*]] = sub i64 [[pi]], ptrtoint (ptr @__typeid_inline5_global_addr to i64)
-  ; X86-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], zext (i8 ptrtoint (ptr @__typeid_inline5_align to i8) to i64)
-  ; X86-NEXT: [[shl:%.*]] = shl i64 [[sub]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_inline5_align to i8)) to i64)
-  ; ARM-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], 5
-  ; ARM-NEXT: [[shl:%.*]] = shl i64 [[sub]], 59
-  ; CHECK-NEXT: [[or:%.*]] = or i64 [[lshr]], [[shl]]
-  ; X86-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], ptrtoint (ptr @__typeid_inline5_size_m1 to i64)
-  ; ARM-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], 31
-  ; CHECK-NEXT: br i1 [[ule]], label %[[t:.*]], label %[[f:.*]]
-
-  ; CHECK: [[t]]:
-  ; CHECK-NEXT: [[trunc:%.*]] = trunc i64 [[or]] to i32
-  ; CHECK-NEXT: [[and:%.*]] = and i32 [[trunc]], 31
-  ; CHECK-NEXT: [[shl2:%.*]] = shl i32 1, [[and]]
-  ; X86-NEXT: [[and2:%.*]] = and i32 ptrtoint (ptr @__typeid_inline5_inline_bits to i32), [[shl2]]
-  ; ARM-NEXT: [[and2:%.*]] = and i32 123, [[shl2]]
-  ; CHECK-NEXT: [[ne:%.*]] = icmp ne i32 [[and2]], 0
-  ; CHECK-NEXT: br label %[[f]]
-
-  ; CHECK: [[f]]:
-  ; CHECK-NEXT: [[phi:%.*]] = phi i1 [ false, %0 ], [ [[ne]], %[[t]] ]
-  ; CHECK-NEXT: ret i1 [[phi]]
+; X86-LABEL: define i1 @inline5(
+; X86-SAME: ptr [[P:%.*]]) {
+; X86-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; X86-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_inline5_global_addr to i64)
+; X86-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], zext (i8 ptrtoint (ptr @__typeid_inline5_align to i8) to i64)
+; X86-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_inline5_align to i8)) to i64)
+; X86-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; X86-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], ptrtoint (ptr @__typeid_inline5_size_m1 to i64)
+; X86-NEXT:    br i1 [[TMP6]], label [[TMP7:%.*]], label [[TMP13:%.*]]
+; X86:       7:
+; X86-NEXT:    [[TMP8:%.*]] = trunc i64 [[TMP5]] to i32
+; X86-NEXT:    [[TMP9:%.*]] = and i32 [[TMP8]], 31
+; X86-NEXT:    [[TMP10:%.*]] = shl i32 1, [[TMP9]]
+; X86-NEXT:    [[TMP11:%.*]] = and i32 ptrtoint (ptr @__typeid_inline5_inline_bits to i32), [[TMP10]]
+; X86-NEXT:    [[TMP12:%.*]] = icmp ne i32 [[TMP11]], 0
+; X86-NEXT:    br label [[TMP13]]
+; X86:       13:
+; X86-NEXT:    [[TMP14:%.*]] = phi i1 [ false, [[TMP0:%.*]] ], [ [[TMP12]], [[TMP7]] ]
+; X86-NEXT:    ret i1 [[TMP14]]
+;
+; ARM-LABEL: define i1 @inline5(
+; ARM-SAME: ptr [[P:%.*]]) {
+; ARM-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; ARM-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_inline5_global_addr to i64)
+; ARM-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], 5
+; ARM-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], 59
+; ARM-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; ARM-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], 31
+; ARM-NEXT:    br i1 [[TMP6]], label [[TMP7:%.*]], label [[TMP13:%.*]]
+; ARM:       7:
+; ARM-NEXT:    [[TMP8:%.*]] = trunc i64 [[TMP5]] to i32
+; ARM-NEXT:    [[TMP9:%.*]] = and i32 [[TMP8]], 31
+; ARM-NEXT:    [[TMP10:%.*]] = shl i32 1, [[TMP9]]
+; ARM-NEXT:    [[TMP11:%.*]] = and i32 123, [[TMP10]]
+; ARM-NEXT:    [[TMP12:%.*]] = icmp ne i32 [[TMP11]], 0
+; ARM-NEXT:    br label [[TMP13]]
+; ARM:       13:
+; ARM-NEXT:    [[TMP14:%.*]] = phi i1 [ false, [[TMP0:%.*]] ], [ [[TMP12]], [[TMP7]] ]
+; ARM-NEXT:    ret i1 [[TMP14]]
+;
   %x = call i1 @llvm.type.test(ptr %p, metadata !"inline5")
   ret i1 %x
 }
 
-; CHECK: define i1 @inline6(ptr [[p:%.*]])
 define i1 @inline6(ptr %p) {
-  ; CHECK-NEXT: [[pi:%.*]] = ptrtoint ptr [[p]] to i64
-  ; CHECK-NEXT: [[sub:%.*]] = sub i64 [[pi]], ptrtoint (ptr @__typeid_inline6_global_addr to i64)
-  ; X86-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], zext (i8 ptrtoint (ptr @__typeid_inline6_align to i8) to i64)
-  ; X86-NEXT: [[shl:%.*]] = shl i64 [[sub]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_inline6_align to i8)) to i64)
-  ; ARM-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], 6
-  ; ARM-NEXT: [[shl:%.*]] = shl i64 [[sub]], 58
-  ; CHECK-NEXT: [[or:%.*]] = or i64 [[lshr]], [[shl]]
-  ; X86-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], ptrtoint (ptr @__typeid_inline6_size_m1 to i64)
-  ; ARM-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], 63
-  ; CHECK-NEXT: br i1 [[ule]], label %[[t:.*]], label %[[f:.*]]
-
-  ; CHECK: [[t]]:
-  ; CHECK-NEXT: [[and:%.*]] = and i64 [[or]], 63
-  ; CHECK-NEXT: [[shl2:%.*]] = shl i64 1, [[and]]
-  ; X86-NEXT: [[and2:%.*]] = and i64 ptrtoint (ptr @__typeid_inline6_inline_bits to i64), [[shl2]]
-  ; ARM-NEXT: [[and2:%.*]] = and i64 1000000000000, [[shl2]]
-  ; CHECK-NEXT: [[ne:%.*]] = icmp ne i64 [[and2]], 0
-  ; CHECK-NEXT: br label %[[f]]
-
-  ; CHECK: [[f]]:
-  ; CHECK-NEXT: [[phi:%.*]] = phi i1 [ false, %0 ], [ [[ne]], %[[t]] ]
-  ; CHECK-NEXT: ret i1 [[phi]]
+; X86-LABEL: define i1 @inline6(
+; X86-SAME: ptr [[P:%.*]]) {
+; X86-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; X86-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_inline6_global_addr to i64)
+; X86-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], zext (i8 ptrtoint (ptr @__typeid_inline6_align to i8) to i64)
+; X86-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_inline6_align to i8)) to i64)
+; X86-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; X86-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], ptrtoint (ptr @__typeid_inline6_size_m1 to i64)
+; X86-NEXT:    br i1 [[TMP6]], label [[TMP7:%.*]], label [[TMP12:%.*]]
+; X86:       7:
+; X86-NEXT:    [[TMP8:%.*]] = and i64 [[TMP5]], 63
+; X86-NEXT:    [[TMP9:%.*]] = shl i64 1, [[TMP8]]
+; X86-NEXT:    [[TMP10:%.*]] = and i64 ptrtoint (ptr @__typeid_inline6_inline_bits to i64), [[TMP9]]
+; X86-NEXT:    [[TMP11:%.*]] = icmp ne i64 [[TMP10]], 0
+; X86-NEXT:    br label [[TMP12]]
+; X86:       12:
+; X86-NEXT:    [[TMP13:%.*]] = phi i1 [ false, [[TMP0:%.*]] ], [ [[TMP11]], [[TMP7]] ]
+; X86-NEXT:    ret i1 [[TMP13]]
+;
+; ARM-LABEL: define i1 @inline6(
+; ARM-SAME: ptr [[P:%.*]]) {
+; ARM-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; ARM-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_inline6_global_addr to i64)
+; ARM-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], 6
+; ARM-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], 58
+; ARM-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; ARM-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], 63
+; ARM-NEXT:    br i1 [[TMP6]], label [[TMP7:%.*]], label [[TMP12:%.*]]
+; ARM:       7:
+; ARM-NEXT:    [[TMP8:%.*]] = and i64 [[TMP5]], 63
+; ARM-NEXT:    [[TMP9:%.*]] = shl i64 1, [[TMP8]]
+; ARM-NEXT:    [[TMP10:%.*]] = and i64 1000000000000, [[TMP9]]
+; ARM-NEXT:    [[TMP11:%.*]] = icmp ne i64 [[TMP10]], 0
+; ARM-NEXT:    br label [[TMP12]]
+; ARM:       12:
+; ARM-NEXT:    [[TMP13:%.*]] = phi i1 [ false, [[TMP0:%.*]] ], [ [[TMP11]], [[TMP7]] ]
+; ARM-NEXT:    ret i1 [[TMP13]]
+;
   %x = call i1 @llvm.type.test(ptr %p, metadata !"inline6")
   ret i1 %x
 }
 
-; CHECK: define i1 @single(ptr [[p:%.*]])
 define i1 @single(ptr %p) {
-  ; CHECK-NEXT: [[pi:%.*]] = ptrtoint ptr [[p]] to i64
-  ; CHECK-NEXT: [[eq:%.*]] = icmp eq i64 [[pi]], ptrtoint (ptr @__typeid_single_global_addr to i64)
-  ; CHECK-NEXT: ret i1 [[eq]]
+; CHECK-LABEL: define i1 @single(
+; CHECK-SAME: ptr [[P:%.*]]) {
+; CHECK-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; CHECK-NEXT:    [[TMP2:%.*]] = icmp eq i64 [[TMP1]], ptrtoint (ptr @__typeid_single_global_addr to i64)
+; CHECK-NEXT:    ret i1 [[TMP2]]
+;
   %x = call i1 @llvm.type.test(ptr %p, metadata !"single")
   ret i1 %x
 }

diff  --git a/llvm/test/Transforms/LowerTypeTests/simplify.ll b/llvm/test/Transforms/LowerTypeTests/simplify.ll
index 87eaed5a51f2453..3ad856d9bb24b8b 100644
--- a/llvm/test/Transforms/LowerTypeTests/simplify.ll
+++ b/llvm/test/Transforms/LowerTypeTests/simplify.ll
@@ -1,3 +1,4 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3
 ; RUN: opt -S -passes=lowertypetests -lowertypetests-summary-action=import -lowertypetests-read-summary=%S/Inputs/import.yaml %s | FileCheck %s
 
 target datalayout = "e-p:64:64"
@@ -5,28 +6,27 @@ target triple = "x86_64-unknown-linux"
 
 declare i1 @llvm.type.test(ptr %ptr, metadata %bitset) nounwind readnone
 
-; CHECK: define i1 @bytearray7(ptr [[p:%.*]])
 define i1 @bytearray7(ptr %p) {
-  ; CHECK-NEXT: [[pi:%.*]] = ptrtoint ptr [[p]] to i64
-  ; CHECK-NEXT: [[sub:%.*]] = sub i64 [[pi]], ptrtoint (ptr @__typeid_bytearray7_global_addr to i64)
-  ; CHECK-NEXT: [[lshr:%.*]] = lshr i64 [[sub]], zext (i8 ptrtoint (ptr @__typeid_bytearray7_align to i8) to i64)
-  ; CHECK-NEXT: [[shl:%.*]] = shl i64 [[sub]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_bytearray7_align to i8)) to i64)
-  ; CHECK-NEXT: [[or:%.*]] = or i64 [[lshr]], [[shl]]
-  ; CHECK-NEXT: [[ule:%.*]] = icmp ule i64 [[or]], ptrtoint (ptr @__typeid_bytearray7_size_m1 to i64)
-  ; CHECK-NEXT: br i1 [[ule]], label %[[t1:.*]], label %[[f:.*]]
-
-  ; CHECK: [[t1]]:
-  ; CHECK-NEXT: [[gep:%.*]] = getelementptr i8, ptr @__typeid_bytearray7_byte_array, i64 [[or]]
-  ; CHECK-NEXT: [[load:%.*]] = load i8, ptr [[gep]]
-  ; CHECK-NEXT: [[and:%.*]] = and i8 [[load]], ptrtoint (ptr @__typeid_bytearray7_bit_mask to i8)
-  ; CHECK-NEXT: [[ne:%.*]] = icmp ne i8 [[and]], 0
-  ; CHECK-NEXT: br i1 [[ne]], label %[[t:.*]], label %[[f:.*]]
-
-  ; CHECK: [[t]]:
-  ; CHECK-NEXT: ret i1 true
-
-  ; CHECK: [[f]]:
-  ; CHECK-NEXT: ret i1 false
+; CHECK-LABEL: define i1 @bytearray7(
+; CHECK-SAME: ptr [[P:%.*]]) {
+; CHECK-NEXT:    [[TMP1:%.*]] = ptrtoint ptr [[P]] to i64
+; CHECK-NEXT:    [[TMP2:%.*]] = sub i64 [[TMP1]], ptrtoint (ptr @__typeid_bytearray7_global_addr to i64)
+; CHECK-NEXT:    [[TMP3:%.*]] = lshr i64 [[TMP2]], zext (i8 ptrtoint (ptr @__typeid_bytearray7_align to i8) to i64)
+; CHECK-NEXT:    [[TMP4:%.*]] = shl i64 [[TMP2]], zext (i8 sub (i8 64, i8 ptrtoint (ptr @__typeid_bytearray7_align to i8)) to i64)
+; CHECK-NEXT:    [[TMP5:%.*]] = or i64 [[TMP3]], [[TMP4]]
+; CHECK-NEXT:    [[TMP6:%.*]] = icmp ule i64 [[TMP5]], ptrtoint (ptr @__typeid_bytearray7_size_m1 to i64)
+; CHECK-NEXT:    br i1 [[TMP6]], label [[TMP7:%.*]], label [[F:%.*]]
+; CHECK:       7:
+; CHECK-NEXT:    [[TMP8:%.*]] = getelementptr i8, ptr @__typeid_bytearray7_byte_array, i64 [[TMP5]]
+; CHECK-NEXT:    [[TMP9:%.*]] = load i8, ptr [[TMP8]], align 1
+; CHECK-NEXT:    [[TMP10:%.*]] = and i8 [[TMP9]], ptrtoint (ptr @__typeid_bytearray7_bit_mask to i8)
+; CHECK-NEXT:    [[TMP11:%.*]] = icmp ne i8 [[TMP10]], 0
+; CHECK-NEXT:    br i1 [[TMP11]], label [[T:%.*]], label [[F]]
+; CHECK:       t:
+; CHECK-NEXT:    ret i1 true
+; CHECK:       f:
+; CHECK-NEXT:    ret i1 false
+;
   %x = call i1 @llvm.type.test(ptr %p, metadata !"bytearray7")
   br i1 %x, label %t, label %f
 


        


More information about the llvm-commits mailing list