# Com Block

## COM-1505 INTEGRATED PSK MODEM

## Overview

The COM-1505 is a complete digital PSK modem, including PSK modulation, demodulation, convolutional error correction, V.35 scrambling, HDLC framing, TCP-IP network interface and USB 2.0 interface.

#### Key features and performance:

- PSK (BPSK, QPSK, OQPSK) modulation
- Continuous mode operation (i.e. Burst mode is not supported)
- Convolution error correction, rates 1/2, 2/3, 3/4, 5/6 and 7/8.
- Overall performance: 2.10<sup>-5</sup> BER @ 4dB Eb/No for K=7 rate <sup>1</sup>/<sub>2</sub> FEC.
- Serial HDLC to transmit empty frames over the synchronous link when no payload data is available.
- V.35 scrambling to randomize the modulated data stream.
- Maximum encoded data rate of 25 Msymbols/s.
- User interfaces:
  - Synchronous serial with elastic buffer or
  - GbE TCP-IP server
  - USB 2.0 FS/HS
- Demodulator performance:
  - BER: < 0.5 dB implementation losses w.r.t. theory
  - Programmable frequency acquisition range.
  - Demodulator acquisition threshold (uncoded) Eb/No = 1dB
- Includes test signal generation and bit error rate measurement.

- Monitoring:
  - o Receiver lock
  - Carrier frequency error
  - o SNR
- ComScope –enabled: key internal signals can be captured in real-time and displayed on host computer.
- Connectorized 3"x 3" module for ease of prototyping. Single 5V supply with reverse voltage and overvoltage protection. Interfaces with 3.3V LVTTL logic.



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

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

MSS • 18221-A Flower Hill Way • Gaithersburg, Maryland 20879 • U.S.A. Telephone: (240) 631-1111 Facsimile: (240) 631-1676 <u>www.ComBlock.com</u> © MSS 2013 Issued 4/25/2013



Modulator connectivity

## Options

Several interface types are supported through multiple firmware options. All firmware versions can be downloaded from

http://www.comblock.com/download.html

Changing the firmware option requires loading the firmware once using the ComBlock control center, then switching between the stored firmware versions The selected firmware option is automatically reloaded at power up or upon software command within 1.2 seconds

## Implementation Block Diagram







Transmitter

## Configuration

An entire ComBlock assembly comprising several ComBlock modules can be monitored and controlled centrally over a single connection with a host computer. Connection types include built-in types:

• USB, TCP-IP/LAN, Asynchronous serial (LVTTL),

or connections via adjacent ComBlocks.

The module configuration is stored in non-volatile memory.

## **Configuration (Basic)**

The easiest way to configure the COM-1505 is to use the **ComBlock Control Center** software supplied with the module on CD. In the **ComBlock Control Center** window detect the ComBlock module(s) by clicking the  $\checkmark$  *Detect* button, next click to highlight the COM-1505 module to be configured, next click the Settings button to display the *Settings* window shown below.

| COM1505 Integrated PSK Modem Basic Settings   |                                                                     |
|-----------------------------------------------|---------------------------------------------------------------------|
| Control                                       |                                                                     |
| Modulation & FEC encoding                     |                                                                     |
| Symbol rate (S/s) 7999992.4 [<60MS/s]         | DAC Sampling Rate (Hz): 63999939                                    |
| Modulation: QPSK 👻                            | Signal gain: 30000 [<65536]                                         |
| Output center frequency: 0 Hz                 | Spectrum inversion 🛛 👽 Channel filter                               |
| FEC encoding Differential encoding            | Convolutional FEC encoding: K=7, R=1/2, Intelsat 👻                  |
| V.35 scrambling VLC encoding                  | Input: LAN/TCP (8-bit parallel)                                     |
| Demodulation & FEC decoding                   |                                                                     |
| Nominal symbol rate (5/s): 8000000 [<50M5/s]  | Modulation: QPSK 🗸                                                  |
| Input center frequency: 0 Hz                  | Frequency acquisition range: 62500 Hz                               |
| AGC response time: 8 [0-14]                   | ☑ Internal AGC loop                                                 |
| FEC decoding 🔲 Differential decoding          | Viterbi FEC decoding: K=7, R=1/2, Intelsat 👻                        |
| ✓ V.35 descrambling                           | Input: 12-bit complex, right connector (J9) (COM-3504 compatible) 👻 |
| Output: LAN/TCP-IP port 1024 (8-bit parallel) |                                                                     |
| General                                       |                                                                     |
| external frequency reference                  |                                                                     |
| Apply Ok                                      | Advan Cancel                                                        |
|                                               |                                                                     |

