Skip to content

Commit

Permalink
[NFC][X86] Precommit tests for memset with minsize being present
Browse files Browse the repository at this point in the history
  • Loading branch information
dseredkin committed Dec 12, 2021
1 parent 90f9855 commit 9633df0
Showing 1 changed file with 148 additions and 0 deletions.
148 changes: 148 additions & 0 deletions llvm/test/CodeGen/X86/memset-minsize.ll
@@ -0,0 +1,148 @@
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=x86_64-unknown-unknown | FileCheck %s

define void @tiny_memset_to_rep_stos(i32* %ptr) minsize nounwind {
; CHECK-LABEL: tiny_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: andq $0, (%rdi)
; CHECK-NEXT: retq
entry:
%0 = bitcast i32* %ptr to i8*
call void @llvm.memset.p0i8.i32(i8* align 4 %0, i8 0, i32 8, i1 false)
ret void
}

define void @small_memset_to_rep_stos(i32* %ptr) minsize nounwind {
; CHECK-LABEL: small_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq $32
; CHECK-NEXT: popq %rcx
; CHECK-NEXT: xorl %eax, %eax
; CHECK-NEXT: rep;stosl %eax, %es:(%rdi)
; CHECK-NEXT: retq
entry:
%0 = bitcast i32* %ptr to i8*
call void @llvm.memset.p0i8.i32(i8* align 4 %0, i8 0, i32 128, i1 false)
ret void
}

define void @medium_memset_to_rep_stos(i32* %ptr) minsize nounwind {
; CHECK-LABEL: medium_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq %rax
; CHECK-NEXT: movl $512, %edx # imm = 0x200
; CHECK-NEXT: xorl %esi, %esi
; CHECK-NEXT: callq memset@PLT
; CHECK-NEXT: popq %rax
; CHECK-NEXT: retq
entry:
%0 = bitcast i32* %ptr to i8*
call void @llvm.memset.p0i8.i32(i8* align 4 %0, i8 0, i32 512, i1 false)
ret void
}

define void @large_memset_to_rep_stos(i32* %ptr) minsize nounwind {
; CHECK-LABEL: large_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq %rax
; CHECK-NEXT: movl $4096, %edx # imm = 0x1000
; CHECK-NEXT: xorl %esi, %esi
; CHECK-NEXT: callq memset@PLT
; CHECK-NEXT: popq %rax
; CHECK-NEXT: retq
entry:
%0 = bitcast i32* %ptr to i8*
call void @llvm.memset.p0i8.i32(i8* align 4 %0, i8 0, i32 4096, i1 false)
ret void
}

define void @huge_memset_to_rep_stos(i32* %ptr) minsize nounwind {
; CHECK-LABEL: huge_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq %rax
; CHECK-NEXT: movl $8192, %edx # imm = 0x2000
; CHECK-NEXT: xorl %esi, %esi
; CHECK-NEXT: callq memset@PLT
; CHECK-NEXT: popq %rax
; CHECK-NEXT: retq
entry:
%0 = bitcast i32* %ptr to i8*
call void @llvm.memset.p0i8.i32(i8* align 4 %0, i8 0, i32 8192, i1 false)
ret void
}

define void @odd_length_memset_to_rep_stos(i32* %ptr) minsize nounwind {
; CHECK-LABEL: odd_length_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq %rax
; CHECK-NEXT: movl $255, %edx
; CHECK-NEXT: xorl %esi, %esi
; CHECK-NEXT: callq memset@PLT
; CHECK-NEXT: popq %rax
; CHECK-NEXT: retq
entry:
%0 = bitcast i32* %ptr to i8*
call void @llvm.memset.p0i8.i32(i8* align 4 %0, i8 0, i32 255, i1 false)
ret void
}

define void @align_1_memset_to_rep_stos(i8* %ptr) minsize nounwind {
; CHECK-LABEL: align_1_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq %rax
; CHECK-NEXT: movl $256, %edx # imm = 0x100
; CHECK-NEXT: xorl %esi, %esi
; CHECK-NEXT: callq memset@PLT
; CHECK-NEXT: popq %rax
; CHECK-NEXT: retq
entry:
call void @llvm.memset.p0i8.i32(i8* align 1 %ptr, i8 0, i32 256, i1 false)
ret void
}

define void @align_2_memset_to_rep_stos(i16* %ptr) minsize nounwind {
; CHECK-LABEL: align_2_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq %rax
; CHECK-NEXT: movl $256, %edx # imm = 0x100
; CHECK-NEXT: xorl %esi, %esi
; CHECK-NEXT: callq memset@PLT
; CHECK-NEXT: popq %rax
; CHECK-NEXT: retq
entry:
%0 = bitcast i16* %ptr to i8*
call void @llvm.memset.p0i8.i32(i8* align 2 %0, i8 0, i32 256, i1 false)
ret void
}

define void @align_4_memset_to_rep_stos(i16* %ptr) minsize nounwind {
; CHECK-LABEL: align_4_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq %rax
; CHECK-NEXT: movl $256, %edx # imm = 0x100
; CHECK-NEXT: xorl %esi, %esi
; CHECK-NEXT: callq memset@PLT
; CHECK-NEXT: popq %rax
; CHECK-NEXT: retq
entry:
%0 = bitcast i16* %ptr to i8*
call void @llvm.memset.p0i8.i32(i8* align 4 %0, i8 0, i32 256, i1 false)
ret void
}

define void @align_8_memset_to_rep_stos(i64* %ptr) minsize nounwind {
; CHECK-LABEL: align_8_memset_to_rep_stos:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq %rax
; CHECK-NEXT: movl $256, %edx # imm = 0x100
; CHECK-NEXT: xorl %esi, %esi
; CHECK-NEXT: callq memset@PLT
; CHECK-NEXT: popq %rax
; CHECK-NEXT: retq
entry:
%0 = bitcast i64* %ptr to i8*
call void @llvm.memset.p0i8.i32(i8* align 8 %0, i8 0, i32 256, i1 false)
ret void
}

declare void @llvm.memset.p0i8.i32(i8* nocapture writeonly, i8, i32, i1)

0 comments on commit 9633df0

Please sign in to comment.