Commit Graph

245 Commits

Author SHA1 Message Date
transistor 9e3b75f9fd Updated readme 2022-09-24 23:17:04 -07:00
transistor 083f3607ba Major reorganization into crates
I wanted to make this a bit more modular, so it's easier in theory to
write external crates that can reuse bits, and selectively compile in
bits, such as adding new systems or new cpu implementations
2022-09-24 23:14:03 -07:00
transistor c395199977 Minor fixes to some tests 2022-09-24 19:46:34 -07:00
transistor ce682565a9 Removed ProcessorTests as submodule because it's rather large 2022-09-24 19:24:52 -07:00
transistor 48bf76f430 Fixed some ASR cases, and updated test results 2022-09-18 22:09:56 -07:00
transistor 94d3e1d389 Renamed value and existing to src_val and dest_val in m68k impl 2022-09-18 20:44:45 -07:00
transistor eea8840483 Fixed the ABCD/SBCD/NBCD instructions (almost)
There are still some failures on the SBCD, but the logic is identical
to other emulator's calculations, but the test case doesn't seem to be
the way it should behave, so I'll leave it for now
2022-09-18 20:34:04 -07:00
transistor 267ef488ab Added PC hack to the various branch/jump instructions 2022-09-18 17:24:37 -07:00
transistor f5a548ac90 Added test results 2022-09-18 17:10:23 -07:00
transistor c55e3db87a Added test results with excluded address errors 2022-09-18 17:09:55 -07:00
transistor 1a65f50ba0 Added hack to return instructions to correctly adjust PC 2022-09-18 16:28:14 -07:00
transistor fa3e484288 Fixed DIVS overflow flag, and issue with exception processing
The signed division overflow was incorrect, and I tried a few bit-wise
approaches, but using the signed 32-bit number to determine 16-bit
overflow using greater than/less than work perfectly

There was also a bug in exception handling where it would push values
to the stack before setting the supervisor flag, but the push funcs
use the supervisor flag to determine which stack pointer to use, so
when an exception happened in user mode, it was pushing to USP when
it should have pushed to SSP
2022-09-18 16:09:50 -07:00
transistor bbd15abb76 Updated readme 2022-09-17 21:43:09 -07:00
transistor 481dd0d7f7 Fixed part of the problem in RTE test failures with Address Error
The I/N bit in the special status word on the stack should be set
when returning from RTE results in a PC that isn't word aligned.
Every other case pretty much, it should be clear
2022-09-17 21:29:04 -07:00
transistor 914ddb17dd Fixed moa-genisis not compiling 2022-09-17 11:16:16 -07:00
transistor e3c4ad88ee Fixed most DIVU tests, and some more DIVS ones 2022-09-16 22:54:59 -07:00
transistor 71c10ff0f0 Slightly improved the handling of the I/N bit in Address Error 2022-09-16 20:49:44 -07:00
transistor ef6fde2a4f Minor fix to RTE 2022-09-15 20:56:52 -07:00
transistor 5304df2a9f Minor fixes to the shift flags, but still haven't fixed the issue 2022-09-15 20:29:47 -07:00
transistor 84d2b5e15b Added test results 2022-09-14 22:51:48 -07:00
transistor a3fbcc7c16 Fixed some DIV tests 2022-09-14 21:52:24 -07:00
transistor 2a9ca9beae Fixed LINK instruction 2022-09-14 20:09:07 -07:00
transistor d074b7fc5e Test after fixing MULS 2022-09-13 22:18:22 -07:00
transistor 099b2fcb55 Copied over test results 2022-09-13 22:01:54 -07:00
transistor 42ca95ef5a Minor changes 2022-09-13 22:00:34 -07:00
transistor 575501599a Fixed MULS tests
DIVS tests are no better
2022-09-13 20:56:19 -07:00
transistor 96e79329e7 Added ability to exclude only extended exceptions 2022-09-13 18:42:49 -07:00
transistor a39557e233 Minor fixes 2022-09-13 16:57:56 -07:00
transistor c161fe5eb9 Fixed command line arguments after upgrading to clap 3.2.20 2022-09-12 22:43:55 -07:00
transistor 873741846c Implemented the CHK and NEGX instructions 2022-09-12 22:19:01 -07:00
transistor 9ff528c463 Fixed some AddressError tests
Adjusted the PC value stored when an Address Error fault occurs to
use the size of the access operation.

