callfn

package
v0.10.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 25, 2021 License: GPL-3.0, GPL-3.0 Imports: 2 Imported by: 0

Documentation

Overview

Package Callfn facilitates the ARM CALLFN process common to both DPC+ and CDF* cartridge mappers. It does not handle the ARM itself and cartridge mappers that use it should take care in particular to Run() and Step() the ARM when required.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type CallFn

type CallFn struct {

	// on ARM program conclusion we JMP to the address after the CALLFN
	ResumeAddr uint16
	// contains filtered or unexported fields
}

CallFn keeps track of the CallFn process common to both DPC+ and CDF* cartridge mappers.

func (*CallFn) Check

func (cf *CallFn) Check(addr uint16) (uint8, bool)

Check state of CallFn. Returns true if it is active and false if it is not. If CallFn is active then the the value to put on the data bus is also returned. If CallFn is not active then the data bus value should be determined in the normal way (most probably by reading the cartridge ROM).

func (*CallFn) IsActive

func (cf *CallFn) IsActive() bool

IsActive returns true if ARM program is still running.

func (*CallFn) Start

func (cf *CallFn) Start(cycles float32)

Start the CallFn process.

func (*CallFn) Step

func (cf *CallFn) Step(clock float32) bool

Step forward one clock. Returns true if CallFn is active and false if not. If false, then the ARM should be stepped but not otherwise.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL