← Back to Technotes

#26: ROM Revision Summary

Author: Rilla Reynolds (rev. Matt Deatherage)
Year: 1987

... summarizes revisions to the Apple IIGS ROM (0/1/3).

View raw text file

Apple II
Technical Notes
_____________________________________________________________________________
                                                  Developer Technical Support


Apple IIGS
#26:    ROM Revision Summary

Revised by:    Matt Deatherage                                 September 1989
Written by:    Rilla Reynolds                                    October 1987

This Technical Note summarizes revisions to the Apple IIGS ROM.
Changes since November 1988:  Revised to cover ROM 3.
_____________________________________________________________________________

Apple currently supports two configurations of the Apple IIGS ROM, ROM 1 and 
ROM 3.  In August 1989, Apple IIGS computers began shipping with a 256K ROM, 
referred to as version 3 or ROM 3 (ROM 2 was skipped since there was already 
enough confusion about the first version, ROM 0, and the second version, ROM 
1).  System Software continues to support ROM 1, but it no longer supports ROM 
0.  Authorized Apple dealers can upgrade older systems (i.e., machines with 
serial numbers lower than E704...) to ROM 1 upon request.

ROM 1 requires System Software 2.0 or later, while ROM 3 requires System 
Software 5.0 or later.  Although applications may work using older system 
software releases, they may not function properly due to the coordination of 
system software and ROM revisions.


Changes from ROM 0 to ROM 1

ADB

  o  Absolute ADB devices are now supported correctly.
  o  ADB fatal system error code is now $0911 instead of $0400.
  o  ADBReset routine now delays about 160 microseconds before reading 
     the buttons.
  o  ADBStatus TRUE is now $FFFF instead of $0001.
  o  All ADB error codes now include the tool number.
  o  SRQrmv no longer crashes when you make the call with a command 
     pending.

AppleDisk 3.5

  o  AppleDisk 3.5 Macintosh block reads and writes now work as 
     documented.
  o  Extended status call now returns bit 0 = 1 if AppleDisk 3.5 media 
     has been switched since the last READ, WRITE, or FORMAT.
  o  New AppleDisk 3.5 status calls have been implemented to get 
     internal variable and work buffer starting addresses.

AppleTalk

  o  Link Access Protocol (LAP) inter-packet gap now handles added SCC 
     delay.
  o  Name Binding Protocol (NBP) now considers uppercase and lowercase 
     characters identical.
  o  A nonexistent protocol no longer hangs the dispatcher.

Desk Manager

  o  SaveScreen and RestoreScreen now work.

Event Manager

  o  Now auto-key events are not posted in the queue unless the queue 
     is empty.
  o  EMStartUp and EMShutDown code has been optimized.
  o  Event Manager now returns an error instead of crashing when there 
     is an attempt to post an invalid event.

Integer Math

New Changes:
  o  Optimized the multiply routine.
RAM patches moved to ROM:
  o  Changes to FixMul, FixRatio, and SDivide.
  o  SDivide recovers from a divide by zero operation.
  o  New calls:  FracMul, FixDiv, FracDiv, FixRound, FracSqrt, FracCos, 
     FracSin, FixATan2, HiWord, LoWord, Long2Fix, Fix2Long, Fix2Frac, 
     Frac2Fix, Fix2X, Frac2X, X2Fix, X2Frac.

Memory Manager

  o  Optimized Purge and Compact for banks 0 and 1 and moved from RAM 
     to ROM.
  o  RAM patches and enhancements moved to ROM.
  o  RAMdisk now returns bytes transferred count on DIB call.
  o  SetHandleSize makes a handle temporarily unpurgeable while 
     changing handle size.

Miscellaneous Tools

RAM patches and enhancements moved to ROM:
  o  AbsClamp fixes.
  o  Battery RAM routines work if data bank is set to a bank other than 
     bank data is in.
  o  Firmware entry calls now return processor status in high byte 
     instead of low byte.
  o  GetAddr with ref number $000E returns SerFlag address for SCC 
     interrupts (useful if not using serial firmware).
  o  ID manager can reuse discarded IDs.
  o  Keyboard interrupts now enable VBL interrupts.
  o  Munger now works with 1-char strings and returns with A=0.
  o  New SysBeep call.
  o  PackBytes and UnpackBytes return with A=0.
  o  ReadBParam and ReadBRAM error codes corrected.
  o  WriteBParam and WriteBRAM do not return error codes (this is a 
     documentation change).
  o  WriteTimeHex Bad Parameter error code is now $31.

