mirror of
https://github.com/fail0verflow/hbc.git
synced 2025-01-12 10:09:09 +01:00
89 lines
1.5 KiB
C
89 lines
1.5 KiB
C
#include <stdio.h>
|
|
#include <stdarg.h>
|
|
|
|
#include <ogcsys.h>
|
|
#include <ogc/machine/processor.h>
|
|
|
|
#include "../config.h"
|
|
|
|
#ifdef DEBUG_APP
|
|
|
|
//#define DEBUG_MEMSTATS
|
|
|
|
static int gprintf_enabled = 1;
|
|
|
|
void gprintf_enable(int enable) {
|
|
gprintf_enabled = enable;
|
|
}
|
|
|
|
int gprintf(const char *format, ...)
|
|
{
|
|
va_list ap;
|
|
u32 level;
|
|
int ret;
|
|
|
|
if (!gprintf_enabled)
|
|
return 0;
|
|
|
|
level = IRQ_Disable();
|
|
va_start(ap, format);
|
|
ret = vprintf(format, ap);
|
|
va_end(ap);
|
|
IRQ_Restore(level);
|
|
|
|
return ret;
|
|
}
|
|
|
|
/********* you know you love it **********/
|
|
static char ascii(char s) {
|
|
if(s < 0x20) return '.';
|
|
if(s > 0x7E) return '.';
|
|
return s;
|
|
}
|
|
|
|
void hexdump(const void *d, int len) {
|
|
u8 *data;
|
|
int i, off;
|
|
data = (u8*)d;
|
|
for (off=0; off<len; off += 16) {
|
|
gprintf("%08x ",off);
|
|
for(i=0; i<16; i++)
|
|
if((i+off)>=len) gprintf(" ");
|
|
else gprintf("%02x ",data[off+i]);
|
|
|
|
gprintf(" ");
|
|
for(i=0; i<16; i++)
|
|
if((i+off)>=len) gprintf(" ");
|
|
else gprintf("%c",ascii(data[off+i]));
|
|
gprintf("\n");
|
|
}
|
|
}
|
|
/********* you know you love it **********/
|
|
|
|
#ifndef UINT_MAX
|
|
#define UINT_MAX ((u32)((s32)-1))
|
|
#endif
|
|
void memstats(int reset) {
|
|
#ifdef DEBUG_MEMSTATS
|
|
static u32 min_free = UINT_MAX;
|
|
static u32 temp_free;
|
|
static u32 level;
|
|
|
|
if (reset)
|
|
min_free = UINT_MAX;
|
|
|
|
_CPU_ISR_Disable(level);
|
|
|
|
temp_free = (u32) SYS_GetArena2Hi() - (u32) SYS_GetArena2Lo();
|
|
|
|
_CPU_ISR_Restore(level);
|
|
|
|
if (temp_free < min_free) {
|
|
min_free = temp_free;
|
|
gprintf("MEM2 free: %8u\n", min_free);
|
|
}
|
|
#endif
|
|
}
|
|
|
|
#endif
|