

August 1, 1997

**Product Specification** 



Design Services for the Design License Agreement with complete Terms and Conditions of Sale.

Notes:

- 1. Assuming all core signals are routed off-chip.
- 2. Minimum guaranteed speed.
- Specific devices are minimum size and speed recommended the core will work in any larger or faster devices from the same families.

Memec Design Services

Maria Aguilar, Project Coordinator Memec Design Services 1819 S. Dobson Rd., Suite 203 Mesa, AZ 85202 Phone: +1 888-360-9044 (in the USA) +1 602-491-4311 (international) Fax: +1 602-491-4907 E-mail: info@memecdesign.com URL: www.memecdesign.com

## Features

- Multi-master operation with arbitration and clock synchronization
- Support for reads, writes, burst reads, burst writes, and repeated start
- User-defined timing and clock frequency
- Fast mode and standard mode operation
- Compatible with popular protocols

# Applications

- Embedded microprocessor boards
- Consumer and professional audio/video
- Home and automotive radio

# **General Description**

The XF-TWSI is an industry standard two-wire serial interface supporting multiple masters.



X8107



## **Functional Description**

The XF-TWSI is partitioned into modules as shown in Figure 1 and described below.

## **Microprocessor Interface Control Logic**

There are three registers used to interface to the host: the Data Register, the Address Register, and the Command Register. The strobes WR\_DATA, WR\_ADDR, and WR\_CMD are directly connected to the clock pins of these register flip-flops for ease of interface.

There is a single parallel in, parallel out, serial in, serial out shift register called NUPSHIFT, which performs the shifting of data for address cycles, write cycles, and read cycles. The parallel output drives MPU\_DOUT[7:0] which is used to return read data to the host.

**Command Register:** The Command Register consists of three bits: the READ bit (bit 0), the STOP bit (bit 1), and the REPEATED START bit (bit 2). These three bits control the operation performed on the serial interface.

The READ bit determines if the operation will be a read (high), or a write (low). The STOP bit will determine if the cycle will stop at the end of the data cycle, or continue on to a burst. The REPEATED START bit will cause the generation of a repeated start protocol.

To generate a single read cycle, the Address register is written with the desired address and the Command Register is written with B011 (binary 011, REPEATED START=0, STOP=1, READ=1) to perform the operation and stop. When the operation is completed (or aborted due to error) the Interrupt pin will go active and the data may be read on MPU\_DOUT[7:0].

To generate a single write cycle, the Address Register is written first, followed by the Data Register, and the Command Register is written with B010 to perform the operation and stop.

A burst read operation is performed in the same manner as a single read, except that the Command Register is written with the STOP bit de-asserted (B001). At the end of the operation an interrupt is generated to the host and the SCL clock line is stretched. When the host has read the data it can write a B011 to the Command Register to perform one more read followed by a stop, or it can write a B001 to perform another read in anticipation of further bursting. Note that there is only one address cycle for a burst read cycle. Also, it is not permitted to follow a read operation or burst read operation with a write operation without first performing a repeated start or a stop.

A burst write operation is performed by setting up the Address and Data Registers, and writing the Command Register with B000. When an interrupt is detected, the next data item is written to the Data Register followed by either a B010 (last data written) or B000 (more data will follow).

The repeated start operation is used to directly follow a read with a write, or a write with a read, without a stop inbetween. Some devices require this for the generation of a second address within the serial bus itself.

Any read or write operation may be followed by a repeated start by resetting the STOP bit and setting the REPEATED START bit when writing to the Command Register. For example, to perform a write cycle followed by a repeated start and a read, the Command Register is written with B100 to perform the write operation. An interrupt will be generated, as always, at the end of the write. Also at the end of the write the clock line (SCL) will be stretched until the new command is written. If a single read is desired the Command Register is written with B011.

**Timing:** The primary clock, CLK, may be operated from 8 to 16 MHz by changing the timing dividers on BUSFREE\_COUNT, HI\_COUNT, and LO\_COUNT core pins. These three bussed pins are used to define the timing for the part by attaching the appropriate divider values. These divider values are multiplexed into a counter which is used to time the low and high width of the SCL clock, the setup time and hold times, and the "bus free" time for arbitration purposes.

