Theory of Operation
- Updated2023-02-17
- 14 minute(s) read
Theory of Operation
This section describes how the GPIB extender circuitry operates.
This section assumes that you are familiar with GPIB. If you are a first-time user or if you would like to review the basics about GPIB, refer to GPIB Basics.
The following figure shows the five layers of a GPIB extender. To form a complete link, you can connect each layer to the corresponding layer of another extender at the remote side.
Message Interpreter Layer
The Message Interpreter Layer handles the handshake between the GPIB extender and other devices on the GPIB. At the same time, the layer monitors the activities that occur on the GPIB, translates them into equivalent local and remote GPIB messages, and sends these messages to the Packet Translation Layer.
Packet Translation Layer
The Packet Translation Layer converts the messages that it receives to packets and sends them to the Link Management Layer. It can also receive packets from the Link Management Layer and convert them back to local or remote GPIB messages.
Link
Management Layer
The Link Management Layer receives packets from the Packet Translation Layer. It sends the packets to the Parallel-to-Serial Conversion Layer and it stores them in a local buffer. If a transmission error occurs, the Link Management Layer can re-send the packets from this local buffer. The Link Management Layer also receives packets from the Parallel-to-Serial Conversion Layer and checks the packets for transmission errors. If the Link Management Layer does not detect an error, it sends the packets to the Packet Translation Layer. However, if it detects a transmission error, then it re-transmits the packets.
Parallel-to-Serial Conversion Layer
The Parallel-to-Serial Conversion Layer accepts packets from the Link Management Layer, converts them into serial data, and sends the data to the Physical Layer. It also extracts serial bits from the Physical Layer, reconstructs them back into packets, and sends them to the Link Management Layer.
Physical Layer
The Physical Layer transmits and receives serial data over the fiber-optic link.
GPIB Basics
This section describes the basic concepts of GPIB, including its physical and electrical characteristics, and configuration requirements.
The ANSI/IEEE Standard 488.1-1987, also known as General Purpose Interface Bus (GPIB), describes a standard interface for communication between instruments and controllers from various vendors. It contains information about electrical, mechanical, and functional specifications. GPIB is a digital, 8-bit parallel communications interface with data transfer rates of 1 Mbyte/s and higher, using a three-wire handshake. The bus supports one System Controller, usually a computer, and up to 14 additional instruments. The ANSI/IEEE Standard 488.2-1992 extends IEEE 488.1 by defining a bus communication protocol, a common set of data codes and formats, and a generic set of common device commands.
Types of Messages
Interconnected GPIB devices communicate by passing messages through the interface system, including device-dependent messages and interface messages.
- Device-dependent messages, also called data or data messages, contain device-specific information, such as programming instructions, measurement results, machine status, and data files.
- Interface messages, also called commands or command
messages, manage the bus itself. Interface messages initialize the
bus, address and unaddress devices, and set device modes for remote or local
programming.
The term command as used here does not refer to device instructions, which are also called commands. Those device-specific instructions are data messages.
Talkers, Listeners, and Controllers
GPIB devices can be Talkers, Listeners, or Controllers. A Talker sends out data messages. Listeners receive data messages. The Controller, usually a computer, manages the flow of information on the bus. It defines the communication links and sends GPIB commands to devices.
Some devices are capable of playing more than one role. A digital voltmeter, for example, can be a Talker and a Listener. If your system has a NI GPIB interface and software installed, it can function as a Talker, Listener, and Controller.
The GPIB is like a typical computer bus, except that the typical computer has circuit cards interconnected via a backplane bus, whereas the GPIB has standalone devices interconnected via a cable bus.
The role of the GPIB Controller is similar to the role of the CPU of a computer, but a better analogy is to the switching center of a city telephone system. The switching center (Controller) monitors the communications network (GPIB). When the center (Controller) notices that a party (device) wants to make a call (send a data message), it connects the caller (Talker) to the receiver (Listener).
The Controller addresses a Talker and a Listener before the Talker can send its message to the Listener. After the message is transmitted, the Controller may unaddress both devices.
Some bus configurations do not require a Controller. For example, one device may always be a Talker (called a Talk-only device) and there may be one or more Listen-only devices.
A Controller is necessary when the active or addressed Talker or Listener must be changed. The Controller function is usually handled by a computer.
With the GPIB interface board and its software your personal computer plays all three roles.
- Controller—to manage the GPIB
- Talker—to send data
- Listener—to receive data
Controller-In-Charge and System
Controller
You can have multiple Controllers on the GPIB, but only one Controller at a time can be the active Controller, or Controller-In-Charge (CIC). The CIC can be either active or inactive (standby). Control can pass from the current CIC to an idle Controller, but only the System Controller, usually a GPIB interface, can make itself the CIC.
GPIB Signals and Lines
Devices on the bus communicate by sending messages. Signals and lines transfer these messages across the GPIB interface, which consists of 16 signal lines and 8 ground return (shield drain) lines. The 16 signal lines are discussed in the following sections.
Data Lines
Eight data lines, DIO1 through DIO8, carry both data and command messages.
Handshake Lines
Three hardware handshake lines asynchronously control the transfer of message bytes between devices. This process is a three-wire interlocked handshake, and it guarantees that devices send and receive message bytes on the data lines without transmission error. The following table summarizes the GPIB handshake lines.
Line | Description |
---|---|
NRFD (not ready for data) | Listening device is ready/not ready to receive a message byte. Also used by the Talker to signal high-speed GPIB transfers. |
NDAC (not data accepted) | Listening device has/has not accepted a message byte. |
DAV (data valid) | Talking device indicates signals on data lines are stable (valid) data. |
Interface Management
Lines
Five hardware lines manage the flow of information across the bus. The following table summarizes the GPIB interface management lines.
Line | Description |
---|---|
ATN (attention) | Controller drives ATN true when it sends commands and false when it sends data messages. |
IFC (interface clear) | System Controller drives the IFC line to initialize the bus and make itself CIC. |
REN (remote enable) | System Controller drives the REN line to place devices in remote or local program mode. |
SRQ (service request) | Any device can drive the SRQ line to asynchronously request service from the Controller. |
EOI (end or identify) | Talker uses the EOI line to mark the end of a data message. Controller uses the EOI line when it conducts a parallel poll. |
Physical and Electrical
Characteristics
Devices are usually connected with a cable assembly consisting of a shielded 24-conductor cable with both a plug and receptacle connector at each end, as shown in the following figure.
With this design, you can link devices in a linear configuration, a star configuration, or a combination of the two configurations. The following figure shows both linear and star configurations.
The standard connector is the Amphenol or Cinch Series 57 Microribbon or Amp Champ type. For special interconnection applications, you use an adapter cable using a non-standard cable and/or connector.
The GPIB uses negative logic with standard TTL (transistor-transistor logic) level. For example, when DAV is true, it is a TTL low level (≤ 0.8 V), and when DAV is false, it is a TTL high level (≥ 2.0 V).
Configuration Requirements
To achieve the high data transfer rate that the GPIB was designed for, you must limit the number of devices on the bus and the physical distance between devices. The following restrictions are typical:
- A maximum separation of 4 m between any two devices and an average separation of 2 m over the entire bus.
- A maximum total cable length of 20 m.
- A maximum of 15 devices connected to each bus, with at least two-thirds powered on.
For high-speed operation, the following restrictions apply:
- All devices in the system must be powered on.
- Cable lengths must be as short as possible with up to a maximum of 15 m of cable for each system.
- There must be at least one equivalent device load per meter of cable.
If you want to exceed these limitations, you can use a bus expander to increase the number of device loads. You can order bus expanders from NI.
Introduction to HS488
This section describes HS488 and the sequence of events in high-speed data transfers.
NI has designed a high-speed data transfer protocol for IEEE 488 called HS488. This protocol increases performance for GPIB reads and writes up to 8 MBytes/s, depending on your system.
If HS488 is enabled, the TNT4882C hardware implements high-speed transfers automatically when communicating with HS488 instruments. If you attempt to enable HS488 on a GPIB interface that does not have the TNT4882C hardware, the ECAP error code is returned.
Objectives
The following sections describe the objectives of HS488.
Faster Transfer Rates
HS488 enables transfer rates that are substantially faster than the IEEE 488 standard. In small systems, the raw transfer rate can be up to 8 MBytes/s. The faster raw transfer rates improve system throughput in systems where devices send long blocks of data. The physical limitations of the cabling system, however, limit the transfer rate.
Compatibility with IEEE 488 Devices
HS488 is a superset of the IEEE 488 standard; thus, you can mix IEEE 488.1, IEEE 488.2, and HS488 devices in the same system.
When connected to an HS488 device, the Controller does not need to be capable of HS488 non-interlocked transfers. While ATN is asserted, the Controller sources multiline messages to HS488 devices just as it sources multiline messages to any IEEE 488 devices.
Automatic HS488 Detection
Addressed HS488 devices can detect whether other addressed devices are capable of HS488 transfers without the interaction of the Controller.
Compatibility with the IEEE 488.2 Standard
The HS488 protocol requires no changes to the IEEE 488.2 standard. Also, HS488 devices do not need to be compliant with IEEE 488.2.
Same Cabling Restrictions as IEEE 488.1
Systems that meet the IEEE 488.1 requirements for high-speed operation also meet the HS488 requirements. HS488 cabling requirements are also the same as the requirements in the IEEE 488.1 standard.
However, using HS488 does not reduce software overhead. Also, system throughput increases depend on data block size.
IEEE 488.1 Requirements for High-Speed
Operation (T1 Delay ≥ 350 ns)
The IEEE 488.1 standard requires that devices used in high-speed operation must use three-state, 48 mA drivers on most signals. Each device must add no more than 50 pF capacitance on each signal, and all devices must be powered on.
The total cable length in a system must be no more than 15 m, or 1 m times the number of devices in the system.
HS488 System Requirements
An HS488 system must meet the IEEE 488.1 requirements and it must implement the following three new interface functions:
- Talking devices must use the Source Handshake Extended (SHE) interface function, which is an extension of the IEEE 488.1 SH function.
- Listening devices must use the Acceptor Handshake Extended (AHE) interface function, which is an extension of the IEEE 488.1 AH function. Accepting devices must have a buffer of at least 3 bytes to store received data.
- HS488 devices must implement the Configuration (CF) interface function. At system power on, the Controller uses previously undefined multiline messages to configure HS488 devices. The CF function enables devices to interpret these multiline messages.
Sequence of Events in Data Transfers
The following figure shows a typical IEEE 488.1 data transfer.
The following figure shows an HS488 data transfer. The HS488 protocol modifies the IEEE 488.1 SH and AH functions. At the beginning of each data transfer, the HS488 SHE and AHE functions determine whether all active Talkers and Listeners are capable of HS488 transfers. If the addressed devices are HS488-capable, they use the HS488 noninterlocked handshake protocol for that data transfer. If any addressed device is not HS488-capable, the transfer continues using the standard three-wire handshake.
Case 1: Talker and Listener are HS488 Capable
The following figure and procedure describe a typical sequence of events in an HS488 data transfer in which both the Talker and Listener are HS488-capable.
- The Controller addresses devices and becomes Standby Controller by unasserting ATN.
- The Listener asserts NDAC and NRFD.
- The Listener unasserts NRFD as it becomes ready to accept a byte.
- After allowing time for the Listener to detect NRFD unasserted, the Talker indicates that it is HS488-capable by sending the HSC message. To send the HSC message true, the Talker asserts the NRFD signal.
- After allowing time for the Listener to respond to the HSC message, the Talker sends the HSC message false. To send the HSC message false, the Talker unasserts the NRFD signal.
- When the Talker has a byte ready to send, it drives the data on the DIO signal lines, allows some settling time, and asserts DAV.
- The Listener unasserts NDAC. HS488-capable Listeners do not assert NRFD as IEEE 488.1 devices would, so the Talker determines that the addressed Listener is HS488-capable.
- The Talker unasserts DAV and drives the next data byte on the GPIB.
- After allowing some settling time, the Talker asserts DAV.
- The Listener latches the byte in response to the assertion (falling) edge of DAV.
- After allowing some hold time, the Talker unasserts DAV and drives the next data byte on the DIO signal lines.
Steps 9-11 are repeated for each data byte.
Case 2: Talker Is HS488-Capable, But Listener Is Not HS488-Capable
The following figure and procedure describe a typical sequence of events in an HS488 data transfer in which the Talker is HS488-capable, but the Listener is not.
Steps 1–6 in the sequence are identical to steps 1–6 in the previous procedure Case 1: Talker and Listener are HS488 Capable. The Listener ignores the HSC message from the Talker.
Then, the IEEE 488.1 Listener enters ACDS and asserts NRFD. As a result, the Talker determines that the addressed Listener is not HS488-capable. The Talker sources bytes using the IEEE 488.1 protocol.
Case 3: Talker Is Not HS488-Capable, But Listener Is HS488-Capable
The Talker does not send an HSC message to the Listener, but sources bytes using the IEEE 488.1 protocol.
The addressed Listener (HS488 or IEEE 488.1) accepts bytes using the IEEE 488.1 standard three-wire handshake, as shown in the following figure.
System Configuration
The HS488 AHE and SHE interface functions depend on several time delays. Some of these delays are a function of the total system cable length.
The Controller must communicate this system configuration data to HS488 devices after the system powers on. The Controller configures HS488 devices by sourcing the following two multiline messages while ATN is true:
- Configuration Enable (CFE)—The Controller sends the CFE message by driving a bit pattern (1E hex) that the IEEE 488.1 standard does not define on the DIO signal lines. The CFE message enables HS488 devices to interpret the SCG message that follows.
- Secondary Command Group (SCG)—This message contains the configuration data. The Secondary Command has the bit pattern 6n hex, where n is the meters of cable in the system. The SCG includes CFG1-CFG15 in the Multiline Interface Messages section.
Multiline Interface Messages
This section lists the multiline interface messages and describes the mnemonics and messages that correspond to the interface functions.
The multiline interface messages are commands defined by the IEEE 488 standard. The messages are sent and received with ATN asserted. The interface functions include initializing the bus, addressing and unaddressing devices, and setting device modes for local or remote programming. For more information about these messages, refer to the ANSI/IEEE Standard 488.1-1987, IEEE Standard Digital Interface for Programmable Instrumentation.
Hex | Dec | ASCII | Message | Hex | Dec | ASCII | Message | |
---|---|---|---|---|---|---|---|---|
00 | 0 | NUL | — | 20 | 32 | SP | MLA0 | |
01 | 1 | SOH | GTL | 21 | 33 | ! | MLA1 | |
02 | 2 | STX | — | 22 | 34 | " | MLA2 | |
03 | 3 | ETX | — | 23 | 35 | # | MLA3 | |
04 | 4 | EOT | SDC | 24 | 36 | $ | MLA4 | |
05 | 5 | ENQ | PPC | 25 | 37 | % | MLA5 | |
06 | 6 | ACK | — | 26 | 38 | & | MLA6 | |
07 | 7 | BEL | — | 27 | 39 | ' | MLA7 | |
08 | 8 | BS | GET | 28 | 40 | ( | MLA8 | |
09 | 9 | HT | TCT | 29 | 41 | ) | MLA9 | |
0A | 10 | LF | — | 2A | 42 | * | MLA10 | |
0B | 11 | VT | — | 2B | 43 | + | MLA11 | |
0C | 12 | FF | — | 2C | 44 | , | MLA12 | |
0D | 13 | CR | — | 2D | 45 | - | MLA13 | |
0E | 14 | SO | — | 2E | 46 | . | MLA14 | |
0F | 15 | SI | — | 2F | 47 | / | MLA15 | |
10 | 16 | DLE | — | 30 | 48 | 0 | MLA16 | |
11 | 17 | DC1 | LLO | 31 | 49 | 1 | MLA17 | |
12 | 18 | DC2 | — | 32 | 50 | 2 | MLA18 | |
13 | 19 | DC3 | — | 33 | 51 | 3 | MLA19 | |
14 | 20 | DC4 | DCL | 34 | 52 | 4 | MLA20 | |
15 | 21 | NAK | PPU | 35 | 53 | 5 | MLA21 | |
16 | 22 | SYN | — | 36 | 54 | 6 | MLA22 | |
17 | 23 | ETB | — | 37 | 55 | 7 | MLA23 | |
18 | 24 | CAN | SPE | 38 | 56 | 8 | MLA24 | |
19 | 25 | EM | SPD | 39 | 57 | 9 | MLA25 | |
1A | 26 | SUB | — | 3A | 58 | : | MLA26 | |
1B | 27 | ESC | — | 3B | 59 | ; | MLA27 | |
1C | 28 | FS | — | 3C | 60 | < | MLA28 | |
1D | 29 | GS | — | 3D | 61 | = | MLA29 | |
1E | 30 | RS | — | 3E | 62 | > | MLA30 | |
1F | 31 | US | CFE | 3F | 63 | ? | UNL | |
40 | 64 | @ | MTA0 | 60 | 96 | ` | MSA0, PPE | |
41 | 65 | A | MTA1 | 61 | 97 | a | MSA1, PPE, CFG1 | |
42 | 66 | B | MTA2 | 62 | 98 | b | MSA2, PPE, CFG2 | |
43 | 67 | C | MTA3 | 63 | 99 | c | MSA3, PPE, CFG3 | |
44 | 68 | D | MTA4 | 64 | 100 | d | MSA4, PPE, CFG4 | |
45 | 69 | E | MTA5 | 65 | 101 | e | MSA5, PPE, CFG5 | |
46 | 70 | F | MTA6 | 66 | 102 | f | MSA6, PPE, CFG6 | |
47 | 71 | G | MTA7 | 67 | 103 | g | MSA7, PPE, CFG7 | |
48 | 72 | H | MTA8 | 68 | 104 | h | MSA8, PPE, CFG8 | |
49 | 73 | I | MTA9 | 69 | 105 | i | MSA9, PPE, CFG9 | |
4A | 74 | J | MTA10 | 6A | 106 | j | MSA10, PPE, CFG10 | |
4B | 75 | K | MTA11 | 6B | 107 | k | MSA11, PPE, CFG11 | |
4C | 76 | L | MTA12 | 6C | 108 | l | MSA12, PPE, CFG12 | |
4D | 77 | M | MTA13 | 6D | 109 | m | MSA13, PPE, CFG13 | |
4E | 78 | N | MTA14 | 6E | 110 | n | MSA14, PPE, CFG14 | |
4F | 79 | O | MTA15 | 6F | 111 | o | MSA15, PPE, CFG15 | |
50 | 80 | P | MTA16 | 70 | 112 | p | MSA16, PPD | |
51 | 81 | Q | MTA17 | 71 | 113 | q | MSA17, PPD | |
52 | 82 | R | MTA18 | 72 | 114 | r | MSA18, PPD | |
53 | 83 | S | MTA19 | 73 | 115 | s | MSA19, PPD | |
54 | 84 | T | MTA20 | 74 | 116 | t | MSA20, PPD | |
55 | 85 | U | MTA21 | 75 | 117 | u | MSA21, PPD | |
56 | 86 | V | MTA22 | 76 | 118 | v | MSA22, PPD | |
57 | 87 | W | MTA23 | 77 | 119 | w | MSA23, PPD | |
58 | 88 | X | MTA24 | 78 | 120 | x | MSA24, PPD | |
59 | 89 | Y | MTA25 | 79 | 121 | y | MSA25, PPD | |
5A | 90 | Z | MTA26 | 7A | 122 | z | MSA26, PPD | |
5B | 91 | [ | MTA27 | 7B | 123 | { | MSA27, PPD | |
5C | 92 | \ | MTA28 | 7C | 124 | | | MSA28, PPD | |
5D | 93 | ] | MTA29 | 7D | 125 | } | MSA29, PPD | |
5E | 94 | ^ | MTA30 | 7E | 126 | ~ | MSA30, PPD | |
5F | 95 | _ | UNT | 7F | 127 | DEL | — |
Multiline Interface Message Definitions | |||
---|---|---|---|
CFE * | Configuration Enable | PPD | Parallel Poll Disable |
CFG * | Configure | PPE | Parallel Poll Enable |
DCL | Device Clear | PPU | Parallel Poll Unconfigure |
GET | Group Execute Trigger | SDC | Selected Device Clear |
GTL | Go To Local | SPD | Serial Poll Disable |
LLO | Local Lockout | SPE | Serial Poll Enable |
MLA | My Listen Address | TCT | Take Control |
MSA | My Secondary Address | UNL | Unlisten |
MTA | My Talk Address | UNT | Untalk |
PPC | Parallel Poll Configure | ||
* This multiline interface message is a proposed extension to the IEEE 488 specification to support the HS488 protocol. |