Fixed bug in Immediate mode

This commit is contained in:
Leeland Heins 2018-12-21 14:52:42 -06:00 committed by GitHub
parent 63c0277a26
commit 565e67f076
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

42
as65.pl
View File

@ -841,8 +841,8 @@ sub sym_sub {
sub handle_8_bit_symbol { sub handle_8_bit_symbol {
my ($ofh, $lineno, $addr, $opcode, $symbol, $line) = @_; my ($ofh, $lineno, $addr, $opcode, $symbol, $line) = @_;
if ($symbol =~ /^[>]/) { if ($symbol =~ /^[<>]/) {
my ($sym) = $symbol =~ /[>](.+)/; my ($sym) = $symbol =~ /[<>](.+)/;
my $symval = $symbols{$sym}; my $symval = $symbols{$sym};
if (defined $symval) { if (defined $symval) {
my $opval = $symval; my $opval = $symval;
@ -854,6 +854,19 @@ sub handle_8_bit_symbol {
print "**** $lineno - Unknown symbol '$symbol' in '$line'\n"; print "**** $lineno - Unknown symbol '$symbol' in '$line'\n";
generate_16($ofh, $addr, $opcode, 0x00, $lineno, $line); generate_16($ofh, $addr, $opcode, 0x00, $lineno, $line);
} }
} elsif ($symbol =~ /^[<]/) {
my ($sym) = $symbol =~ /[<](.+)/;
my $symval = $symbols{$sym};
if (defined $symval) {
my $opval = $symval;
if ($symval =~ /^\$([0-9a-fA-F][0-9a-fA-F])/) {
$opval = hex(lc($1));
}
generate_16($ofh, $addr, $opcode, $opval, $lineno, $line);
} else {
print "**** $lineno - Unknown symbol '$symbol' in '$line'\n";
generate_16($ofh, $addr, $opcode, 0x00, $lineno, $line);
}
} else { } else {
my $symval = $symbols{$symbol}; my $symval = $symbols{$symbol};
if (defined $symval) { if (defined $symval) {
@ -993,10 +1006,10 @@ sub is_Immediate {
return 0 if ($1 > 255); return 0 if ($1 > 255);
return 2; return 2;
# Handle symbols. # Handle symbols.
} elsif ($operand =~ /^#[>]*([A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)$/) { } elsif ($operand =~ /^#[<>]*([A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)$/) {
return 2; return 2;
# Allow arithmetic on symbol # Allow arithmetic on symbol
} elsif ($operand =~ /^#[>]*([A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)\s*[+-]\s*(\$[0-9a-fA-F]+)$/) { } elsif ($operand =~ /^#[<>]*([A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)\s*[+-]\s*(\$[0-9a-fA-F]+)$/) {
return 2; return 2;
} }
@ -1007,6 +1020,7 @@ sub generate_Immediate {
my ($addr, $operand, $opcode, $ofh, $lineno, $line) = @_; my ($addr, $operand, $opcode, $ofh, $lineno, $line) = @_;
# Parse hex # Parse hex
if ($operand =~ /^#\$([0-9a-fA-F][0-9a-fA-F])$/) { if ($operand =~ /^#\$([0-9a-fA-F][0-9a-fA-F])$/) {
#print "opval=$1\n";
my $opval = hex(lc($1)); my $opval = hex(lc($1));
generate_16($ofh, $addr, $opcode, $opval, $lineno, $line); generate_16($ofh, $addr, $opcode, $opval, $lineno, $line);
# Parse binary # Parse binary
@ -1016,14 +1030,16 @@ sub generate_Immediate {
# Parse decimal # Parse decimal
} elsif ($operand =~ /^#(\d+)$/) { } elsif ($operand =~ /^#(\d+)$/) {
generate_16($ofh, $addr, $opcode, $1, $lineno, $line); generate_16($ofh, $addr, $opcode, $1, $lineno, $line);
# Return symbol value # Handle symbol
} elsif ($operand =~ /^#[>]*([A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)/) { } elsif ($operand =~ /^#([<>]*[A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)/) {
handle_8_bit_symbol($ofh, $lineno, $addr, $opcode, $1, $line); handle_8_bit_symbol($ofh, $lineno, $addr, $opcode, $1, $line);
# Allow arithmetic on symbol # Allow arithmetic on symbol
} elsif ($operand =~ /^#([>]*)([A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)\s*[+]\s*(\$[0-9a-fA-F]+)$/) { } elsif ($operand =~ /^#([<>]*)([A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)\s*[+]\s*(\$[0-9a-fA-F]+)$/) {
print "foo $1 $2 $3\n";
# Add # Add
handle_8_bit_symbol_add($ofh, $lineno, $addr, $opcode, $1, $2, $3, $line); handle_8_bit_symbol_add($ofh, $lineno, $addr, $opcode, $1, $2, $3, $line);
} elsif ($operand =~ /^#([>]*)([A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)\s*[-]\s*(\$[0-9a-fA-F]+)$/) { } elsif ($operand =~ /^#([<>]*)([A-Za-z\.\?:][A-Za-z0-9_\.\?:]*)\s*[-]\s*(\$[0-9a-fA-F]+)$/) {
print "foo $1 $2 $3\n";
# Subtract # Subtract
handle_8_bit_symbol_sub($ofh, $lineno, $addr, $opcode, $1, $2, $3, $line); handle_8_bit_symbol_sub($ofh, $lineno, $addr, $opcode, $1, $2, $3, $line);
} else { } else {
@ -1363,14 +1379,12 @@ sub generate_Absolute {
my ($addr, $operand, $opcode, $ofh, $lineno, $line) = @_; my ($addr, $operand, $opcode, $ofh, $lineno, $line) = @_;
# Parse hex # Parse hex
if ($operand =~ /^\$([0-9a-fA-F]*[0-9a-fA-F])([0-9A-Fa-f][0-9A-Fa-f])$/) { if ($operand =~ /^\$([0-9a-fA-F]*[0-9a-fA-F])([0-9A-Fa-f][0-9A-Fa-f])$/) {
#my $opval1 = hex(lc(substr($1, 0, 2))); generate_24($ofh, $addr, $opcode, hex(lc($2)), hex(lc($1)), $lineno, $line);
#my $opval2 = hex(lc(substr($1, 2, 2)));
#generate_24($ofh, $addr, $opcode, $opval2, $opval1, $lineno, $line);
generate_24($ofh, $addr, $opcode, $2, $1, $lineno, $line);
# Parse binary # Parse binary
} elsif ($operand =~ /^%([01]{16})$/) { } elsif ($operand =~ /^%([01]{16})$/) {
my $opval = unpack('C', pack("B16", $1)); my $opval1 = unpack('C', pack("B8", substr($1, 0, 8)));
generate_24($ofh, $addr, $opcode, $opval, $lineno, $line); my $opval2 = unpack('C', pack("B8", substr($1, 8, 8)));
generate_24($ofh, $addr, $opcode, $opval2, $opval1, $lineno, $line);
# Parse decimal # Parse decimal
} elsif ($operand =~ /^(\d+)$/) { } elsif ($operand =~ /^(\d+)$/) {
my $opval = sprintf("%04x", $1); my $opval = sprintf("%04x", $1);