EDN logo


Design Feature: February 3, 1994

PCI local bus gathers momentum

GARY LEGG,
Senior Technical Editor

Both the PCI local bus and the VL bus let high-speed peripherals bypass a PC's slow expansion bus. But PCI is gaining favor among designers, and a crop of new PCI components is starting to simplify local-bus design.

When a flood of data from fast peripherals meets a slow PC-expansion bus, something has to give. And so, with applications in graphics, video, and imaging proliferating rapidly, computer designers are now connecting peripherals directly to a system processor's local bus. But connecting directly to a local bus can result in unpredictable performance, as many designers have learned the hard way. Fortunately, though, help is on the way from the Peripheral Component Interconnect (PCI) bus.

With data throughput as high as 132 Mbytes/sec (even higher in future implementations), the PCI bus smashes the I/O bottleneck of traditional expansion buses. So does the VESA local (VL) bus, for that matter; in fact, the VL bus did it first. But the VL bus is losing ground in the race for market acceptance, mainly because the PCI bus offers a more attractive technology-migration path to the future. In addition, a whole lineup of new products is now making it easier to implement the PCI bus and PCI-compliant peripherals.


Long-range plan prevails

The contest between the PCI and VL buses is much like the race between the tortoise and the hare. VL, developed by the Video Electronics Standards Association, jumped to an early start with a quick-time-to-market solution. It did so, however, with a specification that was somewhat shortsighted and, in the opinion of many designers, rather "casual." PCI, developed by Intel but now an open standard, started more slowly but took a longer range view. PCI components and systems have only recently started appearing on the market, but most designers praise the PCI spec's thoroughness and orientation toward the future.

PCI's forward-looking plan includes processor independence, compatible 32- and 64-bit buses, and a smooth transition from 5 to 3.3V devices (see box, "PCI-bus highlights"). In fact, the PCI bus specification (Ref 1) already contains details for those features. VESA recently added similar features to its VL-bus spec (Ref 2), but not before the PCI bus had already gained a good deal of market momentum. In addition, because the VESA additions increased the VL bus's complexity, they diminished its main selling point—low implementation cost.

Processor independence has contributed a great deal to the PCI bus's success. You can implement the bus on Intel processors, but that doesn't exclude using other processors. For example, Digital Equipment Corp (DEC) is linking PCI to its Alpha processors; Apple, IBM, and Motorola are using it with the Power PC. Any PCI-compliant peripheral works with any of the systems, sparing manufacturers the task of designing models with different interfaces.

PCI-bus highlights

  • Synchronous, processor-independent 32- or 64-bit local bus
  • Operation at 5, 3.3V, and combination
  • Forward and backward compatibility of 32- and 64-bit PCI components and add-in boards
  • Bus speeds as high as 33 MHz
  • Transfer rates as high as 132 Mbytes/sec (264 Mbytes/sec for 64-bit bus) via burst mode
  • Full multimaster capability
  • Hidden (overlapped) central arbitration
  • Concurrency with processor/memory subsystem
  • Write-back and write-through cache support
  • Automatic configuration of PCI add-in cards at power-up

The PCI bus is also compatible with standard expansion buses. You can have both bus types connected to the system processor, or, as Fig 1 shows, you can put a slow expansion bus—ISA, EISA, or MicroChannel (MC)—on top of a PCI bus. With PCI-to-PCI bridge chips coming soon from DEC and IBM, you can even put one PCI bus on top of another.

With a secondary PCI bus, you can put multiple peripheral functions on a single add-in card. These functions, if implemented as bus masters, can communicate with each other over the bus without involving the system processor. Access to the system processor is still possible, however, via the two cascaded PCI buses.

PCI peripherals can exist as chips (for use on a mother board or a single-board computer), as add-in cards, or as external devices with a card interface. A typical PCI desktop computer has three PCI-card slots plus two peripheral functions—for example, a graphics accelerator and a LAN—on the mother board. According to rule-of-thumb guidelines for PCI design, you can put 10 electrical loads on the bus. Each mother-board function or bridge chip counts as one load; each card connector counts as two.

PCI bus vs VL bus

The latest specification for the VESA local (VL) bus (Ref 2) mirrors some of the features of the Peripheral Component Interconnect (PCI) bus. It provides for expansion to 64 bits, for example, and it achieves processor independence by providing "bridge" connections to a processor's local bus. The original VL bus was essentially the same as a 486 local bus, and you could implement it only with 486- and 386-type architectures.

The new VL-bus spec also increases clock rates—to 66 MHz on a mother board and to 50 MHz across card connectors. Previously, the clock rate was 33 MHz on both boards and connectors. Some designers with experience in VL and PCI design are concerned that the higher clock rates, especially across connectors, will cause unreliable operation. Others, however, say that new shielded connectors should be able to handle the faster clock.

The newly specified 64-bit VL bus multiplexes data and addresses, as does the PCI bus. The 32-bit PCI bus also multiplexes addresses and data, but the 32-bit VL bus does not. So, although 64-bit PCI and VL buses require roughly the same number of connections, a 32-bit PCI bus requires considerably fewer than does a 32-bit VL bus. Both the PCI and VL buses provide 32-/64-bit transparency. A 64-bit add-in card works on a 32-bit bus, and a 32-bit card works on a 64-bit bus.

PCI cards are more adaptable to different types of systems, however. A PCI card works in any ISA-, EISA-, or MicroChannel (MC)-based system that also has PCI slots; VL-bus cards have both a VL connector and an ISA, EISA, or MC connector, so they're limited to only one type of system.

In terms of performance, the PCI bus enjoys some advantages over VL. Burst reads and writes, for example, can be essentially any length on PCI. With VL, they're limited to 16 bytes or fewer, thus incurring more overhead for setting up addresses on long transfers.

PCI-bus concurrency allows the system processor to operate independently, and thus not get delayed, when a bus-master peripheral gets bus possession. The VL bus, which until now has been essentially the 486 processor's local bus, has not allowed concurrency. Concurrency will be possible with VL-bus bridge chips, however, and will be available if designers choose to implement it.

PCI add-in cards are mechanically compatible with ISA-, EISA-, or MC-based systems, provided that those systems also have some PCI connectors on the mother board. The PCI-card connector is the MC style, and two types of attachable brackets adapt a standard PCI card for mechanical installation in an ISA/EISA or a MC system. The PCI specification also provides for a smaller 7-in. card, compared with the standard 12.325-in. card.

One of the card slots in a PCI-compliant system can be a "shared" slot that accommodates a PCI card or a standard expansion card. The mother-board PCI connector for a shared slot is very close to the ISA, EISA, or MC connector. The component side of a PCI card is opposite that of the other cards to enable either type of card to fit into roughly the same physical space. You choose which type of card to use; both, obviously, cannot occupy the shared slot at once.

A number of products (Table 1), many of which are just now becoming available, can help you design PCI into your system. Some processors—DEC's Alpha 21066, for example—put the PCI bus on chip. In most cases, however, separate PCI chip sets—sometimes called bridges—essentially create a PCI bus and connect it to a processor's local bus. (Technically speaking, the PCI bus isn't a local bus. It's more like a mezzanine bus that is closely tied to the local bus.)

Other new PCI products add peripherals to your system. Some of these are bridge chips that connect existing standard interfaces—SCSI or IDE, for example—to the PCI bus. Other products are PCI-compliant peripherals implemented as chips or add-in cards. Graphics accelerators and Ethernet controllers are the most prevalent of these.

If you're designing your own PCI-compliant peripheral device, your product options are somewhat limited for now. General-purpose PCI-interface chips aren't yet commercially available, although at least two are in development. PLDs and FPGAs have trouble driving the PCI bus, although Intel says it will introduce some PCI-compatible devices this year.

Peripheral Component Interconnect-bus ICs

ICfunctions available

Manufacturer PCI on µP µP on PCI IDE on PCI SCSI on PCI ISA on PCI
Adaptec

X X
Advanced
Micro Devices



X
American
Micro Circuits

X


Appian
Technology


X

BusLogic

X X
Contaq



X
Digital
Equipment Corp
X



Future Domain


X
IBM
Microelectronics
X



Intel X



NCR Corp


X
Opti X



PLX Technology
X


QLogic


X
Symphony X
X

VLSI Technology X



You can, of course, connect to the PCI bus with an ASIC of your own design. Most ASIC vendors now have PCI drivers in their cell libraries. If you can wait a couple of months, though, the availability of PCI-interface chips could help you avoid the up-front costs of an ASIC.

With PCI-controller chips now in development, you can create a complete interface between a µP and the PCI bus. One controller chip, from American Micro Circuits Corp, interfaces to practically any µP. The chip provides a 32-bit address/data path, all required address decoding, and all the necessary registers and other features for a PCI connection. PLX Technology is developing a similar chip for the i960 µP. Both chips should be available in the second quarter of this year.

