DNBArch.h revision 4e49a5bfccc0a51185eadf69b3e23f68e70f1676
1//===-- DNBArch.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//  Created by Greg Clayton on 6/24/07.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef __DebugNubArch_h__
15#define __DebugNubArch_h__
16
17#include "DNBDefs.h"
18#include "MacOSX/MachException.h"
19
20#include <mach/mach.h>
21#include <stdio.h>
22
23struct DNBRegisterValue;
24struct DNBRegisterSetInfo;
25class DNBArchProtocol;
26class MachThread;
27
28typedef DNBArchProtocol * (* DNBArchCallbackCreate)(MachThread *thread);
29typedef const DNBRegisterSetInfo * (* DNBArchCallbackGetRegisterSetInfo)(nub_size_t *num_reg_sets);
30typedef const uint8_t * const (* DNBArchCallbackGetBreakpointOpcode)(nub_size_t byte_size);
31
32typedef struct DNBArchPluginInfoTag
33{
34    uint32_t cpu_type;
35    DNBArchCallbackCreate               Create;
36    DNBArchCallbackGetRegisterSetInfo   GetRegisterSetInfo;
37    DNBArchCallbackGetBreakpointOpcode  GetBreakpointOpcode;
38} DNBArchPluginInfo;
39
40class DNBArchProtocol
41{
42public:
43    static DNBArchProtocol *
44    Create (MachThread *thread);
45
46    static const DNBRegisterSetInfo *
47    GetRegisterSetInfo (nub_size_t *num_reg_sets);
48
49    static const uint8_t * const
50    GetBreakpointOpcode (nub_size_t byte_size);
51
52    static void
53    RegisterArchPlugin (const DNBArchPluginInfo &arch_info);
54
55    static uint32_t
56    GetArchitecture ();
57
58    static bool
59    SetArchitecture (uint32_t cpu_type);
60
61    virtual bool            GetRegisterValue (int set, int reg, DNBRegisterValue *value) = 0;
62    virtual bool            SetRegisterValue (int set, int reg, const DNBRegisterValue *value) = 0;
63    virtual nub_size_t      GetRegisterContext (void *buf, nub_size_t buf_len) = 0;
64    virtual nub_size_t      SetRegisterContext (const void *buf, nub_size_t buf_len) = 0;
65
66    virtual kern_return_t   GetRegisterState (int set, bool force) = 0;
67    virtual kern_return_t   SetRegisterState (int set) = 0;
68    virtual bool            RegisterSetStateIsValid (int set) const = 0;
69
70    virtual uint64_t        GetPC (uint64_t failValue) = 0;    // Get program counter
71    virtual kern_return_t   SetPC (uint64_t value) = 0;
72    virtual uint64_t        GetSP (uint64_t failValue) = 0;    // Get stack pointer
73    virtual void            ThreadWillResume () = 0;
74    virtual bool            ThreadDidStop () = 0;
75    virtual bool            NotifyException (MachException::Data& exc) { return false; }
76    virtual uint32_t        NumSupportedHardwareBreakpoints() { return 0; }
77    virtual uint32_t        NumSupportedHardwareWatchpoints() { return 0; }
78    virtual uint32_t        EnableHardwareBreakpoint (nub_addr_t addr, nub_size_t size) { return INVALID_NUB_HW_INDEX; }
79    virtual uint32_t        EnableHardwareWatchpoint (nub_addr_t addr, nub_size_t size, bool read, bool write, bool also_set_on_task) { return INVALID_NUB_HW_INDEX; }
80    virtual bool            DisableHardwareBreakpoint (uint32_t hw_index) { return false; }
81    virtual bool            DisableHardwareWatchpoint (uint32_t hw_index, bool also_set_on_task) { return false; }
82    virtual uint32_t        GetHardwareWatchpointHit() { return INVALID_NUB_HW_INDEX; }
83    virtual bool            StepNotComplete () { return false; }
84
85protected:
86    friend class MachThread;
87
88    enum
89    {
90        Trans_Pending = 0,      // Transaction is pending, and checkpoint state has been snapshotted.
91        Trans_Done = 1,         // Transaction is done, the current state is committed, and checkpoint state is irrelevant.
92        Trans_Rolled_Back = 2   // Transaction is done, the current state has been rolled back to the checkpoint state.
93    };
94    virtual bool StartTransForHWP() { return true; }
95    virtual bool RollbackTransForHWP() { return true; }
96    virtual bool FinishTransForHWP() { return true; }
97};
98
99
100#include "MacOSX/arm/DNBArchImpl.h"
101#include "MacOSX/i386/DNBArchImplI386.h"
102#include "MacOSX/x86_64/DNBArchImplX86_64.h"
103#include "MacOSX/ppc/DNBArchImpl.h"
104
105#endif
106