

# PulseBlasterUSB<sup>™</sup> (v2)

(USB Board SP9, SP48, SP50)

(USB Rackmount System SP45)

### **Owner's Manual**



SpinCore Technologies, Inc. www.spincore.com

# Congratulations and *thank you* for choosing a design from SpinCore Technologies, Inc.

We appreciate your business!

At SpinCore, we aim to fully support the needs of our customers. If you are in need of assistance, please contact us and we will strive to provide the necessary support.

© 2013-2022 SpinCore Technologies, Inc. All rights reserved.

SpinCore Technologies, Inc. reserves the right to make changes to the product(s) or information herein without notice. PulseBlasterUSB™, PulseBlaster™, SpinCore, and the SpinCore Technologies, Inc. logos are trademarks of SpinCore Technologies, Inc. All other trademarks are the property of their respective owners.

SpinCore Technologies, Inc. makes every effort to verify the correct operation of the equipment. This equipment version is not intended for use in a system in which the failure of a SpinCore device will threaten the safety of equipment or person(s).

## Table of Contents

| <u>I. Int</u> | roduction6                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | Product Overview                                                                                                                                                                                                                                                                                                                                                                           |
| <u>II. S</u>  | ystem Architecture and Specifications7                                                                                                                                                                                                                                                                                                                                                     |
|               | System Architecture 7                                                                                                                                                                                                                                                                                                                                                                      |
|               | System Architecture         7           Output Signals         7                                                                                                                                                                                                                                                                                                                           |
|               | Timing Characteristics                                                                                                                                                                                                                                                                                                                                                                     |
|               | Instruction Set                                                                                                                                                                                                                                                                                                                                                                            |
|               | External Triggering8                                                                                                                                                                                                                                                                                                                                                                       |
|               | Summary                                                                                                                                                                                                                                                                                                                                                                                    |
|               | Specifications9                                                                                                                                                                                                                                                                                                                                                                            |
|               | Output Channels9                                                                                                                                                                                                                                                                                                                                                                           |
|               | Pulse Timing9                                                                                                                                                                                                                                                                                                                                                                              |
|               | Pulse Program Flow Control9                                                                                                                                                                                                                                                                                                                                                                |
| <u>III. h</u> | nstallation10<br>Installing the SpinAPI Driver and Control Library10                                                                                                                                                                                                                                                                                                                       |
|               | Installing the SpinAPI Driver and Control Florary                                                                                                                                                                                                                                                                                                                                          |
|               |                                                                                                                                                                                                                                                                                                                                                                                            |
|               | Testing the PulseBlaster                                                                                                                                                                                                                                                                                                                                                                   |
| <u>IV. P</u>  |                                                                                                                                                                                                                                                                                                                                                                                            |
| <u>IV. P</u>  | Testing the PulseBlaster10                                                                                                                                                                                                                                                                                                                                                                 |
| <u>IV. P</u>  | Testing the PulseBlaster                                                                                                                                                                                                                                                                                                                                                                   |
| <u>IV. F</u>  | Testing the PulseBlaster                                                                                                                                                                                                                                                                                                                                                                   |
| <u>IV. P</u>  | Testing the PulseBlaster                                                                                                                                                                                                                                                                                                                                                                   |
| <u>IV. F</u>  | Testing the PulseBlaster                                                                                                                                                                                                                                                                                                                                                                   |
| <u>IV. F</u>  | Testing the PulseBlaster                                                                                                                                                                                                                                                                                                                                                                   |
|               | Testing the PulseBlaster.       10         Programming the PulseBlasterUSB.       13         Introduction.       13         Programming with the PulseBlaster Interpreter.       13         Programming with PulseBlaster.NET.       14         Programming in C/C++ using SpinAPI.       15         LabVIEW Extensions.       16                                                          |
|               | Testing the PulseBlaster.       10         Programming the PulseBlasterUSB       13         Introduction       13         Programming with the PulseBlaster Interpreter       13         Programming with PulseBlaster.NET       14         Programming in C/C++ using SpinAPI       15         LabVIEW Extensions       16         Programming with Third-Party GUI Environments       17 |

| SP9 PulseBlasterUSB Board Specific Pin Assignments                      | <u>19</u> |
|-------------------------------------------------------------------------|-----------|
| JP303 IDC Header for PulseBlasterUSB Board (SP9, Main Output Connector) | 19        |
| JP301 IDC Header (Trig/Res/Stat) for SP9 PulseBlasterUSB Board          | <u>20</u> |
| SP48 and SP50 PulseBlasterUSB Board Specific Pin Assignments            | 21        |
| Shrouded IDC Connector FLAG[011] OUT Pin Assignments                    |           |
| Shrouded IDC Connector FLAG[1223] OUT Pin Assignments                   |           |
| HW_RESET/TRIG IDC Header (Trig/Res/Stat) for SP48 and SP50 PulseBlaster |           |
| Board                                                                   |           |
| SMA Connector CLK_OUT                                                   | 23        |
| SMA Connector EXT_CLK                                                   |           |
| Connector Information for Single-bay Enclosure                          | 24        |
| AC Power Connector.                                                     |           |
| DB9 Connector (Trig/Res/Stat)                                           | 24        |
| Status Pins Description                                                 |           |
| Centronics Connector.                                                   |           |
|                                                                         |           |
| Connector Information for 2U BNC/TNC Enclosure                          | 28        |
| DB9 Connector (Trig/Res/Stat) for 2U BNC/TNC Enclosure                  |           |
| Front Panel Connectors for 2U BNC/TNC Enclosure                         | 28        |
| Clock Input Signal Standard                                             |           |
|                                                                         |           |
| Connector Information for 2U BNC Rackmount Enclosure                    |           |
| DB9 Connector (Trig/Res/Stat) for 2U BNC Rackmount Enclosure            | <u>29</u> |
| Clock Oscillator Header                                                 | <u>31</u> |
| Appendix I. Instruction Set Architecture                                | <u>32</u> |
| Instruction Set Architecture of the PulseBlaster Processor              | 22        |
| Machine-Word Definition                                                 |           |
| Breakdown of 80-bit Instruction Word                                    |           |
| Output Pattern and Control Word                                         |           |
| Data Field and Op Code                                                  |           |
| Delay Count.                                                            |           |
| Appendix II. User Programmable Clock Output Design                      | 25        |
| Appendix II. User Programmable Clock Odiput Design                      |           |
| Programming the Clock Feature in C/C++                                  | <u>36</u> |
| Example Use of Programmable Clock Feature in C/C++                      | 36        |
|                                                                         |           |
| Related Products and Accessories                                        | <u>37</u> |
| Contact Information                                                     | 20        |
| Contact Information                                                     |           |

| Document Information |
|----------------------|
|----------------------|

## I. Introduction

#### **Product Overview**

The PulseBlasterUSB<sup>™</sup> is a programmable multichannel pulse/delay generator that is capable of generating pulses and delays ranging from 50 ns to 4.5x10<sup>7</sup> seconds (~521 days) in length when operating with a 100 MHz clock frequency. The PulseBlasterUSB has up to 24 output channels, features highly flexible program flow control, and can accommodate pulse programs containing up to 4096 instructions; if more instructions are necessary, please contact SpinCore for more information. The PulseBlasterUSB is capable of generating complex output pulse patterns featuring very short and very long pulses in the same sequence with a resolution of one clock period (i.e., 10 ns at 100 MHz).