The BUSFREE\_COUNT value is used to set the bus free time in terms of CLK periods. The XF-TWSI must see both the SDA and SCL pins in a high state for the bus free period before it issues a start or repeated start command on the bus. Note that this value must be set greater than the longest SCL high period in the system for arbitration to function properly. For Standard mode devices this should be set to at least 5 microseconds. For Fast mode devices this should be set to at least 1.5 microseconds.

The HI\_COUNT value is used to define the low period of the SCL clock and the setup time for a repeated start command (rising edge of SCL to falling edge of SDA). This value is generally set to 4.7 microseconds for Standard mode and 1.3 microseconds for Fast mode.

The LO\_COUNT value is used to define the high width of the SCL clock, the setup time for a stop command (rising edge of SCL to rising edge of SDA), as well as the start command hold time (falling edge of SDA to falling edge of SCL). This value is generally set to 4.0 microseconds for Standard mode and .6 microseconds for Fast mode.

The values can be added to busses attached to these pins as a series of VCCs and GNDs.Note that the actual values obtained from these dividers will be slightly larger due to state machine overhead.

#### SYNCHRS Block

The SDA and SCL inputs are passed through this module that performs a dual-rank synchronization and glitch filtering when enabled by the FILTER\_EN signal. The synchronized versions of the SDA and SCL signals are used in all core modules.

The XF-TWSI core treats both the SDA and SCL lines as data lines. The SDA line is actually sampled some number of clocks after the rising edge of SCL is detected. This allows for greater noise immunity and more robust operation.

#### **State Machine Block**

The control for the serial interface comes from the TWSI\_SM state machine. This state machine controls the loading and enabling of all shift registers and counters, and is responsible for implementing the basic interface protocol.

**Arbitration:** Before the XF-TWSI issues either a start or repeated start command it samples the synchronized versions of SDA and SCL for BUSFREE\_COUNT x clock periods of high values. If at any time either of these pins is detected in a low (driven) state then the count starts over (it assumes that another master is on the bus). The automatic retrying to obtain the serial bus only occurs until the start command is issued. After that the responsibility of the retry is left to software, since cycles may be of infinite length.

After a start is issued and while the address or data is being written to the slave, the core samples the data on the SDA pin while SCL is high. If a data mismatch is detected then the operation is aborted with an interrupt and a BUSLOSS status. This can also occur during burst reads whenever a NACK is intended to be issued and an ACK is detected instead.

**Performing Basic Cycles:** The interface between the host and the XF-TWSI is interrupt-based. The host sets up the Address and Data Registers, writes the Command Register to initiate the desired operation, and performs other operations until the interrupt is generated by the core. Alternatively, if polled operation is desired, the Status Register may be read to see if the interrupt line is active.

Upon receiving the interrupt the host must read the Status Register to see if either of the two error conditions is present. Bit 2 in the Status Register is BUSLOSS, which occurs if the interface lost the bus to another master before completion of the cycle. Bit 1 in the Status Register is STA-TUS TIMEOUT, which occurs if the slave does not respond with an acknowledge when required. For either of these error conditions the host must retry the current cycle up until the last interrupt. Note that for burst operations the host is responsible for writing the incremented address into the Address Register before retrying the operation.

After the host receives the interrupt and determines the status, it sets up the registers again and writes the Command Register to start the next cycle. The act of writing the Command Register clears out the current interrupt.

## Shift Logic (SHIFTLGC)

The basic cycle on theXF-TWSI serial interface consists of an address cycle followed by a data cycle. The address consists of seven bits and the read/write bit (the LSB). The MSB is always transmitted first on the SDA line. The data cycle can either be a read or a write. For a write operation the XF-IIC shifts the data from the Data Register onto the SDA line. For a read operation the core captures the data into the shift register. The data cycle can end in three different ways:

- 1. A stop can be generated which terminates the current cycle.
- 2. Another data cycle can take place (a burst).
- 3. A repeated start can be generated by the interface.

There is always one interrupt generated for each data cycle independent of the type of cycle. For example, for a burst read cycle an interrupt will be generated for each byte read. For a burst write cycle an interrupt will be generated when each byte transfer is completed.

A repeated start is used to turn the bus around; when a read cycle must be followed directly by a write cycle without a stop in-between. Since the READ bit is a part of the address, if a read followed by write is desired without a stop command, a second address must be issued following the data cycle. The sequence of events in a repeated start

