state files' location is now ~/.config/hpemu
This commit is contained in:
parent
f25ed5776e
commit
7562b83c44
9 changed files with 267 additions and 109 deletions
1
Makefile
1
Makefile
|
@ -21,6 +21,7 @@ dist/hpemu: src/bus.o \
|
||||||
src/files.o \
|
src/files.o \
|
||||||
src/ports.o \
|
src/ports.o \
|
||||||
src/rpl.o \
|
src/rpl.o \
|
||||||
|
src/config.o \
|
||||||
src/timers.o
|
src/timers.o
|
||||||
$(CC) $(CFLAGS) $(LIBS) -o $@ $+
|
$(CC) $(CFLAGS) $(LIBS) -o $@ $+
|
||||||
|
|
||||||
|
|
24
src/config.c
Normal file
24
src/config.c
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
Config config = {
|
||||||
|
.progname = "hpemu",
|
||||||
|
.real_speed = true,
|
||||||
|
.verbose = true,
|
||||||
|
};
|
||||||
|
|
||||||
|
void parse_args( int argc, char* argv[] )
|
||||||
|
{
|
||||||
|
while ( --argc ) {
|
||||||
|
argv++;
|
||||||
|
if ( argv[ 0 ][ 0 ] == '-' ) {
|
||||||
|
switch ( argv[ 0 ][ 1 ] ) {
|
||||||
|
case 't':
|
||||||
|
config.real_speed = true;
|
||||||
|
break;
|
||||||
|
case 'r':
|
||||||
|
config.real_speed = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
16
src/config.h
Normal file
16
src/config.h
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
#ifndef __CONFIG_H
|
||||||
|
#define __CONFIG_H
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
char* progname;
|
||||||
|
bool real_speed;
|
||||||
|
bool verbose;
|
||||||
|
} Config;
|
||||||
|
|
||||||
|
extern Config config;
|
||||||
|
|
||||||
|
void parse_args( int argc, char* argv[] );
|
||||||
|
|
||||||
|
#endif
|
|
@ -9,10 +9,10 @@
|
||||||
#include "bus.h"
|
#include "bus.h"
|
||||||
#include "timers.h"
|
#include "timers.h"
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
#include "gui.h"
|
|
||||||
#include "emulator.h"
|
#include "emulator.h"
|
||||||
#include "files.h"
|
#include "files.h"
|
||||||
#include "ports.h"
|
#include "ports.h"
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
#define MAX_DELTA 4000
|
#define MAX_DELTA 4000
|
||||||
|
|
||||||
|
@ -44,24 +44,25 @@ static int emulator_state = EMULATOR_RUN;
|
||||||
|
|
||||||
void emulator_set_state( int state ) { emulator_state = state; }
|
void emulator_set_state( int state ) { emulator_state = state; }
|
||||||
|
|
||||||
void emulator_init( void )
|
void emulator_init( char* fn_rom, char* fn_ram, char* fn_port1, char* fn_port2 )
|
||||||
{
|
{
|
||||||
static bool locked = false;
|
static bool locked = false;
|
||||||
|
|
||||||
rom_init( "./rom" );
|
get_absolute_working_dir_path( "hpemu" );
|
||||||
ram_init( "./ram" );
|
rom_init( fn_rom );
|
||||||
ports_init( "./port1", "./port2" );
|
ram_init( fn_ram );
|
||||||
|
ports_init( fn_port1, fn_port2 );
|
||||||
bus_init();
|
bus_init();
|
||||||
|
|
||||||
if ( !locked )
|
if ( !locked )
|
||||||
locked = true;
|
locked = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void emulator_exit( void )
|
void emulator_exit( char* fn_rom, char* fn_ram, char* fn_port1, char* fn_port2 )
|
||||||
{
|
{
|
||||||
rom_exit();
|
rom_exit();
|
||||||
ram_exit( "./ram" );
|
ram_exit( fn_ram );
|
||||||
ports_exit( "./port1", "./port2" );
|
ports_exit( fn_port1, fn_port2 );
|
||||||
bus_exit();
|
bus_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -120,7 +121,7 @@ bool emulator_run( void )
|
||||||
if ( !cpu.shutdown ) {
|
if ( !cpu.shutdown ) {
|
||||||
execute_instruction();
|
execute_instruction();
|
||||||
|
|
||||||
throttle( true );
|
throttle( config.real_speed || cpu.keyintp );
|
||||||
|
|
||||||
if ( emulator_state == EMULATOR_STEP ) {
|
if ( emulator_state == EMULATOR_STEP ) {
|
||||||
emulator_set_state( EMULATOR_STOP );
|
emulator_set_state( EMULATOR_STOP );
|
||||||
|
|
|
@ -8,8 +8,8 @@ enum EmulatorStates { EMULATOR_STOP, EMULATOR_STEP, EMULATOR_RUN };
|
||||||
extern volatile bool please_exit;
|
extern volatile bool please_exit;
|
||||||
extern dword emulator_speed;
|
extern dword emulator_speed;
|
||||||
|
|
||||||
extern void emulator_init( void );
|
extern void emulator_init( char* fn_rom, char* fn_ram, char* fn_port1, char* fn_port2 );
|
||||||
extern void emulator_exit( void );
|
extern void emulator_exit( char* fn_rom, char* fn_ram, char* fn_port1, char* fn_port2 );
|
||||||
extern bool emulator_run( void );
|
extern bool emulator_run( void );
|
||||||
|
|
||||||
extern void emulator_set_state( int state );
|
extern void emulator_set_state( int state );
|
||||||
|
|
275
src/files.c
275
src/files.c
|
@ -1,3 +1,4 @@
|
||||||
|
#include <errno.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -5,50 +6,133 @@
|
||||||
#include <unistd.h> // readlink
|
#include <unistd.h> // readlink
|
||||||
#include <linux/limits.h> // PATH_MAX
|
#include <linux/limits.h> // PATH_MAX
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <pwd.h>
|
||||||
|
|
||||||
#include "gui.h"
|
#include "gui.h"
|
||||||
#include "rpl.h"
|
#include "rpl.h"
|
||||||
#include "files.h"
|
#include "files.h"
|
||||||
#include "bus.h"
|
#include "bus.h"
|
||||||
#include "ports.h"
|
#include "ports.h"
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
extern byte current_bank;
|
extern byte current_bank;
|
||||||
extern byte* port2;
|
extern byte* port2;
|
||||||
extern address port2mask;
|
extern address port2mask;
|
||||||
|
|
||||||
char WorkingPath[ 512 ];
|
/* char WorkingPath[ MAX_LENGTH_FILENAME ]; */
|
||||||
|
char absolute_working_dir_path[ MAX_LENGTH_FILENAME ];
|
||||||
|
|
||||||
static address ram_size = 256 * 1024; // in nibbles, not bytes!
|
static address ram_size = 256 * 1024; // in nibbles, not bytes!
|
||||||
|
|
||||||
void getExePath()
|
static address port1_size = ( 256 * 1024 ); /* 128Kio in nibbles */
|
||||||
|
static address port2_size = ( 8192 * 1024 ); /* 4Mio in nibbles */
|
||||||
|
|
||||||
|
void get_absolute_working_dir_path()
|
||||||
{
|
{
|
||||||
char programPath[ 1024 ];
|
if ( absolute_working_dir_path[ 0 ] == '/' )
|
||||||
char temp[ 1024 ];
|
return;
|
||||||
memset( programPath, 0, sizeof( programPath ) );
|
if ( config.verbose )
|
||||||
memset( temp, 0, sizeof( temp ) );
|
fprintf( stderr, "Finding and creating absolute_working_dir_path\n" );
|
||||||
|
|
||||||
char result[ PATH_MAX ];
|
memset( absolute_working_dir_path, 0, sizeof( absolute_working_dir_path ) );
|
||||||
ssize_t count = readlink( "/proc/self/exe", result, PATH_MAX );
|
char* xdg_config_home = getenv( "XDG_CONFIG_HOME" );
|
||||||
const char* path;
|
|
||||||
if ( count != -1 ) {
|
if ( xdg_config_home ) {
|
||||||
path = dirname( result );
|
if ( config.verbose )
|
||||||
strcpy( programPath, path );
|
fprintf( stderr, "XDG_CONFIG_HOME is %s\n", xdg_config_home );
|
||||||
|
|
||||||
|
strcpy( absolute_working_dir_path, xdg_config_home );
|
||||||
|
strcat( absolute_working_dir_path, "/" );
|
||||||
|
} else {
|
||||||
|
char* home = getenv( "HOME" );
|
||||||
|
|
||||||
|
if ( home ) {
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "HOME is %s\n", home );
|
||||||
|
|
||||||
|
strcpy( absolute_working_dir_path, home );
|
||||||
|
strcat( absolute_working_dir_path, "/.config/" );
|
||||||
|
} else {
|
||||||
|
struct passwd* pwd = getpwuid( getuid() );
|
||||||
|
|
||||||
|
if ( pwd ) {
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "pwd->pw_dir is %s\n", pwd->pw_dir );
|
||||||
|
|
||||||
|
strcpy( absolute_working_dir_path, pwd->pw_dir );
|
||||||
|
strcat( absolute_working_dir_path, "/" );
|
||||||
|
} else {
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "can\'t figure out your home directory, "
|
||||||
|
"trying /tmp\n" );
|
||||||
|
|
||||||
|
strcpy( absolute_working_dir_path, "/tmp" );
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
memset( WorkingPath, 0, sizeof( WorkingPath ) );
|
strcat( absolute_working_dir_path, config.progname );
|
||||||
strcpy( WorkingPath, programPath );
|
|
||||||
|
if ( absolute_working_dir_path[ strlen( absolute_working_dir_path ) ] != '/' )
|
||||||
|
strcat( absolute_working_dir_path, "/" );
|
||||||
|
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "SET absolute_working_dir_path = %s\n", absolute_working_dir_path );
|
||||||
|
|
||||||
|
struct stat st;
|
||||||
|
bool make_dir = false;
|
||||||
|
if ( stat( absolute_working_dir_path, &st ) == -1 ) {
|
||||||
|
if ( errno == ENOENT ) {
|
||||||
|
make_dir = true;
|
||||||
|
} else {
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "can\'t stat %s, saving to /tmp\n", absolute_working_dir_path );
|
||||||
|
strcpy( absolute_working_dir_path, "/tmp" );
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if ( !S_ISDIR( st.st_mode ) ) {
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "%s is no directory, saving to /tmp\n", absolute_working_dir_path );
|
||||||
|
strcpy( absolute_working_dir_path, "/tmp" );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( make_dir ) {
|
||||||
|
if ( mkdir( absolute_working_dir_path, 0777 ) == -1 ) {
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "can\'t mkdir %s, saving to /tmp\n", absolute_working_dir_path );
|
||||||
|
strcpy( absolute_working_dir_path, "/tmp" );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* void getExePath() */
|
||||||
|
/* { */
|
||||||
|
/* char programPath[ MAX_LENGTH_FILENAME ]; */
|
||||||
|
/* char temp[ MAX_LENGTH_FILENAME ]; */
|
||||||
|
/* memset( programPath, 0, sizeof( programPath ) ); */
|
||||||
|
/* memset( temp, 0, sizeof( temp ) ); */
|
||||||
|
|
||||||
|
/* char result[ PATH_MAX ]; */
|
||||||
|
/* ssize_t count = readlink( "/proc/self/exe", result, PATH_MAX ); */
|
||||||
|
/* const char* path; */
|
||||||
|
/* if ( count != -1 ) { */
|
||||||
|
/* path = dirname( result ); */
|
||||||
|
/* strcpy( programPath, path ); */
|
||||||
|
/* } */
|
||||||
|
|
||||||
|
/* memset( WorkingPath, 0, sizeof( WorkingPath ) ); */
|
||||||
|
/* strcpy( WorkingPath, programPath ); */
|
||||||
|
/* } */
|
||||||
|
|
||||||
int file_size( char* filename )
|
int file_size( char* filename )
|
||||||
{
|
{
|
||||||
memset( WorkingPath, 0, sizeof( WorkingPath ) );
|
/* memset( WorkingPath, 0, sizeof( WorkingPath ) ); */
|
||||||
getExePath();
|
/* getExePath(); */
|
||||||
|
get_absolute_working_dir_path();
|
||||||
|
|
||||||
FILE* f;
|
FILE* f;
|
||||||
char fullpath[ 1024 ];
|
f = fopen( filename, "r" );
|
||||||
sprintf( fullpath, "%s/%s", WorkingPath, filename );
|
|
||||||
printf( "%s\n", fullpath );
|
|
||||||
f = fopen( fullpath, "r" );
|
|
||||||
if ( !f )
|
if ( !f )
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
@ -60,7 +144,7 @@ int file_size( char* filename )
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
int read_mem_file( char* filename, nibble* mem, int size )
|
int read_mem_file( char* absolute_filename, nibble* mem, int size )
|
||||||
{
|
{
|
||||||
struct stat st;
|
struct stat st;
|
||||||
FILE* fp;
|
FILE* fp;
|
||||||
|
@ -68,15 +152,15 @@ int read_mem_file( char* filename, nibble* mem, int size )
|
||||||
byte rbyte;
|
byte rbyte;
|
||||||
int i, j;
|
int i, j;
|
||||||
|
|
||||||
if ( NULL == ( fp = fopen( filename, "r" ) ) ) {
|
if ( NULL == ( fp = fopen( absolute_filename, "r" ) ) ) {
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* fprintf( stderr, "ct open %s\n", filename ); */
|
fprintf( stderr, "ct open %s\n", absolute_filename );
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( stat( filename, &st ) < 0 ) {
|
if ( stat( absolute_filename, &st ) < 0 ) {
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* fprintf( stderr, "can\'t stat %s\n", filename ); */
|
fprintf( stderr, "can\'t stat %s\n", absolute_filename );
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -85,8 +169,8 @@ int read_mem_file( char* filename, nibble* mem, int size )
|
||||||
* size is same as memory size, old version file
|
* size is same as memory size, old version file
|
||||||
*/
|
*/
|
||||||
if ( fread( mem, 1, ( size_t )size, fp ) != ( unsigned long )size ) {
|
if ( fread( mem, 1, ( size_t )size, fp ) != ( unsigned long )size ) {
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* fprintf( stderr, "can\'t read %s\n", filename ); */
|
fprintf( stderr, "can\'t read %s\n", absolute_filename );
|
||||||
fclose( fp );
|
fclose( fp );
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -96,8 +180,8 @@ int read_mem_file( char* filename, nibble* mem, int size )
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if ( st.st_size != size / 2 ) {
|
if ( st.st_size != size / 2 ) {
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* fprintf( stderr, "strange size %s, expected %d, found %ld\n", filename, size / 2, st.st_size ); */
|
fprintf( stderr, "strange size %s, expected %d, found %ld\n", absolute_filename, size / 2, st.st_size );
|
||||||
fclose( fp );
|
fclose( fp );
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -105,8 +189,8 @@ int read_mem_file( char* filename, nibble* mem, int size )
|
||||||
if ( NULL == ( tmp_mem = ( byte* )malloc( ( size_t )st.st_size ) ) ) {
|
if ( NULL == ( tmp_mem = ( byte* )malloc( ( size_t )st.st_size ) ) ) {
|
||||||
for ( i = 0, j = 0; i < size / 2; i++ ) {
|
for ( i = 0, j = 0; i < size / 2; i++ ) {
|
||||||
if ( 1 != fread( &rbyte, 1, 1, fp ) ) {
|
if ( 1 != fread( &rbyte, 1, 1, fp ) ) {
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* fprintf( stderr, "can\'t read %s\n", filename ); */
|
fprintf( stderr, "can\'t read %s\n", absolute_filename );
|
||||||
fclose( fp );
|
fclose( fp );
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -115,8 +199,8 @@ int read_mem_file( char* filename, nibble* mem, int size )
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if ( fread( tmp_mem, 1, ( size_t )size / 2, fp ) != ( unsigned long )( size / 2 ) ) {
|
if ( fread( tmp_mem, 1, ( size_t )size / 2, fp ) != ( unsigned long )( size / 2 ) ) {
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* fprintf( stderr, "can\'t read %s\n", filename ); */
|
fprintf( stderr, "can\'t read %s\n", absolute_filename );
|
||||||
fclose( fp );
|
fclose( fp );
|
||||||
free( tmp_mem );
|
free( tmp_mem );
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -133,22 +217,22 @@ int read_mem_file( char* filename, nibble* mem, int size )
|
||||||
|
|
||||||
fclose( fp );
|
fclose( fp );
|
||||||
|
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* printf( "read %s\n", filename ); */
|
printf( "read %s\n", absolute_filename );
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int write_mem_file( char* filename, nibble* mem, int size )
|
int write_mem_file( char* absolute_filename, nibble* mem, int size )
|
||||||
{
|
{
|
||||||
FILE* fp;
|
FILE* fp;
|
||||||
byte* tmp_mem;
|
byte* tmp_mem;
|
||||||
byte rbyte;
|
byte rbyte;
|
||||||
int i, j;
|
int i, j;
|
||||||
|
|
||||||
if ( NULL == ( fp = fopen( filename, "w" ) ) ) {
|
if ( NULL == ( fp = fopen( absolute_filename, "w" ) ) ) {
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* fprintf( stderr, "can\'t open %s\n", filename ); */
|
fprintf( stderr, "can\'t open %s\n", absolute_filename );
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -157,8 +241,8 @@ int write_mem_file( char* filename, nibble* mem, int size )
|
||||||
rbyte = ( mem[ j++ ] & 0x0f );
|
rbyte = ( mem[ j++ ] & 0x0f );
|
||||||
rbyte |= ( mem[ j++ ] << 4 ) & 0xf0;
|
rbyte |= ( mem[ j++ ] << 4 ) & 0xf0;
|
||||||
if ( 1 != fwrite( &rbyte, 1, 1, fp ) ) {
|
if ( 1 != fwrite( &rbyte, 1, 1, fp ) ) {
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* fprintf( stderr, "can\'t write %s\n", filename ); */
|
fprintf( stderr, "can\'t write %s\n", absolute_filename );
|
||||||
fclose( fp );
|
fclose( fp );
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -170,8 +254,8 @@ int write_mem_file( char* filename, nibble* mem, int size )
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( fwrite( tmp_mem, 1, ( size_t )size / 2, fp ) != ( unsigned long )size / 2 ) {
|
if ( fwrite( tmp_mem, 1, ( size_t )size / 2, fp ) != ( unsigned long )size / 2 ) {
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* fprintf( stderr, "can\'t write %s\n", filename ); */
|
fprintf( stderr, "can\'t write %s\n", absolute_filename );
|
||||||
fclose( fp );
|
fclose( fp );
|
||||||
free( tmp_mem );
|
free( tmp_mem );
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -182,8 +266,8 @@ int write_mem_file( char* filename, nibble* mem, int size )
|
||||||
|
|
||||||
fclose( fp );
|
fclose( fp );
|
||||||
|
|
||||||
/* if ( verbose ) */
|
if ( config.verbose )
|
||||||
/* printf( "wrote %s\n", filename ); */
|
printf( "wrote %s\n", absolute_filename );
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -197,7 +281,11 @@ void load_file_on_stack( char* filename )
|
||||||
int fsize;
|
int fsize;
|
||||||
address size;
|
address size;
|
||||||
|
|
||||||
fsize = file_size( filename );
|
char fullpath[ MAX_LENGTH_FILENAME ];
|
||||||
|
get_absolute_working_dir_path();
|
||||||
|
sprintf( fullpath, "%s%s", absolute_working_dir_path, filename );
|
||||||
|
|
||||||
|
fsize = file_size( fullpath );
|
||||||
if ( fsize < 11 ) // "PHPH48-X" + prologue (8 + 2.5)
|
if ( fsize < 11 ) // "PHPH48-X" + prologue (8 + 2.5)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -205,7 +293,7 @@ void load_file_on_stack( char* filename )
|
||||||
if ( !buf )
|
if ( !buf )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
f = fopen( filename, "r" );
|
f = fopen( fullpath, "r" );
|
||||||
if ( !f ) {
|
if ( !f ) {
|
||||||
free( buf );
|
free( buf );
|
||||||
return;
|
return;
|
||||||
|
@ -250,7 +338,13 @@ void rom_init( char* filename )
|
||||||
byte *buf, *ptr1, *ptr2;
|
byte *buf, *ptr1, *ptr2;
|
||||||
FILE* f;
|
FILE* f;
|
||||||
|
|
||||||
size = file_size( filename );
|
char fullpath[ MAX_LENGTH_FILENAME ];
|
||||||
|
get_absolute_working_dir_path();
|
||||||
|
sprintf( fullpath, "%s%s", absolute_working_dir_path, filename );
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "fullpath = %s\n", fullpath );
|
||||||
|
|
||||||
|
size = file_size( fullpath );
|
||||||
if ( !size ) {
|
if ( !size ) {
|
||||||
printf( "ERROR: Can't read ROM file size\n" );
|
printf( "ERROR: Can't read ROM file size\n" );
|
||||||
exit( 0x10 );
|
exit( 0x10 );
|
||||||
|
@ -265,9 +359,6 @@ void rom_init( char* filename )
|
||||||
exit( 0x12 );
|
exit( 0x12 );
|
||||||
}
|
}
|
||||||
|
|
||||||
char fullpath[ 1024 ];
|
|
||||||
sprintf( fullpath, "%s/%s", WorkingPath, filename );
|
|
||||||
|
|
||||||
f = fopen( fullpath, "r" );
|
f = fopen( fullpath, "r" );
|
||||||
if ( !f ) {
|
if ( !f ) {
|
||||||
printf( "ERROR: can't open ROM file\n" );
|
printf( "ERROR: can't open ROM file\n" );
|
||||||
|
@ -313,11 +404,23 @@ void ram_init( char* filename )
|
||||||
{
|
{
|
||||||
bus_info.ram_data = malloc( ram_size );
|
bus_info.ram_data = malloc( ram_size );
|
||||||
|
|
||||||
int filesize = file_size( filename );
|
char fullpath[ MAX_LENGTH_FILENAME ];
|
||||||
|
get_absolute_working_dir_path();
|
||||||
|
sprintf( fullpath, "%s%s", absolute_working_dir_path, filename );
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "fullpath = %s\n", fullpath );
|
||||||
|
|
||||||
|
int filesize = file_size( fullpath ) * 2;
|
||||||
|
if ( config.verbose )
|
||||||
fprintf( stderr, "filesize(%i) == ram_size(%i)\n", filesize, ram_size );
|
fprintf( stderr, "filesize(%i) == ram_size(%i)\n", filesize, ram_size );
|
||||||
if ( filesize * 2 == ram_size )
|
if ( filesize == ram_size ) {
|
||||||
read_mem_file( filename, bus_info.ram_data, ram_size );
|
if ( config.verbose )
|
||||||
else {
|
fprintf( stderr, "loading %s as RAM\n", fullpath );
|
||||||
|
read_mem_file( fullpath, bus_info.ram_data, ram_size );
|
||||||
|
} else {
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "Creating RAM\n" );
|
||||||
|
|
||||||
byte* buf = malloc( ram_size );
|
byte* buf = malloc( ram_size );
|
||||||
if ( !buf )
|
if ( !buf )
|
||||||
exit( 0x20 );
|
exit( 0x20 );
|
||||||
|
@ -331,7 +434,15 @@ void ram_init( char* filename )
|
||||||
|
|
||||||
void ram_exit( char* filename )
|
void ram_exit( char* filename )
|
||||||
{
|
{
|
||||||
write_mem_file( filename, bus_info.ram_data, ram_size );
|
fprintf( stderr, "\n\nfilename = %s\n", filename );
|
||||||
|
char fullpath[ MAX_LENGTH_FILENAME ];
|
||||||
|
get_absolute_working_dir_path();
|
||||||
|
sprintf( fullpath, "%s%s", absolute_working_dir_path, filename );
|
||||||
|
if ( config.verbose ) {
|
||||||
|
fprintf( stderr, "fullpath = %s\n", fullpath );
|
||||||
|
fprintf( stderr, "Saving RAM to %s\n", fullpath );
|
||||||
|
}
|
||||||
|
write_mem_file( fullpath, bus_info.ram_data, ram_size );
|
||||||
|
|
||||||
free( bus_info.ram_data );
|
free( bus_info.ram_data );
|
||||||
bus_info.ram_data = NULL;
|
bus_info.ram_data = NULL;
|
||||||
|
@ -347,22 +458,34 @@ void ports_init( char* filename1, char* filename2 )
|
||||||
bus_info.ce1_bs = true;
|
bus_info.ce1_bs = true;
|
||||||
|
|
||||||
// ce2 = port1 (plugged)
|
// ce2 = port1 (plugged)
|
||||||
bus_info.ce2_data = malloc( PORT1_SIZE );
|
bus_info.ce2_data = malloc( port1_size );
|
||||||
|
|
||||||
int filesize = file_size( filename1 );
|
char fullpath1[ MAX_LENGTH_FILENAME ];
|
||||||
if ( filesize * 2 == PORT1_SIZE )
|
get_absolute_working_dir_path();
|
||||||
read_mem_file( filename1, bus_info.ce2_data, ram_size );
|
sprintf( fullpath1, "%s%s", absolute_working_dir_path, filename1 );
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "fullpath = %s\n", fullpath1 );
|
||||||
|
|
||||||
bus_info.ce2_mask = PORT1_SIZE - 1;
|
int filesize = file_size( fullpath1 ) * 2;
|
||||||
|
if ( filesize == port1_size )
|
||||||
|
read_mem_file( fullpath1, bus_info.ce2_data, ram_size );
|
||||||
|
|
||||||
|
bus_info.ce2_mask = port1_size - 1;
|
||||||
bus_info.ce2_r_o = false;
|
bus_info.ce2_r_o = false;
|
||||||
|
|
||||||
// nce3 = port2 (plugged)
|
// nce3 = port2 (plugged)
|
||||||
port2 = malloc( PORT2_SIZE );
|
port2 = malloc( port2_size );
|
||||||
|
|
||||||
filesize = file_size( filename2 );
|
char fullpath2[ MAX_LENGTH_FILENAME ];
|
||||||
if ( filesize * 2 == PORT2_SIZE )
|
get_absolute_working_dir_path();
|
||||||
read_mem_file( filename2, port2, PORT2_SIZE );
|
sprintf( fullpath2, "%s%s", absolute_working_dir_path, filename2 );
|
||||||
port2mask = PORT2_SIZE - 1;
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "fullpath = %s\n", fullpath1 );
|
||||||
|
|
||||||
|
filesize = file_size( fullpath2 ) * 2;
|
||||||
|
if ( filesize == port2_size )
|
||||||
|
read_mem_file( fullpath2, port2, port2_size );
|
||||||
|
port2mask = port2_size - 1;
|
||||||
bus_info.nce3_data = port2;
|
bus_info.nce3_data = port2;
|
||||||
bus_info.nce3_mask = port2mask & 0x3FFFF;
|
bus_info.nce3_mask = port2mask & 0x3FFFF;
|
||||||
bus_info.nce3_r_o = false;
|
bus_info.nce3_r_o = false;
|
||||||
|
@ -373,6 +496,18 @@ void ports_init( char* filename1, char* filename2 )
|
||||||
|
|
||||||
void ports_exit( char* filename1, char* filename2 )
|
void ports_exit( char* filename1, char* filename2 )
|
||||||
{
|
{
|
||||||
write_mem_file( filename1, bus_info.ce2_data, PORT1_SIZE );
|
char fullpath1[ MAX_LENGTH_FILENAME ];
|
||||||
write_mem_file( filename2, port2, PORT2_SIZE );
|
get_absolute_working_dir_path();
|
||||||
|
sprintf( fullpath1, "%s%s", absolute_working_dir_path, filename1 );
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "fullpath = %s\n", fullpath1 );
|
||||||
|
|
||||||
|
char fullpath2[ MAX_LENGTH_FILENAME ];
|
||||||
|
get_absolute_working_dir_path();
|
||||||
|
sprintf( fullpath2, "%s%s", absolute_working_dir_path, filename2 );
|
||||||
|
if ( config.verbose )
|
||||||
|
fprintf( stderr, "fullpath = %s\n", fullpath1 );
|
||||||
|
|
||||||
|
write_mem_file( fullpath1, bus_info.ce2_data, port1_size );
|
||||||
|
write_mem_file( fullpath2, port2, port2_size );
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,13 +3,15 @@
|
||||||
|
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
|
|
||||||
extern char WorkingPath[ 512 ];
|
#define MAX_LENGTH_FILENAME 2048
|
||||||
|
|
||||||
|
extern void get_absolute_working_dir_path();
|
||||||
|
|
||||||
extern int file_size( char* filename );
|
extern int file_size( char* filename );
|
||||||
extern void load_file_on_stack( char* filename );
|
extern void load_file_on_stack( char* filename );
|
||||||
|
|
||||||
extern void rom_init( char* filename );
|
extern void rom_init( char* filename );
|
||||||
extern void rom_exit( void );
|
extern void rom_exit();
|
||||||
|
|
||||||
extern void ram_init( char* filename );
|
extern void ram_init( char* filename );
|
||||||
extern void ram_exit( char* filename );
|
extern void ram_exit( char* filename );
|
||||||
|
|
24
src/main.c
24
src/main.c
|
@ -3,6 +3,7 @@
|
||||||
|
|
||||||
#include <SDL2/SDL.h>
|
#include <SDL2/SDL.h>
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
#include "emulator.h"
|
#include "emulator.h"
|
||||||
#include "gui.h"
|
#include "gui.h"
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
|
@ -18,25 +19,6 @@ unsigned int delay_timer1 = 16384;
|
||||||
unsigned int lastTime_timer5 = 0;
|
unsigned int lastTime_timer5 = 0;
|
||||||
unsigned int delay_timer5 = 64; // fps
|
unsigned int delay_timer5 = 64; // fps
|
||||||
|
|
||||||
static int fullscreen = false;
|
|
||||||
|
|
||||||
static void parse_args( int argc, char* argv[] )
|
|
||||||
{
|
|
||||||
while ( --argc ) {
|
|
||||||
argv++;
|
|
||||||
if ( argv[ 0 ][ 0 ] == '-' ) {
|
|
||||||
switch ( argv[ 0 ][ 1 ] ) {
|
|
||||||
case 'f':
|
|
||||||
fullscreen = true;
|
|
||||||
break;
|
|
||||||
case 'w':
|
|
||||||
fullscreen = false;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void mainloop()
|
static inline void mainloop()
|
||||||
{
|
{
|
||||||
if ( please_exit || !SDL_ready )
|
if ( please_exit || !SDL_ready )
|
||||||
|
@ -65,12 +47,12 @@ int main( int argc, char* argv[] )
|
||||||
parse_args( argc, argv );
|
parse_args( argc, argv );
|
||||||
|
|
||||||
gui_init();
|
gui_init();
|
||||||
emulator_init();
|
emulator_init( "rom", "ram", "port1", "port2" );
|
||||||
|
|
||||||
while ( !please_exit )
|
while ( !please_exit )
|
||||||
mainloop();
|
mainloop();
|
||||||
|
|
||||||
emulator_exit();
|
emulator_exit( "rom", "ram", "port1", "port2" );
|
||||||
gui_exit();
|
gui_exit();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -3,9 +3,6 @@
|
||||||
|
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
|
|
||||||
#define PORT1_SIZE ( 256 * 1024 ) /* 128Kio in nibbles */
|
|
||||||
#define PORT2_SIZE ( 256 * 1024 ) /* 128Kio in nibbles */
|
|
||||||
|
|
||||||
extern byte current_bank;
|
extern byte current_bank;
|
||||||
extern byte* port2;
|
extern byte* port2;
|
||||||
extern address port2mask;
|
extern address port2mask;
|
||||||
|
|
Loading…
Reference in a new issue