# Com Block

# COM-8003SOFT SIGNAL DIVERSITY COMBINING VHDL SOURCE CODE OVERVIEW

## Overview

The COM-8003 ComBlock Module comprises two pieces of software:

- VHDL code to run within the FPGA for all signal processing functions.
- C/Assembly code running within the Atmel ATMega8515L microprocessor for non application-specific monitoring and control functions.

The VHDL code interfaces to the monitoring and control functions by exchanging byte-wide registers on the Atmel microcontroller 8-bit data bus. The control and monitoring registers are defined in the specifications [1].

The Atmel microprocessor code is generic (i.e. non application specific), not user-programmable and functionally transparent to the user. It is thus not described here.

The COM-8003 VHDL code runs on the generic COM-8000 hardware platform. The schematics [2] for this platform are available in this CD.

## Reference documents

[1] specifications: com8003.pdf

[2] hardware schematics: com\_8000schematics.pdf

[3] VHDL source code in directory com-8003\_001\src

[4] Xilinx ISE project files com-8003\_001\com-8003\_ISE41.npl com-8003\_001\com-8003\_ISE63.npl

[5] .ucf constraint files com-8003\_001\src\com8003.ucf [6] .mcs FPGA bit files 8003\_001\com8003\_001.mcs

# **Configuration Management**

The current software revision is 1.

## **Configuration Options**

No option currently supported.

## VHDL development environment

The VHDL software was developed using two development environments:

- (a) Xilinx ISE 4.1 with Synopsys FPGA Express 3.6 as synthesis tool.
- (b) Xilinx ISE 6.3 with XST as synthesis tool.

# Target FPGA

The VHDL code was synthesized for the Xilinx Spartan-IIE XC2S300E-6PQ208 FPGA.

## Xilinx-specific code

The VHDL source code was written in generic VHDL with few Xilinx primitives. No Xilinx CORE is used. The Xilinx primitives are:

- BUFG
- IBUFG

## VHDL software hierarchy



The code is stored with one, and only one, entity per file as shown above.

The root program (highlighted) is com8003.vhd.

The hierarchical nature of the VHDL code reflects the block diagram below:

- com8003 is the root program which includes the input bus driver, the signal diversity combining in combiner and ancillary functions such as monitoring and control functions (interface with microprocessor).
- The *combiner* entity encapsulates most of the signal diversity combining functions, namely frame and superframe synchronization recovery in *sof\_sync*, input elastic buffering, SDRAM access contention, SDRAM read and write transactions in *sdram\_controller\_basic*, signals quality estimation and final combining.
- The *sof\_sync* entity detects frame and superframe synchronization using a 32-bit matched filter to detect the presence of unique words, confirms receiver lock by verifying the periodic nature of the 32-bit unique word, corrects for coherent BPSK/QPSK phase ambiguities and

measures the BER from the unique word. Each frame consists of 4096 bits of data preceded by the 32-bit unique word 0x5A OF BE 66. The superframe length is userdefined. It is an integer number of frames. The superframe unique word is the inverted version of the regular frame unique word.

- The *matched\_filter32* entity detects the 32bit unique word 0x5A0FBE66 in the input serial data stream through correlation. It also detect the unique word subject to 90deg,180deg,270deg phase ambiguity in a coherent BPSK/QPSK demodulator with gray encoding for the phase (see COM-1001 specifications). The detection threshold for the matched filter is set at approximately 10% bit errors (it tolerates 3 bit errors out of 32).
- The *sof\_track* entity is a confirmation circuit for frame synchronization which eliminates false detections and missed detections at the matched filter. Periodic start of frame (SOF) pulses are generated reliably, even in the event of missed detection at the matched filter, in essence a kind of fly-wheel. *Sof\_track* also generates a lock status based on the degree of confidence in detecting SOFs. The lock status is one of several input signal quality measurements to help with the subsequent combining algorithm.
- The *ber\_measurement2* entity measures the bit error rate based on the periodic and known 32-bit unique words. The bit error rate is counted over 1024 bits. The BER is one of several input signal quality measurements to help with the subsequent combining algorithm.
- The *sdram\_controller\_basic* entity is the driver for the external 256MB SDRAM. It manages the SDRAM initialization, the periodic refresh cycles and random access read and write cycles.



COM-8003 Software Functional Block Diagram

## Implementation

#### Overview

Signal diversity combining is a technique whereby a signal is transmitted over several media (satellite links for example) to improve the quality of service. The signal diversity combiner processes these input replicas by removing the differential delay at the receiver and summing the signals to yield the best signal to noise ratio.

