Corrected issues with DbgPrint & _vnsprintf.
This commit is contained in:
parent
fbaaebdb41
commit
e5bfe7264b
|
@ -25,13 +25,6 @@ namespace kernel {
|
||||||
namespace xboxkrnl {
|
namespace xboxkrnl {
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
FAT_INVALID = 0,
|
|
||||||
FAT_VALUE,
|
|
||||||
FAT_POINTER,
|
|
||||||
FAT_EXTRA,
|
|
||||||
} FORMAT_ARGUMENT_TYPE;
|
|
||||||
|
|
||||||
// TODO: clean me up!
|
// TODO: clean me up!
|
||||||
SHIM_CALL DbgPrint_shim(
|
SHIM_CALL DbgPrint_shim(
|
||||||
xe_ppc_state_t* ppc_state, KernelState* state) {
|
xe_ppc_state_t* ppc_state, KernelState* state) {
|
||||||
|
@ -83,7 +76,6 @@ SHIM_CALL DbgPrint_shim(
|
||||||
}
|
}
|
||||||
|
|
||||||
int arg_extras = 0;
|
int arg_extras = 0;
|
||||||
FORMAT_ARGUMENT_TYPE arg_type;
|
|
||||||
|
|
||||||
// skip width
|
// skip width
|
||||||
if (*end == '*') {
|
if (*end == '*') {
|
||||||
|
@ -120,9 +112,9 @@ SHIM_CALL DbgPrint_shim(
|
||||||
}
|
}
|
||||||
|
|
||||||
// get length
|
// get length
|
||||||
int arg_size;
|
int arg_size = 0;
|
||||||
|
|
||||||
if (*format == 'h') {
|
if (*end == 'h') {
|
||||||
++end;
|
++end;
|
||||||
arg_size = 4;
|
arg_size = 4;
|
||||||
if (*end == 'h') {
|
if (*end == 'h') {
|
||||||
|
@ -174,14 +166,15 @@ SHIM_CALL DbgPrint_shim(
|
||||||
*end == 'A' ||
|
*end == 'A' ||
|
||||||
*end == 'c') {
|
*end == 'c') {
|
||||||
char local[512];
|
char local[512];
|
||||||
strncpy(local, start, end + 1 - start);
|
local[0] = '\0';
|
||||||
|
strncat(local, start, end + 1 - start);
|
||||||
|
|
||||||
XEASSERT(arg_size == 8 || arg_size == 4);
|
XEASSERT(arg_size == 8 || arg_size == 4);
|
||||||
if (arg_size == 8) {
|
if (arg_size == 8) {
|
||||||
if (arg_extras == 0) {
|
if (arg_extras == 0) {
|
||||||
uint64_t value = arg_index < 7
|
uint64_t value = arg_index < 7
|
||||||
? SHIM_GET_ARG_64(1 + arg_index)
|
? SHIM_GET_ARG_64(1 + arg_index)
|
||||||
: SHIM_MEM_64(SHIM_GPR_32(1) + ((arg_index - 7) * 8));
|
: SHIM_MEM_32(SHIM_GPR_32(1) + 24 + ((1 + arg_index) * 8));
|
||||||
int result = sprintf(b, local, value);
|
int result = sprintf(b, local, value);
|
||||||
b += result;
|
b += result;
|
||||||
arg_index++;
|
arg_index++;
|
||||||
|
@ -194,7 +187,7 @@ SHIM_CALL DbgPrint_shim(
|
||||||
if (arg_extras == 0) {
|
if (arg_extras == 0) {
|
||||||
uint64_t value = arg_index < 7
|
uint64_t value = arg_index < 7
|
||||||
? SHIM_GET_ARG_64(1 + arg_index)
|
? SHIM_GET_ARG_64(1 + arg_index)
|
||||||
: SHIM_MEM_64(SHIM_GPR_32(1) + ((arg_index - 7) * 8));
|
: SHIM_MEM_32(SHIM_GPR_32(1) + 24 + ((1 + arg_index) * 8));
|
||||||
int result = sprintf(b, local, (uint32_t)value);
|
int result = sprintf(b, local, (uint32_t)value);
|
||||||
b += result;
|
b += result;
|
||||||
arg_index++;
|
arg_index++;
|
||||||
|
@ -204,17 +197,18 @@ SHIM_CALL DbgPrint_shim(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (*format == 's' ||
|
else if (*end == 's' ||
|
||||||
*format == 'p' ||
|
*end == 'p' ||
|
||||||
*format == 'n') {
|
*end == 'n') {
|
||||||
char local[512];
|
char local[512];
|
||||||
strncpy(local, start, end + 1 - start);
|
local[0] = '\0';
|
||||||
|
strncat(local, start, end + 1 - start);
|
||||||
|
|
||||||
XEASSERT(arg_size == 0);
|
XEASSERT(arg_size == 0);
|
||||||
if (arg_extras == 0) {
|
if (arg_extras == 0) {
|
||||||
uint32_t value = arg_index < 7
|
uint32_t value = arg_index < 7
|
||||||
? SHIM_GET_ARG_32(1 + arg_index)
|
? SHIM_GET_ARG_32(1 + arg_index)
|
||||||
: SHIM_MEM_32(SHIM_GPR_32(1) + ((arg_index - 7) * 8));
|
: (uint32_t)SHIM_MEM_64(SHIM_GPR_32(1) + 16 + ((1 + arg_index) * 8));
|
||||||
const char *pointer = (const char *)SHIM_MEM_ADDR(value);
|
const char *pointer = (const char *)SHIM_MEM_ADDR(value);
|
||||||
int result = sprintf(b, local, pointer);
|
int result = sprintf(b, local, pointer);
|
||||||
b += result;
|
b += result;
|
||||||
|
@ -228,6 +222,8 @@ SHIM_CALL DbgPrint_shim(
|
||||||
XEASSERT(false);
|
XEASSERT(false);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
format = end;
|
||||||
}
|
}
|
||||||
*b++ = '\0';
|
*b++ = '\0';
|
||||||
|
|
||||||
|
|
|
@ -333,13 +333,6 @@ SHIM_CALL RtlUnicodeStringToAnsiString_shim(
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
FAT_INVALID = 0,
|
|
||||||
FAT_VALUE,
|
|
||||||
FAT_POINTER,
|
|
||||||
FAT_EXTRA,
|
|
||||||
} FORMAT_ARGUMENT_TYPE;
|
|
||||||
|
|
||||||
// TODO: clean me up!
|
// TODO: clean me up!
|
||||||
SHIM_CALL _vsnprintf_shim(
|
SHIM_CALL _vsnprintf_shim(
|
||||||
xe_ppc_state_t* ppc_state, KernelState* state) {
|
xe_ppc_state_t* ppc_state, KernelState* state) {
|
||||||
|
@ -395,7 +388,6 @@ SHIM_CALL _vsnprintf_shim(
|
||||||
}
|
}
|
||||||
|
|
||||||
int arg_extras = 0;
|
int arg_extras = 0;
|
||||||
FORMAT_ARGUMENT_TYPE arg_type;
|
|
||||||
|
|
||||||
// skip width
|
// skip width
|
||||||
if (*end == '*') {
|
if (*end == '*') {
|
||||||
|
@ -432,9 +424,9 @@ SHIM_CALL _vsnprintf_shim(
|
||||||
}
|
}
|
||||||
|
|
||||||
// get length
|
// get length
|
||||||
int arg_size;
|
int arg_size = 0;
|
||||||
|
|
||||||
if (*format == 'h') {
|
if (*end == 'h') {
|
||||||
++end;
|
++end;
|
||||||
arg_size = 4;
|
arg_size = 4;
|
||||||
if (*end == 'h') {
|
if (*end == 'h') {
|
||||||
|
@ -486,7 +478,8 @@ SHIM_CALL _vsnprintf_shim(
|
||||||
*end == 'A' ||
|
*end == 'A' ||
|
||||||
*end == 'c') {
|
*end == 'c') {
|
||||||
char local[512];
|
char local[512];
|
||||||
strncpy(local, start, end + 1 - start);
|
local[0] = '\0';
|
||||||
|
strncat(local, start, end + 1 - start);
|
||||||
|
|
||||||
XEASSERT(arg_size == 8 || arg_size == 4);
|
XEASSERT(arg_size == 8 || arg_size == 4);
|
||||||
if (arg_size == 8) {
|
if (arg_size == 8) {
|
||||||
|
@ -502,8 +495,8 @@ SHIM_CALL _vsnprintf_shim(
|
||||||
}
|
}
|
||||||
else if (arg_size == 4) {
|
else if (arg_size == 4) {
|
||||||
if (arg_extras == 0) {
|
if (arg_extras == 0) {
|
||||||
uint64_t value = SHIM_MEM_64(arg_ptr + (arg_index * 8)); // TODO: check if this is correct...
|
uint32_t value = (uint32_t)SHIM_MEM_64(arg_ptr + (arg_index * 8)); // TODO: check if this is correct...
|
||||||
int result = sprintf(b, local, (uint32_t)value);
|
int result = sprintf(b, local, value);
|
||||||
b += result;
|
b += result;
|
||||||
arg_index++;
|
arg_index++;
|
||||||
}
|
}
|
||||||
|
@ -512,15 +505,16 @@ SHIM_CALL _vsnprintf_shim(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (*format == 's' ||
|
else if (*end == 's' ||
|
||||||
*format == 'p' ||
|
*end == 'p' ||
|
||||||
*format == 'n') {
|
*end == 'n') {
|
||||||
char local[512];
|
char local[512];
|
||||||
strncpy(local, start, end + 1 - start);
|
local[0] = '\0';
|
||||||
|
strncat(local, start, end + 1 - start);
|
||||||
|
|
||||||
XEASSERT(arg_size == 0);
|
XEASSERT(arg_size == 0);
|
||||||
if (arg_extras == 0) {
|
if (arg_extras == 0) {
|
||||||
uint64_t value = SHIM_MEM_64(arg_ptr + (arg_index * 8)); // TODO: check if this is correct...
|
uint32_t value = (uint32_t)SHIM_MEM_64(arg_ptr + (arg_index * 8)); // TODO: check if this is correct...
|
||||||
const char *pointer = (const char *)SHIM_MEM_ADDR(value);
|
const char *pointer = (const char *)SHIM_MEM_ADDR(value);
|
||||||
int result = sprintf(b, local, pointer);
|
int result = sprintf(b, local, pointer);
|
||||||
b += result;
|
b += result;
|
||||||
|
@ -534,6 +528,7 @@ SHIM_CALL _vsnprintf_shim(
|
||||||
XEASSERT(false);
|
XEASSERT(false);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
format = end;
|
||||||
}
|
}
|
||||||
*b++ = '\0';
|
*b++ = '\0';
|
||||||
SHIM_SET_RETURN((uint32_t)(b - buffer));
|
SHIM_SET_RETURN((uint32_t)(b - buffer));
|
||||||
|
|
Loading…
Reference in New Issue