The intelligence of the PulseBlasterUSB comes from its proprietary microprocessor core architecture. Unlike general-purpose processors, the PulseBlaster processor features a highly optimized instruction set that has been specifically designed for timing applications. A unique and distinguishing feature of the PulseBlaster processor is that the execution time of instructions is user programmable.

User interaction with the PulseBlasterUSB can be accomplished in several different ways. The *PulseBlaster Interpreter* and *PulseBlaster.NET*, SpinCore's graphical programming environments for Windows, allow users to easily create, edit, save and run pulse programs. Graphical User Interfaces (GUI) for MATLAB and LabVIEW have also been developed and are available for download from SpinCore Technologies, Inc. at no charge. PulseBlasterUSB can be controlled through user input of either software or hardware triggering.

Development environments like LabVIEW, MATLAB, and C/C++ can be used to interface with the PulseBlasterUSB through the dedicated Application Programming Interface (API) package called SpinAPI. The SpinAPI package can be used with virtually all Windows programming environments and can also be used with other operating systems, including Linux.

The PulseBlasterUSB is a USB 2.0 device, and can be easily integrated into a wide range of computer systems. USB 2.0 provides an easy to use device which can be quickly connected to almost any computer system, while still providing all the functionality given by the PulseBlaster PCI board.

The PulseBlasterUSB is available in two standard options: a) the board-only option with no enclosure (+5 V DC required), and b) the 2U BNC Rackmount enclosure (full width). The enclosed option include the internal AC/DC power supply.

The 2U BNC Rackmount enclosure (full width) is standard.

## **II. System Architecture and Specifications**

#### **System Architecture**

Figure 1 presents the internal architecture of the PulseBlasterUSB system. The major building blocks are the SRAM memory, the microcontroller (uPC), the integrated bus controller (IBC), the counter, and the output buffers. The entire logic design, including output buffers, is contained on a single silicon chip, making it a System-on-Chip design. User control of the system is accomplished via the USB bus.



**Figure 1**: PulseBlasterUSB system architecture. The clock oscillator signal originates from an on-chip PLL circuit with a typical base frequency of 50 MHz.

The next page describes the *general* characteristics of the PulseBlasterUSB. For more detailed information on the *internal* operation of the PulseBlaster processor, please see **Appendix I. Instruction Set Architecture**.

#### **Output Signals**

The PulseBlasterUSB has up to 24 digital output signal lines. All output signal lines are impedance matched to 50 ohm. The individually controlled digital output bits are 3.3V TTL standard unterminated, and are capable of delivering in excess of 25 mA per bit/channel.

#### **Timing Characteristics**

The PulseBlasterUSB's timing controller accepts an on-board crystal oscillator (or externally applied 3.3V TTL clock signal) of 50 MHz. The innovative architecture of the timing controller allows the processing of either simple timing instructions (delays of up to  $2^{32}$  –1 clock cycles, e.g., approximately 43 seconds at 100 MHz), or double-length timing instructions (up to  $2^{52}$  –1 clock cycles, equivalent to  $4.5 \times 10^7$  seconds, or approximately 521 days, at 100 MHz). Regardless of the type of timing instruction, the timing resolution remains constant for any delay – just one clock period (e.g., 10 ns at 100 MHz).

The core timing controller has a very short minimum delay cycle – only five clock periods. This translates to a 50 ns shortest pulse/delay at 100 MHz.

#### Instruction Set

The PulseBlasterUSB's instruction set allows for highly flexible program flow control. The core microcontroller allows for programs to include branches, subroutines, and loops at up to 8 nested levels – all of this to assist the user in creating dense pulse programs that can cycle through repetitious events, such as those required for multidimensional spectroscopy and imaging applications.

#### External Triggering

The PulseBlasterUSB can be triggered and/or reset externally via dedicated hardware lines. These two hardware lines, Hardware Trigger and Hardware Reset, are pulled high via 10 kOhm resistors and the required control signals are "low-true." This means the control signals will become true on the falling edge and remain true while held at ground. Trigger occurs when the trigger pin is shorted to ground. To protect hardware, do not exceed the recommended voltage levels.

#### Summary

The PulseBlasterUSB is a versatile, high-performance, programmable TTL signal generator which operates at 100 MHz and is capable of generating pulses/delays/intervals ranging from 50 ns to 4.5x10<sup>7</sup> s in duration. The PulseBlasterUSB has up to 24 output channels, features highly flexible program flow control, and can accommodate pulse programs containing as many as 4096 instructions.

Each of the PulseBlasterUSB's outputs is individually controlled, has a standard TTL 3.3 V output voltage<sup>1</sup>, and can provide in excess of 25 mA of current. User interaction and control can be accomplished in several ways: through SpinCore's *PulseBlaster Interpreter* and *PulesBlaster.NET*, which are free graphical programming environments for Windows, or through the SpinAPI control library which is also free of charge and can be integrated into C/C++, MATLAB, LabVIEW and other third-party design environments.

<sup>&</sup>lt;sup>1</sup> No-load voltage level

### **Specifications**

#### **Output Channels**

- Up to 24 individually controlled digital output channels (LVTTL levels, 3.3 V unterminated high state)
- Variable pulses/delays for every output channel
- 25 mA output current per output channel

#### **Pulse Timing**

- 50 ns shortest pulse/interval (at 100 MHz)
- 4.5x10<sup>7</sup> s longest pulse/interval (at 100 MHz)
- 10 ns pulse/interval resolution (at 100 MHz)
- TTL-level (3.3 V max.) external trigger and reset inputs

#### Pulse Program Flow Control

- Subroutines, nested up to 8 levels deep
- Loops, nested up to 8 levels deep
- 20-bit loop counters (max. 1,048,575 repetitions per loop)
- Wait for trigger with 8 clock cycle latency (80 ns at 100 MHz), can wait up to 4.5x10<sup>7</sup> seconds (~521 days)
- Status polling via hardware and software
- Up to 4096 instructions

## **III. Installation**

### Installing the SpinAPI Driver and Control Library

SpinAPI is a custom Application Programming Interface developed by SpinCore Technologies, Inc. for use with the PulseBlaster board. SpinAPI can be utilized using C/C++ or graphically by using other methods detailed in Section IV.

**NOTE**: To ensure proper installation of the board, you must uninstall any previous versions of SpinAPI and complete the following:

- Please do not connect the system/ board until SpinAPI has been installed.
- Install the latest version of SpinAPI found at: <u>http://spincore.com/support/spinapi/</u>.
- After installation, shut down the computer, plug the PulseBlasterUSB's USB cable into the computer and then restart.

Now you are ready to run the test C programs that came in the SpinAPI Package. These example files can be found in the "examples" folder that came with the SpinAPI Package. Open the "PulseBlaster24" sub-folder to access the pre-compiled examples.

#### **Testing the PulseBlaster**

The simplest way to test whether the PulseBlasterUSB has been installed properly and can be controlled as intended is to run a simple test program. The pb24\_ex1.exe program, for example, will cause the outputs to turn on and off with a period of 400ms. To test the board, run pb24\_ex1.exe and observe each digital output with an oscilloscope or with LEDs.

