;	A L T O C O N S T S 2 3 . M U
; Copyright Xerox Corporation 1979

; Symbol and constant definitons for the standard Alto microcode.
; These definitions are for:
;	AltoCode23, AltoCode24, AltoIICode2, and AltoIICode3
; By convention, people writing microcode should 'include' this file
;   in front of their microcode using the following MU construct:
;	#AltoConsts23.mu;
; This entire file is full of magic.  If you modify it in any way
;   you run the risk of being incompatible with the Alto world,
;   not to mention having your Alto stop working.
;
; Revision History:
; September 20, 1977  8:33 PM by Boggs
;	Created from old AltoConsts23.mu
; September 23, 1977  12:17 PM by Taft
; October 11, 1977  2:07 PM by Boggs
;	Added XMAR definition
; May 21, 1979  6:42 PM by Taft
;	Added SRB← and ESRB←

;Symbol definitions

;Bus Sources
;BS 0 ← RRegister
;BS 1 RRegister← (zeroes the bus)
;BS 2 is undefined and therefore makes the bus all ones
;BS 3 and 4 are task specific.  For the 'Ram related' tasks they are:
;	BS 3: ← SRegister
;	BS 4: SRegister← (clobbers the bus with undefined value)
;BS 5 is main memory data (see definition for MD, below)
$MOUSE		$L000000,014006,000100; BS = 6
$DISP		$L000000,014007,000120; BS = 7

;Standard F1s
$XMAR		$L072000,000000,144000; F1 = 1 and F2 = 6 (Extended MAR)
$MAR		$L020001,000000,144000; F1 = 1
$TASK		$L016002,000000,000000; F1 = 2
$BLOCK		$L016003,000000,000000; F1 = 3
$LLSH1		$L000000,022004,000200; F1 = 4
$LRSH1		$L000000,022005,000200; F1 = 5
$LLCY8		$L000000,022006,000200; F1 = 6

;Standard F2s
$BUS=0		$L024001,000000,000000; F2 = 1
$SH<0		$L024002,000000,000000; F2 = 2
$SH=0		$L024003,000000,000000; F2 = 3
$BUS		$L024004,000000,000000; F2 = 4
$ALUCY		$L024005,000000,000000; F2 = 5
$MD		$L026006,014005,124100; F2 = 6, BS = 5

;Emulator specific functions
$BUSODD		$L024010,000000,000000; F2 = 10
$LMRSH1		$L000000,062005,000200;	F2 = 11 Magic Right Shift
$LMLSH1		$L000000,062004,000200;	F2 = 11 Magic Left Shift
$DNS		$L030012,000000,060000; F2 = 12 Do Nova Shift
$ACDEST		$L030013,032013,060100; F2 = 13 Nova Destination AC
$IR		$L026014,000000,124000; F2 = 14 Instruction Register
$IDISP		$L024015,000000,000000; F2 = 15 IR Dispatch
$ACSOURCE	$L000000,032016,000100; F2 = 16 Nova Source AC

;RAM-related task-specific functions
$SWMODE		$L016010,000000,000000;	F1 = 10 Switch Mode (emulator only)
$WRTRAM		$L016011,000000,000000;	F1 = 11 Write Ram
$RDRAM		$L016012,000000,000000;	F1 = 12 Read Ram
$RMR		$L020013,000000,124000;	F1 = 13 Reset Mode Register (emulator only)
$SRB		$L020013,000000,124000;	F1 = 13 Set Register Bank (non-emulator)
$ESRB		$L020015,000000,124000;	F1 = 15 Set Register Bank (emulator only)

;Emulator specific functions decoded by the ETHERNET board
$RSNF		$L000000,070016,000100;	F1 = 16 Read Serial (Host) Number
$STARTF		$L016017,000000,000000;	F1 = 17 Start I/O

$M		$R40;			The M Register
$L		$L040001,036001,144200; The L Register
$T		$L052001,054001,124040; ALUF = 1, The T Register

;ALU Functions.  * => loads T from ALU output
$ORT		$L000000,050002,000002; ALUF = 2 *
$ANDT		$L000000,050003,000002; ALUF = 3
$XORT		$L000000,050004,000002; ALUF = 4
$+1		$L000000,050005,000002; ALUF = 5 *
$-1		$L000000,050006,000002; ALUF = 6 *
$+T		$L000000,050007,000002; ALUF = 7
$-T		$L000000,050010,000002; ALUF = 10
$-T-1		$L000000,050011,000002; ALUF = 11
$+INCT		$L000000,050012,000002; ALUF = 12 * synonym for +T+1
$+T+1		$L000000,050012,000002; ALUF = 12 *
$+SKIP		$L000000,050013,000002; ALUF = 13
$.T		$L000000,050014,000002; ALUF = 14 *
$AND NOT T	$L000000,050015,000002; ALUF = 15

