

### Fall 2007 • Vol. 16, No. 3

#### Pentek, Inc.

One Park Way, Upper Saddle River, NJ 07458 Tel: (201) 818-5900 • Fax: (201) 818-5904 email: pipeline@pentek.com http://www.pentek.com

© 2007 Pentek, Inc. Newsletter Editor: TNT Resources Trademarks are properties of their respective owners. Specifications are subject to change without notice.

quarterly publication for engineering system design and applications.

## **Tools for Real-Time Embedded System Development**

### In This Issue

• Real-Time Embedded Systems **Development** is driven by the unique requirements of each application. More about the nature of hardware and software in the feature article.

"The philosophy of the hardware and software architectures presented here

should prove valuable in helping you make the correct decisions when starting your next



design of a real-time embedded system" Rodger Hosking, Pentek Vice **President and Cofounder** 

• Product Focus: Model 7142 multichannel transceiver with installed core -428. **Click here** 

#### **Technical Resources**

Download the 6th edition of the Digital Receiver Handbook: pentek.com/go/pipedrhb

Download the 3rd Edition of FPGAs for Software Radio Handbook: pentek.com/go/pipefpgahb

Download the 2nd Edition of Critical Techniques for High-Speed A/D **Converters in Real-Time Systems** Handbook:

pentek.com/go/pipehshb

ith each new opportunity, real-time embedded system developers confront a unique set of challenges specific to the requirements at hand. Although methodology and lessons learned in previous projects are invaluable, each new system introduces increasingly more complex hardware and software. Estimating correctly how long development will take, choosing the right approach, and selecting the appropriate tools are crucial for delivering the project on time and coming out ahead on the bottom line. Towards that end, the strategies, considerations and tradeoffs presented here should offer some useful insights.

#### Hardware Environment

A typical real-time embedded system, like the one shown in Figure 1, includes high-speed A/D and D/A converters plus the associated circuitry for clocking, gating, triggering and synchronizing multiple channels. Digital upconverter and downconverter ASICs provide frequency translation for communications and radar applications. FPGAs handle tough real-time signal processing tasks like FFTs, encoding and decoding, encryption and decryption, modulation and demodulation, and beamforming. A fast memory, buffers signal

data to support efficient block transfers to and from other system resources. Often, a fast hard disk allows the system to handle real-time storage and playback of signal data. A control processor manages system resources and often performs some additional signal processing and data formatting tasks.

Connected through an Ethernet link, a host PC workstation running Windows or Linux provides essential non-real-time hardware resources for the operator interface including a monitor, keyboard and mouse. The PC also provides high-capacity disk storage for archiving data files and network connections to the office or facility.

All the necessary hardware components are present, but which software components will ensure that the system performs the way it should?

### **Software Considerations**

A good choice for the real-time control processor is usually a DSP or RISC processor. It should be free of tasks not directly related to essential data movement, formatting or processing. During real-time operation, there should be minimum interaction with the PC. However, before and after real-time operations, the Ethernet link can be extremely useful for initializing the >



Figure 1. Real-Time Record/Playback System Hardware Components



# **Tools for Real-Time Recording System Development**

➤ real-time hardware, configuring modes of operation and for moving data between the real-time disk and the PC disk file system.

Figure 2 is a proposed software model for the real-time recording system shown in Figure 1, partitioned into real-time and nonreal-time domains and joined by Ethernet. While this diagram looks complicated at first, each software module serves a welldefined, essential function to maintain performance while easing software development tasks.

#### **Inside the Real-Time System**

The real-time system on the left side of Figure 2 uses a real-time operating system (RTOS) with low latencies and deterministic behavior to guarantee that no data will be lost while managing the critical tasks it needs to perform. The Board Support Libraries feature well-defined subroutine calls to implement low-level control for all of the real-time front-end hardware resources. This includes configuring the A/Ds and D/As, setting parameters for the digital up- and downconverters, and defining modes in the timing section for triggering, gating and synchronization.

The SCSI file system uses RTOS calls to manage real-time transfer to and from the local Fibre Channel hard disk. A Fibre Channel protocol layer provides a complete high-speed file system interface suitable for real-time recording and playback.

Nearly every RTOS also provides a native stack for Ethernet, TCP/IP drivers and support for sockets, a very popular application layer protocol for networks.

Each of these three resource groups the Board Support Libraries, the Fibre Channel interface and a network socket interface are integrated by the Record /Play Server API (Application Programming Interface) into a set of intuitive high-level functions to simplify development of custom server applications.

The Record/Play Server Application on top, acting as the executive in charge, has complete access to generate and receive Ethernet commands and status, directing real-time data streams on and off the Fibre Channel hard disk, and controlling all operating parameters and modes of the front end data acquisition hardware.



With these software components, the real-time hardware has now assumed the role of a complete, stand-alone functional server subsystem. It is capable of responding to Ethernet commands that are interpreted by the server application and then dispatched efficiently by the server API. When the function is complete, the server application can issue an Ethernet message along with any relevant parameters about the operation.

By extending the code in the server application so that it understands and implements different or more complex commands, the real-time subsystem can acquire new features. These new commands simply implement a new set of calls to the existing collection of Record/Play Server API functions. For example, a new Ethernet command might fetch data from the Fibre Channel disk and deliver back through the Ethernet port.

#### **Inside the Workstation PC**

The Workstation PC on the right side of Figure 2 assumes the role of the client, by sending and receiving Ethernet messages to and from the real-time server subsystem. Virtually all workstation operating systems include native support for Ethernet, TCP/IP, and sockets to support the message transfers. The Client API manages the socket message traffic by appropriately forming outgoing Ethernet commands so they are understood by the real-time server and interpreting status messages that are returned by the server. Like the Record/Play Server API, it presents a set of easy-to-use highlevel commands suitable for client user applications.

Additional socket connections deliver Ethernet data from the server into the Signal Viewer. This application delivers a graphical representation of signals on the PC screen, providing the operator with an oscilloscope display for viewing signal data. This can be useful for checking snapshots of live data from the A/D converter before recording, for verifying the live output of a digital downconverter, and for viewing the data recorded on the Fibre Channel hard drive after the recording.

Any such operations required by the client application, must first be implemented in the client API and then supported as formal commands by the server application. Of course, the necessary functions to execute those commands need to be available in the Record/Play Server API. If not, additional API functions can always be created as required.



## **Tools for Real-Time Recording System Development**

> One typical client application is a virtual instrument panel GUI (graphical user interface) displayed on the monitor. With buttons, knobs, sliders, switches, indicators, status windows and parameter entry windows, the operator simply uses the mouse and keyboard to control operations. Such an application can be written in Visual C, Visual Basic or JAVA to make a visually attractive and functional layout. The GUI would make the appropriate calls to the client API according to which buttons are pushed or which parameters are entered.

Another type of client application could be a larger application that needs a record/ play subsystem as an I/O resource. In this case, the larger application might be written in C or C++, or any other language supported by the operating system. Like the GUI, it would also make calls to the client API to setup up the hardware, start and stop the recording and then fetch data back into the application. By adding this type of functional subsystem that is easy to use and fully characterized, system developers can slash development time and reduce risks.

The rationale for each of the many software blocks shown in Figure 2 should now be appreciated. The modular architecture of this system helps custom application developers to take advantage of the standardized, well-defined interfaces between the modules to add new features, commands and functions. The existing commands and subroutine structures offer excellent examples for building new ones that are fully compliant with the rest of the system. Operating system revisions, maintenance upgrades, and ports to different operating systems all benefit from this modularity.

Figure 3 shows some appropriate candidates for the various modules discussed to illustrate the many choices available. Client workstation platforms for these systems range from handheld devices, blade servers, embedded PCs, laptops, and desktop PCs to networked clusters of high-end multiprocessing systems. In each case, the processors must support a diverse set of infrastructure functions best handled by operating systems like Windows, Linux, Unix, or Solaris.

|                                                              | CLIENT<br>Non-Real Time<br>Workstation PC | SERVER<br>Real-Time Play/Record<br>Sub-System |  |
|--------------------------------------------------------------|-------------------------------------------|-----------------------------------------------|--|
| Physical System                                              | Desktop, Laptop                           | VME, cPCI, PC/104                             |  |
| Processor                                                    | Pentium, PowerPC                          | PowerPC, DSP                                  |  |
| Operating System<br>Sockets, TCP/IP<br>Ethernet, File System | Windows<br>Linux<br>Solaris               | eCos<br>VxWorks<br>LynxOS                     |  |
| Application                                                  | JAVA, Visual C<br>Visual Basic, C, C++    | C, C++                                        |  |
| API (client / server)                                        | JAVA, C, C++                              | C, C++                                        |  |
| Signal Viewer                                                | LabVIEW                                   | -                                             |  |
| Board Support Libraries                                      | -                                         | C, C++                                        |  |
| FPGA Development                                             | Foundation ISE<br>GateFlow                | -                                             |  |