If using a high input impedance oscilloscope to monitor the PulseBlaster's output, place a resistor that matches the characteristic impedance of the transmission line in parallel with the coaxial transmission line at the oscilloscope input (e.g., a 50  $\Omega$  resistor with a 50  $\Omega$  transmission line, see Figure 2 and Figure 3 below).



Figure 2: Left: BNC T-Adapter and Right: BNC 50 Ohm resistor.



**Figure 3:** BNC T-Adapter on the oscilloscope with coaxial transmission line connected on the left and BNC 50 Ohm resistor connected on the right, to terminate the line.

Figure 4 shows what you should expect to see on your oscilloscope when running pb24\_ex1.exe and using a 50 Ohm resistor to terminate the line. Once this behavior has been verified, the user can be confident the board is installed properly.



**Figure 4:** The expected signal from a PulseBlasterUSB (SP9) running example program pb24\_ex1.exe. Notice the amplitude of 2.52 V is due to a 50 Ohm resistor which is terminating the line.

## **IV. Programming the PulseBlasterUSB**

#### Introduction

There are five major methods of programming the PulseBlasterUSB. The simplest and most intuitive methods of control are the graphical interfaces provided by *PulseBlaster Interpreter* and *PulseBlaster.NET*. More advanced control can be exercised by writing custom C/C++ programs which will interact with the SpinAPI control package.

Programming can also be accomplished through the use of third-party GUI packages such as LabVIEW and MATLAB which have the ability to access Dynamic Link Libraries (DLLs) like SpinAPI. All five programming methods are described in detail below.

#### Programming with the PulseBlaster Interpreter

The PulseBlasterUSB can be programmed and controlled via the *PulseBlaster Interpreter*, which is an easy to-use editor that allows you create, edit, save and run your pulse sequence.

With the PulseBlaster Interpreter, pulse patterns can be generated using the simple notation of natural numbers (see the first line in Figure 5, below). For more complex bit patterns, the PulseBlaster Interpreter also accepts binary notation and hexadecimal notation (see lines 2, 3, and 4 in Figure 5, below).

| 🗓 sample1.pb - SpinCore PulseBlaster Interpreter 📃 🗔 🔀        |                                                                                                                  |                           |                            |                   |          |  |  |  |  |
|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------|----------------------------|-------------------|----------|--|--|--|--|
| jie Interpreter Board Help                                    |                                                                                                                  |                           |                            |                   |          |  |  |  |  |
| Open File                                                     | Open File Save File Load Board Start Stop                                                                        |                           |                            |                   |          |  |  |  |  |
| // Sample pi                                                  | 🗸 Sample program for SpinCore PulseBlaster Interpreter.                                                          |                           |                            |                   |          |  |  |  |  |
| // Bi                                                         | Start: On 2 + 7, 500 ns<br>// Bits 2 and 7 on for 500 ns (all other bits off)<br>// Continue to next instruction |                           |                            |                   |          |  |  |  |  |
|                                                               |                                                                                                                  |                           | 0 0000, 500<br>Continue t  | ns<br>o next inst | ruction  |  |  |  |  |
|                                                               |                                                                                                                  |                           | 1 1111, 100<br>Continue to | ns<br>next instr  | uction   |  |  |  |  |
|                                                               | •                                                                                                                | ns, branch,<br>or 100 ns, | Start<br>branch to S       | tart              |          |  |  |  |  |
| <                                                             |                                                                                                                  |                           |                            |                   | >        |  |  |  |  |
|                                                               | Line 3: 16777215 100 0 0<br>Line 4: 16777215 100 6 0                                                             |                           |                            |                   |          |  |  |  |  |
| 4 instructions interpreted.<br>Board programmed successfully. |                                                                                                                  |                           |                            |                   |          |  |  |  |  |
| Clock Frequer                                                 | ncy: 100                                                                                                         |                           | MHz                        | Line 11, C        | olumn 62 |  |  |  |  |

Figure 5: The PulseBlaster Interpreter.

Please follow the link <u>http://www.spincore.com/support/SPBI/</u> for the most recent version of the PulseBlaster Interpreter software, installation instructions, documentation, and sample programs.

### Programming with PulseBlaster.NET

The PulseBlasterUSB can be programmed and controlled using an intuitive .NET GUI designed in C#.

|                        |                                           | ter.NET<br>Help    |                         |        |            |     |                |              |      |                    |                |                |                |                |                                |                |                |          |               |               |               |               |               |               |            |               |               |                                      |   |       |        |
|------------------------|-------------------------------------------|--------------------|-------------------------|--------|------------|-----|----------------|--------------|------|--------------------|----------------|----------------|----------------|----------------|--------------------------------|----------------|----------------|----------|---------------|---------------|---------------|---------------|---------------|---------------|------------|---------------|---------------|--------------------------------------|---|-------|--------|
| Inforr<br>Spin4<br>Boa | nation<br>API Vers<br>ard Num<br>Firmware | sion: 200<br>iber: | 091120c<br>0 📚<br>13-02 | Instru | ictions    | 4 ≎ |                | Contr        |      | d Boar             | d              |                | [              |                | St                             | ><br>art       |                |          |               |               | St            | op            |               | ]             |            | Spi           | nCon          | Core Pul<br>e Technolog<br>ncore.com |   |       | er.NET |
|                        | 0                                         | Duration           | 100 ms                  | ~      | Flag<br>23 |     | <b>⊻</b><br>21 | <b>2</b> 0 1 |      | <b>1</b> 7         | <b>∨</b><br>16 | <b>∨</b><br>15 | <b>∨</b><br>14 | <b>∨</b><br>13 | <b>∨</b><br>12                 | <b>?</b><br>11 | <b>∨</b><br>10 | <b>9</b> | <b>∨</b><br>8 | <b>₽</b><br>7 | <b>₽</b><br>6 | <b>₽</b><br>5 | <b>∨</b><br>4 | <b>∨</b><br>3 | <b>₽</b> 2 | <b>∨</b><br>1 | <b>∨</b><br>0 | Flow Control<br>Code:<br>CONTINUE    | ~ | Data: | 0      |
|                        | 1                                         | Duration           | 200 ms                  | ~      | Flag<br>23 |     | <b>2</b> 1     | 20 1         | 9 18 | ] <b>!</b><br>3 17 | <b>1</b> 6     | <b>∨</b><br>15 | <b>1</b> 4     | <b>V</b><br>13 | 12                             | <b>7</b>       | 10             | <b>9</b> | 8             | <b>₽</b><br>7 | 6             | <b>7</b>      | 4             | <b>∨</b><br>3 | 2          | <b>∨</b><br>1 | 0             | Flow Control<br>Code:<br>LOOP        | ~ | Data: | 3      |
|                        | 2                                         | Duration           | 200 ms                  | ~      | Flag<br>23 |     | <b>1</b><br>21 | 20 1         | 9 18 | 3 17               | <b>7</b>       | 15             | <b>∨</b><br>14 | 13             | <ul><li>✓</li><li>12</li></ul> | 11             | <b>?</b><br>10 | 9        | <b>∨</b><br>8 | 7             | <b>₽</b><br>6 | 5             | <b>∨</b><br>4 | 3             | <b>₽</b> 2 | 1             | <b>V</b><br>0 | Flow Control<br>Code:<br>END_LOOP    |   | Data: | 1      |
|                        | 3                                         | Duration           | 100 ms                  | •      | Flag<br>23 |     | <b>1</b><br>21 | 20 1         | 9 18 | 3 17               | <b>1</b> 6     | <b>1</b> 5     | <b>1</b> 4     | <b>1</b> 3     | 12                             | 11             | 10             | 9        | 8             | 7             | 6             | 5             | 4             | 3             | 2          | 1             | 0             | Flow Control<br>Code:<br>BRANCH      | ~ | Data: | 0      |
|                        |                                           |                    |                         |        |            |     |                |              |      |                    |                |                |                |                |                                |                |                |          |               |               |               |               |               |               |            |               |               |                                      |   |       |        |
|                        |                                           |                    |                         |        |            |     |                |              |      |                    |                |                |                |                | _                              | _              |                |          | _             |               |               |               |               |               | _          | _             |               |                                      |   |       | .;i    |

