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.

Figure 12. GPIB Extender Block Diagram

1378

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.

Table 4. 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.

Table 4. 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.

Figure 13. GPIB Connector and Signal Assignments

1378

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.

Figure 14. Linear and Star System Configuration

1378

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.

Figure 15. IEEE 488.1 Transfers

1378

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.

Figure 16. HS488 Transfers

1378

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.

Figure 17. HS488-Capable Talker and Listener

1378

  1. The Controller addresses devices and becomes Standby Controller by unasserting ATN.
  2. The Listener asserts NDAC and NRFD.
  3. The Listener unasserts NRFD as it becomes ready to accept a byte.
  4. 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.
  5. 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.
  6. 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.
  7. 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.
  8. The Talker unasserts DAV and drives the next data byte on the GPIB.
  9. After allowing some settling time, the Talker asserts DAV.
  10. The Listener latches the byte in response to the assertion (falling) edge of DAV.
  11. 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.

Figure 18. HS488-Capable Talker

1378

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.

Figure 19. Listener Is HS488-Capable

1378

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.

Table 5. Multiline Interface Messages
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.