1
0
Fork 0
forked from Miroirs/x49gp

Compare commits

..

No commits in common. "69ce49c0032787beb8c6d40703bdde18f1419712" and "6fe6c501b06e5880a8c7f2bccc7536587ecee3f6" have entirely different histories.

5 changed files with 51 additions and 39 deletions

View file

@ -705,7 +705,7 @@ static int gdb_handle_packet( GDBState* s, const char* line_buf )
case 'k': case 'k':
/* Kill the target */ /* Kill the target */
fprintf( stderr, "\nQEMU: Terminated via GDBstub\n" ); fprintf( stderr, "\nQEMU: Terminated via GDBstub\n" );
exit( EXIT_SUCCESS ); exit( 0 );
case 'D': case 'D':
/* Detach packet */ /* Detach packet */
gdb_breakpoint_remove_all(); gdb_breakpoint_remove_all();

View file

@ -36,7 +36,7 @@ int main( int argc, char** argv )
if ( argc < 3 ) { if ( argc < 3 ) {
fprintf( stderr, "usage: %s <infile> <outfile>\n", argv[ 0 ] ); fprintf( stderr, "usage: %s <infile> <outfile>\n", argv[ 0 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
if ( !strcmp( argv[ 1 ], "-" ) ) if ( !strcmp( argv[ 1 ], "-" ) )
@ -45,7 +45,7 @@ int main( int argc, char** argv )
in = open( argv[ 1 ], O_RDONLY ); in = open( argv[ 1 ], O_RDONLY );
if ( in < 0 ) { if ( in < 0 ) {
perror( argv[ 1 ] ); perror( argv[ 1 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
} }
@ -55,7 +55,7 @@ int main( int argc, char** argv )
out = open( argv[ 2 ], O_WRONLY | O_CREAT | O_TRUNC, 0666 ); out = open( argv[ 2 ], O_WRONLY | O_CREAT | O_TRUNC, 0666 );
if ( out < 0 ) { if ( out < 0 ) {
perror( argv[ 2 ] ); perror( argv[ 2 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
} }
@ -65,12 +65,12 @@ int main( int argc, char** argv )
input = ( unsigned char* )malloc( size ); input = ( unsigned char* )malloc( size );
if ( !input ) { if ( !input ) {
fprintf( stderr, "%s: out of memory\n", argv[ 0 ] ); fprintf( stderr, "%s: out of memory\n", argv[ 0 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
if ( read( in, input, size ) != size ) { if ( read( in, input, size ) != size ) {
perror( "read" ); perror( "read" );
exit( EXIT_FAILURE ); exit( 1 );
} }
close( in ); close( in );
@ -78,7 +78,7 @@ int main( int argc, char** argv )
memory = malloc( size >> 1 ); memory = malloc( size >> 1 );
if ( !memory ) { if ( !memory ) {
fprintf( stderr, "%s: out of memory\n", argv[ 0 ] ); fprintf( stderr, "%s: out of memory\n", argv[ 0 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
p = input; p = input;
@ -91,7 +91,7 @@ int main( int argc, char** argv )
memory[ i ] = ( *p - 'A' + 10 ) << 0; memory[ i ] = ( *p - 'A' + 10 ) << 0;
else { else {
fprintf( stderr, "%s: parse error at byte %d\n", argv[ 0 ], i ); fprintf( stderr, "%s: parse error at byte %d\n", argv[ 0 ], i );
exit( EXIT_FAILURE ); exit( 1 );
} }
p++; p++;
if ( '0' <= *p && *p <= '9' ) if ( '0' <= *p && *p <= '9' )
@ -102,7 +102,7 @@ int main( int argc, char** argv )
memory[ i ] |= ( *p - 'A' + 10 ) << 4; memory[ i ] |= ( *p - 'A' + 10 ) << 4;
else { else {
fprintf( stderr, "%s: parse error at byte %d\n", argv[ 0 ], i ); fprintf( stderr, "%s: parse error at byte %d\n", argv[ 0 ], i );
exit( EXIT_FAILURE ); exit( 1 );
} }
p++; p++;
} }

View file

@ -36,7 +36,7 @@ int main( int argc, char** argv )
if ( argc < 3 ) { if ( argc < 3 ) {
fprintf( stderr, "usage: %s <infile> <outfile>\n", argv[ 0 ] ); fprintf( stderr, "usage: %s <infile> <outfile>\n", argv[ 0 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
if ( !strcmp( argv[ 1 ], "-" ) ) if ( !strcmp( argv[ 1 ], "-" ) )
@ -45,7 +45,7 @@ int main( int argc, char** argv )
in = open( argv[ 1 ], O_RDONLY ); in = open( argv[ 1 ], O_RDONLY );
if ( in < 0 ) { if ( in < 0 ) {
perror( argv[ 1 ] ); perror( argv[ 1 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
} }
@ -55,7 +55,7 @@ int main( int argc, char** argv )
out = open( argv[ 2 ], O_WRONLY | O_CREAT | O_TRUNC, 0666 ); out = open( argv[ 2 ], O_WRONLY | O_CREAT | O_TRUNC, 0666 );
if ( out < 0 ) { if ( out < 0 ) {
perror( argv[ 2 ] ); perror( argv[ 2 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
} }
@ -65,12 +65,12 @@ int main( int argc, char** argv )
input = ( unsigned char* )malloc( size ); input = ( unsigned char* )malloc( size );
if ( !input ) { if ( !input ) {
fprintf( stderr, "%s: out of memory\n", argv[ 0 ] ); fprintf( stderr, "%s: out of memory\n", argv[ 0 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
if ( read( in, input, size ) != size ) { if ( read( in, input, size ) != size ) {
perror( "read" ); perror( "read" );
exit( EXIT_FAILURE ); exit( 1 );
} }
close( in ); close( in );
@ -78,7 +78,7 @@ int main( int argc, char** argv )
memory = malloc( size >> 1 ); memory = malloc( size >> 1 );
if ( !memory ) { if ( !memory ) {
fprintf( stderr, "%s: out of memory\n", argv[ 0 ] ); fprintf( stderr, "%s: out of memory\n", argv[ 0 ] );
exit( EXIT_FAILURE ); exit( 1 );
} }
p = input; p = input;
@ -91,7 +91,7 @@ int main( int argc, char** argv )
memory[ ( i & ~3 ) + 3 - ( i & 3 ) ] = ( *p - 'A' + 10 ) << 0; memory[ ( i & ~3 ) + 3 - ( i & 3 ) ] = ( *p - 'A' + 10 ) << 0;
else { else {
fprintf( stderr, "%s: parse error at byte %d\n", argv[ 0 ], i ); fprintf( stderr, "%s: parse error at byte %d\n", argv[ 0 ], i );
exit( EXIT_FAILURE ); exit( 1 );
} }
p++; p++;
if ( '0' <= *p && *p <= '9' ) if ( '0' <= *p && *p <= '9' )
@ -102,7 +102,7 @@ int main( int argc, char** argv )
memory[ ( i & ~3 ) + 3 - ( i & 3 ) ] |= ( *p - 'A' + 10 ) << 4; memory[ ( i & ~3 ) + 3 - ( i & 3 ) ] |= ( *p - 'A' + 10 ) << 4;
else { else {
fprintf( stderr, "%s: parse error at byte %d\n", argv[ 0 ], i ); fprintf( stderr, "%s: parse error at byte %d\n", argv[ 0 ], i );
exit( EXIT_FAILURE ); exit( 1 );
} }
p++; p++;
} }

View file

@ -277,24 +277,35 @@ static void config_init( char* progname, int argc, char* argv[] )
case 'h': case 'h':
fprintf( stderr, fprintf( stderr,
"%s %i.%i.%i Emulator for HP 49G+ / 50G calculators\n" "%s %i.%i.%i Emulator for HP 49G+ / 50G calculators\n"
"Usage: %s [<options>]\n" "Usage: %s [<options>] [<config-file>]\n"
"Valid options:\n" "Valid options:\n"
" -c --config[=<filename>] alternate config file\n" " -c, --config[=<filename>] alternate config file\n"
" -D --enable-debug[=<port>] enable the debugger interface\n" " -D, --enable-debug[=<port>] enable the debugger interface\n"
" (default port: %u)\n" " (default port: %u)\n"
" -d --debug use along -D to also start the debugger immediately\n" " -d, --debug use along -D to also start the"
" -f --reflash[=firmware] rebuild the flash using the supplied firmware\n" " debugger immediately\n"
" (default: select one interactively)\n" " -f, --reflash[=firmware] rebuild the flash using the"
" (implies -r for safety reasons)\n" " supplied firmware\n"
" -F --reflash-full use along -f to drop the flash contents\n" " (default: select one"
" in the area beyond the firmware\n" " interactively)\n"
" -r --reboot reboot on startup instead of continuing from the\n" " (implies -r for safety"
" saved state in the config file\n" " reasons)\n"
" -h --help print this message and exit\n" " -F, --reflash-full use along -f to drop the"
"The config file is formatted as INI file and contains the settings for which\n" " flash contents\n"
" persistence makes sense, like calculator model, CPU registers, etc.\n" " in the area beyond the"
" firmware\n"
" -r, --reboot reboot on startup instead of"
" continuing from the\n"
" saved state in the config"
" file\n"
" -h, --help print this message and exit\n"
"The config file is formatted as INI file and contains the"
" settings for which\n"
"persistence makes sense, like calculator model, CPU"
" registers, etc.\n"
"If the config file is omitted, ~/.config/%s/config is used.\n" "If the config file is omitted, ~/.config/%s/config is used.\n"
"Please consult the manual for more details on config file settings.\n", "Please consult the manual for more details on config file"
" settings.\n",
progname, VERSION_MAJOR, VERSION_MINOR, PATCHLEVEL, progname, DEFAULT_GDBSTUB_PORT, progname ); progname, VERSION_MAJOR, VERSION_MINOR, PATCHLEVEL, progname, DEFAULT_GDBSTUB_PORT, progname );
exit( EXIT_SUCCESS ); exit( EXIT_SUCCESS );
break; break;
@ -322,7 +333,8 @@ static void config_init( char* progname, int argc, char* argv[] )
if ( opt.debug_port != 0 && opt.debug_port != DEFAULT_GDBSTUB_PORT ) if ( opt.debug_port != 0 && opt.debug_port != DEFAULT_GDBSTUB_PORT )
fprintf( stderr, fprintf( stderr,
"Additional debug port \"%s\" specified, overriding\n", "Additional debug port \"%s\" specified,"
" overriding\n",
optarg ); optarg );
opt.debug_port = port; opt.debug_port = port;
} }
@ -381,7 +393,7 @@ int main( int argc, char** argv )
x49gp = malloc( sizeof( x49gp_t ) ); x49gp = malloc( sizeof( x49gp_t ) );
if ( NULL == x49gp ) { if ( NULL == x49gp ) {
fprintf( stderr, "%s: %s:%u: Out of memory\n", progname, __FUNCTION__, __LINE__ ); fprintf( stderr, "%s: %s:%u: Out of memory\n", progname, __FUNCTION__, __LINE__ );
exit( EXIT_FAILURE ); exit( 1 );
} }
memset( x49gp, 0, sizeof( x49gp_t ) ); memset( x49gp, 0, sizeof( x49gp_t ) );
@ -423,7 +435,7 @@ int main( int argc, char** argv )
x49gp_s3c2410_init( x49gp ); x49gp_s3c2410_init( x49gp );
if ( x49gp_modules_init( x49gp ) ) { if ( x49gp_modules_init( x49gp ) ) {
exit( EXIT_FAILURE ); exit( 1 );
} }
if ( opt.config == NULL ) { if ( opt.config == NULL ) {
@ -442,7 +454,7 @@ int main( int argc, char** argv )
error = x49gp_modules_load( x49gp, opt.config ); error = x49gp_modules_load( x49gp, opt.config );
if ( error || opt.reinit >= X49GP_REINIT_REBOOT_ONLY ) { if ( error || opt.reinit >= X49GP_REINIT_REBOOT_ONLY ) {
if ( error && error != -EAGAIN ) { if ( error && error != -EAGAIN ) {
exit( EXIT_FAILURE ); exit( 1 );
} }
x49gp_modules_reset( x49gp, X49GP_RESET_POWER_ON ); x49gp_modules_reset( x49gp, X49GP_RESET_POWER_ON );
} }

View file

@ -33,7 +33,7 @@ int x49gp_modules_init( x49gp_t* x49gp )
phys_ram_base = mmap( 0, phys_ram_size, PROT_NONE, MAP_SHARED | MAP_ANON, -1, 0 ); phys_ram_base = mmap( 0, phys_ram_size, PROT_NONE, MAP_SHARED | MAP_ANON, -1, 0 );
if ( phys_ram_base == ( uint8_t* )-1 ) { if ( phys_ram_base == ( uint8_t* )-1 ) {
fprintf( stderr, "%s: can't mmap %08x anonymous bytes\n", __FUNCTION__, phys_ram_size ); fprintf( stderr, "%s: can't mmap %08x anonymous bytes\n", __FUNCTION__, phys_ram_size );
exit( EXIT_FAILURE ); exit( 1 );
} }
#ifdef DEBUG_X49GP_MODULES #ifdef DEBUG_X49GP_MODULES