Figure 6: The PulseBlaster.NET Interface.

The PulseBlaster.NET interface provides a quick and intuitive method for designing pulse programs for your device. Programming is no longer done in text, but instead presented as a simple visual metaphor. Instructions are presented as a series of checkboxes to represent the TTL values produced.

PulseBlaster.NET is capable of saving and loading files that may be transferred between computers. Best of all, any programming errors (e.g. invalid opcode) are indicated to the user immediately, eliminating much debugging work.

The latest version of the program and supporting documentation is available on our website at <u>http://www.spincore.com/support/net/</u>.

#### **Programming in C/C++ using SpinAPI**

The SpinAPI control library allows users to write pulse programs for controlling the PulseBlasterUSB with C/C++ functions. The SpinAPI package also contains several precompiled example pulse programs, along with their source code. These example programs provide an easy way for the user to verify the proper operation of the device and will also provide the user with a jump-start in programming with C/C++ and SpinAPI.

Programming the PulseBlasterUSB in C/C++ uses a simple paradigm in which each generated interval corresponds to a single instruction. Every instruction is programmed with the state of the output channels for that interval, the duration (time) and the program flow information (Op Code and data). An example is shown below.

int start = pb\_inst(0xFFFFFF, CONTINUE, 0, 500\*ms);
 pb\_inst(0x000000, BRANCH, start, 500\*ms);

**Example 1:** Code segment to produce a 1Hz square wave on all outputs. The first parameter of pb\_inst corresponds to the state of the outputs; the second and third, the Op Code and data; and the fourth to the duration of the interval.

Use of this programming paradigm is explained in further detail in the document titled "Using SpinAPI in C/C++ for PulseBlaster Programming" which is available from the SpinCore website at <a href="http://spincore.com/support/spinapi/using\_spin\_api\_pb.shtml">http://spincore.com/support/spinapi/using\_spin\_api\_pb.shtml</a>. The SpinAPI reference document can be found at <a href="http://www.spincore.com/CD/spinapi/spinapi\_reference/">http://www.spincore.com/CD/spinapi/spinapi\_reference/</a>.

The SpinAPI package is available for download free of charge. Detailed explanations of every available API function are available on-line, and the source code of the entire SpinAPI package is also freely available. This may be of value to those users wishing to port the package to other operating systems or platforms. For more information about the SpinAPI package, see <a href="http://spincore.com/support/spinapi/">http://spincore.com/support/spinapi/</a>.

The instructions to compile on Windows can be found at

<u>http://www.spincore.com/support/spinapi/Windows\_Help.shtml</u>. After configuring the compiler, changing one of our example programs and recompiling the executable file for use with your PulseBlasterUSB board is as easy as clicking "Rebuild All" (see Figure 7 below).

| 2 Dev-C++ 4.9.9.2             |                                              |                                                                                                                     |
|-------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| File Edit Search View Project | Execute Debug Tools CVS Window               | Help                                                                                                                |
| 💹 🕘 🔲 🛄 🛍 🚇                   |                                              |                                                                                                                     |
| 8 🗆 🖪 🎛 🖉 🛛 ? 🧕               | Compile current file Shift+Ctrl+F9           | Goto                                                                                                                |
|                               | Run Ctrl+F10                                 |                                                                                                                     |
|                               | Parameters                                   |                                                                                                                     |
| Project Classes Debug c       | 📰 Compile & Run F9                           |                                                                                                                     |
|                               | Rebuild All Ctrl+F11                         |                                                                                                                     |
|                               | Syntax Check                                 |                                                                                                                     |
|                               | Clean                                        |                                                                                                                     |
|                               | Profile analysis                             | ine below will generation the below will generate                                                                   |
|                               | Program Reset Alt+F2                         | help debug any proble                                                                                               |
|                               | printf("Using SpinAF<br>/*If there is more t | <pre>) 2010 SpinCore Techno<br/>I library version %s\)<br/>han one board in the :<br/>ect_boards()) &gt; 1) (</pre> |

Figure 7: Compiling a C example program.

### LabVIEW Extensions

The SpinCore PulseBlaster LabVIEW Extensions (PBLV) provide the ability to program and control the functionality of PulseBlaster boards using the simple National Instruments (NI) LabVIEW graphical programming interface. The package contains basic subVIs that can be used to include PulseBlaster interaction from your own LabVIEW programs, as well as some complete example VIs. Additionally, all of the examples are available as stand-alone applications to control.



**Figure 8:** Example of PulseBlaster LabVIEW Extensions User Interface. The example shown has three instructions that toggle TTL bit 1 on for 200 ms and off for 200 ms.

There are two versions of the LabVIEW extensions available free of charge on our website. The first is for those who do not have LabVIEW or who are not familiar with LabVIEW programming. This option is a stand-alone GUI (see Figure 8 above) that comes in executable form and utilizes the LabVIEW runtime environment. The second is for those who have LabVIEW and would like to make a custom interface for the PulseBlaster board. For more information and downloads please visit http://www.spincore.com/support/PBLV/.

### **Programming with Third-Party GUI Environments**

The SpinAPI control library is a standard Windows Dynamic Link Library (DLL), and virtually all programming languages and software environments (including LabVIEW and MATLAB) provide mechanisms for accessing the functionality of libraries like SpinAPI.

### V. Connecting to the PulseBlasterUSB

The PulseBlasterUSB is available in two standard options: a) the board-only option, no enclosure (+5 V DC required), b) the 2U BNC Rackmount Enclosure. The connectors for each option, along with the single-bay CD-ROM-type enclosure (AC Power Supply included), and the 2U BNC/TNC enclosure (½ width) are explained below.

### **Connector Information for PulseBlasterUSB Board**

#### Power Connector (SP9, SP48, and SP50)

The PulseBlasterUSB board-only option has a 4-pin Molex-style connector for supplying power. The pin and signal arrangements for this connector is as follows:



**Figure 9:** 4 Pin input connector (Molex part 0531090410).

This power connector mates with standard PC power supply connector or Molex part 0015244048.

Note that it is suggested that a PC power supply with the connector specified below is used. This is a standard connector type common on most PCs that will satisfy the power requirements and prevent any damage (such as accidentally reversing polarity). The PulseBlasterUSB board does not contain overvoltage protection, reverse polarity protection, or undercurrent detection. If a PC power supply is not easily accessible it is suggested that a fixed-voltage +5 V power supply with a 3 A maximum current be used.

