diff options
author | Jonathon Pendlum <jonathon.pendlum@ettus.com> | 2022-02-10 02:48:17 -0500 |
---|---|---|
committer | Wade Fife <wade.fife@ettus.com> | 2022-02-10 18:11:41 -0700 |
commit | 8444f84add04f025b7e24855e0ba79446e615e01 (patch) | |
tree | be0082e9d059ba7e816048a06a0cb5737018065a /fpga/usrp3/lib/rfnoc/blocks | |
parent | cdcd39aeb508298e28e8a2a89db5ab9fefd70435 (diff) | |
download | uhd-8444f84add04f025b7e24855e0ba79446e615e01.tar.gz uhd-8444f84add04f025b7e24855e0ba79446e615e01.tar.bz2 uhd-8444f84add04f025b7e24855e0ba79446e615e01.zip |
fpga: rfnoc: Add BLANK_OUTPUT to FIR filter block's parameters
Diffstat (limited to 'fpga/usrp3/lib/rfnoc/blocks')
-rw-r--r-- | fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_block_fir_filter.v | 15 | ||||
-rw-r--r-- | fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_fir_filter_core.v | 14 |
2 files changed, 19 insertions, 10 deletions
diff --git a/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_block_fir_filter.v b/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_block_fir_filter.v index 346de8567..f05c05df1 100644 --- a/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_block_fir_filter.v +++ b/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_block_fir_filter.v @@ -13,11 +13,11 @@ // that are always set to zero, and using internal DSP slice registers to // hold coefficients. // -// For the most efficient DSP slice inference use these settings, set +// For the most efficient DSP slice inference use these settings, set // COEFF_WIDTH to be less than 18. // // Parameters: -// +// // COEFF_WIDTH : Coefficient width // // NUM_COEFFS : Number of coefficients / filter taps @@ -29,6 +29,9 @@ // RELOADABLE_COEFFS : Enable (1) or disable (0) reloading // coefficients at runtime // +// BLANK_OUTPUT : Disable (1) or enable (0) output when initially +// filling internal pipeline +// // SYMMETRIC_COEFFS : Reduce multiplier usage by approximately half // if coefficients are symmetric // @@ -41,7 +44,7 @@ // streaming will cause temporary output // corruption! // -// Note: If using USE_EMBEDDED_REGS_COEFFS, coefficients must be written at +// Note: If using USE_EMBEDDED_REGS_COEFFS, coefficients must be written at // least once since COEFFS_VEC is ignored! // @@ -56,11 +59,12 @@ module rfnoc_block_fir_filter #( parameter COEFF_WIDTH = 16, parameter NUM_COEFFS = 41, parameter [NUM_COEFFS*COEFF_WIDTH-1:0] COEFFS_VEC = // Make impulse by default - { + { {1'b0, {(COEFF_WIDTH-1){1'b1}} }, // Max positive value {(COEFF_WIDTH*(NUM_COEFFS-1)){1'b0}} // Zero for remaining coefficients }, parameter RELOADABLE_COEFFS = 1, + parameter BLANK_OUTPUT = 1, parameter SYMMETRIC_COEFFS = 0, parameter SKIP_ZERO_COEFFS = 0, parameter USE_EMBEDDED_REGS_COEFFS = 1 @@ -161,7 +165,7 @@ module rfnoc_block_fir_filter #( ) noc_shell_fir_filter_i ( .rfnoc_chdr_clk (rfnoc_chdr_clk), .rfnoc_ctrl_clk (rfnoc_ctrl_clk), - .ce_clk (ce_clk), + .ce_clk (ce_clk), .rfnoc_chdr_rst (), .rfnoc_ctrl_rst (), .ce_rst (ce_rst), @@ -280,6 +284,7 @@ module rfnoc_block_fir_filter #( .NUM_COEFFS (NUM_COEFFS), .COEFFS_VEC (COEFFS_VEC), .RELOADABLE_COEFFS (RELOADABLE_COEFFS), + .BLANK_OUTPUT (BLANK_OUTPUT), .SYMMETRIC_COEFFS (SYMMETRIC_COEFFS), .SKIP_ZERO_COEFFS (SKIP_ZERO_COEFFS), .USE_EMBEDDED_REGS_COEFFS (USE_EMBEDDED_REGS_COEFFS) diff --git a/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_fir_filter_core.v b/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_fir_filter_core.v index 774f43761..60303e6fa 100644 --- a/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_fir_filter_core.v +++ b/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_fir_filter/rfnoc_fir_filter_core.v @@ -17,7 +17,7 @@ // // BASE_ADDR : Control port base address to which this block // responds. -// +// // COEFF_WIDTH : Coefficient width // // NUM_COEFFS : Number of coefficients / filter taps @@ -29,6 +29,9 @@ // RELOADABLE_COEFFS : Enable (1) or disable (0) reloading // coefficients at runtime // +// BLANK_OUTPUT : Disable (1) or enable (0) output when initially +// filling internal pipeline +// // SYMMETRIC_COEFFS : Reduce multiplier usage by approximately half // if coefficients are symmetric // @@ -41,7 +44,7 @@ // streaming will cause temporary output // corruption! // -// Note: If using USE_EMBEDDED_REGS_COEFFS, coefficients must be written at +// Note: If using USE_EMBEDDED_REGS_COEFFS, coefficients must be written at // least once since COEFFS_VEC is ignored! @@ -53,11 +56,12 @@ module rfnoc_fir_filter_core #( parameter COEFF_WIDTH = 16, parameter NUM_COEFFS = 41, parameter [NUM_COEFFS*COEFF_WIDTH-1:0] COEFFS_VEC = // Make impulse by default - { + { {1'b0, {(COEFF_WIDTH-1){1'b1}} }, // Max positive value {(COEFF_WIDTH*(NUM_COEFFS-1)){1'b0}} // Zero for remaining coefficients }, parameter RELOADABLE_COEFFS = 1, + parameter BLANK_OUTPUT = 1, parameter SYMMETRIC_COEFFS = 0, parameter SKIP_ZERO_COEFFS = 0, parameter USE_EMBEDDED_REGS_COEFFS = 1 @@ -171,7 +175,7 @@ module rfnoc_fir_filter_core #( .NUM_COEFFS (NUM_COEFFS), .COEFFS_VEC (COEFFS_VEC), .RELOADABLE_COEFFS (RELOADABLE_COEFFS), - .BLANK_OUTPUT (1), + .BLANK_OUTPUT (BLANK_OUTPUT), // Optional optimizations .SYMMETRIC_COEFFS (SYMMETRIC_COEFFS), .SKIP_ZERO_COEFFS (SKIP_ZERO_COEFFS), @@ -202,7 +206,7 @@ module rfnoc_fir_filter_core #( .NUM_COEFFS (NUM_COEFFS), .COEFFS_VEC (COEFFS_VEC), .RELOADABLE_COEFFS (RELOADABLE_COEFFS), - .BLANK_OUTPUT (1), + .BLANK_OUTPUT (BLANK_OUTPUT), // Optional optimizations .SYMMETRIC_COEFFS (SYMMETRIC_COEFFS), .SKIP_ZERO_COEFFS (SKIP_ZERO_COEFFS), |