* cpu/drcbearm64.cpp: Optimised setting up carry flag for ADDC and SUBB.
There's no need to preserve the NZV flags so a two-instruction
sequence can be used.
* cpu/drcbex64.cpp: Simplified code generation for CARRY. I have no
idea why it was preserving RAX at all - it always uses RAX as a
scratch register.
* Fixed program address masks for word addressing.
* Fixed PC shift in state string export.
* handheld/pensebem.cpp: Fixed internal ROM region size.
* makerbot/replicator.cpp: Use lowercase hexadecimal literals.
* skeleton/venteta.cpp: Fixed CPU type for fix PC size (16 bits - also word unit) and internal RAM size (4000 bytes).
* ultimachine/rambo.cpp: Fixed internal ROM region size, use lowercase hexadecimal literals.
* Use references rather than pointers where appropriate, made some variables const.
* Made parameter names match in header and source and reformatted code.
* Also cleaned up metadata, focusing on Laureate Learning Systems, Micrograms Publishing, and Softsmith.
* Removed an imperfect crack of Fractions for Apple II.
New working software list items (apple2_flop_orig.xml)
-------------------------------
Accounts Receivable (version 2.1) (Softsmith)
Acey-Deucey (Softsmith)
Algebra Volume 1 (version 1.3, 31-DEC-81) (Softsmith)
All About Light and Sound
Animal Bytes: Katie the Camel
Animal Bytes: Larry the Lion
Animal Bytes: Maggie the Mink
Animal Bytes: Oscar the Otter
Animal Bytes: Sammy the Sloth
Animal Bytes: Simon the Snake
Astro Attack (Softsmith)
Bugbyter (Softsmith)
Con-Putation (Softsmith)
Concentrate! On Words & Concepts I
Concentrate! On Words & Concepts II
Coordinate Geometry
Cosmic Combat (Softsmith)
Creature Magic
Cross Country Rallye (Softsmith)
Dinner on a Disk (Softsmith)
Disk Director (Softsmith)
Dr. Know
Dragon Wars
Early Emerging Rules: Negation (version 1.0)
Early Emerging Rules: Plurals (version 1.0)
Falcons (Softsmith)
First Verbs
First Words
First Words II
Following Directions: One and Two-Level Commands - Spatial Relations
Fractions (version 3.0 04-10-82) (Softsmith)
Friends or Lovers (Softsmith)
Game of the U.S. (Softsmith)
GeoArt
Geometry Concepts (version 2.1)
Grammar: Building Better Language Skills: Sentences
Grammar: Building Better Language Skills: Verbs
Keyboard Golf (Softsmith)
L.A. Land Monopoly (Softsmith)
Lazer Maze (Softsmith)
Lazer Silk (Softsmith)
Little Counter (version 1.1 26-FEB-82) (Softsmith)
LogoMotion (version 1.2) (Softsmith)
Marine Life: Invertebrate Anatomy
Mathosaurus: Kindergarten
Meet The Presidents (Softsmith)
Micro Barmate (version 1.0) (Softsmith)
Modern Biology: Cellular Respiration
Modern Biology: Photosynthesis
Mummy's Curse (Softsmith)
Music Concepts
Pet Shop (A-347 version 1.0)
Plant and Animal Cells
Starblaster (Softsmith)
States (version 2.0)
SuperGraph
WordFinder
Words & Concepts
Zenith (Softsmith)
New non-working software list items (apple2_flop_orig.xml)
-------------------------------
Guardian (Softsmith)
Removed (apple2_flop_clcracked.xml)
-------------------------------
Fractions (version 3.1 / 25-NOV-83) (imperfect clean crack)
New working software list items (mac_flop_orig.xml)
-------------------------------
Archon
Fast Break
Ferrari Grand Prix (version 1.37)
Fraction Action
FullPaint (version 1.0)
Grid Wars (version 1.0)
Hacker
HardBall
The Bitstream Typeface Library (version 2.0)
New working software list items (mac_flop_clcracked.xml)
-------------------------------
Archon (san inc crack)
Blockout (version 1.3) (4am crack)
Fraction Action (san inc crack)
FullPaint (version 1.0) (san inc crack)
Grid Wars (version 1.0) (san inc crack)
Hacker (san inc crack)
HardBall (san inc crack)
MacRacquetball (version 2.0) (4am crack)
* cpu/drcbearm64.cpp: Fixed ROLAND, ROLINS and CARRY clobbering the
shift input when it's a a register.
* cpu/drcbex86.cpp: Fixed DROLINS clobbering source in I0 and
miscalculating flags when destination is I0.
* cpu/uml.h: Removed assertion that's no longer valid.
* cpu/drcbearm64.cpp: Added minimal operand swizzling to allow AND, OR
and XOR to work without the simplifier.
* cpu/drcbex64.cpp: Optimised shift operations slightly.
* cpu/drcbec.cpp: Added stub implementations for TEST with no flag
outputs to allow running with simplifier disabled.
* cpu/drcbec.cpp: Implemented DREADM/DWRITEM with byte size access.
* cpu/drcbec.cpp: Store pointer to address space directly in instruction
stream.
* cpu/drcbearm64.cpp: Removed some special cases for situations the
simplifier deals with for ROLAND and ROLINS.
* cpu/drcbec.cpp: Added some actual detail to error messages on
encountering unexpected instructions.
- Identified the unkljfpk set as Poker Plus 6 Cards.
- Added new set of Turbo Poker II as parent.
- Added new inputs, worked machine configs, and
buttons-lamps layouts for new games.
- Got rid of some now unnecessary driver inits
- Added another set of Turbo Poker II as first clone.
- Added support for special Turbo Poker II NVRAM.
- Created an extended memory map and respective machine config.
- Added support for enable/disable the NVRAM, required
by the Turbo Poker II MCU handling.
- Created a machine start to init all the necessary things.
- Added new sets: cgip30e, hilokimb, norautpb,
gtipokrb, pokplusa, pokplusb, tpoker2, & tpoker2a.
- More sets: krampcb2, krampcb5 (now working),
and krampcb3, krampcb4, krampcb6 (encrypted).
- Added the PLDs to the Turbo Poker II games as binaries.
- Unified the bipolar PROM palette size in 256 entries.
- Added more documentation, and ASCII PCB layouts.
- Added technical notes.
New working systems
-------------------
Credit Poker (ver.30e, Extra Bonus) [Roberto Fresca, Grull Osgo, Ioannis Bampoulas]
Joker Poker 2000 (£15, Winbank) [Roberto Fresca, Grull Osgo, Ioannis Bampoulas]
Draw Poker HI-LO (bootleg, set 1) [Roberto Fresca, Grull Osgo, Alan Griffin]
New working clones
------------------
GTI Double or Nothing Draw Poker (Cleco) [Roberto Fresca, Grull Osgo, Ioannis Bampoulas]
Draw Poker HI-LO (bootleg, set 2) [Roberto Fresca, Grull Osgo, Alan Griffin]
New systems marked not working
------------------------------
Kimble Double HI-LO (z80 version, unencrypted) [Roberto Fresca, Grull Osgo, Ioannis Bampoulas]
Turbo Poker 2 (set 1) [Roberto Fresca, Grull Osgo, Ioannis Bampoulas]
unknown Kramer Poker (pcb3, encrypted) [Roberto Fresca, Grull Osgo, Alan Griffin]
unknown Kramer Poker (pcb4, encrypted) [Roberto Fresca, Grull Osgo, Alan Griffin]
unknown Kramer Poker (pcb6, encrypted) [Roberto Fresca, Grull Osgo, Alan Griffin]
New clones marked not working
-----------------------------
Poker Plus 6 Cards (set 2) [Roberto Fresca, Grull Osgo, Ioannis Bampoulas]
Poker Plus 6 Cards (set 3) [Roberto Fresca, Grull Osgo, Ioannis Bampoulas]
Turbo Poker 2 (set 1) [Roberto Fresca, Grull Osgo, Ioannis Bampoulas]
* machine/rescap.h: Implemented audio potentiometer law.
Used it in oberheim/dmx.cpp and linn/linndrum.cpp.
* machine/rescap.h: Function should not be a constexpr.
Also avoiding pow in constexpr constants.
* apple/rbv.cpp: Send blue channel to all outputs when a monochrome
monitor is connected.
* apple/rbv.cpp: Implement device_palette_interface rathr than using a
separate palette device.
* apple/rbv.cpp: Derive 60.15 Hz timer and pseudo-VIA clock from clock
input.
* apple/maciici.cpp: Derive clocks from RBV clock crystal.
-docs: Link more configuration options to their descriptions.
* bus/snes/st018.cpp: Add primary support of ST018 coprocessor
moritas2 now boots, but still hangs at in-game.
* bus/snes/st018.cpp: Fix CPU latch accessing
This is pretty hacky - it uses hard-coded parameters to give timing that
would work for each monitor. I have no idea how the CRTC is actually
configured.
* cpu/drcbec.cpp: Interpret index operand for load/store instructions as
a signed value for consistency with other back-ends.
* cpu/drcbec.cpp: Honour alignment rules when packing immediate values.
* cpu/drcbex64.cpp: Don't special-case SEXT with an immediate source -
the simplifier takes care of this.
* cpu/drcbex86.cpp: Be explicit about preserving flags in load/store
instructions.
* docs: Added a couple more UML data movement instructions.
* 6522via: Don't generate a signal on PB7 when the timer 1 latch is
programmed with 0.
On the Victor 9000, the clock for the audio codec is generated by a
via6522. PB7 is connected to the codec's clock input. Non-speech
sounds (e.g. beeps, musical notes) are produced by outputting a cyclical
waveform from the codec, with the pitch determined by the frequency of
the codec clock.
Software running on the Victor 9000 has been observed to attempt to
silence the audio by writing 0 to the T1 timer latch (not by turning off
continuous mode or PB7 output). With the emulated via6522, this resulted
in a high-frequency clock signal being output on PB7, causing a
high-pitched squeal whenever notes are not being played.
From this observed behavior we could infer that the original 6522 HW
does not output a signal on PB7 when the latch value is 0, and that the
Victor 9000 software was relying on this behaviour to silence the audio
output (one would have to assume that the real hardware didn't produce
a squeal).
* mc6852: fix various transmit-related issues which were preventing
victor9k Audio output from working.
The expected behavior of mc6852 is to write the data received in the
FIFO register serially via tx_data_callback(). However, this was not
implemented, and the only way data in the transmit FIFO could be
removed and transmitted was by calling get_tx_byte(), and to then
serially transmit the data by some external mechanism.
Only m68sfdc.cpp calls get_tx_byte(), so it's hard to see how any
other device using the mc6852 would have been able to transmit data.
Software running on victor9k attempting to play audio would hang,
since it would block waiting for the TX FIFO to empty. With these
changes, Victor 9000 audio playback works as expected, with the data
getting sent serially to the Audio codec.
In order to avoid breaking m68sfdc, a new API call is added to allow
data to be sent the "old" way. m68sfdc now calls
set_tx_pull_mode(true), to get the previous behavior. As I understand
it, other devices using mc6852 must be broken, and would need to
be revisited.
* victor9k: complete Audio support, adding a low-pass filter after
the HC-55516 codec. Mark victor9k Audio as working.
* cpu/drcbearm64.cpp Interpret index operand for load and store
instructions as a signed 32-bit value for consistency with x86-64.
Moved code to interpret load and scale the index for integer
load/store to a helper function to make it easier to update if it
needs changes or fixes.
* cpu/drcbearm64.cpp: Use and/orr to set carry flag directly rahter than
using an intermediate register when both operands of a CARRY
instruction are immediates.
* cpu/drcbearm64.cpp: Fixed incorrect operand type assertion for FREAD.
* cpu/drcbearm64.cpp: Use less verbose asmjit helper functions for shift
operations and addressing modes.
* cpu/drcbex64.cpp: Interpret index operand for floating point
load/store as a signed 32-bit value for consistency with integer
load/store.
* cpu/drcbex64.cpp: Guard against any possibility of load and store
instructions altering the flags.
* cpu/drcbex64.cpp: Reduced copy/paste in floating point load/store
instructions.
* cpu/drcbex64.cpp: Cleaned up some casts between integer types with
differing size and signedness.
* docs: Added reference for UML flow control, data movement and emulated
memory access instructions.
* cpu/uml.cpp: Truncate immediates to size for a few more instructions.
* cpu/uml.cpp: Added SPACE_OPCODES since it's a well-known address space
now.
* cpu/uml.cpp: Removed SCALE_DEFAULT. It's unimplemented by back-ends
and unused by front-ends.
* cpu/uml.h, cpu/drcumlsh.h: Less confusing names for parameters to read
and write instruction generators.
* cpu/drcbex86.cpp: Templated 64-bit multiplication helpers on the
zero/sign flag source, cleaned up casting pointers to integers.
New working software list items
-------------------------------
Beyond Zero Tolerance (prototype 19950714) [Hidden Palace]
Eyra - The Crow Maiden (digital release) [no-intro]
Zero Tolerance (Europe, USA) (rev. C) [no-intro]
Zero Tolerance (Germany) [no-intro]
Zero Wing (Retro-Bit) [no-intro]
Zombies Ate My Neighbors (Limited Run Games) [no-intro]