

# Tsi148™ VMEbus Test and Set Application Note

Formal Status September 6, 2012





# Tsi148 VMEbus Test and Set Application Note

This document details both the traditional mechanisms for implementing a VMEbus Test and Set (TAS) function, as well as additional Tsi148-specific solutions. Topics discussed include the following:

- Overview
- Tsi148-specific Wrap-around RMW Solution

## **Revision History**

#### September 6, 2012, Formal

This version includes several minor fixes. No technical changes were made.

#### October 2009, Formal

This version of the document was rebranded as IDT. No technical changes were made.

#### October 2008, Formal

General content update.

#### **Overview**

The traditional methods for implementing a VMEbus test-and-set (TAS) function include the following:

1. A VME RMW cycle

The standard way to implement a TAS is to use the PCI- to-VME bridge device's RMW cycle to set the semaphore. This method is used by a board that does not host the semaphore in its own memory but needs to access the semaphore over the VMEbus. In order to guarantee indivisibility, both the processor host bridge as well as the PCI-to-VME bridge should support the PCI Lock feature.

- 2. Using bus locking capabilities in the PCI-to-VME bridge device
  - Locking of the VMEbus by using the bus locking capability of the PCI-to-VME bridge device can be used to complete the TAS function. When the VMEbus is locked, the semaphore can be read, tested, and, optionally, written. The same method is used by the board that hosted the semaphore and boards that must cross the VMEbus to access the semaphore.
- 3. Software TAS

The software TAS option continuously re-reads the address to obtain the semaphore. The number of times the address must be read is a configurable value which must be large enough to ensure that no other agent trying to acquire the semaphore could have written its own node-unique locking value to the semaphore. The number of times the address must be read is very system dependent and it is difficult to guarantee the desired locked condition in all circumstances and environments.



The Tsi148, like most host bridges, does not support the PCI bus LOCK feature. Because of this, the standard method (method 1) of atomic RMW cycles to obtain the semaphore is not supported. Also, due to a current Tsi148 device errata, the Tsi148 does not support the hardware method (method 2) of locking the VMEbus by using the Tsi148 Device Wants Bus/Device Has Bus (DWB/DHB) bus locking capability. For more information, see the *Tsi148 Device Errata*.

The Tsi148 does support the software TAS but this method can introduce latency and uncertainty into the process. Also because it is a software loop, this process consumes processor time while checking for a collision.

However, in specific applications the Tsi148 can be configured to perform a wrap-around RMW cycle for TAS. The following section details the configuration required.

### Tsi148-specific Wrap-around RMW Solution

The Tsi148 is capable of performing a wrap-around RMW cycle. The device-specific solution can be used to force all local bus (PCI) accesses to the semaphore to be channeled through the VMEbus and the RMW can be used for TAS.

This feature helps control accesses to the semaphore from the local bus by forcing all the processor bus accesses to memory through the VMEbus (see Figure 1). This method works only when the board hosting the semaphore is the same board who is accessing the semaphore. The Tsi148 is the only PCI-to-VME device that supports the wrap-around RMW. If the Tsi148 is used in a system that contains other boards containing different PCI-to-VME bridges, or a system where a different board hosts the semaphore, then the software TAS method (method 3) must be implemented instead.

The Tsi148's errata associated with the wrap-around RMW does not impact TAS functionality. With the errata, during a wrap-around RMW cycle, the read function is always performed correctly but during the write portion, the VMEbus Master may not drive the data bus (due to pull-up resistors that reside on the data bus, all ones (0xFFFFFFFF) would be written). However, the logic of the test and set is that a read of the cleared condition (which is 0) indicates the semaphore has been acquired. Whether the semaphore was acquired, or already in use, writing 1 does not matter because either the semaphore value was already a 1 or it should be a 1. The important part of the algorithm is that the read portion of the wrap-around RMW is correct. The release of the semaphore, setting it to 0, is not performed by means of a wrap-around RMW; it is performed by a write to the semaphore.

Figure 1: Tsi148 Wrap-around RMW TAS Method





#### **IMPORTANT NOTICE AND DISCLAIMER**

RENESAS ELECTRONICS CORPORATION AND ITS SUBSIDIARIES ("RENESAS") PROVIDES TECHNICAL SPECIFICATIONS AND RELIABILITY DATA (INCLUDING DATASHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT OF THIRD-PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for developers who are designing with Renesas products. You are solely responsible for (1) selecting the appropriate products for your application, (2) designing, validating, and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, or other requirements. These resources are subject to change without notice. Renesas grants you permission to use these resources only to develop an application that uses Renesas products. Other reproduction or use of these resources is strictly prohibited. No license is granted to any other Renesas intellectual property or to any third-party intellectual property. Renesas disclaims responsibility for, and you will fully indemnify Renesas and its representatives against, any claims, damages, costs, losses, or liabilities arising from your use of these resources. Renesas' products are provided only subject to Renesas' Terms and Conditions of Sale or other applicable terms agreed to in writing. No use of any Renesas resources expands or otherwise alters any applicable warranties or warranty disclaimers for these products.

(Disclaimer Rev.1.01)

#### **Corporate Headquarters**

TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan www.renesas.com

#### **Trademarks**

Renesas and the Renesas logo are trademarks of Renesas Electronics Corporation. All trademarks and registered trademarks are the property of their respective owners.

#### **Contact Information**

For further information on a product, technology, the most up-to-date version of a document, or your nearest sales office, please visit <a href="https://www.renesas.com/contact-us/">www.renesas.com/contact-us/</a>.