{File name: DandeLisp.df Description: Definitions for Dandelion Lisp Microcode, Created: April 6, 1982 by Purcell Last Edited: 12-Aug-83 10:36:31 charnley Last Edited: 20-Jul-83 10:47:17 charnley {nStkLimOffset} Last Edited: April 6, 1983 6:11 PM FUGATO Last Edited: August 1, 1982 12:57 PM nStkLimOffset Last Edited: March 24, 1983 8:48 PM start merging with Mesa 10 Last Edited: March 24, 1983 9:26 PM DiskCSBOffsetIOCB } {for using old dandelion.df with new diskDlion} {DISK CSB (Trident/Shugart/Quantum) - from 14000 to 1400F hex} Set[DiskCSBOffsetIOCB, 0]; {Parameter Settings} Set[KTval, 114'b], {lisp constant KT} Set[AtomEVALFORM, 370'b], Set[AtomGCSCAN, 371'b], Set[AtomMAKENUMBER, 374'b], Set[AtomSETFVAR, 376'b], Set[AtomINTERPRETER, 400'b], Set[nRhS, 2{??}], Set[nStkLimOffset, 7],{%} Set[UFNspace, STATSspace]; Set[STATSspaceReal, 3{1}], Set[MDSTYPEspaceReal, 3{1}]; Set[INTERFACEbasePage, Rshift[INTERFACEbase, 8]]; Set[DTDbasePage, Rshift[DTDbase, 8]]; Set[ListpDTD.Counter, 14'b], Set[ListpDTD.NextPage, 15'b], Set[ConsNxtPg, Add[Lshift[ListType, 4], ListpDTD.NextPage]], Set[ConsCnt, Add[Lshift[ListType, 4], ListpDTD.Counter]], Set[crhHashTable,3]; { Real Page = 1400'b = 300'x} Set[crhTypeTable,3],{Real Page = 1600'b = 380'x} Set[UFNTablePage, Rshift[UFNTablebase, 8]]; {R AND RH REGISTER DEFINITIONS Since there are no task specific registers in the machine, task identifiers are not bound to the register numbers with which they are shown. Q is reserved for the Emulator Task. Also, the stackP, STK, ib, and pc16 registers are reserved for the Emulator task.} {REGISTERS 0 - 6: EMULATOR} {RegDef[TOS, R, 0];} {Top item of Stack (low word)} RegDef[rhTOS, RH, 0]; {temporary} RegDef[TOSH, R, 1]; {Top item of Stack (high word)} RegDef[rhTOSH, RH, 1]; {temporary} {RegDef[TT, R, 2];} {temporary} {RegDef[rhTT, RH, 2];}{temporary} RegDef[PV, R, 3]; {base reg for prog vars} RegDef[rhPV, RH, 3]; RegDef[S, R, 4]; {Stack pointer points to full odd word {best for jump}} RegDef[rhS, RH, 4]; {RegDef[PC, R, 5];} {real address of program counter (PC16 selects byte)} {RegDef[rhPC, RH, 5];} {program counter high} {RegDef[Rx, R, 6];}{temporary} {RegDef[rhRx, RH, 6];}{temporary} {RegDef[rCount, R, 7];}{instruction counter} {U REGISTER BLOCK 7,8 -- DISK(x000) & TRIDENT} {RegDef[uLimit, U, 80];{rA=8}} {RegDef[uDelta, U, 81];} {RegDef[uLimitH, U, 70];{rA=7}} {U REGISTER BLOCK C,D -- ETHER} RegDef[rCountL, R, 0C]; {Ether - debugging count} RegDef[rhCountL, RH, 0C]; {Ether - debugging count} RegDef[rCountH, R, 0D]; {Ether - debugging count} RegDef[rhCountH, RH, 0D]; {Ether - debugging count} RegDef[uLispBootMsg, U, 0DE]; {also in nLispSAx000Initial.mc} {The allocation of Link registers: # task 0 Emulator 1 Emulator 2 Emulator 3 Emulator 4 Disk 5 Display/LSEP 6 Ethernet 7 IOP } {U REGISTER DEFINITIONS Registers indicated by ** contain Emulator state and must not be modified.} {U REGISTER BLOCK 0 -- EMULATOR STACK TOS} RegDef[uU0, U, 0]: RegDef[uValHigh, U, 1]:{*** rA=TOS}{val space high virtual==22'b} {RegDef[UBitBltArg, U, 2]; {BitBlt}} {RegDef[UHeight, U, 3]; {BitBlt}} {RegDef[UDstVALo, U, 4]; {BitBlt}} {RegDef[UDstBit, U, 5]; {BitBlt}} {RegDef[USrcVALo, U, 6]; {BitBlt}} {RegDef[USrcBit, U, 7]; {BitBlt}} {RegDef[UGray, U, 8]; {BitBlt -- shares with USrcBpl}} {RegDef[UDstBpl, U, 9]; {BitBlt}} {RegDef[UrhVS, U, 0A]; {BitBlt}} {RegDef[UrhVD, U, 0B]; {BitBlt}} {RegDef[UFlags, U, 0C]; {BitBlt}} {RegDef[UWidth, U, 0D]; {BitBlt}} RegDef[uTOS, U, 0D]; {rA=TOS}{fZ=D=←ib}{BitBlt} RegDef[uFF00, U, 0E]: {*** rA=TOS}{FF00 to not use fY field} {RegDef[uValHigh, U, 0F]:}{*** rA=TOS}{val space high virtual==22'b} {U REGISTER BLOCK 1 -- EMULATOR TOSH} {RegDef[uWP, U, 10];} {** wakeups pending} {RegDef[UvC, U, 11];} {** {rA = T}? low half of code (VA, , UvChigh)} RegDef[uKeepTOS, U, 11],{Cons temp} RegDef[u12, U, 12]; {} RegDef[u0FF, U, 13]; {** rA = TOSH} RegDef[uKeepTOSH, U, 14],{Cons temp} {RegDef[uWW, U, 14];} {RegDef[u3FFF, U, 15];} {** constant, rA = TOSH} {RegDef[uPMask, U, 16];} {** rA = T; constant = 0FFC} RegDef[uName, U, 17]; {rA=TOSH}{name used by free var lookup} {RegDef[uWDC, U, 18];} {** wakeup disable counter} {RegDef[UGsave, U, 19];} {}{BitBlt} {RegDef[UtbCount, U, 1A];} {TextBlt Count parameter, rA = T fZ = ErrnIBnStkp} RegDef[uIVar, U, 1B]; {*** rA = TOSH}{fZ= ←RH}{stk addr IVARs} {RegDef[uT, U, 1C];} {rA = T} RegDef[uTOSH, U, 1D]; {rA = T, fZ = ←ib{GCONST}} {RegDef[UrhMDSsave, U, 1E];} {BitBlt} RegDef[u7F, U, 1F];{***} {U REGISTER BLOCK 2 -- EMULATOR rA=TT} RegDef[uSTACKspace, U, 20]; {** rA = TT} RegDef[u0FFF, U, 21]; {** rA = TT} RegDef[UvPCpageL, U, 22]; {** rA = TT, (PC page address)} RegDef[u1FF, U, 23]; {** rA = TT} RegDef[uTT3FF, U, 25]; {}{*** rA = TT} {RegDef[uESP, U, 25];} {*** rA = TT} {RegDef[uFaultParm0 ,U, 26]; {** rA = TT; fault parameter}} RegDef[uPV, U, 26]; {** rA #PV}{save PV}{BitBlt writes} RegDef[uTT, U, 27]; {rA = TT}{** A,Z=TT,←ibNA code base low v} RegDef[u7FFF, U, 28]; {** rA = TT} RegDef[u7FE, U, 29]; {**}{rA=TT} RegDef[uTT3FFF ,U, 2A]; {** rA = TT;} {RegDef[uChain, U, 2A];} {** rA = TT; }{chain; free var lookup} RegDef[uPCCrossL, U, 2B]; {** rA = TT; }{} {RegDef[u200, U, 2C];} {** constant} RegDef[UvCL, U, 2C]; {** A,Z=TT,←ibNA code base low v} RegDef[UvChighL, U, 2D]; {** A,Z=TT,←ib code base high v} {RegDef[u1FFF, U, 2E];} {** constant} {RegDef[u7FF, U, 2F];} {** constant} {U REGISTER BLOCK 3 -- EMULATOR rA=PV} RegDef[uuPV, U, 30]; {} {RegDef[UQSave, U, 31];} {BitBlt temp} RegDef[uFxNoPushReturn, U, 32]; {**==100}{%} RegDef[uU33, U, 33] {} {RegDef[UWidthM1, U, 34];} {BitBlt temp} {RegDef[Umask1, U, 35];} {BitBlt temp} RegDef[U36, U, 36] {} {RegDef[uFaultParm1, U, 37];} {fault parameter} {RegDef[Umask2, U, 37];} {BitBlt temp} {RegDef[UmaskL, U, 38];} {BitBlt temp} RegDef[uFxInCall, U, 39]; {**==400 }{%} {RegDef[ULsave, U, 3A];} {BitBlt temp} {RegDef[UrhLsave, U, 3B];} {BitBlt temp} {RegDef[uLastLevelLOwritten, U, 3C];} {BandBLT -- rA = rLoop} RegDef[unboundPvar, U, 3D]; {**}{==FFFFh} RegDef[unboundFvar, U, 3E]; {**}{==FFFFh} {RegDef[uTickCount, U, 3F];} {** process tick interval} {U REGISTER BLOCK 4 -- EMULATOR rA=S} RegDef[uStkLimO, U, 40]; {**}{==FFFFh} {RegDef[UXsave, U, 42];} {BitBlt temp} {RegDef[UVSsave, U, 43];} {BitBlt temp} {RegDef[USrcVALoSav, U, 44];} {BitBlt temp} {RegDef[UrhGsave, U, 4B];} {rA = G, fZ = ←RH}{BitBLT} RegDef[uPageFault, U, 4E]; {} {U REGISTER BLOCK 5 -- EMULATOR rA=PC} RegDef[uU50 ,U, 50]; {} RegDef[uSavOldHi,U,51], {Lisp temp}{RplPtr} RegDef[uSaveTOS,U,51], {BLT temp} RegDef[uSavOldLo,U,52], {Lisp temp}{RplPtr} RegDef[uSaveTT,U,52], {BLT temp} RegDef[uConsTemp,U,53], {Lisp temp}{Cons} RegDef[uSaveTOSH,U,53], {BLT temp} RegDef[uGcLlo,U,55], {Lisp temp}{GcLookup} RegDef[uGcLhi,U,56], {Lisp temp}{GcLookup} RegDef[uGcLTem,U,57], {Lisp temp}{GcLookup} RegDef[uGcLov,U,58], {Lisp temp}{GcLookup} RegDef[uSavAddr,U,59], {Lisp temp}{RplPtr} {RegDef[UrhPCsave ,U, 5B]; {rA = PC, fZ = ←RH}{BitBlt temp} } RegDef[uPC ,U, 5B]; {rA = PC, fZ = ←RH} {RegDef[UDstVALoSav ,U, 5C]; {BitBlt temp} } {RegDef[UWidthW ,U, 5D]; {BitBlt temp} } RegDef[uPCib ,U, 5D]; {rA = PC, fZ = ←ib} {U REGISTER BLOCK 6 -- EMULATOR rA=Rx} {lots of params for BandBLT & Xfer} {RegDef[ULcntsav, U, 60];} {BitBlt temp rA = Lcount} {RegDef[uRx, U, 60]; {Lisp temp rA = Rx} } RegDef[uFXmark, U, 61]; {** rA = Rx; Frame Extension mark C000h} RegDef[uBFmark, U, 62]; {** Basic Frame mark==8001h} RegDef[uUFNTableBaseHalf, U, 63]; {** rA = T/Rx; } RegDef[uFreeStackBlock, U, 64]; {** rA = T/Rx; }{==0A000} {RegDef[uRx, U, 65];} {** rA = T/Rx; }{} RegDef[uBfResidualRhmask, U, 66]; {** rA = T/Rx; }{==2FFh} RegDef[uESP, U, 67]; {***} RegDef[uFunDef, U, 68]; {}{last fun'n called to debug} RegDef[uChain, U, 69]; {**}{chain; free var lookup} RegDef[uPcBreak, U, 6A]; {**} RegDef[uNewCount,U,6B],{Cons temp} RegDef[uAddrNewCellLo,U,6C],{Cons temp} RegDef[uuRx, U, 6D]; {rA=Rx}{fZ=D=←ib} RegDef[uLispOptions, U, 6F]; {DO NOT DISTURB -- LISP ONLY} RegDef[uBBTime, U, 99];{var.display uses to hold number of blank lines at the bottom of the display} {initialized to be 14'd for normal screen, change to 142'd for videotaping} {new defs for GC things} Set[Q.AddRef,0],{setup for GcLookup} Set[Q.DelRef,1],{setup for GcLookup} {GcLookup links return thru GcLookRet} Set[L2.gcref,1],{GcRef} Set[L2.RplDel,2],{RplPtr} Set[L2.RplAdd,3],{RplPtr} Set[L2.ConsAdd,4],{Cons} Set[L2.ConsDel,5],{Cons} Set[L2.ConsListAdd,6],{Cons} Set[L3.TTFGcL,1], {Link Codes for Common Subroutines} Set[qPageFault, 2'b]; {page fault} Set[qWriteProtect, 3'b]; {} Set[NWWInterrupt, 4'b]; {} Set[L2.0, 0 ]; {L0 MaskRet} Set[L2.WFRet, 2];{must be 2 for WF}{MaskRet} Set[L2.WFRetOdd, 3];{must be 3 for WF}{MaskRet} Set[L2.WFRetMap, 0];{must be 0 for WF} Set[L2.WFRetMapOdd, 1];{must be 1 for WF}{conflict with TextBlt} Set[L2.GFRet, 04]; {L0 RxMapFixCaller} Set[L0.xRedoGF, 1 ]; Set[L0.xRedoFV, 2 ]; Set[L0.xRedoFV0, 3 ]; Set[L0.xRedoCdr, 4 ]; {Set[L0.xRedo, 5 ];{reserved for pair with RedoCdr}} Set[L0.xRedoFVN, 6 ]; {Set[L0.xRedoGC, 7 ];} Set[L0.xRedoSClk, 9 ]; {Set[L0.RedoBLT, 0D];{BLT} defd at WMapFix} {L0 MapFixCaller} Set[L0.RefillFNX, 0 ]; Set[L0.RetRedo, 1 ];{} Set[L0.RedoGV, 4 ];{} Set[L0.RedoGBN, 5 ];{} Set[L0.RedoBP, 6 ];{} Set[L0.RedoGC, 7 ];{} Set[L0.ERefill,8]; {must be even} {Set[L0.RedoPBP, 9 ];} Set[L0.NERefill,0A]; {must end with 01} Set[L0.NERefill.Set,8]; {must end with 00} Set[WhichFixType,0B]; {used to distinquish between Refill & JRemap} Set[L0.FCRedo, 0B ];{must be even} Set[L0.BYRedoE, 0C ];{must be even} Set[L0.BYRedoO, 0D ];{must be odd} Set[L0.FCHRedo, 0E ];{2 or 3 mod 4} Set[L0.JRemap,0F]; {must be 0F} {Set[L0.ji,7];} {L3 FixForTrap} Set[L3.rhTT.Q, 1 ]; Set[L3.rhTT.TT, 2 ]; Set[L3.rhMDS.Q, 3 ]; {L2 typ returns thru typRet} { 1 used by CAR} { 2 used by CDR} { 3 used by LISTP} { 4 used by NTYPX} { 5 used by TYPEP} { 6 used by DTEST} Set[L2.ConsList, 7 ];{Cons} {L2 jn} Set[L2.ok, 0 ]; Set[L2.STK, 1 ]; Set[L2.TOS, 2 ]; {L1 FixForTrap}{Fix routine to preserve Rx{context}} Set[L1.NoFixes, 0 ];{*GCONST} Set[L1.TrapGC, 1 ]; {**GCONST} Set[L1.FCH, 2 ]; {**even} Set[L1.FC, 3 ]; {**funct call} Set[L1.DecOnly, 4]; {*Cadr}{RCLK} {Set[L1.PushDec, 4 ]; {*GETBASEBYTE}} Set[L1.Ret, 5 ]; {*Return} {{Set[L1.fixPBY, 5 ]; {**PUTBASEBYTE}}} Set[L1.PushOnly, 6 ]; {*PUTBASEPTRN (PUTBASEBYTE)} Set[L1.PopOnly, 7]; {=7 FVAR}{*GVAR FVAR} Set[L1.Dec3, 8]; {*GBITS}{Clock} Set[L1.fixWF, 9 ]; {*PUTBITS} Set[L1.PushDec2,0A]; {*PUTBASEN} Set[L1.DecDec,0B]; {*GETBASE.N} Set[L1.Push2OK, 0C ]; {*PUTBASEBYTE} Set[L1.Refill, 0D ]; {**1-Refill} Set[L1.FNX, 0E ]; {must = 0E}{**FNX} Set[L1.fixFV, 0F]; {*fvLookup} {WMapFixCaller} Set[L0.RedoW, 1 ]; {Set[L0.WBYRedo, 2 ];} Set[L0.RedoWF, 3 ]; Set[L0.WBYRedoE, 4 ];{must be even} Set[L0.WBYRedoO, 5 ];{} {Set[L0.RedoWBLT, 6 ],} Set[L0.RedoClk, 8 ], Set[L0.RedoPBP, 9 ], Set[L0.RedoRpl, 0A ],{RplPtr} Set[L0.RedoCons1, 0B ],{Cons} Set[L0.RedoCons2, 0C ],{Cons} Set[L0.RedoBLT, 0D];{BLT} {L3 fvLookUp} Set[L3.FVAR, 2 ];{2 or 3 mod 4} Set[L3.FVARg, 0 ]; {must be even} {L1 fvLookUp 2 bit on for XLDisp} Set[L1.fvStack, 2]; Set[L1.fvUnbound, 3]; Set[L1.fvGlobal, 6]; {stack push ops} Set[L3.atm1, 0]; Set[L3.atm3, Add[08,0]]; Set[L3.pls1, 2]; Set[L3.pls3, Add[08,2]]; Set[L3.pls2, 4]; Set[L3.neg2, 6]; {Set[OpcodeBase, 500];} {MacroDef[WriteOK, LOOPHOLE[wok]];} {MacroDef[opcode, at[Add[#1, OpcodeBase]]];} {MacroDef[AlwaysIBDisp, (IBDisp, IBPtr←1)];} MacroDef[ufn, ( Rx ← #1'b, GOTO[ufn2], c1, at[Add[#1'b, OpcodeBase]])]; MacroDef[ZeroBranch, ZeroBr]; {NZeroBR would force stack overflows}