commit-gnuradio
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Commit-gnuradio] r6755 - in gnuradio/branches/developers/jcorgan/t179/u


From: matt
Subject: [Commit-gnuradio] r6755 - in gnuradio/branches/developers/jcorgan/t179/usrp/fpga: models sdr_lib
Date: Wed, 31 Oct 2007 01:38:01 -0600 (MDT)

Author: matt
Date: 2007-10-31 01:38:00 -0600 (Wed, 31 Oct 2007)
New Revision: 6755

Added:
   gnuradio/branches/developers/jcorgan/t179/usrp/fpga/models/fifo_4k_18.v
Modified:
   gnuradio/branches/developers/jcorgan/t179/usrp/fpga/models/fifo.v
   gnuradio/branches/developers/jcorgan/t179/usrp/fpga/sdr_lib/tx_buffer.v
Log:
cleaned up a lot.  Should properly overrun now, at the least


Modified: gnuradio/branches/developers/jcorgan/t179/usrp/fpga/models/fifo.v
===================================================================
--- gnuradio/branches/developers/jcorgan/t179/usrp/fpga/models/fifo.v   
2007-10-31 05:00:49 UTC (rev 6754)
+++ gnuradio/branches/developers/jcorgan/t179/usrp/fpga/models/fifo.v   
2007-10-31 07:38:00 UTC (rev 6755)
@@ -77,5 +77,6 @@
    assign rdempty = (rdusedw == 0);
    assign rdfull = (rdusedw == depth-1);
    
-endmodule // fifo_1c_1k
+endmodule // fifo
 
+

Added: gnuradio/branches/developers/jcorgan/t179/usrp/fpga/models/fifo_4k_18.v
===================================================================
--- gnuradio/branches/developers/jcorgan/t179/usrp/fpga/models/fifo_4k_18.v     
                        (rev 0)
+++ gnuradio/branches/developers/jcorgan/t179/usrp/fpga/models/fifo_4k_18.v     
2007-10-31 07:38:00 UTC (rev 6755)
@@ -0,0 +1,26 @@
+
+
+module fifo_4k_18
+  (input  [17:0] data,
+   input         wrreq,
+   input         wrclk,
+   output       wrfull,
+   output       wrempty,
+   output [11:0] wrusedw,
+
+   output [17:0] q,
+   input         rdreq,
+   input         rdclk,
+   output       rdfull,
+   output       rdempty,
+   output [11:0] rdusedw,
+
+   input        aclr );
+
+fifo #(.width(18),.depth(4096),.addr_bits(12)) fifo_4k 
+  ( data, wrreq, rdreq, rdclk, wrclk, aclr, q,
+    rdfull, rdempty, rdusedw, wrfull, wrempty, wrusedw);
+   
+endmodule // fifo_4k_18
+
+   

Modified: 
gnuradio/branches/developers/jcorgan/t179/usrp/fpga/sdr_lib/tx_buffer.v
===================================================================
--- gnuradio/branches/developers/jcorgan/t179/usrp/fpga/sdr_lib/tx_buffer.v     
2007-10-31 05:00:49 UTC (rev 6754)
+++ gnuradio/branches/developers/jcorgan/t179/usrp/fpga/sdr_lib/tx_buffer.v     
2007-10-31 07:38:00 UTC (rev 6755)
@@ -24,141 +24,138 @@
 // Fifo has 1024 or 2048 lines
 
 module tx_buffer
