Thomas Harte
|
ed4ddcfda8
|
Reduces call/return overhead on Microcycle methods.
|
2019-07-09 19:55:30 -04:00 |
|
Thomas Harte
|
69b94719a1
|
Switches to faster bit count logic.
|
2019-07-09 18:41:20 -04:00 |
|
Thomas Harte
|
5078f6fb5c
|
Marginally reduces MOVE heft.
|
2019-07-09 18:07:11 -04:00 |
|
Thomas Harte
|
94457d81b6
|
Eliminates redundant and integer-size-troubling AND on ASL.
|
2019-07-08 18:33:50 -04:00 |
|
Thomas Harte
|
fb352a8d40
|
Ensures assert is completely excluded if NDEBUG.
|
2019-07-08 18:00:37 -04:00 |
|
Thomas Harte
|
b9c2c42bc0
|
Switches drives to using floats for time counting.
Hopefully to eliminate a lot of unnecessary `Time` work; inaccuracies should still be within tolerable range.
|
2019-07-02 15:43:03 -04:00 |
|
Thomas Harte
|
c4cbe9476c
|
Corrects EA selection logic, fixing MOVEP.
|
2019-07-02 13:54:21 -04:00 |
|
Thomas Harte
|
0a67cc3dab
|
Goes nuclear on ROXL and ROXR.
|
2019-07-01 23:05:48 -04:00 |
|
Thomas Harte
|
726e07ed5b
|
Corrects ASL overflow flag.
|
2019-07-01 19:46:58 -04:00 |
|
Thomas Harte
|
11d8f765b2
|
Corrects divide-by-zero exception length, enables all other DIVS checks.
|
2019-07-01 15:46:04 -04:00 |
|
Thomas Harte
|
514e57b3e9
|
Corrects DIVU timing and flags, improves DIVS.
|
2019-07-01 14:24:32 -04:00 |
|
Thomas Harte
|
d8fb6fb951
|
Corrects MULU timing.
|
2019-06-30 22:40:10 -04:00 |
|
Thomas Harte
|
255f0d4b2a
|
Corrects MULS timing.
|
2019-06-30 22:33:54 -04:00 |
|
Thomas Harte
|
8d0cd356fd
|
Corrects TRAP, TRAPV and CHK timing.
|
2019-06-29 21:25:22 -04:00 |
|
Thomas Harte
|
17666bc059
|
Corrects CHK flags.
|
2019-06-28 19:48:53 -04:00 |
|
Thomas Harte
|
241d29ff7c
|
Imports SBCD and NBCD tests, and fixes corresponding operation.
|
2019-06-28 19:39:08 -04:00 |
|
Thomas Harte
|
c5039a4719
|
Imports ANDI, ORI and EORI to SR tests.
Hence corrects supervisor/user privileges for SR/CCR.
|
2019-06-28 15:05:46 -04:00 |
|
Thomas Harte
|
6c588a1510
|
Makes some further random swings at tracking the startup procedure.
|
2019-06-28 13:03:47 -04:00 |
|
Thomas Harte
|
d81053ea38
|
Invents some additional PEA tests, and further fixes PEA.
|
2019-06-27 17:59:03 -04:00 |
|
Thomas Harte
|
8d39c3bc98
|
Takes a shot at fixing PEA for A7-relative addresses.
Unit tests required. Tomorrow.
|
2019-06-26 23:24:54 -04:00 |
|
Thomas Harte
|
c0591090f5
|
Imports DIVU tests.
|
2019-06-26 22:25:48 -04:00 |
|
Thomas Harte
|
538aecb46e
|
Imports CMP tests, and fixes CMP.l timing.
|
2019-06-26 22:02:04 -04:00 |
|
Thomas Harte
|
dbdbea85c2
|
Imports CMPA tests, and fixes CMPA.w.
|
2019-06-26 21:42:48 -04:00 |
|
Thomas Harte
|
ba2224dd06
|
Imports NEGX tests and thereby fixes NEGX's zero flag.
|
2019-06-26 19:39:04 -04:00 |
|
Thomas Harte
|
79066f8628
|
Imports NOT tests, fixes NOT overflow and carry flags.
|
2019-06-25 22:18:11 -04:00 |
|
Thomas Harte
|
2c813a2692
|
Imports CMPM tests and fixes CMPM.bw source/destination order.
|
2019-06-25 21:46:01 -04:00 |
|
Thomas Harte
|
d2cb595b83
|
Proactively attempts to fix CMPM PostInc addressing.
|
2019-06-25 21:24:03 -04:00 |
|
Thomas Harte
|
ecb5a0b8cc
|
Incorporates ADDX tests and fixes ADDX PreDec.
|
2019-06-25 19:18:07 -04:00 |
|
Thomas Harte
|
e12e8fc616
|
Incorporates ASR tests, and fixes ASR (xxx).w.
... which was re-injecting the wrong bit to preserve sign.
|
2019-06-25 18:44:31 -04:00 |
|
Thomas Harte
|
1fbbf32cd2
|
Adds ASL tests, and corrects ASL (xxx).w.
Overflow is wrong on other ASLs though, I think.
|
2019-06-25 18:09:01 -04:00 |
|
Thomas Harte
|
31edb15369
|
Reduces 68000 startup costs a little further.
|
2019-06-25 17:41:13 -04:00 |
|
Thomas Harte
|
e830d23533
|
Incorporates TRAPV tests.
|
2019-06-24 21:21:35 -04:00 |
|
Thomas Harte
|
9a666fb8cc
|
Imports NEG tests and fixes NEG.l Dn timing.
|
2019-06-24 19:43:30 -04:00 |
|
Thomas Harte
|
0e208ed432
|
Fixes cycle counting in the test machine.
|
2019-06-24 17:55:09 -04:00 |
|
Thomas Harte
|
c8b769de8a
|
Completes import of LSL tests and fixes various LSL issues.
Including LSL (xxx).w actually being LSR, and the carry flag generally being questionable.
|
2019-06-24 17:45:38 -04:00 |
|
Thomas Harte
|
c447655047
|
Resolves assumption that shifts greater than the bit count of the relevant int are well-defined in C.
|
2019-06-24 16:51:43 -04:00 |
|
Thomas Harte
|
3ec9a1d869
|
Incorporates JMP tests, fixes JSR (xxx).l timing.
|
2019-06-24 15:36:33 -04:00 |
|
Thomas Harte
|
faef917cbd
|
Improves resizeable microcycle test.
|
2019-06-24 10:55:22 -04:00 |
|
Thomas Harte
|
d27ba90c07
|
Attempts to introduce more rigour to variable-length instruction handling.
|
2019-06-24 10:43:28 -04:00 |
|
Thomas Harte
|
db4ca746e3
|
Introduces BSET tests, fixes BSET timing.
|
2019-06-23 22:53:37 -04:00 |
|
Thomas Harte
|
d50fbfb506
|
Imports EXG and PEA tests, and fixes EXG timing.
|
2019-06-23 22:21:25 -04:00 |
|
Thomas Harte
|
86fdc75feb
|
Incorporates RTR test, adding a ProcessorState helper.
|
2019-06-23 18:37:32 -04:00 |
|
Thomas Harte
|
b63231523a
|
Completes import of ROL tests.
|
2019-06-23 17:33:12 -04:00 |
|
Thomas Harte
|
70e296674d
|
Starts import of ROL tests.
Including time tests, this time.
|
2019-06-22 22:42:57 -04:00 |
|
Thomas Harte
|
8c8493bc9d
|
Ensures proper loading of the SP at reset.
|
2019-06-21 18:20:26 -04:00 |
|
Thomas Harte
|
ccfe1b13cb
|
Imports DIVS, MULS and MOVE from SR tests.
Not all passing.
|
2019-06-21 16:03:11 -04:00 |
|
Thomas Harte
|
0c1c10bc66
|
Introduces a test that proves that DIVS' attempt to set proper timing isn't working.
|
2019-06-20 19:29:02 -04:00 |
|
Thomas Harte
|
fafd1801fe
|
Introduces first DIVS test, and associated fixes.
|
2019-06-20 19:02:03 -04:00 |
|
Thomas Harte
|
79d8d27b4c
|
Reintroduces use of locations_by_bus_step_ to decrease 68000 construction time.
|
2019-06-20 15:10:11 -04:00 |
|
Thomas Harte
|
440f52c943
|
Incorporates TRAP test.
|
2019-06-19 21:18:30 -04:00 |
|