; A request has been made for the following, but it is unlikely ever to be implemented.
;$ZEROALU	$L000000,050016,000040;	ALUF = 16
;ALUF 17 is unassigned

;Handy fakes
$SINK		$L044000,000000,124000;	DF3 = 0  Bus source without dest 
$NOP		$L042000,000000,000000;	NDF3 = 0 every computer needs one

; Definitions for the Nova debugger and DEBAL
$HALT		$L042001,000000,000000;
$BREAK		$L042003,000000,000000;
$WENB		$L042005,000000,000000;
$READY?		$L042006,000000,000000;
$NOVA		$L044002,046003,124100;
$END		$L034000,000000,000000;


;Constant definitions

$0		$L000000,012000,000100;	Constant 0 is SUPER SPECIAL

$ALLONES4	$M4:177777;	Constant normally ANDed with KSTAT
$ALLONES5	$M5:177777;	Constant normally ANDed with MD
$M17		$M6:000017;	Constant normally ANDed with MOUSE
$ALLONES7	$M7:177777;	Constant normally ANDed with DISP
$M177770	$M7:177770;	Mask for DISP
$M7		$M7:000007;	Mask for DISP
$X17		$M7:000017;	Mask for DISP

$ONE		$1;		The constant 1
$2		$2;
$-2		$177776;	- Disk header word count
$3		$3;
$4		$4;
$5		$5;
$6		$6;
$7		$7;
$10		$10;
$-10		$177770;	- Disk label word count
$17		$17;
$20		$20;
$37		$37;
$ALLONES	$177777;	The REAL -1 (not a mask)
$40		$40;
$77		$77;
$100		$100;
$177		$177;
$200		$200;
$377		$377;
$177400		$177400;
$-400		$177400;	- DISK DATA WORD COUNT
$2000		$2000;
$PAGE1		$400;
$DASTART	$420;		MAIN MEMORY DISPLAY HEADER ADDRESS
$KBLKADR	$521;		MAIN MEMORY DISK BLOCK ADDRESS
$MOUSELOC	$424;		MAIN MEMORY MOUSE BLOCK ADDRESS
$CURLOC		$426;		MAIN MEMORY CURSOR BLOCK ADDRESS
$CLOCKLOC	$430;
$CON100		$100;
$CADM		$7772;		CYLINDER AND DISK MASK
$SECTMSK	$170000;	SECTOR MASK
$SECT2CM	$40000;		CAUSES ILLEGAL SECTORS TO CARRY OUT
$-4		$177774;	CURRENTLY UNUSED
$177766		$177766;	CURRENTLY UNUSED
$177753		$177753;	CURRENTLY UNUSED
$TOTUWC		$44000;		NO DATA TRANSFER, USE WRITE CLOCK
$TOWTT		$66000;		NO DATA TRANSFER, DISABLE WORD TASK
$STUWC		$4000;		TRANSFER DATA USING WRITING CLOCK
$STRCWFS	$10000;		TRANSFER DATA USING NORMAL CLOCK, WAIT FOR SYNC
$177000		$177000;
$77777		$77777;
$77740		$77740;
$LOW14		$177774;
$77400		$77400;
$-67D		$177675;
$7400		$7400;
$7417		$7417;
$170360		$170360;
$60110		$60110;
$30000		$30000;
$70531		$70531;
$20411		$20411;
$65074		$65074;
$41023		$41023;
$122645		$122645;
$177034		$177034;
$37400		$37400;
$BIAS		$177700;	CURSOR Y BIAS
$WWLOC		$452;		WAKEUP WAITING IN PAGE 1
$PCLOC		$500;		PC VECTOR IN PAGE 1
$100000		$100000;
$177740		$177740;
$COMERR1	$277;		COMMAND ERROR MASK
$-7		$177771;	CURRENTLY UNUSED
$177760		$177760;
$-3		$177775;
$4560		$4560;
$56440		$56440;
$34104		$34104;
$64024		$64024;
$176000		$176000;
$177040		$177040;
$177042		$177042;
$203		$203;
$360		$360;
$177600		$177600;
$174000		$174000;
$160000		$160000;
$140000		$140000;
$777		$777;
$1777		$1777;
$3777		$3777;
$7777		$7777;
$17777		$17777;
$37777		$37777;
$1000		$1000;
$20000		$20000;
$40000		$40000;
$-15D		$177761;
$TRAPDISP	$526;
$TRAPPC		$527;
$TRAPCON	$470;
$JSRC		$6000;		JSR@ 0
$MASKTAB	$460;		Mask Table Starting address for convert
$SH3CONST	$14023;		DESTINATION = 3, SKIP IF NONZERO CARRY,
;				BASE CARRY = 0

