thermosphere: add src/gdb to build list, fix subsequent warnings and errors

This commit is contained in:
TuxSH 2020-01-31 01:58:56 +00:00
parent 55c92b3ab1
commit 6becc5dc8a
6 changed files with 17 additions and 22 deletions

View file

@ -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

View file

@ -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;

View file

@ -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)
{

View file

@ -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;

View file

@ -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);
}

View file

@ -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);
}