-  ( input usbclk,
+  ( // USB Side
+    input usbclk,
     input bus_reset,  // Used here for the 257-Hack to fix the FX2 bug
-    input reset,  // standard DSP-side reset
     input [15:0] usbdata,
     input wire WR,
-    output wire have_space,
+    output reg have_space,
     output reg tx_underrun,
+    input clear_status,
+
+    // DSP Side
+    input txclk,
+    input reset,  // standard DSP-side reset
     input wire [3:0] channels,
     output reg [15:0] tx_i_0,
     output reg [15:0] tx_q_0,
     output reg [15:0] tx_i_1,
     output reg [15:0] tx_q_1,
-    output reg [15:0] tx_i_2,
-    output reg [15:0] tx_q_2,
-    output reg [15:0] tx_i_3,
-    output reg [15:0] tx_q_3,
-    input txclk,
     input txstrobe,
-    input clear_status,
     output wire tx_empty,
     output [31:0] debugbus
     );
    
-   wire [11:0] txfifolevel;
-   reg [8:0] write_count;
-   wire tx_full;
-   wire [15:0] fifodata;
-   wire rdreq;
-
-   reg [3:0] load_next;
-
-   // DAC Side of FIFO
-   assign    rdreq = ((load_next != channels) & !tx_empty);
+   wire [11:0]           txfifolevel;
+   wire [15:0]           fifodata;
+   wire          rdreq;
+   reg [3:0]     phase;
+   wire          sop_f, iq_f;
+   reg                   sop;
    
-   always @(posedge txclk)
-     if(reset)
-       begin
-         {tx_i_0,tx_q_0,tx_i_1,tx_q_1,tx_i_2,tx_q_2,tx_i_3,tx_q_3}
-           <= #1 128'h0;
-         load_next <= #1 4'd0;
-       end
-     else
-       if(load_next != channels)
-        begin
-           load_next <= #1 load_next + 4'd1;
-           case(load_next)
-             4'd0 : tx_i_0 <= #1 tx_empty ? 16'd0 : fifodata;
-             4'd1 : tx_q_0 <= #1 tx_empty ? 16'd0 : fifodata;
-             4'd2 : tx_i_1 <= #1 tx_empty ? 16'd0 : fifodata;
-             4'd3 : tx_q_1 <= #1 tx_empty ? 16'd0 : fifodata;
-             4'd4 : tx_i_2 <= #1 tx_empty ? 16'd0 : fifodata;
-             4'd5 : tx_q_2 <= #1 tx_empty ? 16'd0 : fifodata;
-             4'd6 : tx_i_3 <= #1 tx_empty ? 16'd0 : fifodata;
-             4'd7 : tx_q_3 <= #1 tx_empty ? 16'd0 : fifodata;
-           endcase // case(load_next)
-        end // if (load_next != channels)
-       else if(txstrobe & (load_next == channels))
-        begin
-           load_next <= #1 4'd0;
-        end
-
    // USB Side of FIFO
-   assign have_space = (txfifolevel <= (4095-256));
-
+   reg [15:0]    usbdata_reg;
+   reg                   wr_reg;
+   reg [8:0]     write_count;
+   
    always @(posedge usbclk)
-     if(bus_reset)        // Use bus reset because this is on usbclk
-       write_count <= #1 0;
-     else if(WR & ~write_count[8])
-       write_count <= #1 write_count + 9'd1;
+     have_space <= (txfifolevel < (4092-256));  // be extra conservative
+   
+   always @(posedge usbclk)
+     begin
+       wr_reg <= WR;
+       usbdata_reg <= usbdata;
+     end
+   
+   always @(posedge usbclk)
+     if(bus_reset)
+       write_count <= 0;
+     else if(wr_reg)
+       write_count <= write_count + 1;
      else
-       write_count <= #1 WR ? write_count : 9'b0;
-
-   // Detect Underruns
-   always @(posedge txclk)
-     if(reset)
-       tx_underrun <= 1'b0;
-     else if(txstrobe & (load_next != channels))
-       tx_underrun <= 1'b1;
-     else if(clear_status)
-       tx_underrun <= 1'b0;
-
-   // Debugging
-   wire   sop_f;
-   wire   iq_f;
+       write_count <= 0;
    
+   always @(posedge usbclk)
+     sop <= WR & ~wr_reg; // Edge detect
+   
    // FIFO
    fifo_4k_18 txfifo 
-     ( .data ( {sop,iq_sense,usbdata} ),
-       .wrreq ( WR & ~write_count[8] ),
+     ( // USB Write Side
+       .data ( {sop,write_count[0],usbdata_reg} ),
+       .wrreq ( wr_reg & ~write_count[8] ),
        .wrclk ( usbclk ),
-       
+       .wrfull ( ),
+       .wrempty ( ),
+       .wrusedw ( txfifolevel ),
+       // DSP Read Side
        .q ( {sop_f, iq_f, fifodata} ),                 
        .rdreq ( rdreq ),
        .rdclk ( txclk ),
-       
-       .aclr ( reset ),  // asynch, so we can use either
-       
+       .rdfull ( ),
        .rdempty ( tx_empty ),
        .rdusedw (  ),
-       .wrfull ( tx_full ),
-       .wrusedw ( txfifolevel )
-       );
+       // Async, shared
+       .aclr ( reset ) );
    
+   // DAC Side of FIFO
+   always @(posedge txclk)
+     if(reset)
+       begin
+         {tx_i_0,tx_q_0,tx_i_1,tx_q_1} <= 64'h0;
+         phase <= 4'd0;
+       end
+     else if(phase == channels)
+       begin
+         if(txstrobe)
+           phase <= 4'd0;
+       end
+     else
+       if(~tx_empty)
+        begin
+           case(phase)
+             4'd0 : tx_i_0 <= fifodata;
+             4'd1 : tx_q_0 <= fifodata;
+             4'd2 : tx_i_1 <= fifodata;
+             4'd3 : tx_q_1 <= fifodata;
+           endcase // case(phase)
+           phase <= phase + 4'd1;
+        end
+      
+   assign    rdreq = ((phase != channels) & ~tx_empty);
+   
+   // Detect Underruns, cross clock domains
+   reg clear_status_dsp, tx_underrun_dsp;
+   always @(posedge txclk)
+     clear_status_dsp <= clear_status;
+
+   always @(posedge usbclk)
+     tx_underrun <= tx_underrun_dsp;
+           
+   always @(posedge txclk)
+     if(reset)
+       tx_underrun_dsp <= 1'b0;
+     else if(txstrobe & (phase != channels))
+       tx_underrun_dsp <= 1'b1;
+     else if(clear_status_dsp)
+       tx_underrun_dsp <= 1'b0;
+
    // Debugging Aids
    assign debugbus[0] = WR;
    assign debugbus[1] = have_space;
    assign debugbus[2] = tx_empty;
-   assign debugbus[3] = tx_full;
+   assign debugbus[3] = 0;
    assign debugbus[4] = tx_underrun;
    assign debugbus[5] = write_count[8];
    assign debugbus[6] = txstrobe;
    assign debugbus[7] = rdreq;
-   assign debugbus[11:8] = load_next;
+   assign debugbus[11:8] = phase;
    assign debugbus[12] = iq_f;
    assign debugbus[13] = sop_f;
-   assign debugbus[14] = iq_sense;
+   assign debugbus[14] = write_count[0];
    assign debugbus[15] = sop;
    assign debugbus[16] = txclk;
    assign debugbus[17] = usbclk;
    assign debugbus[31:18] = 0;
- 
-         
-   // Generate start of packet signal and IQ sense
-   reg         wr_reg;
-   reg  iq_sense;           // 0 -> I, 1 -> Q
-   wire sop = WR & ~wr_reg; // Edge detect
-   
-   always @(posedge usbclk)
-     wr_reg <= WR;
-     
-   always @(posedge usbclk)
-     if (WR)
-       iq_sense <= ~iq_sense;
-     else
-       iq_sense <= 1'b0;
-         
+          
 endmodule // tx_buffer
 





reply via email to

[Prev in Thread] Current Thread [Next in Thread]