Thomas Harte
|
0857dd0ae5
|
Include fixed base cost in MULU and MULS.
|
2022-06-01 14:05:23 -04:00 |
|
Thomas Harte
|
5a4f117a12
|
Merge branch '68000Mk2' of github.com:TomHarte/CLK into 68000Mk2
|
2022-06-01 10:48:14 -04:00 |
|
Thomas Harte
|
62ed1ca2fd
|
Fix MOVE CCR permissions.
|
2022-06-01 09:22:47 -04:00 |
|
Thomas Harte
|
d1298c8863
|
Correct MOVE timing without breaking PEA, LEA, etc.
|
2022-06-01 09:06:08 -04:00 |
|
Thomas Harte
|
75e85b80aa
|
Factor out the common stuff of exception state.
|
2022-06-01 08:20:33 -04:00 |
|
Thomas Harte
|
73815ba1dd
|
No need for this hoop jumping here.
|
2022-06-01 08:20:06 -04:00 |
|
Thomas Harte
|
e1abf431cb
|
Don't test undefined flags.
|
2022-05-30 16:23:51 -04:00 |
|
Thomas Harte
|
8e0fa3bb5f
|
DIV # with a divide by zero should be 44 cycles.
|
2022-05-29 21:22:45 -04:00 |
|
Thomas Harte
|
8ffaf1a8e4
|
Ensure did_divu/s are performed even upon divide by zero.
|
2022-05-29 21:18:19 -04:00 |
|
Thomas Harte
|
7788a109b0
|
Tweak more overtly to avoid divide by zero.
|
2022-05-29 20:51:50 -04:00 |
|
Thomas Harte
|
9eea471e72
|
Resolve infinite recursion.
|
2022-05-29 20:39:22 -04:00 |
|
Thomas Harte
|
3ef53315a2
|
Don't try to append operands to 'None'.
|
2022-05-29 15:28:16 -04:00 |
|
Thomas Harte
|
2a40e419fc
|
Fix CHK tests: timing and expected flags.
|
2022-05-29 15:26:56 -04:00 |
|
Thomas Harte
|
d6f72d9862
|
Avoid runtime checking of instruction supervisor requirements.
|
2022-05-29 14:56:44 -04:00 |
|
Thomas Harte
|
3da720c789
|
Make requires_supervisor explicitly compile-time usable.
|
2022-05-29 14:55:24 -04:00 |
|
Thomas Harte
|
dbf7909b85
|
Fix timing of CMPM.
|
2022-05-29 14:49:42 -04:00 |
|
Thomas Harte
|
57aa8d2f17
|
Correct timing of ADDQ.
|
2022-05-29 14:34:06 -04:00 |
|
Thomas Harte
|
35e73b77f4
|
Fix interrupt stack frame.
|
2022-05-27 21:55:17 -04:00 |
|
Thomas Harte
|
d17d77714f
|
Remove outdated TODO.
|
2022-05-27 15:40:06 -04:00 |
|
Thomas Harte
|
e8dd8215ba
|
Tweak per empirical results.
|
2022-05-27 15:39:02 -04:00 |
|
Thomas Harte
|
e11990e453
|
Make an attempt at DIVS timing.
|
2022-05-27 15:38:54 -04:00 |
|
Thomas Harte
|
165ebe8ae3
|
Add time calculation for MULU and MULS.
|
2022-05-27 15:38:14 -04:00 |
|
Thomas Harte
|
e746637bee
|
Fill in dynamic cost of shifts.
|
2022-05-27 15:38:08 -04:00 |
|
Thomas Harte
|
67b340fa5e
|
Fix interrupt request address.
|
2022-05-27 10:33:36 -04:00 |
|
Thomas Harte
|
c97245e626
|
Fix CalcEA timing; make MOVEfromSR a read-modify-write.
|
2022-05-27 10:32:28 -04:00 |
|
Thomas Harte
|
5f030edea4
|
Simplify transaction.
|
2022-05-26 19:37:30 -04:00 |
|
Thomas Harte
|
88e33353a1
|
Fix instruction and time counting, and initial state.
|
2022-05-26 09:17:37 -04:00 |
|
Thomas Harte
|
f3c0c62c79
|
Switch register-setting interface.
|
2022-05-26 07:52:14 -04:00 |
|
Thomas Harte
|
866787c5d3
|
Make an effort to withdraw from the high-circuitous stuff of working around the reset sequence.
|
2022-05-25 20:22:38 -04:00 |
|
Thomas Harte
|
367ad8079a
|
Add a call to set register state with population of the prefetch.
|
2022-05-25 20:22:05 -04:00 |
|
Thomas Harte
|
64491525b4
|
Work further to guess at caller's intention for set_state.
Probably I should just eliminate the initial reset, somehow.
|
2022-05-25 17:01:18 -04:00 |
|
Thomas Harte
|
68b184885f
|
Reapply only the status.
|
2022-05-25 16:54:25 -04:00 |
|
Thomas Harte
|
06f3c716f5
|
Make better effort to establish initial state.
|
2022-05-25 16:47:41 -04:00 |
|
Thomas Harte
|
22714b8c7f
|
Capture state at instruction end, for potential inspection.
|
2022-05-25 16:32:26 -04:00 |
|
Thomas Harte
|
80c1bedffb
|
Eliminate false prefetch for BSR.
|
2022-05-25 16:32:02 -04:00 |
|
Thomas Harte
|
56ad6d24ee
|
Fix ANDI/ORI/EORI to CCR/SR timing.
|
2022-05-25 16:20:26 -04:00 |
|
Thomas Harte
|
4ad0e04c23
|
Fix macro for n being an expression.
|
2022-05-25 16:05:45 -04:00 |
|
Thomas Harte
|
f9d1c554b7
|
Fix for the actual number of cycles in a standard reset.
|
2022-05-25 16:05:28 -04:00 |
|
Thomas Harte
|
ee58301a46
|
Add RaiseException macro.
|
2022-05-25 15:45:09 -04:00 |
|
Thomas Harte
|
f2a7660390
|
Merge branch 'master' into 68000Mk2
|
2022-05-25 15:40:10 -04:00 |
|
Thomas Harte
|
d4c7ce2d6f
|
Merge pull request #1035 from TomHarte/68000TestIssues
Add details on gaps in coverage.
|
2022-05-25 15:39:42 -04:00 |
|
Thomas Harte
|
4961e39fb6
|
Mention DIVU/DIVS flags.
|
2022-05-25 15:39:00 -04:00 |
|
Thomas Harte
|
0bedf608c0
|
Add details on gaps in coverage.
|
2022-05-25 15:36:27 -04:00 |
|
Thomas Harte
|
1ab831f571
|
Add the option to log a list of all untested instructions.
|
2022-05-25 13:17:01 -04:00 |
|
Thomas Harte
|
72425fc2e1
|
Fix bus data size of MOVE.b xx, -(An).
|
2022-05-25 13:00:36 -04:00 |
|
Thomas Harte
|
a5f2dfbc0c
|
Initialise registers to 0 for better testability.
TODO: is this the real initial state?
|
2022-05-25 11:47:42 -04:00 |
|
Thomas Harte
|
5db6a937cb
|
Have TRAP and TRAPV push the next instruction address to the stack.
|
2022-05-25 11:47:21 -04:00 |
|
Thomas Harte
|
9709b9b1b1
|
Standard exceptions don't raise the interrupt level.
|
2022-05-25 11:37:39 -04:00 |
|
Thomas Harte
|
2c6b9b4c9d
|
Switch comparative trace tests to 68000 Mk2.
|
2022-05-25 11:32:00 -04:00 |
|
Thomas Harte
|
463fbb07f9
|
Adapt remaining 68000 tests to use Mk2.
|
2022-05-25 10:55:17 -04:00 |
|