Z-80 code question about a loop that depends on the contents of the refresh register
Maciej W. Rozycki
macro at linux-mips.org
Fri Dec 30 12:45:55 CST 2016
On Wed, 14 Dec 2016, Tony Duell wrote:
> What I need to do is find exactly how the flags are set by the
> LD A,R
It's been long since I did anything with the Z80, but offhand all flags
are set as with ALU operations according to the value loaded into the
accumulator (same with LD A,I, but not the reverse loads IIRC). These are
the only Z80 LD instructions that set the flags.
If help is still needed with interpreting this piece of code I can reach
out for documentation and refresh old memory.
BTW, as a side effect of incomplete instruction decoding and the lack of
trapping on unimplemented operations the Z80 had a number of undocumented
operations available, which however were reliable across different silicon
manufactured and eventually got figured out and documented. Some software
relied on correct execution of these operations and may require an
accurate emulator implementation to run correctly.
XZX is one emulator I know of that has claimed support for all these
operations in its core processor support (I and R registers should also be
correctly handled); otherwise emulating Sinclair ZX Spectrum class systems
and running as an X11 client on various *nix systems. I haven't used it
for years now though and have no idea whether it has been maintained
beyond 1997 which is when the version I still have around has been
released.
Maciej
More information about the cctech
mailing list