84PCE:Ports:6000

From WikiTI
Revision as of 20:51, 3 April 2015 by Calc84maniac (Talk | contribs)

Jump to: navigation, search

Synopsis

Port Number: 6000-601F

Memory-mapped address: F10000

Function: Watchdog timer

This range of ports is a watchdog timer (appears to be model FTWDT010). Its primary feature is a 32-bit looping downward counter which can be set to either 32768Hz or the CPU frequency. It can also be used to reset the calculator or trigger a non-maskable interrupt (which typically will also reset the calculator). It is unknown whether it can trigger a maskable interrupt.

Registers

All registers are little-endian.

  • 6000-6003 (R):
    • 32-bit counter register.
  • 6004-6007 (R/W):
    • 32-bit load register. The counter is loaded with this value when it reaches 0 or the restart register is used.
  • 6008-6009 (W):
    • 16-bit restart register. When the value 5AB9h is written here, the counter is restarted. The bytes can be written individually.
  • 600C (R/W):
    • Bit 0: Timer enable. Set to make the counter count down.
    • Bit 1: System reset enable. Set to reboot the calculator when the counter reaches 0.
    • Bit 2: System reset interrupt enable. Set to trigger a non-maskable interrupt when the counter reaches 0.
    • Bit 3: External signal enable. Set to enable the external signal when the counter reaches 0 (this may have no effect).
    • Bit 4: Clock source. Set to 1 to use the 32768Hz clock, or 0 to use the CPU clock.
  • 6010 (R):
    • Status register. Bit 0 is set after the timer has reached 0, otherwise reset.
  • 6014 (W):
    • Status clear register. Write 1 to reset bit 0 of the status register.
  • 6018 (R/W):
    • 8-bit interrupt length register. Controls the amount of time an interrupt is signaled.
  • 601C-601F (R):
    • 32-bit revision register. Reads a constant 0x00010602, which corresponds to revision 1.6.2.