Thus, the signal diversity combiner comprises three distinct circuits:

- (a) a synchronization circuit, whereby the start of frame and start of superframe are detected for each input signal.
- (b) An elastic buffer, whereby the differential delay among the various replica is removed.
- (c) An intelligent combiner, whereby the synchronized replica are summed with adaptively controlled coefficients for maximum output SNR.

#### **Synchronization Detection**

#### **Elastic Buffering**

Elastic buffering is used to re-align in time all the signal replicas after they experience differential delays during propagation and at the transmitter.



A single synchronous DRAM (SDRAM) module is shared among all signals. The 256 MB SDRAM module is partitioned in eight sections, to implement elastic buffering for each one of the eight input signals. Each section is sized so as to contain at least two superframes as shown below:

3



Each signal is formatted with a short (4096-bit) frame and a longer superframe. As the role of the superframe is to eliminate any time ambiguity occurring during propagation, the superframe size is selected as the smallest number of frames strictly greater than 2\*(maximum differential propagation delay among replicas). By consequence, the superframe size depends on the data rate. Example:

- Data rate: 5 Kbps
- Maximum differential propagation delay among replicas: 4ms (12,000 km/c)
- Equivalent number of bits in differential delay: 20 bits
- Minimum superframe size = 1 frame = 4096 bits

There are, however, operational cases whereby a signal is purposely transmitted n superframes earlier than the other replicas. This method can be used to provided time diversity in a broadcast network for example. In such a case, the SDRAM section for a given signal can be increased from 2 to n+2.



Each section comprises a write pointer wptr<sub>i</sub> and a read pointer rptr<sub>i</sub>.



During normal operation, the write pointer is slightly ahead of the read pointer.

The goal of the elastic buffer algorithm is to realign several streams in time. The algorithm is expected to be resilient to outside events such as intermittent receiver lock on one or several signals, blocking (all input signals disappear), drifting bit clocks and Doppler. The emphasis is on avoiding catastrophic failures while keeping the algorithm simple to implement and comprehend. No special effort is made here to assess the integrity of a given signal (this is for the follow-on combiner to decide). Instead, the emphasis in on maintaining the integrity of the read and write pointers only.

The data written to the SDRAM consists of the demodulated bit together with qualifiers such as bit quality (4-bit soft quantization), receiver lock status (SOF\_LOCKx), start of superframe flag (SOSFx) and bit error rate summary BERx. The occupied space is thus 8 bits for each demodulated bit. The main objective is to keep demodulated bit and quality information together so that they are subject to the same delay through the SDRAM.

The frame synchronization sequence (unique word) is stripped off the data stream prior to writing to the SDRAM. Therefore, the occupied space for a frame is (4096 bits/frame) \* (8bits/sample) / (64-bit SDRAM word) = 512 SDRAM words.

#### Write pointer management algorithm

#### Let us denote:

*start\_address*<sub>i</sub> = lowest memory address in the sector reserved for signal i. This address is always a multiple of superframe sizes and always in the form  $n * sf\_size *4096$ , where 4096 is the number of bits in a frame,  $sf\_size$  is the number of frames in a superframe, and n is an integer. For ease of computing modulo operations,  $sf\_size$  is restricted to the authorized values of 2,4,8,16,32,64,128 and n is selected to be a power of 2.

#### Let us denote

*buffer\_size*<sub>i</sub> = the elastic buffer size for signal i.

The rules governing the write pointer for each signal i are as follows:

- definition: the write pointer indicates the next location to be written.
- In general. the write pointer is incremented after writing an incoming sample, even if the receiver does not clearly indicate lock. This means that all write pointers move independently of each others. In particular, the sampling clock frequency for each signal is distinct. The write pointer is incremented circularly in the range
   [start\_addressi, start\_addressi + buffer\_sizei[
- Exception 1: "superframe is out of synchronization":

   if a start of superframe is received while the write pointer points to a memory location inconsistent with a start of superframe location (i.e. not a multiple of *sf\_size*\*4096 samples), the write pointer is reset to *start\_address<sub>i</sub>*, the first address in the sector.
- Exception 2: "frame is out of synchronization": if a start of frame is received while the

write pointer points to a memory location inconsistent with a start of frame location (i.e. not a multiple of 4096 samples), the write pointer is moved to the nearest SOF location. This exception is to take care of short loss of receiver lock (a few seconds) causing the bit clock to drift by a few bits. Particularly important if the receiver bit timing loop is a first order loop.

#### Read pointer management algorithm

Let us decompose the read pointer into an upper address *rptr\_superframe* representing an integer number of superframes and a lower address *rptr\_bits* representing the bits within a superframe. *rptr\_i = rptr\_superframe<sub>i</sub>* \* *sf\_size* \* 4096 + *rptr\_bits<sub>i</sub> + start\_address<sub>i</sub>* 

Let us denote  $sf_offset_i$  the fixed delay required at reception of signal i, expressed in number of samples This fixed and known delay is to compensate for the differential delay implemented at the transmitter in time-diversity systems. This delay is always a multiple number of superframes.

The rules governing the read pointer management for each signal i are as follows:

- definition: the read pointer indicates the next location to be read from.
- A single read clock, common to all signals, is used to move all read pointers. The read clock frequency is set slightly above (101%) the nominal data rate, to accommodate for local variations of crystal frequencies.
- In general, all active signals are read once per read clock period. The read pointers are incremented after reading. The read pointers are incremented circularly in the range [*start\_address<sub>i</sub>*, *start\_address<sub>i+I</sub>*]. As all read pointers are incremented simultaneously, their lower addresses *rptr\_bits<sub>i</sub>* are identical.
- Exception 1: "flow control check". The read pointer is incremented at the read clock if and only if all qualified elastic buffers contain at least 1 sample to be read. By 'qualified', we mean that

(a) the receiver lock status for signal i
(which can be checked by reading ahead the sample) indicates lock, and
(b) the alignment between read and write pointer is consistent with the desired superframe delay *sf\_offset<sub>i</sub>* (see exception 2 below).

The number of samples ready to be read is computed as:

 $(wptr_i - rptr_i - sf_offset_i)$ modulo  $buffer_size_i$ 

 Exception 2: superframe realignment. The elastic buffer algorithm will ensure that the delay between read and write pointer is consistent with the desired superframe delay *sf\_offset<sub>i</sub>*. The delay (*wptr<sub>i</sub> - rptr<sub>i</sub>*) modulo *buffer\_size<sub>i</sub>* must be within the window
 [*sf\_offset<sub>i</sub>*, *sf\_offset<sub>i</sub>* + ½ *sf\_size* \*4096]. In other words, the minimum delay is sf\_offset, and the maximum delay sf\_offset + ½ a superframe.

If this condition is not met, two cases can occur:

(a) It is correctable: the delay (*wptr<sub>i</sub>* – *rptr<sub>i</sub>*)modulo (*sf\_size* \*4096) is within the window  $[0, \frac{1}{2} sf_size$  \*4096]. the elastic buffer algorithm will adjust the upper address *rptr\_superframe* so that the delay between read and write pointer is consistent with the desired superframe delay.

(b) It is not correctable: the delay (*wptr<sub>i</sub>* – *rptr<sub>i</sub>*)modulo (*sf\_size* \*4096) is outside the window  $[0, \frac{1}{2} sf_size$  \*4096]. In this case, the elastic buffer is disqualified (see exception 1 above). No read pointer adjustment is implemented other than the regular increment.

#### **SDRAM Controller**

The code is written for interfacing with a generic 256MB SDRAM SODIMM memory module. A set of specifications can be obtained from Micron (MT48LC16M16A2 – 4 MEG X 16 X 4 BANKS). The clock provided to the SDRAM is 40 MHz, well below the specified maximum for PC100/PC133 SDRAMs. The read and write pointers representing SDRAM addresses are written with 27-bit precision

so as to allow easy extension to 1GB SDRAM memory modules if needed.

In order to minimize the number of FPGA flip-flops used for serial to parallel conversions, a basic SDRAM write transaction deals with a single 64-bit word. Burst mode, although conducive to a higher SDRAM throughput, is not used because of the extra FPGA resources required.

In addition to the read, and write operations, the *sdram\_controller\_basic* entity takes care of the initial SDRAM initialization, of periodic auto refresh and of the contention avoidance mechanism between the asynchronous read/write transactions and the auto refresh transaction.

## Signal Quality Criteria

In order to assist the combiner in selecting the best combinations of input signals, multiple signal quality measurements are performed throughout the FPGA. Some measurements are performed prior to the selective SDRAM delay:

- receiver lock status, based on the detection of periodic start of frame synchronization markers.
- BER measurement performed on the 32-bit unique words over 32 successive frames.
- 4-bit soft-quantized samples gathered at the demodulators.

These early quality measurements are performed for each input signal replica. Their timing alignement with the demodulated bit is preserved through the SDRAM. In other words, the quality measurements are subject to the same delay through the SDRAM as the demodulated information bit.

Some other quality measurements are performed after the selective SDRAM delay:

- SNR measurement using the standard deviation of the 4-bit soft-quantized samples.
- detection of misaligned streams.

## Clock / Timing

The clock distribution scheme embodied in the COM-8003 is illustrated below.



Darker blue = internal 40 MHz clock \* indicates edge-trigger signal

The core signal processing performed within the FPGA and all the inputs/outputs are synchronous with the 40 MHz internal oscillator.

Baseline clock architecture

## **VHDL Simulation**

Representative simulation screens for salient internal signals are captured and discussed below.

## Input Data Bus

Definition:

| Definition.    |                                                                                                |
|----------------|------------------------------------------------------------------------------------------------|
| Input Module   | Definition                                                                                     |
| Interface      |                                                                                                |
| Shared bus     |                                                                                                |
| BUS_CLK_OUT    | 40 MHz output reference clock for use on the synchronous bus.                                  |
| BUS_ADDR[3:0]  | Bus address. Output (since this module is the bus Master). Designates which slave module is    |
|                | targeted for this read or write transaction.                                                   |
|                | All 1's indicates that the write data is to be broadcasted to all receiving slave modules.     |
|                | Read at the rising edge of BUS_CLK_OUT.                                                        |
| BUS_RWN        | Read/Write#. Output (since this module is the bus Master).                                     |
|                | Indicates whether a read (1) or write (0) transaction is conducted. Read at the rising edge of |
|                | BUS_CLK_OUT. Read and Write refer to the bus master's perspective.                             |
| BUS_DATA[15:0] | Bi-directional data bus.                                                                       |
|                | Output when $BUS_RWN = '0'$ .                                                                  |
|                | Input when BUS_RWN = '1'.                                                                      |
|                | Read data is delayed by two clock periods with respect to the read request from the master.    |
|                | Functional definition during read:                                                             |
|                | • bit 0 SAMPLE_CLK_IN. '1' when 4-bit soft-quantized samples are available.                    |
|                | • bits(4:1) DATA_IN(3:0) soft quantized samples from demodulator. MSb is the information bit.  |
|                | 3 LSBs are quality bits.                                                                       |
|                | • bits(15:5) undefined                                                                         |

The COM-8003 is capable of reading multiple data streams from multiple demodulators over a shared data bus. The COM-8003 is bus 'master', i.e. it drives the BUS\_CLK\_OUT, BUS\_ADDR, BUS\_RWN signals. The 16-bit BUS\_DATA is bi-directional. The simulation below shows that the COM-8003 is reading data from four demodulators at bus addresses 0,1,2 and 3 respectively. For simplicity, only one demodulator, responding to bus address 0, is simulated.

The simulation shows that the read data (read marker) is delayed by two clock periods with respect to the read request (blue marker). The bus data is converted to internal serial data streams (DATA0\_IN/SAMPLE0\_CLK) two clocks later (black marker).

| Signal        | 1:1512:152:102:50ns<br>15200ns 15300ns 15400ns 15500ns 15600ns 15700ns 15800ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BUS_CLK       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| BUS_ADDR      | 3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,3,0,2,2,3,0,2,2,0,2,0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| BUS_RWN       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| BUS_DATA[10]  | · <u>22222</u> ··· <u>2222</u> ··· <u>2</u> · <u>2</u> |
| BUS_DATA[9]   | ······································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| BUS_DATA[8]   | ···ZZZZZ···ZZZZZ···ZZZZZ···ZZZZZZ···ZZZZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| BUS_DATA[7]   | · ZZZZZ···ZZZZZ···ZZZZZ···ZZZZZ···ZZZZZZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| BUS_DATA[6]   | · ZZZZZ ··· ZZZZZZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| BUS_DATA[5]   | ······································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| BUS_DATA[4]   | ·· ZZZZZ·· ZZZZZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| BUS_DATA[3]   | · <u>zzzzz</u> · · <u>z</u> zzzz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| BUS_DATA[2]   | · <u>22222</u> ··· <u>2</u> 2222                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| BUS_DATA[1]   | ······································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| BUS_DATA[0]   | ·· ZZZZZ·· ZZZZZ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| BUS_DATA_D[O] | <u>z zzzzz zzzzzz</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| BUS_DATA_D[1] | Z       ·· ZZZZZ       ·· ZZZZZZ       ·· ZZZZZZ       ·· ZZZZZZ       ·· ZZZZZZ       ·· ZZZZZZ       ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| DATAO_IN      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| SAMPLEO_CLK   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

Data bus simulation. COM-1018 DSSS demodulator -> COM-8003 signal diversity combiner

#### Frame / SuperFrame Synchronization

Key signals for the *sof\_sync* component are shown below for a configuration consisting of a 4128-bit long frame and a 2-frame long superframe. DATA\_IN, BIT\_CLK\_IN are the serial input signal. SOF2/SOSF2 are the start of frame and start of superframe at the generator, shown for the sole purpose of comparison with the recovered start of frame (SOF) and start of superframe (SOSF). The detected phase ambiguity is 0, meaning no inversion or phase ambiguity at the demodulator. The bit error rate, shown here as zero, is computed over 1024 bit (32 consecutive 32-bit unique words). DETECT is the unprocessed output of the *matched\_filter32* 32-bit matched filter entity to detect one of four possible versions of the unique word.



Frame / SuperFrame Synchronization

## **Bit Error Rate Measurement**

The *ber\_measurement2* component measures the bit error rate (uncoded) over 1024 bits, using the known bits within the unique word synchronization sequence. This method provides a good estimate of the signal quality on-the-fly, without having to substitute the payload data with a PRBS sequence. The measurement period is 32 frames (to reach a total of 32\*32-bit unique words = 1024 bits). The signal BER\_LOCAL is the running bit error count while the signal BER is the final count for the last detection window. There is no requirement to align the BER measurement window with the superframe.



## **Combiner configuration**

The main configuration parameters of the *combiner* component are:

- the superframe length SUPERFRAME\_LENGTH (expressed as number of fixed-length frames)
- the known delay SF\_OFFSET\_i of received stream i with respect to the reference stream 0 (expressed as number of superframes)
- the list of active streams STREAMS\_ENABLED



Address constants, in hexadecimal

The SDRAM is automatically apportioned into contiguous sectors, one for each stream. The simulation above shows the start addresses. When computing SDRAM addresses, the following should be taking into account:

- (a) the SDRAM data width is 64-bit, thus each address represents 8 bytes of data.
- (b) Each demodulator sample occupies one byte of SDRAM storage (4 bit soft quantization, lock status, start of superframe marker and BER summary).

#### Signal path to SDRAM

The signal path within the *combiner* component, from the input to the SDRAM write is illustrated by the onestream simulation below. The 4-bit soft-quantized demodulator output is DATA0\_IN with its sample clock SAMPLE0\_CLK. After going through the *sof\_sync* component, the data stream DATA0A is corrected for demodulator phase ambiguities. Ancillary information such as the synchronization information (SOF\_LOCK0) is appended to form the one-byte sample DATA0B. The capture below clearly shows the start-of-frame lock status information changing in bit 4 DATA0B as lock is detected.

The input FIFO IFIFO\_0 aggregates the 8-bit wide DATA0B samples into 64-bit wide SDRAM\_DATA\_IN samples. The FIFO itself is 128-bit long so as to allow simultaneous read and write in opposite halfs. WPTR1\_0 and RPTR1\_0 are the input FIFO write and read pointers, respectively.

The capture shows an instance of write pointer realignement at the blue marker because the detected start of frame is not aligned with the 64-bit word boundary in accordance with the write pointer management algorithm described in a previous section The write pointer WPTR1\_0 is reset from F to 8.

| Signal                    | Value                             | 1:1628880 1631440ns<br>1628000ns 1630000ns 1632000ns 1634000ns 1636000n         |
|---------------------------|-----------------------------------|---------------------------------------------------------------------------------|
| DATAO_IN                  | 0                                 | F(0)(F) 0 (F)                                                                   |
| SAMPLEO_CLK               | 'O'                               |                                                                                 |
| SAMPLEOA_CLK              | 'O'                               |                                                                                 |
| SOFO_LOCAL                | 'O'                               | ······                                                                          |
| SOF_LOCKO_LOCAL           | '1'                               | ······                                                                          |
| SOSFO_LOCAL               | 'O'                               |                                                                                 |
| DATAOA_ENABLE             | '1'                               | · · · · · · · · · · · · · · · · · · ·                                           |
| DATAOA                    | O                                 | F(0)(F)(0)F                                                                     |
| DATAOB                    | 10                                | 0(00)(0F)(00) 10 1F                                                             |
| IFIFO_O                   | 10101010101010100F00000F0000F0F0F | 0/00/000F000F0/00/00/00/00/00/00/00/10/10/10/10/10/10                           |
| WPTR1_0                   | 0                                 | 9(A)B)C)D)E)F)9)A)B)C)D)E)F)0)1)2)3)4)5)6)7)8)9)A)B)C)                          |
| WPTR1_O_ALT               | 0                                 | 9(A)(B)(C)(D)(E)(F)(9)(A)(B)(C)(D)(E)(F)(0)(1)(2)(3)(4)(5)(6)(7)(8)(9)(A)(B)(C) |
| RPTR1_0                   | '1'                               | ·····                                                                           |
| SDRAM_ADDR                | 00001E4                           | 00001E4 00001E5 00001E6                                                         |
| SDRAM_ADDR_IN_O           | 00001E5                           | 00001E5 00001E6 (00001E7                                                        |
| SDRAM_DATA_IN             | OFOOOOOFOOOFOF                    | OF00000FC00F0F0F 1010101010101010 (1F1F1F1F1F1                                  |
| SDRAM_SAMPLE_CLK_IN       | 'O'                               | ······                                                                          |
| SDRAM_CURRENT_TRANSACTION | o                                 | 0 0 0                                                                           |
|                           |                                   |                                                                                 |

Data path (single stream 0) from demodulated sample to SDRAM

Another instance of write pointer realignement is shown in the capture below. In this case, the start of superframe SOSF0\_LOCAL is not aligned with an SDRAM superframe boundary. The SDRAM address is reset to the start address for this stream.

|     | Signal                    | Value                            | 64772            |                                                   |      |      |                                   |                      |                          | 300ns          |          |         |              |       |       |                |      | 0.000     |       |       |       |
|-----|---------------------------|----------------------------------|------------------|---------------------------------------------------|------|------|-----------------------------------|----------------------|--------------------------|----------------|----------|---------|--------------|-------|-------|----------------|------|-----------|-------|-------|-------|
| Ш   |                           |                                  |                  |                                                   |      | 470  |                                   | ns                   |                          | 047            | 100      | Uns     | . °          | 4000  | 000   | 19<br>1 1 1 1  | 0403 | 1         |       | 1 1 1 | .900  |
|     | DATAO_IN                  | F                                | ( F              | 0                                                 | I    | 0    | 1                                 | FO                   | F                        | ΟĪ             | 0        |         | F            | 0     |       | F              | 0    | F         | 0     | FΟ    | F     |
|     | SAMPLEO_CLK               | '1'                              | <u> </u>         | $\left  \cdot \right  \cdot \left  \cdot \right $ | •    |      |                                   | • •                  |                          |                |          | • • • • | HH           |       |       |                | H    |           |       |       | 4.1.1 |
|     | SAMPLEOA_CLK              | 'O'                              | 4444             |                                                   | +    |      |                                   | $\left\{ + \right\}$ | $\left\{ \cdot \right\}$ |                | ·        |         |              |       | • • • |                | 111  |           |       |       | HH    |
|     | SOFO_LOCAL                | 'O'                              |                  |                                                   |      |      |                                   |                      |                          |                |          |         |              |       |       |                |      |           |       |       |       |
|     | SOF_LOCKD_LOCAL           | '1'                              |                  |                                                   |      |      |                                   |                      |                          |                |          |         |              |       |       |                |      |           |       |       |       |
|     | SOSFO_LOCAL               | 'O'                              |                  |                                                   |      |      |                                   |                      |                          |                |          |         |              |       |       |                |      |           |       |       |       |
|     | DATAOA_ENABLE             | '1'                              |                  |                                                   |      |      |                                   |                      |                          |                |          |         |              |       |       |                |      |           | • • • |       |       |
|     | DATAOA                    | F                                | IC F             |                                                   | 0    | I    | 0                                 | F                    | OF                       | 0              | I (      | )       | F            |       | 0     | F              | 0    | F         | ļ     | F     | O F   |
|     | DATAOB                    | lF                               | :: 1F            |                                                   | .0   | : :  | LO                                | 11                   | 1(1                      | . <b>J 1</b> ( | : 1      | 0       | 1F           |       | 10    | 1F             | 10   | 11        |       | 1011  | 1(1   |
|     | IFIFO_0                   | 101F1F10101010301010101010101F1F | 10101            | F1F:                                              | .010 | )1F: | 1F1                               | 010                  | )10:                     | 1010           | ):1      | 0:10    | 1 <b>F</b> : | ::::1 | .F :  | ::: <b>1</b> F | -00  | 101H      | œ     | 10:   | 10    |
|     | WPTR1_0                   | F                                |                  |                                                   |      | 8    |                                   |                      |                          |                | 31       | I ( I I | 1(:2         | 3430  | 789   | j I ( I I      | IC:  | ા ન ક     | °[8]9 | JIC   | III   |
|     | WPTR1_O_ALT               | F                                |                  |                                                   |      | 8    |                                   |                      |                          |                | <u> </u> | I ( I I | 1(:2         | इन्ह) | - E S | j I ( I I      | IC:  | ં ને કે લ | 169   | JIC   | IFF   |
|     | RPTR1_0                   | '1'                              |                  |                                                   |      |      |                                   |                      |                          |                |          |         |              |       | •     |                |      |           |       |       |       |
|     | SDRAM_ADDR_IN_O           | 00007E5                          | 00007E5          |                                                   |      |      | 000                               | 0001                 | . 00                     | 00002          | : 00     | 0000    | 3 00         | 0000  | 04    |                |      |           |       |       |       |
|     | SDRAM_ADDR                | 00007E4                          | 00007E4          |                                                   |      |      |                                   | 000                  | 0000                     | 00             | 10000    | . 00    | 0000         | 2 00  | 0000  | 03             |      |           |       |       |       |
|     | SDRAM_DATA_IN             | 1010101010101F1F                 | 1010101010101F1F |                                                   |      |      | (1F1F1F1)10101F1)101F1F1)11F1F1F1 |                      |                          |                |          |         | F 1.         |       |       |                |      |           |       |       |       |
|     | SDRAM_SAMPLE_CLK_IN       | 'O'                              |                  |                                                   |      |      |                                   |                      |                          |                |          |         |              |       |       |                |      |           |       |       |       |
|     | SDRAM_CURRENT_TRANSACTION | o                                |                  |                                                   |      |      | 0                                 |                      |                          |                |          |         |              | 0     | X     | 0              | Γ    | 0         | T     | 0     |       |
| II. |                           |                                  |                  |                                                   |      |      |                                   |                      |                          |                |          |         | 1            |       |       |                |      |           |       |       |       |

Superframe is out of synchronization with SDRAM write pointer. SDRAM write pointer is reset.

#### Signal path from SDRAM

All active streams are read from the SDRAM as a group. The bit rate is controlled by a numerically controlled oscillator which generates BIT\_CLK. Since the SDRAM samples are 8 byte wide, the SDRAM read rate is READ\_CLK (BIT\_CLK / 8). Each READ\_CLK pulse triggers a sequence of SDRAM read transactions, one for each active stream. The simulation capture below illustrates this in the case of 4 active streams (STREAMS\_ENABLED = "00001111"). The SDRAM lower address bits SDRAM\_ADDR\_OUT\_L are the same for all active streams. The SDRAM upper address bits SDRAM\_ADDR\_OUT\_U\_x reflect the SDRAM memory map and the known delay between streams.



Reading 4 streams from the SDRAM

## **Flow Control**

Demodulated data streams are written to the SDRAM at data rates determined by the demodulators. All data streams are nominally at the same data rate. However, each data stream may experience small data rate variations due to such effect as Doppler.

On the other side (the read side) of the SDRAM, all data streams are read at the same rate which is set by a numerically controlled oscillator. The NCO is set slightly higher (1 + 1/128) than the nominal demodulator rate. The READ\_CLK is generated by the NCO. A flow control mechanism ensures that the read pointers do not move past the write pointers. When the SDRAM virtual buffers are empty, READ\_CLK pulses are temporarily disabled by the READ\_CLK\_ENABLE signal. The simulation capture below illustrates this flow control mechanism. It can be observed that the samples are addresses 3BE and 13BE are read from SDRAM shortly after being written to SDRAM.



Flow control

## **Output FIFO**

Data is read from the SDRAM 64-bit at a time. Each SDRAM output word consists of 8 x 8-bit samples. The 64-bit words are written to the output FIFO OFIFO\_x, where x identifies which stream. The 128-bit wide FIFOs are used as "A/B" buffers. Data is written to the "A" half while being read from the "B" half and vice versa. The write pointer WPTR2 points to the FIFO half to be written to. The read pointer RPTR2 points to the FIFO byte to be read. Since all active streams are synchronized at this point, the write and read pointers are common to all streams.

Below is a simulation capture illustrating the output FIFO operation in the parallel to serial conversion. Two streams are active in this simulation.



Output FIFO. 64-bit parallel to 8-bit serial conversion.

#### Read pointer / Write pointer synchronization

The VHDL code automatically detects any misalignment between the write pointer and the read pointer for each stream. Any misalignment, as per the rules described earlier in this document, is immediately detected and the flag STREAMx\_RPTR\_REALIGNMENT\_NEEDED is raised. Consequently, the upper address field is incremented one half superframe at a time until the misalignment is corrected. If the misalignment is not correctable, the flag STREAMx\_RPTR\_REALIGNMENT\_NEEDED stays high and the corresponding stream is ignored.

| Signal                          | 3088540ns 3088560ns 3088580ns 3088600ns 3088620ns 3088640ns 3088660ns 30886 |  |  |  |  |  |  |  |  |  |  |
|---------------------------------|-----------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| SUPERFRAME_LENGTH               | 02                                                                          |  |  |  |  |  |  |  |  |  |  |
| SDRAM_SUPERFRAME_SIZE           | 0000400                                                                     |  |  |  |  |  |  |  |  |  |  |
| SDRAM_1_5_SUPERFRAME_SIZE       | 0000600                                                                     |  |  |  |  |  |  |  |  |  |  |
| SDRAM_SECTORO_SIZE              | 0000800                                                                     |  |  |  |  |  |  |  |  |  |  |
| SDRAM_ADDR_IN_O                 | 00007AF X 00007B0                                                           |  |  |  |  |  |  |  |  |  |  |
| SDRAM_ADDR_OUT_O                | 0000380 0000780 0000380 0000780                                             |  |  |  |  |  |  |  |  |  |  |
| SDRAM_POINTERS_DIFF_0           | 00003FF X 7FFFFFF X 00003FF X 0000000                                       |  |  |  |  |  |  |  |  |  |  |
| SDRAM_POINTERS_DIFF_0[26]       | ······                                                                      |  |  |  |  |  |  |  |  |  |  |
| SDRAM_STREAM_DELAY_O            | 00 00003FF X 00007FF X 00003FF X 0000000                                    |  |  |  |  |  |  |  |  |  |  |
| SDRAM_ADDR_OUT_L                | 03B0                                                                        |  |  |  |  |  |  |  |  |  |  |
| SDRAM_ADDR_OUT_U_O              | 0000000 X 0000400 X 0000000 X 0000400                                       |  |  |  |  |  |  |  |  |  |  |
| STREAMO_RPTR_REALIGNMENT_NEEDED |                                                                             |  |  |  |  |  |  |  |  |  |  |
| SDRAM_ADDR_OUT_U_INCREMENT      |                                                                             |  |  |  |  |  |  |  |  |  |  |
| STREAMO_RPTR_REALIGNMENT_DONE   |                                                                             |  |  |  |  |  |  |  |  |  |  |

Misalignment detected and corrected.

## **FPGA Occupancy**

| Design Summary.                       |     |       |        |    |     |
|---------------------------------------|-----|-------|--------|----|-----|
| Number of errors: 0                   |     |       |        |    |     |
| Number of warnings: 4                 |     |       |        |    |     |
| Number of Slices: 3,0                 | 070 | out c | of 3,0 | 72 | 99% |
| Number of Slices containing           |     |       |        |    |     |
| unrelated logic:                      | 177 | out c | of 3,0 | 70 | 5%  |
| Number of Slice Flip Flops: 2,        | 561 | out c | of 6,1 | 44 | 41% |
| Total Number 4 input LUTs: 4,2        | 266 | out c | of 6,1 | 44 | 69% |
| Number used as LUTs:                  |     |       | 3,9    | 46 |     |
| Number used as a route-thru:          |     |       | 2      | 91 |     |
| Number used as Shift registers        | :   |       |        | 29 |     |
| Number of bonded IOBs:                | 123 | out c | of 1   | 42 | 86% |
| Number of GCLKs:                      | 3   | out c | of     | 4  | 75% |
| Number of GCLKIOBs:                   | 3   | out c | f      | 4  | 75% |
| Total equivalent gate count for desig | an: | 55.1  | 53     |    |     |

Additional JTAG gate count for IOBs: 6,048

## **Acknowledgments**

This product development was funded by SBIR Phase II research contract "Signal Diversity Combining for Improved Satellite Communications" awarded by the US Air Force Research Laboratory, Rome, NY.

## **Contact Information**

MSS • 18221 Flower Hill Way #A • Gaithersburg, Maryland 20879 • U.S.A. Telephone: (240) 631-1111 Facsimile: (240) 631-1676 E-mail: info@comblock.com