cycle is: start, address cycle, data cycle, repeated start, address cycle, data cycle, stop. Each of the data cycles can be repeated if bursting is desired, and the stop cycle could actually be another repeated start, if desired.

#### **External Crystal Support**

This core does not support connection of a crystal directly to the device. The XC4000 will require a clock input.

|                                | Subcycle             | Command Register Contents |      |      |
|--------------------------------|----------------------|---------------------------|------|------|
| Operation                      |                      | Repstart                  | Stop | Read |
| Single Read                    | Single Read          | 0                         | 1    | 1    |
| Single Write                   | Single Write         | 0                         | 1    | 0    |
| Burst Read                     | Burst Read Start     | 0                         | 0    | 1    |
|                                | Burst Read Continue  | 0                         | 0    | 1    |
|                                | Last Burst Read      | 0                         | 1    | 1    |
| Burst Write                    | Burst Write Start    | 0                         | 0    | 0    |
|                                | Burst Write Continue | 0                         | 0    | 0    |
|                                | Last Burst Write     | 0                         | 1    | 0    |
| Read with Repeated Start fol-  | Read with RepStart   | 1                         | 0    | 1    |
| lowed by Burst Write           | Burst Write Start    | 0                         | 0    | 0    |
|                                | Burst Write Continue | 0                         | 0    | 0    |
|                                | Last Burst Write     | 0                         | 1    | 0    |
| Write with Repeated Start fol- | Write with RepStart  | 1                         | 0    | 0    |
| lowed by Burst Read            | Burst Read Start     | 0                         | 0    | 1    |
|                                | Burst Read Continue  | 0                         | 0    | 1    |
|                                | Last Burst Read      | 0                         | 1    | 1    |
| Illegal Sequence               | Burst Read           | 0                         | 0    | 1    |
|                                | Burst Write          | 0                         | 0    | 0    |
| Illegal Sequence               | Burst Write          | 0                         | 0    | 0    |
|                                | Burst Read           | 0                         | 0    | 1    |

#### **Table 1: Available Command Sequences**

# Pinout

The XF-TWSI may be implemented as stand-alone logic using the provided pinout or may be implemented internally with the users design. Both versions are included with the Core deliverables. Signal names are provided in the block diagram shown in Figure 1, and Table 2.

#### **Table 2: Core Signal Pinout**

| Signal       | Signal<br>Direction | Description                                                                                                                                                     |  |
|--------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CLK          | Input               | Primary clock used for all                                                                                                                                      |  |
|              |                     | circuits.                                                                                                                                                       |  |
| RESET        | Input               | Reset, active high.                                                                                                                                             |  |
| RD_L         | Input               | When active "0" with prop-<br>er read buffer/register se-<br>lected allows reads on the<br>MPU_DOUT[7:0].                                                       |  |
| TWSI_DATA    | Input               | When active "1" with a RD_L allows reads on MPU_DOUT{7:0].                                                                                                      |  |
| WR_L         | Input               | Rising edge of this signal registers data in internal registers when addressed.                                                                                 |  |
| MPU_DIN[7:0] | Input               | Microprocessor Data In<br>lines used to program Da-<br>ta, Address, and Com-<br>mand Registers.                                                                 |  |
| WR_DATA      | Input               | When active "1" with a<br>WR_L strobes 8-bits of<br>data from MPU_DIN[7:0]<br>into Data Register for seri-<br>al bus write cycle.                               |  |
| WR_ADDR      | Input               | When active "1" with a<br>WR_L strobes least signif-<br>icant 7 bits of data on<br>MPU_DIN[7:0] lines into<br>Address Register for all<br>Serial Bus Operations |  |