## **Configuration (Advanced)**

Alternatively, users can access the full set of configuration features by specifying 8-bit control registers as listed below. These control registers can be set manually through the ComBlock Control Center or by software using the ComBlock API (see www.comblock.com/download/M&C reference.pdf)

All control registers are read/write. Definitions for the <u>Control registers</u> and <u>Status registers</u> are provided below.

#### **Control Registers**

The module configuration parameters are stored in volatile (SRT command) or non-volatile memory (SRG command). All control registers are read/write.

| Transmitter                             |                                                                            |  |
|-----------------------------------------|----------------------------------------------------------------------------|--|
| Parameters                              | Configuration                                                              |  |
| Input selection /<br>format, test modes | Select the origin of the transmitter input data stream.                    |  |
|                                         | 0 = high-speed USB, 8-bit<br>parallel                                      |  |
|                                         | 1 = LAN/TCP-IP, port 1024<br>(through Ethernet adapter), 8-bit<br>parallel |  |
|                                         | 2 = 1-bit synchronous serial                                               |  |
|                                         | 3 = internal PRBS-11 test sequence                                         |  |
|                                         | 5 = unmodulated carrier                                                    |  |
|                                         | 8-bit parallel input bytes are transmitted MSb first.                      |  |
|                                         | REG5(3:0)                                                                  |  |

| FEC convolutional encoder  |                                                                               |  |  |
|----------------------------|-------------------------------------------------------------------------------|--|--|
| Parameters                 | rameters Configuration                                                        |  |  |
| Constraint                 | 0001 = (K = 7, R = 1/2, Intelsat)                                             |  |  |
| length K and               | 0010 = (K = 7, R=2/3, Intelsat)                                               |  |  |
| rate R                     | 0011 = (K = 7, R = 3/4, Intelsat)                                             |  |  |
|                            | 0100 = (K = 7, R = 5/6, Intelsat)                                             |  |  |
|                            | 0100 = (K = 7, R = 7/8, Intelsat)<br>0101 = (K = 7, R = 7/8, Intelsat)        |  |  |
|                            | REG12(4:1)                                                                    |  |  |
| Differential               |                                                                               |  |  |
| Encoding                   | Differential encoding is useful in removing phase ambiguities at the PSK      |  |  |
|                            | demodulator, at the expense of doubling                                       |  |  |
|                            | the bit error rate.                                                           |  |  |
|                            | When enabled, the differential decoding must be enabled at the receiving end. |  |  |
|                            | There is no need to use the differential                                      |  |  |
|                            | encoding to remove phase ambiguities at                                       |  |  |
|                            | the PSK demodulator when the Viterbi                                          |  |  |
|                            | decoder and HDLC decoder are enabled.                                         |  |  |
|                            | 0 = disabled                                                                  |  |  |
|                            | 1 = enabled                                                                   |  |  |
|                            | REG12(5)                                                                      |  |  |
| Bypass FEC<br>encoding     | 0 = encoding enabled                                                          |  |  |
| encounig                   | 1 = bypass                                                                    |  |  |
|                            | REG12(6)                                                                      |  |  |
| V.35/Intelsat<br>IESS 308  | 0 = enabled                                                                   |  |  |
| scrambling                 | 1 = bypass                                                                    |  |  |
| before FEC<br>encoding     | REG12(7)                                                                      |  |  |
| HDLC                       | 0 = enabled                                                                   |  |  |
| encoding                   | • • • • • • • • • • • • • • • • • • • •                                       |  |  |
|                            | 1 = bypass<br>REG12(0)                                                        |  |  |
| DCV Madul                  |                                                                               |  |  |
| PSK Modula                 |                                                                               |  |  |
| Parameters                 | Configuration                                                                 |  |  |
| Processing<br>clock        | Modulator processing clock. Also serves as DAC sampling clock.                |  |  |
| <b>f</b> <sub>clk_tx</sub> | as DAC sampling clock.                                                        |  |  |
|                            | 20-bit unsigned integer expressed as                                          |  |  |
|                            | $f_{clk tx} * 2^{20} / 300 MHz.$                                              |  |  |
|                            |                                                                               |  |  |
|                            | 120 MHz maximum.                                                              |  |  |
|                            | 20 MHz recommended minimum                                                    |  |  |
|                            |                                                                               |  |  |
|                            | REG0 = bits 7-0 (LSB)                                                         |  |  |
|                            | REG1 = bits 15 - 8 (MSB)                                                      |  |  |
|                            | REG2(3:0) = bits 19 - 16 (MSB)                                                |  |  |
|                            | 1002(0.0) = 01000 = 10(0000)                                                  |  |  |

|                                             | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Internal/External<br>frequency<br>reference | 0 = internal. Use the internal 60 MHz<br>clock (from the USB PHY) as<br>frequency reference.<br>1 = external. Use the 10 MHz clock<br>externally supplied through the J7<br>SMA connector as frequency<br>reference.<br>REG2(7)                                                                                                                                  |
| Symbol rate<br>f <sub>symbol</sub> rate tx  | The modulator symbol rate is in the<br>form $\mathbf{f}_{symbol rate tx} = \mathbf{f}_{clk\_tx} / 2^{n}$<br>where n ranges from 1 ( $\mathbf{f}_{clk\_tx}$ is<br>twice the symbol rate) to 15 (symbol<br>rate = $\mathbf{f}_{clk\_tx} / 65536$ ).<br>n is defined in REG3(3:0)                                                                                   |
| Modulation type                             | 0 = BPSK<br>1 = QPSK<br>2 = OQPSK<br>REG4(5:0)                                                                                                                                                                                                                                                                                                                   |
| Spectrum<br>inversion                       | Invert Q bit. This is helpful in<br>compensating any frequency<br>spectrum inversion occurring in a<br>subsequent RF frequency translation.<br>0 = off<br>1 = on                                                                                                                                                                                                 |
|                                             | REG4(6)                                                                                                                                                                                                                                                                                                                                                          |
| Channel filter<br>enabled                   | 0 = enable the spectrum shaping<br>filters (root raised cosine,<br>interpolation)<br>1 = bypass the spectrum shaping<br>filters. (special use in applications                                                                                                                                                                                                    |
|                                             | when a root raised cosine filter is not<br>used in the demodulator.)<br>REG4(7)                                                                                                                                                                                                                                                                                  |
| Signal gain                                 | Signal level.<br>16-bit unsigned integer.<br>The maximum level should be<br>adjusted to prevent saturation. The<br>settings may vary slightly with the<br>selected symbol rate. Therefore, we<br>recommend <u>checking for saturation at</u><br><u>the D/A converter</u> when changing<br>either the symbol rate or the signal<br>gain.<br>REG6 = bits 7-0 (LSB) |
|                                             | REG7= bits 15-8 (MSB)                                                                                                                                                                                                                                                                                                                                            |

| r                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output<br>Center<br>frequency<br>(f <sub>cout</sub> ) | Frequency translation.<br>32-bit signed integer (2's complement<br>representation) expressed as<br>$f_{cout} * 2^{32} / f_{elk_tx}$<br>REG8 = bits 7-0 (LSB)<br>REG9 = bits 15 - 8<br>REG10 = bits 23 - 16<br>REG11 = bits 31 - 23 (MSB)<br>Option -C only<br>Set the nominal input bit rate in order to<br>generate a regular bit clock to the data<br>source. Must be consistent with the<br>modulator symbol rate, modulation type<br>and FEC rate.<br>Example: 2 Mbps : x051EB852 |
|                                                       | $f_{input bit rate tx} * 2^{32} / f_{clk_rx}$<br>REG13 = bits 7-0 (LSB)<br>REG14 = bits 15 - 8                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                       | REG15 = bit 23 - 16<br>REG16 = bit 31 - 23 (MSB)                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| External<br>transmitter<br>gain<br>control            | When using an external transceiver such as<br>the COM-350x family, the transmitter gain<br>can be controlled through the<br>TX_GAIN_CNTRL1 analog output signal.<br>Range $0 - 3.3V$ .<br>REG17 = bits 7-0 (LSB)<br>REG18(3:0) = bits 11-8                                                                                                                                                                                                                                            |
| External<br>transmitter<br>controls                   | REG19(0): TX_ENB<br>REG19(1) = RX_TXN                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Receiver                                          |                                                                                                                                                                                                                                                          |  |
|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PSK Demodula                                      | PSK Demodulator                                                                                                                                                                                                                                          |  |
| Parameters                                        | Configuration                                                                                                                                                                                                                                            |  |
| Processing clock                                  | The demodulator processing clock<br>also serves as A/D converter<br>sampling clock.                                                                                                                                                                      |  |
|                                                   | It can be generated within the FPGA or externally.                                                                                                                                                                                                       |  |
|                                                   | Code baseline $\mathbf{f}_{clk_rx} = 100 \text{ MHz}$                                                                                                                                                                                                    |  |
|                                                   | Note: when using IF undersampling,<br>a dedicated oscillator is<br>recommended as the FPGA-                                                                                                                                                              |  |
|                                                   | generated clock may show excessive<br>jitter (which translates into phase<br>noise).                                                                                                                                                                     |  |
| Nominal symbol rate                               | The demodulator nominal symbol rate is in the form $\mathbf{f}_{symbol rate rx} * 2^{32}$ /                                                                                                                                                              |  |
| <b>f</b> <sub>symbol</sub> rate rx                | f <sub>clk_rx</sub><br>REG25 = bits 7-0 (LSB)                                                                                                                                                                                                            |  |
|                                                   | $REG26 = bits \ 15 - 8$                                                                                                                                                                                                                                  |  |
|                                                   | REG27 = bit 23 - 16                                                                                                                                                                                                                                      |  |
|                                                   | REG28 = bit 31 – 23 (MSB)                                                                                                                                                                                                                                |  |
| Nominal Center<br>frequency $(\mathbf{f}_{c_rx})$ | Expected center frequency of the<br>received signal. 32-bit signed integer<br>(2's complement representation)<br>expressed as                                                                                                                            |  |
|                                                   | $\mathbf{f_{c_rx}} * 2^{32} / \mathbf{f_{clk_rx}}$                                                                                                                                                                                                       |  |
|                                                   | In the case of IF undersampling, the<br>residual intermediate frequency is<br>removed here. For example, in the<br>case of a 125 MHz IF signal sampled<br>at 100 Msamples/s, the 25 MHz<br>residual frequency is removed here<br>by entering 0x40000000. |  |
|                                                   | REG29 = bit 7-0 (LSB)                                                                                                                                                                                                                                    |  |
|                                                   | REG30 = bit 15 - 8                                                                                                                                                                                                                                       |  |
|                                                   | REG31 = bit 23 – 16                                                                                                                                                                                                                                      |  |
|                                                   | REG32 = bit 31 – 23 (MSB)                                                                                                                                                                                                                                |  |
| Modulation type                                   | 0 = BPSK                                                                                                                                                                                                                                                 |  |
|                                                   | 1 = QPSK                                                                                                                                                                                                                                                 |  |
|                                                   | 2 = OQPSK                                                                                                                                                                                                                                                |  |
|                                                   | REG33(5:0)                                                                                                                                                                                                                                               |  |

| clock                                                  | Spectrum<br>inversion                    | Invert Q bit. This is helpful in<br>compensating any frequency spectrum<br>inversion occurring during RF<br>frequency translations.<br>0 = off<br>1 = on<br>REG33(6)                                                                                                                                                                                                                                                              |
|--------------------------------------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IHz<br>mpling,                                         | High SNR                                 | To minimize the false lock probability<br>at high SNR, set this bit to '1' when<br>Eb/No is likely to exceed 10dB. To<br>emphasize operation at very low Eb/No,<br>set this bit to '0'<br>REG33(7)                                                                                                                                                                                                                                |
| $\frac{\text{accessive}}{\text{mbol}}$                 | Frequency<br>acquisition<br>range (scan) | The demodulator natural frequency<br>acquisition range is around 1% of the<br>symbol range (depending on<br>modulation, SNR). The frequency<br>acquisition range can be extended by<br>frequency scanning. Scanning steps are<br>spaced ( $\mathbf{f}_{symbol rate rx}$ /128) apart. The user<br>can thus trade-off acquisition time<br>versus frequency acquisition range by<br>specifying the number of scanning steps<br>here. |
| f the<br>l integer<br>on)                              |                                          | For example, 16 steps yield a frequency<br>acquisition range of +/-( <b>f</b> <sub>symbol rate rx</sub><br>*12.5%)<br>REG24                                                                                                                                                                                                                                                                                                       |
| ng, the<br>icy is<br>in the<br>sampled<br>Hz<br>d here | AGC<br>response time                     | Users can to optimize the AGC response<br>time while avoiding instabilities<br>(depends on external factors such as<br>gain signal filtering at the RF front-end<br>and symbol rate). The response time is<br>approximately:<br>0 = 8 symbols,<br>1 = 16 symbols,<br>2 = 32 symbols,<br>3 = 64 symbols, etc<br>10 = every thousand symbols.<br>Valid range 0 to 14.<br>REG34(4:0)                                                 |
|                                                        | AGC internal / external                  | 0 = internal AGC<br>1 = external AGC<br>When selecting internal AGC mode, the<br>user is responsible for avoiding<br>saturation at or prior to the A/D<br>converter.                                                                                                                                                                                                                                                              |
|                                                        |                                          | The internal AGC maximum gain is 256<br>in amplitude (48 dB in power).<br>Therefore, it is recommended to keep<br>the input samples amplitude between                                                                                                                                                                                                                                                                             |
|                                                        |                                          | 7                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Input selection                                                    | <ul> <li>maximum and maximum/256. In the input dynamic range is larger, please adjust the INTERNAL_AGC_005 process within <i>RECEIVER1.vhd</i>.</li> <li>REG34(7)</li> <li>0 = digital real 12-bit unsigned samples, right connector, COM-3504 transceiver. Use in the case of IF input signal.</li> <li>1 = digital complex 2*12-bit unsigned samples, right connector, COM-3504 transceiver</li> <li>Use in case of baseband (near-zero center frequency) input signal.</li> <li>7 = internal loopback mode, from modulator.</li> <li>REG35(2:0)</li> </ul> |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Viterbi FEC d                                                      | , ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Parameters                                                         | Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Constraint<br>length K and<br>rate R                               | 0001 = (K = 7, R=1/2, Intelsat) $0010 = (K = 7, R=2/3, Intelsat)$ $0011 = (K = 7, R=3/4, Intelsat)$ $0100 = (K = 7, R=5/6, Intelsat)$ $0101 = (K = 7, R=7/8, Intelsat)$ $REG37(4:1)$                                                                                                                                                                                                                                                                                                                                                                          |
| Differential<br>Decoding                                           | 0 = disabled $1 = enabled$ $REG37(5)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Bypass FEC<br>decoding                                             | 0 = decoding enabled<br>1 = bypass<br>REG37(6)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| V.35/Intelsat<br>IESS 308<br>descrambling<br>after FEC<br>decoding | 0 = enabled<br>1 = bypass<br>REG37(7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| HDLC<br>decoding                                                   | 0 = enabled<br>1 = bypass<br>REG37(0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Output<br>selection                                                | 0 = high-speed USB, 8-bit parallel<br>1 = LAN/TCP-IP, port 1024 (through<br>Ethernet adapter), 8-bit parallel<br>2 = 1-bit synchronous serial<br>3 = exclusively to the BER<br>measurement<br>REG36(2:0)                                                                                                                                                                                                                                                                                                                                                      |
| Enable test<br>points                                              | Enable (1)/Disable (0) test points on J6<br>connector<br>REG36(7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Network Interface                                                                          |                                                                                                                                                                                                                                    |  |
|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Parameters                                                                                 | Configuration                                                                                                                                                                                                                      |  |
| IP address<br>(when<br>connected to<br>Gbit Ethernet<br>PHY like<br>COM-5102,<br>COM-5104) | 4-byte IPv4 address.<br>Example : 0x AC 10 01 80 designates<br>address 172.16.1.128<br>The new address becomes effective<br>immediately (no need to reset the<br>ComBlock).<br>REG41: MSB<br>REG42<br>REG43<br>REG43<br>REG44: LSB |  |

(Re-)Writing to the last control register REG44 is recommended after a configuration change to enact the change.

#### **Configuration example**

#### Modulator:

2 Msymbols/s modulation, BPSK, convolutional encoding K=7 R=1/2, PRBS-11 test sequence, baseband (0Hz) complex (I/Q) modulated output signal.



Typical RF output spectrum (after D/A conversion and direct RF modulation)

## **Status Registers**

Digital status registers are read-only.

| PSK/QAM/APSK Demodulator Monitoring                         |                                                                                                                                                                                                                                                                                                                                             |  |  |
|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Parameters                                                  | Monitoring                                                                                                                                                                                                                                                                                                                                  |  |  |
| Front-end<br>AGC                                            | 8-bit unsigned value prior to DAC<br>conversion to RX_AGC1. Inverted<br>scale: 0 is for the maximum gain.<br>SREG10                                                                                                                                                                                                                         |  |  |
| Carrier<br>frequency<br>offset<br>(fcdelta)<br>Carrier      | Residual frequency offset with respect<br>to the nominal carrier frequency.<br>24-bit signed integer (2's complement)<br>expressed as<br>fcdelta $* 2^{24} / f_{clk\_rx}$ .<br>SREG11 = LSB<br>SREG12<br>SREG13 = MSB<br>Lock is declared if the standard                                                                                   |  |  |
| tracking loop<br>lock status                                | deviation of the phase error is less than<br>25deg rms.<br>0 = unlocked<br>1 = locked<br>SREG14(0)                                                                                                                                                                                                                                          |  |  |
| Inverse SNR                                                 | A measure of noise over signal power.<br>0 represents a noiseless signal. Valid<br>only when demodulator is locked.<br>SREG15                                                                                                                                                                                                               |  |  |
| Viterbi FEC de                                              | coder monitoring                                                                                                                                                                                                                                                                                                                            |  |  |
| Parameters                                                  | Monitoring                                                                                                                                                                                                                                                                                                                                  |  |  |
| Synchronized                                                | (FEC_DEC_LOCK_STATUS variable)<br>Solid '1' when the Viterbi decoder is<br>locked. '0' or toggling when unlocked.<br>SREG14(1)                                                                                                                                                                                                              |  |  |
| Decoder built-<br>in BER                                    | The Viterbi decoder computes the BER                                                                                                                                                                                                                                                                                                        |  |  |
|                                                             | on the received (encoded) data stream<br>irrespective of the transmitted bit<br>stream. Encoded stream bit errors<br>detected over a 1000-bit measurement<br>window (unless modified in<br><i>com1509pkg.vhd</i> ).<br>SREG16 = bits 7 - 0 (LSB)<br>SREG17 = bits 15 - 8<br>SREG18 = bits 23 - 16 (MSB)                                     |  |  |
| HDLC decoder                                                | irrespective of the transmitted bit<br>stream. Encoded stream bit errors<br>detected over a 1000-bit measurement<br>window (unless modified in<br>com1509pkg.vhd).<br>SREG16 = bits 7 – 0 (LSB)<br>SREG17 = bits 15 – 8<br>SREG18 = bits 23 – 16 (MSB)                                                                                      |  |  |
| HDLC decoder<br>Parameters                                  | irrespective of the transmitted bit<br>stream. Encoded stream bit errors<br>detected over a 1000-bit measurement<br>window (unless modified in<br>com1509pkg.vhd).<br>SREG16 = bits 7 – 0 (LSB)<br>SREG17 = bits 15 – 8<br>SREG18 = bits 23 – 16 (MSB)                                                                                      |  |  |
|                                                             | irrespective of the transmitted bit<br>stream. Encoded stream bit errors<br>detected over a 1000-bit measurement<br>window (unless modified in<br>com1509pkg.vhd).<br>SREG16 = bits 7 - 0 (LSB)<br>SREG17 = bits 15 - 8<br>SREG18 = bits 23 - 16 (MSB)<br>monitoring                                                                        |  |  |
| Parameters<br>Cumulative<br>number of valid<br>bits at HDLC | irrespective of the transmitted bit<br>stream. Encoded stream bit errors<br>detected over a 1000-bit measurement<br>window (unless modified in<br><i>com1509pkg.vhd</i> ).<br>SREG16 = bits 7 – 0 (LSB)<br>SREG17 = bits 15 – 8<br>SREG18 = bits 23 – 16 (MSB)<br>monitoring<br>SREG19: LSB<br>SREG20:<br>SREG20:<br>SREG21:<br>SREG22: MSB |  |  |

| Bit Errors             | Bit errors can be counted when a PRBS-<br>11 test sequence is transmitted.                                                            |  |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|
|                        | Number of bit errors in a 1,000,000 bit<br>window.<br>32 bit unsigned.<br>SREG23: error_count[7:0] (LSB)<br>SREG24: error_count[15:8] |  |
|                        | SREG25: error_count[23:16]                                                                                                            |  |
|                        | SREG26: error_count[31:24] (MSB)                                                                                                      |  |
|                        | The bit errors counter is updated once<br>every periodic measurement window.<br>Reading the value will not reset the<br>counter.      |  |
| BER<br>Synchronization | 0 = not synchronized. 2047-bit pattern is not detected.                                                                               |  |
| status                 | 1 = synchronized                                                                                                                      |  |
|                        | SREG27(0)                                                                                                                             |  |
| <b>TCP-IP</b> Conne    | ction Monitoring                                                                                                                      |  |
| Parameters             | Monitoring                                                                                                                            |  |
| TCP-IP                 | Bit 0 = port 1028 (M&C) connected                                                                                                     |  |
| connection on          | Bit $1 = \text{port } 1024 \text{ (data) connected}$                                                                                  |  |
| port 1024              | 1 for connected, 0 otherwise                                                                                                          |  |
| (data stream)          | SREG28(1:0)                                                                                                                           |  |
| LAN PHY ID             | Expect 0x22 when the PHY IC is Micrel KSZ9021.                                                                                        |  |
|                        | SREG29(LSB)                                                                                                                           |  |
| MAC address            | Unique 48-bit hardware address (802.3).<br>In the form<br>SREG30:SREG31:SREG32::SREG35                                                |  |
|                        | Since the MAC address is unique, it can<br>also be used as a unique identifier in a<br>radio network with many nodes.                 |  |

Note: multi-words status registers such as frequency offset or BER, are latched upon reading status register SREG10.

## Troubleshooting checklist

1. Place modem in loopback mode (REG35 = 0x07) while sending a PRBS-11 test sequence (REG5 = 0x03). Be sure to direct the demodulated bit stream to the BER measurement (REG36 = 0x03).

Check the status registers for

- a. Demodulator and Viterbi decoder are locked: SREG14 = 0x03
- b. No Viterbi decoder errors: SREG16/17/18 = 0
- c. BER measurement is synchronized: SREG27 = 0x01
- d. No BER errors: SREG23/24/25/26 = 0
- e. Bits are being received at the HDLC decoder output: SREG19/20/21/22 counter keeps increasing at a rate consistent with the modulation rate.

## ComScope Monitoring

Key internal signals can be captured in real-time and displayed on a host computer using the ComScope feature of the ComBlock Control Center. The COM-1505 signal traces and trigger are defined as follows:

| Trace 1 signals                          | Format   | Nominal sampling | Buffer<br>length |
|------------------------------------------|----------|------------------|------------------|
|                                          |          | rate             | (samples)        |
| 1: Input signal (I-                      | 8-bit    | Input            | 512              |
| channel) after AGC,                      | signed   | sampling         |                  |
| frequency translation,<br>CIC decimation |          | rate/R           |                  |
| 2: phase after                           | 8-bit    | 1 sample /       | 512              |
| scanning and before                      | signed   | symbol           |                  |
| final carrier tracking loop              |          |                  |                  |
| 3: Magnitude after                       | 8-bit    | 1 sample /       | 512              |
| final AGC                                | signed   | symbol           |                  |
| 4: symbol timing                         | 8-bit    | 1 sample /       | 512              |
| tracking correction                      | unsigned | symbol           |                  |
| (accumulated)<br>Trace 2 signals         | Format   | Nominal          | Buffer           |
| Trace 2 signals                          | ronnat   | sampling         | length           |
|                                          |          | rate             | (samples)        |
| 1: Input signal (Q-                      | 8-bit    | Input            | 512              |
| channel) after AGC,                      | signed   | sampling         |                  |
| frequency translation,<br>CIC decimation |          | rate/R           |                  |
| 2: Demodulated I                         | 8-bit    | 1 sample /       | 512              |
| channel                                  | signed   | symbol           |                  |
| 3: Input signal I-                       | 8-bit    | Input            | 512              |
| channel                                  | signed   | sampling         |                  |
|                                          | 0.1.1    | rate             | 510              |
| 4: PLL Carrier<br>tracking phase         | 8-bit    | Input            | 512              |
| correction                               | signed   | sampling<br>rate |                  |
| (accumulated)                            |          |                  |                  |
| Trace 3 signals                          | Format   | Nominal          | Buffer           |
|                                          |          | sampling         | length           |
| 1: Input signal Q-                       | 8-bit    | rate<br>Input    | (samples)        |
| channel                                  | signed   | sampling         | 512              |
|                                          | Signed   | rate             |                  |
| 2: final AGC gain                        | 8-bit    | variable         | 512              |
|                                          | signed   |                  |                  |
| Trigger Signal                           | Format   |                  |                  |
| N/A                                      |          |                  |                  |

Signals sampling rates can be changed under software control by adjusting the decimation factor and/or selecting the  $\mathbf{f}_{\text{clk_rx}}$  processing clock as real-time sampling clock.

In particular, selecting the  $\mathbf{f}_{clk,rx}$  processing clock as real-time sampling clock allows one to have the same time-scale for all signals.

The ComScope user manual is available at www.comblock.com/download/comscope.pdf.



ComScope example: showing demodulated Ichannel (red) and received phase after scanning/before tracking (blue)

#### **Digital Test Points**

Enabled if REG36(7) = '1', high-impedance otherwise.

| Test                 | Definition                                   |
|----------------------|----------------------------------------------|
| Point                |                                              |
| J6/A29               | Carrier locked                               |
| J6/A30               | Recovered carrier: scanner                   |
| J6/A31               | Recovered carrier: PLL                       |
| _J6/A32              | Overall demodulator lock (STATE=2)           |
| J6/A33               | Phase ambiguity removal step (pulse)         |
| <sub>E</sub> J6/A34  | Reset demodulator in false lock (pulse)      |
| [J6/A35              | Viterbi decoder locked                       |
| <sup>60</sup> J6/A36 | BER tester synchronized                      |
| J6/A37               | Byte error detected by BER tester            |
| J6/A38               | BER tester detecting periodic start of PRBS- |
| · ·                  | 11 test sequence                             |

## Operation

## **Constellation: Symbol Mapping**

The packing of serial data stream into symbols is done with the Most Significant bit first.

#### BPSK





Gray encoding.



#### Recovery

This module is protected against corruption by an invalid FPGA configuration file (during firmware upgrade for example) or an invalid user configuration. To recover from such occurrence, connect a jumper in JP1 position 2-3 prior and during power-up. This prevents the FPGA configuration and restore communication. Once this is done, the user can safely re-load a valid FPGA configuration file into flash memory using the ComBlock Control Center.

## I/Os

#### 1-bit synchronous serial (-B option)



In the transmit direction, the user provides both clock (CLK\_IN) and data (TX\_DATA\_IN). The user should always check the "Clear-To-Send" CTS\_OUT flag before sending additional data bits to the modulator. As option **–B** includes HDLC, the user is allowed not to transmit data. When so, the modem will send empty HDLC frames.

#### 1-bit synchronous serial (-C option)



In the transmit direction, the user provides serial data (TX\_DATA\_IN), preferably at the falling edge of the modem-supplied CLK\_IN. The TX\_DATA\_IN is read at the rising edge of CLK\_IN. The user MUST provide data, otherwise an underflow condition will occur. Option –C is for continuous-mode operation. No gap in data

transmission is allowed.

## **TCP-IP (-A option)**

The transmit and receive data streams can also be transferred over a TCP-IP network connection. This requires an additional Ethernet PHY with standard RGMII or GMII interface (a COM-5102 plug-in Ethernet adapter for example).

In this case, the modem acts as a TCP server, waiting for connection from a remote client at port 1024. A unique IP address and a unique MAC address must be assigned to the modem (see control registers REG41 through REG50).

The TCP-IP protocol guarantees that no overflow will occur in the user to modem direction. The built-in flowcontrol mechanism of the TCP-IP will prevent the user application from writing more data than the modem can handle for the specified data rate.

In the receiver to user direction however, it is the user's responsibility to read data as fast as possible to prevent an overflow condition from occurring at the receiver.

The TCP bytes are sent/received serially, most-significant bit first.

The modem monitoring and control information can also be sent over the same physical link, using the TCP server at port 1028.

More information regarding the built-in 10/100/1000 Mbps Ethernet MAC and the TCP server can be found here:

www.comblock.com/download/com5401soft.pdf www.comblock.com/download/com5402soft.pdf

#### USB

Data streams can also be transmitted over a USB 2.0 cable, together with monitoring and control information. This modem acts as a USB device. See http://comblock.com/download/USB20\_UserManual.pdf for details.

More information regarding the built-in USB 2.0 Serial Interface Engine (SIE) can be found here: <u>http://comblock.com/download/USB2soft.pdf</u>

## Performance



BER performance, demodulator only (no FEC)



BER performance, FEC only (no demodulator)

## **Absolute Maximum Ratings**

| Supply voltage                | -0.5V min, +6V |
|-------------------------------|----------------|
|                               | max            |
| 40-pin connector inputs (when | -0.5V min,     |
| configured as LVTTL)          | +3.6V max      |

#### Important: I/O signals are 0-3.3V LVTTL. Inputs are NOT 5V tolerant!

## Mechanical Interface



## Schematics

The board schematics are available on-line at <a href="http://comblock.com/download/com\_1500schematics.pdf">http://comblock.com/download/com\_1500schematics.pdf</a>

## Pinout

#### USB

Both USB ports are equipped with mini type AB connectors. (G = GND). In both cases, the COM-1524 acts as a USB device.



#### Left Connector J6



This interface is compatible with the COM-5102/COM- 5401

10/100/1000 Mbps Ethernet PHY

. (-A firmware)



2\*16-bit output samples, 2\*12-bit input samples. This interface is compatible with the COM-3504 dual Analog<->Digital Conversions.

#### I/O Compatibility List

(not an exhaustive list)

| Left connector (J6)                               |  |  |
|---------------------------------------------------|--|--|
| <u>COM-5102</u> Gigabit Ethernet + HDMI interface |  |  |
| COM-5401 4-port 10/100/1000 Mbps Ethernet         |  |  |
| Transceivers (limited to one port)                |  |  |
| COM-1500 FPGA + DDR2 SODIMM socket + ARM          |  |  |
| development platform                              |  |  |
| Right connector (J9)                              |  |  |
| COM-3504 Dual Analog <-> Digital Conversions      |  |  |
| COM-1524 channel emulator                         |  |  |
| COM-1500 FPGA + DDR2 SODIMM socket + ARM          |  |  |
| development platform                              |  |  |

#### **Configuration Management**

This specification is to be used in conjunction with VHDL software revision 6.

## **ComBlock Ordering Information**

COM-1505 Integrated PSK modem

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