1dda28197Spatrick //===-- RegisterContextKDP_x86_64.cpp -------------------------------------===//
2061da546Spatrick //
3061da546Spatrick // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4061da546Spatrick // See https://llvm.org/LICENSE.txt for license information.
5061da546Spatrick // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6061da546Spatrick //
7061da546Spatrick //===----------------------------------------------------------------------===//
8061da546Spatrick
9061da546Spatrick #include "RegisterContextKDP_x86_64.h"
10061da546Spatrick #include "ProcessKDP.h"
11061da546Spatrick #include "ThreadKDP.h"
12061da546Spatrick
13061da546Spatrick using namespace lldb;
14061da546Spatrick using namespace lldb_private;
15061da546Spatrick
RegisterContextKDP_x86_64(ThreadKDP & thread,uint32_t concrete_frame_idx)16061da546Spatrick RegisterContextKDP_x86_64::RegisterContextKDP_x86_64(
17061da546Spatrick ThreadKDP &thread, uint32_t concrete_frame_idx)
18061da546Spatrick : RegisterContextDarwin_x86_64(thread, concrete_frame_idx),
19061da546Spatrick m_kdp_thread(thread) {}
20061da546Spatrick
21*be691f3bSpatrick RegisterContextKDP_x86_64::~RegisterContextKDP_x86_64() = default;
22061da546Spatrick
DoReadGPR(lldb::tid_t tid,int flavor,GPR & gpr)23061da546Spatrick int RegisterContextKDP_x86_64::DoReadGPR(lldb::tid_t tid, int flavor,
24061da546Spatrick GPR &gpr) {
25061da546Spatrick ProcessSP process_sp(CalculateProcess());
26061da546Spatrick if (process_sp) {
27061da546Spatrick Status error;
28061da546Spatrick if (static_cast<ProcessKDP *>(process_sp.get())
29061da546Spatrick ->GetCommunication()
30061da546Spatrick .SendRequestReadRegisters(tid, GPRRegSet, &gpr, sizeof(gpr),
31061da546Spatrick error)) {
32061da546Spatrick if (error.Success())
33061da546Spatrick return 0;
34061da546Spatrick }
35061da546Spatrick }
36061da546Spatrick return -1;
37061da546Spatrick }
38061da546Spatrick
DoReadFPU(lldb::tid_t tid,int flavor,FPU & fpu)39061da546Spatrick int RegisterContextKDP_x86_64::DoReadFPU(lldb::tid_t tid, int flavor,
40061da546Spatrick FPU &fpu) {
41061da546Spatrick ProcessSP process_sp(CalculateProcess());
42061da546Spatrick if (process_sp) {
43061da546Spatrick Status error;
44061da546Spatrick if (static_cast<ProcessKDP *>(process_sp.get())
45061da546Spatrick ->GetCommunication()
46061da546Spatrick .SendRequestReadRegisters(tid, FPURegSet, &fpu, sizeof(fpu),
47061da546Spatrick error)) {
48061da546Spatrick if (error.Success())
49061da546Spatrick return 0;
50061da546Spatrick }
51061da546Spatrick }
52061da546Spatrick return -1;
53061da546Spatrick }
54061da546Spatrick
DoReadEXC(lldb::tid_t tid,int flavor,EXC & exc)55061da546Spatrick int RegisterContextKDP_x86_64::DoReadEXC(lldb::tid_t tid, int flavor,
56061da546Spatrick EXC &exc) {
57061da546Spatrick ProcessSP process_sp(CalculateProcess());
58061da546Spatrick if (process_sp) {
59061da546Spatrick Status error;
60061da546Spatrick if (static_cast<ProcessKDP *>(process_sp.get())
61061da546Spatrick ->GetCommunication()
62061da546Spatrick .SendRequestReadRegisters(tid, EXCRegSet, &exc, sizeof(exc),
63061da546Spatrick error)) {
64061da546Spatrick if (error.Success())
65061da546Spatrick return 0;
66061da546Spatrick }
67061da546Spatrick }
68061da546Spatrick return -1;
69061da546Spatrick }
70061da546Spatrick
DoWriteGPR(lldb::tid_t tid,int flavor,const GPR & gpr)71061da546Spatrick int RegisterContextKDP_x86_64::DoWriteGPR(lldb::tid_t tid, int flavor,
72061da546Spatrick const GPR &gpr) {
73061da546Spatrick ProcessSP process_sp(CalculateProcess());
74061da546Spatrick if (process_sp) {
75061da546Spatrick Status error;
76061da546Spatrick if (static_cast<ProcessKDP *>(process_sp.get())
77061da546Spatrick ->GetCommunication()
78061da546Spatrick .SendRequestWriteRegisters(tid, GPRRegSet, &gpr, sizeof(gpr),
79061da546Spatrick error)) {
80061da546Spatrick if (error.Success())
81061da546Spatrick return 0;
82061da546Spatrick }
83061da546Spatrick }
84061da546Spatrick return -1;
85061da546Spatrick }
86061da546Spatrick
DoWriteFPU(lldb::tid_t tid,int flavor,const FPU & fpu)87061da546Spatrick int RegisterContextKDP_x86_64::DoWriteFPU(lldb::tid_t tid, int flavor,
88061da546Spatrick const FPU &fpu) {
89061da546Spatrick ProcessSP process_sp(CalculateProcess());
90061da546Spatrick if (process_sp) {
91061da546Spatrick Status error;
92061da546Spatrick if (static_cast<ProcessKDP *>(process_sp.get())
93061da546Spatrick ->GetCommunication()
94061da546Spatrick .SendRequestWriteRegisters(tid, FPURegSet, &fpu, sizeof(fpu),
95061da546Spatrick error)) {
96061da546Spatrick if (error.Success())
97061da546Spatrick return 0;
98061da546Spatrick }
99061da546Spatrick }
100061da546Spatrick return -1;
101061da546Spatrick }
102061da546Spatrick
DoWriteEXC(lldb::tid_t tid,int flavor,const EXC & exc)103061da546Spatrick int RegisterContextKDP_x86_64::DoWriteEXC(lldb::tid_t tid, int flavor,
104061da546Spatrick const EXC &exc) {
105061da546Spatrick ProcessSP process_sp(CalculateProcess());
106061da546Spatrick if (process_sp) {
107061da546Spatrick Status error;
108061da546Spatrick if (static_cast<ProcessKDP *>(process_sp.get())
109061da546Spatrick ->GetCommunication()
110061da546Spatrick .SendRequestWriteRegisters(tid, EXCRegSet, &exc, sizeof(exc),
111061da546Spatrick error)) {
112061da546Spatrick if (error.Success())
113061da546Spatrick return 0;
114061da546Spatrick }
115061da546Spatrick }
116061da546Spatrick return -1;
117061da546Spatrick }
118