Signed-off-by: Mihail Abakumov <mikhail.abaku...@ispras.ru> Signed-off-by: Pavel Dovgalyuk <dovga...@ispras.ru> Signed-off-by: Dmitriy Koltunov <koltu...@ispras.ru> --- include/exec/windbgstub-utils.h | 1 + windbgstub-utils.c | 23 +++++++++++++++++++++++ windbgstub.c | 4 ++++ 3 files changed, 28 insertions(+)
diff --git a/include/exec/windbgstub-utils.h b/include/exec/windbgstub-utils.h index d390bc1dfe..e76bf1ad6f 100755 --- a/include/exec/windbgstub-utils.h +++ b/include/exec/windbgstub-utils.h @@ -115,6 +115,7 @@ void kd_api_read_io_space(CPUState *cpu, PacketData *pd); void kd_api_write_io_space(CPUState *cpu, PacketData *pd); void kd_api_read_physical_memory(CPUState *cpu, PacketData *pd); void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd); +void kd_api_get_version(CPUState *cpu, PacketData *pd); void kd_api_unsupported(CPUState *cpu, PacketData *pd); SizedBuf kd_gen_exception_sc(CPUState *cpu); diff --git a/windbgstub-utils.c b/windbgstub-utils.c index 1fba54f9d9..171097eba2 100755 --- a/windbgstub-utils.c +++ b/windbgstub-utils.c @@ -1198,6 +1198,29 @@ void kd_api_write_physical_memory(CPUState *cpu, PacketData *pd) mem->ActualBytesWritten = ldl_p(&len); } +void kd_api_get_version(CPUState *cpu, PacketData *pd) +{ + DBGKD_GET_VERSION64 *version; + int err = cpu_memory_rw_debug(cpu, kd->version.addr, + PTR(pd->m64) + 0x10, + M64_SIZE - 0x10, 0); + if (!err) { + version = (DBGKD_GET_VERSION64 *) (PTR(pd->m64) + 0x10); + + version->MajorVersion = lduw_p(&version->MajorVersion); + version->MinorVersion = lduw_p(&version->MinorVersion); + version->Flags = lduw_p(&version->Flags); + version->MachineType = lduw_p(&version->MachineType); + version->Unused[0] = lduw_p(version->Unused); + version->KernBase = ldq_p(&version->KernBase); + version->PsLoadedModuleList = ldq_p(&version->PsLoadedModuleList); + version->DebuggerDataList = ldq_p(&version->DebuggerDataList); + } else { + pd->m64.ReturnStatus = STATUS_UNSUCCESSFUL; + WINDBG_ERROR("get_version: " FMT_ERR, err); + } +} + void kd_api_unsupported(CPUState *cpu, PacketData *pd) { WINDBG_ERROR("Catched unimplemented api %s", diff --git a/windbgstub.c b/windbgstub.c index 118e9dd697..b37393d93c 100755 --- a/windbgstub.c +++ b/windbgstub.c @@ -190,6 +190,10 @@ static void windbg_process_manipulate_packet(ParsingContext *ctx) kd_api_write_physical_memory(cpu, &ctx->data); break; + case DbgKdGetVersionApi: + kd_api_get_version(cpu, &ctx->data); + break; + case DbgKdClearAllInternalBreakpointsApi: return;