Revision as of 13:32, 10 January 2015 edit31.48.73.38 (talk) →Use as a computer interface: This is what the reference says so that is what the article has to say.← Previous edit | Latest revision as of 11:46, 21 November 2024 edit undoSbmeirow (talk | contribs)Extended confirmed users, Rollbackers117,052 edits →External links: simplify | ||
(100 intermediate revisions by 61 users not shown) | |||
Line 1: | Line 1: | ||
{{short description|General Purpose Interface Bus (GPIB) specification}} | |||
] | |||
{{Lead too short|date=January 2024}} | |||
] | |||
'''IEEE |
'''IEEE 488''', also known as '''HP-IB''' ('''Hewlett-Packard Interface Bus''') and generically as '''GPIB''' ('''General Purpose Interface Bus'''), is a short-range digital communications ] ] ] ] specification developed by ]. It subsequently became the subject of several standards. | ||
Although the bus was created in the late 1960s to connect together ], it also had some success during the 1970s and 1980s as a ] for early ]s, notably the ]. Newer standards have largely replaced IEEE 488 for computer use, but it is still used by test equipment. | |||
==Origins== | |||
In the late 1960s, ]<ref>This part of HP was later spun off as ].</ref> was manufacturing various automated test and measurement instruments, such as digital ]s and ]s. They developed the ''HP Interface Bus (HP-IB)'' to enable easier interconnection between instruments and controllers (computers and other instruments). | |||
== History == | |||
The bus was relatively easy to implement using the technology at the time, using a simple parallel ] and several individual control lines. For example, the HP 59501 Power Supply Programmer and HP 59306A Relay Actuator were both relatively simple HP-IB peripherals implemented only in ], using no microprocessor. | |||
In the 1960s, ] (HP) manufactured various automated test and measurement instruments, such as digital ]s and ]s. They developed the ''HP Interface Bus (HP-IB)'' to enable easier interconnection between instruments and controllers (computers and other instruments).<ref>{{cite journal |first=Gerald E. |last=Nelson |first2=David W. |last2=Ricci |title=A Practical Interface System for Electronic Instruments |journal=Hewlett-Packard Journal |volume=24 |issue=2 |pages=2–7 |date=October 1972 |url=http://hparchive.com/Journals/HPJ-1972-10.pdf |quote=Controllers: 3260A Marked Card Reader; ] Calculator (with 11144A Interface Kit) }}<br/>{{cite journal |first=Donald C. |last=Loughry |title=A Common Digital Interface for Programmable Instruments: The Evolution of a System |journal=Hewlett-Packard Journal |volume=24 |issue=2 |pages=8–11 |date=October 1972 |url=http://hparchive.com/Journals/HPJ-1972-10.pdf}}</ref> This part of HP was later (c. 1999) spun off as ], and in 2014 Agilent's test and measurement division was spun off as ].{{cn|date=January 2024}} | |||
The bus was relatively easy to implement using the technology at the time, using a simple parallel ] and several individual control lines. For example, the HP 59501 Power Supply Programmer and HP 59306A Relay Actuator were both relatively simple HP-IB peripherals implemented in ], without the need for a microprocessor. | |||
HP licensed the HP-IB patents for a nominal fee to other manufacturers. It became known as the General Purpose Interface Bus (GPIB), and became a ] for automated and industrial instrument control. As GPIB became popular, it was formalized by various ]s. | HP licensed the HP-IB patents for a nominal fee to other manufacturers. It became known as the General Purpose Interface Bus (GPIB), and became a ] for automated and industrial instrument control. As GPIB became popular, it was formalized by various ]s. | ||
In 1975, the ] standardized the bus as ''Standard Digital Interface for Programmable Instrumentation'', IEEE 488; it was revised in 1978 (producing IEEE 488-1978).<ref>{{Citation |title=IEEE Standard Digital Interface for Programmable Instrumentation |publisher=] |year=1978 |id=ANSI/IEEE Std 488-1978 |isbn=978-1-5044-0366-5 |doi=10.1109/IEEESTD.1978.7425098}}<br>{{Citation |title=IEEE Standard Digital Interface for Programmable Instrumentation |publisher=] |year=1987 |id=ANSI/IEEE Std 488.1-1987 |isbn=0-471-62222-2 <!-- This is the ISBN on the document --> }}, p. iii</ref> The standard was revised in 1987, and redesignated as IEEE 488.1 (IEEE 488.1-1987). These standards formalized the mechanical, electrical, and basic protocol parameters of GPIB, but said nothing about the format of commands or data. | |||
==Standards== | |||
In 1975, the ] standardized the bus as ''Standard Digital Interface for Programmable Instrumentation'', '''IEEE-488'''; it was revised in 1978 (producing IEEE-488-1978).<ref>{{Citation |title=IEEE Standard Digital Interface for Programmable Instrumentation |publisher=] |year=1987 |id=ANSI/IEEE Std 488.1-1987 |isbn=0-471-62222-2 <!-- This is the ISBN on the document --> |doi= }}, p. iii</ref> The standard was revised in 1987, and redesignated as '''IEEE-488.1''' (IEEE-488.1-1987). These standards formalized the mechanical, electrical, and basic protocol parameters of GPIB, but said nothing about the format of commands or data. | |||
In 1987, IEEE introduced ''Standard Codes, Formats, Protocols, and Common Commands'', |
In 1987, IEEE introduced ''Standard Codes, Formats, Protocols, and Common Commands'', IEEE 488.2. It was revised in 1992.<ref>{{Citation |title=IEEE Standard Codes, Formats, Protocols, and Common Commands for Use With IEEE Std 488.1-1987, IEEE Standard Digital Interface for Programmable Instrumentation |publisher=] |year=1992 |id=IEEE Std 488.2-1992 |isbn=978-1-55937-238-1 }}</ref> IEEE 488.2 provided for basic syntax and format conventions, as well as device-independent commands, data structures, error protocols, and the like. IEEE 488.2 built on IEEE 488.1 without superseding it; equipment can conform to IEEE 488.1 without following IEEE 488.2. | ||
While IEEE |
While IEEE 488.1 defined the hardware and IEEE 488.2 defined the protocol, there was still no standard for instrument-specific commands. Commands to control the same class of instrument, ''e.g.'', multimeters, varied between manufacturers and even models. | ||
The United States Air Force,<ref>Project Mate in 1985</ref> and later Hewlett-Packard, recognized this as a problem. In 1989, HP developed their Test Measurement Language (TML)<ref>{{cite web | title = GPIB 101, A Tutorial of the GPIB Bus | publisher = ICS Electronics | url = http://www.icselect.com/ab_note.html#anchor338658 | page=5, paragraph = SCPI Commands }}</ref> or Test and Measurement Systems Language (TMSL)<ref>{{cite web | title = Hewlett Packard Test & Measurement Catalog 1991 | publisher = hparchive.com | url = http://hparchive.com/Catalogs/HP-Catalog-1991.pdf | page=8, paragraph = SCPI }}</ref> which was the forerunner to ] (SCPI), introduced as an industry standard in 1990.<ref>{{cite web | title = History of GPIB | publisher = National Instruments | url = http://zone.ni.com/devzone/cda/tut/p/id/3419 | quote = In 1990, the IEEE 488.2 specification included the Standard Commands for Programmable Instrumentation (SCPI) document. | access-date = 2010-02-06 }}</ref> SCPI added standard generic commands, and a series of instrument classes with corresponding class-specific commands. SCPI mandated the IEEE 488.2 syntax, but allowed other (non-IEEE 488.1) physical transports. | |||
The United States Air Force,<ref>Project Mate in 1985</ref> and later Hewlett-Packard, recognized this problem. In 1989, HP developed their TML language<ref>{{cite web | |||
|title=GPIB 101, A Tutorial of the GPIB Bus | |||
|publisher=ICS Electronics | |||
|url=http://www.icselect.com/ab_note.html#anchor338658 | |||
|page=5, paragraph=SCPI Commands | |||
}}</ref> which was the forerunner to ] (SCPI). SCPI was introduced as an industry standard in 1990.<ref>{{cite web | |||
|title=History of GPIB | |||
|publisher=National Instruments | |||
|url=http://zone.ni.com/devzone/cda/tut/p/id/3419 | |||
|quote=In 1990, the IEEE 488.2 specification included the Standard Commands for Programmable Instrumentation (SCPI) document. | |||
|accessdate=2010-02-06 | |||
}}</ref> SCPI added standard generic commands, and a series of instrument classes with corresponding class-specific commands. SCPI mandated the IEEE-488.2 syntax, but allowed other (non-IEEE-488.1) physical transports. | |||
The ] developed their own standards in parallel with the IEEE, with |
The ] developed their own standards in parallel with the IEEE, with IEC 60625-1 and IEC 60625-2 (IEC 625), later replaced by ]. | ||
] introduced a backward-compatible extension to IEEE |
] introduced a backward-compatible extension to IEEE 488.1, originally known as HS-488. It increased the maximum data rate to 8 ]/s, although the rate decreases as more devices are connected to the bus. This was incorporated into the standard in 2003 (IEEE 488.1-2003),<ref>{{Cite web | title = Upgraded Standard Boosts Speed of IEEE 488 Instrument Buses Eightfold | date = 2003-10-06 | publisher = IEEE | url = http://standards.ieee.org/announcements/pr_4881upgrade.html | archive-url = https://web.archive.org/web/20031207052849/http://standards.ieee.org/announcements/pr_4881upgrade.html | url-status = dead | archive-date = December 7, 2003 | access-date = 2010-02-06 }}</ref> over HP's objections.<ref>{{Cite press release|title=HP and Other Test and Measurement Companies Urge IEEE to Oppose Revisions of Established IEEE 488 Standard |publisher=Hewlett-Packard Company |date=December 1997 |url=http://grouper.ieee.org/groups/imstc8/488/1/hppress12-97.html |access-date=2010-02-16 |url-status=dead |archive-url=https://web.archive.org/web/20110610164221/http://grouper.ieee.org/groups/imstc8/488/1/hppress12-97.html |archive-date=2011-06-10}}</ref><ref>{{cite web|title=P488.1 Project Home |publisher=IEEE |url=http://grouper.ieee.org/groups/imstc8/488/1/ |access-date=2010-02-16 |url-status=dead |archive-url=https://web.archive.org/web/20100428090906/http://grouper.ieee.org/groups/imstc8/488/1/ |archive-date=2010-04-28}}</ref> | ||
|title=Upgraded Standard Boosts Speed of IEEE 488 Instrument Buses Eightfold | |||
|date=6 October 2003 | |||
|publisher=IEEE | |||
|url=http://standards.ieee.org/announcements/pr_4881upgrade.html | |||
|accessdate=2010-02-06 | |||
}} | |||
</ref> over HP's objections.<ref>{{Cite press release | |||
|title=HP and Other Test and Measurement Companies Urge IEEE to Oppose Revisions of Established IEEE-488 Standard | |||
|publisher=Hewlett-Packard Company | |||
|date=December 1997 | |||
|url=http://grouper.ieee.org/groups/imstc8/488/1/hppress12-97.html | |||
|accessdate=2010-02-16 | |||
}}</ref><ref>{{cite web | |||
|title=P488.1 Project Home | |||
|publisher=IEEE | |||
|url=http://grouper.ieee.org/groups/imstc8/488/1/ | |||
|accessdate=2010-02-16 | |||
}}</ref> | |||
In 2004, the IEEE and IEC combined their respective standards into a "Dual Logo" IEEE/IEC standard IEC 60488-1, ''Standard for Higher Performance Protocol for the Standard Digital Interface for Programmable Instrumentation - Part 1: General'',<ref>{{cite book | title = IEC/IEEE Standard for Higher Performance Protocol for the Standard Digital Interface for Programmable Instrumentation - Part 1: General (Adoption of IEEE Std 488.1-2003) | publisher = IEEE | doi = 10.1109/IEEESTD.2004.95749 | isbn = 978-0-7381-4536-5 }}</ref> replaces IEEE 488.1/IEC 60625-1, and IEC 60488-2,''Part 2: Codes, Formats, Protocols and Common Commands'',<ref>{{cite book | title = Standard Digital Interface for Programmable Instrumentation- Part 2: Codes, Formats, Protocols and Common Commands (Adoption of (IEEE Std 488.2-1992) | publisher = IEEE | doi = 10.1109/IEEESTD.2004.95390 | hdl = 11059/14380 | isbn = 978-0-7381-4100-8 }}</ref> replaces IEEE 488.2/IEC 60625-2.<ref>{{cite web | title = Replaced or Withdrawn Publications | url = http://www.iec.ch/cgi-bin/procgi.pl/www/iecwww.p?header=IEC&search=replaced&wwwprog=sea22.p | publisher = IEC | access-date = 2010-02-06 | url-status = dead | archive-url = https://archive.today/20120417191411/http://www.iec.ch/cgi-bin/procgi.pl/www/iecwww.p?header=IEC&search=replaced&wwwprog=sea22.p | archive-date = 2012-04-17 }}</ref> | |||
In 2004, the IEEE and IEC combined their respective standards into a "Dual Logo" IEEE/IEC standard '''IEC-60488-1''', ''Standard for Higher Performance Protocol for the Standard Digital Interface for Programmable Instrumentation - Part 1: General'',<ref>{{cite web | |||
|title=IEC/IEEE Standard for Higher Performance Protocol for the Standard Digital Interface for Programmable Instrumentation - Part 1: General (Adoption of IEEE Std 488.1-2003) | |||
|publisher=IEEE | |||
|url=http://ieeexplore.ieee.org/xpl/freeabs_all.jsp?tp=&isnumber=30476&arnumber=1405845&punumber=9646 | |||
|accessdate=2010-02-06 | |||
}}</ref> replaces IEEE-488.1/IEC-60625-1, and '''IEC-60488-2''',''Part 2: Codes, Formats, Protocols and Common Commands'',<ref>{{cite web | |||
|title=Standard Digital Interface for Programmable Instrumentation- Part 2: Codes, Formats, Protocols and Common Commands (Adoption of (IEEE Std 488.2-1992) | |||
|publisher=IEEE | |||
|url=http://ieeexplore.ieee.org/xpl/freeabs_all.jsp?tp=&isnumber=29721&arnumber=1352831&punumber=9359 | |||
|accessdate=2010-02-06 | |||
}}</ref> replaces IEEE-488.2/IEC-60625-2.<ref>{{cite web | |||
|title=Replaced or Withdrawn Publications | |||
|url=http://www.iec.ch/cgi-bin/procgi.pl/www/iecwww.p?header=IEC&search=replaced&wwwprog=sea22.p | |||
|publisher=IEC | |||
|accessdate=2010-02-06 | |||
}}</ref> | |||
== Characteristics == | == Characteristics == | ||
IEEE-488 is an ], electrically ] bus. The bus employs sixteen signal lines — eight used for bi-directional data transfer, three for handshake, and five for bus management — plus eight ground return lines. | |||
IEEE 488 is an ], electrically ] bus which employs sixteen signal lines — eight used for bi-directional data transfer, three for ], and five for bus management — plus eight ground return lines. | |||
Every device on the bus has a unique 5-bit primary ], in the range from 0 to 30 (31 total possible addresses).<ref name="NI-488.2">{{Cite book | |||
|title=NI-488.2 User Manual | |||
|date=February 2005 | |||
|publisher=National Instruments Corporation | |||
|id=NI P/N 370428C-01 | |||
|page=A-2 | |||
|chapter=GPIB Addressing | |||
|quote=The primary address is a number in the range 0 to 30. | |||
|url=http://www.ni.com/pdf/manuals/370428c.pdf | |||
|accessdate=2010-02-16 | |||
}}</ref><ref name="Agilent_82350B">{{Cite book | |||
|title=Agilent 82350B PCI GPIB Interface: Installation and Configuration Guide | |||
|date=20 July 2009 | |||
|publisher=Agilent Technologies | |||
|id=Agilent P/N 82350-90004 | |||
|page=26 | |||
|chapter=Table 1-1: 82350 GPIB interface card configuration parameters | |||
|quote=any address in the range 0 - 30, inclusive, may be used | |||
|url=http://cp.literature.agilent.com/litweb/pdf/82350-90004.pdf | |||
|accessdate=2010-02-16 | |||
}}</ref> | |||
The bus supports 31 five-bit primary device addresses numbered from 0 to 30, allocating a unique address to each device on the bus.<ref name="NI-488.2">{{Cite book | title = NI-488.2 User Manual | date = February 2005 | publisher = National Instruments Corporation | id = NI P/N 370428C-01 | page = A-2 | chapter = GPIB Addressing | quote = The primary address is a number in the range 0 to 30. | chapter-url = http://www.ni.com/pdf/manuals/370428c.pdf | access-date = 2010-02-16 }}</ref><ref name="Agilent_82350B">{{Cite book|chapter-url=http://literature.cdn.keysight.com/litweb/pdf/82350-90004.pdf|title=Agilent 82350B PCI GPIB Interface: Installation and Configuration Guide|date=2009-07-20|publisher=Agilent Technologies|page=26|chapter=Table 1-1: 82350 GPIB interface card configuration parameters|id=Agilent P/N 82350-90004|quote=any address in the range 0 - 30, inclusive, may be used|access-date=2010-02-16}}</ref> | |||
The standard allows up to 15 devices to share a single physical bus of up to 20 meters total cable length. The physical topology can be linear or star (forked).<ref>{{Cite web | |||
|title=GPIB Instrument Control Tutorial | |||
|publisher=National Instruments | |||
|date=24 August 2009 | |||
|quote=connected in either a daisy-chain or star topology | |||
|url=http://zone.ni.com/devzone/cda/tut/p/id/2761 | |||
|accessdate=2010-02-16 | |||
}}</ref> Active extenders allow longer buses, with up to 31 devices theoretically possible on a logical bus. | |||
The standard allows up to 15 devices to share a single physical bus of up to {{convert|20|m}} total cable length. The physical topology can be linear or star (forked).<ref>{{Cite web | title = GPIB Instrument Control Tutorial | publisher = National Instruments | date = 2009-08-24 | quote = connected in either a daisy-chain or star topology | url = http://zone.ni.com/devzone/cda/tut/p/id/2761 | access-date = 2010-02-16 }}</ref> Active extenders allow longer buses, with up to 31 devices theoretically possible on a logical bus. | |||
Control and data transfer functions are logically separated; a controller can address one device as a “talker” and one or more devices as “listeners” without having to participate in the data transfer. It is possible for multiple controllers to share the same bus; but only one can be the "Controller In Charge" at a time.<ref>{{Cite book | |||
|title=NI-488.2 User Manual | |||
|date=February 2005 | |||
|publisher=National Instruments Corporation | |||
|id=NI P/N 370428C-01 | |||
|page=A-1 | |||
|url=http://www.ni.com/pdf/manuals/370428c.pdf | |||
|accessdate=2010-02-16 | |||
}}</ref> | |||
Control and data transfer functions are logically separated; a controller can address one device as a "talker" and one or more devices as "listeners" without having to participate in the data transfer. It is possible for multiple controllers to share the same bus, but only one can be the "Controller In Charge" at a time.<ref>{{Cite book | title = NI-488.2 User Manual | date = February 2005 | publisher = National Instruments Corporation | id = NI P/N 370428C-01 | page = A-1 | url = http://www.ni.com/pdf/manuals/370428c.pdf | access-date = 2010-02-16 | archive-url = https://web.archive.org/web/20081202204121/http://www.ni.com/pdf/manuals/370428c.pdf | archive-date = 2008-12-02 | url-status = dead }}</ref> | |||
In the original protocol, transfers use an interlocked, three-wire ''ready–valid–accepted'' ].<ref>{{Cite book | |||
|title=NI-488.2 User Manual | |||
|date=February 2005 | |||
|publisher=National Instruments Corporation | |||
|id=NI P/N 370428C-01 | |||
|page=A-3 | |||
|chapter=Handshake Lines | |||
|url=http://www.ni.com/pdf/manuals/370428c.pdf | |||
|accessdate=2010-02-16 | |||
}}</ref> The maximum data rate is about one megabyte per second. The later HS-488 extension relaxes the handshake requirements, allowing up to 8 Mbyte/s. The slowest participating device determines the speed of the bus.<ref>{{Cite web | |||
|title=Using HS488 to Improve GPIB System Performance | |||
|publisher=National Instruments Corporation | |||
|date=30 March 2009 | |||
|url=http://zone.ni.com/devzone/cda/tut/p/id/4552 | |||
|accessdate=2010-02-16 | |||
}}</ref> | |||
In the original protocol, transfers use an interlocked, three-wire ''ready–valid–accepted'' handshake.<ref>{{Cite book | title = NI-488.2 User Manual | date = February 2005 | publisher = National Instruments Corporation | id = NI P/N 370428C-01 | page = A-3 | chapter = Handshake Lines | chapter-url = http://www.ni.com/pdf/manuals/370428c.pdf | access-date = 2010-02-16 }}</ref> The maximum data rate is about one megabyte per second. The later HS-488 extension relaxes the handshake requirements, allowing up to 8 Mbyte/s. The slowest participating device determines the speed of the bus.<ref>{{Cite web | title = Using HS488 to Improve GPIB System Performance | publisher = National Instruments Corporation | date = 30 March 2009 | url = http://zone.ni.com/devzone/cda/tut/p/id/4552 | access-date = 2010-02-16 }}</ref> | |||
== Connectors == | |||
== Connectors == | |||
{{Infobox connector | |||
{{ infobox connector | |||
|name=IEEE-488 | |||
| name = IEEE 488 | |||
|pinout_image=] | |||
| pinout_image = ] | |||
|pinout_caption=Female IEEE-488 connector | |||
| pinout_caption = Female IEEE 488 connector | |||
|pin1=Data input/output bit. | |||
|pin1_name=DIO1 | | pin1 = Data input/output bit | pin1_name = DIO1 | ||
|pin2=Data input/output bit |
| pin2 = Data input/output bit | pin2_name = DIO2 | ||
| pin3 = Data input/output bit | pin3_name = DIO3 | |||
|pin2_name=DIO2 | |||
| |
| pin4 = Data input/output bit | pin4_name = DIO4 | ||
| pin5 = End-or-identify | pin5_name = EOI | |||
|pin3_name=DIO3 | |||
| pin6 = Data valid | pin6_name = DAV | |||
|pin4=Data input/output bit. | |||
| pin7 = Not ready for data | pin7_name = NRFD | |||
|pin4_name=DIO4 | |||
| pin8 = Not data accepted | pin8_name = NDAC | |||
|pin5=End-or-identify. | |||
| pin9 = Interface clear | pin9_name = IFC | |||
|pin5_name=EOI | |||
| pin10 = Service request | pin10_name = SRQ | |||
|pin6=Data valid. | |||
| pin11 = Attention | pin11_name = ATN | |||
|pin6_name=DAV | |||
| pin12 = | pin12_name = SHIELD | |||
|pin7=Not ready for data. | |||
| pin13 = Data input/output bit | pin13_name = DIO5 | |||
|pin7_name=NRFD | |||
| pin14 = Data input/output bit | pin14_name = DIO6 | |||
|pin8=Not data accepted. | |||
| pin15 = Data input/output bit | pin15_name = DIO7 | |||
|pin8_name=NDAC | |||
| pin16 = Data input/output bit | pin16_name = DIO8 | |||
|pin9=Interface clear. | |||
| pin17 = Remote enable | pin17_name = REN | |||
|pin9_name=IFC | |||
| pin18 = (wire twisted with DAV) | pin18_name = GND | |||
|pin10=Service request. | |||
| pin19 = (wire twisted with NRFD) | pin19_name = GND | |||
|pin10_name=SRQ | |||
| pin20 = (wire twisted with NDAC) | pin20_name = GND | |||
|pin11=Attention. | |||
| pin21 = (wire twisted with IFC) | pin21_name = GND | |||
|pin11_name=ATN | |||
| pin22 = (wire twisted with SRQ) | pin22_name = GND | |||
|pin12= | |||
| pin23 = (wire twisted with ATN) | pin23_name = GND | |||
|pin12_name=SHIELD | |||
| pin24 = | pin24_name = Logic ground | |||
|pin13=Data input/output bit. | |||
|pin13_name=DIO5 | |||
|pin14=Data input/output bit. | |||
|pin14_name=DIO6 | |||
|pin15=Data input/output bit. | |||
|pin15_name=DIO7 | |||
|pin16=Data input/output bit. | |||
|pin16_name=DIO8 | |||
|pin17=Remote enable. | |||
|pin17_name=REN | |||
|pin18=(wire twisted with DAV) | |||
|pin18_name=GND | |||
|pin19=(wire twisted with NRFD) | |||
|pin19_name=GND | |||
|pin20=(wire twisted with NDAC) | |||
|pin20_name=GND | |||
|pin21=(wire twisted with IFC) | |||
|pin21_name=GND | |||
|pin22=(wire twisted with SRQ) | |||
|pin22_name=GND | |||
|pin23=(wire twisted with ATN) | |||
|pin23_name=GND | |||
|pin24= | |||
|pin24_name=Logic ground | |||
}} | }} | ||
IEEE |
IEEE 488 specifies a 24-pin ]-designed ] connector. Micro ribbon connectors have a D-shaped metal shell, but are larger than ] connectors. They are sometimes called "Centronics connectors" after the 36-pin micro ribbon connector ] used for their printers. | ||
One unusual feature of IEEE 488 connectors is they commonly use a "double-headed" design, with male on one side, and female on the other. This allows stacking connectors for easy ]. Mechanical considerations limit the number of stacked connectors to four or fewer, although a workaround involving physically supporting the connectors may be able to get around this. | |||
They are held in place by screws, either 6-32 UNK<ref>{{Cite book|chapter-url=http://bitsavers.org/pdf/hp/hpib/TutorialDescrOfHPIB.pdf |title=Tutorial Description of the Hewlett-Packard Interface Bus |publisher=Hewlett-Packard|page=28|chapter=Mechanical Aspects|quote=Some existing cables use English threads (6-32UNK).|access-date=2022-06-13}}</ref> (now largely obsolete) or ] M3.5×0.6 ]s. Early versions of the standard suggested that metric screws should be blackened to avoid confusion with the incompatible UTS threads. However, by the 1987 revision this was no longer considered necessary because of the prevalence of metric threads.<ref>{{Citation |title=IEEE Standard Digital Interface for Programmable Instrumentation |publisher=] |year=1987 |id=ANSI/IEEE Std 488.1-1987 |isbn=978-0-471-62222-2|page=v|quote=The "helpful note" on metric threads found in previous editions has been deleted since metric thread use is common IEEE 488 practice. Consequently, the recommendation to coat such parts in black material to call attention to metric threads is also considered unnecessary.}}</ref> | |||
One unusual feature of IEEE-488 connectors is they commonly use a "double-headed" design, with male on one side, and female on the other. This allows stacking connectors for easy ]. Mechanical considerations limit the number of stacked connectors to four or fewer, although a possible workaround involving physically supporting the connectors can expand this. | |||
The IEC 60625 standard prescribes the use of 25-pin ] connectors (the same as used for the ] on ]s). This connector did not gain significant market acceptance against the established 24-pin connector. | |||
They are held in place by screws, either ] (now largely obsolete) or ] M3.5×0.6 ]s. By convention, metric screws are colored black, as the two threads do not mate. | |||
== Capabilities == | |||
The IEC-60625 standard prescribes the use of 25-pin ] connectors (the same as used for the ] on ]s). This connector did not gain significant market acceptance against the established 24-pin connector. | |||
] | |||
==Capabilities== | |||
{| class="wikitable" | {| class="wikitable" | ||
|+ Capabilities<ref>{{Citation |last=Tilden |first=Mark D. |title=4041 GPIB Programming Guide |year=1983 |chapter=Appendix A: Subsets Describe Interface Functions |pages= 113–115 |publisher=Tektronix, Inc. |chapter-url=http://www.mirrorservice.org/sites/www.bitsavers.org/pdf/tektronix/404x/070-4696-00_4041_GPIB_Programming_Guide_Sep1983.pdf }}</ref> | |||
|- | |- | ||
! Function | |||
! Function !! Abbreviation !! Description / Example | |||
! colspan=2 | Abbreviation | |||
! Description and examples | |||
|- | |- | ||
| Source Handshake |
| Source Handshake | ||
| SH | |||
| 1 | |||
| Complete | |||
|- | |- | ||
| Acceptor Handshake|| AH |
| Acceptor Handshake|| AH | ||
| 1 | |||
| Complete | |||
|- | |- | ||
| rowspan=3 | Basic Talker | |||
| Basic Talker || T || T5 - responds to serial poll; untalks when listen address received; talk only capability<br>T6 - untalks when listen address received; no talk only<br>T7 - no serial poll; untalks when listen address received; talk only capability | |||
| rowspan=3 | T | |||
| 5 | |||
| Responds to serial poll; untalks when listen address received; talk only capability | |||
|- | |- | ||
| 6 | |||
| Extended Talker || TE || TE0 - no extended talker | |||
| Untalks when listen address received; no talk only | |||
|- | |- | ||
| 7 | |||
| Basic Listener || L || L3 - Listen only mode; unlistens if talk address received<br>L4 - Unlistens if talk address received | |||
| No serial poll; untalks when listen address received; talk only capability | |||
|- | |- | ||
| Extended Talker | |||
| Extended Listener || LE || LE0 - no extended listener | |||
| TE | |||
| 0 | |||
| No extended talker | |||
|- | |- | ||
| rowspan=2 | Basic Listener | |||
| Service Request || SR || SR0 - no service request capability<br>SR1 - complete | |||
| rowspan=2 | L | |||
| 3 | |||
| Listen only mode; unlistens if talk address received | |||
|- | |- | ||
| 4 | |||
| Remote-Local || RL || RL0 - no local lockout<br>RL1 - complete | |||
| Unlistens if talk address received | |||
|- | |- | ||
| Extended Listener | |||
| Parallel Poll || PP || PP0 - does not respond to Parallel Poll | |||
| LE | |||
| 0 | |||
| No extended listener | |||
|- | |- | ||
| rowspan=2 | Service Request | |||
| Device Clear || DC || DC1 - complete | |||
| rowspan=2 | SR | |||
| 0 | |||
| No service request capability | |||
|- | |- | ||
| 1 | |||
| Device Trigger || DT || DT0 - no device trigger capability<br>DT1 - complete | |||
| Complete | |||
|- | |- | ||
| rowspan=2 | Remote-Local | |||
| Controller || C || C0 - no controller function | |||
| rowspan=2 | RL | |||
| 0 | |||
| No local lockout | |||
|- | |- | ||
| 1 | |||
| || E || E1 - open collector drive electronics<br>E2 - three state drivers | |||
| Complete | |||
|- | |||
| Parallel Poll | |||
| PP | |||
| 0 | |||
| Does not respond to Parallel Poll | |||
|- | |||
| Device Clear | |||
| DC | |||
| 1 | |||
| complete | |||
|- | |||
| rowspan=2 | Device Trigger | |||
| rowspan=2 | DT | |||
| 0 | |||
| No device trigger capability | |||
|- | |||
| 1 | |||
| Complete | |||
|- | |||
| Controller | |||
| C | |||
| 0 | |||
| No controller function | |||
|- | |||
| rowspan=2 | | |||
| rowspan=2 | E | |||
| 1 | |||
| Open collector drive electronics | |||
|- | |||
| 2 | |||
| Three state drivers | |||
|} | |} | ||
More information see Tektronix.<ref>{{Citation |last=Tilden |first=Mark D. |title=4041 GPIB Programming Guide |year=1983 |chapter=Appendix A: Subsets Describe Interface Functions |pages= 113–115 |publisher=Tektronix, Inc. |url=http://www.xmission.com/~legalize/vintage/docs/tektronix/070-4696-00_4041_GPIB_Programming_Guide_Sep1983.pdf |doi= }}</ref> | |||
==Use as a computer interface== | == Use as a computer interface == | ||
] GPIB controller card for ] bus]] | |||
HP's designers did not specifically plan for IEEE |
HP's designers did not specifically plan for IEEE 488 to be a peripheral interface for general-purpose computers; the focus was on instrumentation. But when HP's early ]s needed an interface for peripherals (]s, ]s, ], ]s, etc.), HP-IB was readily available and easily adapted to the purpose. | ||
HP computer products which used HP-IB included the ], ],<ref>{{cite web | title = HP 98135A HP-IB Interface 9815 | url=http://www.hpmuseum.net/display_item.php?hw=463 | work = HP Computer Museum | access-date = 2010-02-06 }}</ref> the ] series,<ref>{{cite web | title = 59310A HP-IB Interface | quote = HP-IB interface for HP1000 and HP2000 computers | url=http://www.hpmuseum.net/display_item.php?hw=522 | work = HP Computer Museum | access-date = 2010-02-06 }}</ref> and the ] series.<ref>{{cite web | title = 27113A HP-IB Interface | quote = CIO HP-IB interface for 3000 Series 900 | url=http://www.hpmuseum.net/display_item.php?hw=786 | work = HP Computer Museum | access-date = 2010-02-06 }}</ref> HP computer peripherals which did not utilize the RS-232 communication interface often used HP-IB including disc systems like the ]. Some of HP's advanced pocket calculators of the 1980s, such as the ] and ] series, also had IEEE 488 capabilities, via an optional ]/HP-IB interface module. | |||
HP computer products which used HP-IB included the ], ],<ref>{{cite web | |||
|title=HP 98135A HP-IB Interface 9815 | |||
|url=http://www.hpmuseum.net/display_item.php?hw=463 | |||
|work=HP Computer Museum | |||
|accessdate=2010-02-06 | |||
}}</ref> the ] series,<ref>{{cite web | |||
|title=59310A HP-IB Interface | |||
|quote=HP-IB interface for HP1000 and HP2000 computers | |||
|url=http://www.hpmuseum.net/display_item.php?hw=522 | |||
|work=HP Computer Museum | |||
|accessdate=2010-02-06 | |||
}}</ref> and the ] series.<ref>{{cite web | |||
|title=27113A HP-IB Interface | |||
|quote=CIO HP-IB interface for 3000 Series 900 | |||
|url=http://www.hpmuseum.net/display_item.php?hw=786 | |||
|work=HP Computer Museum | |||
|accessdate=2010-02-06 | |||
}}</ref> Some of HP's advanced pocket calculators of the 1980s, such as the ] and ] series, also had IEEE-488 capabilities, via an optional ]/HP-IB interface module. | |||
Other manufacturers adopted GPIB for their computers as well, such as with the ] line. | Other manufacturers adopted GPIB for their computers as well, such as with the ] line. | ||
The ] (introduced 1977) range of personal computers connected their peripherals using the IEEE |
The ] (introduced 1977) range of personal computers connected their peripherals using the IEEE 488 bus, but with a non-standard card edge connector. Commodore's following 8-bit machines utilized a ] whose protocol was based on IEEE 488.<ref>{{cite book |last=Bagnall |first=Brian |date=2006 |title=On the Edge: The Spectacular Rise and Fall of Commodore |publisher=Variant Press |page=221 |isbn=0-9738649-0-7 |oclc=761384138 }}</ref> Commodore marketed an IEEE 488 cartridge for the VIC-20<ref>Commodore drawing for VIC-1112 - Drawing no. 1110010 Rev:A</ref> and the Commodore 64.<ref></ref> Several third party suppliers of ] made a cartridge for the C64 that provided an IEEE 488-derived interface on a card edge connector similar to that of the PET series.<ref>http://www.zimmers.net/anonftp/pub/cbm/schematics/cartridges/c64/ieee-488/index.html Link to schematic for one such converter.</ref> | ||
Eventually, faster, more complete standards such as ] superseded IEEE |
Eventually, faster, more complete standards such as ] superseded IEEE 488 for peripheral access. | ||
<gallery widths=160 heights=90> | |||
{{Gallery | |||
Commodore 8032-SK -- rear panel.jpg|Rear of ] showing IEEE 488 port | |||
|width=175 | |||
SFD1001 back.jpg|Rear of ] SFD 1001 ] with IEEE 488 port | |||
|lines=3 | |||
Technofor-IEEE488.JPG|C64 interface | |||
|Image:CBM610 back.jpg|Rear of the ] showing ] IEEE-488 port | |||
Acorn IEEE488 Interface (back).jpg|] IEEE 488 Interface | |||
|Image:SFD1001 back.jpg|Rear of the ] SFD 1001 ] with IEEE-488 port | |||
| |
USB-GPIB-Converter.jpg|] GPIB ] | ||
Digitaloszilloskop Schnittstellen IMGP1974 WP.jpg|Rear of ] TDS 210 digital ] with IEEE 488 port | |||
Data Acquisition Agilent %282%29.jpg|Rear of ] 34970A ] chassis / ] with IEEE 488 port | |||
Keithley DMM7510 7.5 Digit Bench Multimeter (16895247108).jpg|Rear of ] DMM7510 ] with IEEE 488 port | |||
|Image:Technofor-IEEE488.JPG|C64 interface | |||
7580B Plotter Settings.jpg|] 7580B ] with IEEE 488 port | |||
|Image:HP7935_rear_HP-IB_port.jpg|] disc drive HP-IB Panel | |||
Hp-thinkjet-a-rear.jpg| HP ] 2225A with IEEE 488 port | |||
}} | |||
</gallery> | |||
== Comparison with other interface standards == | == Comparison with other interface standards == | ||
Line 272: | Line 207: | ||
Electrically, IEEE 488 used a hardware interface that could be implemented with some discrete logic or with a microcontroller. The hardware interface enabled devices made by different manufacturers to communicate with a single host. Since each device generated the asynchronous handshaking signals required by the bus protocol, slow and fast devices could be mixed on one bus. The data transfer is relatively slow, so ] issues such as impedance matching and line termination are ignored. There was no requirement for ] between the bus and devices, which created the possibility of ] causing extra noise and loss of data. | Electrically, IEEE 488 used a hardware interface that could be implemented with some discrete logic or with a microcontroller. The hardware interface enabled devices made by different manufacturers to communicate with a single host. Since each device generated the asynchronous handshaking signals required by the bus protocol, slow and fast devices could be mixed on one bus. The data transfer is relatively slow, so ] issues such as impedance matching and line termination are ignored. There was no requirement for ] between the bus and devices, which created the possibility of ] causing extra noise and loss of data. | ||
Physically, the IEEE |
Physically, the IEEE 488 connectors and cabling were rugged and held in place by screws. While physically large and sturdy connectors were an advantage in industrial or laboratory set ups, the size and cost of the connectors was a liability in applications such as personal computers. | ||
Although the electrical and physical interfaces were well defined, there was not an initial standard command set. Devices from different manufacturers might use different commands for the same function.<ref>Early devices might respond to an <code>ID</code> command with an identification string; later standards had devices respond to the <code>*ID</code> command.</ref> Some aspects of the command protocol standards were not standardized until ] (SCPI) in 1990. |
Although the electrical and physical interfaces were well defined, there was not an initial standard command set. Devices from different manufacturers might use different commands for the same function.<ref>Early devices might respond to an <code>ID</code> command with an identification string; later standards had devices respond to the <code>*ID</code> command.</ref> Some aspects of the command protocol standards were not standardized until ] (SCPI) in 1990. Implementation options (e.g. end of transmission handling) can complicate interoperability in pre-IEEE 488.2 devices. | ||
More recent standards such as ], ], and ] take advantage of declining costs of interface electronics to implement more complex standards providing higher bandwidth. The multi-conductor (parallel data) connectors and shielded cable were inherently more costly than the connectors and cabling that could be used serial data transfer standards such as ], ], USB, FireWire or Ethernet. Very few mass-market personal computers or peripherals (such as printers or scanners) implemented IEEE 488. | More recent standards such as ], ], and ] take advantage of declining costs of interface electronics to implement more complex standards providing higher bandwidth. The multi-conductor (parallel data) connectors and shielded cable were inherently more costly than the connectors and cabling that could be used with serial data transfer standards such as ], ], USB, FireWire or Ethernet. Very few mass-market personal computers or peripherals (such as printers or scanners) implemented IEEE 488. | ||
==See also== | == See also == | ||
{{commonscat}} | |||
{{Commons category|IEEE 488}} | |||
* ] (SCPI) | |||
* ] (PXI) | |||
* ] (LXI) | |||
* ] (VISA) | |||
* ] | |||
* ] | |||
* {{annotated link|Commodore bus}} | |||
==References== | |||
* {{annotated link|HP Series 80}} | |||
{{Reflist|30em}} | |||
* {{annotated link|HP-IL}} | |||
* {{annotated link|LAN eXtensions for Instrumentation}} | |||
* {{annotated link|PCI eXtensions for Instrumentation}} | |||
* {{annotated link|Rocky Mountain BASIC}} | |||
* {{annotated link|Standard Commands for Programmable Instruments}} | |||
* {{annotated link|Virtual Instrument Software Architecture}} | |||
== |
== References == | ||
* {{Cite book|title=IEC-60488-1: Higher performance protocol for the standard digital interface for programmable instrumentation | |||
|volume=Part 1: General | |||
|publisher=International Electrotechnical Commission | |||
|date=15 July 2004 | |||
|url=http://webstore.iec.ch/webstore/webstore.nsf/artnum/032787 | |||
}} | |||
* {{Cite book|title=IEC-60488-2: Standard digital interface for programmable instrumentation | |||
|volume=Part 2: Codes, formats, protocols and common commands | |||
|publisher=International Electrotechnical Commission | |||
|date=7 May 2004 | |||
|url=http://webstore.iec.ch/webstore/webstore.nsf/ArtNum_PK/32175 | |||
}} | |||
* | |||
{{ |
{{refs}} | ||
== External links == | |||
;Part 1 Specifications | |||
* , 158 page PDF file, costs in 2024 | |||
;Part 2 Specifications | |||
* , 254 page PDF file, costs in 2024 ''(superseded by IEEE/IEC 60488-2-2004)'' | |||
* , 264 page PDF file, costs in 2024 | |||
;Other | |||
* | |||
{{Computer-bus}} | |||
{{IEEE standards}} | {{IEEE standards}} | ||
{{Authority control}} | |||
{{DEFAULTSORT:Ieee-488}} | |||
] | ] | ||
] | ] |
Latest revision as of 11:46, 21 November 2024
General Purpose Interface Bus (GPIB) specificationThis article's lead section may be too short to adequately summarize the key points. Please consider expanding the lead to provide an accessible overview of all important aspects of the article. (January 2024) |
IEEE 488, also known as HP-IB (Hewlett-Packard Interface Bus) and generically as GPIB (General Purpose Interface Bus), is a short-range digital communications 8-bit parallel multi-master interface bus specification developed by Hewlett-Packard. It subsequently became the subject of several standards.
Although the bus was created in the late 1960s to connect together automated test equipment, it also had some success during the 1970s and 1980s as a peripheral bus for early microcomputers, notably the Commodore PET. Newer standards have largely replaced IEEE 488 for computer use, but it is still used by test equipment.
History
In the 1960s, Hewlett-Packard (HP) manufactured various automated test and measurement instruments, such as digital multimeters and logic analyzers. They developed the HP Interface Bus (HP-IB) to enable easier interconnection between instruments and controllers (computers and other instruments). This part of HP was later (c. 1999) spun off as Agilent Technologies, and in 2014 Agilent's test and measurement division was spun off as Keysight Technologies.
The bus was relatively easy to implement using the technology at the time, using a simple parallel bus and several individual control lines. For example, the HP 59501 Power Supply Programmer and HP 59306A Relay Actuator were both relatively simple HP-IB peripherals implemented in TTL, without the need for a microprocessor.
HP licensed the HP-IB patents for a nominal fee to other manufacturers. It became known as the General Purpose Interface Bus (GPIB), and became a de facto standard for automated and industrial instrument control. As GPIB became popular, it was formalized by various standards organizations.
In 1975, the IEEE standardized the bus as Standard Digital Interface for Programmable Instrumentation, IEEE 488; it was revised in 1978 (producing IEEE 488-1978). The standard was revised in 1987, and redesignated as IEEE 488.1 (IEEE 488.1-1987). These standards formalized the mechanical, electrical, and basic protocol parameters of GPIB, but said nothing about the format of commands or data.
In 1987, IEEE introduced Standard Codes, Formats, Protocols, and Common Commands, IEEE 488.2. It was revised in 1992. IEEE 488.2 provided for basic syntax and format conventions, as well as device-independent commands, data structures, error protocols, and the like. IEEE 488.2 built on IEEE 488.1 without superseding it; equipment can conform to IEEE 488.1 without following IEEE 488.2.
While IEEE 488.1 defined the hardware and IEEE 488.2 defined the protocol, there was still no standard for instrument-specific commands. Commands to control the same class of instrument, e.g., multimeters, varied between manufacturers and even models.
The United States Air Force, and later Hewlett-Packard, recognized this as a problem. In 1989, HP developed their Test Measurement Language (TML) or Test and Measurement Systems Language (TMSL) which was the forerunner to Standard Commands for Programmable Instrumentation (SCPI), introduced as an industry standard in 1990. SCPI added standard generic commands, and a series of instrument classes with corresponding class-specific commands. SCPI mandated the IEEE 488.2 syntax, but allowed other (non-IEEE 488.1) physical transports.
The IEC developed their own standards in parallel with the IEEE, with IEC 60625-1 and IEC 60625-2 (IEC 625), later replaced by IEC 60488-2.
National Instruments introduced a backward-compatible extension to IEEE 488.1, originally known as HS-488. It increased the maximum data rate to 8 Mbyte/s, although the rate decreases as more devices are connected to the bus. This was incorporated into the standard in 2003 (IEEE 488.1-2003), over HP's objections.
In 2004, the IEEE and IEC combined their respective standards into a "Dual Logo" IEEE/IEC standard IEC 60488-1, Standard for Higher Performance Protocol for the Standard Digital Interface for Programmable Instrumentation - Part 1: General, replaces IEEE 488.1/IEC 60625-1, and IEC 60488-2,Part 2: Codes, Formats, Protocols and Common Commands, replaces IEEE 488.2/IEC 60625-2.
Characteristics
IEEE 488 is an 8-bit, electrically parallel bus which employs sixteen signal lines — eight used for bi-directional data transfer, three for handshake, and five for bus management — plus eight ground return lines.
The bus supports 31 five-bit primary device addresses numbered from 0 to 30, allocating a unique address to each device on the bus.
The standard allows up to 15 devices to share a single physical bus of up to 20 metres (66 ft) total cable length. The physical topology can be linear or star (forked). Active extenders allow longer buses, with up to 31 devices theoretically possible on a logical bus.
Control and data transfer functions are logically separated; a controller can address one device as a "talker" and one or more devices as "listeners" without having to participate in the data transfer. It is possible for multiple controllers to share the same bus, but only one can be the "Controller In Charge" at a time.
In the original protocol, transfers use an interlocked, three-wire ready–valid–accepted handshake. The maximum data rate is about one megabyte per second. The later HS-488 extension relaxes the handshake requirements, allowing up to 8 Mbyte/s. The slowest participating device determines the speed of the bus.
Connectors
IEEE 488 specifies a 24-pin Amphenol-designed micro ribbon connector. Micro ribbon connectors have a D-shaped metal shell, but are larger than D-subminiature connectors. They are sometimes called "Centronics connectors" after the 36-pin micro ribbon connector Centronics used for their printers.
One unusual feature of IEEE 488 connectors is they commonly use a "double-headed" design, with male on one side, and female on the other. This allows stacking connectors for easy daisy-chaining. Mechanical considerations limit the number of stacked connectors to four or fewer, although a workaround involving physically supporting the connectors may be able to get around this.
They are held in place by screws, either 6-32 UNK (now largely obsolete) or metric M3.5×0.6 threads. Early versions of the standard suggested that metric screws should be blackened to avoid confusion with the incompatible UTS threads. However, by the 1987 revision this was no longer considered necessary because of the prevalence of metric threads.
The IEC 60625 standard prescribes the use of 25-pin D-subminiature connectors (the same as used for the parallel port on IBM PC compatibles). This connector did not gain significant market acceptance against the established 24-pin connector.
Capabilities
Function | Abbreviation | Description and examples | |
---|---|---|---|
Source Handshake | SH | 1 | Complete |
Acceptor Handshake | AH | 1 | Complete |
Basic Talker | T | 5 | Responds to serial poll; untalks when listen address received; talk only capability |
6 | Untalks when listen address received; no talk only | ||
7 | No serial poll; untalks when listen address received; talk only capability | ||
Extended Talker | TE | 0 | No extended talker |
Basic Listener | L | 3 | Listen only mode; unlistens if talk address received |
4 | Unlistens if talk address received | ||
Extended Listener | LE | 0 | No extended listener |
Service Request | SR | 0 | No service request capability |
1 | Complete | ||
Remote-Local | RL | 0 | No local lockout |
1 | Complete | ||
Parallel Poll | PP | 0 | Does not respond to Parallel Poll |
Device Clear | DC | 1 | complete |
Device Trigger | DT | 0 | No device trigger capability |
1 | Complete | ||
Controller | C | 0 | No controller function |
E | 1 | Open collector drive electronics | |
2 | Three state drivers |
Use as a computer interface
HP's designers did not specifically plan for IEEE 488 to be a peripheral interface for general-purpose computers; the focus was on instrumentation. But when HP's early microcomputers needed an interface for peripherals (disk drives, tape drives, printers, plotters, etc.), HP-IB was readily available and easily adapted to the purpose.
HP computer products which used HP-IB included the HP Series 80, HP 9800 series, the HP 2100 series, and the HP 3000 series. HP computer peripherals which did not utilize the RS-232 communication interface often used HP-IB including disc systems like the HP 7935. Some of HP's advanced pocket calculators of the 1980s, such as the HP-41 and HP-71B series, also had IEEE 488 capabilities, via an optional HP-IL/HP-IB interface module.
Other manufacturers adopted GPIB for their computers as well, such as with the Tektronix 405x line.
The Commodore PET (introduced 1977) range of personal computers connected their peripherals using the IEEE 488 bus, but with a non-standard card edge connector. Commodore's following 8-bit machines utilized a serial bus whose protocol was based on IEEE 488. Commodore marketed an IEEE 488 cartridge for the VIC-20 and the Commodore 64. Several third party suppliers of Commodore 64 peripherals made a cartridge for the C64 that provided an IEEE 488-derived interface on a card edge connector similar to that of the PET series.
Eventually, faster, more complete standards such as SCSI superseded IEEE 488 for peripheral access.
- Rear of Commodore 8032-SK showing IEEE 488 port
- Rear of Commodore SFD 1001 floppy disk drive with IEEE 488 port
- C64 interface
- Acorn IEEE 488 Interface
- USB GPIB Protocol converter
- Rear of Tektronix TDS 210 digital oscilloscope with IEEE 488 port
- Rear of Keysight 34970A data acquisition chassis / multimeter with IEEE 488 port
- Rear of Keithley DMM7510 multimeter with IEEE 488 port
- HP 7580B plotter with IEEE 488 port
- HP ThinkJet 2225A with IEEE 488 port
Comparison with other interface standards
This section does not cite any sources. Please help improve this section by adding citations to reliable sources. Unsourced material may be challenged and removed. (February 2010) (Learn how and when to remove this message) |
Electrically, IEEE 488 used a hardware interface that could be implemented with some discrete logic or with a microcontroller. The hardware interface enabled devices made by different manufacturers to communicate with a single host. Since each device generated the asynchronous handshaking signals required by the bus protocol, slow and fast devices could be mixed on one bus. The data transfer is relatively slow, so transmission line issues such as impedance matching and line termination are ignored. There was no requirement for galvanic isolation between the bus and devices, which created the possibility of ground loops causing extra noise and loss of data.
Physically, the IEEE 488 connectors and cabling were rugged and held in place by screws. While physically large and sturdy connectors were an advantage in industrial or laboratory set ups, the size and cost of the connectors was a liability in applications such as personal computers.
Although the electrical and physical interfaces were well defined, there was not an initial standard command set. Devices from different manufacturers might use different commands for the same function. Some aspects of the command protocol standards were not standardized until Standard Commands for Programmable Instruments (SCPI) in 1990. Implementation options (e.g. end of transmission handling) can complicate interoperability in pre-IEEE 488.2 devices.
More recent standards such as USB, FireWire, and Ethernet take advantage of declining costs of interface electronics to implement more complex standards providing higher bandwidth. The multi-conductor (parallel data) connectors and shielded cable were inherently more costly than the connectors and cabling that could be used with serial data transfer standards such as RS-232, RS-485, USB, FireWire or Ethernet. Very few mass-market personal computers or peripherals (such as printers or scanners) implemented IEEE 488.
See also
- Commodore bus – Serial bus of the home computers series of Commodore
- HP Series 80 – 1980 Hewlett-Packard small scientific desktop computer
- HP-IL – communications protocolPages displaying wikidata descriptions as a fallback
- LAN eXtensions for Instrumentation – Standard for controlling instrumentation and data acquisition instrumentation over Ethernet
- PCI eXtensions for Instrumentation
- Rocky Mountain BASIC – Dialect of the BASIC programming language
- Standard Commands for Programmable Instruments – Communications protocol for test equipment
- Virtual Instrument Software Architecture – Test and measurement APIPages displaying short descriptions of redirect targets
References
- Nelson, Gerald E.; Ricci, David W. (October 1972). "A Practical Interface System for Electronic Instruments" (PDF). Hewlett-Packard Journal. 24 (2): 2–7.
Controllers: 3260A Marked Card Reader; 9820A Calculator (with 11144A Interface Kit)
Loughry, Donald C. (October 1972). "A Common Digital Interface for Programmable Instruments: The Evolution of a System" (PDF). Hewlett-Packard Journal. 24 (2): 8–11. - IEEE Standard Digital Interface for Programmable Instrumentation, Institute of Electrical and Electronics Engineers, 1978, doi:10.1109/IEEESTD.1978.7425098, ISBN 978-1-5044-0366-5, ANSI/IEEE Std 488-1978
IEEE Standard Digital Interface for Programmable Instrumentation, Institute of Electrical and Electronics Engineers, 1987, ISBN 0-471-62222-2, ANSI/IEEE Std 488.1-1987, p. iii - IEEE Standard Codes, Formats, Protocols, and Common Commands for Use With IEEE Std 488.1-1987, IEEE Standard Digital Interface for Programmable Instrumentation, Institute of Electrical and Electronics Engineers, 1992, ISBN 978-1-55937-238-1, IEEE Std 488.2-1992
- Project Mate in 1985
- "GPIB 101, A Tutorial of the GPIB Bus". ICS Electronics. p. 5, paragraph = SCPI Commands.
- "Hewlett Packard Test & Measurement Catalog 1991" (PDF). hparchive.com. p. 8, paragraph = SCPI.
- "History of GPIB". National Instruments. Retrieved 2010-02-06.
In 1990, the IEEE 488.2 specification included the Standard Commands for Programmable Instrumentation (SCPI) document.
- "Upgraded Standard Boosts Speed of IEEE 488 Instrument Buses Eightfold". IEEE. 2003-10-06. Archived from the original on December 7, 2003. Retrieved 2010-02-06.
- "HP and Other Test and Measurement Companies Urge IEEE to Oppose Revisions of Established IEEE 488 Standard" (Press release). Hewlett-Packard Company. December 1997. Archived from the original on 2011-06-10. Retrieved 2010-02-16.
- "P488.1 Project Home". IEEE. Archived from the original on 2010-04-28. Retrieved 2010-02-16.
- IEC/IEEE Standard for Higher Performance Protocol for the Standard Digital Interface for Programmable Instrumentation - Part 1: General (Adoption of IEEE Std 488.1-2003). IEEE. doi:10.1109/IEEESTD.2004.95749. ISBN 978-0-7381-4536-5.
- Standard Digital Interface for Programmable Instrumentation- Part 2: Codes, Formats, Protocols and Common Commands (Adoption of (IEEE Std 488.2-1992). IEEE. doi:10.1109/IEEESTD.2004.95390. hdl:11059/14380. ISBN 978-0-7381-4100-8.
- "Replaced or Withdrawn Publications". IEC. Archived from the original on 2012-04-17. Retrieved 2010-02-06.
- "GPIB Addressing" (PDF). NI-488.2 User Manual. National Instruments Corporation. February 2005. p. A-2. NI P/N 370428C-01. Retrieved 2010-02-16.
The primary address is a number in the range 0 to 30.
- "Table 1-1: 82350 GPIB interface card configuration parameters" (PDF). Agilent 82350B PCI GPIB Interface: Installation and Configuration Guide. Agilent Technologies. 2009-07-20. p. 26. Agilent P/N 82350-90004. Retrieved 2010-02-16.
any address in the range 0 - 30, inclusive, may be used
- "GPIB Instrument Control Tutorial". National Instruments. 2009-08-24. Retrieved 2010-02-16.
connected in either a daisy-chain or star topology
- NI-488.2 User Manual (PDF). National Instruments Corporation. February 2005. p. A-1. NI P/N 370428C-01. Archived from the original (PDF) on 2008-12-02. Retrieved 2010-02-16.
- "Handshake Lines" (PDF). NI-488.2 User Manual. National Instruments Corporation. February 2005. p. A-3. NI P/N 370428C-01. Retrieved 2010-02-16.
- "Using HS488 to Improve GPIB System Performance". National Instruments Corporation. 30 March 2009. Retrieved 2010-02-16.
- "Mechanical Aspects" (PDF). Tutorial Description of the Hewlett-Packard Interface Bus. Hewlett-Packard. p. 28. Retrieved 2022-06-13.
Some existing cables use English threads (6-32UNK).
- IEEE Standard Digital Interface for Programmable Instrumentation, Institute of Electrical and Electronics Engineers, 1987, p. v, ISBN 978-0-471-62222-2, ANSI/IEEE Std 488.1-1987,
The "helpful note" on metric threads found in previous editions has been deleted since metric thread use is common IEEE 488 practice. Consequently, the recommendation to coat such parts in black material to call attention to metric threads is also considered unnecessary.
- Tilden, Mark D. (1983), "Appendix A: Subsets Describe Interface Functions" (PDF), 4041 GPIB Programming Guide, Tektronix, Inc., pp. 113–115
{{citation}}
: Cite uses generic title (help) - "HP 98135A HP-IB Interface 9815". HP Computer Museum. Retrieved 2010-02-06.
- "59310A HP-IB Interface". HP Computer Museum. Retrieved 2010-02-06.
HP-IB interface for HP1000 and HP2000 computers
- "27113A HP-IB Interface". HP Computer Museum. Retrieved 2010-02-06.
CIO HP-IB interface for 3000 Series 900
- Bagnall, Brian (2006). On the Edge: The Spectacular Rise and Fall of Commodore. Variant Press. p. 221. ISBN 0-9738649-0-7. OCLC 761384138.
- Commodore drawing for VIC-1112 - Drawing no. 1110010 Rev:A
- Reverse-engineered schematics for Commodore C64 IEEE interface
- http://www.zimmers.net/anonftp/pub/cbm/schematics/cartridges/c64/ieee-488/index.html Link to schematic for one such converter.
- Early devices might respond to an
ID
command with an identification string; later standards had devices respond to the*ID
command.
External links
- Part 1 Specifications
- IEEE/IEC 60488-1-2004, 158 page PDF file, costs USD$391 in 2024
- Part 2 Specifications
- IEEE 488.2-1992, 254 page PDF file, costs USD$52 in 2024 (superseded by IEEE/IEC 60488-2-2004)
- IEEE/IEC 60488-2-2004, 264 page PDF file, costs USD$373 in 2024
- Other
Technical and de facto standards for wired computer buses | |
---|---|
General | |
Standards |
|
Storage |
|
Peripheral | |
Audio | |
Portable | |
Embedded | |
Interfaces are listed by their speed in the (roughly) ascending order, so the interface at the end of each section should be the fastest. Category |
IEEE standards | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Current | |||||||||||
802 series |
| ||||||||||
Proposed | |||||||||||
Superseded | |||||||||||