1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
|
//
// Copyright 2014 Ettus Research LLC
//
module axis_packet_debug
#(
parameter EXPECTED_SID = 32'h0000_0050
)
(
input clk,
input reset,
input clear,
//Packet In
input [63:0] tdata,
input tlast,
input tvalid,
input tready,
//Per packet info
output reg pkt_strobe,
output reg [15:0] length,
output reg [63:0] checksum,
output reg bad_sid,
//Statistics
output reg [31:0] pkt_count
);
localparam ST_HEADER = 1'b0;
localparam ST_DATA = 1'b1;
//Packet state logic
reg pkt_state;
always @(posedge clk) begin
if (reset) begin
pkt_state <= ST_HEADER;
end else if (tvalid & tready) begin
pkt_state <= tlast ? ST_HEADER : ST_DATA;
end
end
//Trigger logic
always @(posedge clk)
if (reset)
pkt_strobe <= 1'b0;
else
pkt_strobe <= tvalid && tready && tlast;
//Length capture
always @(posedge clk)
if (reset || (tvalid && tready && tlast))
length <= 16'd0;
else
if (tvalid & tready)
length <= length + 16'd8;
//Checksum capture
always @(posedge clk)
if (reset || (tvalid && tready && tlast) )
checksum <= 64'd0;
else
if (tvalid & tready)
checksum <= checksum ^ tdata;
//Counts
always @(posedge clk)
if (reset | clear) begin
pkt_count <= 32'd0;
end else begin
if (tvalid && tready && tlast) begin
pkt_count <= pkt_count + 32'd1;
end
end
// Check for unexpected SID
always @(posedge clk)
if (reset | clear) begin
bad_sid <= 1'b0;
end else if ((pkt_state == ST_HEADER) && tvalid && tready ) begin
bad_sid <= tdata[31:0] != EXPECTED_SID;
end else begin
bad_sid <= 1'b0;
end
endmodule // cvita_packet_debug
|