Author: adrian Date: Wed Apr 27 12:06:22 2016 New Revision: 267740 URL: http://llvm.org/viewvc/llvm-project?rev=267740&view=rev Log: Module debugging: Fix the DWO filename for PCH in a relative path. PCH in a relative location had a redundant relative path on the DWO filename and the DW_AT_compilation_dir. This patch fixes this and adds testcases for PCH in the same directory, in a relative, and an absolute location.
rdar://problem/25537947 Added: cfe/trunk/test/PCH/debug-info-pch-path.c Modified: cfe/trunk/lib/Serialization/ASTReader.cpp Modified: cfe/trunk/lib/Serialization/ASTReader.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Serialization/ASTReader.cpp?rev=267740&r1=267739&r2=267740&view=diff ============================================================================== --- cfe/trunk/lib/Serialization/ASTReader.cpp (original) +++ cfe/trunk/lib/Serialization/ASTReader.cpp Wed Apr 27 12:06:22 2016 @@ -7566,8 +7566,9 @@ ASTReader::getSourceDescriptor(unsigned if (ModuleMgr.size() == 1) { ModuleFile &MF = ModuleMgr.getPrimaryModule(); StringRef ModuleName = llvm::sys::path::filename(MF.OriginalSourceFileName); - return ASTReader::ASTSourceDescriptor(ModuleName, MF.OriginalDir, - MF.FileName, MF.Signature); + StringRef FileName = llvm::sys::path::filename(MF.FileName); + return ASTReader::ASTSourceDescriptor(ModuleName, MF.OriginalDir, FileName, + MF.Signature); } return None; } Added: cfe/trunk/test/PCH/debug-info-pch-path.c URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/PCH/debug-info-pch-path.c?rev=267740&view=auto ============================================================================== --- cfe/trunk/test/PCH/debug-info-pch-path.c (added) +++ cfe/trunk/test/PCH/debug-info-pch-path.c Wed Apr 27 12:06:22 2016 @@ -0,0 +1,76 @@ +// REQUIRES: shell +// +// RUN: rm -rf %t +// RUN: mkdir %t +// RUN: cd %t +// +// --------------------------------------------------------------------- +// Relative PCH, same directory. +// --------------------------------------------------------------------- +// +// RUN: %clang_cc1 -fmodule-format=obj -emit-pch \ +// RUN: -triple %itanium_abi_triple \ +// RUN: -o prefix.pch %S/debug-info-limited-struct.h +// +// RUN: %clang_cc1 -debug-info-kind=standalone \ +// RUN: -dwarf-ext-refs -fmodule-format=obj \ +// RUN: -triple %itanium_abi_triple \ +// RUN: -include-pch prefix.pch %s -emit-llvm -o %t.nodir.ll %s +// RUN: cat %t.nodir.ll | FileCheck %s --check-prefix=CHECK-REL-NODIR +// +// +// CHECK-REL-NODIR: !DICompileUnit +// CHECK-REL-NODIR-SAME: file: ![[C:[0-9]+]] +// CHECK-REL-NODIR-NOT: dwoId +// CHECK-REL-NODIR: ![[C]] = !DIFile({{.*}}directory: "[[DIR:.*]]" +// CHECK-REL-NODIR: !DICompileUnit( +// CHECK-REL-NODIR-SAME: file: ![[PCH:[0-9]+]] +// CHECK-REL-NODIR-SAME: splitDebugFilename: "prefix.pch" +// CHECK-REL-NODIR: ![[PCH]] = !DIFile({{.*}}directory: "[[DIR]]" + +// --------------------------------------------------------------------- +// Relative PCH in a subdirectory. +// --------------------------------------------------------------------- +// +// RUN: mkdir pchdir +// RUN: %clang_cc1 -fmodule-format=obj -emit-pch \ +// RUN: -triple %itanium_abi_triple \ +// RUN: -o pchdir/prefix.pch %S/debug-info-limited-struct.h +// +// RUN: %clang_cc1 -debug-info-kind=standalone \ +// RUN: -dwarf-ext-refs -fmodule-format=obj \ +// RUN: -triple %itanium_abi_triple \ +// RUN: -include-pch pchdir/prefix.pch %s -emit-llvm -o %t.rel.ll %s +// RUN: cat %t.rel.ll | FileCheck %s --check-prefix=CHECK-REL + +// CHECK-REL: !DICompileUnit +// CHECK-REL-SAME: file: ![[C:[0-9]+]] +// CHECK-REL-NOT: dwoId +// CHECK-REL: ![[C]] = !DIFile({{.*}}directory: "[[DIR:.*]]" +// CHECK-REL: !DICompileUnit( +// CHECK-REL-SAME: file: ![[PCH:[0-9]+]] +// CHECK-REL-SAME: splitDebugFilename: "prefix.pch" +// CHECK-REL: ![[PCH]] = !DIFile({{.*}}directory: "[[DIR]]{{.*}}pchdir" + +// --------------------------------------------------------------------- +// Absolute PCH. +// --------------------------------------------------------------------- +// +// RUN: %clang_cc1 -fmodule-format=obj -emit-pch \ +// RUN: -triple %itanium_abi_triple \ +// RUN: -o %t/prefix.pch %S/debug-info-limited-struct.h +// +// RUN: %clang_cc1 -debug-info-kind=standalone \ +// RUN: -dwarf-ext-refs -fmodule-format=obj \ +// RUN: -triple %itanium_abi_triple \ +// RUN: -include-pch %t/prefix.pch %s -emit-llvm -o %t.abs.ll %s +// RUN: cat %t.abs.ll | FileCheck %s --check-prefix=CHECK-ABS + +// CHECK-ABS: !DICompileUnit +// CHECK-ABS-SAME: file: ![[C:[0-9]+]] +// CHECK-ABS-NOT: dwoId +// CHECK-ABS: ![[C]] = !DIFile({{.*}}directory: "[[DIR:.*]]" +// CHECK-ABS: !DICompileUnit( +// CHECK-ABS-SAME: file: ![[PCH:[0-9]+]] +// CHECK-ABS-SAME: splitDebugFilename: "prefix.pch" +// CHECK-ABS: ![[PCH]] = !DIFile({{.*}}directory: "[[DIR]]" _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits