

## COM-7001 TURBO CODE ERROR CORRECTION ENCODER / DECODER

## Key Features

- Full duplex turbo code encoder / decoder.
- Rate: 0.25 to 0.97.
- Block length: 64 bits to 4 Kbits.
- Speed up to 11.7 Mbps.
- Automatic frame synchronization.
- 4-bit soft-quantization input.
- Includes unique word for frame synchronization, helical interleaving, scrambling and CRC.
- Single 5V supply. Connectorized 3"x 3" module for ease of prototyping. Standard 40 pin 2mm dual row connectors (left, right, bottom). Interfaces with 5V and 3.3V logic.

For the latest data sheet, please refer to the **ComBlock** web site: <u>www.comblock.com/download/com7001.pdf</u>. These specifications are subject to change without notice.

For an up-to-date list of **ComBlock** modules, please refer to <u>www.comblock.com/product\_list.htm</u>.





## Turbo Codes

Two-dimensional and three-dimensional turbo codes are supported. The constituent code for each dimension is chosen among the following :

| Hamming           | Parity            |
|-------------------|-------------------|
|                   | (4,3)             |
| (8,4)             | (8,7)             |
| (16,11)           | (16,15)           |
| (32,26) [2D only] | (32,31) [2D only] |
| (64,57) [2D only] | (64,63) [2D only] |

There are two key restrictions in selecting the 2D or 3D codes :

(a) the third dimension code is limited to a maximum length of 16 bits.

(b) the maximum block size (including the CRC) is 4096 bits.

Below are a few examples of code selection and the resulting block size and code rate.

| Code                       | Block<br>size<br>(bits) | Rate  |
|----------------------------|-------------------------|-------|
| 2D (64,57)x(64,57)         | 4096                    | 0.793 |
| 3D (32,26)x(32,26)x(4,3)   | 4096                    | 0.495 |
| 3D (16,11)x(16,11)x(16,11) | 4096                    | 0.325 |
| 2D (8,4)x(8,4)             | 64                      | 0.25  |

The overall ability to correct errors is affected by the code rate, the block size and the number of iterations at the decoding end. A high number of iterations will reduce the throughput but increase the error correction capability. It the data rate is set above the capabilities of the decoder, the number of decoding iterations will be automatically reduced.

Below are a few examples of code selection, the resulting coding gain at  $10^{-6}$  BER and data throughput, assuming 6 decoding iterations :

| Code                     | Coding<br>gain @<br>10 <sup>-6</sup><br>BER | Throughput<br>(encoded /<br>decoded) in<br>Mbit/s |
|--------------------------|---------------------------------------------|---------------------------------------------------|
| 2D (64,57)x(64,57)       | 7.3 dB                                      | 11.7/9.2                                          |
| 3D (32,26)x(32,26)x(4,3) | 8.1 dB                                      | 10.4/5.1                                          |
| 3D                       | 8.5 dB                                      | 11.0/3.5                                          |
| (16,11)x(16,11)x(16,11)  |                                             |                                                   |

Utilities to help with the selection of turbo codes and the computation of block length, rate and coding gain can be found at <u>www.aha.com</u>.

## Electrical Interface

The input signals on connector J2 are synchronous with the input clock CLK\_IN (pin A1/J2). The maximum frequency for CLK\_IN is 40 MHz. Input signals are read at the rising edge of CLK\_IN.

All I/O signals on the other connectors (J3/J4) are synchronous with the internal 40 MHz clock CLK\_OUT. Output signals are generated on the falling edge, while input signals are read on the rising edge of CLK\_OUT.

| Coded data input                                                                                 | Definition                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA_C_IN[3:0]                                                                                   | Coded data input (typically from a                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                  | demodulator). 4-bit soft quantized.                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                  | Unsigned representation.                                                                                                                                                                                                                                                                                                                                                                      |
| DATA_C_CLK_IN                                                                                    | Input sample clock. One CLK-                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                  | wide pulse. Read input data at                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                  | rising edge of CLK when                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                  | $DATA_C_CLK_IN = '1'$                                                                                                                                                                                                                                                                                                                                                                         |
| Decoded Output                                                                                   | Definition                                                                                                                                                                                                                                                                                                                                                                                    |
| DATA_D_OUT                                                                                       | Decoded data bit.                                                                                                                                                                                                                                                                                                                                                                             |
| DATA_D_CLK_OUT                                                                                   | Decoded bit clock. One CLK-wide                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                  | pulse. Read output data at rising                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                  | edge of CLK when                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                  | $DATA_D_CLK_OUT = '1'$                                                                                                                                                                                                                                                                                                                                                                        |
| SOF_D_OUT                                                                                        | Code block synchronization pulse.                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                  | One CLK-wide pulse, aligned                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                  | with DATA_D_CLK_OUT for the                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                  | first bit of the frame (code block).                                                                                                                                                                                                                                                                                                                                                          |
| DATA_D_VALID_OUT                                                                                 | Indicates whether residual errors                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                  | were found in the PREVIOUS                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                  | frame after error correction based                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                  | on the CRC check (when enabled).                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                  | Read at the following start of                                                                                                                                                                                                                                                                                                                                                                |
| Uncoded data imput                                                                               | frame when FRAME_SYNC = '1'. <b>Definition</b>                                                                                                                                                                                                                                                                                                                                                |
| Uncoded data input<br>DATA_U_IN                                                                  |                                                                                                                                                                                                                                                                                                                                                                                               |
| DATA_0_IN                                                                                        | Uncoded data to be transmitted over noisy channel.                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                               |
| DATA_U_CLK_IN                                                                                    | Input bit clock. One CLK-wide                                                                                                                                                                                                                                                                                                                                                                 |
| DATA_U_CLK_IN                                                                                    | Input bit clock. One CLK-wide<br>pulse. Read input data at rising                                                                                                                                                                                                                                                                                                                             |
| DATA_U_CLK_IN                                                                                    | pulse. Read input data at rising<br>edge of CLK when                                                                                                                                                                                                                                                                                                                                          |
| DATA_U_CLK_IN                                                                                    | pulse. Read input data at rising                                                                                                                                                                                                                                                                                                                                                              |
| DATA_U_CLK_IN DATA_U_CLK_IN_RE                                                                   | pulse. Read input data at rising edge of CLK when                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                  | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'                                                                                                                                                                                                                                                                                                                   |
| DATA_U_CLK_IN_RE                                                                                 | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'<br>Output. One CLK-wide pulse.                                                                                                                                                                                                                                                                                    |
| DATA_U_CLK_IN_RE                                                                                 | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'<br>Output. One CLK-wide pulse.<br>Requests a sample from the                                                                                                                                                                                                                                                      |
| DATA_U_CLK_IN_RE<br>Q<br>Encoded data output                                                     | pulse. Read input data at rising<br>edge of CLK whenDATA_U_CLK_IN = '1'Output. One CLK-wide pulse.Requests a sample from the<br>module upstream. For flow-control<br>purposes.Definition                                                                                                                                                                                                      |
| DATA_U_CLK_IN_RE<br>Q                                                                            | pulse. Read input data at rising<br>edge of CLK whenDATA_U_CLK_IN = '1'Output. One CLK-wide pulse.Requests a sample from the<br>module upstream. For flow-control<br>purposes.DefinitionEncoded data to be transmitted                                                                                                                                                                        |
| DATA_U_CLK_IN_RE<br>Q<br>Encoded data output<br>DATA_E_OUT                                       | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'Output. One CLK-wide pulse.<br>Requests a sample from the<br>module upstream. For flow-control<br>purposes.DefinitionEncoded data to be transmitted<br>over noisy channel.                                                                                                                                         |
| DATA_U_CLK_IN_RE<br>Q<br>Encoded data output                                                     | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'Output. One CLK-wide pulse.<br>Requests a sample from the<br>module upstream. For flow-control<br>purposes.DefinitionEncoded data to be transmitted<br>over noisy channel.Output bit clock. One CLK-wide                                                                                                           |
| DATA_U_CLK_IN_RE<br>Q<br>Encoded data output<br>DATA_E_OUT                                       | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'Output. One CLK-wide pulse.<br>Requests a sample from the<br>module upstream. For flow-control<br>purposes.DefinitionEncoded data to be transmitted<br>over noisy channel.Output bit clock. One CLK-wide<br>pulse. Read input data at rising                                                                       |
| DATA_U_CLK_IN_RE<br>Q<br>Encoded data output<br>DATA_E_OUT                                       | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'Output. One CLK-wide pulse.<br>Requests a sample from the<br>module upstream. For flow-control<br>purposes.DefinitionEncoded data to be transmitted<br>over noisy channel.Output bit clock. One CLK-wide<br>pulse. Read input data at rising<br>edge of CLK when                                                   |
| DATA_U_CLK_IN_RE<br>Q<br>Encoded data output<br>DATA_E_OUT<br>DATA_E_CLK_OUT                     | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'Output. One CLK-wide pulse.<br>Requests a sample from the<br>module upstream. For flow-control<br>purposes.DefinitionEncoded data to be transmitted<br>over noisy channel.Output bit clock. One CLK-wide<br>pulse. Read input data at rising<br>edge of CLK when<br>DATA_E_CLK_OUT = '1'                           |
| DATA_U_CLK_IN_RE<br>Q<br>Encoded data output<br>DATA_E_OUT<br>DATA_E_CLK_OUT<br>DATA_E_CLK_OUT_R | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'Output. One CLK-wide pulse.<br>Requests a sample from the<br>module upstream. For flow-control<br>purposes.DefinitionEncoded data to be transmitted<br>over noisy channel.Output bit clock. One CLK-wide<br>pulse. Read input data at rising<br>edge of CLK when<br>DATA_E_CLK_OUT = '1'Input. One CLK-wide pulse. |
| DATA_U_CLK_IN_RE<br>Q<br>Encoded data output<br>DATA_E_OUT<br>DATA_E_CLK_OUT                     | pulse. Read input data at rising<br>edge of CLK when<br>DATA_U_CLK_IN = '1'Output. One CLK-wide pulse.<br>Requests a sample from the<br>module upstream. For flow-control<br>purposes.DefinitionEncoded data to be transmitted<br>over noisy channel.Output bit clock. One CLK-wide<br>pulse. Read input data at rising<br>edge of CLK when<br>DATA_E_CLK_OUT = '1'                           |

|                        | control purposes.                   |
|------------------------|-------------------------------------|
| Ancillary Signals      | Definition                          |
| CLK_IN                 | Input clock for the I/O signals on  |
|                        | connector J2. Maximum               |
|                        | frequency is 40 MHz.                |
| CLK_OUT                | Output clock for the I/O signals on |
|                        | connector J3/J4. Fixed frequency    |
|                        | <b>f</b> <sub>clk</sub> of 40 MHz.  |
| Serial Monitoring &    | DB9 connector.                      |
| Control                | 115 Kbaud/s. 8-bit, no parity, one  |
|                        | stop bit. No flow control.          |
| <b>Power Interface</b> | 4.75 – 5.25VDC. Terminal block.     |
|                        | Power consumption is                |
|                        | approximately proportional to the   |
|                        | CLK frequency. The maximum          |
|                        | power consumption at 40 MHz is      |
|                        | 300mA.                              |

## Operations

#### **CRC** check

The Cyclic Redundancy Code is used to detect blocks which contain uncorrected errors. A 16-bit or 32-bit CRC is appended to the data in each block. In applications where spectral efficiency is important, the CRC check can be disabled by software command.

The generic form of the CRC code generator is shown below:



Two standard CRC encoders are available: CCITT 16-bit CRC and 32-bit CRC. The feedback taps are 0x1 10 21 and 0x1 04 C1 1D B7 respectively. The MSB is the leftmost tap on the generic CRC code generator shown above.

#### Scrambling

A scrambler can be used to randomize the transmitted bit pattern. The scrambler is a 16-bit linear feedback shift register with generator polynomial  $1 + x^{14} + x^{15}$ .



The scrambler/descrambler is reset at each frame. The seed value (contents of the register upon reset) is 0x5210, where the MSB is in the rightmost register 15. The scrambling and descrambling feature can be enabled or disabled by software command.

#### **Unique Word**

A unique word is used for synchronizing the received data stream with the periodic code blocks. The unique word is 32-bit long: 01011010 00001111 10111110 01100110 (binary) 0x 5A 0F BE 66 (hex) The most significant bit (left-most) is transmitted first.

In order to limit the bandwidth expansion to less than 5%, the unique word transmission frequency depends on the code block size:

| Code block size                 | UW transmission rate    |
|---------------------------------|-------------------------|
| $\geq$ 1024 bits                | Once every block        |
| $\geq$ 512 bits and < 1024 bits | Once every two blocks   |
| $\geq$ 256 bits and < 512 bits  | Once every four blocks  |
| < 256 bits                      | Once every eight blocks |

The unique word is not error corrected.

The unique word transmission or reception can be disabled by software command. This can be useful in configurations where frame synchronization references are available externally.

If unique word synchronization is enabled, the 32bit unique word is removed from the received data stream prior to error correction.

# Configuration (via Serial Link / LAN)

Complete assemblies can monitored and controlled centrally over a single serial or LAN connection.

The module configuration parameters are stored in non-volatile memory. All control registers are read/write.

Programmers developing custom applications (using the <u>ComBlock API</u> instead of the supplied ComBlock control center graphical user interface) should know that configuration changes are enacted upon (re-)writing to the last register (REG12).

## This module operates at a fixed internal clock rate $\mathbf{f}_{clk}$ of 40 MHz.

Undefined control registers or register bits are for backward software compatibility and/or future use. They are ignored in the current firmware version.

| Parameters                           | Attributes                                                                |
|--------------------------------------|---------------------------------------------------------------------------|
| I/O pinout                           | 00 = full duplex                                                          |
| selection                            | 01 = encoder only                                                         |
|                                      | 10 = decoder only                                                         |
|                                      | REG0 bits 2-1                                                             |
| CRC insertions                       | 00 = off                                                                  |
| (transmitter side)                   | 01 = 16-bit on                                                            |
|                                      | 10 = 32-bit on                                                            |
|                                      | REG0 bits 4-3                                                             |
| CRC check                            | 00 = off                                                                  |
| (receiver side)                      | 01 = 16-bit on                                                            |
|                                      | 10 = 32-bit on                                                            |
|                                      | REG0 bits 6-5                                                             |
| Scrambling                           | 0 = off                                                                   |
| (transmitter side)                   | 1 = on                                                                    |
|                                      | REG0 bit 7                                                                |
| Scrambling                           | 0 = off                                                                   |
| (receiver side)                      | 1 = on                                                                    |
|                                      | REG1 bit 0                                                                |
| Tx unique word                       | 0 = off                                                                   |
|                                      | 1 = on                                                                    |
|                                      | REG1 bit 1                                                                |
| Rx unique word                       | 0 = off                                                                   |
| synchronization                      | 1 = on                                                                    |
| and removal.                         | REG1 bit 2                                                                |
| Turbo code                           | When set, bypasses the turbo product                                      |
| bypass mode                          | code at both the encoder and decoder.                                     |
|                                      | Connects Uncoded side (_U) to                                             |
|                                      | Encoded side (_E). Connects Coded                                         |
|                                      | side (_C) to Decoded side (_D).                                           |
|                                      | Note: soft-quantized bits are lost in                                     |
|                                      | the process. Only the most signicant                                      |
|                                      | bit is kept.                                                              |
|                                      | 0 = off                                                                   |
|                                      | 1 = on                                                                    |
| T . 1                                | REG1 bit 3                                                                |
| Internal pattern<br>generation (test | 00 = test mode disabled                                                   |
| mode)                                | 01                                                                        |
|                                      | 01 = counting sequence:                                                   |
|                                      | When set, the baseband input is disabled and a periodic pattern is        |
|                                      | disabled and a periodic pattern is<br>internally generated at the encoder |
|                                      | input. The pattern consists of an 8-bit                                   |
|                                      | counter, MSB transmitted first.                                           |
|                                      | counce, wish nanshinged first.                                            |
|                                      | 10 = internal generation of 2047-bit                                      |
|                                      | periodic pseudo-random bit sequence                                       |
|                                      | as modulator input. (overrides                                            |
|                                      | external input bit stream).                                               |
|                                      | enternar input on buounij.                                                |
|                                      | The test pattern bit rate is                                              |
|                                      | r r r r r r r r r r r r r r r r r r r                                     |

|                              | automatically set by the external sink              |
|------------------------------|-----------------------------------------------------|
|                              | module (typically a modulator) as part              |
|                              | of the flow control mechanism.                      |
|                              |                                                     |
|                              | REG1 bits 5-4                                       |
| Tx code X-axis               | 0000 = no code                                      |
| (1 <sup>st</sup> dimension)  | 0011 = (8,4) Hamming                                |
|                              | 0100 = (16, 11) Hamming                             |
|                              | 0101 = (32,26) Hamming                              |
|                              | 0110 = (64,57) Hamming                              |
|                              | 1010 = (4,3) parity code                            |
|                              | 1011 = (8,7) parity code                            |
|                              | 1100 = (16,15) parity code                          |
|                              | 1100 = (32,31) parity code                          |
|                              | 1110 = (64,63) parity code                          |
|                              | REG2 bits 3-0                                       |
| Tx code Y-axis               | Same definition as above.                           |
| $(2^{nd} \text{ dimension})$ | REG2 bits 7-4                                       |
| Tx code Z-axis               |                                                     |
| (3 <sup>rd</sup> dimension)  | Same as above but limited to codes of               |
|                              | length 16 or less.                                  |
|                              | REG3 bits 3-0                                       |
| Tx code block size           | Function of the code selection and the              |
| (encoded block               | CRC selection above. For example if                 |
| size)                        | a 3D code (4,3)x(8,7)x(16,15) is used               |
|                              | in conjunction with 32-bit CRC, the                 |
|                              | block length is $3x7x15 - 32 = 283$ .               |
|                              | This field must always be defined                   |
|                              | (even when configured in decoder-                   |
|                              | only mode).                                         |
|                              | REG3 bits 7-4 (LSB)                                 |
|                              | REG4 bits 7-0                                       |
| Rx code X-axis               | Same definition as for tx code.                     |
| (1 <sup>st</sup> dimension)  | Receiver codes can be selected                      |
|                              | independently of transmitter codes.                 |
|                              | REG5 bits 3-0                                       |
| Rx code Y-axis               | Same definition as above                            |
| (2 <sup>nd</sup> dimension)  | REG5 bits 7-4                                       |
| Rx code Z-axis               | Same as above but limited to codes of               |
| (3 <sup>rd</sup> dimension)  | length 16 or less.                                  |
| Ň,                           | REG6 bits 3-0                                       |
| Rx code block                | Function of the code selection. For                 |
| size                         | example if a 3D code                                |
| (decoded block               | 1                                                   |
| size)                        | (4,3)x(8,7)x(16,15) is used, the block              |
| ,                            | length is $4x8x16 = 512$ .<br>Maximum size is 4096. |
|                              |                                                     |
|                              | Special case: 0 means 4096                          |
|                              | This field must always be defined                   |
|                              | (even when configured in encoder-                   |
|                              | only mode).                                         |
|                              | REG6 bits 7-4 (LSB)                                 |
|                              | REG7 bits 7-0                                       |
| Turbo code                   | 1 - 254. Typical settings is 6.                     |
| decoder maximum              | Special case: $0 =$ the decoder outputs             |
| number of                    | the hard decision value for each bit                |
| iterations                   | without correction.                                 |
|                              | REG8 bits 7-0                                       |
| Encoder data rate            | In most cases, the COM-7001 encoder                 |
| internal / external          | output data rate is determined by                   |
| selection                    | modules downstream (for example a                   |
| 1                            | autes as misticuli (for example a                   |

|                             | modulator).<br>There are, however, cases when the<br>encoder output data rate is set using<br>an internal NCO (for example when<br>testing turbo code encoder and<br>decoder back to back).                                                                                                                                                                                                                                     |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | 0 = exter nal. Encoder output bit rate<br>is based on DATA_E_CLK_OUT_REQ<br>bit requests from following module.                                                                                                                                                                                                                                                                                                                 |
|                             | 1 = internal. Output bit rate is selected<br>internally by the NCO frequency set<br>in REG10/11/12. Bit requests<br>DATA_E_CLK_OUT_REQ are ignored.<br>REG9 bit 6                                                                                                                                                                                                                                                               |
| Enable test points          | <ul> <li>1 = Enable additional test points on<br/>connector J4.</li> <li>0 = Disable.</li> <li>REG9 bit 7.</li> </ul>                                                                                                                                                                                                                                                                                                           |
| Encoder output<br>data rate | Internal generation of the encoder<br>output data rate. Ignore this field<br>when the output data rate is<br>determined by modules downstream.<br>24-bit signed integer (2's complement<br>representation) expressed as<br>fsymbol rate $* 2^{24} / \mathbf{f}_{clk}$ . The internal<br>processing clock $\mathbf{f}_{clk}$ is typically 40<br>MHz.<br>REG10 = bit 7-0 (LSB)<br>REG11 = bit 15 - 8<br>REG12 = bit 23 - 16 (MSB) |

Baseline configurations can be found at www.comblock.com/tsbasic\_settings.htm and

imported into the ComBlock assembly using the ComBlock Control Center File | Import menu.

#### Configuration example:

REG0 = 0x80 REG1 = 0x07 REG2 = 0x66 REG3 = 0x10 REG4 = 0xCB REG5 = 0x66 REG6 = 0x00 REG7 = 0x00 REG8 = 0x06REG9/10/11/12 = 0x00

Scrambling enabled. No CRC inserted. Unique word insertion and detection. Turbo code enabled. Same code for encoder and decoder: 2D (64,57)x(64,57), rate = 0.793. Block size is 4096 bit.

## Monitoring (via Serial Link / LAN)

Monitoring registers are read-only.

| Parameters         | Monitoring                          |
|--------------------|-------------------------------------|
| Channel bit error  | Bit errors counted over 1024        |
| rate               | uncorrected bits (unique word).     |
|                    | This measurement is refreshed       |
|                    | every 16 frames.                    |
|                    | REG13: bits 7-0                     |
|                    | REG14: bits 15-8                    |
| Number of errors   | REG15: bits 7-0                     |
| corrected in each  | REG16: bits 11-8                    |
| frame              |                                     |
| CRC check          | 0 = pass                            |
|                    | 1 = fail                            |
|                    | REG16 bit 12                        |
| Option o / Version | Returns '7001ov' when prompted      |
| v                  | for option o and version v numbers. |

## Timing

### Clocks

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



(\*) denotes edge-trigger signal

Baseline clock architecture Green = f<sub>clk</sub> processing zone 40 MHz Blue = CLK\_IN I/O zone Brown = AHA4524, 160 MHz

#### Input



Output



## Test Points

Test points are provided for easy access by an oscilloscope probe.

| Test     | Definition                                   |
|----------|----------------------------------------------|
| Point    |                                              |
| TP1      | '1' when the turbo code encoder data path    |
| (E_GOUT) | is empty and not processing a block. '0'     |
|          | otherwise. Use this test point to assess the |
|          | encoder utilization ratio.                   |
| TP2      | '1' when the turbo code decoder data path    |
| (D_GOUT) | is empty. Use this test point to assess the  |
|          | decoder utilization ratio.                   |
| TP3      | Receive unique word synchronization.         |
|          | '1' when a unique word is detected with      |
|          | less than 10% bit errors (at least 28        |
|          | matching bits out of 32).                    |
| TP4      | Receive start of frame, at the turbo decoder |
|          | output.                                      |
| INIT     | Unique word transmit enable. Provides        |
|          | some indication as to the encoded frame      |
|          | period.                                      |
| J4/B7    | Receive frame synchronization.               |
|          | Solid '1' when receiving periodic frame      |
|          | preambles at the right time. '0' or toggling |
|          | otherwise.                                   |
| J4/B8    | '1' when encoder input buffer contains at    |
|          | least a full frame of data ready to encode,  |
|          | '0' otherwise.                               |
| J4/B9    | '1' when encoder output buffer contains      |
|          | data, '0' when empty                         |
| J4/B11   | '1' when decoder input buffer contains a     |
|          | full frame of data ready to decode, '0'      |
|          | otherwise.                                   |
| J4/B12   | '1' when decoder output buffer contains      |
|          | data, '0' when empty.                        |

Special test points on connector J4 are enabled only when REG9(7) = '1'. High impedance otherwise.

## Schematics

The hardware schematics are available on the ComBlock CD shipped with every module.

## **Configuration Management**

This specification document is consistent with the following software versions:

COM-7001 FPGA firmware: Version 22 and above.

ComBlock Control Center graphical user interface: Revision 2.24 and above.

These software versions can be downloaded from <a href="http://www.comblock.com/download.htm">www.comblock.com/download.htm</a>

## Mechanical Interface



## Pinout

## Serial Link P1

The DB-9 connector is wired as data circuit terminating equipment (DCE). Connection to a PC is over a straight-through cable. No null modem or gender changer is required.



DB-9 Female

#### Input / Output Connectors

The pinout for the 40-pin input / output connectors can be selected by software command among three possible configurations:

- (a) full duplex
- (b) encoder only
- (c) decoder only

#### Full duplex mode



#### **Encoder-only mode**



#### **Decoder-only mode**





#### Interface with demodulator

The decoder input is designed for direct connection with the following modules:

COM-1001 BPSK/QPSK/OQPSK

#### demodulator

COM-1011/1018 DSSS Demodulator



#### Interface with modulator

The modulator output is designed for direct connection with the following modules:

COM-1002 BPSK/QPSK/OQPSK modulator

COM-1012/1019 DSSS modulator COM-1028 FSK/MSK/GFSK/GMSK modulator



**Baseband Interface (J3/J4 Male Connectors)** The baseband interface is designed for direct

connection with the following module: COM-5001 LAN/IP Network Interface



#### Baseband Interface (J2 Female Connector)

The baseband interface is designed for direct connection with the following module: COM-5001 LAN/IP Network Interface

### I/O Compatibility List

(not an exhaustive list)

| Input              | Output             |
|--------------------|--------------------|
| COM-5001 LAN/IP    | COM-5001 LAN/IP    |
| Network Interface  | Network Interface  |
| COM-1001           | COM-1002           |
| BPSK/QPSK/OQPSK    | BPSK/QPSK/OQPSK    |
| demodulator        | modulator          |
| COM-1011/1018 DSSS | COM-1012/1019 DSSS |
| demodulator        | modulator          |
| COM-1027           | COM-1028           |
| FSK/MSK/GFSK/GMSK  | FSK/MSK/GFSK/GMSK  |
| demodulator        | modulator          |

## **ComBlock Ordering Information**

COM-7001 TURBO CODE ENCODER / DECODER

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