[Lldb-commits] [lldb] r188952 - Adding separate cfa alignment check for Darwin and non-Darwin targets in 32-bit ABI.
Andrew Kaylor
andrew.kaylor at intel.com
Wed Aug 21 15:40:46 PDT 2013
Author: akaylor
Date: Wed Aug 21 17:40:46 2013
New Revision: 188952
URL: http://llvm.org/viewvc/llvm-project?rev=188952&view=rev
Log:
Adding separate cfa alignment check for Darwin and non-Darwin targets in 32-bit ABI.
Modified:
lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.cpp
lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.h
Modified: lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.cpp?rev=188952&r1=188951&r2=188952&view=diff
==============================================================================
--- lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.cpp (original)
+++ lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.cpp Wed Aug 21 17:40:46 2013
@@ -235,12 +235,22 @@ ABIMacOSX_i386::GetRedZoneSize () const
ABISP
ABIMacOSX_i386::CreateInstance (const ArchSpec &arch)
{
- static ABISP g_abi_sp;
+ static ABISP g_abi_mac_sp;
+ static ABISP g_abi_other_sp;
if (arch.GetTriple().getArch() == llvm::Triple::x86)
{
- if (!g_abi_sp)
- g_abi_sp.reset (new ABIMacOSX_i386);
- return g_abi_sp;
+ if (arch.GetTriple().isOSDarwin())
+ {
+ if (!g_abi_mac_sp)
+ g_abi_mac_sp.reset (new ABIMacOSX_i386(true));
+ return g_abi_sp;
+ }
+ else
+ {
+ if (!g_abi_other_sp)
+ g_abi_other_sp.reset (new ABIMacOSX_i386(false));
+ return g_abi_sp;
+ }
}
return ABISP();
}
Modified: lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.h
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.h?rev=188952&r1=188951&r2=188952&view=diff
==============================================================================
--- lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.h (original)
+++ lldb/trunk/source/Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.h Wed Aug 21 17:40:46 2013
@@ -79,9 +79,21 @@ public:
virtual bool
CallFrameAddressIsValid (lldb::addr_t cfa)
{
- // Make sure the stack call frame addresses are are 8 byte aligned
- if (cfa & (8ull - 1ull))
- return false; // Not 8 byte aligned
+ // Darwin call frame addresses must be 16-byte aligned, but other OS's
+ // only need 4-byte alignment. Otherwise the ABI matches, so we have
+ // this one minor override here.
+ if (target_is_darwin)
+ {
+ // Make sure the stack call frame addresses are are 16 byte aligned
+ if (cfa & (16ull - 1ull))
+ return false; // Not 16 byte aligned
+ }
+ else
+ {
+ // Make sure the stack call frame addresses are are 4 byte aligned
+ if (cfa & (4ull - 1ull))
+ return false; // Not 4 byte aligned
+ }
if (cfa == 0)
return false; // Zero is not a valid stack address
return true;
@@ -132,7 +144,11 @@ protected:
RegisterIsCalleeSaved (const lldb_private::RegisterInfo *reg_info);
private:
- ABIMacOSX_i386() : lldb_private::ABI() { } // Call CreateInstance instead.
+ ABIMacOSX_i386(bool is_darwin) : lldb_private::ABI(),
+ target_is_darwin(is_darwin)
+ { } // Call CreateInstance instead.
+
+ bool target_is_darwin;
};
More information about the lldb-commits
mailing list