mirror of
https://github.com/livingcomputermuseum/ContrAlto.git
synced 2026-01-17 00:23:24 +00:00
46 lines
1.5 KiB
C#
46 lines
1.5 KiB
C#
using System;
|
|
|
|
namespace Contralto.CPU
|
|
{
|
|
public partial class AltoCPU
|
|
{
|
|
/// <summary>
|
|
/// DisplayWordTask provides functionality for the DHT task
|
|
/// </summary>
|
|
private sealed class DisplayHorizontalTask : Task
|
|
{
|
|
public DisplayHorizontalTask(AltoCPU cpu) : base(cpu)
|
|
{
|
|
_taskType = TaskType.DisplayHorizontal;
|
|
_wakeup = false;
|
|
}
|
|
|
|
protected override bool ExecuteInstruction(MicroInstruction instruction)
|
|
{
|
|
// We put ourselves back to sleep immediately once we've started running
|
|
_wakeup = false;
|
|
|
|
return base.ExecuteInstruction(instruction);
|
|
}
|
|
|
|
protected override void ExecuteSpecialFunction2(MicroInstruction instruction)
|
|
{
|
|
DisplayHorizontalF2 dh2 = (DisplayHorizontalF2)instruction.F2;
|
|
switch (dh2)
|
|
{
|
|
case DisplayHorizontalF2.EVENFIELD:
|
|
_nextModifier |= (ushort)(_cpu._system.DisplayController.EVENFIELD ? 1 : 0);
|
|
break;
|
|
|
|
case DisplayHorizontalF2.SETMODE:
|
|
_cpu._system.DisplayController.SETMODE(_busData);
|
|
break;
|
|
|
|
default:
|
|
throw new InvalidOperationException(String.Format("Unhandled display word F2 {0}.", dh2));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|