xref: /openbsd-src/gnu/llvm/lldb/source/Plugins/Process/MacOSX-Kernel/RegisterContextKDP_x86_64.cpp (revision be691f3bb6417f04a68938fadbcaee2d5795e764)
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