summaryrefslogtreecommitdiffstats
path: root/usrp2/fifo/fifo_spec.txt
diff options
context:
space:
mode:
authorMatt Ettus <matt@ettus.com>2010-06-14 11:59:19 -0700
committerMatt Ettus <matt@ettus.com>2010-06-14 11:59:19 -0700
commit81ad405f9ddecf13e1238bdc53a251b0b71022b5 (patch)
tree999d7ebf90ad86e8e56aa8f06a44d5b74fa4833f /usrp2/fifo/fifo_spec.txt
parentfb704918b285a7d039cda27daf35f628442a7dca (diff)
parent1935f2a4ed0d0abc90bb3fe7fed745ff84ab6d7c (diff)
downloaduhd-81ad405f9ddecf13e1238bdc53a251b0b71022b5.tar.gz
uhd-81ad405f9ddecf13e1238bdc53a251b0b71022b5.tar.bz2
uhd-81ad405f9ddecf13e1238bdc53a251b0b71022b5.zip
Merge branch 'master' into u2p
* master: produces good bin files first attempt at cleaning up the build system
Diffstat (limited to 'usrp2/fifo/fifo_spec.txt')
-rw-r--r--usrp2/fifo/fifo_spec.txt36
1 files changed, 36 insertions, 0 deletions
diff --git a/usrp2/fifo/fifo_spec.txt b/usrp2/fifo/fifo_spec.txt
new file mode 100644
index 000000000..133b9fa8e
--- /dev/null
+++ b/usrp2/fifo/fifo_spec.txt
@@ -0,0 +1,36 @@
+
+
+FIFO and Buffer Interface Spec
+
+Buffer Interface Data Wires -- matches fifo36
+ DATA[31:0]
+ FLAGS[3:0]
+ Bit 0 SOP
+ Bit 1 EOP
+ If SOP=1 && EOP=1, OCC contains error flags
+ Bits 3:2 OCC[1:0] --> 00 = all 4 bytes
+ 01 = 1 byte
+ 10 = 2 bytes
+ 11 = 3 bytes
+
+fifo36 --> {OCC[1:0],EOP,SOP,DATA[31:0]}
+ OCC same as buffer interface
+
+fifo19 --> {OCC,EOP,SOP,DATA[15:0]}
+ Doesn't fit well into BRAM, dist RAM ok
+ OCC = 1 means last word is half full
+ = 0 means last word is full
+
+fifo18 --> {EOP,SOP,DATA[15:0]}
+ No half-word capability? Should we drop sop instead?
+
+Control Wires - Data into FIFO
+ SRC_RDY_i Upstream has data for me
+ DST_RDY_o I have space
+ Transfer occurs if SRC_RDI_i && DST_RDY_o
+
+Control Wires - Data out of FIFO
+ SRC_RDY_o I have data for downstream
+ DST_RDY_i Downstream has space
+ Transfer occurs if SRC_RDI_o && DST_RDY_i
+