Client applications and the client API can be written in C or C++, and GUI components can use visual versions of these tools. A popular trend towards using JAVA for both the client applications and API helps with portability across platforms and operating systems. The signal viewer application is an ideal candidate for LabVIEW which offers tools specifically oriented towards signal processing and display, and is now available for many workstation environments.

By its nature, the real-time server system is less heterogeneous and runs under operating systems like VxWorks, eCos, or LynxOS. Most of the components, including the board support libraries, server application and API, and the network and disk drivers are all written in C or C++, with some lower level functions coded in assembly language.

#### **Putting It All Together**

Pentek's SystemFlow<sup>®</sup> is an implementation of this software framework. It was developed to address hardware platforms like the real-time recording/playback system of Figure 1, which is similar to the Pentek RTS 2504 Real-Time Recorder/Playback system. SystemFlow includes the software modules shown in Figure 2 written with the software tools highlighted in color in Figure 3. By following this proposed software architecture, SystemFlow successfully fulfills two different product objectives for the same hardware: 1) a ready-to-use record/playback instrument, and 2) a realtime signal processing development platform.

To meet the needs of the record/playback instrument, special enhancements were made. These include a complete virtual instrument GUI, a real-time file manager, and a full-featured signal viewer. The workstation GUI, shown in Figure 4 on the next page, was written in JAVA and runs under both Windows and Linux.

Intuitive buttons, indicators, status windows and parameter entry windows are geared for novice users who simply want to capture signals and transfer files to their workstation.

A sophisticated File Manager, implemented through extensions to both the client API (also written in JAVA) and the server API (written in C), supports usernamed files and headers that automatically store important system parameters in each recording.



## **Tools for Real-Time Recording System Development**

➤ The client Signal Viewer shown in Figure 5 is written in LabVIEW and includes display windows for both time and frequency domains, dual annotated cursors, and automatic calculation of critical signal parameters such as harmonic distortion and signal to noise ratio.

To meet the alternate needs of a realtime signal processing development platform, SystemFlow includes source code for the software modules that were created for the record/play instrument. System developers can start with this fully functioning instrument and incrementally extend, replace, or modify each module as required to meet the custom requirements they need.

For customizing workstation modules, JAVA source is provided for the client GUI application and client API, and the LabVIEW script is provided for the Signal Viewer.

For customizing server modules, a complete eCos development environment running under Windows offers license-free, open-source tools including the GNU compiler, Insight for the GDB debugger, CYGWIN make utilities, an eCos kernel configuration utility, and a TFTP server. C source code is supplied for the record/play server application and server API, the file manager and the socket interface. Pentek

Gate Flow

| RTS 2504                                                                                                                |                                                       | and Signa              |                                                                   |
|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|------------------------|-------------------------------------------------------------------|
| Setup<br>Configure                                                                                                      |                                                       | r Status:<br>Connected | Capacity:<br>70004 MB                                             |
| Acquire<br>Record Filename<br>Record Status: Positi<br>Stopped 1056<br>Data Loss                                        | 6157<br>on (MB): Data F                               |                        | Preview<br>© Ch. 1<br>© Ch. 2<br>Preview                          |
| @ DAC                                                                                                                   | Stopped P<br>Data Loss C<br>wer Ch. 2                 | Position (MB):<br>)    | Data Rate:<br>0 MB/s                                              |
| 01/09 13:48:56 00<br>01/09 14:35:12 00                                                                                  | 00006176 r1<br>00001184 r2                            | ename<br>tData         | File Properties<br>Save to Host<br>Delete                         |
| Used: 4272 MB                                                                                                           | Free: 65732 MB                                        | Larg                   | est Block: 61572 MB                                               |
| Current Disk Configura<br>SCSI ID Model<br>0 ST318452FC<br>1 ST318453FC<br>2 ST318452FC<br>3 ST318453FC<br>3 ST318453FC | ation<br>Capacity<br>17501<br>17501<br>17501<br>17501 | 0<br>0<br>0            | Block Size<br>5843670<br>5843686<br>5843670<br>5843686<br>5843686 |
| Figure 4. Pe                                                                                                            | entek RT<br>strumen                                   |                        | Virtual                                                           |