### SP9 PulseBlasterUSB Board Specific Pin Assignments

#### JP303 IDC Header for PulseBlasterUSB Board (SP9, Main Output Connector)

The TTL signals are exposed on a shrouded 50-pin male IDC connector (JP303). The shrouded IDC connector labeled JP303 can also be accessed using an SP31 board (Figure 21 on page 37) which allows the use of MMCX cables. This enables the individual bits of the PulseBlaster to be more easily accessed. Pin 1 on the MMCX adapter board can be identified with a square pin.

| Pin Number | Function |
|------------|----------|
| 2          | Bit 0    |
| 4          | Bit 1    |
| 6          | Bit 2    |
| 8          | Bit 3    |
| 10         | Bit 4    |
| 12         | Bit 5    |
| 14         | Bit 6    |
| 16         | Bit 7    |
| 18         | Bit 8    |
| 20         | Bit 9    |
| 22         | Bit 10   |
| 24         | Bit 11   |
| 26         | Bit 12   |
| 28         | Bit 13   |
| 30         | Bit 14   |
| 32         | Bit 15   |
| 34         | Bit 16   |
| 36         | Bit 17   |
| 38         | Bit 18   |
| 40         | Bit 19   |
| 42         | Bit 20   |
| 44         | Bit 21   |
| 46         | Bit 22   |
| 48         | Bit 23   |
| 50         | NC       |

**Table 1:** Pin out for 50 pinIDC Connector.

Note: All other pins are ground.

#### JP301 IDC Header (Trig/Res/Stat) for SP9 PulseBlasterUSB Board

For SP9 PulseBlasterUSB boards that are not fully enclosed, the trigger, reset and status pins are available on the IDC Header labeled JP301 in addition to a DB9 connector. The pinout for the IDC header is shown in Figure 10 and Table 2 below. Please refer to the **DB9 Connector (Trig/Res/Stat)** section on page 24 for more details about the signals and the DB9 pinout.



Figure 10: Shrouded IDC Header JP301.

| Pin Number | Function         |  |  |  |  |  |
|------------|------------------|--|--|--|--|--|
| 1          | Ground           |  |  |  |  |  |
| 2          | Hardware Trigger |  |  |  |  |  |
| 3          | Ground           |  |  |  |  |  |
| 4          | Hardware Reset   |  |  |  |  |  |
| 5          | Ground           |  |  |  |  |  |
| 6          | WAITING          |  |  |  |  |  |
| 7          | Ground           |  |  |  |  |  |
| 8          | RUNNING          |  |  |  |  |  |
| 9          | STOPPED          |  |  |  |  |  |
| 10         | RESET            |  |  |  |  |  |

 Table 2: IDC Header JP301 Pinout.

#### SP48 and SP50 PulseBlasterUSB Board Specific Pin Assignments

#### Shrouded IDC Connector FLAG[0..11]\_OUT Pin Assignments

The shrouded IDC connector labeled Flag[0..11]\_OUT outputs TTL signals generated by the user's program. Please consult the table below for pin assignments.

|      | Pin Assignments |      |        |  |  |  |  |  |
|------|-----------------|------|--------|--|--|--|--|--|
| Pin# |                 | Pin# |        |  |  |  |  |  |
| 1    | Bit 0           | 14   | GND    |  |  |  |  |  |
| 2    | GND             | 15   | Bit 7  |  |  |  |  |  |
| 3    | Bit 1           | 16   | GND    |  |  |  |  |  |
| 4    | GND             | 17   | Bit 8  |  |  |  |  |  |
| 5    | Bit 2           | 18   | GND    |  |  |  |  |  |
| 6    | GND             | 19   | Bit 9  |  |  |  |  |  |
| 7    | Bit 3           | 20   | GND    |  |  |  |  |  |
| 8    | GND             | 21   | Bit 10 |  |  |  |  |  |
| 9    | Bit 4           | 22   | GND    |  |  |  |  |  |
| 10   | GND             | 23   | Bit 11 |  |  |  |  |  |
| 11   | Bit 5           | 24   | GND    |  |  |  |  |  |
| 12   | GND             | 25   | NC     |  |  |  |  |  |
| 13   | Bit 6           | 26   | GND    |  |  |  |  |  |

**Table 3:** Lower 12 output bits and 12 ground lines onthe 26 pin IDC connector.

The shrouded IDC connector labeled FLAG[0..11]\_OUT can also be accessed using an SP53 board (Figure 24 on page 39) which allows the use of MMCX cables. This enables the individual bits of the PulseBlaster to be more easily accessed. Pin 1 on the MMCX adapter board can be identified with a square pin.



#### Shrouded IDC Connector FLAG[12..23]\_OUT Pin Assignments

The shrouded IDC connector labeled Flag[12..23]\_OUT outputs TTL signals generated by the user's program. Please consult the table below for pin assignments.

|      | Pin Assignments |      |        |  |  |  |  |  |
|------|-----------------|------|--------|--|--|--|--|--|
| Pin# |                 | Pin# |        |  |  |  |  |  |
| 1    | Bit 12          | 14   | GND    |  |  |  |  |  |
| 2    | GND             | 15   | Bit 19 |  |  |  |  |  |
| 3    | Bit 13          | 16   | GND    |  |  |  |  |  |
| 4    | GND             | 17   | Bit 20 |  |  |  |  |  |
| 5    | Bit 14          | 18   | GND    |  |  |  |  |  |
| 6    | GND             | 19   | Bit 21 |  |  |  |  |  |
| 7    | Bit 15          | 20   | GND    |  |  |  |  |  |
| 8    | GND             | 21   | Bit 22 |  |  |  |  |  |
| 9    | Bit 16          | 22   | GND    |  |  |  |  |  |
| 10   | GND             | 23   | Bit 23 |  |  |  |  |  |
| 11   | Bit 17          | 24   | GND    |  |  |  |  |  |
| 12   | GND             | 25   | NC     |  |  |  |  |  |
| 13   | Bit 18          | 26   | GND    |  |  |  |  |  |

**Table 4:** Higher 12 output bits and 12 ground lines onthe 26 pin IDC connector.

The shrouded IDC connector labeled FLAG[12..23]\_OUT can also be accessed using an SP53 board (Figure 24 on page 39) which allows the use of MMCX cables. This enables the individual bits of the PulseBlaster to be more easily accessed. Pin 1 on the MMCX adapter board can be identified with a square pin.

## HW\_RESET/TRIG IDC Header (Trig/Res/Stat) for SP48 and SP50 PulseBlasterUSB Board

For SP48 and SP50 PulseBlasterUSB boards, the trigger, reset and status pins are available on the IDC Header labeled HW\_RESET/TRIG. The pinout for the IDC header is shown in Figure 11 and Table 5 below. Please refer to the **Status Pins Description** section on page 25 for more details about the signals.

| Pin 2 | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ | Pin 10 |
|-------|-------------|-------------|-------------|-------------|-------------|--------|
| Pin 1 | $\boxtimes$ | $\boxtimes$ | $\boxtimes$ |             | $\boxtimes$ | Pin 9  |
|       |             |             |             |             |             |        |

