xref: /freebsd-src/contrib/llvm-project/lldb/source/Plugins/ABI/Hexagon/ABISysV_hexagon.h (revision 349cc55c9796c4596a5b9904cd3281af295f878f)
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