15ffd83dbSDimitry Andric //===-- ABISysV_ppc64.h ----------------------------------------*- C++ -*-===// 25ffd83dbSDimitry Andric // 35ffd83dbSDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 45ffd83dbSDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 55ffd83dbSDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 65ffd83dbSDimitry Andric // 75ffd83dbSDimitry Andric //===----------------------------------------------------------------------===// 85ffd83dbSDimitry Andric 95ffd83dbSDimitry Andric #ifndef LLDB_SOURCE_PLUGINS_ABI_POWERPC_ABISYSV_PPC64_H 105ffd83dbSDimitry Andric #define LLDB_SOURCE_PLUGINS_ABI_POWERPC_ABISYSV_PPC64_H 115ffd83dbSDimitry Andric 125ffd83dbSDimitry Andric #include "lldb/Target/ABI.h" 135ffd83dbSDimitry Andric #include "lldb/lldb-private.h" 145ffd83dbSDimitry Andric 155ffd83dbSDimitry Andric class ABISysV_ppc64 : public lldb_private::RegInfoBasedABI { 165ffd83dbSDimitry Andric public: 175ffd83dbSDimitry Andric ~ABISysV_ppc64() override = default; 185ffd83dbSDimitry Andric 195ffd83dbSDimitry Andric size_t GetRedZoneSize() const override; 205ffd83dbSDimitry Andric 215ffd83dbSDimitry Andric bool PrepareTrivialCall(lldb_private::Thread &thread, lldb::addr_t sp, 225ffd83dbSDimitry Andric lldb::addr_t functionAddress, 235ffd83dbSDimitry Andric lldb::addr_t returnAddress, 245ffd83dbSDimitry Andric llvm::ArrayRef<lldb::addr_t> args) const override; 255ffd83dbSDimitry Andric 265ffd83dbSDimitry Andric bool GetArgumentValues(lldb_private::Thread &thread, 275ffd83dbSDimitry Andric lldb_private::ValueList &values) const override; 285ffd83dbSDimitry Andric 295ffd83dbSDimitry Andric lldb_private::Status 305ffd83dbSDimitry Andric SetReturnValueObject(lldb::StackFrameSP &frame_sp, 315ffd83dbSDimitry Andric lldb::ValueObjectSP &new_value) override; 325ffd83dbSDimitry Andric 335ffd83dbSDimitry Andric lldb::ValueObjectSP 345ffd83dbSDimitry Andric GetReturnValueObjectImpl(lldb_private::Thread &thread, 355ffd83dbSDimitry Andric lldb_private::CompilerType &type) const override; 365ffd83dbSDimitry Andric 375ffd83dbSDimitry Andric bool 385ffd83dbSDimitry Andric CreateFunctionEntryUnwindPlan(lldb_private::UnwindPlan &unwind_plan) override; 395ffd83dbSDimitry Andric 405ffd83dbSDimitry Andric bool CreateDefaultUnwindPlan(lldb_private::UnwindPlan &unwind_plan) override; 415ffd83dbSDimitry Andric 425ffd83dbSDimitry Andric bool RegisterIsVolatile(const lldb_private::RegisterInfo *reg_info) override; 435ffd83dbSDimitry Andric 445ffd83dbSDimitry Andric // The SysV ppc64 ABI requires that stack frames be 16 byte aligned. 455ffd83dbSDimitry Andric // When there is a trap handler on the stack, e.g. _sigtramp in userland 465ffd83dbSDimitry Andric // code, we've seen that the stack pointer is often not aligned properly 475ffd83dbSDimitry Andric // before the handler is invoked. This means that lldb will stop the unwind 485ffd83dbSDimitry Andric // early -- before the function which caused the trap. 495ffd83dbSDimitry Andric // 505ffd83dbSDimitry Andric // To work around this, we relax that alignment to be just word-size 515ffd83dbSDimitry Andric // (8-bytes). 525ffd83dbSDimitry Andric // Allowing the trap handlers for user space would be easy (_sigtramp) but 535ffd83dbSDimitry Andric // in other environments there can be a large number of different functions 545ffd83dbSDimitry Andric // involved in async traps. CallFrameAddressIsValid(lldb::addr_t cfa)555ffd83dbSDimitry Andric bool CallFrameAddressIsValid(lldb::addr_t cfa) override { 565ffd83dbSDimitry Andric // Make sure the stack call frame addresses are 8 byte aligned 575ffd83dbSDimitry Andric if (cfa & (8ull - 1ull)) 585ffd83dbSDimitry Andric return false; // Not 8 byte aligned 595ffd83dbSDimitry Andric if (cfa == 0) 605ffd83dbSDimitry Andric return false; // Zero is not a valid stack address 615ffd83dbSDimitry Andric return true; 625ffd83dbSDimitry Andric } 635ffd83dbSDimitry Andric CodeAddressIsValid(lldb::addr_t pc)645ffd83dbSDimitry Andric bool CodeAddressIsValid(lldb::addr_t pc) override { 655ffd83dbSDimitry Andric // We have a 64 bit address space, so anything is valid as opcodes 665ffd83dbSDimitry Andric // aren't fixed width... 675ffd83dbSDimitry Andric return true; 685ffd83dbSDimitry Andric } 695ffd83dbSDimitry Andric 705ffd83dbSDimitry Andric const lldb_private::RegisterInfo * 715ffd83dbSDimitry Andric GetRegisterInfoArray(uint32_t &count) override; 725ffd83dbSDimitry Andric 735ffd83dbSDimitry Andric // Static Functions 745ffd83dbSDimitry Andric 755ffd83dbSDimitry Andric static void Initialize(); 765ffd83dbSDimitry Andric 775ffd83dbSDimitry Andric static void Terminate(); 785ffd83dbSDimitry Andric 795ffd83dbSDimitry Andric static lldb::ABISP CreateInstance(lldb::ProcessSP process_sp, const lldb_private::ArchSpec &arch); 805ffd83dbSDimitry Andric GetPluginNameStatic()81*349cc55cSDimitry Andric static llvm::StringRef GetPluginNameStatic() { return "sysv-ppc64"; } 825ffd83dbSDimitry Andric 835ffd83dbSDimitry Andric // PluginInterface protocol 845ffd83dbSDimitry Andric GetPluginName()85*349cc55cSDimitry Andric llvm::StringRef GetPluginName() override { return GetPluginNameStatic(); } 865ffd83dbSDimitry Andric 875ffd83dbSDimitry Andric protected: 885ffd83dbSDimitry Andric void CreateRegisterMapIfNeeded(); 895ffd83dbSDimitry Andric 905ffd83dbSDimitry Andric lldb::ValueObjectSP 915ffd83dbSDimitry Andric GetReturnValueObjectSimple(lldb_private::Thread &thread, 925ffd83dbSDimitry Andric lldb_private::CompilerType &ast_type) const; 935ffd83dbSDimitry Andric 945ffd83dbSDimitry Andric bool RegisterIsCalleeSaved(const lldb_private::RegisterInfo *reg_info); 955ffd83dbSDimitry Andric 965ffd83dbSDimitry Andric private: 975ffd83dbSDimitry Andric using lldb_private::RegInfoBasedABI::RegInfoBasedABI; // Call CreateInstance instead. 985ffd83dbSDimitry Andric 995ffd83dbSDimitry Andric lldb::ByteOrder GetByteOrder() const; 1005ffd83dbSDimitry Andric }; 1015ffd83dbSDimitry Andric 1025ffd83dbSDimitry Andric #endif // LLDB_SOURCE_PLUGINS_ABI_POWERPC_ABISYSV_PPC64_H 103