Figure 11: Shrouded IDC Header HW\_RESET/TRIG.

| Pin Number | Function         |
|------------|------------------|
| 1          | Ground           |
| 2          | RESET            |
| 3          | Ground           |
| 4          | RUNNING          |
| 5          | Ground           |
| 6          | WAITING          |
| 7          | Ground           |
| 8          | Hardware Reset   |
| 9          | Ground           |
| 10         | Hardware Trigger |

 Table 5: IDC Header HW\_RESET/TRIG

 Pinout.

#### SMA Connector CLK\_OUT

This SMA connector outputs the reference clock as a 3.3 V TTL signal, i.e., it generates positive- only voltage. Note that the PulseBlasterUSB boards use 50 MHz as the reference clock frequency and that clock is internally multiplied to provide that actual PulseBlaster Core frequency<sup>2</sup>. The output resembles a square wave if properly terminated. This signal can be measured with an oscilloscope using either a high impedance probe at the SMA connector or a 50 ohm coaxial line that is terminated.

#### SMA Connector EXT\_CLK

This SMA connector can be used to input an external clock signal. Extreme care should be exercised, and certain conditions have to be met prior to using this connector. First, before attaching any external clock source, the internal clock oscillator must be removed from its socket. The internal clock oscillator's orientation should be noted - if the internal clock is reconnected, it must be inserted in the same orientation or board damage may occur. Second, the external clock signal must be 3.3 V TTL, i.e., a positive-only voltage - any negative voltage at the EXT\_CLK connector will damage the programmable-logic processor chip. Third, the EXT\_CLK connector for certain boards is not terminated on the printed circuit board, and a 50 ohm

<sup>&</sup>lt;sup>2</sup> Custom firmware may use a different speed reference clock and may not be internally multiplied.

terminating resistor should be used externally via a T connector placed directly at the SMA EXT\_CLK connector. If the EXT\_CLK is terminated, there will be a 50 ohm resistor on the R001 pad. Soldering a 50 ohm resistor to this pad, if not already populated, is an alternative to using a T connector with a 50 ohm resistor.

### **Connector Information for Single-bay Enclosure**

#### **AC Power Connector**

The PulseBlasterUSB system in the single-bay enclosure is provided with an internal auto-sensing universal AC power supply. An IEC C14 male connector is exposed at the rear of the enclosure which may be connected to 120/240 V, 50/60 Hz mains power.

#### DB9 Connector (Trig/Res/Stat)



Figure 12: Female DB-9 Output Connector.

| Pin Number | Function         |
|------------|------------------|
| 1          | STOPPED          |
| 2          | RESET            |
| 3          | Ground           |
| 4          | Hardware Reset   |
| 5          | Hardware Trigger |
| 6          | Ground           |
| 7          | RUNNING          |
| 8          | WAITING          |
| 9          | Ground           |

 Table 6: Female DB-9 connector pin assignments.

The DB-9 connector contains both input and output pins: the Hardware Trigger and Hardware Reset control lines (which are inputs), and four status output pins which allow external monitoring of the state of the PulseBlasterUSB. The status bits are defined as follows:

#### Status Pins Description

**Stopped** – Driven high when the PulseBlasterUSB device has encountered a STOP Op Code during program execution and has therefore entered a stopped state. The device must be reset before it can start running again.

**Reset** – In versions up to firmware 13-7, this signal is driven low when the PulseBlasterUSB device is in a RESET state. In versions after 13-7, this signal is driven high when the device is in a RESET state.

**Running** – Driven high while the PulseBlasterUSB device is executing a program and low when the device enters a reset state or idle state.

**Waiting** – Driven high when the PulseBlasterUSB device has encountered a WAIT Op Code and is waiting for the next trigger in order to resume operation (trigger may be hardware or software generated).

#### Hardware Trigger

The hardware trigger is pulled to high voltage (3.3V) on the board and can be triggered by a low pulse (or shorting to ground). When a falling edge is detected (e.g., shorting the pin to ground) and the program is idle, code execution is triggered. If the program is idle due to a WAIT Op Code, then the HW\_Trigger will cause the program to continue to the next instruction. If the program is idle due to a STOP Op Code or a HW\_Reset signal, then the HW\_Trigger starts execution from the beginning of the program. When using the STOP Op Code, a HW\_Reset or software reset (pb\_reset()) needs to be applied prior to the HW\_Trigger.

### **NOTE:** The PulseBlasterUSB requires a 3.3V input signal for HW\_Trigger. **Applying voltages to the** *input pins that are greater than 3.3V or less than 0V will damage the PulseBlasterUSB.*

Figure 13, below, shows an example of the HW\_Trigger signal with a latency of 80 ns. Please refer to the Instruction Set Architecture section in Appendix I for more details on programming the duration of the WAIT latency. To trigger once, the trigger signal must begin at high voltage (between 2V and 3.3V), then must be pulled low (to ground) and stay low for at least 10 ns before returning to high voltage. The PulseBlaster will continue to trigger or reset for as long as the HW\_Trigger or HW\_Reset signals stay at ground. If using a long TTL cable, make sure it is terminated and a buffer is used. If necessary, use an inverter or program the triggering device to match the high-low-high HW\_Trigger signal. The input impedance of the HW\_Trigger pin is 10 kOhms.



**Figure 13:** Demonstration of HW\_Trigger signal with a latency of 80 ns. The blue shows the HW\_Trigger signal, the pink shows one of the output flags. **Caution:** applying voltages to the input pins that are greater than 3.3V or less than 0V will damage the board.

#### **Hardware Reset**

The hardware reset signal is pulled to high voltage (3.3V) on the board and can be triggered by a low pulse (or shorting to ground). When a falling edge is detected (e.g., by shorting the pin to ground) the program execution will halt and the controller will reset itself back to the beginning of the program. Program execution can be resumed by either a software start command (pb\_start()) or by a hardware trigger.

**NOTE:** The PulseBlasterUSB requires a 3.3V input signal for HW\_Reset. **Applying voltages to the** input pins that are greater than 3.3V or less than 0V will damage the PulseBlasterUSB.

**NOTE:** With firmware version 28-1, the output flags hold the value in the state the board is reset in.

#### **Centronics Connector**

All input and output connectors are mounted at the back of the PulseBlasterUSB enclosure. The pin layout is shown in Figure 14 and the association between bits and pins is shown in Table 7.



**Figure 14:** General pin layout for the Centronics connector.

| Pin Number | Output Bit |  |
|------------|------------|--|
| 26         | 0          |  |
| 27         | 1          |  |
| 28         | 2          |  |
| 29         | 3          |  |
| 30         | 4          |  |
| 31         | 5          |  |
| 32         | 6          |  |
| 33         | 7          |  |
| 34         | 8          |  |
| 35         | 9          |  |
| 36         | 10         |  |
| 37         | 11         |  |
| 38         | 12         |  |
| 39         | 13         |  |
| 40         | 14         |  |
| 41         | 15         |  |
| 42         | 16         |  |
| 43         | 17         |  |
| 44         | 18         |  |
| 45         | 19         |  |
| 46 20      |            |  |
| 47         | 21         |  |
| 48         | 22         |  |
| 49         | 23         |  |
| 50         | NC         |  |

**Table 7:** Centronicsconnector pin assignments.

Note: All other pins are ground.