ReadyFlow<sup>®</sup> Board Support Libraries include C source code for the data movement, mode and parameter initialization, timing and control of all hardware resources on the boards. For FPGA code development, the Xilinx ISE Foundation Tool Suite is installed in the Windows workstation. The Pentek GateFlow® FPGA Design Kit contains all ISE project files and VHDL source code for the specific hardware boards. In this way, FPGA developers can build upon the standard interfaces and structures already instantiated. An FPGA code loader utility transfers newly created FPGA bit streams through the Ethernet link into the FPGA.

All software development tasks for the workstation, the real-time server, and the FPGAs are performed on the Windows workstation. All real-time server development tasks are supported across the Ethernet link through drivers and utilities. Except for the optional Xilinx ISE tools and GateFlow Design Kit, all these resources are bundled into the SystemFlow package.

The unique requirements of each realtime embedded system will drive choices in the hardware, the nature and function of the software modules, the operating systems and software languages. However, the philosophy of the software architecture outlined here should prove valuable in helping you make those decisions when starting your next design.













## GateFlow Transceiver with Four Multiband DDCs and Interpolation Filter - PMC/XMC 7142-428 Installed Core

## **General Information**

Model 7142-428, Digital Transceiver with Multiband DDC Core and Interpolation Filter, is a complete software radio system in a PMC/XMC module. It includes four A/D and one D/A converters capable of bandwidths to 40 MHz and above for connection to HF or IF ports of a communications or radar system.

The front end accepts four full scale analog HF or IF inputs on front panel MMCX connectors at +10 dBm into 50 ohms with transformer coupling into Linear Technology LTC2255 14-bit 125 MHz A/D converters.

The digital outputs are delivered to the Virtex-4 FPGA for signal processing or for routing to other module resources.

A TI DAC5686 digital upconverter (DUC) and D/A accepts a baseband real or complex data stream from the FPGA with signal bandwidths up to 40 MHz.

When operating as an upconverter, it interpolates and translates real or complex baseband input signals to any IF center frequency between DC and 160 MHz. It delivers real or quadrature (I+Q) analog output samples at up to 320 MHz to the 16-bit D/A converter. Analog output is through a front panel MMCX connector at +4 dBm into 50 ohms. If translation is disabled, the DAC5686 acts as an interpolating 16-bit D/A with output sampling rates up to 500 MHz.



## **Core 428 Multiband DDCs**

The Core 428 downconverter translates any frequency band within the input bandwidth range down to zero frequency. The DDCs consist of two cascaded decimating FIR filters. Each filter is capable of any decimation from 2 to 256. The decimations of the first stage filter and the second stage filter multiply to yield overall decimation factors up to 65,536.

The NCO provides over 108 dB spurious-free dynamic range (SFDR). The FIR filter is capable of storing and utilizing two

#### **Features**

- Complete software radio transceiver solution
- Four 125 MHz 14-bit A/Ds
- Two Xilinx Virtex-4 FPGAs
- One 500 MHz 16-bit D/A
- GateFlow Core 428 with four highperformance multiband DDCs and Interpolation Filter factory-installed
- Two sets of 18-bit user-programmable FIR filter coefficients
- Decimation range from 2 to 65,536
- Interpolation range from 2 to 32,768
- I/O bandwidths from 8 kHz to 40 MHz
- Multiple module synchronization

independent sets of user-programmable 18-bit coefficients.

Four identical Core 428 DDCs are factory installed in the 7142 FPGA. An input multiplexer allows any DDC to independently select any of the four A/D sources. The total decimation range from 2 to 65,536 provides output bandwidths from 50 MHz down to 1.52 kHz for an A/D sampling rate of 125 MHz and assuming an 80% filter.

#### **Core 428 Interpolation Filter**

The Core 428 interpolation filter increases

the sampling rate of real or complex baseband signals by a factor of 16 to 2048, programmable in steps of 4, and relieves the host processor from performing upsampling tasks. The interpolation filter can be used in series with the DUC's built-in interpolation, creating an interpolation factor up to 32,768.

For more information and a price quotation click here:

pentek.com/go/ pipe7142-428