For general guidance in PCI design, start with the PCI Special Interest Group (PCI SIG). PCI SIG oversees the PCI specification and provides additional design guidelines that aren't formally specified. The group now has more than 200 member companies; many are developing PCI components and add-in boards. Contact PCI SIG (see box, "For free information... ") for a list.

The next few months will see a flood of PCI products. Some will be new; others will be products that are just now stable enough to warrant volume production. Because PCI is new and its technical specification is fairly de-manding, some early components had difficulty meeting all the spec's requirements.

The PCI bus still faces market competition from the VL bus (see box, "PCI bus vs VL bus"), but the long-range outlook seems to favor PCI. The VL bus's main advantage is that it is essentially the same as the 486 local bus and thus is inexpensive to implement in a 486-based system. As the use of other processors increases, however, the balance will tip to PCI.

Once start-up difficulties subside, the PCI bus could substantially change the "flavor" of PCs, both on the desktop and in embedded systems. By putting peripheral-I/O speeds on a par with processor speeds—and by doing so with standard, high-volume, off-the-shelf components—PCI could make possible a range of products and applications that previously were technically or economically infeasible. The PCI bus could, in fact, become one of the enabling technologies of the decade.

Looking ahead

The Peripheral Component Interconnect (PCI) bus's bandwidth is adequate even for bus-hogging applications like full-motion video, but bandwidth requirements will undoubtedly increase. Fiber-interface communication can easily consume 100 Mbytes/sec, and high-definition television (HDTV) and multimedia will also be very demanding.

Extending the PCI bus to 64 bits will satisfy many of those demands, stretching bandwidth from 132 to 264 Mbytes/sec. A 64-bit specification is in place, and 64-bit PCI products should start appearing this year.

To further increase data throughput, the PCI clock rate could eventually double, to 66 MHz, or even quadruple. The higher rate could initially prove troublesome across card connectors, but single-board systems—without the connectors' added capacitance—will be less of a challenge.

A second PCI bus—implemented on top of another PCI bus via a bridge chip—offers some interesting possibilities for new system architectures. A secondary bus on an add-in card, for example, will let you include multiple PCI-peripheral functions on the card. The PCI SIG is also investigating a card-top connector that links cards via a secondary bus.


References

1. "PCI Local Bus Specification, Revision 2.0," PCI Special Interest Group, Hillsboro, OR, 1993.

2. "VL-Bus 2.0," Video Electronics Standards Association, San Jose, CA, 1993.

3. The PCI Local Bus: A Technology Overview, Intel Corp, Santa Clara, CA, 1993.

4. Rowell, Dave, "PCI Local Bus Has Arrived," PC Magazine, November 9, 1993, pg 187.

5. Mosley, JD, "Bypass the PC Bus to Speed up Your System," EDN, February 18, 1993, pg 65.


Author's biography

You can reach Senior Technical Editor Gary Legg at (617) 558-4404, fax (617) 558-4470.


For free information...
When you contact any of the following manufacturers directly, please let them know you read about their products at the EDN Magazine WWW site.
Adaptec
Milpitas, CA
(408) 945-8600
Advanced Micro Devices Inc
Sunnyvale, CA
(408) 732-2400
American Micro Circuits Corp
San Diego, CA
(619) 450-9333
Appian Technology Inc
Sunnyvale, CA
(408) 730-5406
BusLogic Inc
Santa Clara, CA
(408) 492-9090
Contaq Microsystems Inc
San Jose, CA
(408) 428-9025
Digital Equipment Corp
Maynard, MA
(508) 493-5111
Future Domain Corp
Irvine, CA
(714) 253-0913
IBM Microelectronics
Somers, NY
(914) 765-1900
Intel Corp
Santa Clara, CA
(408) 765-8080
NCR Corp
Colorado Springs, CO
(800) 334-5454
Opti Inc
Santa Clara, CA
(408) 980-8178
PLX Technology
Mountain View, CA
(415) 960-0448
QLogic Corp
Costa Mesa, CA
(714) 438-2200
Symphony Laboratories
Santa Clara, CA
(408) 986-1701
VLSI Technology Inc
Tempe, AZ
(602) 752-8574


| EDN Access | feedback | subscribe to EDN! |
| design features | design ideas |


Copyright © 1995 EDN Magazine. EDN is a registered trademark of Reed Properties Inc, used under license.