7
IDT72605/72615 CMOS SYNCBiFIFO
256 x 18x 2 and 512 x 18 x 2
INDUSTRIALTEMPERATURERANGE
Data A
CSA
R/WA
ENA
OEA
I/O
Port A Operation
0
I
Data A is written on CLKA
↑. This write cycle immediately following low-impedance cycle is prohibited. Note
that even though OEA= 0, a LOW logic level on R/WA, once qualified by a rising edge on CLKA, will put Data A into
ahigh-impedancestate.
0
1
I
Data A is written on CLKA
↑
0
1
X
I
Data A is ignored
0
1
0
O
Data is read(1) from RAM array to output register on CLKA
↑, Data A is low-impedance
0
1
0
1
O
Data is read(1) from RAM array to output register on CLKA
↑, Data A is high-impedance
0
1
0
O
Outputregisterdoesnotchange(2),DataAislow-impedance
0
1
O
Outputregisterdoesnotchange(2),DataAishigh-impedance
1
0
X
I
Data A is ignored(3)
1
X
O
DataAishigh-impedance(3)
NOTES:
1. When A2A1A0 = 000, the next B
→A FIFO value is read out of the output register and the read pointer advances. If A2A1A0 = 001, the bypass path is selected and bypass
data from the Port B input register is read from the Port A output register. If A2A1A00 = 1XX, a flag offset register is selected and its offset is read out through Port A output
register.
2. Regardless of the condition of A2A1A0, the data in the Port A output register does not change and the B
→A read pointer does not advance.
3. If CSA# is HIGH, then BYPB is HIGH. No bypass occur under this condition.
TABLE 1 PORT A OPERATION CONTROL SIGNALS
CSA
A2
A1
A0
Read
Write
0000
B
→A FIFO
A
→B FIFO
0001
18-bit Bypass Path
0100
A
→B FIFO Almost-Empty
FlagOffset
0101
A
→B FIFO Almost-Full
FlagOffset
0110
B
→A FIFO Almost-Empty
FlagOffset
0111
B
→A FIFO Almost-Full
FlagOffset
1
X
Port A Disabled
TABLE 2 ACCESSING PORT A RE-
SOURCES USING CSA, A2, A1, AND A0
ofeachportoperateindependently,PortAcanbereadingbypassdataatthe
same time Port B is reading bypass data.
When R/WA and ENA is LOW, data on pins DA0-DA17 is written into Port
Ainputregister. FollowingtherisingedgeofCLKAforthiswrite,theA
→BFull
Flag(FFAB)goesLOW. SubsequentwritesintoPortAareblockedbyinternal
logic until FFAB goes HIGH again. On the next CLKB rising edge, the A
→B
EmptyFlag(EFAB)goesHIGHindicatingtoPortBthatdataisavailable. Once
R/WBisHIGHandENBisLOW,dataisreadintothePortBoutputregister. OEB
stillcontrolswhetherPortBisinahigh-impedancestate. WhenOEBisLOW,
theoutputregisterdataappearsatDB0-DB17. EFABgoesLOWfollowingthe
CLKBrisingedgeforthisread. FFABgoesHIGHonthenextCLKArisingedge,
lettingPortAknowthatanotherwordcanbewrittenthroughthebypasspath.
Bypass data transfers from Port B to Port A work in a similar manner with
EFBA and FFBA indicating the Port A output register state.
When the Port A address changes from bypass mode (A2A1A0=001) to
FIFOmode(A2A1A0=000)ontherisingedgeofCLKA,thedataheldinthePort
Boutputregistermaybeoverwritten. UnlessPortAmonitorstheBYPBpinand
waitsforPortBtoclockoutthelastbypassword,datafromtheA
→BFIFOwill
overwrite data in the Port B output register. BYPB will go HIGH on the rising
edgeofCLKBsignifyingthatPortBhasfinisheditslastbypassoperation.Port
B must read any bypass data in the output register on this last CLKB clock or
itislostandtheSyncBiFIFOreturnstoFIFOoperations. Itisespeciallyimportant
tomonitorBYPBwhenCLKBismuchslowerthanCLKAtoavoidthiscondition.
BYPB will also go HIGH after CSA is brought HIGH; in this manner the Port B
bypass data may also be lost.
SincethePortAprocessorcontrolsCSAandthebypassmode,thisscenario
can be handled for B
→Abypassdata. ThePortAprocessormustbesetup
to read the last bypass word before leaving bypass mode.
PORT A CONTROL SIGNALS
ThePortAcontrolsignalspinsdictatethevariousoperationsshowninTable
2. Port A is accessed when CSA is LOW, and is inactive if CSA is HIGH. R/
WAandENAlinesdeterminewhenDataAcanbewrittenorread. IfR/WAand
ENAareLOW,dataiswrittenintoinputregisterontheLOW-to-HIGHtransition
ofCLKA. IfR/WAisHIGHandOEAisLOW,datacomesoutofbusandisread
fromoutputregisterintothree-statebuffer. Refertopindescriptionsformore
information.
PROGRAMMABLEFLAGS
The IDT SyncBiFIFO has eight flags: four flags for A
→B FIFO (EFAB,
PAEAB, PAFAB, FFAB), and four flags for B
→AFIFO(EFBA,PAEBA,PAFBA,
FFBA). TheEmptyandFullflagsarefixed,whiletheAlmost-EmptyandAlmost-
FulloffsetscanbesettoanydepththroughtheFlagOffsetRegisters(seeTable
3). The flags are asserted at the depths shown in the Flag Truth Table (Table
4).Afterreset,theprogrammableflagoffsetsaresetto8.ThismeanstheAlmost-
EmptyflagsareassertedatEmpty+8wordsdeep,andtheAlmost-Fullflagsare
asserted at Full -8 words deep.
ThePAEABissynchronizedtoCLKB,whilePAEABissynchronizedtoCLKA;
and PAEBA is synchronized to CLKA, while PAEBA is synchronized to CLKB.
Iftheminimumtime(tSKEW2)betweenarisingCLKBandarisingCLKAismet,
theflagwillchangestateonthecurrentclock;otherwise,theflagmaynotchange
stateuntilthenextclockrisingedge. Forthespecificflagtimings,refertoFigures
12-15.
PORT B CONTROL SIGNALS
ThePortBcontrolsignalpinsdictatethevariousoperationsshowninTable
5. Port B is independent of CSA. R/WB and ENB lines determine when Data