Thomas Harte
|
e68b3a2f32
|
Corrects JMP program.
|
2020-10-07 19:59:29 -04:00 |
|
Thomas Harte
|
f7b119ffe1
|
Moves temporary logging, fixes branch instructions.
|
2020-10-07 19:57:58 -04:00 |
|
Thomas Harte
|
a4cec95db1
|
Corrects load and transfer flag oversights.
|
2020-10-07 19:36:23 -04:00 |
|
Thomas Harte
|
84c4fa197b
|
Corrects DEX mapping, notes new Dormann failure case.
|
2020-10-07 18:48:03 -04:00 |
|
Thomas Harte
|
eac722cf59
|
Implements enough of ADC and SBC for the Dormann test definitively to fail.
|
2020-10-07 18:36:17 -04:00 |
|
Thomas Harte
|
7439a326a6
|
Implements BIT (in regular and immediate forms).
|
2020-10-07 18:15:18 -04:00 |
|
Thomas Harte
|
5ca1c0747f
|
Generalises CMP to implement CPX and CPY.
|
2020-10-07 18:09:56 -04:00 |
|
Thomas Harte
|
466ca38dfa
|
Corrects TXY and TYX; kudos to PatrickvL for the spot!
|
2020-10-07 18:05:42 -04:00 |
|
Thomas Harte
|
93b0839036
|
Knocks out some transfer operations.
I'm possibly only seven or eight away from being able to test with complete official-opcode-only 6502 code?
|
2020-10-06 22:29:34 -04:00 |
|
Thomas Harte
|
e068cbc103
|
Implements CMP and fixes a zero-flag error on 16-bit operations.
|
2020-10-06 21:47:26 -04:00 |
|
Thomas Harte
|
5c809e5fbf
|
Implements rolls and shifts.
|
2020-10-06 21:34:39 -04:00 |
|
Thomas Harte
|
3933bf49cf
|
Implements BRL.
|
2020-10-06 21:28:54 -04:00 |
|
Thomas Harte
|
7065ba4857
|
Implements the single-byte branches.
|
2020-10-06 21:24:43 -04:00 |
|
Thomas Harte
|
ebff83018e
|
Implements the bitwise operators.
|
2020-10-06 20:17:03 -04:00 |
|
Thomas Harte
|
9ce9167e3c
|
Formalises work left to do.
|
2020-10-06 19:12:19 -04:00 |
|
Thomas Harte
|
993eff1d3d
|
Starts slowly, with flag manipulation.
|
2020-10-06 16:25:30 -04:00 |
|
Thomas Harte
|
7be983ec00
|
Slightly improve exposition.
|
2020-10-05 22:25:20 -04:00 |
|
Thomas Harte
|
18e8d6ce06
|
Makes an effort to factor out the 6502's [lazy] flags.
This is preparatory to deciding which instructions, if any, are worth factoring out.
|
2020-10-05 22:23:33 -04:00 |
|
Thomas Harte
|
b7ba0d4327
|
Attempts to complete all addressing modes.
So, if bugs didn't exist, it'd just be members of the Operation enum to go.
|
2020-10-05 17:04:57 -04:00 |
|
Thomas Harte
|
825201f4f2
|
Adds direct indirect.
|
2020-10-04 22:11:41 -04:00 |
|
Thomas Harte
|
9a05c68ce7
|
Attempts direct and direct indexed indirect.
|
2020-10-04 22:06:25 -04:00 |
|
Thomas Harte
|
d8dccf2500
|
Attempts a full implementation of MVN and MVP.
|
2020-10-04 19:21:04 -04:00 |
|
Thomas Harte
|
b416aa640f
|
Slightly tidies up, eliminating some store bugs.
|
2020-10-04 19:12:04 -04:00 |
|
Thomas Harte
|
4ebf594b3b
|
This should bring me up to absolute, y.
i.e. next is datasheet program 7.
|
2020-10-04 19:02:47 -04:00 |
|
Thomas Harte
|
8a83024962
|
Starts a dash towards just completing the addressing modes for now.
This brings me up to the end of absolute long (i.e. 4a on the datasheet).
|
2020-10-04 18:52:46 -04:00 |
|
Thomas Harte
|
bdc1136b96
|
Edges towards working short absolute addressing mode.
|
2020-10-03 21:30:24 -04:00 |
|
Thomas Harte
|
da78dea98f
|
Merge branch 'master' into 65816
|
2020-10-03 21:00:29 -04:00 |
|
Thomas Harte
|
dcf8cb14e2
|
Merge pull request #842 from TomHarte/QtMouseEscape
Adds F8+F12 as an alternative mouse-release combo for Qt.
|
2020-10-02 20:37:46 -04:00 |
|
Thomas Harte
|
38912859e1
|
Adds F8+F12 as an alternative mouse-release combo for Qt.
|
2020-10-02 20:31:47 -04:00 |
|
Thomas Harte
|
b83d93abc2
|
Accepts that whether instructions do 8- or 16-bit bus accesses depends on either M or X depending on the operation.
|
2020-10-02 17:08:30 -04:00 |
|
Thomas Harte
|
36f843bc6e
|
Ensure std::function is visible to 65816Storage.cpp.
|
2020-09-29 19:23:38 -04:00 |
|
Thomas Harte
|
15c87e02e9
|
Ditto for printf .
|
2020-09-29 18:53:02 -04:00 |
|
Thomas Harte
|
00923eac7c
|
Ensure assert is visible to 65816Implementation.hpp.
|
2020-09-29 18:52:25 -04:00 |
|
Thomas Harte
|
a72ac8294c
|
Adds 65816 alternates to Klaus Dormann's tests.
While also correcting a couple of misspellings of his name. Apologies, Klaus!
|
2020-09-29 18:49:58 -04:00 |
|
Thomas Harte
|
4f03bf754d
|
Adds the 65816 to SConstruct.
|
2020-09-29 18:43:39 -04:00 |
|
Thomas Harte
|
78b3ec4b10
|
The actual work begins: starts implementing 65816 micro-ops.
|
2020-09-29 18:42:07 -04:00 |
|
Thomas Harte
|
ef1a514785
|
Introduces 6502Selector, for picking either a 6502 or a 65816 based on a single template parameter.
|
2020-09-28 21:35:46 -04:00 |
|
Thomas Harte
|
6635876e7e
|
Performs a bare factoring out of the 6502 bus handler.
|
2020-09-28 18:43:53 -04:00 |
|
Thomas Harte
|
5645f90abe
|
Takes a minor first step towards actually performing 65816 instructions.
|
2020-09-27 22:20:58 -04:00 |
|
Thomas Harte
|
b96cd4d18b
|
Resolves another unsafe pointer assumption.
|
2020-09-27 22:20:13 -04:00 |
|
Thomas Harte
|
ad8a2e2cb9
|
Corrects a long-standing naming obscurity.
|
2020-09-27 22:19:42 -04:00 |
|
Thomas Harte
|
fa438e5113
|
Merge branch 'master' into 65816
|
2020-09-27 15:10:54 -04:00 |
|
Thomas Harte
|
8641494809
|
Resolve various test-case warnings.
|
2020-09-27 15:10:29 -04:00 |
|
Thomas Harte
|
f4a23af5d6
|
Merge pull request #840 from MaddTheSane/patch-1
Update 6502TimingTests.swift
|
2020-09-27 15:02:10 -04:00 |
|
Thomas Harte
|
5449e90b34
|
Edges towards offering the 65816 as another type of 6502 for testing.
|
2020-09-26 22:31:50 -04:00 |
|
Thomas Harte
|
1cd664ad85
|
Adds a sanity check.
|
2020-09-26 21:43:26 -04:00 |
|
Thomas Harte
|
e680022b1f
|
Completes the opcode set.
A million bugs yet to find.
|
2020-09-26 21:35:31 -04:00 |
|
Thomas Harte
|
67c2ce2174
|
Takes a run at completing the stack section.
I'm not really sure about BRK though — does it gain a signature on the 65816?
|
2020-09-26 21:20:01 -04:00 |
|
Thomas Harte
|
596e700b60
|
Drags myself onto the final page of bus programs.
233 opcodes now complete; six bus programs to go.
|
2020-09-26 20:57:24 -04:00 |
|
Thomas Harte
|
4a53b6e538
|
Adds push and pull, reaching 229/256 opcodes.
|
2020-09-26 20:38:29 -04:00 |
|