# COM-1831SOFT Burst mode Spread-Spectrum modem VHDL source code overview / IP core #### **Overview** The COM-1831SOFT is a burst-mode direct-sequence spread-spectrum modem for transmitting and receiving UDP data frames over a wireless or cable medium. It not only includes the DSSS modulation and demodulation functions, but also ancillary functions such as error correction, internet protocol stack and Ethernet MAC. The chip rates, symbol rates, spreading Gold code, and center frequency are fully programmable at run time. Several other generic parameters allow one to customize the code for the target application. Frame length, frequency acquisition range, acquisition threshold, preamble length, number of parallel code search circuits are all adjustable prior to code synthesis. The entire **VHDL** source code is deliverable. #### **Key features and performance:** - Burst mode operation: - Fixed-length data frames from/to LAN/UDP ports - Multiple frames transmitted efficiently with only 32-symbol separation. - Acquisition: 1600-symbol preamble with no apriori knowledge of arrival time - Large frequency acquisition range: ±(chip\_rate / 64) or (1.8\*symbol\_rate), whichever is smaller, with no apriori knowledge. - End-to-end latency: 2672 symbol / modulation symbol rate. For example 1.2ms at 2.5Msymbols/s. - Programmable chip rate, up to 79.5 Mchips/s (limited by FPGA technology XC7A100T-1) - 2047-chip Gold codes - Data rate practical range from chip\_rate/2047 to chip\_rate/30 - Built-in tools: PRBS-11 pseudo-random test sequence, BER tester, AWGN generator, and internal loop back mode. - Monitoring: - o Carrier frequency error - o SNR - o BER - Provided with IP core: - VHDL source code - VHDL test bench with PRBS11 sequence generator and bit error rate measurement. - o Java code to send UDP frames ## Target Hardware The code is written in generic standard VHDL so as to be ported to a variety of FPGAs. It was compiled and simulated using Xilinx Vivado v2015.2 tools. It was tested on Xilinx 7-series FPGA (Artix7-100T) # Configuration #### **Synthesis-time configuration parameters** The following constants are user-defined in the generic section of the encoder and decoder components prior to synthesis. These parameters generally define the size of the decoder embodiment. | Parameters | Configuration | |-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Tx payload length (in bits) MOD_PAYLOAD_LENGTH | Typically 512 bits (no FEC) or 1040 (with FEC), but can be changed as needed | | Rx payload length (in bits) DEMOD_PAYLOAD_ LENGTH | Typically 512 bits (no FEC) or 1040 (with FEC), but can be changed as needed | | 32-bit sync word | Baseline | | SYNC_WORD | 0x5A0FBE66 | | FEC encoder code selection ENC_CODE_SEL | Baseline K=9, rate ½ See COM-1510SOFT for the full range of convolutional FEC codes. | | FEC decoder code selection | Baseline | | DEC_CODE_SEL | K=9, rate ½ See COM-1510SOFT for the full range of convolutional FEC codes. | | Number of parallel code acquisition circuits NACQ = NMUX * NACQ_DIV | NACQ parallel circuits<br>accelerate the search for<br>the receiver code replica<br>to match the received<br>signal's.<br>Trade-off acquisition<br>time versus FPGA<br>occupancy. | | | Because of a timing constraint, these circuits are divided into NMUX groups of NACQ_DIV circuits. See comments within the burst_dsss_demod.vhd code regarding the timing constraints to select NMUX and NACQ_DIV | | Non-coherent integration & dump period N_NCID | Trade-off acquisition time versus threshold C/No | | First preamble extension FIRST_PREAMBLE_ | Modulator-inserted preamble length, | | EXTENSION | expressed in number of symbols. Baseline: 1600. The preamble must be long enough for the demodulator to acquire the burst prior to the payload field. Depends on NACQ, N_NCID and threshold C/No. | |------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Enable internal additive white Gaussian noise generation AWGN_EN | Generally not needed during operations. Useful during development testing as it eliminates the need for an external noise generator. | | BER tester measurement window BER CONTROL(2:0) | Baseline: 10,000 bits ("001") | #### **Run-time configuration parameters** The user can set and modify the following controls at run-time through the top-level component interface: | D 4 | C | |---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Parameters | Configuration | | Tx | | | Modulator<br>clock<br>frequency | CLK_TX_GEN_D,_M,_O The modulator clock CLK_TXg frequency must be programmable dynamically (see CLKGEN7_MMCM_DYNAMIC) for fine control of the chip rate. | | Chip rate | MOD_CHIP_RATE_NDIV | | | The modulator chip rate is in the form $\mathbf{f}_{\text{chip\_rate\_tx}} = \mathbf{f}_{\text{clk\_tx}} / 2^n$ where n ranges from 1 (2 samples per chip) to 15 (chip rate = $\mathbf{f}_{\text{clk\_tx}} / 32768$ ). | | Symbol rate | MOD_SYMBOL_RATE1 The I-channel symbol rate can be set independently of the spreading code period as f <sub>symbol rate</sub> * 2 <sup>32</sup> / f <sub>clk tx</sub> | | Spreading code | The I-channel Gold code is selected through the linear feedback shift register initialization. | | | MOD_LFSRA_INIT | | Output<br>center<br>frequency | MOD_CENTER_FREQ The modulated signal center frequency can be shifted in frequency | | | 32-bit signed integer (2's complement | | Output level Output level MOD_GAIN 16-bit amplitude scaling factor for the modulated signal. The maximum level should be adjusted to prevent saturation. The settings may vary slightly with the selected chip rate. Please check for saturation (see test points) when changing either the chip rate or the signal gain. RX CIC decimation factor CIC_R Receiver decimation factor from felk_ade to 4* fehip_rate_rx. Valid range 1 - 16384 Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as fehip_rate_rx * 2^32/ felk_ade. The maximum practical chip rate is felk_ade/2. The maximum allowed error between transmitted and received chip rate is +/-100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT RECEIVER_CENTER_FREQ The nominal center frequency is a fixed frequency offset applied to the input | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------------------------| | Output level MOD_GAIN 16-bit amplitude scaling factor for the modulated signal. The maximum level should be adjusted to prevent saturation. The settings may vary slightly with the selected chip rate. Please check for saturation (see test points) when changing either the chip rate or the signal gain. Rx | | | | 16-bit amplitude scaling factor for the modulated signal. The maximum level should be adjusted to prevent saturation. The settings may vary slightly with the selected chip rate. Please check for saturation (see test points) when changing either the chip rate or the signal gain. Rx | | | | In the maximum level should be adjusted to prevent saturation. The settings may vary slightly with the selected chip rate. Please check for saturation (see test points) when changing either the chip rate or the signal gain. RX CIC decimation factor CIC_R Receiver decimation factor from f <sub>clk_ade</sub> to 4* f <sub>chip_rate_rx</sub> . Valid range 1 - 16384 Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as f <sub>chip_rate_rx</sub> * 2 <sup>32</sup> / f <sub>clk_ade</sub> . The maximum practical chip rate is f <sub>clk_ade</sub> /2. The maximum allowed error between transmitted and received chip rate is +/-100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f <sub>symbol_rate_i</sub> * 2 <sup>32</sup> / f <sub>clk_ade</sub> The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center The nominal center frequency is a fixed | Output level | MOD_GAIN | | modulated signal. The maximum level should be adjusted to prevent saturation. The settings may vary slightly with the selected chip rate. Please check for saturation (see test points) when changing either the chip rate or the signal gain. Rx CIC decimation factor CIC_R Receiver decimation factor from f <sub>clk_ade</sub> to 4* f <sub>chip_rate_rx</sub> . Valid range 1 - 16384 Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as f <sub>chip_rate_rx</sub> * 2 <sup>32</sup> / f <sub>clk_ade</sub> . The maximum practical chip rate is f <sub>clk_ade</sub> /2. The maximum allowed error between transmitted and received chip rate is +/-100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f <sub>symbol_rate_i</sub> * 2 <sup>32</sup> / f <sub>clk_ade</sub> The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | 16-bit amplitude scaling factor for the | | The maximum level should be adjusted to prevent saturation. The settings may vary slightly with the selected chip rate. Please check for saturation (see test points) when changing either the chip rate or the signal gain. Rx CIC decimation factor CIC_R Receiver decimation factor from f <sub>clk_ade</sub> to 4* f <sub>chip_rate_rx</sub> . Valid range 1 - 16384 Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as f <sub>chip_rate_rx</sub> * 2 <sup>32</sup> / f <sub>clk_ade</sub> . The maximum practical chip rate is f <sub>clk_ade</sub> /2. The maximum allowed error between transmitted and received chip rate is +/-100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f <sub>symbol_rate_i</sub> * 2 <sup>32</sup> / f <sub>clk_ade</sub> The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center TRECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | 1 0 | | prevent saturation. The settings may vary slightly with the selected chip rate. Please check for saturation (see test points) when changing either the chip rate or the signal gain. RX CIC decimation factor NOMINAL CHIP RATE 32-bit integer expressed as fehip_rate_rx * 2 <sup>32</sup> / felk_ade. The maximum practical chip rate is felk_ade /2. The maximum allowed error between transmitted and received chip rate is +/-100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as fsymbol_rate_i * 2 <sup>32</sup> / felk_ade The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | | | slightly with the selected chip rate. Please check for saturation (see test points) when changing either the chip rate or the signal gain. RX CIC decimation factor Nominal chip rate channel symbol rate, defined as fsymbol rate is 232 / fclk adc Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | 1 | | check for saturation (see test points) when changing either the chip rate or the signal gain. RX CIC decimation factor CIC_R Receiver decimation factor from f <sub>clk_ade</sub> to 4* f <sub>chip_rate_rx</sub> . Valid range 1 - 16384 Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as f <sub>chip_rate_rx</sub> * 2 <sup>32</sup> / f <sub>clk_ade</sub> . The maximum practical chip rate is f <sub>clk_ade</sub> /2. The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f <sub>symbol rate</sub> i * 2 <sup>32</sup> / f <sub>clk ade</sub> Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | | | when changing either the chip rate or the signal gain. RX CIC decimation factor Receiver decimation factor from f <sub>clk_adc</sub> to 4* f <sub>chip_rate_rx</sub> . Valid range 1 - 16384 Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as f <sub>chip_rate_rx</sub> * 2³² / f <sub>clk_adc</sub> . The maximum practical chip rate is f <sub>clk_adc</sub> /2. The maximum allowed error between transmitted and received chip rate is +/-100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f <sub>symbol rate</sub> i * 2³² / f <sub>clk adc</sub> Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | | | CIC decimation factor factor CIC_R Receiver decimation factor from felk_ade to 4* fehip_rate_rx. Valid range 1 - 16384 Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as fehip_rate_rx * 2^32 / felk_ade. The maximum practical chip rate is felk_ade /2. The maximum allowed error between transmitted and received chip rate is +/-100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as fsymbol rate i * 2^32 / felk_ade Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | | | CIC decimation factor CIC_R Receiver decimation factor from felk_adc to 4* fehip_rate_rx. Valid range 1 - 16384 | | | | CIC decimation factor CIC_R Receiver decimation factor from f <sub>clk_adc</sub> to 4* f <sub>chip_rate_rx</sub> . Valid range 1 - 16384 Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as f <sub>chip_rate_rx</sub> * 2 <sup>32</sup> / f <sub>clk_adc</sub> . The maximum practical chip rate is f <sub>clk_adc</sub> /2. The maximum allowed error between transmitted and received chip rate is +/-100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f <sub>symbol_rate_i</sub> * 2 <sup>32</sup> / f <sub>clk_adc</sub> The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | Rv | orgina Sama | | Receiver decimation factor from felk_adc to 4* fehip_rate_rx. Valid range 1 - 16384 Nominal chip rate NomINAL_CHIP_RATE 32-bit integer expressed as fehip_rate_rx * 2^{32} / felk_adc. The maximum practical chip rate is felk_adc /2. The maximum allowed error between transmitted and received chip rate is +/-100ppm. Symbol rate NomINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as fsymbol rate i * 2^{32} / felk_adc The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | CIC P | | Nominal chip rate Nominal chip rate Nominal chip rate Nominal chip rate Nominal chip rate Nominal chip rate 32-bit integer expressed as fehip_rate_rx * 2^{32} / felk_ade. The maximum practical chip rate is felk_ade /2. The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate Nominal I-channel symbol rate, defined as fsymbol rate i * 2^{32} / felk_ade Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | _ | | Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as fchip_rate_rx * 2 <sup>32</sup> / fclk_adc. The maximum practical chip rate is fclk_adc /2. The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as fsymbol rate i * 2 <sup>32</sup> / fclk adc Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | | | Nominal chip rate NOMINAL_CHIP_RATE 32-bit integer expressed as fchip_rate_rx * 2 <sup>32</sup> / fclk_adc. The maximum practical chip rate is fclk_adc /2. The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as fsymbol rate i * 2 <sup>32</sup> / fclk_adc Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | factor | Valid range 1 - 16384 | | chip rate 32-bit integer expressed as f_chip_rate_rx * 2^{32} / f_clk_adc. The maximum practical chip rate is f_clk_adc /2. The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f_symbol_rate_i * 2^{32} / f_clk_adc Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | vand lange 1 - 10304 | | chip rate 32-bit integer expressed as f_chip_rate_rx * 2^{32} / f_clk_adc. The maximum practical chip rate is f_clk_adc /2. The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f_symbol_rate_i * 2^{32} / f_clk_adc Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | | | The maximum practical chip rate is felk_ade. The maximum practical chip rate is felk_ade /2. The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as fsymbol rate i * 2 <sup>32</sup> / felk_ade Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | | | The maximum practical chip rate is f <sub>clk_adc</sub> /2. The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f <sub>symbol rate i</sub> * 2 <sup>32</sup> / f <sub>clk adc</sub> Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | chip rate | | | The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as fsymbol rate i * 2 <sup>32</sup> / fclk adc Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | | | The maximum allowed error between transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as fsymbol rate i * 2 <sup>32</sup> / felk ade Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center RECEIVER_CENTER_FREQ The nominal center frequency is a fixed | | 1 1 | | transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f <sub>symbol rate i</sub> * 2 <sup>32</sup> / f <sub>clk adc</sub> Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center The nominal center frequency is a fixed | | /2. | | transmitted and received chip rate is +/- 100ppm. Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f <sub>symbol rate i</sub> * 2 <sup>32</sup> / f <sub>clk adc</sub> Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center The nominal center frequency is a fixed | | The maximum allowed error between | | Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as f_symbol rate i * 2 <sup>32</sup> / f_clk adc Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center The nominal center frequency is a fixed | | | | Symbol rate NOMINAL_SYMBOL_RATE1 Nominal I-channel symbol rate, defined as fsymbol_rate_i * 2 <sup>32</sup> / felk_ade Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center Nominal input center The nominal center frequency is a fixed | | · • | | Nominal I-channel symbol rate, defined as f_symbol rate i * 2 <sup>32</sup> / f_clk adc | Symbol rate | | | as f <sub>symbol rate i</sub> * 2 <sup>32</sup> / f <sub>clk adc</sub> Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center The nominal center frequency is a fixed | - 5 51 1 | | | Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center The nominal center frequency is a fixed | | · · · · · · · · · · · · · · · · · · · | | Spreading code The I-channel Gold code is selected through the linear feedback shift register initialization. LFSRA_INIT Nominal input center The nominal center frequency is a fixed | | 1 42 | | through the linear feedback shift register initialization. LFSRA_INIT Nominal input center The nominal center frequency is a fixed | Spreading | | | initialization. LFSRA_INIT Nominal input center The nominal center frequency is a fixed | | | | Nominal input center The nominal center frequency is a fixed | | - | | Nominal input center The nominal center frequency is a fixed | | LFSRA INIT | | input center The nominal center frequency is a fixed | Nominal | | | input center | | | | | Impair contor | frequency offset applied to the input | | frequency | samples. It is used for fine frequency corrections, for example to correct clock drifts. 32-bit signed integer (2's complement representation) expressed as \$f_c * 2^{32} / f_{clk, adc}\$ | |-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Loopback<br>mode | LOOPBACK_MODE Binary flag to connect the modulated output (possibly including noise and frequency offset) to the receiver input within the FPGA. | | Receiver<br>AGC<br>response | RECEIVER_AGC_RESPONSE Users can to optimize AGC response time while avoiding instabilities (depends on external factors such as gain signal filtering at the RF front-end and chip rate). The AGC_DAC gain control signal is updated as follows 0 = every chip, 1 = every 2 input chips, 2 = every 4 input chips, 3 = every 8 input chips, etc 10 = every 1000 input chips. Valid range 0 to 14. | # Operation See <a href="https://www.comblock.com/download/com1831.pdf">www.comblock.com/download/com1831.pdf</a> [1] or <a href="https://www.comblock.com/download/com1931.pdf">www.comblock.com/download/com1931.pdf</a> [5] for a detailed description of the modem operation. #### Limitations 1. The spreading factor (chip rate / symbol rate) must be in the range 30 to 2047 Functional block diagram # Software Licensing The COM-1831SOFT is supplied under the following key licensing terms: - 1. A nonexclusive, nontransferable license to use the VHDL source code internally, and - 2. An unlimited, royalty-free, nonexclusive transferable license to make and use products incorporating the licensed materials, solely in bitstream format, on a worldwide basis. The complete VHDL/IP Software License Agreement can be downloaded from http://www.comblock.com/download/softwarelicense.pdf # **Configuration Management** The current software revision is 1. | Directory | Contents | |-----------|-------------------------------------------------------| | /doc | Specifications, user manual, implementation documents | | /src | .vhd source code. One component per file. | | /sim | Test benches | | /bin | .bit files | | /java | Java source code to send UDP frames | Key files: Xilinx Vivado project file: /project1/project\_1.xpr # VHDL development environment The VHDL software was developed using the following development environment for VHDL synthesis and VHDL simulation. (a) Xilinx Vivado 2015.2 The size is compatible with the free Xilinx WebPack tools. ## Ready-to-use Hardware The COM-1831SOFT was developed on, and therefore ready to use on the following commercial off-the-shelf hardware platform: | FPGA development platform | | |--------------------------------------------------------------------------|--| | COM-1800 FPGA Artix7-100T + GbE + DDR3 socket + ARM development platform | | | COM-1931 L/S-band transceiver | | | Analog | | | COM-3504 Dual Analog <-> Digital Conversions | | | COM-3506 [400 MHz – 3GHz] RF transceiver | | ## **Device Utilization Summary** The implementation size depends essentially on two key user-defined parameters in the generic section of the demodulator, namely: - The number of parallel code acquisition circuits NACQ - The FEC code constraint length K selected through the DEC\_CODE\_SEL parameter (K=9 is the largest implementation) Device: Xilinx Artix7-100T NACQ = 48, K = 9 convolutional codec, 160 MHz ADC clock, 80-160 MHz DAC clock Xilinx Artix 160 MHz 160 MHz 7 Spartan-1 No Xilinx-specific code MHz FPGA families are listed below: Device family 7 -2 Xilinx Kintex The VHDL source code is written in generic VHDL. No Xilinx CORE is used. No Xilinx primitive need to be used. Dual-port RAM blocks Typical maximum clock frequencies for various CLK TXg 250 - 300 MHz CLK P 125 MHz 125 MHz **CLK ADCg** 250 - 300 # are inferred. #### Clock and decoding speed The design uses three different clocks, all locked onto either a 10 MHz or a 19.2 MHz external frequency reference, as selected by the **OPTION** generic parameter. Other frequency references can also be used by changing the CLK GEN MMCM ADJ.vhd multiply, divide and period parameters. **CLK ADCg**: Fixed frequency analog-to-digital converter sampling clock. Drives the external ADCs. Controls the maximum receive chip rate. **CLK TXg**: Dynamically programmable DAC sampling clock. Used for fine control of the chip rate. Drives the external DACs. Controls the maximum transmit chip rate. **CLK P**: 125 MHz processing clock used for gigabit Ethernet interface, FEC encoder, and FEC decoder. There is no advantage in increasing this clock frequency beyond 125 MHz. #### VHDL components overview #### Top level The code is stored with one, and only one, entity per file as shown above. COM1831\_TOP.vhd is the top level. It includes several other ComBlock components such as the COM-1510SOFT burst FEC encoder and decoder, the COM-5402SOFT IP stack and the COM-5401SOFT tri-mode Ethernet MAC. LFSR11.vhd: pseudo random binary sequence generator PRBS-11. Generates a PRBS11 test sequence at the modulator input. The PRBS11 sequence is recognized by the BER2 bit error rate tester at the receiving end to measure the link quality. Disabled during normal operation. ENCODER\_GMR\_3G.vhd is the block convolutional encoder. It supports zero-tail insertion mechanism. The data source sends a complete frame, as delineated by the SOF\_IN and EOF\_IN flags. Once a complete input frame is received, the encoder will generate a complete encoded output frame. Thus, the encoding latency is one input frame duration. CROSS\_CLK\_DOMAINS\_NODATALOSS.vhd preserves the signal integrity while crossing clock domains (from the general processing clock domain CLK\_P to the digital modulator clock domain CLK\_TXg for example). BURST\_DSSS\_MODULATOR.vhd implements the digital modulation and spectrum shaping. Key controls include chip rate, modulation symbol rate, output signal amplitude, spreading code. AWGN.vhd implements the optional additive white Gaussian noise by generating complex (I,Q) independent Gaussian random samples once every CLK\_TXg clock period. Instantiation is controlled by the generic flag AWGN EN. RECEIVER1.vhd is the front-end digital receiver which processes digital samples from the A/D converter(s). Its functions include fixed frequency translation to (near-zero) baseband, AGC, variable decimation (CIC) filters and one half-band filter for image rejection. Input digital samples can be complex (in the case of baseband input samples) or real (in the case of IF undersampling). BURST\_DSSS\_DEMOD.vhd is the heart of the demodulator. It conducts parallel search of the spreading code during acquisition. Once the code is locked, an internal 2048-point FFT computes the frequency error. Once corrected for frequency error, the received signal is fed into carrier and symbol timing tracking loops for coherent demodulation. A matched filter detects the presence of the sync word marking the start of the fixed-length data field. VITERBI\_DECODER\_GMR\_3G.vhd is the block FEC decoder top component in this hierarchical design. It includes state machines to handle tail-biting and zero tail when applicable. *BER2.vhd* synchronizes with the received bit stream and counts the number of bit error when a PRBS-11 sequence is being transmitted. COM5401.vhd implements the 10/100/1000 Ethernet MAC functions. It is designed to interface with an external Gigabit Ethernet PHY integrated circuit via a standard RGMII or GMII interface. The default interface is RGMII. [2] COM5402.vhd implements the higher-level IP protocols, namely ARP, PING, TCP server, UDP (unicast and multicast), IGMP. [3] SIM2OUTFILE.vhd writes three 12-bit data variables to a tab delimited file which can be subsequently read by Matlab (load command) for plotting or analysis. #### Test environment tbcom1831.vhd in the /sim directory is a test bench consisting of a back-to-back PRBS-11 pseudorandom sequence generator, convolutional encoder, modulator, additive white Gaussian noise, demodulator, Viterbi decoder and bit error rate tester. No stimulus file is needed. #### Reference documents [1] <u>COM-1831</u> Burst mode DSSS modem 80 Mchip/s, specifications for the ready-to-use hardware module. [2] COM-5401SOFT Tri-mode 10/100/1000 Ethernet MAC, VHDL source code overview www.comblock.com/download/com5401soft.pdf [3] COM-5402SOFT IP/TCP/UDP/ARP/PING STACK for GbE VHDL source code overview www.comblock.com/download/com5402soft.pdf [4] COM-1510SOFT Block-mode convolutional FEC codec VHDL source code overview www.comblock.com/download/com1510soft.pdf [5] COM-1931 L/S-band burst-mode spreadspectrum transceiver www.comblock.com/com1931.html ## **ComBlock Ordering Information** COM-1831SOFT BURST MODE SPREAD-SPECTRUM MODEM, VHDL SOURCE CODE / IP CORE ECCN: 5E001.b.4 #### Contact Information MSS • 845-N Quince Orchard Boulevard • Gaithersburg, Maryland 20878-1676 • U.S.A. Telephone: (240) 631-1111 Facsimile: (240) 631-1676 E-mail: info@comblock.com