DIRECTORY Atom,DynaBusInterface,Rope; DynCacheProg6: CEDAR PROGRAM IMPORTS Atom EXPORTS ~ BEGIN Quad: TYPE = DynaBusInterface.Quad; Cmd: TYPE = DynaBusInterface.Cmd; L: PROC [c: BOOL] RETURNS [rc: REF ANY] = {rc _ NEW[BOOL _ c]}; C: PROC [c: CARD] RETURNS [rc: REF ANY] = {rc _ NEW[CARD _ c]}; Q: PROC [c: Quad] RETURNS [rc: REF ANY] = {rc _ NEW[Quad _ c]}; Com: PROC [c: Cmd] RETURNS [rc: REF ANY] = {rc _ NEW[Cmd _ c]}; R: PROC [c: Rope.ROPE] RETURNS [rc: REF ANY] = {rc _ NEW[Rope.ROPE _ c]}; Atom.PutProp[$Simul2Sender, $PKList, LIST[ LIST[$ClearFlag, $MemReady], LIST[$ClearFlag, $DynReadDone], $Init, $StartStop, $ReceiveAll, LIST[$WaitSync, $DBusReady], -- wait DBus ready LIST[$IOWrite0, C[1], L[TRUE], L[TRUE], C[0],C[28],C[28],C[28],C[22],C[22]], $WaitMsgSent, $WaitMsgReceived, -- for the Echo $WaitReply, LIST[$IOWrite1, C[1],C[10],C[0],C[0]], $WaitMsgSent, $WaitMsgReceived, -- for the Echo $WaitReply, LIST[$IOWrite2, C[1],C[10],C[0]], $WaitMsgSent, $WaitMsgReceived, -- for the Echo $WaitReply, LIST[$WriteBlockRqst, Q[[0,0,0011H,2288H]],Q[[0,0,0123H,4567H]],Q[[1,1,1,1]],Q[[2,2,2,2]],Q[[3,3,3,3]]], $WaitMsgSent, LIST[$SetFlag, $MemReady], $WaitMapRqst, LIST[$MapReply, C[0FH]], LIST[$WaitSync, $CacheFull], LIST[$WaitReadBlockRqstandCheck, Q[[0,0,0004H,5128H]],Q[[0004H,5131H,0004H,5131H]]], -- for the Test DeMapRply inbetween LIST[$DeMapRply1, Q[[0,0,0004H,5128H]],Q[[0123H,4567H,89ABH,0CDEFH]]], $WaitMapRqst, LIST[$MapReply, C[0FH]], LIST[$WaitReadBlockRqstandCheck, Q[[0,0,0004H,5128H]],Q[[0004H,5139H,0004H,5139H]]], -- for the retry $Loop, $WaitMapRqst, LIST[$MapReply, C[0FH]], LIST[$Jump, $Loop] ]]; END. ,DynCacheProg6.mesa Copyright Σ 1987 by Xerox Corporation. All rights reserved. Created by Jean Gastinel, June 2, 1988 3:38:27 pm PDT Jean Gastinel June 16, 1988 8:01:11 pm PDT LIST[$Wait, C[200]], -- for waiting DBus intit Initialize memory controller Now lets pretend to be a Map Cache ΚΪ˜codešœ™Kšœ<™