Monitor

  o  80-column screens maintained if break occurs and Pascal protocol 
     in effect.
  o  AppleSoft tabbing in 80-column mode now works correctly.
  o  Control Panel's Maximum RAM Disk Size increased to 8128K instead 
     of 4096K.
  o  Firmware version number returned is $1 instead of $0.
  o  Interrupts now disabled during paddle read routines.
  o  Interrupts re-enabled after fatal system error (for debug DAs).
  o  Mouse clamps with positive minimum and negative maximum works 
     (e.g., $6000 min, $8000 max).
  o  New monitor command, pound sign (#), installs monitor entry and 
     memory peeker classic desk accessories (unless already installed), 
     accessible via the Control Panel.  Reinstalled automatically on 
     reset;  disabled by power off only.
  o  New monitor command, Control-N, clears m, e, and x bits for native 
     mode.  (Control-R still  switches to 8-bit, emulation mode.)
  o  RESET entry point at $00FA62 sets state register to $0C and shadow 
     register to $08.
  o  Shadowing of the Super Hi-Res area in Bank 1 is no longer enabled 
     automatically.
  o  WAIT routine now always exits with C=1.

QuickDraw II

RAM patches and enhancements moved to ROM:
  o  640-mode pen masks now work when portRect origin not a multiple of 8.
  o  Arcs, ovals, and round rects can be drawn across bank boundaries.
  o  Changes to round drawing routines: PPToPort, GetFontLore, 
     GetROMFont, and InflateTextBuffer.
  o  Current bank bytes 100...106 no longer modified by scaling and 
     mapping calls.
  o  FontFlags 1 and 2 added for pen width and color control.
  o  FramePoly returns with A=0.
  o  GetPort returns all four bytes of GrafPort.
  o  HideCursor and ShowCursor work correctly with obscured cursor.
  o  MapRgn now works on rectangular regions.
  o  Pixel painting routines support QuickDraw Auxiliary Tool Set 
     stretching and shrinking.
  o  PPToPort now clips correctly to the current portRect.
  o  QDStartUp and QDShutDown save and restore the scan line interrupt 
     vector.
  o  RectInRgn bug fixed.
  o  ScrollRect works when the ClipRgn and VisRgn are not rectangular.
  o  SetSysFont works.
  o  StdPixels now returns with A=0 if the pen is not visible.
  o  Text underline bug fixed.
  o  TextBounds works.
New QuickDraw changes:
  o  Busy flag now maintained correctly by ClosePort, OffsetRgn, 
     InsetRgn, KillPoly, FillRect, FrameOval, PaintOval, EraseOval, 
     InvertOval, FillOval, FrameArc, PaintArc, EraseArc, InvertArc, 
     FillArc, FrameRRect, PaintRRect, EraseRRect, InvertRRect, and 
     FillRRect.
  o  Cursor appears in correct Super Hi-Res mode as determined by the 
     low byte's bit 7 (320/640) of the MasterSCB.

SANE

  o  Elems now can be called from any part of memory.
  o  HALT exception jumping through the incorrect vector fixed.
  o  Integer overflow during conversion reported.
  o  STATUS call moved to ROM.

Scheduler

  o  Scheduler now accepts a flush function call.
  o  Task-handling RAM patch (on System Disk 1.0 and later) moved to 
     ROM.

Serial I/O

  o  First character after an XON is no longer trashed when buffering 
     is not enabled.
  o  If serial mode bit 17 = 1, parity and framing error suppression 
     are defeated.
  o  Parity, baud, and data format commands work with buffering.
  o  STATUS call will not report that a character is ready if the 
     character arrives with a parity or framing error.
  o  STATUS call works correctly with XON/XOFF protocol.

SmartPort

  o  PR#5, following a PR#5 with I/O error (i.e., no disk in drive), 
     now boots as expected.
  o  SmartPort manipulates only Slot 6 motor on detect so the IWM can 
     run in fast mode.

Sound

  o  Fixed bug in FFStopSound call.
  o  Fixed low-level RAM read/write bug.
  o  Interrupts are disabled when the internal bell is active.
  o  Interrupts no longer need to be disabled when accessing sound RAM.
  o  New sound diagnostics with the following error codes:  $0C001 = 
     failed RAM data test, $0C002 = RAM address test, $0C003 = register 
     data test, and $0C004 = control register test.
  o  Sound Manager RAM patches and enhancements moved to ROM.

Text Tools

RAM patches moved to ROM:
  o  RAM patches moved to ROM for Writing and ErrorWriting routines.
  o  TextInit Illegal device error now is in 16-bit mode instead of 8.

Tool Locator

  o  Optimized tool dispatcher.
  o  ROM tools present on a memory expansion card are installed.


Changes from ROM 1 to ROM 3

ROM 3 is 256K (double the size of ROM 1) and contains several tools which do 
not exist in ROM 1.  The patch file TS3 fixes known bugs in ROM 3 which were 
discovered after it was frozen.  ROM 3 tools are basically System Software 5.0 
tools, and the System Software 5.0 documentation covers these tools in detail.  
This Note only documents non-tool changes.

AppleDisk 3.5 and SmartPort

  o  Use new routines for all block reads to fast RAM to eliminate 
     double buffering.
  o  The extended DIB status call returns the device subtype byte $C1.
  o  Fixed anomalies described in SmartPort Technical Note #6, Apple 
     IIGS SmartPort Errata.
  o  Fixed a ROM 1 bug that caused Write Protected to be returned with 
     higher priority than Device Offline for the ProDOS STATUS call.

AppleTalk

  o  AppleTalk moved to slots 1 and 2 from slot 7.

Control Panel CDA

  o  The original Options menu is now the Keyboard menu and does not 
     contain mouse parameters.
  o  A new Mouse menu is present.  The new keyboard microcontroller 
     allows finer control of mouse tracking, so a selection procedure 
     better than yes or no is present.  Parameters are also available 
     to set the keyboard mouse feature, which allows the numeric keypad 
     to emulate a mouse.
  o  Added an option to resize the RAM disk on the next reset in the 
     RAM Disk menu.  This option resets to No after one reboot and 
     resizing so the RAM disk is not accidently reformatted on every 
     boot thereafter.
  o  If slot 7 is set to AppleTalk, the Control Panel displays a 
     warning if neither slot 1 nor slot 2 is similarly set.
  o  The Printer Port and Modem Port menus now display only those 
     parameters that may be changed if AppleTalk is the selection for 
     those ports.
  o  The RAM disk no longer has minimum and maximum settings, but 
     rather one RAM disk size setting.

Monitor

  o  Enhanced memory searching commands to automatically cross bank 
     boundaries.
  o  Added Step and Trace debugging functions.
  o  Now provide vectors for the same functionality as the GS/OS System 
     Service calls MEMORY_MOVER, DYN_SLOT_ARBITER and SET_SYS_SPEED in 
     bank $E1.
  o  Now resize the RAM disk when the system is rebooted with the 
     Control-Open Apple-Shift-Reset key combination.
  o  Handle text page 2 shadowing and power-up bits in the new CYA 
     chip.
  o  Flash the border if the sound volume is set to zero and a beep is 
     necessary.
  o  In ROM 1 and earlier, the Miscellaneous Tools mouse firmware 
     called the 8-bit mouse routines in the $C400 space to do the work.  
     In ROM 3, the 8-bit routines call the 16-bit routines to read the 
     hardware.  This change effectively means those programs which use 
     16-bit mouse calls (including desktop applications through the 
     Event Manager) may use the mouse when slot 4 is set to Your Card.
  o  Slots 1 and 2 may now be set to Printer, Modem, AppleTalk, or Your 
     Card.  With System Software 5.0, slot 7 does not need to be set to 
     AppleTalk to use an AppleTalk network, although one can do it for 
     compatibility.  There is no transparent printing firmware in slot 7.
  o  The Alternate Display Mode CDA no longer sets the system to fast 
     speed when normal speed is selected in the Control Panel.
  o  Added a new command, {val}=V, to set the video screen display I/O 
     switches when resuming a program.
  o  Control-T command now works as a toggle--executing it once changes 
     to text mode, but now executing it again switches back to the 
     previous video mode   You may change this saved video mode with 
     the =V command.
  o  Battery RAM value $59 now controls the presence of the Visit 
     Monitor and Memory Peeker CDAs.  If this byte has the high bit set 
     at boot time, the CDAs are automatically installed.
  o  The Monitor and Memory Peeker both allow the use of Control-X to 
     terminate a long display (i.e., a handle list or memory dump).

Serial I/O

  o  XON and XOFF are no longer sent with the high bit set when 
     buffering is enabled.
  o  Terminal mode cursor is more consistent with the rest of the 
     system.
  o  Extended Interface calls now return errors in the carry and the 
     accumulator.

Toolbox

The following tools are now in ROM:

  o  Window Manager
  o  Menu Manager
  o  Control Manager
  o  Line Edit
  o  Dialog Manager
  o  Scrap Manager
  o  Font Manager
  o  List Manager


Further Reference
_____________________________________________________________________________
  o  Apple IIGS Firmware Reference
  o  Apple IIGS Toolbox Reference
  o  Apple IIGS Technical Note #52, Loading and Special Memory
  o  SmartPort Technical Note #6, Apple IIGS SmartPort Errata