-
Notifications
You must be signed in to change notification settings - Fork 57
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Suggestion: Turbo support #2
Comments
I beg to disagree. Once you have used a turbo MSX machine, you won’t want to go back and will start wondering why they haven’t done this earlier. 😉 There are plenty of heavy games and apps that will run much better when a turbo is present. Just to name a few:
As you have seen, the SuperTurbo design is very simple and compact
SuperTurbo takes a very simple approach to this. It just lowers the clock when needed
Not really necessary, for speeds up to 10.74MHz. But the approach I use when I want to be conservative is to connect the SLTSL pin of the slot-1 to one of the SuperTurbo break inputs. This allows a flexible configuration where the slot-2 is the “turbo slot” and the slot-1 is the “slow slot”. On a new motherboard like this, configuration switches could be added to select if a slot will be turbo or not. |
Ok. For the current PCB, maybe it could be added later as a daughterboard piggybacked to the U12 position (+RD signal). It seems to be possible since you took great care on the mobo design. Just please add simple jumpers to each slot /CPUCLK signal, to make it easier to inject the turbo clock there for a specific slot if needed. Due to being very simplistic, the SuperTurbo 3.0 is a good design to add turbo for older/existing machines, or when space/cost/DIP-requirement are of concern. If you're going to use a CPLD, then it's much better to take the wait-state generator approach. The VDP requires a custom waitstate generator. Please let me know at this thread when you decide to implement it, so I can come back to describe the specifications. A generic waitstate generator will have a horrible impact on the CPU->VDP access, as happened on the MSX Turbo-R. |
I added this suggestion here on its own issue, to avoid cluttering on the MSX.org news thread.
In fact, the circuit for the turbo is very simple. For the MSX1 and MSX2, the turbo will be disabled on all I/O operations, but it still can provide a very welcome boost in performance. An MSX1 at 5.37MHz with this turbo can run ZX-Spectrum ports at their correct speed, i.e.
As mentioned before, for the MSX2+ it's possible to speed-up the access to the VRAM, thanks to the V9958 /WAIT feature. For this, Belavenuto and myself have designed a GAL logic that:
It only can't read the status of the turbo, as it was designed to complement implement the turbo on Sanyo2+ machines, and those already provide the turbo status feature internally. You probably would be able to easily add the turbo status feature
If you're interested, I can gladly send you the .EQN file for the turbo GAL as an open-source contribution.
The text was updated successfully, but these errors were encountered: