Vi-ta [vee-tuh] | Critical Embedded Systems are everywhere . . . Become a leader in setting new directions! |
The VMEbus read/write cycle is the 'standard' bus cycle. It has the following attributes:
Table 1 shows the VMEbus signals that are used by the read/write cycle. They are grouped as address, data and control type signals.
|
||
|
|
|
AM0-AM5 DS0*, DS1* LWORD* |
|
WRITE* DS0*, DS1* DTACK* BERR* RETRY* |
Figure 1 shows a typical read cycle (with address pipelining). During that cycle, the following activity occurs:
The VMEbus write cycle is not shown. It is similar to the read cycle, except that the MASTER asserts WRITE* and places valid data onto the bus. The SLAVE then latches the data after DSA* has been asserted by the MASTER.
It should also be noted that the VMEbus specification uses two forms of nomenclature for the data strobes. The actual signal names are called DS0* and DS1*. However, the specification often refers to data strobes DSA* and DSB*. These are not the names of actual signal lines, but are used to indicate the order in which the data strobes are asserted. DSA* is always driven first by the MASTER, and DSB* is always driven second. However, DSA* can refer to either DS0* or DS1*. Also, in some cases the term DSX* can be used. This is shorthand notation which indicates that either data strobe is asserted.
VMEbus uses a fully interlocked handshaking mechanism between data strobes DS0* and DS1*, and terminating signals DTACK*, BERR* and RETRY*.
At the beginning of a cycle a MASTER must not assert either data strobe until DTACK*, BERR* and RETRY* have all been negated by the SLAVE. Failing to do so may corrupt data on the current (or the previous) cycle. At the end of a cycle a SLAVE cannot negate DTACK*, BERR* or RETRY* until the MASTER has negated both data strobes DS0* and DS1*. These two mechanisms form a fully interlocked handshaking mechanism.
Care must be used when evaluating or designing MASTERs that use the 680XX or other microprocessor families. Many microprocessors don't use a fully interlocking bus cycle, and circuitry must be provided to make them totally compliant.
Some microprocessors or peripherals use address pipelining to speed up data transfers. During address pipelining the bus master broadcasts the address of the next bus cycle before the current cycle has completed. This is shown as 'address rot' (i.e. a rotten address) in Figure 1. There, the MASTER places a new address onto the bus immediately after the SLAVE asserts DTACK*. However, this can take place before the SLAVE negates the DTACK* signal.
Originally, address pipelining was considered a VMEbus feature. However, on rare occasions it has caused incompatibility between modules. In those cases, a poorly designed VMEbus SLAVE module will latch it's address lines on the falling edge of AS*. This can cause problems if the MASTER is attempting an address pipelining cycle. In those cases, the MASTER can latch the wrong data, thereby corrupting the bus cycle. If the SLAVE is designed correctly, however, this problem will not occur.
This page last updated: Dec 5, 2000
Copyright 2000 Wade D. Peterson. All rights reserved.