

# **Registered Adder**

July 17, 1998

**Product Specification** 



Xilinx Inc. 2100 Logic Drive

San Jose, CA 95124

Phone: +1 408-559-7778
Fax: +1 408-559-7114
E-mail: coregen@xilinx.com
URL: www.xilinx.com

### **Features**

- · Two data bus inputs: 2 to 32 bits wide
- Supports both 2's complement signed and unsigned data
- Drop-in modules for the XC4000E, EX, XL, XV and Spartan families
- · Registered output
- Clock Enable for output register
- · Asynchronous Clear for output register
- · Uses Fast Carry logic for high speed
- High performance and density guaranteed through Relational Placed Macro (RPM) mapping and placement technology
- Available in Xilinx CORE Generator

# **Functional Description**

The Registered Adder module accepts two input buses, **A** and **B**, and a carry-input (**CI**), adds them, and registers the sum, **S**. The input data buses can be either 2's complement signed or unsigned numbers.



Figure 1: Functional Representation

| Signal   | Signal Direction | Description                                                                                                                                                                 |
|----------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A[n:0]   | Input            | A data input – value is added to B data and Carry Input (CI).                                                                                                               |
| B[n:0]   | Input            | B data input – value is added to A data and Carry Input (CI).                                                                                                               |
| CI       | Input            | CARRY IN – carry input.<br>Treated as a 1-bit binary<br>number and added to A and<br>B.                                                                                     |
| CE       | Input            | CLOCK ENABLE – active high signal used to enable the transfer of data from the adder to the output register.                                                                |
| С        | Input            | CLOCK – with the exception of asynchronous control inputs (where applicable), control and data inputs are captured, and new output data formed on rising clock transitions. |
| S[n+1:0] | Output           | SUM DATA OUTPUT – the registered output of the adder. Note: 1-bit wider than input operands, A and B.                                                                       |
| CLR      | Input            | ASYNCHRONOUS CLEAR - resets the output register. Overrides Clock and Clock Enable. Level sensitive.                                                                         |

The output bus is 1-bit wider than the input operands to accommodate any carry-out that may be generated when adding the MSBs.

### **Pinout**

Port names for the schematic symbol are shown in Figure 1 and described in Table 1.

#### **CORE Generator Parameters**

The CORE Generator parameterization window for this macro is shown in Figure 2. The parameters are as follows:

- Component Name: Enter a name for the output files generated for this module.
- . Input Width: Select an input bit width from the pull-

down menu. The valid range is 2-32. The same data width is applied to both the A and B inputs. The output size is automatically set to the input width plus one.

• Signed: Select Signed or Unsigned.

### **Core Resource Utilization**

Table 2 shows the resource utilization required for sample bit widths.

## **Ordering Information**

This macro comes free with the Xilinx CORE Generator. For additional information contact your local Xilinx sales representative, or e-mail requests to coregen@xilinx.com.



Figure 2: Parameterization Window

Table 2: Registered Adder Characterization Data

| Input Width | CLB Count | Area<br>Required for<br>RPM (Rows,<br>Columns) | 4000XL-08<br>(Advanced) MHz | 4000XL-09<br>MHz | 4000XL-3 MHz | Spartan-4<br>(Advanced)<br>MHz |
|-------------|-----------|------------------------------------------------|-----------------------------|------------------|--------------|--------------------------------|
| 4           | 4         | 4,1                                            |                             | 146              | 95           | 122                            |
| 8           | 6         | 6,1                                            |                             | 132              | 87           | 110                            |
| 12          | 8         | 8,1                                            |                             | 115              | 74           | 99                             |
| 16          | 10        | 10,1                                           |                             | 109              | 70           | 89                             |
| 20          | 12        | 12,1                                           |                             | 98               | 63           | 82                             |
| 24          | 14        | 14,1                                           |                             | 88               | 57           | 75                             |
| 32          | 18        | 18,1                                           | 92                          | 85               | 55           | 65                             |

To achieve the performance documented in this table, it may be necessary to specify a TIMESPEC (timing specification) PERIOD constraint appropriate to meet the documented frequency.

#### **Parameter File Information**

| Parameter Name | Туре    | Notes      |
|----------------|---------|------------|
| Component_Name | String  |            |
| Input_Width    | Integer | 2 - 32     |
| Signed         | Boolean | True/False |