aboutsummaryrefslogtreecommitdiffstats
path: root/usrp2/vrt/vita_tx_control.v
diff options
context:
space:
mode:
authorMatt Ettus <matt@ettus.com>2010-07-20 15:22:19 -0700
committerMatt Ettus <matt@ettus.com>2010-07-28 10:00:44 -0700
commit0cf5dc0aac63940358f13db6f60ef44b55e78a50 (patch)
tree868d2886ba08ebbbbb70e9fe563cbab5b78b8d88 /usrp2/vrt/vita_tx_control.v
parentffadd16f70d918fc7774c0b88fb6d47d7b257763 (diff)
downloaduhd-0cf5dc0aac63940358f13db6f60ef44b55e78a50.tar.gz
uhd-0cf5dc0aac63940358f13db6f60ef44b55e78a50.tar.bz2
uhd-0cf5dc0aac63940358f13db6f60ef44b55e78a50.zip
introduce new error types
Diffstat (limited to 'usrp2/vrt/vita_tx_control.v')
-rw-r--r--usrp2/vrt/vita_tx_control.v57
1 files changed, 42 insertions, 15 deletions
diff --git a/usrp2/vrt/vita_tx_control.v b/usrp2/vrt/vita_tx_control.v
index bffc64e52..29d3041b5 100644
--- a/usrp2/vrt/vita_tx_control.v
+++ b/usrp2/vrt/vita_tx_control.v
@@ -6,10 +6,11 @@ module vita_tx_control
input set_stb, input [7:0] set_addr, input [31:0] set_data,
input [63:0] vita_time,
- output underrun,
+ output reg [3:0] error_code,
+ output error,
// From vita_tx_deframer
- input [4+64+WIDTH-1:0] sample_fifo_i,
+ input [5+64+WIDTH-1:0] sample_fifo_i,
input sample_fifo_src_rdy_i,
output sample_fifo_dst_rdy_o,
@@ -20,14 +21,16 @@ module vita_tx_control
output [31:0] debug
);
-
- assign sample = sample_fifo_i[4+64+WIDTH-1:4+64];
+
+ assign sample = sample_fifo_i[5+64+WIDTH-1:5+64];
wire [63:0] send_time = sample_fifo_i[63:0];
wire eop = sample_fifo_i[64];
wire eob = sample_fifo_i[65];
wire sob = sample_fifo_i[66];
wire send_at = sample_fifo_i[67];
+ wire seqnum_err = sample_fifo_i[68];
+
wire now, early, late, too_early;
// FIXME ignore too_early for now for timing reasons
@@ -41,7 +44,13 @@ module vita_tx_control
localparam IBS_RUN = 1; // FIXME do we need this?
localparam IBS_CONT_BURST = 2;
localparam IBS_UNDERRUN = 3;
- localparam IBS_UNDERRUN_DONE = 4;
+ localparam IBS_TIME_ERROR = 4;
+ localparam IBS_SEQ_ERROR = 5;
+ localparam IBS_ERROR_DONE = 7;
+
+ localparam CODE_UNDERRUN = 2;
+ localparam CODE_SEQ_ERROR = 4;
+ localparam CODE_TIME_ERROR = 8;
reg [2:0] ibs_state;
@@ -57,10 +66,12 @@ module vita_tx_control
case(ibs_state)
IBS_IDLE :
if(sample_fifo_src_rdy_i)
- if(~send_at | now)
+ if(seqnum_err)
+ ibs_state <= IBS_SEQ_ERROR;
+ else if(~send_at | now)
ibs_state <= IBS_RUN;
else if(late | too_early)
- ibs_state <= IBS_UNDERRUN;
+ ibs_state <= IBS_TIME_ERROR;
IBS_RUN :
if(strobe)
@@ -74,24 +85,40 @@ module vita_tx_control
IBS_CONT_BURST :
if(strobe)
- ibs_state <= IBS_UNDERRUN_DONE;
+ ibs_state <= IBS_ERROR_DONE;
else if(sample_fifo_src_rdy_i)
- ibs_state <= IBS_RUN;
+ if(seqnum_err)
+ ibs_state <= IBS_SEQ_ERROR;
+ else
+ ibs_state <= IBS_RUN;
IBS_UNDERRUN :
- if(sample_fifo_src_rdy_i & eop)
- ibs_state <= IBS_UNDERRUN_DONE;
-
- IBS_UNDERRUN_DONE :
+ begin
+ error_code <= CODE_UNDERRUN;
+ if(sample_fifo_src_rdy_i & eop)
+ ibs_state <= IBS_ERROR_DONE;
+ end
+ IBS_TIME_ERROR :
+ begin
+ error_code <= CODE_TIME_ERROR;
+ ibs_state <= IBS_ERROR_DONE;
+ end
+ IBS_SEQ_ERROR :
+ begin
+ error_code <= CODE_SEQ_ERROR;
+ ibs_state <= IBS_ERROR_DONE;
+ end
+ IBS_ERROR_DONE :
;
+
endcase // case (ibs_state)
assign sample_fifo_dst_rdy_o = (ibs_state == IBS_UNDERRUN) | (strobe & (ibs_state == IBS_RUN)); // FIXME also cleanout
assign run = (ibs_state == IBS_RUN) | (ibs_state == IBS_CONT_BURST);
- assign underrun = (ibs_state == IBS_UNDERRUN_DONE);
+ assign error = (ibs_state == IBS_ERROR_DONE);
assign debug = { { now,early,late,too_early,eop,eob,sob,send_at },
- { sample_fifo_src_rdy_i, sample_fifo_dst_rdy_o, strobe, run, underrun, ibs_state[2:0] },
+ { sample_fifo_src_rdy_i, sample_fifo_dst_rdy_o, strobe, run, error, ibs_state[2:0] },
{ 8'b0 },
{ 8'b0 } };