15ffd83dbSDimitry Andric //===-- ABISysV_mips.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_MIPS_ABISYSV_MIPS_H 105ffd83dbSDimitry Andric #define LLDB_SOURCE_PLUGINS_ABI_MIPS_ABISYSV_MIPS_H 115ffd83dbSDimitry Andric 125ffd83dbSDimitry Andric #include "lldb/Target/ABI.h" 135ffd83dbSDimitry Andric #include "lldb/lldb-private.h" 145ffd83dbSDimitry Andric 155ffd83dbSDimitry Andric class ABISysV_mips : public lldb_private::RegInfoBasedABI { 165ffd83dbSDimitry Andric public: 175ffd83dbSDimitry Andric ~ABISysV_mips() 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 bool IsSoftFloat(uint32_t fp_flag) const; 455ffd83dbSDimitry Andric CallFrameAddressIsValid(lldb::addr_t cfa)465ffd83dbSDimitry Andric bool CallFrameAddressIsValid(lldb::addr_t cfa) override { 475ffd83dbSDimitry Andric // Make sure the stack call frame addresses are 8 byte aligned 485ffd83dbSDimitry Andric if (cfa & (8ull - 1ull)) 495ffd83dbSDimitry Andric return false; // Not 8 byte aligned 505ffd83dbSDimitry Andric if (cfa == 0) 515ffd83dbSDimitry Andric return false; // Zero is not a valid stack address 525ffd83dbSDimitry Andric return true; 535ffd83dbSDimitry Andric } 545ffd83dbSDimitry Andric CodeAddressIsValid(lldb::addr_t pc)555ffd83dbSDimitry Andric bool CodeAddressIsValid(lldb::addr_t pc) override { 565ffd83dbSDimitry Andric // Just make sure the address is a valid 32 bit address. Bit zero 575ffd83dbSDimitry Andric // might be set due to MicroMIPS function calls, so don't enforce alignment. 585ffd83dbSDimitry Andric return (pc <= UINT32_MAX); 595ffd83dbSDimitry Andric } 605ffd83dbSDimitry Andric 615ffd83dbSDimitry Andric const lldb_private::RegisterInfo * 625ffd83dbSDimitry Andric GetRegisterInfoArray(uint32_t &count) override; 635ffd83dbSDimitry Andric 645ffd83dbSDimitry Andric // Static Functions 655ffd83dbSDimitry Andric 665ffd83dbSDimitry Andric static void Initialize(); 675ffd83dbSDimitry Andric 685ffd83dbSDimitry Andric static void Terminate(); 695ffd83dbSDimitry Andric 705ffd83dbSDimitry Andric static lldb::ABISP CreateInstance(lldb::ProcessSP process_sp, const lldb_private::ArchSpec &arch); 715ffd83dbSDimitry Andric GetPluginNameStatic()72*349cc55cSDimitry Andric static llvm::StringRef GetPluginNameStatic() { return "sysv-mips"; } 735ffd83dbSDimitry Andric 745ffd83dbSDimitry Andric // PluginInterface protocol 755ffd83dbSDimitry Andric GetPluginName()76*349cc55cSDimitry Andric llvm::StringRef GetPluginName() override { return GetPluginNameStatic(); } 775ffd83dbSDimitry Andric 785ffd83dbSDimitry Andric protected: 795ffd83dbSDimitry Andric void CreateRegisterMapIfNeeded(); 805ffd83dbSDimitry Andric 815ffd83dbSDimitry Andric lldb::ValueObjectSP 825ffd83dbSDimitry Andric GetReturnValueObjectSimple(lldb_private::Thread &thread, 835ffd83dbSDimitry Andric lldb_private::CompilerType &ast_type) const; 845ffd83dbSDimitry Andric 855ffd83dbSDimitry Andric bool RegisterIsCalleeSaved(const lldb_private::RegisterInfo *reg_info); 865ffd83dbSDimitry Andric 875ffd83dbSDimitry Andric private: 885ffd83dbSDimitry Andric using lldb_private::RegInfoBasedABI::RegInfoBasedABI; // Call CreateInstance instead. 895ffd83dbSDimitry Andric }; 905ffd83dbSDimitry Andric 915ffd83dbSDimitry Andric #endif // LLDB_SOURCE_PLUGINS_ABI_MIPS_ABISYSV_MIPS_H 92