blob: 388009d0fa00def750a6986c454c93e1ee14335d [file] [log] [blame]
Bhushan D. Attardea8219f22015-06-18 07:02:10 +00001//===-- ABISysV_mips.h ----------------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#ifndef liblldb_ABISysV_mips_h_
11#define liblldb_ABISysV_mips_h_
12
13// C Includes
14// C++ Includes
15// Other libraries and framework includes
16// Project includes
17#include "lldb/lldb-private.h"
18#include "lldb/Target/ABI.h"
19
20class ABISysV_mips :
21 public lldb_private::ABI
22{
23public:
Eugene Zelenko17af3f92015-10-16 18:49:42 +000024 ~ABISysV_mips() override = default;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000025
Eugene Zelenko17af3f92015-10-16 18:49:42 +000026 size_t
27 GetRedZoneSize() const override;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000028
Eugene Zelenko17af3f92015-10-16 18:49:42 +000029 bool
30 PrepareTrivialCall(lldb_private::Thread &thread,
31 lldb::addr_t sp,
32 lldb::addr_t functionAddress,
33 lldb::addr_t returnAddress,
34 llvm::ArrayRef<lldb::addr_t> args) const override;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000035
Eugene Zelenko17af3f92015-10-16 18:49:42 +000036 bool
37 GetArgumentValues(lldb_private::Thread &thread,
38 lldb_private::ValueList &values) const override;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000039
Eugene Zelenko17af3f92015-10-16 18:49:42 +000040 lldb_private::Error
41 SetReturnValueObject(lldb::StackFrameSP &frame_sp, lldb::ValueObjectSP &new_value) override;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000042
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000043 lldb::ValueObjectSP
Eugene Zelenko17af3f92015-10-16 18:49:42 +000044 GetReturnValueObjectImpl(lldb_private::Thread &thread,
45 lldb_private::CompilerType &type) const override;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000046
Eugene Zelenko17af3f92015-10-16 18:49:42 +000047 bool
48 CreateFunctionEntryUnwindPlan(lldb_private::UnwindPlan &unwind_plan) override;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000049
Eugene Zelenko17af3f92015-10-16 18:49:42 +000050 bool
51 CreateDefaultUnwindPlan(lldb_private::UnwindPlan &unwind_plan) override;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000052
Eugene Zelenko17af3f92015-10-16 18:49:42 +000053 bool
54 RegisterIsVolatile(const lldb_private::RegisterInfo *reg_info) override;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000055
Eugene Zelenko17af3f92015-10-16 18:49:42 +000056 bool
Sagar Thakurad5b55a2016-05-24 14:52:50 +000057 IsSoftFloat(uint32_t fp_flag) const;
58
59 bool
Eugene Zelenko17af3f92015-10-16 18:49:42 +000060 CallFrameAddressIsValid(lldb::addr_t cfa) override
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000061 {
62 // Make sure the stack call frame addresses are 8 byte aligned
63 if (cfa & (8ull - 1ull))
64 return false; // Not 8 byte aligned
65 if (cfa == 0)
66 return false; // Zero is not a valid stack address
67 return true;
68 }
69
Eugene Zelenko17af3f92015-10-16 18:49:42 +000070 bool
71 CodeAddressIsValid(lldb::addr_t pc) override
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000072 {
Bhushan D. Attardef55a0a42015-10-06 08:52:08 +000073 // Just make sure the address is a valid 32 bit address. Bit zero
74 // might be set due to MicroMIPS function calls, so don't enforce alignment.
75 return (pc <= UINT32_MAX);
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000076 }
77
Eugene Zelenko17af3f92015-10-16 18:49:42 +000078 const lldb_private::RegisterInfo *
79 GetRegisterInfoArray(uint32_t &count) override;
80
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000081 //------------------------------------------------------------------
82 // Static Functions
83 //------------------------------------------------------------------
Eugene Zelenko17af3f92015-10-16 18:49:42 +000084
Bhushan D. Attardea8219f22015-06-18 07:02:10 +000085 static void
86 Initialize();
87
88 static void
89 Terminate();
90
91 static lldb::ABISP
92 CreateInstance (const lldb_private::ArchSpec &arch);
93
94 static lldb_private::ConstString
95 GetPluginNameStatic();
96
97 //------------------------------------------------------------------
98 // PluginInterface protocol
99 //------------------------------------------------------------------
Bhushan D. Attardea8219f22015-06-18 07:02:10 +0000100
Eugene Zelenko17af3f92015-10-16 18:49:42 +0000101 lldb_private::ConstString
102 GetPluginName() override;
103
104 uint32_t
105 GetPluginVersion() override;
Bhushan D. Attardea8219f22015-06-18 07:02:10 +0000106
107protected:
108 void
109 CreateRegisterMapIfNeeded ();
110
Eugene Zelenko17af3f92015-10-16 18:49:42 +0000111 lldb::ValueObjectSP
112 GetReturnValueObjectSimple(lldb_private::Thread &thread,
113 lldb_private::CompilerType &ast_type) const;
114
Bhushan D. Attardea8219f22015-06-18 07:02:10 +0000115 bool
116 RegisterIsCalleeSaved (const lldb_private::RegisterInfo *reg_info);
117
118private:
Eugene Zelenko17af3f92015-10-16 18:49:42 +0000119 ABISysV_mips() :
120 lldb_private::ABI()
121 {
122 // Call CreateInstance instead.
123 }
Bhushan D. Attardea8219f22015-06-18 07:02:10 +0000124};
125
Eugene Zelenko17af3f92015-10-16 18:49:42 +0000126#endif // liblldb_ABISysV_mips_h_