Directory CacheOps; Imports BitOps, BitSwOps, Dragon; Open BitOps, BitSwOps, Dragon; CELLTYPE "MEntryCtl" PORTS[ Vdd, Gnd<BOOL, PhAb, PhBb<BOOL, Resetb<BOOL, QValidA, nQValidA, QSharedA, nQSharedA, QMasterA, nQMasterA=BIT-(Special XPhobic), MQSelBA, MatchQSelBA>INT[4], nQDirtyB=INT[4], RPValidBitA, nRPValidBitA, RPDirtyBitA, nRPDirtyBitA, VPValidBitA, nVPValidBitA=BIT-(Special XPhobic), ForceAllDataSelectsBA>BOOL, CellAdrBA, nCellAdrBA>INT[7], SelOrphanAdrBA, SelMapAdrBA, SelVPBA, SelRPVictimBA, SelRPDecoderBA, SelRealDataBA, SelDecodeBA>BOOL, SenseVictimA>BOOL, PAdr2831AB<INT[4], DriveVirtualPageAdrBA, DriveVirtualBlockAdrBA>BOOL, MDataI=INT[32], SetSharedA, ResetMasterA, SetRPDirtyVPValidA, FlagLatchB, SetFlagsA, IncrementVictimBA, IncrementMAdrCtrB, ZeroMAdrCtrB, SampleDirtyBitsB, DeleteDirtyBitB, VictimSelectBA, RefreshToDecoderBA, IfGrantThenGetAdrElseRefreshToDecoderBA, FetchAddressBA, DirtyBitsToMQSelBA, SamplePAdr2831B, SampleMAdr2831B, Adr2829ToMQSelBA, AddressBitsToMDataIA, VictimAddressBitsToMDataIA, SelectRPBA, SelectVPVictimOrOrphanBA, SelectRealDataBA, SelVictimOrOrphanBA, RefreshIfRefVirtualBA, SenseVictimBA<BOOL, GetAdrCmdBA<EnumType["CacheOps.PreFetchAdrCmd"], IsCleanBA, LatchSharedBA, MasterBA, MatchRealBlockAB, ContinueBA<BOOL, OneDirtyBA, SomeDirtyBA>BOOL, MAdr3031BA>INT[2] ] State RefreshCountAB, RefreshCountBA: CARDINAL, VictimCountAB, VictimCountBA: CARDINAL, MAdrCtrAB, MAdrCtrBA: CARDINAL, IncrementVictimAB: BOOL, LatchVPValidBA, LatchRPDirtyBA: BOOL, VictimDirtyBitsAB, VictimDirtyBitsBA: BitWord, Adr2829BA, FirstDirty: CARDINAL, DoGetAdrBA, DoRefreshBA, VictimDataSelectBA, ReallyVictimToDecoderBA: BOOL EvalSimple DriveBit: PROC[bit, nBit: Switch, dBit: BOOL] RETURNS [newBit, newNBit: Switch] = { newBit _ SIBISS[dBit, bit, [[driveStrong, L], [driveStrong, H]]]; newNBit _ SIBISS[dBit, nBit, [[driveStrong, H], [driveStrong, L]]]; }; { s: SwitchTypes.Strength _ IF PhBb THEN drive ELSE none; VPValidBitA _ SIBISS[TRUE, VPValidBitA, [[none, X], [s, H]]]; nVPValidBitA _ SIBISS[TRUE, nVPValidBitA, [[none, X], [s, H]]]; RPValidBitA _ SIBISS[TRUE, RPValidBitA, [[none, X], [s, H]]]; nRPValidBitA _ SIBISS[TRUE, nRPValidBitA, [[none, X], [s, H]]]; RPDirtyBitA _ SIBISS[TRUE, RPDirtyBitA, [[none, X], [s, H]]]; nRPDirtyBitA _ SIBISS[TRUE, nRPDirtyBitA, [[none, X], [s, H]]]; QValidA _ SIBISS[TRUE, QValidA, [[none, X], [s, H]]]; nQValidA _ SIBISS[TRUE, nQValidA, [[none, X], [s, H]]]; QMasterA _ SIBISS[TRUE, QMasterA, [[none, X], [s, H]]]; nQMasterA _ SIBISS[TRUE, nQMasterA, [[none, X], [s, H]]]; QSharedA _ SIBISS[TRUE, QSharedA, [[none, X], [s, H]]]; nQSharedA _ SIBISS[TRUE, nQSharedA, [[none, X], [s, H]]]; }; Assert[NOT MoreThanOneOf[SetSharedA, SetFlagsA, SetRPDirtyVPValidA]]; IF Resetb AND PhAb THEN { [VPValidBitA, nVPValidBitA] _ DriveBit[VPValidBitA, nVPValidBitA, FALSE]; [RPValidBitA, nRPValidBitA] _ DriveBit[RPValidBitA, nRPValidBitA, FALSE]; [RPDirtyBitA, nRPDirtyBitA] _ DriveBit[RPDirtyBitA, nRPDirtyBitA, FALSE]; [QMasterA, nQMasterA] _ DriveBit[QMasterA, nQMasterA, FALSE]; [QSharedA, nQSharedA] _ DriveBit[QSharedA, nQSharedA, FALSE]; [QValidA, nQValidA] _ DriveBit[QValidA, nQValidA, FALSE]; }; IF SetSharedA THEN [QSharedA, nQSharedA] _ DriveBit[QSharedA, nQSharedA, TRUE]; IF ResetMasterA THEN [QMasterA, nQMasterA] _ DriveBit[QMasterA, nQMasterA, FALSE]; IF SetRPDirtyVPValidA THEN { [VPValidBitA, nVPValidBitA] _ DriveBit[VPValidBitA, nVPValidBitA, LatchVPValidBA]; [RPDirtyBitA, nRPDirtyBitA] _ DriveBit[RPDirtyBitA, nRPDirtyBitA, LatchRPDirtyBA]; }; IF FlagLatchB THEN { LatchVPValidBA _ EBFD[MDataI, 32, 30]; LatchRPDirtyBA _ EBFD[MDataI, 32, 31]; }; IF SetFlagsA THEN { [VPValidBitA, nVPValidBitA] _ DriveBit[VPValidBitA, nVPValidBitA, TRUE]; [RPValidBitA, nRPValidBitA] _ DriveBit[RPValidBitA, nRPValidBitA, TRUE]; [RPDirtyBitA, nRPDirtyBitA] _ DriveBit[RPDirtyBitA, nRPDirtyBitA, NOT IsCleanBA]; [QMasterA, nQMasterA] _ DriveBit[QMasterA, nQMasterA, FALSE]; [QSharedA, nQSharedA] _ DriveBit[QSharedA, nQSharedA, LatchSharedBA]; [QValidA, nQValidA] _ DriveBit[QValidA, nQValidA, TRUE]; }; IF PhAb THEN { RefreshCountAB _ IF Resetb THEN 0 ELSE RefreshCountBA; VictimCountAB _ IF Resetb THEN 0 ELSE VictimCountBA; VictimDirtyBitsAB _ VictimDirtyBitsBA; MAdrCtrAB _ MAdrCtrBA; IncrementVictimAB _ IncrementVictimBA; }; IF PhBb THEN VictimCountBA _ IF IncrementVictimAB AND NOT MatchRealBlockAB THEN (VictimCountAB+1) MOD 4 ELSE VictimCountAB; SenseVictimA _ PhAb AND SenseVictimBA AND NOT MatchRealBlockAB; Assert[NOT MoreThanOneOf[IncrementMAdrCtrB, ZeroMAdrCtrB, SamplePAdr2831B, SampleMAdr2831B]]; IF IncrementMAdrCtrB THEN MAdrCtrBA _ IF ContinueBA THEN ((MAdrCtrAB+1) MOD 4) ELSE MAdrCtrAB; IF ZeroMAdrCtrB THEN MAdrCtrBA _ 0; Assert[NOT MoreThanOneOf[SampleDirtyBitsB, DeleteDirtyBitB]]; IF SampleDirtyBitsB THEN VictimDirtyBitsBA _ WNOT[nQDirtyB, 4]; IF PhAb THEN nQDirtyB _ 0FH; IF DeleteDirtyBitB THEN FOR i:[0..4) IN [0..4) DO IF EBFW[VictimDirtyBitsAB, 4, i] THEN { VictimDirtyBitsBA _ IBIW[FALSE, VictimDirtyBitsAB, 4, i]; EXIT; }; ENDLOOP; SomeDirtyBA _ FALSE; FOR i:[0..4) IN [0..4) DO IF EBFW[VictimDirtyBitsBA, 4, i] THEN { OneDirtyBA _ TRUE; IF SomeDirtyBA THEN OneDirtyBA _ FALSE; SomeDirtyBA _ TRUE; }; ENDLOOP; DoGetAdrBA _ (MasterBA AND IfGrantThenGetAdrElseRefreshToDecoderBA) OR FetchAddressBA; DoRefreshBA _ (NOT MasterBA AND IfGrantThenGetAdrElseRefreshToDecoderBA) OR RefreshToDecoderBA OR (RefreshIfRefVirtualBA AND GetAdrCmdBA=RefVirtual); VictimDataSelectBA _ (SelVictimOrOrphanBA AND NOT MatchRealBlockAB) OR VictimSelectBA; SelMapAdrBA _ DoGetAdrBA AND GetAdrCmdBA=RefRealAssemble; DriveVirtualPageAdrBA _ (DoGetAdrBA AND GetAdrCmdBA=RefVirtual) OR SelectVPVictimOrOrphanBA; DriveVirtualBlockAdrBA _ (DoGetAdrBA AND (GetAdrCmdBA=RefRealMap OR GetAdrCmdBA=RefRealAssemble OR GetAdrCmdBA=RefVirtual)) OR SelectVPVictimOrOrphanBA; SelRPVictimBA _ DoGetAdrBA AND GetAdrCmdBA=VictimReal; SelRPDecoderBA _ SelectRPBA AND NOT MatchRealBlockAB; SelVPBA _ SelectVPVictimOrOrphanBA AND NOT MatchRealBlockAB; SelOrphanAdrBA _ SelectVPVictimOrOrphanBA AND MatchRealBlockAB; ReallyVictimToDecoderBA _ SelRPDecoderBA OR VictimDataSelectBA; SelRealDataBA _ SelectRealDataBA OR (SelVictimOrOrphanBA AND MatchRealBlockAB); SelDecodeBA _ DoRefreshBA OR VictimDataSelectBA; IF PhBb THEN ForceAllDataSelectsBA _ Resetb; Assert[NOT MoreThanOneOf[ReallyVictimToDecoderBA, DoRefreshBA]]; IF ReallyVictimToDecoderBA THEN CellAdrBA _ ICIW[VictimCountBA, 0, 7, 0, 7]; Assert[NOT MoreThanOneOf[DoRefreshBA, DirtyBitsToMQSelBA, Adr2829ToMQSelBA]]; IF PhBb THEN RefreshCountBA _ IF DoRefreshBA THEN (RefreshCountAB+1) MOD 512 ELSE RefreshCountAB; IF DoRefreshBA THEN { CellAdrBA _ MWTW[RefreshCountBA, 9, 0, 7, 0, 7, 0, 7]; MQSelBA _ SELECT ECFW[RefreshCountBA, 9, 7, 2] FROM 0 => 8, 1 => 4, 2 => 2, 3 => 1, ENDCASE => ERROR; }; nCellAdrBA _ WNOT[CellAdrBA, 7]; IF Resetb THEN MQSelBA _ 0FH; FOR i:[0..4) IN [0..4) DO IF EBFW[VictimDirtyBitsBA, 4, i] THEN { FirstDirty _ i; EXIT; }; ENDLOOP; IF DirtyBitsToMQSelBA THEN { MQSelBA _ IBIW[TRUE, 0, 4, FirstDirty]; }; IF SamplePAdr2831B THEN { Adr2829BA _ ECFW[PAdr2831AB, 4, 0, 2]; MAdrCtrBA _ ECFW[PAdr2831AB, 4, 2, 2] }; IF SampleMAdr2831B THEN { Adr2829BA _ ECFD[MDataI, 32, 28, 2]; MAdrCtrBA _ ECFD[MDataI, 32, 30, 2] }; MatchQSelBA _ SELECT Adr2829BA FROM 0 => 8, 1 => 4, 2 => 2, 3 => 1, ENDCASE => ERROR; IF Adr2829ToMQSelBA THEN { MQSelBA _ SELECT Adr2829BA FROM 0 => 8, 1 => 4, 2 => 2, 3 => 1, ENDCASE => ERROR; }; MAdr3031BA _ ICIW[MAdrCtrBA, MAdr3031BA, 2, 0, 2]; Assert[NOT MoreThanOneOf[AddressBitsToMDataIA, VictimAddressBitsToMDataIA]]; IF AddressBitsToMDataIA THEN MDataI _ MWTD[PAdr2831AB, 4, 0, 4, MDataI, 32, 28, 4]; IF VictimAddressBitsToMDataIA THEN { MDataI _ ICID[FirstDirty, MDataI, 32, 28, 2]; MDataI _ ICID[0, MDataI, 32, 30, 2]; }; ENDCELLTYPE �����CacheMInterfaceMEntryCtl.rose Last edited by: Barth, July 27, 1984 5:33:44 pm PDT Last edited by: Curry, January 29, 1985 9:30:00 pm PST Timing and housekeeping interface Buffered timing and housekeeping interface Cell control P control <=> M control Internal main memory interface Entry Control ROM interface Control steel wool Intermediate values, not actual state bits The next block of code assumes that the instructions have been set to none and only sets the instructions if a strength other than none is to be applied. Êï��˜�šœ™Jšœ3™3Jšœ6™6—J˜�J˜Jšœ!˜!Jšœ˜J™�šœ˜Jšœ˜J˜�šœ!™!Jšœ Ïkœ˜J™�—šœ*™*Jšœœ˜Jšœœ˜ J˜�—™Jšœ<œ˜RJšœœœ˜-JšœPœ˜fJšœœ˜Jšœœ˜Jšœ`œ˜eJšœ œ˜J™�—™Jšœœ˜Jšœ.œ˜3J˜�—šœ™Jšœœ˜J˜�—™Jšœåœ˜êJ˜�—™Jšœ0˜0JšœAœ˜FJšœœ˜Jšœœ˜—Jšœ˜J˜�˜Jšœ œ˜)Jšœœ˜'Jšœœ˜Jšœœ˜Jšœ œ˜%Jšœ.˜.Jšœœ˜ ™*JšœF˜J——˜ J˜�šÏnœœœœ˜SJšœ œœœ˜AJšœ œœœ˜CJ˜J˜�—šœ˜Jšœœœœ˜7Jš œœœœœ˜=Jš œœœœœ˜?Jš œœœœœ˜=Jš œœœœœ˜?Jš œœœœœ˜=Jš œœœœœ˜?Jš œ œœœœ˜5Jš œœœœœ˜7Jš œœœœœ˜7Jš œœœœœ˜9Jš œœœœœ˜7Jš œœœœœ˜9Jšœ˜—J˜�Jšœ™™™J™�Jšœœ;˜EJ˜�šœœœ˜JšœBœ˜IJšœBœ˜IJšœBœ˜IJšœ6œ˜=Jšœ6œ˜=Jšœ2œ˜9J˜—Jšœœ7œ˜OJšœœ7œ˜Ršœœ˜JšœR˜RJšœR˜RJ˜—šœœ˜Jšœœ˜&Jšœœ˜&J˜—šœœ˜JšœBœ˜HJšœBœ˜HJšœBœ˜QJšœ6œ˜=JšœE˜EJšœ2œ˜8J˜—J˜�šœœ˜Jšœœœœ˜6Jšœœœœ˜4Jšœ&˜&Jšœ˜Jšœ&˜&J˜—J˜�Jšœœœœœœœœ˜|Jšœœœœ˜?J˜�JšœœS˜]Jšœœ œœœœ˜^Jšœœ˜#J˜�Jšœœ3˜=Jšœœœ˜?Jšœœ˜š œœœ œ˜1šœœœ˜'Jšœœœ˜9Jšœ˜J˜—Jšœ˜—Jšœœ˜šœ œ˜šœœœ˜'Jšœ œ˜Jšœ œœ˜'Jšœœ˜J˜—Jšœ˜—J˜�Jšœœ*œ˜VJšœœ œ*œœœ˜•Jšœ*œœœ˜VJšœœ˜9Jšœ$œœ˜\Jš œ%œœœœ˜˜Jšœœ˜6Jšœœœ˜5Jšœ#œœ˜<Jšœ*œ˜?Jšœ)œ˜?Jšœ!œœ˜OJšœœ˜0J˜�Jšœœ ˜,Jšœœ6˜@Jšœœ œ˜LJšœœC˜MJšœœœ œœœ˜ašœ œ˜Jšœœ&˜6šœ œœ˜3J˜J˜J˜J˜Jšœœ˜—Jšœ˜—Jšœ œ˜ Jšœœ˜šœ œ˜šœœœ˜'Jšœ˜Jšœ˜J˜—Jšœ˜—šœœ˜Jšœ œœ˜'J˜—šœœ˜Jšœœ˜&Jšœœ˜%J˜—šœœ˜Jšœœ˜$Jšœœ˜#J˜—šœœ˜#J˜J˜J˜J˜Jšœœ˜—šœœ˜šœ œ˜J˜J˜J˜J˜Jšœœ˜—J˜—Jšœ œ!˜2J˜�JšœœB˜LJšœœ œ)˜Sšœœ˜$Jšœ œ ˜-Jšœ œ˜$J˜——Jš˜—J˜�—�…—����Œ��)“��