| Signal               | Signal<br>Direction | Description                                                                                                                                                                                                                                                                 |  |
|----------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CMD_STAT             | In/Out              | When active "1" with a<br>WR_L strobes least signif-<br>icant 3 bits of data from<br>MPU_DIN[7:0] lines into<br>Command Register and<br>initiates serial bus cycle;<br>also clears Interrupt line at<br>this time. When active "1"<br>with a RD_L reads Status<br>Register. |  |
| WR_HI_CNT            | Input               | When active "1" with a<br>WR_L strobes 8-bits of<br>data from MPU_DIN[7:0]<br>into HI_COUNT Register<br>used to set number of CLK<br>clock periods for low peri-<br>od of SCL and setup time<br>for a repeated start opera-<br>tion.                                        |  |
| WR_LO_CNT            | Input               | When active "1" with a<br>WR_L strobes 8-bits of<br>data from MPU_DIN[7:0]<br>into LO_COUNT Register<br>used to set number of CLK<br>clock periods for high<br>count of SCL, hold time for<br>start command, and setup<br>time for stop command.                            |  |
| WR_BUSFREE_<br>COUNT | Input               | When active "1" with<br>WR_L strobes 8-bits of<br>data from MPU_DIN[7:0]<br>into BUSFREE_COUNT<br>register used to set bus<br>free period.                                                                                                                                  |  |
| INTERRUPT            | Output              | Interrupt line set upon<br>completion or abort of seri-<br>al cycle. It is cleared by<br>writing to Command, ac-<br>tive high.                                                                                                                                              |  |
| MPU_DOUT[7:0]        | Output              | Returns read data after ac-<br>tivation of Interrupt pin and<br>error free status.                                                                                                                                                                                          |  |
| SDA_IN               | In                  | Serial Data In.                                                                                                                                                                                                                                                             |  |
| SDA_O                | Out                 | Serial Data Out.                                                                                                                                                                                                                                                            |  |
|                      | In                  | Serial Clock In.                                                                                                                                                                                                                                                            |  |
| SCL_IN               |                     |                                                                                                                                                                                                                                                                             |  |

## **Core Modifications**

The XF-TWSI meets or exceeds the industry standard. However, in most cases the Timespecs can be tightened significantly. Successful operation with 120ns bus cycles has been achieved. In all cases, a post-route timing analysis should be performed to verify performance. Implementation beyond 10MHz and other customizing is available through Memec Design Services.

## **Verification Methods**

Complete functional and timing simulation has been performed on the XF-TWSI using Viewsim. (Simulation vectors used for verification are provided with the core.) The README.TXT file has a short description of the top level CMD files used to simulate the design. These CMD files include descriptions and comments.

## **Recommended Design Experience**

Users should be familiar with ViewLogic PROcapture or Office schematic entry and Xilinx design flows. Users should also have experience with microprocessor systems and peripherals.

## **Ordering Information**

The XF-TWSI Two-wire Serial Interface Core is provided under license from Memec Design Services for use in Xilinx programmable logic devices and Xilinx HardWire<sup>TM</sup> gate arrays. To purchase or make further inquiries about this or other Memec Design Services products, contact MDS directly at the location listed on the front page.

Information furnished by Memec Design Services is believed to be accurate and reliable. Memec Design Services reserves the right to change specifications detailed in this data sheet at any time without notice, in order to improve reliability, function or design, and assumes no responsibility for any errors within this document. Memec Design Services does not make any commitment to update this information.

Memec Design Services assumes no obligation to correct any errors contained herein or to advise any user of this text of any correction, if such be made, nor does the Company assume responsibility for the functioning of undescribed features or parameters. Memec Design Services will not assume any liability for the accuracy or correctness of any support or assistance provided to a user.

Memec Design Services does not represent that products described herein are free from patent infringement or from any other third-party right. No license is granted by implication or otherwise under any patent or patent rights of Memec Design Services.

Memec Design Services products are not intended for use in life support appliances, devices, or systems. Use of a Memec Design Services product in such application without the written consent of the appropriate Memec Design Services officer is prohibited.

All trademarks, registered trademarks, or servicemarks are property of their respective owners.

# Related Documentation and Information

## Xilinx Programmable Logic

For information on Xilinx programmable logic or development system software, contact your local Xilinx sales office, or:

Xilinx, Inc. 2100 Logic Drive San Jose, CA 95124 Phone: +1 408-559-7778 Fax: +1 408-559-7114 URL: www.xilinx.com

For general Xilinx literature, contact:

| Phone:  | +1 800-231-3386 (inside the US)  |
|---------|----------------------------------|
|         | +1 408-879-5017 (outside the US) |
| E-mail: | literature@xilinx.com            |

For AllianceCORE<sup>™</sup> specific information, contact:

| Phone: | +1 408-879-5381 |
|--------|-----------------|
|--------|-----------------|

URL: www.xilinx.com/products /logicore/alliance/tblpart.htm