[PATCH] D20002: Fix Bug 11740: Turn off -g when there are directive file debug info
Zhizhou Yang via llvm-commits
llvm-commits at lists.llvm.org
Fri May 20 13:21:09 PDT 2016
zhizhouy updated this revision to Diff 57978.
zhizhouy added a comment.
Updated the test file, removed the useless test command,
and added some description about the test case.
http://reviews.llvm.org/D20002
Files:
lib/MC/MCParser/AsmParser.cpp
test/MC/AsmParser/directive_file-2.s
test/MC/AsmParser/directive_file-errors.s
Index: test/MC/AsmParser/directive_file-errors.s
===================================================================
--- test/MC/AsmParser/directive_file-errors.s
+++ test/MC/AsmParser/directive_file-errors.s
@@ -1,9 +0,0 @@
-// RUN: not llvm-mc -g -triple i386-unknown-unknown %s 2> %t.err | FileCheck %s
-// RUN: FileCheck --check-prefix=CHECK-ERRORS %s < %t.err
-// Test for Bug 11740
-
- .file "hello"
- .file 1 "world"
-
-// CHECK: .file "hello"
-// CHECK-ERRORS:6:9: error: input can't have .file dwarf directives when -g is used to generate dwarf debug info for assembly code
Index: test/MC/AsmParser/directive_file-2.s
===================================================================
--- test/MC/AsmParser/directive_file-2.s
+++ test/MC/AsmParser/directive_file-2.s
@@ -0,0 +1,11 @@
+# RUN: llvm-mc -triple i386-unknown-unknown %s | FileCheck %s
+// Test for Bug 11740
+// This testcase has two directive files,
+// when compiled with -g, this testcase will not report error,
+// but keep the debug info existing in the assembly file.
+
+ .file "hello"
+ .file 1 "world"
+
+// CHECK: .file "hello"
+// CHECK: .file 1 "world"
Index: lib/MC/MCParser/AsmParser.cpp
===================================================================
--- lib/MC/MCParser/AsmParser.cpp
+++ lib/MC/MCParser/AsmParser.cpp
@@ -3001,12 +3001,11 @@
if (FileNumber == -1)
getStreamer().EmitFileDirective(Filename);
else {
+ // If there is -g option as well as debug info from directive file,
+ // we turn off -g option, directly use the existing debug info instead.
if (getContext().getGenDwarfForAssembly())
- Error(DirectiveLoc,
- "input can't have .file dwarf directives when -g is "
- "used to generate dwarf debug info for assembly code");
-
- if (getStreamer().EmitDwarfFileDirective(FileNumber, Directory, Filename) ==
+ getContext().setGenDwarfForAssembly(false);
+ else if (getStreamer().EmitDwarfFileDirective(FileNumber, Directory, Filename) ==
0)
Error(FileNumberLoc, "file number already allocated");
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D20002.57978.patch
Type: text/x-patch
Size: 2106 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160520/5e4642e1/attachment.bin>
More information about the llvm-commits
mailing list