Corrected issues with DbgPrint & _vnsprintf.

This commit is contained in:
Rick Gibbed 2013-06-02 09:44:31 -07:00
parent fbaaebdb41
commit e5bfe7264b
2 changed files with 27 additions and 36 deletions

View File

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

View File

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