diff options
author | Charles Davis <cdavis@mines.edu> | 2011-05-22 04:15:07 +0000 |
---|---|---|
committer | Charles Davis <cdavis@mines.edu> | 2011-05-22 04:15:07 +0000 |
commit | bc2daa0f932c5a63b5932a353a485e6ccf721fa2 (patch) | |
tree | b2bb48f53e254cfdd376d0c367fe76449a3d1ab4 /llvm | |
parent | 1c8bd5ad7ed9aebcec55c06e8ef7924081a57838 (diff) | |
download | bcm5719-llvm-bc2daa0f932c5a63b5932a353a485e6ccf721fa2.tar.gz bcm5719-llvm-bc2daa0f932c5a63b5932a353a485e6ccf721fa2.zip |
Implement emission of all Win64 exception tables. Make the COFF streamer emit
these tables.
llvm-svn: 131833
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/include/llvm/MC/MCStreamer.h | 9 | ||||
-rw-r--r-- | llvm/lib/MC/MCStreamer.cpp | 7 | ||||
-rw-r--r-- | llvm/lib/MC/MCWin64EH.cpp | 17 | ||||
-rw-r--r-- | llvm/lib/MC/WinCOFFStreamer.cpp | 1 |
4 files changed, 33 insertions, 1 deletions
diff --git a/llvm/include/llvm/MC/MCStreamer.h b/llvm/include/llvm/MC/MCStreamer.h index bfcb4609aee..c12caf01b03 100644 --- a/llvm/include/llvm/MC/MCStreamer.h +++ b/llvm/include/llvm/MC/MCStreamer.h @@ -81,6 +81,7 @@ namespace llvm { void EmitFrames(bool usingCFI); MCWin64EHUnwindInfo *getCurrentW64UnwindInfo(){return CurrentW64UnwindInfo;} + void EmitW64Tables(); public: virtual ~MCStreamer(); @@ -95,6 +96,14 @@ namespace llvm { return FrameInfos[i]; } + unsigned getNumW64UnwindInfos() { + return W64UnwindInfos.size(); + } + + MCWin64EHUnwindInfo &getW64UnwindInfo(unsigned i) { + return W64UnwindInfos[i]; + } + /// @name Assembly File Formatting. /// @{ diff --git a/llvm/lib/MC/MCStreamer.cpp b/llvm/lib/MC/MCStreamer.cpp index 164325e8f4f..f268f9e3756 100644 --- a/llvm/lib/MC/MCStreamer.cpp +++ b/llvm/lib/MC/MCStreamer.cpp @@ -506,3 +506,10 @@ void MCStreamer::EmitFrames(bool usingCFI) { if (EmitDebugFrame) MCDwarfFrameEmitter::Emit(*this, usingCFI, false); } + +void MCStreamer::EmitW64Tables() { + if (!getNumW64UnwindInfos()) + return; + + MCWin64EHUnwindEmitter::Emit(*this); +} diff --git a/llvm/lib/MC/MCWin64EH.cpp b/llvm/lib/MC/MCWin64EH.cpp index 9884f66e5fb..fc394504bfb 100644 --- a/llvm/lib/MC/MCWin64EH.cpp +++ b/llvm/lib/MC/MCWin64EH.cpp @@ -110,7 +110,7 @@ static void EmitUnwindCode(MCStreamer &streamer, MCWin64EHInstruction &inst) { } static void EmitRuntimeFunction(MCStreamer &streamer, - MCWin64EHUnwindInfo *info) { + const MCWin64EHUnwindInfo *info) { MCContext &context = streamer.getContext(); streamer.EmitValue(MCSymbolRefExpr::Create(info->Begin, context), 4); @@ -185,5 +185,20 @@ void MCWin64EHUnwindEmitter::EmitUnwindInfo(MCStreamer &streamer, llvm::EmitUnwindInfo(streamer, info); } +void MCWin64EHUnwindEmitter::Emit(MCStreamer &streamer) { + MCContext &context = streamer.getContext(); + // Emit the unwind info structs first. + const TargetAsmInfo &asmInfo = context.getTargetAsmInfo(); + const MCSection *xdataSect = asmInfo.getWin64EHTableSection(); + streamer.SwitchSection(xdataSect); + for (unsigned i = 0; i < streamer.getNumW64UnwindInfos(); ++i) + llvm::EmitUnwindInfo(streamer, &streamer.getW64UnwindInfo(i)); + // Now emit RUNTIME_FUNCTION entries. + const MCSection *pdataSect = asmInfo.getWin64EHFuncTableSection(); + streamer.SwitchSection(pdataSect); + for (unsigned i = 0; i < streamer.getNumW64UnwindInfos(); ++i) + EmitRuntimeFunction(streamer, &streamer.getW64UnwindInfo(i)); +} + } // End of namespace llvm diff --git a/llvm/lib/MC/WinCOFFStreamer.cpp b/llvm/lib/MC/WinCOFFStreamer.cpp index 8b0cfcbd62c..6c36c1231c8 100644 --- a/llvm/lib/MC/WinCOFFStreamer.cpp +++ b/llvm/lib/MC/WinCOFFStreamer.cpp @@ -388,6 +388,7 @@ void WinCOFFStreamer::EmitWin64EHHandlerData() { } void WinCOFFStreamer::Finish() { + EmitW64Tables(); MCObjectStreamer::Finish(); } |