For mating connectors see Digi-Key part number 1550RMA-ND, T1504A-ND or similar.

### **Connector Information for 2U BNC/TNC Enclosure**

#### DB9 Connector (Trig/Res/Stat) for 2U BNC/TNC Enclosure

The Trig/Res/Stat DB9 connector information is shown in Figure 15 and Table 8, below. The Hardware Trigger and Hardware Reset are both low-true, so each of these pins would need to be shorted to ground to cause a trigger or reset, respectively. Please refer to the **Status Pins Description**, above, for additional information about each pins functionality.





| Pin Number | Function         |
|------------|------------------|
| 1          | Hardware Trigger |
| 2          | Hardware Reset   |
| 3          | WAITING          |
| 4          | RUNNING          |
| 5          | RESET            |
| 6          | Ground           |
| 7          | Ground           |
| 8          | Ground           |
| 9          | STOPPED          |

**Table 8:** Trig/Res/Stat Female DB9connector pin assignments.

#### Front Panel Connectors for 2U BNC/TNC Enclosure

This enclosure provides 8 output bits through either BNC or TNC connectors, arranged as in Figure 16, below. There is also an external clock signal input provided through a BNC or TNC connector. This clock line is terminated on the PulseBlaster board with a 50  $\Omega$  resistor. Please see the **Clock Input Signal Standard** section below for more details. Because the 2U enclosure may be configured with either BNC or TNC connectors, please specify which configuration you require when ordering.

#### **Clock Input Signal Standard**

- External clock input available on 2U enclosure (LVTTL level, 3.3V unterminated high state).
- Must be positive voltage only; sinusoidal inputs must be converted to LVTTL levels.
- The clock input connection is internally terminated with a 50  $\Omega$  resistor.
- Clock input must be 50 MHz. Please inquire with SpinCore for custom input frequencies.



Figure 16: Front-panel connectors for 2U BNC/TNC enclosure.

### **Connector Information for 2U BNC Rackmount Enclosure**

#### **Connectors for 2U BNC Rackmount Enclosure**

This enclosure provides 24 output bits through BNC connectors. The front panel also contains the USB connector, the Trig/Res/Stat DB9 connector, and the ON/OFF toggle switch which powers on the PulseBlasterUSB. They are arranged in a format which is 3 rows of 8 bits. On the reverse side of the Rackmount enclosure is the AC Input.

#### DB9 Connector (Trig/Res/Stat) for 2U BNC Rackmount Enclosure

The Trig/Res/Stat DB9 connector information is shown in Figure 17 and Table 9, below. The numbering of the pins may be different from the text on the physical DB9 connector. The Hardware Trigger and Hardware Reset are both low-true, so each of these pins would need to be shorted to ground to cause a trigger or reset, respectively. Please refer to the **Status Pins Description**, above, for additional information about each pins functionality.





| Pin Number | Function         |
|------------|------------------|
| 1          | Hardware Trigger |
| 2          | Hardware Reset   |
| 3          | WAITING          |
| 4          | RUNNING          |
| 5          | RESET            |
| 6          | Ground           |
| 7          | Ground           |
| 8          | Ground           |
| 9          | STOPPED          |

**Table 9:** Trig/Res/Stat Male DB9connector pin assignments.

### **Clock Oscillator Header**

The PulseBlasterUSB comes with a crystal oscillator mounted on the oscillator socket to provide a timing signal for the board. If required, it is possible to remove the oscillator that comes standard, and instead drive the PulseBlasterUSB with an external clock signal. The oscillator module can be removed from the board, and an external signal can be input through the header pins. Do not attempt to drive a PulseBlaster board with an external clock while an oscillator module is also connected. The standard clock oscillator's orientation should be noted - if the clock oscillator is reconnected, it must be inserted in the same orientation or board damage may occur. The external clock signal must be a TTL square wave, i.e. a digital signal of no more than 3.3 V. This is the absolute maximum allowable voltage, typically a voltage of 1.5-2 V is sufficient. Be aware that the TTL signal must be a positive-only signal, any negative voltage will damage the programmable-logic chip.



**Figure 18:** Both the bare header socket and the installed clock module are shown above. Please note the proper orientation of the 50 MHz clock.

## **Appendix I. Instruction Set Architecture**

### Instruction Set Architecture of the PulseBlaster Processor

#### Machine-Word Definition

The PulseBlaster pulse timing and control processor implements an 80-bit-wide Very Long Instruction Word (VLIW) architecture. The VLIW memory words have specific bits/fields dedicated to specific purposes, and every word should be viewed as a single instruction of the micro-controller. The maximum number of instructions that can be loaded into on-board memory varies by model.

The execution time of instructions can be varied and is controlled by one of the fields of the instruction word – the shortest execution time is five clock cycles of the reference clock oscillator and the longest is 2^32 - 1 clock cycles (for standard instructions). All instructions have the same format and bit length, and all bit fields must be filled. Figure 19 shows the fields and bit definitions of the 80-bit instruction word.

#### **Bit Definitions for the 80-bit Instruction Word (VLIW)**

| Output/Control Word | Data Field | OP Code  | Delay Count |
|---------------------|------------|----------|-------------|
| (24 bits)           | (20 bits)  | (4 bits) | (32 bits)   |

Figure 19: Bit definitions of the 80-bit instruction/memory word.

#### Breakdown of 80-bit Instruction Word

The 80-bit instruction word is broken up into 4 sections:

- 1. Output Pattern and Control Word 24 bits.
- 2. Data Field 20 bits.
- 3. Op Code 4 bits.
- 4. Delay Count 32 bits.

#### **Output Pattern and Control Word**

The first 24 bits of the 80-bit machine word of the PulseBlaster processor are the output bits. The 24 output bits retain their value throughout the entire duration of the instruction represented by the machine word.

#### Data Field and Op Code

Table 10 (below) describes the available operational codes (referred to as Op Codes) and their associated data fields. Note that the data field's function is dependent on the Op Codes.

| Op Code<br># | Instruction | Data Field                                                                                           | Function                                                                                                                                                                                                                                                                                                                                 |
|--------------|-------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0            | CONTINUE    | Ignored                                                                                              | Program execution continues to next instruction                                                                                                                                                                                                                                                                                          |
| 1            | STOP        | lgnored                                                                                              | Stop execution of program. Aborts the operation of the micro-controller with no control of output states.                                                                                                                                                                                                                                |
| 2            | LOOP        | Number of desired loops. This value must be greater than or equal to 1.                              | Specifies the beginning point of a loop. The Data<br>Field is used to specify number of loops.<br>Execution will continue to next instruction.                                                                                                                                                                                           |
| 3            | END_LOOP    | Address of beginning of loop                                                                         | Specifies the end of a loop. Execution returns to beginning of loop and decrements loop counter.                                                                                                                                                                                                                                         |
| 4            | JSR         | Address of first subroutine<br>instruction                                                           | Program execution jumps to the beginning of the desired subroutine                                                                                                                                                                                                                                                                       |
| 5            | RTS         | Ignored                                                                                              | Return from subroutine. Execution continues with the instruction following the previous JSR                                                                                                                                                                                                                                              |
| 6            | BRANCH      | Address of next instruction                                                                          | Program execution continues with the instruction at the specified address                                                                                                                                                                                                                                                                |
| 7            | LONG_DELAY  | Desired multiplication factor for<br>the "Delay Count" field. Must be<br>greater than or equal to 2. | Used to execute very long instructions/ intervals.<br>Data Field specifies a multiplier of the Delay Field.<br>Execution continues to next instruction.                                                                                                                                                                                  |
| 8            | WAIT        | lgnored                                                                                              | Program execution stops and waits for hardware<br>trigger. Execution continues to next instruction<br>after receipt of trigger. The exit latency is equal to<br>the delay value entered in the WAIT instruction<br>line plus a fixed delay of 6 clock cycles. The WAIT<br>Op Code may not be used by the first instruction<br>in memory. |

 Table 10: Op Code and Data Field Description.

