15ffd83dbSDimitry Andric //===-- ABISysV_hexagon.h ----------------------------------------*- C++ 25ffd83dbSDimitry Andric //-*-===// 35ffd83dbSDimitry Andric // 45ffd83dbSDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 55ffd83dbSDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 65ffd83dbSDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 75ffd83dbSDimitry Andric // 85ffd83dbSDimitry Andric //===----------------------------------------------------------------------===// 95ffd83dbSDimitry Andric 105ffd83dbSDimitry Andric #ifndef LLDB_SOURCE_PLUGINS_ABI_HEXAGON_ABISYSV_HEXAGON_H 115ffd83dbSDimitry Andric #define LLDB_SOURCE_PLUGINS_ABI_HEXAGON_ABISYSV_HEXAGON_H 125ffd83dbSDimitry Andric 135ffd83dbSDimitry Andric #include "lldb/Target/ABI.h" 145ffd83dbSDimitry Andric #include "lldb/lldb-private.h" 155ffd83dbSDimitry Andric 165ffd83dbSDimitry Andric class ABISysV_hexagon : public lldb_private::RegInfoBasedABI { 175ffd83dbSDimitry Andric public: 185ffd83dbSDimitry Andric ~ABISysV_hexagon() override = default; 195ffd83dbSDimitry Andric 205ffd83dbSDimitry Andric size_t GetRedZoneSize() const override; 215ffd83dbSDimitry Andric 225ffd83dbSDimitry Andric bool PrepareTrivialCall(lldb_private::Thread &thread, lldb::addr_t sp, 235ffd83dbSDimitry Andric lldb::addr_t functionAddress, 245ffd83dbSDimitry Andric lldb::addr_t returnAddress, 255ffd83dbSDimitry Andric llvm::ArrayRef<lldb::addr_t> args) const override; 265ffd83dbSDimitry Andric 275ffd83dbSDimitry Andric // special thread plan for GDB style non-jit function calls 285ffd83dbSDimitry Andric bool 295ffd83dbSDimitry Andric PrepareTrivialCall(lldb_private::Thread &thread, lldb::addr_t sp, 305ffd83dbSDimitry Andric lldb::addr_t functionAddress, lldb::addr_t returnAddress, 315ffd83dbSDimitry Andric llvm::Type &prototype, 325ffd83dbSDimitry Andric llvm::ArrayRef<ABI::CallArgument> args) const override; 335ffd83dbSDimitry Andric 345ffd83dbSDimitry Andric bool GetArgumentValues(lldb_private::Thread &thread, 355ffd83dbSDimitry Andric lldb_private::ValueList &values) const override; 365ffd83dbSDimitry Andric 375ffd83dbSDimitry Andric lldb_private::Status 385ffd83dbSDimitry Andric SetReturnValueObject(lldb::StackFrameSP &frame_sp, 395ffd83dbSDimitry Andric lldb::ValueObjectSP &new_value) override; 405ffd83dbSDimitry Andric 415ffd83dbSDimitry Andric lldb::ValueObjectSP 425ffd83dbSDimitry Andric GetReturnValueObjectImpl(lldb_private::Thread &thread, 435ffd83dbSDimitry Andric lldb_private::CompilerType &type) const override; 445ffd83dbSDimitry Andric 455ffd83dbSDimitry Andric // specialized to work with llvm IR types 465ffd83dbSDimitry Andric lldb::ValueObjectSP GetReturnValueObjectImpl(lldb_private::Thread &thread, 475ffd83dbSDimitry Andric llvm::Type &type) const override; 485ffd83dbSDimitry Andric 495ffd83dbSDimitry Andric bool 505ffd83dbSDimitry Andric CreateFunctionEntryUnwindPlan(lldb_private::UnwindPlan &unwind_plan) override; 515ffd83dbSDimitry Andric 525ffd83dbSDimitry Andric bool CreateDefaultUnwindPlan(lldb_private::UnwindPlan &unwind_plan) override; 535ffd83dbSDimitry Andric 545ffd83dbSDimitry Andric bool RegisterIsVolatile(const lldb_private::RegisterInfo *reg_info) override; 555ffd83dbSDimitry Andric CallFrameAddressIsValid(lldb::addr_t cfa)565ffd83dbSDimitry Andric bool CallFrameAddressIsValid(lldb::addr_t cfa) override { 575ffd83dbSDimitry Andric // Make sure the stack call frame addresses are 8 byte aligned 585ffd83dbSDimitry Andric if (cfa & 0x07) 595ffd83dbSDimitry Andric return false; // Not 8 byte aligned 605ffd83dbSDimitry Andric if (cfa == 0) 615ffd83dbSDimitry Andric return false; // Zero is not a valid stack address 625ffd83dbSDimitry Andric return true; 635ffd83dbSDimitry Andric } 645ffd83dbSDimitry Andric CodeAddressIsValid(lldb::addr_t pc)655ffd83dbSDimitry Andric bool CodeAddressIsValid(lldb::addr_t pc) override { 665ffd83dbSDimitry Andric // We have a 64 bit address space, so anything is valid as opcodes 675ffd83dbSDimitry Andric // aren't fixed width... 685ffd83dbSDimitry Andric return true; 695ffd83dbSDimitry Andric } 705ffd83dbSDimitry Andric 715ffd83dbSDimitry Andric const lldb_private::RegisterInfo * 725ffd83dbSDimitry Andric GetRegisterInfoArray(uint32_t &count) override; 735ffd83dbSDimitry Andric 745ffd83dbSDimitry Andric // Static Functions 755ffd83dbSDimitry Andric 765ffd83dbSDimitry Andric static void Initialize(); 775ffd83dbSDimitry Andric 785ffd83dbSDimitry Andric static void Terminate(); 795ffd83dbSDimitry Andric 805ffd83dbSDimitry Andric static lldb::ABISP CreateInstance(lldb::ProcessSP process_sp, const lldb_private::ArchSpec &arch); 815ffd83dbSDimitry Andric GetPluginNameStatic()82*349cc55cSDimitry Andric static llvm::StringRef GetPluginNameStatic() { return "sysv-hexagon"; } 835ffd83dbSDimitry Andric 845ffd83dbSDimitry Andric // PluginInterface protocol 855ffd83dbSDimitry Andric GetPluginName()86*349cc55cSDimitry Andric llvm::StringRef GetPluginName() override { return GetPluginNameStatic(); } 875ffd83dbSDimitry Andric 885ffd83dbSDimitry Andric protected: 895ffd83dbSDimitry Andric void CreateRegisterMapIfNeeded(); 905ffd83dbSDimitry Andric 915ffd83dbSDimitry Andric lldb::ValueObjectSP 925ffd83dbSDimitry Andric GetReturnValueObjectSimple(lldb_private::Thread &thread, 935ffd83dbSDimitry Andric lldb_private::CompilerType &ast_type) const; 945ffd83dbSDimitry Andric 955ffd83dbSDimitry Andric bool RegisterIsCalleeSaved(const lldb_private::RegisterInfo *reg_info); 965ffd83dbSDimitry Andric 975ffd83dbSDimitry Andric private: 985ffd83dbSDimitry Andric using lldb_private::RegInfoBasedABI::RegInfoBasedABI; // Call CreateInstance instead. 995ffd83dbSDimitry Andric }; 1005ffd83dbSDimitry Andric 1015ffd83dbSDimitry Andric #endif // LLDB_SOURCE_PLUGINS_ABI_HEXAGON_ABISYSV_HEXAGON_H 102