[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / LoopIdiom / memcpy-debugify-remarks.ll
blob264f34dd044af3ca76e3cbb078f3c143075fef2a
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -passes=debugify,loop-idiom,verify -pass-remarks=loop-idiom -pass-remarks-analysis=loop-idiom -pass-remarks-output=%t.yaml -verify-each -verify-dom-info -verify-loop-info  < %s -S 2>&1 | FileCheck %s
3 ; RUN: FileCheck --input-file=%t.yaml %s --check-prefixes=YAML
5 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
6 target triple = "x86_64-unknown-linux-gnu"
8 ; Check that everything still works when debuginfo is present, and that it is reasonably propagated.
10 ; CHECK: remark: <stdin>:6:1: Formed a call to llvm.memcpy.p0.p0.i64() intrinsic from load and store instruction in test6_dest_align function{{$}}
12 ; YAML:      --- !Passed
13 ; YAML-NEXT: Pass:            loop-idiom
14 ; YAML-NEXT: Name:            ProcessLoopStoreOfLoopLoad
15 ; YAML-NEXT: DebugLoc:        { File: '<stdin>', Line: 6, Column: 1 }
16 ; YAML-NEXT: Function:        test6_dest_align
17 ; YAML-NEXT: Args:
18 ; YAML-NEXT:   - String:          'Formed a call to '
19 ; YAML-NEXT:   - NewFunction:     llvm.memcpy.p0.p0.i64
20 ; YAML-NEXT:   - String:          '() intrinsic from '
21 ; YAML-NEXT:   - Inst:            load and store
22 ; YAML-NEXT:   - String:          ' instruction in '
23 ; YAML-NEXT:   - Function:        test6_dest_align
24 ; YAML-NEXT:     DebugLoc:        { File: '<stdin>', Line: 1, Column: 0 }
25 ; YAML-NEXT:   - String:          ' function'
26 ; YAML-NEXT:   - FromBlock:       for.body
27 ; YAML-NEXT:   - ToBlock:         bb.nph
28 ; YAML-NEXT: ...
30 define void @test6_dest_align(ptr noalias align 1 %Base, ptr noalias align 4 %Dest, i64 %Size) nounwind ssp {
31 ; CHECK-LABEL: @test6_dest_align(
32 ; CHECK-NEXT:  bb.nph:
33 ; CHECK-NEXT:    [[TMP0:%.*]] = shl nuw i64 [[SIZE:%.*]], 2, !dbg [[DBG18:![0-9]+]]
34 ; CHECK-NEXT:    call void @llvm.memcpy.p0.p0.i64(ptr align 4 [[DEST:%.*]], ptr align 1 [[BASE:%.*]], i64 [[TMP0]], i1 false), !dbg [[DBG19:![0-9]+]]
35 ; CHECK-NEXT:    br label [[FOR_BODY:%.*]], !dbg [[DBG18]]
36 ; CHECK:       for.body:
37 ; CHECK-NEXT:    [[INDVAR:%.*]] = phi i64 [ 0, [[BB_NPH:%.*]] ], [ [[INDVAR_NEXT:%.*]], [[FOR_BODY]] ], !dbg [[DBG20:![0-9]+]]
38 ; CHECK-NEXT:    call void @llvm.dbg.value(metadata i64 [[INDVAR]], metadata [[META9:![0-9]+]], metadata !DIExpression()), !dbg [[DBG20]]
39 ; CHECK-NEXT:    [[I_0_014:%.*]] = getelementptr i32, ptr [[BASE]], i64 [[INDVAR]], !dbg [[DBG21:![0-9]+]]
40 ; CHECK-NEXT:    call void @llvm.dbg.value(metadata ptr [[I_0_014]], metadata [[META11:![0-9]+]], metadata !DIExpression()), !dbg [[DBG21]]
41 ; CHECK-NEXT:    [[DESTI:%.*]] = getelementptr i32, ptr [[DEST]], i64 [[INDVAR]], !dbg [[DBG22:![0-9]+]]
42 ; CHECK-NEXT:    call void @llvm.dbg.value(metadata ptr [[DESTI]], metadata [[META12:![0-9]+]], metadata !DIExpression()), !dbg [[DBG22]]
43 ; CHECK-NEXT:    [[V:%.*]] = load i32, ptr [[I_0_014]], align 1, !dbg [[DBG23:![0-9]+]]
44 ; CHECK-NEXT:    call void @llvm.dbg.value(metadata i32 [[V]], metadata [[META13:![0-9]+]], metadata !DIExpression()), !dbg [[DBG23]]
45 ; CHECK-NEXT:    [[INDVAR_NEXT]] = add i64 [[INDVAR]], 1, !dbg [[DBG24:![0-9]+]]
46 ; CHECK-NEXT:    call void @llvm.dbg.value(metadata i64 [[INDVAR_NEXT]], metadata [[META15:![0-9]+]], metadata !DIExpression()), !dbg [[DBG24]]
47 ; CHECK-NEXT:    [[EXITCOND:%.*]] = icmp eq i64 [[INDVAR_NEXT]], [[SIZE]], !dbg [[DBG25:![0-9]+]]
48 ; CHECK-NEXT:    call void @llvm.dbg.value(metadata i1 [[EXITCOND]], metadata [[META16:![0-9]+]], metadata !DIExpression()), !dbg [[DBG25]]
49 ; CHECK-NEXT:    br i1 [[EXITCOND]], label [[FOR_END:%.*]], label [[FOR_BODY]], !dbg [[DBG26:![0-9]+]]
50 ; CHECK:       for.end:
51 ; CHECK-NEXT:    ret void, !dbg [[DBG27:![0-9]+]]
53 bb.nph:
54   br label %for.body
56 for.body:                                         ; preds = %bb.nph, %for.body
57   %indvar = phi i64 [ 0, %bb.nph ], [ %indvar.next, %for.body ]
58   %I.0.014 = getelementptr i32, ptr %Base, i64 %indvar
59   %DestI = getelementptr i32, ptr %Dest, i64 %indvar
60   %V = load i32, ptr %I.0.014, align 1
61   store i32 %V, ptr %DestI, align 4
62   %indvar.next = add i64 %indvar, 1
63   %exitcond = icmp eq i64 %indvar.next, %Size
64   br i1 %exitcond, label %for.end, label %for.body
66 for.end:                                          ; preds = %for.body, %entry
67   ret void