I also flipped the IN bit in the word that's written to the top of
the stack on an AddressError, even though that's opposite of what
the docs say.  It seems to pass the tests.  I probably have something
else going wrong, but it shouldn't be an important bit either way.
2022-09-12 21:47:36 -07:00
transistor 42bfabb743 Added test results 2022-09-11 21:52:29 -07:00
transistor 1a098bde6f Fixed various m68k bugs
Added support for RTR and RESET.
Fixed flags behavior for ASd
Added function to set PC, and fixed some instruction's handling of
an address fault a bit better
2022-09-11 21:27:29 -07:00
transistor d9a1295dda Fixed ADDX/SUBX instructions 2022-09-11 20:08:29 -07:00
transistor c4a99245e3 Added option to exclude or only run tests that involve an exception 2022-09-11 18:52:19 -07:00
transistor 03f4e11e3b Added proper AddressError handling to m68k
Also a few fixes, such as correcting a decode error in ADDX
2022-09-11 17:42:54 -07:00
transistor 34bdd86772 Added address mask to memory accesses from the tests 2022-09-11 14:51:58 -07:00
transistor aa39b4b11f Modified to use SR mask so that certain bits in SR are always 0 2022-09-11 14:50:37 -07:00
transistor 0582625b5e Fixed some issue with m68k
Some debug code was enabled that prevented illegal instructions
from being handled normally with a processor exception

The brief instruction word decoding could cause an illegal instruction
if it didn't match the docs, but the actual implementation would not
complain in those cases, so I modified it to not perform validation
for <=MC68010

Increment and Decrement addressing modes, when using the stack pointer,
will always inc/dec by at least 2 bytes, even if it's a byte operation,
to keep the stack aligned to the nearest word boundary
2022-09-10 21:09:35 -07:00
transistor 27f71b0f33 Added test results 2022-09-10 20:49:26 -07:00
transistor 1a3d8cc0c5 Fixed issue with Inc/Dec addressing modes
For instructions that use an operand twice, where it called
get_target_value and set_target_value, if the addressing mode was
one where it would increment or decrement a pointer, it was
causing a double inc/dec because of the two calls to get/set target.
I added an argument to let the functions know if they will be called
twice, in which case it assumes that get will be the first and set
will be the second, and inc/decs only once in the appropriate function
for whether it pre-incs or post-decs
2022-09-10 14:27:19 -07:00
transistor c53253c050 Added more options to run select tests to harte test runner 2022-09-10 14:08:01 -07:00
transistor f3a177489e Fixed the percentage summary for the harte tests 2022-09-09 23:43:06 -07:00
transistor c57c8f87b4 Added test running for Tom Harte's ProcessorTests test suite 2022-09-09 23:17:33 -07:00
transistor 8060f7179b Fixed some warnings 2022-09-09 22:31:55 -07:00
transistor 2c2b8e58b4 WIP 2022-09-08 19:51:29 -07:00
transistor 62a484d317 Modified the parser to work on the entire input
Previously it was going line by line, but that makes it hard to
properly parse multiline comments, so I modified it to include line
terminators in the token stream.  I also added parsing of /* */
and | \n comment types.  There is still a problem with line numbers
in the post-parsing phases, but they seem correct in the parser/lexer
stage.  It's still not able to parse the syscall.s file from Computie
but it's mostly just issues with named constants preceeded by a
"#" or "-" character.  As for the encoding stage, it has a problem
with a move instruction that uses a label.
2022-05-15 20:44:36 -07:00
transistor 586a16509f Added an assembler for the m68k
It can encode some basic instructions but not the more complicated
addressing modes or special instructions.  It can keep track of
labels and patch the displacement addresses after assembling the
output data, but it doesn't check for duplicates or that a label
has been declared before it appears.  It also doesn't take into
account the origin yet.  To run it, there is an m68kas command
that will take a file and print the data:
```
cargo run -p moa --bin m68kas <filename>
```

It's not yet tied into the rest of the system, but could be used in
the debugger to allow insertion of new code into a running system.
2022-05-12 21:53:34 -07:00
transistor 061c13fdc7 Updated sn76489 2022-01-26 19:15:46 -08:00
transistor 54bf7a3085 Renamed moa-ym2612 to moa-synth, and put CircularBuffer into its own file 2022-01-26 11:14:52 -08:00