mirror of
https://github.com/softwarejanitor/as65.git
synced 2025-01-15 12:31:22 +00:00
Fixed bug in Immediate mode
This commit is contained in:
parent
63c0277a26
commit
565e67f076
42
as65.pl
42
as65.pl
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user