mirror of
https://github.com/jhshi/openofdm.git
synced 2025-01-23 20:48:00 +00:00
269 lines
7.7 KiB
Verilog
269 lines
7.7 KiB
Verilog
|
|
`timescale 1 ns / 1 ps
|
|
|
|
module openofdm_rx #
|
|
(
|
|
parameter integer IQ_DATA_WIDTH = 16,
|
|
parameter integer RSSI_HALF_DB_WIDTH = 11,
|
|
|
|
parameter integer C_S00_AXI_DATA_WIDTH = 32,
|
|
parameter integer C_S00_AXI_ADDR_WIDTH = 7
|
|
)
|
|
(
|
|
// intf to dot11
|
|
//input wire openofdm_core_rst,
|
|
input wire signed [(RSSI_HALF_DB_WIDTH-1):0] rssi_half_db,
|
|
input wire [(2*IQ_DATA_WIDTH-1):0] sample_in,
|
|
input wire sample_in_strobe,
|
|
|
|
output wire demod_is_ongoing, // this needs to be corrected further to indicate actual RF on going regardless the latency
|
|
// output wire pkt_ht,
|
|
output wire pkt_header_valid,
|
|
output wire pkt_header_valid_strobe,
|
|
output wire ht_unsupport,
|
|
output wire [7:0] pkt_rate,
|
|
output wire [15:0] pkt_len,
|
|
// output wire [15:0] pkt_len_total, // for interface to byte_to_word.v in rx_intf.v
|
|
output wire byte_out_strobe,
|
|
output wire [7:0] byte_out,
|
|
// output wire [15:0] byte_count_total, // for interface to byte_to_word.v in rx_intf.v
|
|
output wire [15:0] byte_count,
|
|
output wire fcs_out_strobe,
|
|
output wire fcs_ok,
|
|
|
|
// axi lite based register configuration interface
|
|
input wire s00_axi_aclk,
|
|
input wire s00_axi_aresetn,
|
|
input wire [C_S00_AXI_ADDR_WIDTH-1 : 0] s00_axi_awaddr,
|
|
input wire [2 : 0] s00_axi_awprot,
|
|
input wire s00_axi_awvalid,
|
|
output wire s00_axi_awready,
|
|
input wire [C_S00_AXI_DATA_WIDTH-1 : 0] s00_axi_wdata,
|
|
input wire [(C_S00_AXI_DATA_WIDTH/8)-1 : 0] s00_axi_wstrb,
|
|
input wire s00_axi_wvalid,
|
|
output wire s00_axi_wready,
|
|
output wire [1 : 0] s00_axi_bresp,
|
|
output wire s00_axi_bvalid,
|
|
input wire s00_axi_bready,
|
|
input wire [C_S00_AXI_ADDR_WIDTH-1 : 0] s00_axi_araddr,
|
|
input wire [2 : 0] s00_axi_arprot,
|
|
input wire s00_axi_arvalid,
|
|
output wire s00_axi_arready,
|
|
output wire [C_S00_AXI_DATA_WIDTH-1 : 0] s00_axi_rdata,
|
|
output wire [1 : 0] s00_axi_rresp,
|
|
output wire s00_axi_rvalid,
|
|
input wire s00_axi_rready
|
|
);
|
|
|
|
// reg0~19 for config write; from reg20 for reading status
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg0;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg1; //
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg2;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg3; //
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg4; //
|
|
/*
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg5; //
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg6; //
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg7; //
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg8;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg9; //
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg10;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg11;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg12;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg13;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg14;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg15;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg16;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg17;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg18;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg19; */
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg20; // read openofdm rx core internal state
|
|
/*
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg21;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg22;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg23;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg24;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg25;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg26;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg27;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg28;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg29;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg30;
|
|
wire [(C_S00_AXI_DATA_WIDTH-1):0] slv_reg31;
|
|
*/
|
|
|
|
wire [3:0] state;
|
|
wire state_changed;
|
|
reg [31:0] state_history;
|
|
|
|
assign slv_reg20 = state_history;
|
|
|
|
always @(posedge s00_axi_aclk) begin
|
|
if (s00_axi_aresetn==0) begin
|
|
state_history <= 0;
|
|
end else if (state_changed) begin
|
|
state_history[3:0] <= state;
|
|
state_history[31:4] <= state_history[27:0];
|
|
end
|
|
end
|
|
|
|
dot11 # (
|
|
) dot11_i (
|
|
.clock(s00_axi_aclk),
|
|
.enable( ~slv_reg1[0] ),
|
|
//.reset ( (~s00_axi_aresetn)|slv_reg0[0]|openofdm_core_rst ),
|
|
.reset ( (~s00_axi_aresetn)|slv_reg0[0] ),
|
|
|
|
.power_thres(slv_reg2[10:0]),
|
|
.min_plateau(slv_reg3),
|
|
|
|
.rssi_half_db(rssi_half_db),
|
|
|
|
.sample_in(sample_in),
|
|
.sample_in_strobe(sample_in_strobe),
|
|
.soft_decoding(slv_reg4[0]),
|
|
|
|
// OUTPUT: bytes and FCS status
|
|
.demod_is_ongoing(demod_is_ongoing),
|
|
// .pkt_begin(),
|
|
// .pkt_ht(),
|
|
.pkt_header_valid(pkt_header_valid),
|
|
.pkt_header_valid_strobe(pkt_header_valid_strobe),
|
|
.ht_unsupport(ht_unsupport),
|
|
.pkt_rate(pkt_rate),
|
|
.pkt_len(pkt_len),
|
|
// .pkt_len_total(pkt_len_total),
|
|
.byte_out_strobe(byte_out_strobe),
|
|
.byte_out(byte_out),
|
|
// .byte_count_total(byte_count_total),
|
|
.byte_count(byte_count),
|
|
.fcs_out_strobe(fcs_out_strobe),
|
|
.fcs_ok(fcs_ok),
|
|
|
|
/////////////////////////////////////////////////////////
|
|
// DEBUG PORTS
|
|
/////////////////////////////////////////////////////////
|
|
// decode status
|
|
.state(state),
|
|
.status_code(),
|
|
.state_changed(state_changed),
|
|
|
|
// power trigger
|
|
.power_trigger(),
|
|
|
|
// sync short
|
|
.short_preamble_detected(),
|
|
.phase_offset(),
|
|
|
|
// sync long
|
|
.sync_long_metric(),
|
|
.sync_long_metric_stb(),
|
|
.long_preamble_detected(),
|
|
.sync_long_out(),
|
|
.sync_long_out_strobe(),
|
|
.sync_long_state(),
|
|
|
|
// equalizer
|
|
.equalizer_out(),
|
|
.equalizer_out_strobe(),
|
|
.equalizer_state(),
|
|
|
|
// legacy signal info
|
|
.legacy_sig_stb(),
|
|
.legacy_rate(),
|
|
.legacy_sig_rsvd(),
|
|
.legacy_len(),
|
|
.legacy_sig_parity(),
|
|
.legacy_sig_parity_ok(),
|
|
.legacy_sig_tail(),
|
|
|
|
// ht signal info
|
|
.ht_sig_stb(),
|
|
.ht_mcs(),
|
|
.ht_cbw(),
|
|
.ht_len(),
|
|
.ht_smoothing(),
|
|
.ht_not_sounding(),
|
|
.ht_aggregation(),
|
|
.ht_stbc(),
|
|
.ht_fec_coding(),
|
|
.ht_sgi(),
|
|
.ht_num_ext(),
|
|
.ht_sig_crc_ok(),
|
|
|
|
// decoding pipeline
|
|
.demod_out(),
|
|
.demod_out_strobe(),
|
|
|
|
.deinterleave_erase_out(),
|
|
.deinterleave_erase_out_strobe(),
|
|
|
|
.conv_decoder_out(),
|
|
.conv_decoder_out_stb(),
|
|
|
|
.descramble_out(),
|
|
.descramble_out_strobe()
|
|
);
|
|
|
|
openofdm_rx_s_axi # (
|
|
.C_S_AXI_DATA_WIDTH(C_S00_AXI_DATA_WIDTH),
|
|
.C_S_AXI_ADDR_WIDTH(C_S00_AXI_ADDR_WIDTH)
|
|
) openofdm_rx_s_axi_i (
|
|
.S_AXI_ACLK(s00_axi_aclk),
|
|
.S_AXI_ARESETN(s00_axi_aresetn),
|
|
.S_AXI_AWADDR(s00_axi_awaddr),
|
|
.S_AXI_AWPROT(s00_axi_awprot),
|
|
.S_AXI_AWVALID(s00_axi_awvalid),
|
|
.S_AXI_AWREADY(s00_axi_awready),
|
|
.S_AXI_WDATA(s00_axi_wdata),
|
|
.S_AXI_WSTRB(s00_axi_wstrb),
|
|
.S_AXI_WVALID(s00_axi_wvalid),
|
|
.S_AXI_WREADY(s00_axi_wready),
|
|
.S_AXI_BRESP(s00_axi_bresp),
|
|
.S_AXI_BVALID(s00_axi_bvalid),
|
|
.S_AXI_BREADY(s00_axi_bready),
|
|
.S_AXI_ARADDR(s00_axi_araddr),
|
|
.S_AXI_ARPROT(s00_axi_arprot),
|
|
.S_AXI_ARVALID(s00_axi_arvalid),
|
|
.S_AXI_ARREADY(s00_axi_arready),
|
|
.S_AXI_RDATA(s00_axi_rdata),
|
|
.S_AXI_RRESP(s00_axi_rresp),
|
|
.S_AXI_RVALID(s00_axi_rvalid),
|
|
.S_AXI_RREADY(s00_axi_rready),
|
|
|
|
.SLV_REG0(slv_reg0),
|
|
.SLV_REG1(slv_reg1),
|
|
.SLV_REG2(slv_reg2),
|
|
.SLV_REG3(slv_reg3),
|
|
.SLV_REG4(slv_reg4), /*,
|
|
.SLV_REG5(slv_reg5),
|
|
.SLV_REG6(slv_reg6),
|
|
.SLV_REG7(slv_reg7),
|
|
.SLV_REG8(slv_reg8),
|
|
.SLV_REG9(slv_reg9),
|
|
.SLV_REG10(slv_reg10),
|
|
.SLV_REG11(slv_reg11),
|
|
.SLV_REG12(slv_reg12),
|
|
.SLV_REG13(slv_reg13),
|
|
.SLV_REG14(slv_reg14),
|
|
.SLV_REG15(slv_reg15),
|
|
.SLV_REG16(slv_reg16),
|
|
.SLV_REG17(slv_reg17),
|
|
.SLV_REG18(slv_reg18),
|
|
.SLV_REG19(slv_reg19),*/
|
|
.SLV_REG20(slv_reg20)/*
|
|
.SLV_REG21(slv_reg21),
|
|
.SLV_REG22(slv_reg22),
|
|
.SLV_REG23(slv_reg23),
|
|
.SLV_REG24(slv_reg24),
|
|
.SLV_REG25(slv_reg25),
|
|
.SLV_REG26(slv_reg26),
|
|
.SLV_REG27(slv_reg27),
|
|
.SLV_REG28(slv_reg28),
|
|
.SLV_REG29(slv_reg29),
|
|
.SLV_REG30(slv_reg30),
|
|
.SLV_REG31(slv_reg31)*/
|
|
);
|
|
|
|
endmodule
|