diff options
| -rw-r--r-- | usrp2/control_lib/settings_readback_bus_fifo_ctrl.v | 210 | ||||
| -rw-r--r-- | usrp2/top/N2x0/Makefile.N210R3 | 2 | ||||
| -rw-r--r-- | usrp2/top/N2x0/Makefile.N210R4 | 2 | 
3 files changed, 122 insertions, 92 deletions
| diff --git a/usrp2/control_lib/settings_readback_bus_fifo_ctrl.v b/usrp2/control_lib/settings_readback_bus_fifo_ctrl.v index 24c618d79..7927c2eef 100644 --- a/usrp2/control_lib/settings_readback_bus_fifo_ctrl.v +++ b/usrp2/control_lib/settings_readback_bus_fifo_ctrl.v @@ -19,6 +19,7 @@  module settings_readback_bus_fifo_ctrl      #( +        parameter FIFO_DEPTH = 6, //64 entries depth          parameter SID = 0, //stream id for vita return packet          parameter PROT_DEST = 0 //protocol framer destination      ) @@ -71,15 +72,33 @@ module settings_readback_bus_fifo_ctrl      wire [31:0] in_command_hdr, out_command_hdr;      wire [31:0] in_command_data, out_command_data;      wire in_command_has_time, out_command_has_time; -    wire in_command_valid, in_command_ready; -    wire out_command_valid, out_command_ready; +    wire command_fifo_full, command_fifo_empty; +    wire command_fifo_read, command_fifo_write; -    fifo_cascade #(.WIDTH(129), .SIZE(4)) command_fifo ( -        .clk(clock), .reset(reset), .clear(clear), +    medfifo #(.WIDTH(129), .DEPTH(FIFO_DEPTH-4)) command_fifo ( +        .clk(clock), .rst(reset), .clear(clear),          .datain({in_command_ticks, in_command_hdr, in_command_data, in_command_has_time}), -        .src_rdy_i(in_command_valid), .dst_rdy_o(in_command_ready),          .dataout({out_command_ticks, out_command_hdr, out_command_data, out_command_has_time}), -        .src_rdy_o(out_command_valid), .dst_rdy_i(out_command_ready) +        .write(command_fifo_write), .full(command_fifo_full), //input interface +        .empty(command_fifo_empty), .read(command_fifo_read)  //output interface +    ); + +    //------------------------------------------------------------------ +    //-- The result fifo: +    //-- Stores an individual result of a command per line. +    //------------------------------------------------------------------ +    wire [63:0] in_result_ticks, out_result_ticks; +    wire [31:0] in_result_hdr, out_result_hdr; +    wire [31:0] in_result_data, out_result_data; +    wire result_fifo_full, result_fifo_empty; +    wire result_fifo_read, result_fifo_write; + +    medfifo #(.WIDTH(128), .DEPTH(FIFO_DEPTH-4)) result_fifo ( +        .clk(clock), .rst(reset), .clear(clear), +        .datain({in_result_ticks, in_result_hdr, in_result_data}), +        .dataout({out_result_ticks, out_result_hdr, out_result_data}), +        .write(result_fifo_write), .full(result_fifo_full), //input interface +        .empty(result_fifo_empty), .read(result_fifo_read)  //output interface      );      //------------------------------------------------------------------ @@ -111,9 +130,7 @@ module settings_readback_bus_fifo_ctrl      reg has_sid_reg, has_cid_reg, has_tsi_reg, has_tsf_reg;      assign in_ready = (in_state < STORE_CMD); - -    //wire-up command inputs -    assign in_command_valid    = (in_state == STORE_CMD); +    assign command_fifo_write  = (in_state == STORE_CMD);      assign in_command_ticks    = in_ticks_reg;      assign in_command_data     = in_data_reg;      assign in_command_hdr      = in_hdr_reg; @@ -197,7 +214,7 @@ module settings_readback_bus_fifo_ctrl              end              STORE_CMD: begin -                if (in_command_valid && in_command_ready) in_state <= READ_LINE0; +                if (~command_fifo_full) in_state <= READ_LINE0;              end              endcase //in_state @@ -205,69 +222,58 @@ module settings_readback_bus_fifo_ctrl      end      //------------------------------------------------------------------ -    //-- Output state machine: -    //-- Read a command fifo entry, act on it, produce ack packet. +    //-- Command state machine: +    //-- Read a command fifo entry, act on it, produce result.      //------------------------------------------------------------------ -    localparam LOAD_CMD       = 0; -    localparam WAIT_CMD       = 1; -    localparam ACTION_EVENT   = 2; -    localparam WRITE_PROT_HDR = 3; -    localparam WRITE_VRT_HDR  = 4; -    localparam WRITE_VRT_SID  = 5; -    localparam WRITE_VRT_TSF0 = 6; -    localparam WRITE_VRT_TSF1 = 7; -    localparam WRITE_RB_HDR   = 8; -    localparam WRITE_RB_DATA  = 9; - -    reg [4:0] out_state; - -    //holdover from current read inputs -    reg [31:0] out_data_reg, out_hdr_reg; -    reg [63:0] out_ticks_reg; +    localparam LOAD_CMD    = 0; +    localparam EVENT_CMD   = 1; -    assign out_valid = (out_state > ACTION_EVENT); +    reg cmd_state; +    reg [31:0] rb_data; -    assign out_command_ready = (out_state == LOAD_CMD); +    reg [63:0] command_ticks_reg; +    reg [31:0] command_hdr_reg; +    reg [31:0] command_data_reg;      wire now, early, late, too_early; +    `ifdef FIFO_CTRL_USE_TIME      time_compare time_compare( -        .time_now(vita_time), .trigger_time(out_ticks_reg), +        .time_now(vita_time), .trigger_time(command_ticks_reg),          .now(now), .early(early), .late(late), .too_early(too_early)); +    `else +    assign now = 0; +    assign late = 1; +    `endif + +    //action occurs in the event state and when there is fifo space (should always be true) +    //the third condition is that is an event time has been set, action is delayed until that time +    wire action = (cmd_state == EVENT_CMD) && ~result_fifo_full && ((out_command_has_time)? (now || late || clear) : 1); + +    assign command_fifo_read = action; +    assign result_fifo_write = action; +    assign in_result_ticks = vita_time; +    assign in_result_hdr = command_hdr_reg; +    assign in_result_data = rb_data;      always @(posedge clock) begin          if (reset) begin -            out_state <= LOAD_CMD; +            cmd_state <= LOAD_CMD;          end          else begin -            case (out_state) +            case (cmd_state)              LOAD_CMD: begin -                if (out_command_valid && out_command_ready) begin -                    out_state <= (out_command_has_time)? WAIT_CMD : ACTION_EVENT; -                    out_data_reg <= out_command_data; -                    out_hdr_reg <= out_command_hdr; -                    out_ticks_reg <= out_command_ticks; -                end -            end - -            WAIT_CMD: begin -                if (clear) out_state <= LOAD_CMD; -                else if (now || late) out_state <= ACTION_EVENT; -            end - -            ACTION_EVENT: begin // poking and peeking happens here! -                out_state <= WRITE_PROT_HDR; +                if (~command_fifo_empty) cmd_state <= EVENT_CMD; +                command_ticks_reg <= out_command_ticks; +                command_hdr_reg <= out_command_hdr; +                command_data_reg <= out_command_data;              end -            WRITE_RB_DATA: begin -                if (writing) out_state <= LOAD_CMD; +            EVENT_CMD: begin // poking and peeking happens here! +                if (action) cmd_state <= LOAD_CMD;              end -            default: begin -                if (writing) out_state <= out_state + 1; -            end - -            endcase //out_state +            endcase //cmd_state          end      end @@ -276,41 +282,65 @@ module settings_readback_bus_fifo_ctrl      //------------------------------------------------------------------      reg strobe_reg;      assign strobe = strobe_reg; -    assign data = out_data_reg; -    assign addr = out_hdr_reg[7:0]; -    wire poke = out_hdr_reg[8]; +    assign data = command_data_reg; +    assign addr = command_hdr_reg[7:0]; +    wire poke = command_hdr_reg[8];      always @(posedge clock) begin -        if (reset || out_state != ACTION_EVENT) strobe_reg <= 0; -        else                                    strobe_reg <= poke; +        if (reset || clear) strobe_reg <= 0; +        else                strobe_reg <= action && poke;      end      //------------------------------------------------------------------      //-- readback mux      //------------------------------------------------------------------ -    reg [31:0] rb_data; -    reg [63:0] rb_time;      always @(posedge clock) begin -        if (out_state == ACTION_EVENT) begin -            rb_time <= vita_time; -            case (addr[3:0]) -                0 : rb_data <= word00; -                1 : rb_data <= word01; -                2 : rb_data <= word02; -                3 : rb_data <= word03; -                4 : rb_data <= word04; -                5 : rb_data <= word05; -                6 : rb_data <= word06; -                7 : rb_data <= word07; -                8 : rb_data <= word08; -                9 : rb_data <= word09; -                10: rb_data <= word10; -                11: rb_data <= word11; -                12: rb_data <= word12; -                13: rb_data <= word13; -                14: rb_data <= word14; -                15: rb_data <= word15; -            endcase // case(addr_reg[3:0]) +        case (out_command_hdr[3:0]) +            0 : rb_data <= word00; +            1 : rb_data <= word01; +            2 : rb_data <= word02; +            3 : rb_data <= word03; +            4 : rb_data <= word04; +            5 : rb_data <= word05; +            6 : rb_data <= word06; +            7 : rb_data <= word07; +            8 : rb_data <= word08; +            9 : rb_data <= word09; +            10: rb_data <= word10; +            11: rb_data <= word11; +            12: rb_data <= word12; +            13: rb_data <= word13; +            14: rb_data <= word14; +            15: rb_data <= word15; +        endcase // case(addr_reg[3:0]) +    end + +    //------------------------------------------------------------------ +    //-- Output state machine: +    //-- Read a command fifo entry, act on it, produce ack packet. +    //------------------------------------------------------------------ +    localparam WRITE_PROT_HDR = 0; +    localparam WRITE_VRT_HDR  = 1; +    localparam WRITE_VRT_SID  = 2; +    localparam WRITE_VRT_TSF0 = 3; +    localparam WRITE_VRT_TSF1 = 4; +    localparam WRITE_RB_HDR   = 5; +    localparam WRITE_RB_DATA  = 6; + +    reg [2:0] out_state; + +    assign out_valid = ~result_fifo_empty; +    assign result_fifo_read = out_data[33] && writing; + +    always @(posedge clock) begin +        if (reset) begin +            out_state <= WRITE_PROT_HDR; +        end +        else if (writing && out_state == WRITE_RB_DATA) begin +            out_state <= WRITE_PROT_HDR; +        end +        else if (writing) begin +            out_state <= out_state + 1;          end      end @@ -327,12 +357,12 @@ module settings_readback_bus_fifo_ctrl      always @* begin          case (out_state)              WRITE_PROT_HDR: out_data_int <= prot_hdr; -            WRITE_VRT_HDR:  out_data_int <= {12'b010100000001, out_hdr_reg[19:16], 16'd6}; +            WRITE_VRT_HDR:  out_data_int <= {12'b010100000001, out_result_hdr[19:16], 16'd6};              WRITE_VRT_SID:  out_data_int <= SID; -            WRITE_VRT_TSF0: out_data_int <= rb_time[63:32]; -            WRITE_VRT_TSF1: out_data_int <= rb_time[31:0]; -            WRITE_RB_HDR:   out_data_int <= out_hdr_reg; -            WRITE_RB_DATA:  out_data_int <= rb_data; +            WRITE_VRT_TSF0: out_data_int <= out_result_ticks[63:32]; +            WRITE_VRT_TSF1: out_data_int <= out_result_ticks[31:0]; +            WRITE_RB_HDR:   out_data_int <= out_result_hdr; +            WRITE_RB_DATA:  out_data_int <= out_result_data;              default:        out_data_int <= 0;          endcase //state      end @@ -346,11 +376,11 @@ module settings_readback_bus_fifo_ctrl      //-- debug outputs      //------------------------------------------------------------------      assign debug = { -        in_state, out_state, //8 +        in_state, cmd_state, out_state, //8          in_valid, in_ready, in_data[33:32], //4          out_valid, out_ready, out_data[33:32], //4 -        in_command_valid, in_command_ready, //2 -        out_command_valid, out_command_ready, //2 +        command_fifo_empty, command_fifo_full, //2 +        command_fifo_read, command_fifo_write, //2          addr, //8          strobe_reg, strobe, poke, out_command_has_time //4      }; diff --git a/usrp2/top/N2x0/Makefile.N210R3 b/usrp2/top/N2x0/Makefile.N210R3 index 411aa20f1..3ef769d3a 100644 --- a/usrp2/top/N2x0/Makefile.N210R3 +++ b/usrp2/top/N2x0/Makefile.N210R3 @@ -70,7 +70,7 @@ SYNTHESIZE_PROPERTIES = \  "Use Clock Enable" Auto \  "Use Synchronous Reset" Auto \  "Use Synchronous Set" Auto \ -"Verilog Macros" "$(CUSTOM_DEFS)" +"Verilog Macros" " FIFO_CTRL_USE_TIME=1 $(CUSTOM_DEFS)"  TRANSLATE_PROPERTIES = \  "Macro Search Path" "$(shell pwd)/../../coregen/" diff --git a/usrp2/top/N2x0/Makefile.N210R4 b/usrp2/top/N2x0/Makefile.N210R4 index 44ce17b3f..315388586 100644 --- a/usrp2/top/N2x0/Makefile.N210R4 +++ b/usrp2/top/N2x0/Makefile.N210R4 @@ -71,7 +71,7 @@ SYNTHESIZE_PROPERTIES = \  "Use Clock Enable" Auto \  "Use Synchronous Reset" Auto \  "Use Synchronous Set" Auto \ -"Verilog Macros" "LVDS=1 $(CUSTOM_DEFS)" +"Verilog Macros" "LVDS=1 FIFO_CTRL_USE_TIME=1 $(CUSTOM_DEFS)"  TRANSLATE_PROPERTIES = \  "Macro Search Path" "$(shell pwd)/../../coregen/" | 
