mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-04 05:17:07 +00:00 
			
		
		
		
	Now that `Metadata` is typeless, reflect that in the assembly.  These
are the matching assembly changes for the metadata/value split in
r223802.
  - Only use the `metadata` type when referencing metadata from a call
    intrinsic -- i.e., only when it's used as a `Value`.
  - Stop pretending that `ValueAsMetadata` is wrapped in an `MDNode`
    when referencing it from call intrinsics.
So, assembly like this:
    define @foo(i32 %v) {
      call void @llvm.foo(metadata !{i32 %v}, metadata !0)
      call void @llvm.foo(metadata !{i32 7}, metadata !0)
      call void @llvm.foo(metadata !1, metadata !0)
      call void @llvm.foo(metadata !3, metadata !0)
      call void @llvm.foo(metadata !{metadata !3}, metadata !0)
      ret void, !bar !2
    }
    !0 = metadata !{metadata !2}
    !1 = metadata !{i32* @global}
    !2 = metadata !{metadata !3}
    !3 = metadata !{}
turns into this:
    define @foo(i32 %v) {
      call void @llvm.foo(metadata i32 %v, metadata !0)
      call void @llvm.foo(metadata i32 7, metadata !0)
      call void @llvm.foo(metadata i32* @global, metadata !0)
      call void @llvm.foo(metadata !3, metadata !0)
      call void @llvm.foo(metadata !{!3}, metadata !0)
      ret void, !bar !2
    }
    !0 = !{!2}
    !1 = !{i32* @global}
    !2 = !{!3}
    !3 = !{}
I wrote an upgrade script that handled almost all of the tests in llvm
and many of the tests in cfe (even handling many `CHECK` lines).  I've
attached it (or will attach it in a moment if you're speedy) to PR21532
to help everyone update their out-of-tree testcases.
This is part of PR21532.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@224257 91177308-0d34-0410-b5e6-96231b3b80d8
		
	
		
			
				
	
	
		
			56 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
; RUN: opt < %s -S -inline -inline-threshold=2 | FileCheck %s
 | 
						|
; RUN: opt < %s -S -strip-debug -inline -inline-threshold=2 | FileCheck %s
 | 
						|
;
 | 
						|
; The purpose of this test is to check that debug info doesn't influence
 | 
						|
; inlining decisions.
 | 
						|
 | 
						|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
 | 
						|
target triple = "x86_64-unknown-linux-gnu"
 | 
						|
 | 
						|
declare void @llvm.dbg.declare(metadata, metadata, metadata) #1
 | 
						|
declare void @llvm.dbg.value(metadata, i64, metadata, metadata) #1
 | 
						|
 | 
						|
define <4 x float> @inner_vectors(<4 x float> %a, <4 x float> %b) {
 | 
						|
entry:
 | 
						|
  call void @llvm.dbg.value(metadata !{}, i64 0, metadata !{}, metadata !{})
 | 
						|
  %mul = fmul <4 x float> %a, <float 3.000000e+00, float 3.000000e+00, float 3.000000e+00, float 3.000000e+00>
 | 
						|
  call void @llvm.dbg.value(metadata !{}, i64 0, metadata !{}, metadata !{})
 | 
						|
  %mul1 = fmul <4 x float> %b, <float 5.000000e+00, float 5.000000e+00, float 5.000000e+00, float 5.000000e+00>
 | 
						|
  call void @llvm.dbg.value(metadata !{}, i64 0, metadata !{}, metadata !{})
 | 
						|
  %add = fadd <4 x float> %mul, %mul1
 | 
						|
  ret <4 x float> %add
 | 
						|
}
 | 
						|
 | 
						|
define float @outer_vectors(<4 x float> %a, <4 x float> %b) {
 | 
						|
; CHECK-LABEL: @outer_vectors(
 | 
						|
; CHECK-NOT: call <4 x float> @inner_vectors(
 | 
						|
; CHECK: ret float
 | 
						|
 | 
						|
entry:
 | 
						|
  call void @llvm.dbg.value(metadata !{}, i64 0, metadata !{}, metadata !{})
 | 
						|
  call void @llvm.dbg.value(metadata !{}, i64 0, metadata !{}, metadata !{})
 | 
						|
  %call = call <4 x float> @inner_vectors(<4 x float> %a, <4 x float> %b)
 | 
						|
  call void @llvm.dbg.value(metadata !{}, i64 0, metadata !{}, metadata !{})
 | 
						|
  %vecext = extractelement <4 x float> %call, i32 0
 | 
						|
  %vecext1 = extractelement <4 x float> %call, i32 1
 | 
						|
  %add = fadd float %vecext, %vecext1
 | 
						|
  %vecext2 = extractelement <4 x float> %call, i32 2
 | 
						|
  %add3 = fadd float %add, %vecext2
 | 
						|
  %vecext4 = extractelement <4 x float> %call, i32 3
 | 
						|
  %add5 = fadd float %add3, %vecext4
 | 
						|
  ret float %add5
 | 
						|
}
 | 
						|
 | 
						|
attributes #0 = { nounwind readnone }
 | 
						|
 | 
						|
!llvm.dbg.cu = !{!0}
 | 
						|
!llvm.module.flags = !{!3, !4}
 | 
						|
!llvm.ident = !{!5}
 | 
						|
 | 
						|
!0 = !{!"0x11\004\00\000\00\000\00\000", !1, !2, !2, !{}, !2, !2} ; [ DW_TAG_compile_unit ]
 | 
						|
!1 = !{!"", !""}
 | 
						|
!2 = !{i32 0}
 | 
						|
!3 = !{i32 2, !"Dwarf Version", i32 4}
 | 
						|
!4 = !{i32 1, !"Debug Info Version", i32 2}
 | 
						|
!5 = !{!""}
 |