mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-04 05:17:07 +00:00 
			
		
		
		
	Finish off PR23080 by renaming the debug info IR constructs from `MD*` to `DI*`. The last of the `DIDescriptor` classes were deleted in r235356, and the last of the related typedefs removed in r235413, so this has all baked for about a week. Note: If you have out-of-tree code (like a frontend), I recommend that you get everything compiling and tests passing with the *previous* commit before updating to this one. It'll be easier to keep track of what code is using the `DIDescriptor` hierarchy and what you've already updated, and I think you're extremely unlikely to insert bugs. YMMV of course. Back to *this* commit: I did this using the rename-md-di-nodes.sh upgrade script I've attached to PR23080 (both code and testcases) and filtered through clang-format-diff.py. I edited the tests for test/Assembler/invalid-generic-debug-node-*.ll by hand since the columns were off-by-three. It should work on your out-of-tree testcases (and code, if you've followed the advice in the previous paragraph). Some of the tests are in badly named files now (e.g., test/Assembler/invalid-mdcompositetype-missing-tag.ll should be 'dicompositetype'); I'll come back and move the files in a follow-up commit. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@236120 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			28 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
; RUN: llc -filetype=asm < %s | FileCheck %s
 | 
						|
target triple = "thumbv7-apple-ios7.0.0"
 | 
						|
%class.Matrix3.0.6.10 = type { [9 x float] }
 | 
						|
define arm_aapcscc void @_Z9GetMatrixv(%class.Matrix3.0.6.10* noalias nocapture sret %agg.result) #0 {
 | 
						|
  br i1 fcmp oeq (float fadd (float fadd (float fmul (float undef, float undef), float fmul (float undef, float undef)), float fmul (float undef, float undef)), float 0.000000e+00), label %_ZN7Vector39NormalizeEv.exit, label %1
 | 
						|
  tail call arm_aapcscc void @_ZL4Sqrtd() #3
 | 
						|
  br label %_ZN7Vector39NormalizeEv.exit
 | 
						|
_ZN7Vector39NormalizeEv.exit:                     ; preds = %1, %0
 | 
						|
  ; rdar://problem/15094721.
 | 
						|
  ;
 | 
						|
  ; When this (partially) dead use gets eliminated (and thus the def
 | 
						|
  ; of the vreg holding %agg.result) the dbg_value becomes dangling
 | 
						|
  ; and SelectionDAGISel crashes.  It should definitely not
 | 
						|
  ; crash. Drop the dbg_value instead.
 | 
						|
  ; CHECK-NOT: "matrix"
 | 
						|
  tail call void @llvm.dbg.declare(metadata %class.Matrix3.0.6.10* %agg.result, metadata !45, metadata !DIExpression(DW_OP_deref))
 | 
						|
  %2 = getelementptr inbounds %class.Matrix3.0.6.10, %class.Matrix3.0.6.10* %agg.result, i32 0, i32 0, i32 8
 | 
						|
  ret void
 | 
						|
}
 | 
						|
declare void @llvm.dbg.declare(metadata, metadata, metadata) #1
 | 
						|
declare arm_aapcscc void @_ZL4Sqrtd() #2
 | 
						|
!4 = !DICompositeType(tag: DW_TAG_class_type, name: "Matrix3", line: 20, size: 288, align: 32, file: !5, identifier: "_ZTS7Matrix3")
 | 
						|
!5 = !DIFile(filename: "test.ii", directory: "/Volumes/Data/radar/15094721")
 | 
						|
!39 = !DISubprogram(name: "GetMatrix", linkageName: "_Z9GetMatrixv", line: 32, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: true, scopeLine: 32, file: !5, scope: !40, type: !41, function: void (%class.Matrix3.0.6.10*)* @_Z9GetMatrixv)
 | 
						|
!40 = !DIFile(filename: "test.ii", directory: "/Volumes/Data/radar/15094721")
 | 
						|
!41 = !DISubroutineType(types: null)
 | 
						|
!45 = !DILocalVariable(tag: DW_TAG_auto_variable, name: "matrix", line: 35, scope: !39, file: !40, type: !4)
 |