notaz.gp2x.de
/
pcsx_rearmed.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
(libretro) Library version is too long to show in RGUI
[pcsx_rearmed.git]
/
libpcsxcore
/
psxbios.c
diff --git
a/libpcsxcore/psxbios.c
b/libpcsxcore/psxbios.c
index
cad69b3
..
12c17ef
100644
(file)
--- a/
libpcsxcore/psxbios.c
+++ b/
libpcsxcore/psxbios.c
@@
-25,6
+25,8
@@
#include "psxbios.h"
#include "psxhw.h"
#include "psxbios.h"
#include "psxhw.h"
+#include "gpu.h"
+#include <zlib.h>
#undef SysPrintf
#define SysPrintf if (Config.PsxOut) printf
#undef SysPrintf
#define SysPrintf if (Config.PsxOut) printf
@@
-804,8
+806,8
@@
void psxBios_qsort() { // 0x31
}
void psxBios_malloc() { // 0x33
}
void psxBios_malloc() { // 0x33
- unsigned int *chunk, *newchunk;
- unsigned int dsize, csize, cstat;
+ unsigned int *chunk, *newchunk
= NULL
;
+ unsigned int dsize
= 0
, csize, cstat;
int colflag;
#ifdef PSXBIOS_LOG
PSXBIOS_LOG("psxBios_%s\n", biosA0n[0x33]);
int colflag;
#ifdef PSXBIOS_LOG
PSXBIOS_LOG("psxBios_%s\n", biosA0n[0x33]);
@@
-875,7
+877,7
@@
void psxBios_malloc() { // 0x33
// split free chunk
*chunk = SWAP32(dsize);
newchunk = (u32*)((uptr)chunk + dsize + 4);
// split free chunk
*chunk = SWAP32(dsize);
newchunk = (u32*)((uptr)chunk + dsize + 4);
- *newchunk = SWAP32((
csize - dsize - 4) & 0xfffffffc
| 1);
+ *newchunk = SWAP32((
(csize - dsize - 4) & 0xfffffffc)
| 1);
}
// return pointer to allocated memory
}
// return pointer to allocated memory
@@
-938,7
+940,7
@@
void psxBios_InitHeap() { // 0x39
heap_end = (u32 *)((u8 *)heap_addr + size);
*heap_addr = SWAP32(size | 1);
heap_end = (u32 *)((u8 *)heap_addr + size);
*heap_addr = SWAP32(size | 1);
- SysPrintf("InitHeap %x,%x : %x %x\n",a0,a1, (
uptr)heap_addr-(uptr)psxM
, size);
+ SysPrintf("InitHeap %x,%x : %x %x\n",a0,a1, (
int)((uptr)heap_addr-(uptr)psxM)
, size);
pc0 = ra;
}
pc0 = ra;
}
@@
-988,7
+990,7
@@
_start:
case 'g': case 'G':
ptmp += sprintf(ptmp, tmp2, (double)psxMu32(sp + n * 4)); n++; break;
case 'p':
case 'g': case 'G':
ptmp += sprintf(ptmp, tmp2, (double)psxMu32(sp + n * 4)); n++; break;
case 'p':
- case 'i':
+ case 'i':
case 'u':
case 'd': case 'D':
case 'o': case 'O':
case 'x': case 'X':
case 'd': case 'D':
case 'o': case 'O':
case 'x': case 'X':
@@
-1010,7
+1012,7
@@
_start:
memcpy((char*)PSXM(sp), save, 4 * 4);
memcpy((char*)PSXM(sp), save, 4 * 4);
- SysPrintf(tmp);
+ SysPrintf(
"%s",
tmp);
pc0 = ra;
}
pc0 = ra;
}
@@
-1118,6
+1120,7
@@
void psxBios_mem2vram() { // 0x47
void psxBios_SendGPU() { // 0x48
GPU_writeStatus(a0);
void psxBios_SendGPU() { // 0x48
GPU_writeStatus(a0);
+ gpuSyncPluginSR();
pc0 = ra;
}
pc0 = ra;
}
@@
-1818,7
+1821,7
@@
void psxBios_putchar() { // 3d
}
void psxBios_puts() { // 3e/3f
}
void psxBios_puts() { // 3e/3f
- SysPrintf(Ra0);
+ SysPrintf(
"%s",
Ra0);
pc0 = ra;
}
pc0 = ra;
}
@@
-1834,7
+1837,8
@@
int nfile;
if ((*ptr & 0xF0) != 0x50) continue; \
ptr+= 0xa; \
if (pfile[0] == 0) { \
if ((*ptr & 0xF0) != 0x50) continue; \
ptr+= 0xa; \
if (pfile[0] == 0) { \
- strcpy(dir->name, ptr); \
+ strncpy(dir->name, ptr, sizeof(dir->name)); \
+ dir->name[sizeof(dir->name) - 1] = '\0'; \
} else for (i=0; i<20; i++) { \
if (pfile[i] == ptr[i]) { \
dir->name[i] = ptr[i]; \
} else for (i=0; i<20; i++) { \
if (pfile[i] == ptr[i]) { \
dir->name[i] = ptr[i]; \