Fixed updxell crashing...

Signed-off-by: Swizzy <swizzy@hotmail.co.uk>
This commit is contained in:
Swizzy 2013-07-13 00:44:45 +02:00 committed by tuxuser
parent 812ef5f554
commit 53ebe50411

View File

@ -148,12 +148,13 @@ int launch_file(void * addr, unsigned len, int filetype){
printf(" * Loading kboot.conf ...\n");
ret = try_kbootconf(addr,len);
break;
case TYPE_UPDXELL:
if (memcmp(addr + XELL_FOOTER_OFFSET, XELL_FOOTER, XELL_FOOTER_LENGTH) || len != XELL_SIZE)
return -1;
printf(" * Loading UpdXeLL binary...\n");
ret = updateXeLL(addr,len);
break;
// This shit is broken!
// case TYPE_UPDXELL:
//if (memcmp(addr + XELL_FOOTER_OFFSET, XELL_FOOTER, XELL_FOOTER_LENGTH) || len != XELL_SIZE)
// return -1;
// printf(" * Loading UpdXeLL binary...\n");
// ret = updateXeLL(addr,len);
// break;
default:
printf("! Unsupported filetype supplied!\n");
}
@ -168,6 +169,12 @@ int try_load_file(char *filename, int filetype)
return -1;
}
if (filetype == TYPE_UPDXELL)
{
updateXeLL(filename);
return -1;
}
wait_and_cleanup_line();
printf("Trying %s...\r",filename);
@ -178,12 +185,20 @@ int try_load_file(char *filename, int filetype)
}
struct stat s;
fstat(f, &s);
if (fstat(f, &s) != 0) // Make sure FStat actually works...
return -1;
long size = s.st_size;
if (size <= 0)
{
close(f);
return -1;
}
int size = s.st_size;
void * buf=malloc(size);
printf("\n * '%s' found, loading %d...\n",filename,size);
printf("\n * '%s' found, loading %ld...\n",filename,size);
int r = read(f, buf, size);
if (r < 0)
{