aboutsummaryrefslogtreecommitdiff
path: root/source/Plugins/ABI/SysV-hexagon/ABISysV_hexagon.h
blob: 337e3fdcf7b54c07e355a470f13d40d2a1951528 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
//===-- ABISysV_hexagon.h ----------------------------------------*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//

#ifndef liblldb_ABISysV_hexagon_h_
#define liblldb_ABISysV_hexagon_h_

// C Includes
// C++ Includes
// Other libraries and framework includes
// Project includes
#include "lldb/lldb-private.h"
#include "lldb/Target/ABI.h"

class ABISysV_hexagon :
    public lldb_private::ABI
{
public:
    ~ABISysV_hexagon() override = default;

    size_t
    GetRedZoneSize() const override;

    bool
    PrepareTrivialCall(lldb_private::Thread &thread,
                       lldb::addr_t sp,
                       lldb::addr_t functionAddress,
                       lldb::addr_t returnAddress,
                       llvm::ArrayRef<lldb::addr_t> args) const override;
    
    // special thread plan for GDB style non-jit function calls
    bool
    PrepareTrivialCall(lldb_private::Thread &thread, 
                       lldb::addr_t sp,
                       lldb::addr_t functionAddress,
                       lldb::addr_t returnAddress,
                       llvm::Type &prototype,
                       llvm::ArrayRef<ABI::CallArgument> args) const override;

    bool
    GetArgumentValues(lldb_private::Thread &thread,
                       lldb_private::ValueList &values) const override;
    
    lldb_private::Error
    SetReturnValueObject(lldb::StackFrameSP &frame_sp,
                         lldb::ValueObjectSP &new_value) override;

    lldb::ValueObjectSP
    GetReturnValueObjectImpl(lldb_private::Thread &thread,
                             lldb_private::CompilerType &type) const override;
        
    // specialized to work with llvm IR types
    lldb::ValueObjectSP
    GetReturnValueObjectImpl(lldb_private::Thread &thread, llvm::Type &type) const override;

    bool
    CreateFunctionEntryUnwindPlan(lldb_private::UnwindPlan &unwind_plan) override;
    
    bool
    CreateDefaultUnwindPlan(lldb_private::UnwindPlan &unwind_plan) override;
        
    bool
    RegisterIsVolatile(const lldb_private::RegisterInfo *reg_info) override;

    bool
    CallFrameAddressIsValid(lldb::addr_t cfa) override
    {
        // Make sure the stack call frame addresses are 8 byte aligned
        if (cfa & 0x07)
            return false;   // Not 8 byte aligned
        if (cfa == 0)
            return false;   // Zero is not a valid stack address
        return true;
    }
    
    bool
    CodeAddressIsValid(lldb::addr_t pc) override
    {
        // We have a 64 bit address space, so anything is valid as opcodes
        // aren't fixed width...
        return true;
    }

    const lldb_private::RegisterInfo *
    GetRegisterInfoArray(uint32_t &count) override;

    //------------------------------------------------------------------
    // Static Functions
    //------------------------------------------------------------------

    static void
    Initialize();

    static void
    Terminate();

    static lldb::ABISP
    CreateInstance ( const lldb_private::ArchSpec &arch );

    static lldb_private::ConstString
    GetPluginNameStatic();
    
    //------------------------------------------------------------------
    // PluginInterface protocol
    //------------------------------------------------------------------

    lldb_private::ConstString
    GetPluginName() override;

    uint32_t
    GetPluginVersion() override;

protected:
    void
    CreateRegisterMapIfNeeded();

    lldb::ValueObjectSP
    GetReturnValueObjectSimple(lldb_private::Thread &thread,
                               lldb_private::CompilerType &ast_type) const;

    bool
    RegisterIsCalleeSaved (const lldb_private::RegisterInfo *reg_info);

private:
    ABISysV_hexagon() : 
        lldb_private::ABI() 
    {
         // Call CreateInstance instead.
    }
};

#endif // liblldb_ABISysV_hexagon_h_