mirror of
https://github.com/Fledge68/WiiFlow_Lite.git
synced 2024-11-24 04:09:15 +01:00
550ac3356b
-set down wiiflows entry point from 0x80A00000 to 0x8062000 (saves ALOT of MEM1 for lists etc, so wiiflow should be able to read in alot of more games in for example plugin coverflow) -recompiled libjpeg -removed alot of annoying debug prints -made the trailer code faster
162 lines
3.2 KiB
C
162 lines
3.2 KiB
C
//Enable the line below to always write SD log
|
|
//#define sd_write_log
|
|
|
|
#include <gccore.h>
|
|
#include <malloc.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <sys/iosupport.h>
|
|
#include <stdarg.h>
|
|
|
|
#include "gecko.h"
|
|
#include "wifi_gecko.h"
|
|
#include "memory/mem2.hpp"
|
|
|
|
/* init-globals */
|
|
bool geckoinit = false;
|
|
bool textVideoInit = false;
|
|
bool bufferMessages = true;
|
|
bool WriteToSD = false;
|
|
char tmpfilebuffer[1024];
|
|
|
|
static ssize_t __out_write(struct _reent *r __attribute__((unused)), int fd __attribute__((unused)), const char *ptr, size_t len)
|
|
{
|
|
if(geckoinit && ptr)
|
|
{
|
|
u32 level;
|
|
level = IRQ_Disable();
|
|
usb_sendbuffer_safe(1, ptr, len);
|
|
IRQ_Restore(level);
|
|
}
|
|
return len;
|
|
}
|
|
|
|
static const devoptab_t gecko_out = {
|
|
"stdout", // device name
|
|
0, // size of file structure
|
|
NULL, // device open
|
|
NULL, // device close
|
|
__out_write, // device write
|
|
NULL, // device read
|
|
NULL, // device seek
|
|
NULL, // device fstat
|
|
NULL, // device stat
|
|
NULL, // device link
|
|
NULL, // device unlink
|
|
NULL, // device chdir
|
|
NULL, // device rename
|
|
NULL, // device mkdir
|
|
0, // dirStateSize
|
|
NULL, // device diropen_r
|
|
NULL, // device dirreset_r
|
|
NULL, // device dirnext_r
|
|
NULL, // device dirclose_r
|
|
NULL, // device statvfs_r
|
|
NULL, // device ftruncate_r
|
|
NULL, // device fsync_r
|
|
NULL, // device deviceData
|
|
NULL, // device chmod_r
|
|
NULL, // device fchmod_r
|
|
};
|
|
|
|
static void USBGeckoOutput()
|
|
{
|
|
devoptab_list[STD_OUT] = &gecko_out;
|
|
devoptab_list[STD_ERR] = &gecko_out;
|
|
}
|
|
|
|
static void WriteToFile(char* tmp, int len)
|
|
{
|
|
if(!bufferMessages)
|
|
return;
|
|
|
|
if((strlen(tmpfilebuffer) + len) < 1024)
|
|
strcat(tmpfilebuffer, tmp);
|
|
|
|
if(WriteToSD)
|
|
{
|
|
FILE *outfile = fopen("sd:/wiiflow.log", "a");
|
|
if(outfile)
|
|
{
|
|
fwrite(tmpfilebuffer, 1, strlen(tmpfilebuffer), outfile);
|
|
memset(tmpfilebuffer, 0, 1024);
|
|
fclose(outfile);
|
|
}
|
|
}
|
|
}
|
|
|
|
char gprintfBuffer[256];
|
|
void gprintf(const char *format, ...)
|
|
{
|
|
va_list va;
|
|
va_start(va, format);
|
|
int len = vsnprintf(gprintfBuffer, 255, format, va);
|
|
__out_write(NULL, 0, gprintfBuffer, len);
|
|
WifiGecko_Send(gprintfBuffer, len);
|
|
WriteToFile(gprintfBuffer, len);
|
|
va_end(va);
|
|
}
|
|
|
|
char ascii(char s)
|
|
{
|
|
if(s < 0x20)
|
|
return '.';
|
|
if(s > 0x7E)
|
|
return '.';
|
|
return s;
|
|
}
|
|
|
|
void ghexdump(void *d, int len)
|
|
{
|
|
u8 *data;
|
|
int i, off;
|
|
data = (u8*)d;
|
|
|
|
gprintf("\n 0 1 2 3 4 5 6 7 8 9 A B C D E F 0123456789ABCDEF");
|
|
gprintf("\n==== =============================================== ================\n");
|
|
|
|
for (off = 0; off < len; off += 16)
|
|
{
|
|
gprintf("%04x ",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");
|
|
}
|
|
}
|
|
|
|
const char *initstr = "USB Gecko inited.\n";
|
|
bool InitGecko()
|
|
{
|
|
if(geckoinit)
|
|
return geckoinit;
|
|
|
|
USBGeckoOutput();
|
|
memset(tmpfilebuffer, 0, 1024);
|
|
|
|
#ifdef sd_write_log
|
|
WriteToSD = true;
|
|
#endif
|
|
|
|
u32 geckoattached = usb_isgeckoalive(EXI_CHANNEL_1);
|
|
if(geckoattached)
|
|
{
|
|
geckoinit = true;
|
|
usb_flush(EXI_CHANNEL_1);
|
|
__out_write(NULL, 0, initstr, strlen(initstr));
|
|
}
|
|
return geckoinit;
|
|
}
|