Jump to content

Bus analyzer: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Added missing protocols for Ellisys
Line 23: Line 23:
== Manufacturers ==
== Manufacturers ==
* [[Agilent Technologies]] - PCI, PCI Express analyzers
* [[Agilent Technologies]] - PCI, PCI Express analyzers
* [[Byte Paradigm]] - SPI, I2C analyzers
* [[Corelis]] - I2C analyzers
* [[Corelis]] - I2C analyzers
* [[Ellisys]] - [[USB]], [[Wireless USB]], [[WiMedia]]
* [[Ellisys]] - [[USB]], [[Wireless USB]], [[WiMedia]]

Revision as of 11:47, 12 June 2008

A typical bus analyzer: this one has an adaptor pod to allow it to interface to Serial ATA devices.

A bus analyzer is a computer bus analysis tool, often a combination of hardware and software, used during development of hardware or device drivers for a specific bus, diagnosing bus or device failures, or reverse engineering.

A bus analyzer is a type of protocol analyzer, which is designed for use with certain specific parallel and serial bus architectures. It differs from other protocol analyzers which analyze traffic running across non-bus-based mediums ranging from ethernet networks to wireless LANs or PANs.

The bus analyzer monitors the bus traffic and decodes and displays the data. It is essentially a logic analyzer with some additional knowledge of the underlying bus traffic characteristics.

Some key differentiator between bus and logic analyzers are:

1. Cost: Logic analyzers usually carry higher prices than bus analyzers. The converse of this fact is that a logic analyzer can be used with a variety of bus architectures, whereas a bus analyzer is only good with one architecture.
2. Targeted Capabilities and Preformatting of data: A bus analyzer can be designed to provide very specific context for data coming in from the bus. Analyzers for serial buses like USB for example take serial data that arrives as a serial stream of binary 1s and 0s and displays it as logical packets differentiated by chirp, headers, payload etc...
3. From a user's perspective, a (greatly) simplified viewpoint may be that developers who want the most complete and most targeted capabilities for a single bus architecture may be best served with a bus analyzer, while users who work with several protocols in parallel my be better served with a Logic Analyzer that is less costly than several different bus analyzers and enables them to learn a single user interface vs several.

Analyzers are now available for virtually all existing computer bus standards and form factors such as PCI, CompactPCI, PCI Express, PMC, USB, VMEbus, CANbus and LINbus, etc. Specialized bus analyzers are also used in the mass storage industry to analyze popular data transfer protocols between computers and drives. These cover popular data busses like SATA, SAS, ATA/PI, SCSI, etc. These devices are typically connected in series between the host computer and the target drive, where they 'snoop' traffic on the bus, capture it and present it in human-readable format.


PCI Express Bus Exerciser testing an add in card

For many bus architectures like PCI Express, PCI, SAS, SATA, USB and so on, Analyzers are often used in conjunction with a "Bus Exerciser", which actively engages the bus while the analyzer snoops it. Especially with these bus architectures (PCI and PCI-Express), manufacturers have bundled these functions together into a "Bus Analyzer/Exerciser" that resides on a single board or integrated set of boards. These devices make it possible to generate bad bus traffic as well as good so that the device error recovery systems can be tested. They are also often used to verify compliance with the standard to ensure interoperability of devices since they can reproduce known scenarios in a repeatable way.


Manufacturers

See also