mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-18 11:16:10 +00:00
thermosphere: add src/gdb to build list, fix subsequent warnings and errors
This commit is contained in:
parent
55c92b3ab1
commit
6becc5dc8a
6 changed files with 17 additions and 22 deletions
|
@ -49,7 +49,7 @@ endif
|
|||
#---------------------------------------------------------------------------------
|
||||
TARGET := $(notdir $(CURDIR))
|
||||
BUILD := build
|
||||
SOURCES := src src/platform $(PLATFORM_SOURCES)
|
||||
SOURCES := src src/platform src/gdb $(PLATFORM_SOURCES)
|
||||
DATA := data
|
||||
INCLUDES := include ../common/include
|
||||
|
||||
|
|
|
@ -93,7 +93,7 @@ typedef struct GDBContext {
|
|||
|
||||
char *commandData, *commandEnd;
|
||||
size_t lastSentPacketSize;
|
||||
char *buffer[GDB_BUF_LEN + 4];
|
||||
char buffer[GDB_BUF_LEN + 4];
|
||||
char *workBuffer;
|
||||
} GDBContext;
|
||||
|
||||
|
|
|
@ -7,11 +7,10 @@
|
|||
|
||||
#include <string.h>
|
||||
|
||||
#include "gdb/hio.h"
|
||||
#include "gdb/net.h"
|
||||
#include "gdb/mem.h"
|
||||
#include "gdb/debug.h"
|
||||
#include "fmt.h"
|
||||
#include "hio.h"
|
||||
#include "net.h"
|
||||
#include "mem.h"
|
||||
#include "debug.h"
|
||||
|
||||
bool GDB_FetchPackedHioRequest(GDBContext *ctx, u32 addr)
|
||||
{
|
||||
|
|
|
@ -48,7 +48,7 @@ u32 GDB_SearchMemory(bool *found, GDBContext *ctx, uintptr_t addr, size_t len, c
|
|||
{
|
||||
// Note: need to ensure GDB_WORK_BUF_LEN is at least 0x1000 bytes in size
|
||||
|
||||
char *buf = ctx->workBuffer;
|
||||
u8 *buf = (u8 *)ctx->workBuffer;
|
||||
size_t maxNbPages = GDB_WORK_BUF_LEN / 0x1000;
|
||||
uintptr_t curAddr = addr;
|
||||
|
||||
|
|
|
@ -20,13 +20,13 @@ GDB_DECLARE_HANDLER(ReadRegisters)
|
|||
{
|
||||
ENSURE(ctx->selectedThreadId == currentCoreCtx->coreId);
|
||||
|
||||
const ExceptionStackFrame *frame = currentCoreCtx->guestFrame;
|
||||
const FpuRegisterCache *fpuRegCache = fpuReadRegisters();
|
||||
ExceptionStackFrame *frame = currentCoreCtx->guestFrame;
|
||||
FpuRegisterCache *fpuRegCache = fpuReadRegisters();
|
||||
|
||||
char *buf = ctx->buffer + 1;
|
||||
size_t n = 0;
|
||||
|
||||
struct PACKED ALIGN(4) {
|
||||
struct {
|
||||
u64 sp;
|
||||
u64 pc;
|
||||
u32 cpsr;
|
||||
|
@ -35,7 +35,6 @@ GDB_DECLARE_HANDLER(ReadRegisters)
|
|||
.pc = frame->elr_el2,
|
||||
.cpsr = (u32)frame->spsr_el2,
|
||||
};
|
||||
static_assert(sizeof(cpuSprs) == 12, "sizeof(cpuSprs) != 12");
|
||||
|
||||
u32 fpuSprs[2] = {
|
||||
(u32)fpuRegCache->fpsr,
|
||||
|
@ -44,7 +43,7 @@ GDB_DECLARE_HANDLER(ReadRegisters)
|
|||
|
||||
|
||||
n += GDB_EncodeHex(buf + n, frame->x, sizeof(frame->x));
|
||||
n += GDB_EncodeHex(buf + n, &cpuSprs, sizeof(cpuSprs));
|
||||
n += GDB_EncodeHex(buf + n, &cpuSprs, 8+8+4);
|
||||
n += GDB_EncodeHex(buf + n, fpuRegCache->q, sizeof(fpuRegCache->q));
|
||||
n += GDB_EncodeHex(buf + n, fpuSprs, sizeof(fpuSprs));
|
||||
|
||||
|
@ -64,12 +63,11 @@ GDB_DECLARE_HANDLER(WriteRegisters)
|
|||
size_t n = 0;
|
||||
size_t m = 0;
|
||||
|
||||
struct PACKED ALIGN(4) {
|
||||
struct {
|
||||
u64 sp;
|
||||
u64 pc;
|
||||
u32 cpsr;
|
||||
} cpuSprs;
|
||||
static_assert(sizeof(cpuSprs) == 12, "sizeof(cpuSprs) != 12");
|
||||
|
||||
u32 fpuSprs[2];
|
||||
|
||||
|
@ -78,7 +76,7 @@ GDB_DECLARE_HANDLER(WriteRegisters)
|
|||
size_t sz;
|
||||
} info[4] = {
|
||||
{ frame->x, sizeof(frame->x) },
|
||||
{ &cpuSprs, sizeof(cpuSprs) },
|
||||
{ &cpuSprs, 8+8+4 },
|
||||
{ fpuRegCache->q, sizeof(fpuRegCache->q) },
|
||||
{ fpuSprs, sizeof(fpuSprs) },
|
||||
};
|
||||
|
@ -142,10 +140,9 @@ GDB_DECLARE_HANDLER(ReadRegister)
|
|||
{
|
||||
ENSURE(ctx->selectedThreadId == currentCoreCtx->coreId);
|
||||
|
||||
const ExceptionStackFrame *frame = currentCoreCtx->guestFrame;
|
||||
const FpuRegisterCache *fpuRegCache = NULL;
|
||||
ExceptionStackFrame *frame = currentCoreCtx->guestFrame;
|
||||
FpuRegisterCache *fpuRegCache = NULL;
|
||||
|
||||
char *buf = ctx->buffer + 1;
|
||||
unsigned long gdbRegNum;
|
||||
|
||||
if (GDB_ParseHexIntegerList(&gdbRegNum, ctx->commandData, 1, 0) == NULL) {
|
||||
|
@ -211,6 +208,5 @@ GDB_DECLARE_HANDLER(WriteRegister)
|
|||
fpuCommitRegisters();
|
||||
}
|
||||
|
||||
else
|
||||
return GDB_ReplyOk(ctx);
|
||||
}
|
||||
|
|
|
@ -25,7 +25,7 @@ static inline size_t guestReadMemory(uintptr_t addr, size_t size, void *buf)
|
|||
return guestReadWriteMemory(addr, size, buf, NULL);
|
||||
}
|
||||
|
||||
static inline size_t guestWriteMemory(uintptr_t addr, size_t size, void *buf)
|
||||
static inline size_t guestWriteMemory(uintptr_t addr, size_t size, const void *buf)
|
||||
{
|
||||
return guestReadWriteMemory(addr, size, NULL, buf);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue