aboutsummaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authorspicyjpeg <88942473+spicyjpeg@users.noreply.github.com>2022-06-27 22:19:18 +0200
committerspicyjpeg <88942473+spicyjpeg@users.noreply.github.com>2022-06-27 22:19:18 +0200
commit578181ace1374e72cb93d69d2c201ce7a0a2300c (patch)
tree8e91212c966bf95bd7c34901e56dad7f81b9af57 /tools
parentef776e728cfa67fbca38bb375152b336fa0b5200 (diff)
downloadpsn00bsdk-578181ace1374e72cb93d69d2c201ce7a0a2300c.tar.gz
Add 8 MB RAM support and customizable _start stub
Diffstat (limited to 'tools')
-rw-r--r--tools/util/elf2x.c44
1 files changed, 22 insertions, 22 deletions
diff --git a/tools/util/elf2x.c b/tools/util/elf2x.c
index 9a7c126..38ed60d 100644
--- a/tools/util/elf2x.c
+++ b/tools/util/elf2x.c
@@ -154,31 +154,31 @@ int main(int argc, char** argv) {
}
- exe_tsize = (exe_haddr-exe_taddr);
- exe_tsize += prg_heads[head.prg_entry_count-1].p_filesz;
+ exe_tsize = (exe_haddr - exe_taddr);
+ exe_tsize += prg_heads[head.prg_entry_count - 1].p_filesz;
- if( !quiet ) {
-
- printf( "pc:%08x t_addr:%08x t_size:%d\n",
- head.prg_entry_addr, exe_taddr, exe_tsize );
-
- }
+ if (!quiet)
+ printf(
+ "pc:%08x t_addr:%08x t_size:%d\n",
+ head.prg_entry_addr,
+ exe_taddr,
+ exe_tsize
+ );
// Check if load address is appropriate in main RAM locations
- if( ( ( exe_taddr>>24 ) == 0x0 ) || ( ( exe_taddr>>24 ) == 0x80 ) ||
- ( ( exe_taddr>>24 ) == 0xA0 ) ) {
-
- if( ( exe_taddr&0x00ffffff ) < 65536 ) {
-
- printf( "Warning: Program text address overlaps kernel area!\n" );
-
- }
-
- }
-
-
- // Pad out the size to multiples of 2KB
- exe_tsize = 2048*((exe_tsize+2047)/2048);
+ if (
+ ((exe_taddr >= 0x00000000) && (exe_taddr < 0x00001000)) ||
+ ((exe_taddr >= 0x80000000) && (exe_taddr < 0x80001000)) ||
+ ((exe_taddr >= 0xa0000000) && (exe_taddr < 0xa0001000))
+ )
+ printf("WARNING: program text address overlaps kernel area!\n");
+
+ // Throw warning if executable is larger than 2MB
+ if (exe_tsize > 0x1f0000)
+ printf("WARNING: executable is larger than available RAM on a stock console!\n");
+
+ // Pad out the size to multiples of 2KB (CD sector size)
+ exe_tsize = ((exe_tsize + 2047) / 2048) * 2048;
// Load the binary data
binary = (unsigned char*)malloc( exe_tsize );