diff options
author | Bill Wendling <isanbard@gmail.com> | 2010-01-16 01:40:55 +0000 |
---|---|---|
committer | Bill Wendling <isanbard@gmail.com> | 2010-01-16 01:40:55 +0000 |
commit | bf5cfa1a4144a4d48997f3836131879b4be2c020 (patch) | |
tree | 6b2f4339e7f7912534463a4c2943fe75c5fe1ecd /llvm/lib/CodeGen/AsmPrinter/DwarfException.cpp | |
parent | 94d91a5b30db90125ef6c2eaef40aee1ce69ea15 (diff) | |
download | bcm5719-llvm-bf5cfa1a4144a4d48997f3836131879b4be2c020.tar.gz bcm5719-llvm-bf5cfa1a4144a4d48997f3836131879b4be2c020.zip |
Retrying r91337:
The CIE says that the LSDA point in the FDE section is an "sdata4". That's fine,
but we need it to actually be 4-bytes in the FDE for some platforms. Allow
individual platforms to decide for themselves.
llvm-svn: 93616
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter/DwarfException.cpp')
-rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfException.cpp | 27 |
1 files changed, 19 insertions, 8 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfException.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfException.cpp index d01f300990c..c1d3f4900c3 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfException.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfException.cpp @@ -283,17 +283,28 @@ void DwarfException::EmitFDE(const FunctionEHFrameInfo &EHFrameInfo) { if (MMI->getPersonalities()[0] != NULL) { bool is4Byte = TD->getPointerSize() == sizeof(int32_t); - Asm->EmitULEB128Bytes(is4Byte ? 4 : 8); - Asm->EOL("Augmentation size"); + if (Asm->TM.getLSDAEncoding() == DwarfLSDAEncoding::FourByte) { + Asm->EmitULEB128Bytes(4); + Asm->EOL("Augmentation size"); - if (EHFrameInfo.hasLandingPads) - EmitReference("exception", EHFrameInfo.Number, true, false); - else { - if (is4Byte) - Asm->EmitInt32((int)0); + if (EHFrameInfo.hasLandingPads) + EmitReference("exception", EHFrameInfo.Number, true, true); else - Asm->EmitInt64((int)0); + Asm->EmitInt32((int)0); + } else { + Asm->EmitULEB128Bytes(is4Byte ? 4 : 8); + Asm->EOL("Augmentation size"); + + if (EHFrameInfo.hasLandingPads) { + EmitReference("exception", EHFrameInfo.Number, true, false); + } else { + if (is4Byte) + Asm->EmitInt32((int)0); + else + Asm->EmitInt64((int)0); + } } + Asm->EOL("Language Specific Data Area"); } else { Asm->EmitULEB128Bytes(0); |