The execution time of instructions is determined by the content of the Delay field (and the Data field, when applicable), and the output state remains constant during the entire instruction.

NOTE : The following two exceptions apply:

- (1) The processor will ignore the delay field of instructions containing the STOP command. Upon encountering an instruction containing the STOP command, the processor will halt execution immediately rather than after the delay specified in the Delay Count field.
- (2) The WAIT Op Code may not be used by the first instruction in memory. If you wish to have the processor wait for an external trigger at the beginning of your pulse routine, we suggest that you use two instructions: one with the CONTINUE Op Code (and with a very short delay) followed by an instruction which uses the WAIT Op Code.

*NOTE* : The behavior of the output flags after a STOP command is firmware dependent. With firmware version 13-12 and 28-1, the output flags hold the value given to them in the previous instruction. If a different behavior is desired, please contact SpinCore Technologies, Inc. for alternate firmware options. *NOTE :* With firmware version 28-1, the instruction before either STOP or WAIT Op Code is required to be at least six clock cycles. The delay count for Op Codes LONG\_DELAY and END\_LOOP must be at least six clock cycles.

#### **Delay Count**

The value of the Delay Count field (a 32-bit value) determines the length of time that the current instruction should be executed. The number in this field represents the number of periods of the master clock oscillator that will occur before the execution of the next instruction begins.

Standard time units should be entered into the Delay Field when using the SpinAPI package or the PulseBlaster Interpreter. The allowed units are *ns* (nanoseconds), *us* (microseconds), and *ms* (milliseconds). SpinAPI and the PulseBlaster Interpreter will automatically convert these values into the appropriate number of clock cycles when the PulseBlasterUSB is programmed.

## Appendix II. User Programmable Clock Output Design

The PulseBlaster USB design 13-9\* features user programmable clock outputs on the pins that would normally have the top 4 flag bits. The Clock Output Channels 0-3 can output pulse patterns such as those seen in Figure 20. Once the clocks are programmed, they remain running at the same rate until they are reprogrammed or the board is turned off. The user can program the period, the clock high time, and the offset as shown in Figure 20. This feature runs on a 50 MHz clock and has 32-bit resolution, meaning the shortest pulse possible is 20 ns and the longest interval is 85 seconds with a resolution of 20 ns.



Figure 20: Timing Diagram for User Programmable Clock Outputs.

<sup>\*</sup>Please contact SpinCore directly about purchasing the PulseBlaster USB board with 13-9 design.

### Programming the Clock Feature in C/C++

To program the three parameters into your board, you must use a function in SpinAPI called pb\_set\_pulse\_regs. The function takes four parameters:

pb\_set\_pulse\_regs(unsigned int channel, double period, double clock\_high, double offset)

Channel must be an integer between 0 and 3 corresponding to one of the four channels. Period can be as long as 85 seconds or as short as 40 ns. Clock High and Offset must be between 20 ns and 85 seconds. This function needs to be called either before pb\_start\_programming(PULSE\_PROGRAM) or after pb\_stop\_programming(); it can't be included with a pulse program. Once the function is run, the clock is immediately changed.

Since the programmable clock outputs are controlled by a 50 MHz clock, only increments of 20 ns can be programmed to the board. An input value that is not a multiple of 20 ns will be rounded down to the closest multiple of 20 ns that is less than it.

### Example Use of Programmable Clock Feature in C/C++

There is a sample program for this functionality included with the SpinAPI examples. It uses the code seen in Example 3 to produce outputs on all channels with equal period and clock high times but with varying delays.

| pb_set_pulse_regs(0, 200.0 * us, 20.0 * us, 20.0 * us); |
|---------------------------------------------------------|
| pb_set_pulse_regs(1, 200.0 * us, 20.0 * us, 40.0 * us); |
| pb_set_pulse_regs(2, 200.0 * us, 20.0 * us, 60.0 * us); |
| pb_set_pulse_regs(3, 200.0 * us, 20.0 * us, 80.0 * us); |
|                                                         |

**Example 2:** Programming the clock outputs.

## **Related Products and Accessories**

- 1. PulseBlasterESR-PRO Alternate version of the PulseBlaster that are capable of Higher Clock Frequencies (currently up to 500 MHz). For more information, please see the Product URLs of the aforementioned products at <a href="http://www.spincore.com/products.shtml">http://www.spincore.com/products.shtml</a>.
- Firmware version 13-9 Alternate firmware for the PulseBlasterUSB which features user programmable clock outputs on the pins that would normally have the top 4 flag bits. Please see Appendix II. User Programmable Clock Output Design for more details.
- PulseBlasterDDS Built upon the PulseBlaster, the PulseBlasterDDS features programmable TTL outputs and RF Pulse Generation. For more information, please visit <u>http://www.spincore.com/products/PulseBlasterDDS-300/</u>.
- 4. If you require an Oven Controlled Clock Oscillator (sub-ppm stability) or other custom features, please visit <u>http://spincore.com/products/OCXO/</u> or inquire with SpinCore Technologies through our contact form, which is available at <u>http://www.spincore.com/contact.shtml</u>.
- SP31, SpinCore MMCX Adapter Board This adapter board allows easy access to the individual bits of the SP9 PulseBlaster. MMCX cables are available upon request. For ordering information, please visit <u>http://spincore.com/products/Adapters/</u> or contact SpinCore at <u>http://www.spincore.com/contact.shtml</u>.



Figure 21: SP31, MMCX Adapter Board allows easy access to individual bits. Left: IDC Connector. Right: MMCX Connectors.



Figure 22: SP31, MMCX Adapter Board orientation and configuration with PulseBlasterUSB Board.



Figure 23: SP31, MMCX Adapter Board orientation and configuration with PulseBlasterUSB Board from a different angle.

 SP53, SpinCore MMCX Adapter Board (Figure 24) – This adapter board allows easy access to the individual bits of the SP48 and SP50 PulseBlaster. For ordering information, please visit <a href="http://spincore.com/products/Adapters/">http://spincore.com/products/Adapters/</a> or contact SpinCore at <a href="http://www.spincore.com/contact.shtml">http://www.spincore.com/contact.shtml</a>.



Figure 24: SP53, MMCX Adapter Board allows easy access to individual bits

## **Contact Information**

SpinCore Technologies, Inc. 4631 NW 53rd Avenue, SUITE 103 Gainesville, FL 32653 USA

Telephone (USA): Website: Web Form: 352-271-7383 http://www.spincore.com http://spincore.com/contact.shtml

## **Document Information**

Revision history of this document is maintained at SpinCore.