-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy pathIZ80ProcessorAgent.cs
70 lines (63 loc) · 3.07 KB
/
IZ80ProcessorAgent.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
namespace Konamiman.Z80dotNet
{
/// <summary>
/// Represents a class that allows to perform a limited set of operations on an <see cref="IZ80Processor"/>.
/// </summary>
public interface IZ80ProcessorAgent : IExecutionStopper
{
/// <summary>
/// Reads the next opcode byte from the memory location currently pointed by the PC register,
/// then increments PC by one.
/// </summary>
/// <returns>The byte obtained from memory</returns>
byte FetchNextOpcode();
/// <summary>
/// Reads the next opcode byte from the memory location currently pointed by the PC register,
/// but does not modify PC.
/// </summary>
/// <returns>The byte obtained from memory</returns>
/// <remarks>This method can be useful to handle 0xDD and 0xFD prefixes.
/// If <see cref="IZ80InstructionExecutor.Execute"/> receives one of these bytes, it can use this method
/// the check the next opcode byte. If both bytes do not form a supported instruction
/// (for example, if the second byte is another 0xDD/0xFD byte), then <see cref="IZ80InstructionExecutor.Execute"/>
/// simply returns; the first 0xDD/0xFD acts then as a NOP, and the
/// second byte will be fetched again for the next invocation of <see cref="IZ80InstructionExecutor.Execute"/>.
/// Otherwise, <see cref="FetchNextOpcode"/> in invoked in order to get PC properly incremented.
/// </remarks>
byte PeekNextOpcode();
/// <summary>
/// Reads one byte from memory.
/// </summary>
/// <param name="address">Memory address to read from</param>
/// <returns>Obtained byte</returns>
byte ReadFromMemory(ushort address);
/// <summary>
/// Writes one byte to memory.
/// </summary>
/// <param name="address">Memory address to write to</param>
/// <param name="value">Value to write</param>
void WriteToMemory(ushort address, byte value);
/// <summary>
/// Reads one byte from an I/O port.
/// </summary>
/// <param name="portNumber">Port number to read from</param>
/// <returns>Obtained byte</returns>
byte ReadFromPort(byte portNumber);
/// <summary>
/// Writes one byte to an I/O port.
/// </summary>
/// <param name="portNumber">Port number to write to</param>
/// <param name="value">Value to write</param>
void WriteToPort(byte portNumber, byte value);
/// <summary>
/// Returns the current register set used by the processor.
/// </summary>
IZ80Registers Registers { get; }
/// <summary>
/// Changes the current interrupt mode.
/// </summary>
/// <param name="interruptMode">The new interrupt mode.</param>
/// <exception cref="System.InvalidOperationException">Attempt to set a value other than 0, 1 or 2</exception>
void SetInterruptMode(byte interruptMode);
}
}