diff options
| author | Josh Blum <josh@joshknows.com> | 2011-01-19 22:23:46 -0800 | 
|---|---|---|
| committer | Josh Blum <josh@joshknows.com> | 2011-01-19 22:23:46 -0800 | 
| commit | 9239878b0b81c3a368bf11cfc2fe48bfb05ff902 (patch) | |
| tree | f41a5e58eac89b35cb99537a0a0b64662384a9f2 /fpga/usrp2/udp | |
| parent | fc138381ee4bd8d191795230b7447071a85e1f28 (diff) | |
| parent | 7d918c5f6acc9a5d2c8ae03e2e67b403f7efd5ff (diff) | |
| download | uhd-9239878b0b81c3a368bf11cfc2fe48bfb05ff902.tar.gz uhd-9239878b0b81c3a368bf11cfc2fe48bfb05ff902.tar.bz2 uhd-9239878b0b81c3a368bf11cfc2fe48bfb05ff902.zip  | |
Merge branch 'next'
Conflicts:
	host/lib/usrp/usrp2/codec_impl.cpp
Diffstat (limited to 'fpga/usrp2/udp')
| -rw-r--r-- | fpga/usrp2/udp/prot_eng_tx.v | 56 | ||||
| -rw-r--r-- | fpga/usrp2/udp/prot_eng_tx_tb.v | 27 | 
2 files changed, 54 insertions, 29 deletions
diff --git a/fpga/usrp2/udp/prot_eng_tx.v b/fpga/usrp2/udp/prot_eng_tx.v index a18eb73ae..c642842f6 100644 --- a/fpga/usrp2/udp/prot_eng_tx.v +++ b/fpga/usrp2/udp/prot_eng_tx.v @@ -7,6 +7,8 @@  //            Odd means the last word is half full  //   Flags[1:0] is {eop, sop}  //   Protocol word format is: +//             21   UDP Source Port Here +//             20   UDP Dest Port Here  //             19   Last Header Line  //             18   IP Header Checksum XOR  //             17   IP Length Here @@ -34,28 +36,40 @@ module prot_eng_tx     assign dst_rdy_o 	 = dst_rdy_i & (do_payload | (state==0) | (state==1) | (state==30));     assign src_rdy_o 	 = src_rdy_i & ~((state==0) | (state==1) | (state==30)); -   localparam HDR_WIDTH  = 16 + 4;  // 16 bits plus flags +   localparam HDR_WIDTH  = 16 + 6;  // 16 bits plus flags     localparam HDR_LEN 	 = 32;      // Up to 64 bytes of protocol     // Store header values in a small dual-port (distributed) ram     reg [HDR_WIDTH-1:0] header_ram[0:HDR_LEN-1];     wire [HDR_WIDTH-1:0] header_word; -   reg [15:0]  chk_precompute; -    + +   reg [1:0] 		port_sel; +   reg [31:0] 		per_port_data[0:3]; +   reg [15:0] 		udp_src_port, udp_dst_port, chk_precompute; + +   always @(posedge clk) udp_src_port <= per_port_data[port_sel][31:16]; +   always @(posedge clk) udp_dst_port <= per_port_data[port_sel][15:0]; +     always @(posedge clk)       if(set_stb & ((set_addr & 8'hE0) == BASE)) -       begin -	  header_ram[set_addr[4:0]] <= set_data; -	  if(set_data[18]) -	    chk_precompute <= set_data[15:0]; -       end +       header_ram[set_addr[4:0]] <= set_data; + +   always @(posedge clk) +     if(set_stb & (set_addr == (BASE + 14))) +       chk_precompute <= set_data[15:0]; + +   always @(posedge clk) +     if(set_stb & ((set_addr & 8'hFC) == (BASE+24))) +       per_port_data[set_addr[1:0]] <= set_data; -   assign header_word = header_ram[state]; +   wire do_udp_src_port = header_word[21]; +   wire do_udp_dst_port = header_word[20]; +   wire last_hdr_line   = header_word[19]; +   wire do_ip_chk       = header_word[18]; +   wire do_ip_len       = header_word[17]; +   wire do_udp_len      = header_word[16]; -   wire last_hdr_line  = header_word[19]; -   wire ip_chk 	       = header_word[18]; -   wire ip_len 	       = header_word[17]; -   wire udp_len        = header_word[16]; +   assign header_word = header_ram[state];     // Protocol State Machine     reg [15:0] length; @@ -75,6 +89,7 @@ module prot_eng_tx  	   0 :  	     begin  		fast_path <= datain[0]; +		port_sel <= datain[2:1];  		state <= 1;  	     end  	   1 : @@ -113,15 +128,18 @@ module prot_eng_tx       checksum_reg <= checksum;     always @* -     if(ip_chk) -       //dataout_int 	<= header_word[15:0] ^ ip_length; +     if(do_payload) +       dataout_int 	<= datain[15:0]; +     else if(do_ip_chk)         dataout_int 	<= 16'hFFFF ^ checksum_reg; -     else if(ip_len) +     else if(do_ip_len)         dataout_int 	<= ip_length; -     else if(udp_len) +     else if(do_udp_len)         dataout_int 	<= udp_length; -     else if(do_payload) -       dataout_int 	<= datain[15:0]; +     else if(do_udp_src_port) +       dataout_int      <= udp_src_port; +     else if(do_udp_dst_port) +       dataout_int      <= udp_dst_port;       else         dataout_int 	<= header_word[15:0]; diff --git a/fpga/usrp2/udp/prot_eng_tx_tb.v b/fpga/usrp2/udp/prot_eng_tx_tb.v index e7ffeb5e1..c8fffe605 100644 --- a/fpga/usrp2/udp/prot_eng_tx_tb.v +++ b/fpga/usrp2/udp/prot_eng_tx_tb.v @@ -80,7 +80,7 @@ module prot_eng_tx_tb();        begin  	 count 	      <= 4;  	 src_rdy_f36i <= 1; -	 f36_data     <= 32'h0001_000c; +	 f36_data     <= 32'h0003_000c;  	 f36_sof      <= 1;  	 f36_eof      <= 0;  	 f36_occ      <= 0; @@ -140,16 +140,23 @@ module prot_eng_tx_tb();  	@(negedge rst);  	@(posedge clk);  	WriteSREG(BASE, {12'b0, 4'h0, 16'h0000}); -	WriteSREG(BASE+1, {12'b0, 4'h0, 16'h0000}); -	WriteSREG(BASE+2, {12'b0, 4'h0, 16'hABCD}); -	WriteSREG(BASE+3, {12'b0, 4'h0, 16'h1234}); -	WriteSREG(BASE+4, {12'b0, 4'h8, 16'h5678}); -	WriteSREG(BASE+5, {12'b0, 4'h0, 16'hABCD}); -	WriteSREG(BASE+6, {12'b0, 4'h0, 16'hABCD}); -	WriteSREG(BASE+7, {12'b0, 4'h0, 16'hABCD}); -	WriteSREG(BASE+8, {12'b0, 4'h0, 16'hABCD}); -	WriteSREG(BASE+9, {12'b0, 4'h0, 16'hABCD}); +	WriteSREG(BASE+1, {11'b0, 5'h00, 16'h0000}); +	WriteSREG(BASE+2, {11'b0, 5'h00, 16'hABCD}); +	WriteSREG(BASE+3, {11'b0, 5'h00, 16'h1234}); +	WriteSREG(BASE+4, {11'b0, 5'h00, 16'h5678}); +	WriteSREG(BASE+5, {11'b0, 5'h00, 16'hF00D}); +	WriteSREG(BASE+6, {11'b0, 5'h00, 16'hBEEF}); +	WriteSREG(BASE+7, {11'b0, 5'h10, 16'hDCBA}); +	WriteSREG(BASE+8, {11'b0, 5'h00, 16'h4321}); +	WriteSREG(BASE+9, {11'b0, 5'h04, 16'hABCD}); +	WriteSREG(BASE+10, {11'b0, 5'h08, 16'hABCD});  	@(posedge clk); +	 +	WriteSREG(BASE+24, 16'h6666); +	WriteSREG(BASE+25, 16'h7777); +	WriteSREG(BASE+26, 16'h8888); +	WriteSREG(BASE+27, 16'h9999); +	  	PutPacketInFIFO36(32'hA0B0C0D0,16);  	@(posedge clk);  	@(posedge clk);  | 
