From 75f598d216bbdb43b473c72953442a8e5a8d2672 Mon Sep 17 00:00:00 2001 From: "Duncan P. N. Exon Smith" Date: Sat, 28 Feb 2015 22:20:16 +0000 Subject: [PATCH] AsmWriter: Escape string fields in metadata Properly escape string fields in metadata. I've added a spot-check with direct coverage for `MDFile::getFilename()`, but we'll get more coverage once the hierarchy is moved into place (since this comes up in various checked-in testcases). I've replicated the `if` logic using the `ShouldSkipEmpty` flag (although a follow-up commit is going to change how often this flag is specified); no NFCI other than escaping the string fields. llvm-svn: 230875 --- lib/IR/AsmWriter.cpp | 58 +++++++++++--------------- test/Assembler/mdfile-escaped-chars.ll | 9 ++++ 2 files changed, 33 insertions(+), 34 deletions(-) create mode 100644 test/Assembler/mdfile-escaped-chars.ll diff --git a/lib/IR/AsmWriter.cpp b/lib/IR/AsmWriter.cpp index 05aa3c5c6d9..f7664f356a2 100644 --- a/lib/IR/AsmWriter.cpp +++ b/lib/IR/AsmWriter.cpp @@ -1369,7 +1369,7 @@ static void writeMDEnumerator(raw_ostream &Out, const MDEnumerator *N, TypePrinting *, SlotTracker *, const Module *) { Out << "!MDEnumerator("; FieldSeparator FS; - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName(), /* ShouldSkipEmpty */ false); Out << FS << "value: " << N->getValue(); Out << ")"; } @@ -1379,8 +1379,7 @@ static void writeMDBasicType(raw_ostream &Out, const MDBasicType *N, Out << "!MDBasicType("; FieldSeparator FS; writeTag(Out, FS, N); - if (!N->getName().empty()) - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName()); if (N->getSizeInBits()) Out << FS << "size: " << N->getSizeInBits(); if (N->getAlignInBits()) @@ -1415,8 +1414,7 @@ static void writeMDDerivedType(raw_ostream &Out, const MDDerivedType *N, Out << "!MDDerivedType("; FieldSeparator FS; writeTag(Out, FS, N); - if (!N->getName().empty()) - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName()); if (N->getFile()) { Out << FS << "file: "; writeMetadataAsOperand(Out, N->getFile(), TypePrinter, Machine, @@ -1454,8 +1452,7 @@ static void writeMDCompositeType(raw_ostream &Out, const MDCompositeType *N, Out << "!MDCompositeType("; FieldSeparator FS; writeTag(Out, FS, N); - if (!N->getName().empty()) - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName()); if (N->getFile()) { Out << FS << "file: "; writeMetadataAsOperand(Out, N->getFile(), TypePrinter, Machine, @@ -1505,8 +1502,7 @@ static void writeMDCompositeType(raw_ostream &Out, const MDCompositeType *N, writeMetadataAsOperand(Out, N->getTemplateParams(), TypePrinter, Machine, Context); } - if (!N->getIdentifier().empty()) - Out << FS << "identifier: \"" << N->getIdentifier() << "\""; + writeStringField(Out, FS, "identifier", N->getIdentifier()); Out << ")"; } @@ -1528,8 +1524,10 @@ static void writeMDFile(raw_ostream &Out, const MDFile *N, TypePrinting *, SlotTracker *, const Module *) { Out << "!MDFile("; FieldSeparator FS; - Out << FS << "filename: \"" << N->getFilename() << "\""; - Out << FS << "directory: \"" << N->getDirectory() << "\""; + writeStringField(Out, FS, "filename", N->getFilename(), + /* ShouldSkipEmpty */ false); + writeStringField(Out, FS, "directory", N->getDirectory(), + /* ShouldSkipEmpty */ false); Out << ")"; } @@ -1545,14 +1543,11 @@ static void writeMDCompileUnit(raw_ostream &Out, const MDCompileUnit *N, Out << N->getSourceLanguage(); Out << FS << "file: "; writeMetadataAsOperand(Out, N->getFile(), TypePrinter, Machine, Context); - if (!N->getProducer().empty()) - Out << FS << "producer: \"" << N->getProducer() << "\""; + writeStringField(Out, FS, "producer", N->getProducer()); Out << FS << "isOptimized: " << (N->isOptimized() ? "true" : "false"); - if (!N->getFlags().empty()) - Out << FS << "flags: \"" << N->getFlags() << "\""; + writeStringField(Out, FS, "flags", N->getFlags()); Out << FS << "runtimeVersion: " << N->getRuntimeVersion(); - if (!N->getSplitDebugFilename().empty()) - Out << FS << "splitDebugFilename: \"" << N->getSplitDebugFilename() << "\""; + writeStringField(Out, FS, "splitDebugFilename", N->getSplitDebugFilename()); Out << FS << "emissionKind: " << N->getEmissionKind(); if (N->getEnumTypes()) { Out << FS << "enums: "; @@ -1589,9 +1584,8 @@ static void writeMDSubprogram(raw_ostream &Out, const MDSubprogram *N, FieldSeparator FS; Out << FS << "scope: "; writeMetadataAsOperand(Out, N->getScope(), TypePrinter, Machine, Context); - Out << FS << "name: \"" << N->getName() << "\""; - if (!N->getLinkageName().empty()) - Out << FS << "linkageName: \"" << N->getLinkageName() << "\""; + writeStringField(Out, FS, "name", N->getName(), /* ShouldSkipEmpty */ false); + writeStringField(Out, FS, "linkageName", N->getLinkageName()); if (N->getFile()) { Out << FS << "file: "; writeMetadataAsOperand(Out, N->getFile(), TypePrinter, Machine, @@ -1698,8 +1692,7 @@ static void writeMDNamespace(raw_ostream &Out, const MDNamespace *N, Out << FS << "file: "; writeMetadataAsOperand(Out, N->getFile(), TypePrinter, Machine, Context); } - if (!N->getName().empty()) - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName()); if (N->getLine()) Out << FS << "line: " << N->getLine(); Out << ")"; @@ -1712,7 +1705,7 @@ static void writeMDTemplateTypeParameter(raw_ostream &Out, const Module *Context) { Out << "!MDTemplateTypeParameter("; FieldSeparator FS; - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName(), /* ShouldSkipEmpty */ false); Out << FS << "type: "; writeMetadataAsOperand(Out, N->getType(), TypePrinter, Machine, Context); Out << ")"; @@ -1726,7 +1719,7 @@ static void writeMDTemplateValueParameter(raw_ostream &Out, Out << "!MDTemplateValueParameter("; FieldSeparator FS; writeTag(Out, FS, N); - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName(), /* ShouldSkipEmpty */ false); Out << FS << "type: "; writeMetadataAsOperand(Out, N->getType(), TypePrinter, Machine, Context); Out << FS << "value: "; @@ -1741,9 +1734,8 @@ static void writeMDGlobalVariable(raw_ostream &Out, const MDGlobalVariable *N, FieldSeparator FS; Out << FS << "scope: "; writeMetadataAsOperand(Out, N->getScope(), TypePrinter, Machine, Context); - Out << FS << "name: \"" << N->getName() << "\""; - if (!N->getLinkageName().empty()) - Out << FS << "linkageName: \"" << N->getLinkageName() << "\""; + writeStringField(Out, FS, "name", N->getName(), /* ShouldSkipEmpty */ false); + writeStringField(Out, FS, "linkageName", N->getLinkageName()); if (N->getFile()) { Out << FS << "file: "; writeMetadataAsOperand(Out, N->getFile(), TypePrinter, Machine, @@ -1779,7 +1771,7 @@ static void writeMDLocalVariable(raw_ostream &Out, const MDLocalVariable *N, writeTag(Out, FS, N); Out << FS << "scope: "; writeMetadataAsOperand(Out, N->getScope(), TypePrinter, Machine, Context); - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName(), /* ShouldSkipEmpty */ false); if (N->getFile()) { Out << FS << "file: "; writeMetadataAsOperand(Out, N->getFile(), TypePrinter, Machine, @@ -1832,17 +1824,15 @@ static void writeMDObjCProperty(raw_ostream &Out, const MDObjCProperty *N, const Module *Context) { Out << "!MDObjCProperty("; FieldSeparator FS; - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName(), /* ShouldSkipEmpty */ false); if (N->getFile()) { Out << FS << "file: "; writeMetadataAsOperand(Out, N->getFile(), TypePrinter, Machine, Context); } if (N->getLine()) Out << FS << "line: " << N->getLine(); - if (!N->getSetterName().empty()) - Out << FS << "setter: \"" << N->getSetterName() << "\""; - if (!N->getGetterName().empty()) - Out << FS << "getter: \"" << N->getGetterName() << "\""; + writeStringField(Out, FS, "setter", N->getSetterName()); + writeStringField(Out, FS, "getter", N->getGetterName()); if (N->getAttributes()) Out << FS << "attributes: " << N->getAttributes(); if (N->getType()) { @@ -1866,7 +1856,7 @@ static void writeMDImportedEntity(raw_ostream &Out, const MDImportedEntity *N, } if (N->getLine()) Out << FS << "line: " << N->getLine(); - Out << FS << "name: \"" << N->getName() << "\""; + writeStringField(Out, FS, "name", N->getName(), /* ShouldSkipEmpty */ false); Out << ")"; } diff --git a/test/Assembler/mdfile-escaped-chars.ll b/test/Assembler/mdfile-escaped-chars.ll new file mode 100644 index 00000000000..5dfd12caf9c --- /dev/null +++ b/test/Assembler/mdfile-escaped-chars.ll @@ -0,0 +1,9 @@ +; RUN: llvm-as < %s | llvm-dis | llvm-as | llvm-dis | FileCheck %s +; RUN: verify-uselistorder %s + +; Spot-check that metadata string fields are correctly escaped. + +!named = !{!0} + +; CHECK: !0 = !MDFile(filename: "\00\01\02\80\81\82\FD\FE\FF", directory: "/dir") +!0 = !MDFile(filename: "\00\01\02\80\81\82\FD\FE\FF", directory: "/dir")