#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