$600		$600;		Ethernet addresses
$601		$601;
$602		$602;
$603		$603;
$604		$604;
$605		$605;
$606		$606;
$607		$607;
$610		$610;
$612		$612;

$ITQUAN		$422;
$ITIBIT		$423;	
$402		$402;		where label block is stored on disk boot
$M177760	$M7:177760;	MASK FOR DISP.  FOR I/O INSTRUCTIONS
$JSRCX		$4000;		JSR 0
$KBLKADR2	$523;
$KBLKADR3	$524;

$MFRRDL		$177757;	DISK HEADER READ DELAY IS 21 WORDS
$MFR0BL		$177744;	DISK HEADER PREAMBLE IS 34 WORDS
$MIRRDL		$177774;	DISK INTERRECORD READ DELAY IS 4 WORDS
$MIR0BL		$177775;	DISK INTERRECORD PREAMBLE IS 3 WORDS
$MRPAL		$177775;	DISK READ POSTAMBLE LENGTH IS 3 WORDS
$MWPAL		$177773;	DISK WRITE POSTAMBLE LENGTH IS 5 WORDS
$BDAD		$12;		ON BOOT, DISK ADDRESS GOES IN LOC 12

$REFMSK		$77740;		MRT Refresh mask
$X37		$M7:37;		NOPAR MASK
$M177740	$M7:177740;	DITTO
$EIALOC		$177701;	LOCATION OF EIA INPUT HARDWARE

$7000		$7000;		mapbase
$176		$176;		mapmask
$177576		$177576;	mapmask3
$30		$30;		reprobinc
$15		$15;		wrt-1
$1770		$1770;		ciad
$101771		$101771;	cilow
$175777		$175777;	for resetting fbn
$11		$11;		just to have small integers
$13		$13;
$14		$14;
$16		$16;		for 2CODE
$60		$60;		low R to high R bus source
$776		$776;
$177577		$177577;	-129
$100777		$100777;
$177677		$177677;
$177714		$177714;	(-2fvar+14)

$2527		$2527;
$101		$101;
$630		$630;
$631		$631;
$642		$642;

$lgm1		$M7:1;
$lgm3		$M7:3;
$lgm10		$M7:10;
$lgm14		$M7:14;
$lgm20		$M7:20;
$lgm40		$M7:40;
$lgm100		$M7:100;
$lgm200		$M7:200;

$disp.300	$M7:300;
$-616		$177162;
$-650		$177130;
$22		$22;
$24		$24;
$-20		$177760;
$335		$335;		endcode for getframe
$1377		$1377;		smallnzero
$401		$401;
$2001		$2001;
$21		$21;		just to have them
$23		$23;
$25		$25;
$26		$26;
$27		$27;
$31		$31;
$1675		$1675;
$736		$736;
$-660		$177120;
$300		$300;
$disp.377	$M7:377;
$6001		$6001;		f.e. flg, quick flg, use count
$disp.3		$M7:3;

; Constants for subroutine returns using IR.
; See 9.2.1 of the hardware manual for details.

$sr1		$60110;
$sr0		$70531;
$sr2		$61000;
$sr3		$61400;
$sr4		$62000;
$sr5		$62400;
$sr6		$67000; 	value of 16b mapped to 6 by disp prom
$sr7		$63400;
$sr10		$64024;
$sr11		$64400;
$sr12		$65074;
; Are you wondering why sr13 is missing?  So is everyone else.
$sr14		$66000;
$sr15		$66400;
$sr16		$63000; 	value of 6 mapped to 16b by disp prom
$sr17		$77400;
$sr20		$65400;
$sr21		$65401;
$sr22		$65402;
$sr23		$65403;
$sr24		$65404;
$sr25		$65405;
$sr26		$65406;
$sr27		$65407;
$sr30		$65410;
$sr31		$65411;
$sr32		$65412;
$sr33		$65413;
$sr34		$65414;
$sr35		$65415;
$sr36		$65416;
$sr37		$65417;

$-13D		$177763;

$ERRADDR	$177024;	AltoII MEAR (Memory Error Address Reg)
$ERRSTAT	$177025;	AltoII MESR (Memory Error Status Reg)
$ERRCTRL	$177026;	AltoII MECR (Memory Error Control Reg)
$REFZERO	$7774;

$2377		$2377;		Added for changed Ethernet microcode
$2777		$2777;
$3377		$3377;
$477		$477;		Added for BitBlt
$576		$576;		Added for Ethernet boot
$177175		$177175;

;Requests for the following new constants have been made:
;NOTE THAT THESE ARE NOT YET DEFINED

;$lgm2		$M7:2;
;$lgm4		$M7:4;
;$32		$32;
;$33		$33;
;$34		$34;
;$35		$35;
;$36		$36;