1*f6aab3d8Srobert //===-- RegisterContextFreeBSDKernel_i386.cpp -----------------------------===//
2*f6aab3d8Srobert //
3*f6aab3d8Srobert // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*f6aab3d8Srobert // See https://llvm.org/LICENSE.txt for license information.
5*f6aab3d8Srobert // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*f6aab3d8Srobert //
7*f6aab3d8Srobert //===----------------------------------------------------------------------===//
8*f6aab3d8Srobert
9*f6aab3d8Srobert #include "RegisterContextFreeBSDKernel_i386.h"
10*f6aab3d8Srobert
11*f6aab3d8Srobert #include "lldb/Target/Process.h"
12*f6aab3d8Srobert #include "lldb/Target/Thread.h"
13*f6aab3d8Srobert #include "lldb/Utility/RegisterValue.h"
14*f6aab3d8Srobert #include "llvm/Support/Endian.h"
15*f6aab3d8Srobert
16*f6aab3d8Srobert using namespace lldb;
17*f6aab3d8Srobert using namespace lldb_private;
18*f6aab3d8Srobert
RegisterContextFreeBSDKernel_i386(Thread & thread,RegisterInfoInterface * register_info,lldb::addr_t pcb_addr)19*f6aab3d8Srobert RegisterContextFreeBSDKernel_i386::RegisterContextFreeBSDKernel_i386(
20*f6aab3d8Srobert Thread &thread, RegisterInfoInterface *register_info, lldb::addr_t pcb_addr)
21*f6aab3d8Srobert : RegisterContextPOSIX_x86(thread, 0, register_info), m_pcb_addr(pcb_addr) {
22*f6aab3d8Srobert }
23*f6aab3d8Srobert
ReadGPR()24*f6aab3d8Srobert bool RegisterContextFreeBSDKernel_i386::ReadGPR() { return true; }
25*f6aab3d8Srobert
ReadFPR()26*f6aab3d8Srobert bool RegisterContextFreeBSDKernel_i386::ReadFPR() { return true; }
27*f6aab3d8Srobert
WriteGPR()28*f6aab3d8Srobert bool RegisterContextFreeBSDKernel_i386::WriteGPR() {
29*f6aab3d8Srobert assert(0);
30*f6aab3d8Srobert return false;
31*f6aab3d8Srobert }
32*f6aab3d8Srobert
WriteFPR()33*f6aab3d8Srobert bool RegisterContextFreeBSDKernel_i386::WriteFPR() {
34*f6aab3d8Srobert assert(0);
35*f6aab3d8Srobert return false;
36*f6aab3d8Srobert }
37*f6aab3d8Srobert
ReadRegister(const RegisterInfo * reg_info,RegisterValue & value)38*f6aab3d8Srobert bool RegisterContextFreeBSDKernel_i386::ReadRegister(
39*f6aab3d8Srobert const RegisterInfo *reg_info, RegisterValue &value) {
40*f6aab3d8Srobert if (m_pcb_addr == LLDB_INVALID_ADDRESS)
41*f6aab3d8Srobert return false;
42*f6aab3d8Srobert
43*f6aab3d8Srobert struct {
44*f6aab3d8Srobert llvm::support::ulittle32_t edi;
45*f6aab3d8Srobert llvm::support::ulittle32_t esi;
46*f6aab3d8Srobert llvm::support::ulittle32_t ebp;
47*f6aab3d8Srobert llvm::support::ulittle32_t esp;
48*f6aab3d8Srobert llvm::support::ulittle32_t ebx;
49*f6aab3d8Srobert llvm::support::ulittle32_t eip;
50*f6aab3d8Srobert } pcb;
51*f6aab3d8Srobert
52*f6aab3d8Srobert Status error;
53*f6aab3d8Srobert size_t rd =
54*f6aab3d8Srobert m_thread.GetProcess()->ReadMemory(m_pcb_addr, &pcb, sizeof(pcb), error);
55*f6aab3d8Srobert if (rd != sizeof(pcb))
56*f6aab3d8Srobert return false;
57*f6aab3d8Srobert
58*f6aab3d8Srobert uint32_t reg = reg_info->kinds[lldb::eRegisterKindLLDB];
59*f6aab3d8Srobert switch (reg) {
60*f6aab3d8Srobert #define REG(x) \
61*f6aab3d8Srobert case lldb_##x##_i386: \
62*f6aab3d8Srobert value = pcb.x; \
63*f6aab3d8Srobert break;
64*f6aab3d8Srobert
65*f6aab3d8Srobert REG(edi);
66*f6aab3d8Srobert REG(esi);
67*f6aab3d8Srobert REG(ebp);
68*f6aab3d8Srobert REG(esp);
69*f6aab3d8Srobert REG(eip);
70*f6aab3d8Srobert
71*f6aab3d8Srobert #undef REG
72*f6aab3d8Srobert
73*f6aab3d8Srobert default:
74*f6aab3d8Srobert return false;
75*f6aab3d8Srobert }
76*f6aab3d8Srobert
77*f6aab3d8Srobert return true;
78*f6aab3d8Srobert }
79*f6aab3d8Srobert
WriteRegister(const RegisterInfo * reg_info,const RegisterValue & value)80*f6aab3d8Srobert bool RegisterContextFreeBSDKernel_i386::WriteRegister(
81*f6aab3d8Srobert const RegisterInfo *reg_info, const RegisterValue &value) {
82*f6aab3d8Srobert return false;
83*f6aab3d8Srobert }
84