; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5 ; RUN: opt -mtriple=amdgcn--amdpal -passes=load-store-vectorizer -S -o - %s | FileCheck --check-prefix=OOB-STRICT %s ; RUN: opt -mtriple=amdgcn--amdpal -passes=load-store-vectorizer -mattr=+relaxed-buffer-oob-mode -S -o - %s | FileCheck --check-prefixes=OOB-RELAXED %s ; The test checks that relaxed-buffer-oob-mode allows merging loads even if the target load is not naturally aligned. define amdgpu_kernel void @merge_align_4(ptr addrspace(7) captures(none) %p) #0 { ; ; OOB-STRICT-LABEL: define amdgpu_kernel void @merge_align_4( ; OOB-STRICT-SAME: ptr addrspace(7) captures(none) [[P:%.*]]) { ; OOB-STRICT-NEXT: [[ENTRY:.*:]] ; OOB-STRICT-NEXT: [[GEP_M8:%.*]] = getelementptr i8, ptr addrspace(7) [[P]], i32 -8 ; OOB-STRICT-NEXT: [[LD_M8:%.*]] = load i32, ptr addrspace(7) [[GEP_M8]], align 4 ; OOB-STRICT-NEXT: [[GEP_M4:%.*]] = getelementptr i8, ptr addrspace(7) [[P]], i32 -4 ; OOB-STRICT-NEXT: [[LD_M4:%.*]] = load i32, ptr addrspace(7) [[GEP_M4]], align 4 ; OOB-STRICT-NEXT: [[GEP_0:%.*]] = getelementptr i8, ptr addrspace(7) [[P]], i32 0 ; OOB-STRICT-NEXT: [[LD_0:%.*]] = load i32, ptr addrspace(7) [[GEP_0]], align 4 ; OOB-STRICT-NEXT: [[GEP_4:%.*]] = getelementptr i8, ptr addrspace(7) [[P]], i64 4 ; OOB-STRICT-NEXT: [[LD_4:%.*]] = load i32, ptr addrspace(7) [[GEP_4]], align 4 ; OOB-STRICT-NEXT: ret void ; ; OOB-RELAXED-LABEL: define amdgpu_kernel void @merge_align_4( ; OOB-RELAXED-SAME: ptr addrspace(7) captures(none) [[P:%.*]]) #[[ATTR0:[0-9]+]] { ; OOB-RELAXED-NEXT: [[ENTRY:.*:]] ; OOB-RELAXED-NEXT: [[GEP_M8:%.*]] = getelementptr i8, ptr addrspace(7) [[P]], i32 -8 ; OOB-RELAXED-NEXT: [[TMP0:%.*]] = load <4 x i32>, ptr addrspace(7) [[GEP_M8]], align 4 ; OOB-RELAXED-NEXT: [[LD_M81:%.*]] = extractelement <4 x i32> [[TMP0]], i32 0 ; OOB-RELAXED-NEXT: [[LD_M42:%.*]] = extractelement <4 x i32> [[TMP0]], i32 1 ; OOB-RELAXED-NEXT: [[LD_03:%.*]] = extractelement <4 x i32> [[TMP0]], i32 2 ; OOB-RELAXED-NEXT: [[LD_44:%.*]] = extractelement <4 x i32> [[TMP0]], i32 3 ; OOB-RELAXED-NEXT: ret void ; entry: %gep_m8 = getelementptr i8, ptr addrspace(7) %p, i32 -8 %ld_m8 = load i32, ptr addrspace(7) %gep_m8, align 4 %gep_m4 = getelementptr i8, ptr addrspace(7) %p, i32 -4 %ld_m4 = load i32, ptr addrspace(7) %gep_m4, align 4 %gep_0 = getelementptr i8, ptr addrspace(7) %p, i32 0 %ld_0 = load i32, ptr addrspace(7) %gep_0, align 4 %gep_4 = getelementptr i8, ptr addrspace(7) %p, i64 4 %ld_4 = load i32, ptr addrspace(7) %gep_4, align 4 ret void } ; The test checks that strict OOB mode (relaxed-buffer-oob-mode not set) allows merging loads if the target load is naturally aligned. define amdgpu_kernel void @merge_align_16(ptr addrspace(7) captures(none) %p) #0 { ; OOB-STRICT-LABEL: define amdgpu_kernel void @merge_align_16( ; OOB-STRICT-SAME: ptr addrspace(7) captures(none) [[P:%.*]]) { ; OOB-STRICT-NEXT: [[ENTRY:.*:]] ; OOB-STRICT-NEXT: [[GEP_M8:%.*]] = getelementptr i8, ptr addrspace(7) [[P]], i32 -8 ; OOB-STRICT-NEXT: [[TMP0:%.*]] = load <4 x i32>, ptr addrspace(7) [[GEP_M8]], align 16 ; OOB-STRICT-NEXT: [[LD_M81:%.*]] = extractelement <4 x i32> [[TMP0]], i32 0 ; OOB-STRICT-NEXT: [[LD_M42:%.*]] = extractelement <4 x i32> [[TMP0]], i32 1 ; OOB-STRICT-NEXT: [[LD_03:%.*]] = extractelement <4 x i32> [[TMP0]], i32 2 ; OOB-STRICT-NEXT: [[LD_44:%.*]] = extractelement <4 x i32> [[TMP0]], i32 3 ; OOB-STRICT-NEXT: ret void ; ; OOB-RELAXED-LABEL: define amdgpu_kernel void @merge_align_16( ; OOB-RELAXED-SAME: ptr addrspace(7) captures(none) [[P:%.*]]) #[[ATTR0]] { ; OOB-RELAXED-NEXT: [[ENTRY:.*:]] ; OOB-RELAXED-NEXT: [[GEP_M8:%.*]] = getelementptr i8, ptr addrspace(7) [[P]], i32 -8 ; OOB-RELAXED-NEXT: [[TMP0:%.*]] = load <4 x i32>, ptr addrspace(7) [[GEP_M8]], align 16 ; OOB-RELAXED-NEXT: [[LD_M81:%.*]] = extractelement <4 x i32> [[TMP0]], i32 0 ; OOB-RELAXED-NEXT: [[LD_M42:%.*]] = extractelement <4 x i32> [[TMP0]], i32 1 ; OOB-RELAXED-NEXT: [[LD_03:%.*]] = extractelement <4 x i32> [[TMP0]], i32 2 ; OOB-RELAXED-NEXT: [[LD_44:%.*]] = extractelement <4 x i32> [[TMP0]], i32 3 ; OOB-RELAXED-NEXT: ret void ; entry: %gep_m8 = getelementptr i8, ptr addrspace(7) %p, i32 -8 %ld_m8 = load i32, ptr addrspace(7) %gep_m8, align 16 %gep_m4 = getelementptr i8, ptr addrspace(7) %p, i32 -4 %ld_m4 = load i32, ptr addrspace(7) %gep_m4, align 4 %gep_0 = getelementptr i8, ptr addrspace(7) %p, i32 0 %ld_0 = load i32, ptr addrspace(7) %gep_0, align 8 %gep_4 = getelementptr i8, ptr addrspace(7) %p, i64 4 %ld_4 = load i32, ptr addrspace(7) %gep_4, align 4 ret void }