[llvm-commits] [llvm] r133319 - /llvm/trunk/lib/MC/MCAsmStreamer.cpp

Bill Wendling isanbard at gmail.com
Fri Jun 17 17:19:35 PDT 2011


Author: void
Date: Fri Jun 17 19:19:35 2011
New Revision: 133319

URL: http://llvm.org/viewvc/llvm-project?rev=133319&view=rev
Log:
* Override the "EmitBytes" function, since it can sneak values in that way.
* Make this used only if CFI is used.

Modified:
    llvm/trunk/lib/MC/MCAsmStreamer.cpp

Modified: llvm/trunk/lib/MC/MCAsmStreamer.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCAsmStreamer.cpp?rev=133319&r1=133318&r2=133319&view=diff
==============================================================================
--- llvm/trunk/lib/MC/MCAsmStreamer.cpp (original)
+++ llvm/trunk/lib/MC/MCAsmStreamer.cpp Fri Jun 17 19:19:35 2011
@@ -1342,6 +1342,7 @@
       Assignments.push_back(Value);
     MCAsmStreamer::EmitAssignment(Symbol, Value);
   }
+  virtual void EmitBytes(StringRef Data, unsigned AddrSpace);
   virtual void EmitIntValue(uint64_t Value, unsigned Size,
                             unsigned AddrSpace = 0);
   virtual void EmitValueImpl(const MCExpr *Value, unsigned Size,
@@ -1360,6 +1361,22 @@
 
 } // end anonymous namespace
 
+void MCLSDADecoderAsmStreamer::EmitBytes(StringRef Data, unsigned AddrSpace) {
+  if (InLSDA && Data.size() == 1) {
+    LSDAEncoding.push_back((unsigned)(unsigned char)Data[0]);
+    ++BytesRead;
+
+    if (LSDAEncoding.size() == 4)
+      // The fourth value tells us where the bottom of the type table is.
+      LSDASize = BytesRead + LSDAEncoding[3];
+    else if (LSDAEncoding.size() == 6)
+      // The sixth value tells us where the start of the action table is.
+      ActionTableBytes = BytesRead;
+  }
+
+  MCAsmStreamer::EmitBytes(Data, AddrSpace);
+}
+
 void MCLSDADecoderAsmStreamer::EmitIntValue(uint64_t Value, unsigned Size,
                                             unsigned AddrSpace) {
   if (!InLSDA)
@@ -1607,7 +1624,7 @@
   ExceptionHandling::ExceptionsType ET =
     Context.getAsmInfo().getExceptionHandlingType();
 
-  if (isVerboseAsm &&
+  if (useCFI && isVerboseAsm &&
       (ET == ExceptionHandling::SjLj || ET == ExceptionHandling::DwarfCFI))
     return new MCLSDADecoderAsmStreamer(Context, OS, isVerboseAsm, useLoc,
                                         useCFI, IP, CE, TAB, ShowInst);





More information about the llvm-commits mailing list