From 9bc3c4f3735edee75dde444e6c7a7bea5e589ed9 Mon Sep 17 00:00:00 2001 From: Adrian Prantl Date: Wed, 27 Apr 2016 17:06:22 +0000 Subject: [PATCH] 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 llvm-svn: 267740 --- clang/lib/Serialization/ASTReader.cpp | 5 ++- clang/test/PCH/debug-info-pch-path.c | 76 +++++++++++++++++++++++++++++++++++ 2 files changed, 79 insertions(+), 2 deletions(-) create mode 100644 clang/test/PCH/debug-info-pch-path.c diff --git a/clang/lib/Serialization/ASTReader.cpp b/clang/lib/Serialization/ASTReader.cpp index 5cf0eb4..910f5dc 100644 --- a/clang/lib/Serialization/ASTReader.cpp +++ b/clang/lib/Serialization/ASTReader.cpp @@ -7566,8 +7566,9 @@ ASTReader::getSourceDescriptor(unsigned ID) { 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; } diff --git a/clang/test/PCH/debug-info-pch-path.c b/clang/test/PCH/debug-info-pch-path.c new file mode 100644 index 0000000..402d44d --- /dev/null +++ b/clang/test/PCH/debug-info-pch-path.c @@ -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]]" -- 2.7.4