[llvm] 750a687 - [Codeview] Fix incorrect size determination for complex types.

Steve Merritt via llvm-commits llvm-commits at lists.llvm.org
Fri Feb 24 06:32:14 PST 2023


Author: Steve Merritt
Date: 2023-02-24T09:20:52-05:00
New Revision: 750a6870eb41922f7013c163b458a02d5aa8994b

URL: https://github.com/llvm/llvm-project/commit/750a6870eb41922f7013c163b458a02d5aa8994b
DIFF: https://github.com/llvm/llvm-project/commit/750a6870eb41922f7013c163b458a02d5aa8994b.diff

LOG: [Codeview] Fix incorrect size determination for complex types.

In Codeview, the basic type of a complex represents the size
of an individual component rather than the sum of the real
and imaginary components.

Differential Revision: https://reviews.llvm.org/D143760

Added: 
    

Modified: 
    llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp
    llvm/lib/DebugInfo/CodeView/TypeRecordHelpers.cpp
    llvm/test/DebugInfo/COFF/fortran-basic.ll

Removed: 
    


################################################################################
diff  --git a/llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp b/llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp
index 824a57dcf1ef1..5542c560a490c 100644
--- a/llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp
+++ b/llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp
@@ -1793,12 +1793,14 @@ TypeIndex CodeViewDebug::lowerTypeBasic(const DIBasicType *Ty) {
     }
     break;
   case dwarf::DW_ATE_complex_float:
+    // The CodeView size for a complex represents the size of
+    // an individual component.
     switch (ByteSize) {
-    case 2:  STK = SimpleTypeKind::Complex16;  break;
-    case 4:  STK = SimpleTypeKind::Complex32;  break;
-    case 8:  STK = SimpleTypeKind::Complex64;  break;
-    case 10: STK = SimpleTypeKind::Complex80;  break;
-    case 16: STK = SimpleTypeKind::Complex128; break;
+    case 4:  STK = SimpleTypeKind::Complex16;  break;
+    case 8:  STK = SimpleTypeKind::Complex32;  break;
+    case 16: STK = SimpleTypeKind::Complex64;  break;
+    case 20: STK = SimpleTypeKind::Complex80;  break;
+    case 32: STK = SimpleTypeKind::Complex128; break;
     }
     break;
   case dwarf::DW_ATE_float:

diff  --git a/llvm/lib/DebugInfo/CodeView/TypeRecordHelpers.cpp b/llvm/lib/DebugInfo/CodeView/TypeRecordHelpers.cpp
index e44dec6d63966..046b660abfab9 100644
--- a/llvm/lib/DebugInfo/CodeView/TypeRecordHelpers.cpp
+++ b/llvm/lib/DebugInfo/CodeView/TypeRecordHelpers.cpp
@@ -144,15 +144,15 @@ uint64_t llvm::codeview::getSizeInBytesForTypeIndex(TypeIndex TI) {
 
   // Complex float.
   case SimpleTypeKind::Complex16:
-    return 2;
-  case SimpleTypeKind::Complex32:
     return 4;
-  case SimpleTypeKind::Complex64:
+  case SimpleTypeKind::Complex32:
     return 8;
+  case SimpleTypeKind::Complex64:
+    return 16;
   case SimpleTypeKind::Complex80:
-    return 10;
+    return 20;
   case SimpleTypeKind::Complex128:
-    return 16;
+    return 32;
 
   default:
     return 0;

diff  --git a/llvm/test/DebugInfo/COFF/fortran-basic.ll b/llvm/test/DebugInfo/COFF/fortran-basic.ll
index f4732e9b103f9..1a44235553820 100644
--- a/llvm/test/DebugInfo/COFF/fortran-basic.ll
+++ b/llvm/test/DebugInfo/COFF/fortran-basic.ll
@@ -8,6 +8,9 @@
 ;         double precision d
 ;         logical l
 ;         character*6 c
+;         complex*8 cmp8
+;         complex*16 cmp16
+;         complex*32 cmp32
 ;
 ;         common /com/ d, l, c
 ;
@@ -16,6 +19,9 @@
 ;         d = 8.0
 ;         l = .TRUE.
 ;         c = 'oooooo'
+;         cmp8 = (8.8, 1.1)
+;         cmp16 = (16.16, 2.2)
+;         cmp32 = (32.32, 3.3)
 ;	end
 ;
 ; CHECK: Array ([[array2_t:.*]]) {
@@ -37,6 +43,21 @@
 ; CHECK-NEXT: SizeOf: 6
 ; CHECK-NEXT: CHARACTER_0
 ;
+; CHECK:      Type: _Complex __float128 (0x53)
+; CHECK-NEXT: Flags [
+; CHECK-NEXT: ]
+; CHECK-NEXT: VarName: CMP32
+;
+; CHECK:      Type: _Complex double (0x51)
+; CHECK-NEXT: Flags [
+; CHECK-NEXT: ]
+; CHECK-NEXT: VarName: CMP16
+;
+; CHECK:      Type: _Complex float (0x50)
+; CHECK-NEXT: Flags [
+; CHECK-NEXT: ]
+; CHECK-NEXT: VarName: CMP8
+;
 ; CHECK: DataOffset: ARRAY$ARRAY2+0x0
 ; CHECK-NEXT: Type: [[array2_t]]
 ; CHECK-NEXT: DisplayName: ARRAY2
@@ -67,6 +88,10 @@ source_filename = "fortran-basic.f"
 target datalayout = "e-m:w-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
 target triple = "x86_64-pc-windows-msvc"
 
+%complex_256bit = type { fp128, fp128 }
+%complex_128bit = type { double, double }
+%complex_64bit = type { float, float }
+
 @strlit = internal unnamed_addr constant [6 x i8] c"oooooo"
 @COM = common unnamed_addr global [18 x i8] zeroinitializer, align 32, !dbg !0, !dbg !9, !dbg !12
 @"ARRAY$ARRAY2" = internal global [8 x i32] zeroinitializer, align 16, !dbg !15
@@ -77,14 +102,23 @@ target triple = "x86_64-pc-windows-msvc"
 define void @MAIN__() #0 !dbg !3 {
 alloca_0:
   %"$io_ctx" = alloca [6 x i64], align 8
+  %"ARRAY$CMP32" = alloca %complex_256bit, align 16
+  %"ARRAY$CMP16" = alloca %complex_128bit, align 8, !dbg !42
+  %"ARRAY$CMP8" = alloca %complex_64bit, align 8, !dbg !42
+  call void @llvm.dbg.declare(metadata ptr %"ARRAY$CMP32", metadata !27, metadata !DIExpression()), !dbg !42
+  call void @llvm.dbg.declare(metadata ptr %"ARRAY$CMP16", metadata !29, metadata !DIExpression()), !dbg !41
+  call void @llvm.dbg.declare(metadata ptr %"ARRAY$CMP8", metadata !31, metadata !DIExpression()), !dbg !40
   %strlit_fetch.1 = load [6 x i8], ptr @strlit, align 1, !dbg !39
   %func_result = call i32 @for_set_reentrancy(ptr @0), !dbg !39
-  store i32 1, ptr @"ARRAY$ARRAY1", align 1, !dbg !40
-  store i32 2, ptr @"ARRAY$ARRAY2", align 1, !dbg !41
-  store double 8.000000e+00, ptr @COM, align 1, !dbg !42
-  store i32 -1, ptr getelementptr inbounds ([18 x i8], ptr @COM, i32 0, i64 8), align 1, !dbg !43
-  call void @llvm.for.cpystr.i64.i64.i64(ptr getelementptr inbounds ([18 x i8], ptr @COM, i32 0, i64 12), i64 6, ptr @strlit, i64 3, i64 0, i1 false), !dbg !44
-  ret void, !dbg !45
+  store i32 1, ptr @"ARRAY$ARRAY1", align 1, !dbg !43
+  store i32 2, ptr @"ARRAY$ARRAY2", align 1, !dbg !44
+  store double 8.000000e+00, ptr @COM, align 1, !dbg !45
+  store i32 -1, ptr getelementptr inbounds ([18 x i8], ptr @COM, i32 0, i64 8), align 1, !dbg !46
+  call void @llvm.for.cpystr.i64.i64.i64(ptr getelementptr inbounds ([18 x i8], ptr @COM, i32 0, i64 12), i64 6, ptr @strlit, i64 3, i64 0, i1 false), !dbg !47
+  store %complex_64bit { float 0x40219999A0000000, float 0x3FF19999A0000000 }, ptr %"ARRAY$CMP8", align 8, !dbg !48
+  store %complex_128bit { double 0x403028F5C0000000, double 0x40019999A0000000 }, ptr %"ARRAY$CMP16", align 8, !dbg !49
+  store %complex_256bit { fp128 0xL00000000000000004004028F5C000000, fp128 0xL00000000000000004000A66666000000 }, ptr %"ARRAY$CMP32", align 16, !dbg !50
+  ret void, !dbg !51
 }
 
 declare i32 @for_set_reentrancy(ptr nocapture readonly)
@@ -95,22 +129,26 @@ declare ptr @llvm.intel.subscript.p0.i64.i64.p0.i64(i8, i64, i64, ptr, i64) #1
 ; Function Attrs: argmemonly nofree nosync nounwind willreturn
 declare void @llvm.for.cpystr.i64.i64.i64(ptr noalias nocapture writeonly, i64, ptr noalias nocapture readonly, i64, i64, i1 immarg) #2
 
+; Function Attrs: nocallback nofree nosync nounwind readnone speculatable willreturn
+declare void @llvm.dbg.declare(metadata, metadata, metadata) #3
+
 attributes #0 = { noinline nounwind optnone uwtable "frame-pointer"="none" "intel-lang"="fortran" "min-legal-vector-width"="0" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" }
 attributes #1 = { nounwind readnone speculatable }
 attributes #2 = { argmemonly nofree nosync nounwind willreturn }
+attributes #3 = { nocallback nofree nosync nounwind readnone speculatable willreturn }
 
-!llvm.module.flags = !{!28, !29, !30}
+!llvm.module.flags = !{!34, !35, !36}
 !llvm.dbg.cu = !{!7}
 !omp_offload.info = !{}
 
 !0 = !DIGlobalVariableExpression(var: !1, expr: !DIExpression())
-!1 = distinct !DIGlobalVariable(name: "D", linkageName: "COM", scope: !2, file: !4, line: 5, type: !27, isLocal: false, isDefinition: true)
+!1 = distinct !DIGlobalVariable(name: "D", linkageName: "COM", scope: !2, file: !4, line: 5, type: !33, isLocal: false, isDefinition: true)
 !2 = !DICommonBlock(scope: !3, declaration: null, name: "COM", file: !4, line: 8)
 !3 = distinct !DISubprogram(name: "ARRAY", linkageName: "MAIN__", scope: !4, file: !4, line: 1, type: !5, scopeLine: 1, spFlags: DISPFlagDefinition | DISPFlagMainSubprogram, unit: !7, retainedNodes: !26)
-!4 = !DIFile(filename: "fortran-basic.f", directory: "d:\\iusers\\cchen15\\examples\\tests\\vsdF-nightly\\vsdF\\opt_none_debug")
+!4 = !DIFile(filename: "fortran-basic.f", directory: "d:\\temp")
 !5 = !DISubroutineType(types: !6)
 !6 = !{null}
-!7 = distinct !DICompileUnit(language: DW_LANG_Fortran95, file: !4, producer: "Intel(R) Fortran 22.0-1034", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, globals: !8, splitDebugInlining: false, nameTableKind: None)
+!7 = distinct !DICompileUnit(language: DW_LANG_Fortran95, file: !4, producer: "Fortran", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, globals: !8, splitDebugInlining: false, nameTableKind: None)
 !8 = !{!0, !9, !12, !15, !21}
 !9 = !DIGlobalVariableExpression(var: !10, expr: !DIExpression(DW_OP_plus_uconst, 8))
 !10 = distinct !DIGlobalVariable(name: "L", linkageName: "COM", scope: !2, file: !4, line: 6, type: !11, isLocal: false, isDefinition: true)
@@ -129,15 +167,27 @@ attributes #2 = { argmemonly nofree nosync nounwind willreturn }
 !23 = !DICompositeType(tag: DW_TAG_array_type, baseType: !18, elements: !24)
 !24 = !{!25}
 !25 = !DISubrange(count: 10, lowerBound: 1)
-!26 = !{}
-!27 = !DIBasicType(name: "REAL*8", size: 64, encoding: DW_ATE_float)
-!28 = !{i32 7, !"PIC Level", i32 2}
-!29 = !{i32 2, !"Debug Info Version", i32 3}
-!30 = !{i32 2, !"CodeView", i32 1}
+!26 = !{!27, !29, !31}
+!27 = !DILocalVariable(name: "CMP32", scope: !3, file: !4, line: 10, type: !28)
+!28 = !DIBasicType(name: "COMPLEX*32", size: 256, encoding: DW_ATE_complex_float)
+!29 = !DILocalVariable(name: "CMP16", scope: !3, file: !4, line: 9, type: !30)
+!30 = !DIBasicType(name: "COMPLEX*16", size: 128, encoding: DW_ATE_complex_float)
+!31 = !DILocalVariable(name: "CMP8", scope: !3, file: !4, line: 8, type: !32)
+!32 = !DIBasicType(name: "COMPLEX*8", size: 64, encoding: DW_ATE_complex_float)
+!33 = !DIBasicType(name: "REAL*8", size: 64, encoding: DW_ATE_float)
+!34 = !{i32 7, !"PIC Level", i32 2}
+!35 = !{i32 2, !"Debug Info Version", i32 3}
+!36 = !{i32 2, !"CodeView", i32 1}
 !39 = !DILocation(line: 1, column: 10, scope: !3)
-!40 = !DILocation(line: 9, column: 9, scope: !3)
-!41 = !DILocation(line: 10, column: 9, scope: !3)
-!42 = !DILocation(line: 11, column: 9, scope: !3)
-!43 = !DILocation(line: 12, column: 9, scope: !3)
-!44 = !DILocation(line: 13, column: 9, scope: !3)
-!45 = !DILocation(line: 14, column: 2, scope: !3)
+!40 = !DILocation(line: 8, column: 9, scope: !3)
+!41 = !DILocation(line: 9, column: 9, scope: !3)
+!42 = !DILocation(line: 10, column: 9, scope: !3)
+!43 = !DILocation(line: 14, column: 9, scope: !3)
+!44 = !DILocation(line: 15, column: 9, scope: !3)
+!45 = !DILocation(line: 16, column: 9, scope: !3)
+!46 = !DILocation(line: 17, column: 9, scope: !3)
+!47 = !DILocation(line: 18, column: 9, scope: !3)
+!48 = !DILocation(line: 19, column: 9, scope: !3)
+!49 = !DILocation(line: 20, column: 9, scope: !3)
+!50 = !DILocation(line: 21, column: 9, scope: !3)
+!51 = !DILocation(line: 22, column: 2, scope: !3)


        


More information about the llvm-commits mailing list