| 1 | //===-- RegisterContextPOSIXCore_x86_64.cpp -------------------------------===// |
| 2 | // |
| 3 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| 4 | // See https://llvm.org/LICENSE.txt for license information. |
| 5 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| 6 | // |
| 7 | //===----------------------------------------------------------------------===// |
| 8 | |
| 9 | #include "RegisterContextPOSIXCore_x86_64.h" |
| 10 | #include "lldb/Target/Thread.h" |
| 11 | #include "lldb/Utility/DataExtractor.h" |
| 12 | #include "lldb/Utility/RegisterValue.h" |
| 13 | |
| 14 | using namespace lldb_private; |
| 15 | |
| 16 | RegisterContextCorePOSIX_x86_64::( |
| 17 | Thread &thread, RegisterInfoInterface *register_info, |
| 18 | const DataExtractor &gpregset, llvm::ArrayRef<CoreNote> notes) |
| 19 | : RegisterContextPOSIX_x86(thread, 0, register_info) { |
| 20 | size_t size, len; |
| 21 | |
| 22 | size = GetGPRSize(); |
| 23 | m_gpregset.reset(p: new uint8_t[size]); |
| 24 | len = |
| 25 | gpregset.ExtractBytes(offset: 0, length: size, dst_byte_order: lldb::eByteOrderLittle, dst: m_gpregset.get()); |
| 26 | if (len != size) |
| 27 | m_gpregset.reset(); |
| 28 | |
| 29 | DataExtractor fpregset = getRegset( |
| 30 | Notes: notes, Triple: register_info->GetTargetArchitecture().GetTriple(), RegsetDescs: FPR_Desc); |
| 31 | size = sizeof(FXSAVE); |
| 32 | m_fpregset.reset(p: new uint8_t[size]); |
| 33 | len = |
| 34 | fpregset.ExtractBytes(offset: 0, length: size, dst_byte_order: lldb::eByteOrderLittle, dst: m_fpregset.get()); |
| 35 | if (len != size) |
| 36 | m_fpregset.reset(); |
| 37 | } |
| 38 | |
| 39 | bool RegisterContextCorePOSIX_x86_64::ReadGPR() { |
| 40 | return m_gpregset != nullptr; |
| 41 | } |
| 42 | |
| 43 | bool RegisterContextCorePOSIX_x86_64::ReadFPR() { |
| 44 | return m_fpregset != nullptr; |
| 45 | } |
| 46 | |
| 47 | bool RegisterContextCorePOSIX_x86_64::WriteGPR() { |
| 48 | assert(0); |
| 49 | return false; |
| 50 | } |
| 51 | |
| 52 | bool RegisterContextCorePOSIX_x86_64::WriteFPR() { |
| 53 | assert(0); |
| 54 | return false; |
| 55 | } |
| 56 | |
| 57 | bool RegisterContextCorePOSIX_x86_64::ReadRegister(const RegisterInfo *reg_info, |
| 58 | RegisterValue &value) { |
| 59 | const uint8_t *src; |
| 60 | size_t offset; |
| 61 | const size_t fxsave_offset = reg_info->byte_offset - GetFXSAVEOffset(); |
| 62 | // make the offset relative to the beginning of the FXSAVE structure because |
| 63 | // this is the data that we have (not the entire UserArea) |
| 64 | |
| 65 | if (m_gpregset && reg_info->byte_offset < GetGPRSize()) { |
| 66 | src = m_gpregset.get(); |
| 67 | offset = reg_info->byte_offset; |
| 68 | } else if (m_fpregset && fxsave_offset < sizeof(FXSAVE)) { |
| 69 | src = m_fpregset.get(); |
| 70 | offset = fxsave_offset; |
| 71 | } else { |
| 72 | return false; |
| 73 | } |
| 74 | |
| 75 | Status error; |
| 76 | value.SetFromMemoryData(reg_info: *reg_info, src: src + offset, src_len: reg_info->byte_size, |
| 77 | src_byte_order: lldb::eByteOrderLittle, error); |
| 78 | |
| 79 | return error.Success(); |
| 80 | } |
| 81 | |
| 82 | bool RegisterContextCorePOSIX_x86_64::ReadAllRegisterValues( |
| 83 | lldb::WritableDataBufferSP &data_sp) { |
| 84 | return false; |
| 85 | } |
| 86 | |
| 87 | bool RegisterContextCorePOSIX_x86_64::WriteRegister( |
| 88 | const RegisterInfo *reg_info, const RegisterValue &value) { |
| 89 | return false; |
| 90 | } |
| 91 | |
| 92 | bool RegisterContextCorePOSIX_x86_64::WriteAllRegisterValues( |
| 93 | const lldb::DataBufferSP &data_sp) { |
| 94 | return false; |
| 95 | } |
| 96 | |
| 97 | bool RegisterContextCorePOSIX_x86_64::HardwareSingleStep(bool enable) { |
| 98 | return false; |
| 99 | } |
| 100 | |