Difference between revisions of "83:Ports:04"

From WikiTI
Jump to: navigation, search
Line 29: Line 29:
 
The calculator uses mode 0 for normal operation. If you change the memory map mode be sure to change it back before returning control.
 
The calculator uses mode 0 for normal operation. If you change the memory map mode be sure to change it back before returning control.
  
To calculate resulting timer frequency you can use the following formula:
+
To calculate the resulting timer frequency you can use the following formula:
  
 
freq = 1800 * ((out_value & 0x10) ? 1.0 : 0.9) / (3 + ((out_value & 0x06) << 1)) / 6000000
 
freq = 1800 * ((out_value & 0x10) ? 1.0 : 0.9) / (3 + ((out_value & 0x06) << 1)) / 6000000

Revision as of 00:12, 3 April 2005

Synopsis

Port Number: 04h

Function: Timer Interrupt Frequency and Memory Map Control

This port controls the frequency of the hardware timer and the memory map mode.

Read Values

This is a mirror of the link port.

Write Values

  • Bit 0 reset to select memory map mode 0. In mode 0 the RAM and ROM is mapped to CPU memory as follows:
    • Address 0000h ~ 3FFFh: ROM Page 0
    • Address 4000h ~ 7FFFh: Swappable (Page selected in 83:Ports:00/83:Ports:02)
    • Address 8000h ~ BFFFh: RAM Page 1
    • Address C000h ~ FFFFh: RAM Page 0
  • Bit 0 set to select memory map mode 1. In mode 1 the RAM and ROM is mapped to CPU memory as follows:
    • Address 0000h ~ 3FFFh: ROM Page 0
    • Address 4000h ~ 7FFFh: RAM Page 0
    • Address 8000h ~ BFFFh: Swappable (Page selected in 83:Ports:00/83:Ports:02)
    • Address C000h ~ FFFFh: RAM Page 1
  • Bits 1 and 2 control the hardware timer frequency. Setting both 0 sets the timer to the fastest speed, and both 1 is the slowest speed. The normal speed is with both bits 1.
  • Bit 3: Unused? Always 0.
  • Bit 4: Timer frequency multiplier; when this bit is set, all the times are multiplied by 90% (i. e. it's 11.1% faster) compared to when it's reset.
  • Bit 5-7: Unknown, but definitely used.

Comments

The calculator uses mode 0 for normal operation. If you change the memory map mode be sure to change it back before returning control.

To calculate the resulting timer frequency you can use the following formula:

freq = 1800 * ((out_value & 0x10) ? 1.0 : 0.9) / (3 + ((out_value & 0x06) << 1)) / 6000000