

---

# ***SmartFusion2 and IGLOO2 Macro Library Guide***



# Table of Contents - All Macros

---

|                       |    |                            |    |
|-----------------------|----|----------------------------|----|
| AND2.....             | 12 | OSCILLATOR .....           | 21 |
| AND3.....             | 12 | OUTBUF .....               | 48 |
| AND4.....             | 13 | OUTBUF_DIFF .....          | 48 |
| ARI1.....             | 18 | RAM1K18.....               | 54 |
| BIBUF .....           | 44 | RAM64x18.....              | 62 |
| BIBUF_DIFF .....      | 44 | RCLKINT .....              | 16 |
| BUFD.....             | 14 | RGCLKINT.....              | 16 |
| BUFF.....             | 13 | SLE .....                  | 17 |
| CLKBIBUF.....         | 45 | SYSCTRL_RESET_STATUS ..... | 23 |
| CLKBUF .....          | 45 | SYSRESET .....             | 23 |
| CLKBUF_DIFF .....     | 46 | TRIBUFF .....              | 49 |
| CLKINT .....          | 14 | TRIBUFF_DIFF .....         | 49 |
| CLKINT_PRESERVE ..... | 15 | UJTAG .....                | 42 |
| DDR_IN.....           | 50 | XOR2.....                  | 38 |
| DDR_OUT.....          | 52 | XOR3.....                  | 39 |
| DFN1 .....            | 26 | XOR4.....                  | 40 |
| DFN1C0 .....          | 27 | XOR8.....                  | 41 |
| DFN1E1 .....          | 27 |                            |    |
| DFN1E1C0 .....        | 28 |                            |    |
| DFN1E1P0 .....        | 29 |                            |    |
| DFN1P0.....           | 30 |                            |    |
| DLN1 .....            | 30 |                            |    |
| DLN1C0 .....          | 31 |                            |    |
| DLN1P0 .....          | 31 |                            |    |
| FCEND_BUFF.....       | 20 |                            |    |
| FCINIT_BUFF .....     | 21 |                            |    |
| FLASH_FREEZE.....     | 21 |                            |    |
| GCLKBIBUF .....       | 26 |                            |    |
| GCLKBUF .....         | 24 |                            |    |
| GCLKBUF_DIFF .....    | 25 |                            |    |
| GCLKINT.....          | 15 |                            |    |
| INBUF .....           | 47 |                            |    |
| INBUF_DIFF .....      | 47 |                            |    |
| INV.....              | 32 |                            |    |
| INVD .....            | 32 |                            |    |
| LIVE_PROBE_FB.....    | 24 |                            |    |
| MACC .....            | 69 |                            |    |
| MX2.....              | 33 |                            |    |
| MX4.....              | 33 |                            |    |
| NAND2 .....           | 34 |                            |    |
| NAND3 .....           | 34 |                            |    |
| NAND4 .....           | 35 |                            |    |
| NOR2.....             | 35 |                            |    |
| NOR3.....             | 36 |                            |    |
| NOR4.....             | 36 |                            |    |
| OR2.....              | 37 |                            |    |
| OR3.....              | 37 |                            |    |
| OR4.....              | 38 |                            |    |

## Table of Contents - Combinatorial Logic

---

|             |    |
|-------------|----|
| AND2.....   | 12 |
| AND3.....   | 12 |
| AND4.....   | 13 |
| ARI1.....   | 18 |
| BUFD.....   | 14 |
| BUFF.....   | 13 |
| INV.....    | 32 |
| INVD .....  | 32 |
| MX2.....    | 33 |
| MX4.....    | 33 |
| NAND2 ..... | 34 |
| NAND3 ..... | 34 |
| NAND4 ..... | 35 |
| NOR2.....   | 35 |
| NOR3.....   | 36 |
| NOR4.....   | 36 |
| OR2.....    | 37 |
| OR3.....    | 37 |
| OR4.....    | 38 |
| XOR2.....   | 38 |
| XOR3.....   | 39 |
| XOR4.....   | 40 |
| XOR8.....   | 41 |

## Table of Contents - Sequential Logic

---

|                |    |
|----------------|----|
| DFN1 .....     | 26 |
| DFN1C0 .....   | 27 |
| DFN1E1 .....   | 27 |
| DFN1E1C0 ..... | 28 |
| DFN1E1P0 ..... | 29 |
| DFN1P0.....    | 30 |
| DLN1 .....     | 30 |
| DLN1C0 .....   | 31 |
| DLN1P0 .....   | 31 |
| SLE .....      | 17 |

---

## Table of Contents - RAM Blocks

---

|               |    |
|---------------|----|
| RAM1K18 ..... | 54 |
| RAM64x18..... | 62 |

---

## Table of Contents - Math Blocks

---

MACC ..... 69

---

## Table of Contents - I/Os

---

|                    |    |
|--------------------|----|
| BIBUF .....        | 44 |
| BIBUF_DIFF .....   | 44 |
| CLKBIBUF.....      | 45 |
| CLKBUF .....       | 45 |
| CLKBUF_DIFF .....  | 46 |
| DDR_IN.....        | 50 |
| DDR_OUT.....       | 52 |
| GCLKBIBUF .....    | 26 |
| GCLKBUF .....      | 24 |
| GCLKBUF_DIFF ..... | 25 |
| INBUF .....        | 47 |
| INBUF_DIFF .....   | 47 |
| OUTBUF .....       | 48 |
| OUTBUF_DIFF .....  | 48 |
| TRIBUFF .....      | 49 |
| TRIBUFF_DIFF ..... | 49 |
| UJTAG.....         | 42 |

---

## Table of Contents - Clocking

---

|                       |    |
|-----------------------|----|
| CLKBIBUF.....         | 45 |
| CLKBUF .....          | 45 |
| CLKBUF_DIFF .....     | 46 |
| CLKINT .....          | 14 |
| CLKINT_PRESERVE ..... | 15 |
| GCLKBIBUF .....       | 26 |
| GCLKBUF .....         | 24 |
| GCLKBUF_DIFF .....    | 25 |
| GCLKINT.....          | 15 |
| RCLKINT.....          | 16 |
| RGCLKINT .....        | 16 |

---

## Table of Contents - Special

---

|                            |    |
|----------------------------|----|
| FCEND_BUFF.....            | 20 |
| FCINIT_BUFF .....          | 21 |
| FLASH_FREEZE.....          | 21 |
| LIVE_PROBE_FB .....        | 24 |
| OSCILLATOR .....           | 21 |
| SYSCTRL_RESET_STATUS ..... | 23 |
| SYSRESET .....             | 23 |

# Introduction

---

This macro library guide supports the SmartFusion2 and IGLOO2 families. See the Microsemi website for macro guides for other families.

This guide follows a naming convention for sequential macros that is unambiguous and extensible, making it possible to understand the function of the macros by their name alone.

The first two mandatory characters of the macro name will indicate the basic macro function:

- DF - D-type flip-flop
- DL - D-type latch

The next mandatory character indicates the output polarity:

- I - output inverted (QN with bubble)
- N - output non-inverted (Q without bubble)

The next mandatory number indicates the polarity of the clock or gate:

- 1 - rising edge triggered flip-flop or transparent high latch (non-bubbled)
- 0 - falling edge triggered flip-flop or transparent low latch (bubbled)

The next two optional characters indicate the polarity of the Enable pin, if present:

- E0 - active low enable (bubbled)
- E1 - active high enable (non-bubbled)

The next two optional characters indicate the polarity of the asynchronous Preset pin, if present:

- P0 - active low asynchronous preset (bubbled)
- P1 - active high asynchronous preset (non-bubbled)

The next two optional characters indicate the polarity of the asynchronous Clear pin, if present:

- C0 - active low asynchronous clear (bubbled)
- C1 - active high asynchronous clear (non-bubbled)

All sequential and combinatorial macros (except MX4 and XOR8) use one logic element in the SmartFusion2 and IGLOO2 families.

As an example, the macro DFN1E1C0 indicates a D-type flip-flop (DF) with a non-inverted (N) Q output, positive-edge triggered (1), with Active High Clock Enable (E1) and Active Low Asynchronous Clear (C0). See [Figure 1](#).



**Figure 1 • Naming Convention**

## AND2

2-Input AND

---



---

Figure 2 • AND2

| Inputs | Output |
|--------|--------|
| A, B   | Y      |

### Truth Table

| A | B | Y |
|---|---|---|
| X | 0 | 0 |
| 0 | X | 0 |
| 1 | 1 | 1 |

## AND3

3-Input AND

---



---

Figure 3 • AND3

| Input   | Output |
|---------|--------|
| A, B, C | Y      |

### Truth Table

| A | B | C | Y |
|---|---|---|---|
| X | X | 0 | 0 |
| X | 0 | X | 0 |
| 0 | X | X | 0 |
| 1 | 1 | 1 | 1 |

## AND4

4-Input AND

---



*Figure 4 • AND4*

| Input      | Output |
|------------|--------|
| A, B, C, D | Y      |

### ***Truth Table***

| A | B | C | D | Y |
|---|---|---|---|---|
| X | X | X | 0 | 0 |
| X | X | 0 | X | 0 |
| X | 0 | X | X | 0 |
| 0 | X | X | X | 0 |
| 1 | 1 | 1 | 1 | 1 |

## BUFF

Buffer

---



*Figure 5 • BUFF*

| Input | Output |
|-------|--------|
| A     | Y      |

### ***Truth Table***

| A | Y |
|---|---|
| 0 | 0 |
| 1 | 1 |

## BUFD

Buffer. Note that Compile optimization will not remove this macro.

---



Figure 6 • BUFD

---

| Input | Output |
|-------|--------|
| A     | Y      |

### Truth Table

| A | Y |
|---|---|
| 0 | 0 |
| 1 | 1 |

## CLKINT

Macro used to route an internal fabric signal to global network.

---



Figure 7 • CLKINT

---

| Input | Output |
|-------|--------|
| A     | Y      |

### Truth Table

| A | Y |
|---|---|
| 0 | 0 |
| 1 | 1 |

## CLKINT\_PRESERVE

Macro used to route an internal fabric signal to global network. It has the same functionality as CLKINT except that this clock always stay on the global clock network and will not be demoted during design implementation.



**Figure 8 • CLKINT\_PRESERVE**

| Input | Output |
|-------|--------|
| A     | Y      |

### Truth Table

| A | Y |
|---|---|
| 0 | 0 |
| 1 | 1 |

## GCLKINT

Gated macro used to route an internal fabric signal to global network. The Enable signal can be used to turn off the global network to save power.



**Figure 9 • GCLKINT**

| Input | Output |
|-------|--------|
| A, EN | Y      |

### Truth Table

| A | EN | Y |
|---|----|---|
| X | 0  | 0 |
| 0 | X  | 0 |
| 1 | 1  | 1 |

## RCLKINT

Macro used to route an internal fabric signal to a row global buffer, thus creating a local clock.



Figure 10 • RCLKINT

| Input | Output |
|-------|--------|
| A     | Y      |

### Truth Table

| A | Y |
|---|---|
| 0 | 0 |
| 1 | 1 |

## RGCLKINT

Gated macro used to route an internal fabric signal to a row global buffer, thus creating a local clock. The Enable signal can be used to turn off the local clock to save power.



Figure 11 • RGCLKINT

| Input | Output |
|-------|--------|
| A, EN | Y      |

### Truth Table

| A | EN | Y |
|---|----|---|
| X | 0  | 0 |
| 0 | X  | 0 |
| 1 | 1  | 1 |

## SLE

Sequential Logic Element



**Figure 12 • SLE**

| Input |                                | Output |
|-------|--------------------------------|--------|
| Name  | Function                       | Q      |
| D     | Data                           |        |
| CLK   | Clock                          |        |
| EN    | Enable                         |        |
| ALn   | Asynchronous Load (Active Low) |        |
| ADn*  | Asynchronous Data (Active Low) |        |
| SLn   | Synchronous Load (Active Low)  |        |
| SD*   | Synchronous Data               |        |
| LAT*  | Latch Enable                   |        |

\*Note: ADn, SD and LAT are static signals defined at design time and need to be tied to 0 or 1.

### Truth Table

| ALn | ADn | LAT | CLK        | EN | SLn | SD | D | Q <sub>n+1</sub> |
|-----|-----|-----|------------|----|-----|----|---|------------------|
| 0   | ADn | X   | X          | X  | X   | X  | X | !ADn             |
| 1   | X   | 0   | Not rising | X  | X   | X  | X | Qn               |
| 1   | X   | 0   | ↑          | 0  | X   | X  | X | Qn               |
| 1   | X   | 0   | ↑          | 1  | 0   | SD | X | SD               |
| 1   | X   | 0   | ↑          | 1  | 1   | X  | D | D                |
| 1   | X   | 1   | 0          | X  | X   | X  | X | Qn               |
| 1   | X   | 1   | 1          | 0  | X   | X  | X | Qn               |
| 1   | X   | 1   | 1          | 1  | 0   | SD | X | SD               |
| 1   | X   | 1   | 1          | 1  | 1   | X  | D | D                |

## ARI1

The ARI1 macro is responsible for representing all arithmetic operations in the pre-layout phase



**Figure 13 • ARI1**

| Input           | Output    |
|-----------------|-----------|
| A, B, C, D, FCI | Y, S, FCO |

The ARI1 cell has a 20bit INIT string parameter that is used to configure its functionality. The interpretation of the 16 LSB of the INIT string is shown in the table below. F0 is the value of Y when A = 0 and F1 is the value of Y when A = 1.

**Table 1 • Interpretation of 16 LSB of the INIT String for ARI1**

| ADCB | Y        |    |
|------|----------|----|
| 0000 | INIT[0]  | F0 |
| 0001 | INIT[1]  |    |
| 0010 | INIT[2]  |    |
| 0011 | INIT[3]  |    |
| 0100 | INIT[4]  |    |
| 0101 | INIT[5]  |    |
| 0110 | INIT[6]  |    |
| 0111 | INIT[7]  |    |
| 1000 | INIT[8]  | F1 |
| 1001 | INIT[9]  |    |
| 1010 | INIT[10] |    |
| 1011 | INIT[11] |    |
| 1100 | INIT[12] |    |
| 1101 | INIT[13] |    |
| 1110 | INIT[14] |    |
| 1111 | INIT[15] |    |

**Table 2 • Truth Table for S**

| Y | FCI | S |
|---|-----|---|
| 0 | 0   | 0 |
| 0 | 1   | 1 |
| 1 | 0   | 1 |
| 1 | 1   | 0 |


**Figure 14 • ARI1 Logic**

The 4 MSB of the INIT string controls the output of the carry bits. The carry is generated using carry propagation and generation bits, which are evaluated according to the tables below.

**Table 3 • ARI1 INIT[17:16] String Interpretation**

| INIT[17] | INIT[16] | G  |
|----------|----------|----|
| 0        | 0        | 0  |
| 0        | 1        | F0 |
| 1        | 0        | 1  |
| 1        | 1        | F1 |

**Table 4 • ARI1 INIT[19:18] String Interpretation**

| INIT[19] | INIT[18] | P |
|----------|----------|---|
| 0        | 0        | 0 |
| 0        | 1        | Y |
| 1        | X        | 1 |

**Table 5 • FCO Truth Table**

| P | G | FCI | FCO |
|---|---|-----|-----|
| 0 | G | X   | G   |
| 1 | X | FCI | FCI |

## FCEND\_BUFF

Buffer, driven by the FCO pin of the last macro in the Carry-Chain.

---



**Figure 15 • FCEND\_BUFF**

---

| Input | Output |
|-------|--------|
| A     | Y      |

**Truth Table**

| A | Y |
|---|---|
| 0 | 0 |
| 1 | 1 |

## FCINIT\_BUFF

Buffer, used to initialize the FCI pin of the first macro in the Carry-Chain.



Figure 16 • FCINIT\_BUFF

---

| Input | Output |
|-------|--------|
| A     | Y      |

### Truth Table

| A | Y |
|---|---|
| 0 | 0 |
| 1 | 1 |

## FLASH\_FREEZE

The Flash\_Freeze macro is a special-purpose macro that provides information on when the chip is about to go into Flash Freeze mode to allow the user to perform any housekeeping needed before the device enters into Flash Freeze mode. The macro has 2 outputs:

- FF\_TO\_START: This signal goes high when the FPGA is about to go into Flash Freeze mode.
- FF\_DONE: This signal goes high when the FPGA has successfully entered Flash Freeze mode.



Figure 17 • FLASH\_FREEZE

For more information about this macro, refer to the [System Controller User Guide](#) and the [SmartFusion2 Low Power Design User Guide](#).

There is no simulation model for this macro. The two outputs remain low during simulation because Flash Freeze is not supported during simulation.

## OSCILLATOR

The OSC macro is a special-purpose macro. It can be configured as a Crystal Oscillator (XTLOSC), a 25/50 MHz RC Oscillator or a 1MHz RC Oscillator. All three configurations are supported by simulation models.

## XTLOSC

The crystal oscillator provides up to a 20 MHz clock signal. Physically, it requires connection to an external crystal, however, for simulation purposes the XTL pin provides a clock signal running at the desired input frequency. MODE is a two-bit configuration parameter that specifies the frequency range. If the DISABLE input is high, the output is low.

| MODE[1:0] | Frequency Range (MHz) |
|-----------|-----------------------|
| 00        | N/A                   |
| 01        | 0.032–0.075           |
| 10        | 0.075–2.0             |
| 11        | 2.0–20.0              |



Figure 18 • XTLOSC

## RCOSC\_1MHz

The RCOSC\_1MHz oscillator is an RC oscillator that provides a free running clock of 1MHz frequency. The DISABLE pin is active high and when asserted, it turns off the oscillator output.



Figure 19 • RCOSC\_1MHz

## RCOSC\_25\_50MHz

The RCOSC\_25\_50MHz oscillator is an RC oscillator that provides a free running clock of 25 MHz (at 1.0V supply voltage) or 50MHz (at 1.2V supply voltage). The DISABLE pin is active high and when asserted, it turns off the oscillator output.



---

Figure 20 • RCOSC\_25\_50MHz

## SYSRESET

SYSRESET is a special-purpose macro. The Output POWER\_ON\_RESET\_N goes low at power up and when DEVRST\_N goes low.

---



---

Figure 21 • SYSRESET

| Input    | Output           |
|----------|------------------|
| DEVRST_N | POWER_ON_RESET_N |

### Truth Table

| DEVRST_N | POWER_ON_RESET_N |
|----------|------------------|
| 0        | 0                |
| 1        | 1                |

## SYSCTRL\_RESET\_STATUS

This is a special-purpose macro to check the status of the System Controller. The output port RESET\_STATUS goes high if the System Controller is in reset ("System Controller Suspend Mode" option is checked in Device Settings under Libero's Project Settings).



---

**Figure 22 • SYSCTRL\_RESET\_STATUS**

This macro is not supported in simulation.

## LIVE\_PROBE\_FB

This is a special-purpose macro that feeds the live probe signals back to the fabric. You can connect the PROBE\_A/PROBE\_B signals to any unused I/O during design generation. This is useful if PROBE\_A/PROBE\_B cannot be brought out for debug due to board limitations.

**Note:** PROBE\_A and PROBE\_B pins must be reserved if LIVE\_PROBE\_FB macro is used.

---



---

**Figure 23 • LIVE\_PROBE\_FB**

This macro is not supported in simulation.

## GCLKBUF

Gated input I/O macro to global network; the Enable signal can be used to turn off the global network to save power.

---



---

**Figure 24 • GCLKBUF**

| Input   | Output |
|---------|--------|
| PAD, EN | Y      |

**Truth Table**

| PAD | EN | Y |
|-----|----|---|
| X   | 0  | 0 |
| Z   | 1  | X |
| 0   | X  | 0 |
| 1   | 1  | 1 |

## GCLKBUF\_DIFF

Gated differential I/O macro to global network; the Enable signal can be used to turn off the global network, Differential I/O

---



**Figure 25 • GCLKBUF\_DIFF**

Differential

| Input   | Output |
|---------|--------|
| PAD, EN | Y      |

**Truth Table**

| PADP | PADN | EN | Y |
|------|------|----|---|
| X    | X    | 0  | 0 |
| Z    | Z    | 1  | X |
| 0    | 0    | 1  | X |
| 1    | 1    | 1  | X |
| 0    | 1    | 1  | 0 |
| 1    | 0    | 1  | 1 |

## GCLKBIBUF

Bidirectional I/O macro with gated input to global network; the Enable signal can be used to turn off the global network to save power.



*Figure 26 • GCLKBIBUF*

| Input         | Output |
|---------------|--------|
| D, E, EN, PAD | Y, PAD |

### Truth Table

| D | E | EN | PAD | Y   |
|---|---|----|-----|-----|
| X | 0 | 0  | X   | 0   |
| X | 0 | 1  | Z   | X   |
| X | 0 | 1  | PAD | PAD |
| D | 1 | 0  | D   | 0   |
| D | 1 | 1  | D   | D   |

## DFN1

D-Type Flip-Flop



*Figure 27 • DFN1*

| Input  | Output |
|--------|--------|
| D, CLK | Q      |

### Truth Table

| CLK        | D | Q <sub>n+1</sub> |
|------------|---|------------------|
| not Rising | X | Q <sub>n</sub>   |
| ↑          | D | D                |

## DFN1C0

D-Type Flip-Flop with active low Clear



**Figure 28 • DFN1C0**

| Input       | Output |
|-------------|--------|
| D, CLK, CLR | Q      |

### Truth Table

| CLR | CLK        | D | $Q_{n+1}$ |
|-----|------------|---|-----------|
| 0   | X          | X | 0         |
| 1   | not Rising | X | $Q_n$     |
| 1   | ↑          | D | D         |

## DFN1E1

D-Type Flip-Flop with active high Enable



**Figure 29 • DFN1E1**

| Input     | Output |
|-----------|--------|
| D, E, CLK | Q      |

### Truth Table

| E | CLK        | D | $Q_{n+1}$ |
|---|------------|---|-----------|
| 0 | X          | X | $Q_n$     |
| 1 | not Rising | X | $Q_n$     |
| 1 | ↑          | D | D         |

## DFN1E1C0

D-Type Flip-Flop, with active high Enable and active low Clear.

---



---

**Figure 30 • DFN1E1C0**

| Input          | Output |
|----------------|--------|
| CLR, D, E, CLK | Q      |

**Truth Table**

| CLR | E | CLK        | D | $Q_{n+1}$ |
|-----|---|------------|---|-----------|
| 0   | X | X          | X | 0         |
| 1   | 0 | X          | X | $Q_n$     |
| 1   | 1 | not Rising | X | $Q_n$     |
| 1   | 1 | ↑          | D | D         |

## DFN1E1P0

D-Type Flip-Flop with active high Enable and active low Preset.

---



---

Figure 31 • DFN1E1P0

---

| Input          | Output |
|----------------|--------|
| D, E, PRE, CLK | Q      |

**Truth Table**

| PRE | E | CLK        | D | $Q_{n+1}$ |
|-----|---|------------|---|-----------|
| 0   | X | X          | X | 1         |
| 1   | 0 | X          | X | $Q_n$     |
| 1   | 1 | not Rising | X | $Q_n$     |
| 1   | 1 | ↑          | D | D         |

## DFN1P0

D-Type Flip-Flop with active low Preset.



*Figure 32 • DFN1P0*

| Input       | Output |
|-------------|--------|
| D, PRE, CLK | Q      |

### ***Truth Table***

| PRE | CLK        | D | Q <sub>n+1</sub> |
|-----|------------|---|------------------|
| 0   | X          | X | 1                |
| 1   | not Rising | X | Q <sub>n</sub>   |
| 1   | ↑          | D | D                |

## DLN1

Data Latch



*Figure 33 • DLN1*

| Input | Output |
|-------|--------|
| D, G  | Q      |

### ***Truth Table***

| G | D | Q |
|---|---|---|
| 0 | X | Q |
| 1 | D | D |

## DLN1C0

Data Latch with active low Clear



*Figure 34 • DLN1C0*

| Input     | Output |
|-----------|--------|
| CLR, D, G | Q      |

### ***Truth Table***

| CLR | G | D | Q |
|-----|---|---|---|
| 0   | X | X | 0 |
| 1   | 0 | X | Q |
| 1   | 1 | D | D |

## DLN1P0

Data Latch with active low Preset



*Figure 35 • DLN1P0*

| Input     | Output |
|-----------|--------|
| D, G, PRE | Q      |

### ***Truth Table***

| PRE | G | D | Q |
|-----|---|---|---|
| 0   | X | X | 1 |
| 1   | 0 | X | Q |
| 1   | 1 | D | D |

## INV

Inverter

---



Figure 36 • INV

| Input | Output |
|-------|--------|
| A     | Y      |

### Truth Table

| A | Y |
|---|---|
| 0 | 1 |
| 1 | 0 |

## INVD

Inverter; note that Compile optimization will not remove this macro.

---



Figure 37 • INVD

| Input | Output |
|-------|--------|
| A     | Y      |

### Truth Table

| A | Y |
|---|---|
| 0 | 1 |
| 1 | 0 |

## MX2

2 to 1 Multiplexer

---



**Figure 38 • MX2**

| Input   | Output |
|---------|--------|
| A, B, S | Y      |

### Truth Table

| A | B | S | Y |
|---|---|---|---|
| A | X | 0 | A |
| X | B | 1 | B |

## MX4

4 to 1 Multiplexer

This macro uses two logic modules.

---



**Figure 39 • MX4**

| Input                  | Output |
|------------------------|--------|
| D0, D1, D2, D3, S0, S1 | Y      |

### Truth Table

| D3 | D2 | D1 | D0 | S1 | S0 | Y  |
|----|----|----|----|----|----|----|
| X  | X  | X  | D0 | 0  | 0  | D0 |
| X  | X  | D1 | X  | 0  | 1  | D1 |
| X  | D2 | X  | X  | 1  | 0  | D2 |
| D3 | X  | X  | X  | 1  | 1  | D3 |

## NAND2

2-Input NAND

---



---

Figure 40 • NAND2

| Input | Output |
|-------|--------|
| A, B  | Y      |

### Truth Table

| A | B | Y |
|---|---|---|
| X | 0 | 1 |
| 0 | X | 1 |
| 1 | 1 | 0 |

## NAND3

3-Input NAND

---



---

Figure 41 • NAND3

| Input   | Output |
|---------|--------|
| A, B, C | Y      |

### Truth Table

| A | B | C | Y |
|---|---|---|---|
| X | X | 0 | 1 |
| X | 0 | X | 1 |
| 0 | X | X | 1 |
| 1 | 1 | 1 | 0 |

## NAND4

4-input NAND

---



*Figure 42 • NAND4*

| Input      | Output |
|------------|--------|
| A, B, C, D | Y      |

### Truth Table

| A | B | C | D | Y |
|---|---|---|---|---|
| X | X | X | 0 | 1 |
| X | X | 0 | X | 1 |
| X | 0 | X | X | 1 |
| 0 | X | X | X | 1 |
| 1 | 1 | 1 | 1 | 0 |

## NOR2

2-input NOR

---



*Figure 43 • NOR2*

| Input | Output |
|-------|--------|
| A, B  | Y      |

### Truth Table

| A | B | Y |
|---|---|---|
| 0 | 0 | 1 |
| X | 1 | 0 |
| 1 | X | 0 |

## NOR3

3-input NOR

---



**Figure 44 • NOR3**

| Input   | Output |
|---------|--------|
| A, B, C | Y      |

### Truth Table

| A | B | C | Y |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| X | X | 1 | 0 |
| X | 1 | X | 0 |
| 1 | X | X | 0 |

## NOR4

4-input NOR

---



**Figure 45 • NOR4**

| Input      | Output |
|------------|--------|
| A, B, C, D | Y      |

### Truth Table

| A | B | C | D | Y |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 1 |
| 1 | X | X | X | 0 |
| X | 1 | X | X | 0 |
| X | X | 1 | X | 0 |
| X | X | X | 1 | 0 |

## OR2

2-input OR

---



**Figure 46 • OR2**

| Input | Output |
|-------|--------|
| A, B  | Y      |

**Truth Table**

| A | B | Y |
|---|---|---|
| 0 | 0 | 0 |
| X | 1 | 1 |
| 1 | X | 1 |

## OR3

3-input OR

---



**Figure 47 • OR3**

| Input   | Output |
|---------|--------|
| A, B, C | Y      |

**Truth Table**

| A | B | C | Y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| X | X | 1 | 1 |
| X | 1 | X | 1 |
| 1 | X | X | 1 |

## OR4

4-input OR

---



Figure 48 • OR4

| Input      | Output |
|------------|--------|
| A, B, C, D | Y      |

### Truth Table

| A | B | C | D | Y |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 1 | X | X | X | 1 |
| X | 1 | X | X | 1 |
| X | X | 1 | X | 1 |
| X | X | X | 1 | 1 |

## XOR2

2-input XOR

---



Figure 49 • XOR2

| Input | Output |
|-------|--------|
| A, B  | Y      |

### Truth Table

| A | B | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

## XOR3

3-input XOR

---



---

Figure 50 • XOR3

| Input   | Output |
|---------|--------|
| A, B, C | Y      |

**Truth Table**

| A | B | C | Y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 0 | 1 | 0 | 1 |
| 1 | 1 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 1 | 1 | 1 |

## XOR4

4-input XOR

---



Figure 51 • XOR4

---

| Input      | Output |
|------------|--------|
| A, B, C, D | Y      |

### Truth Table

| A | B | C | D | Y |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 1 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 0 | 1 | 1 | 1 |
| 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 | 0 |

## XOR8

8-input XOR

This macro uses two logic modules.

---



Figure 52 • XOR8

---

| Input                  | Output |
|------------------------|--------|
| A, B, C, D, E, F, G, H | Y      |

### Truth Table

If you have an odd number of inputs that are High, the output is High (1).

If you have an even number of inputs that are High, the output is Low (0).

For example:

| A | B | C | D | E | F | G | H | Y |
|---|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |

## UJTAG

The UJTAG macro is a special purpose macro. It allows access to the user JTAG circuitry on board the chip. You must instantiate a UJTAG macro in your design if you plan to make use of the user JTAG feature. The TMS, TDI, TCK, TRSTB and TDO pins of the macro must be connected to top level ports of the design.



**Figure 53 • UJTAG**

**Table 6: Ports and Descriptions**

| Port       | Direction | Polarity | Description                                                                                                                                                                                    |
|------------|-----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UIREG[7:0] | Output    | —        | This 8-bit bus carries the contents of the JTAG instruction register of each device. Instruction values 16 to 127 are not reserved and can be employed as user-defined instructions            |
| URSTB      | Output    | Low      | URSTB is an Active Low signal and is asserted when the TAP controller is in Test-Logic-Reset mode. URSTB is asserted at power-up, and a power-on reset signal resets the TAP controller state. |
| UTDI       | Output    | —        | This port is directly connected to the TAP's TDI signal                                                                                                                                        |
| UTDO       | Input     | —        | This port is the user TDO output. Inputs to the UTDO port are sent to the TAP TDO output MUX when the IR address is in user range.                                                             |
| UDRSH      | Output    | High     | Active High signal enabled in the Shift_DR_TAP state.                                                                                                                                          |
| UDRCAP     | Output    | High     | Active High signal enabled in the Capture_DR_TAP state.                                                                                                                                        |
| UDRCK      | Output    | —        | This port is directly connected to the TAP's TCK signal.                                                                                                                                       |
| UDRUPD     | Output    | High     | Active High signal enabled in the Update_DR_TAP state.                                                                                                                                         |

**Table 6: Ports and Descriptions (Continued)**

| <b>Port</b> | <b>Direction</b> | <b>Polarity</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                               |
|-------------|------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TCK         | Input            | —               | Test Clock. Serial input for JTAG boundary scan, ISP, and UJTAG. The TCK pin does not have an internal pull-up/pull-down resistor. Connect TCK to GND or +3.3 V through a resistor (500-1 KΩ) placed close to the FPGA pin to prevent totem-pole current on the input buffer and TMS from entering into an undesired state. If JTAG is not used, connect it to GND.              |
| TDI         | Input            | —               | Test Data In. Serial input for JTAG boundary scan. There is an internal weak pull-up resistor on the TDI pin.                                                                                                                                                                                                                                                                    |
| TDO         | Output           | —               | Test Data Out. Serial output for JTAG boundary scan. The TDO pin does not have an internal pull-up/pull-down resistor.                                                                                                                                                                                                                                                           |
| TMS         | Input            | —               | Test mode select. The TMS pin controls the use of the IEEE1532 boundary scan pins (TCK, TDI, TDO, and TRST). There is an internal weak pull-up resistor on the TMS pin.                                                                                                                                                                                                          |
| TRSTB       | Input            | Low             | Test reset. The TRSTB pin is an active low input. It synchronously initializes (or resets) the boundary scan circuitry. There is an internal weak pull-up resistor on the TRSTB pin.<br>To hold the JTAG in reset mode and prevent it from entering into undesired states in critical applications, connect TRSTB to GND through a 1 KΩ resistor (placed close to the FPGA pin). |

## BIBUF

Bidirectional Buffer



**Figure 54 • BIBUF**

| Input     | Output |
|-----------|--------|
| D, E, PAD | PAD, Y |

**Truth Table**

| MODE   | E | D | PAD | Y   |
|--------|---|---|-----|-----|
| OUTPUT | 1 | D | D   | D   |
| INPUT  | 0 | X | Z   | X   |
| INPUT  | 0 | X | PAD | PAD |

## BIBUF\_DIFF

Bidirectional Buffer, Differential I/O



**Figure 55 • BIBUF\_DIFF**

| Input            | Output        |
|------------------|---------------|
| D, E, PADP, PADN | PADP, PADN, Y |

**Truth Table**

| MODE   | E | D | PADP | PADN | Y |
|--------|---|---|------|------|---|
| OUTPUT | 1 | 0 | 0    | 1    | 0 |
| OUTPUT | 1 | 1 | 1    | 0    | 1 |
| INPUT  | 0 | X | Z    | Z    | X |
| INPUT  | 0 | X | 0    | 0    | X |
| INPUT  | 0 | X | 1    | 1    | X |
| INPUT  | 0 | X | 0    | 1    | 0 |
| INPUT  | 0 | X | 1    | 0    | 1 |

## CLKBIBUF

Bidirectional Buffer with Input to global network



**Figure 56 • CLKBIBUF**

| Input     | Output |
|-----------|--------|
| D, E, PAD | PAD, Y |

### Truth Table

| D | E | PAD | Y |
|---|---|-----|---|
| X | 0 | Z   | X |
| X | 0 | 0   | 0 |
| X | 0 | 1   | 1 |
| 0 | 1 | 0   | 0 |
| 1 | 1 | 1   | 1 |

## CLKBUF

Input Buffer to global network



**Figure 57 • CLKBUF**

| Input | Output |
|-------|--------|
| PAD   | Y      |

### Truth Table

| PAD | Y |
|-----|---|
| 0   | 0 |
| 1   | 1 |

## CLKBUF\_DIFF

Differential I/O macro to global network, Differential I/O



---

**Figure 58 • INBUF\_DIFF**

| Input      | Output |
|------------|--------|
| PADP, PADN | Y      |

### **Truth Table**

| PADP | PADN | Y |
|------|------|---|
| Z    | Z    | Y |
| 0    | 0    | X |
| 1    | 1    | X |
| 0    | 1    | 0 |
| 1    | 0    | 1 |

## INBUF

Input Buffer



**Figure 59 • INBUF**

| Input | Output |
|-------|--------|
| PAD   | Y      |

### Truth Table

| PAD | Y |
|-----|---|
| Z   | X |
| 0   | 0 |
| 1   | 1 |

## INBUF\_DIFF

Input Buffer, Differential I/O



**Figure 60 • INBUF\_DIFF**

| Input      | Output |
|------------|--------|
| PADP, PADN | Y      |

### Truth Table

| PADP | PADN | Y |
|------|------|---|
| Z    | Z    | X |
| 0    | 0    | X |
| 1    | 1    | X |
| 0    | 1    | 0 |
| 1    | 0    | 1 |

## OUTBUF

Output buffer

---



---

Figure 61 • OUTBUF

| Input | Output |
|-------|--------|
| D     | PAD    |

**Truth Table**

| D | PAD |
|---|-----|
| 0 | 0   |
| 1 | 1   |

## OUTBUF\_DIFF

Output buffer, Differential I/O

---



---

Figure 62 • OUTBUF\_DIFF

| Input | Output     |
|-------|------------|
| D     | PADP, PADN |

**Truth Table**

| D | PADP | PADN |
|---|------|------|
| 0 | 0    | 1    |
| 1 | 1    | 0    |

## TRIBUFF

Tristate output buffer

---



*Figure 63 • TRIBUFF*

| Input | Output |
|-------|--------|
| D, E  | PAD    |

### ***Truth Table***

| D | E | PAD |
|---|---|-----|
| X | 0 | Z   |
| D | 1 | D   |

## TRIBUFF\_DIFF

Tristate output buffer, Differential I/O

---



*Figure 64 • TRIBUFF\_DIFF*

| Input | Output     |
|-------|------------|
| D, E  | PADP, PADN |

### ***Truth Table***

| D | E | PADP | PADN |
|---|---|------|------|
| X | 0 | Z    | Z    |
| 0 | 1 | 0    | 1    |
| 1 | 1 | 1    | 0    |

## DDR\_IN

Input DDR Register; input D must be connected to an I/O.



**Figure 65 • DDR\_IN**

| Input                         | Output |
|-------------------------------|--------|
| D, CLK, EN, ALn, ADn, SLn, SD | QR, QF |

| Input |                                | Output |                  |
|-------|--------------------------------|--------|------------------|
| Name  | Function                       | Name   | Function         |
| D     | Data                           | QR     | Q (Rising Edge)  |
| CLK   | Clock                          | QF     | Q (Falling Edge) |
| EN    | Enable                         |        |                  |
| ALn   | Asynchronous Load (Active Low) |        |                  |
| ADn*  | Asynchronous Data (Active Low) |        |                  |
| SLn   | Synchronous Load (Active Low)  |        |                  |
| SD*   | Synchronous Data               |        |                  |

**\*Note:** ADn and SD are static inputs defined at design time and need to be tied to 0 or 1.

### Truth Table

| ALn | CLK        | EN | SLn | df<br>(Internal<br>Signal) | QR <sub>(n+1)</sub> | QF <sub>(n+1)</sub> |
|-----|------------|----|-----|----------------------------|---------------------|---------------------|
| 1   | Not rising | X  | X   | df                         | QR <sub>n</sub>     | QF <sub>n</sub>     |
| 1   | ↑          | 0  | X   | df                         | QR <sub>n</sub>     | QF <sub>n</sub>     |
| 1   | ↑          | 1  | 1   | df                         | D                   | df <sub>n</sub>     |
| 1   | ↓          | X  | X   | D                          | QR <sub>n</sub>     | QF <sub>n</sub>     |
| 1   | ↑          | 1  | 0   | df                         | SD                  | SD                  |
| 0   | X          | X  | X   | !AD <sub>n</sub>           | !AD <sub>n</sub>    | !AD <sub>n</sub>    |



---

Figure 66 • DDR\_IN

## DDR\_OUT

The DDR\_OUT macro is an output DDR cell and is available for pre-layout simulation. It consists of two SLE macros. The output Q must be connected to an I/O.



**Figure 67 • DDR\_OUT**

| Input             |                                | Output |
|-------------------|--------------------------------|--------|
| Name              | Function                       |        |
| DR                | Data (Rising Edge)             | Q      |
| DF                | Data (Falling Edge)            |        |
| CLK               | Clock                          |        |
| EN                | Enable                         |        |
| AL <sub>n</sub>   | Asynchronous Load (Active Low) |        |
| AD <sub>n</sub> * | Asynchronous Data (Active Low) |        |
| SL <sub>n</sub>   | Synchronous Load (Active Low)  |        |
| SD*               | Synchronous Data               |        |

**\*Note:** ADn and SD are static inputs defined at design time and need to be tied to 0 or 1.

### Truth Table

| AL <sub>n</sub> | CLK        | EN | SL <sub>n</sub> | Q <sub>n+1</sub> |
|-----------------|------------|----|-----------------|------------------|
| 1               | not rising | X  | X               | Q <sub>n</sub>   |
| 1               | ↑          | 0  | X               | Q <sub>n</sub>   |
| 1               | ↑          | 1  | 1               | DR <sub>n</sub>  |

| <b>ALn</b> | <b>CLK</b> | <b>EN</b> | <b>SLn</b> | <b>Q<sub>n+1</sub></b> |
|------------|------------|-----------|------------|------------------------|
| 1          | ↓          | 1         | 1          | DF <sub>n</sub>        |
| 1          | ↑          | 1         | 0          | SD                     |
| 0          | X          | X         | X          | !AD <sub>n</sub>       |

## RAM1K18

The RAM1K18 block contains 18,432 memory bits and is a true dual-port memory. The RAM1K18 memory can also be configured in two-port mode. All read/write operations to the RAM1K18 memory are synchronous. To improve the read data delay, an optional pipeline register at the output is available. A feed-through write mode is also available to enable immediate access to the write data. The RAM1K18 memory has two data ports which can be independently configured in any combination shown below.

1. Dual-Port RAM with the following configurations:

- 1Kx18, 1Kx16
- 2Kx9, 2Kx8
- 4Kx4
- 8Kx2
- 16Kx1

2. Two-Port RAM with the following configurations:

- 512x36, 512x32
- 1Kx18, 1Kx16
- 2Kx9, 2Kx8
- 4Kx4
- 8Kx2
- 16Kx1

The main features of the RAM1K18 memory block are as follows:

- A RAM1K18 block has 18,432 bits.
- A RAM1K18 block provides two independent data ports A and B.
- RAM1K18 has a true dual-port mode, for which both ports have word widths less than or equal to 18 bits.
- In true dual-port mode, each port can be independently configured to any of the following depth/width: 1Kx18, 1Kx16, 2Kx9, 2Kx8, 4Kx4, 8Kx2, and 16Kx1.
- The widths of each port can be different, but one needs to be a multiple of the other. There are 29 unique combinations of true dual-port aspect ratios:
  - 1Kx18/1Kx18, 1Kx18/2Kx9,
  - 1Kx16/1Kx16, 1Kx16/2Kx8, 1Kx16/4Kx4, 1Kx16/8Kx2, 1Kx16/16Kx1,
  - 2Kx9/1Kx18, 2Kx9/2Kx9,
  - 2Kx8/1Kx16, 2Kx8/2Kx8, 2Kx8/4Kx4, 2Kx8/8Kx2, 2Kx8/16Kx1,
  - 4Kx4/1Kx16, 4Kx4/2Kx8, 4Kx4/4Kx4, 4Kx4/8Kx2, 4Kx4/16Kx1,
  - 8Kx2/1Kx16, 8Kx2/2Kx8, 8Kx2/4Kx4, 8Kx2/8Kx2, 8Kx2/16Kx1,
  - 16Kx1/1Kx16, 16Kx1/2Kx8, 16Kx1/4Kx4, 16Kx1/8Kx2, 16Kx1/16Kx1
- RAM1K18 also has a two-port mode. In this case, Port A will become the read port and Port B becomes the write port.
- In two-port mode, each port can be independently configured to any of the following depth/width: 512x36, 512x32, 1Kx18, 1Kx16, 2Kx9, 2Kx8, 4Kx4, 8Kx2 and 16Kx1.
- The widths of each port can be different, but one needs to be a multiple of the other. There are 45 unique combinations of two-port aspect ratios:
  - 512x36/512x36, 512x36/1Kx18, 512x36/2Kx9,
  - 512x32/512x32, 512x32/1Kx16, 512x32/2Kx8, 512x32/4Kx4, 512x32/8Kx2, 512x32/16Kx1,
  - 1Kx18/512x36, 1Kx18/1Kx18, 1Kx18/2Kx9,
  - 1Kx16/512x32, 1Kx16/1Kx16, 1Kx16/2Kx8, 1Kx16/4Kx4, 1Kx16/8Kx2, 1Kx16/16Kx1,
  - 2Kx9/512x36, 2Kx9/1Kx18, 2Kx9/2Kx9,
  - 2Kx8/512x32, 2Kx8/1Kx16, 2Kx8/2Kx8, 2Kx8/4Kx4, 2Kx8/8Kx2, 2Kx8/16Kx1,
  - 4Kx4/512x32, 4Kx4/1Kx16, 4Kx4/2Kx8, 4Kx4/4Kx4, 4Kx4/8Kx2, 4Kx4/16Kx1,
  - 8Kx2/512x32, 8Kx2/1Kx16, 8Kx2/2Kx8, 8Kx2/4Kx4, 8Kx2/8Kx2, 8Kx2/16Kx1,

- 16Kx1/512x32, 16Kx1/1Kx16, 16Kx1/2Kx8, 16Kx1/4Kx4, 16Kx1/8Kx2, 16Kx1/16Kx1
- RAM1K18 performs synchronous operation for setting up the address as well as writing and reading the data. The address, data, block port select and write-enable inputs are registered.
- An optional pipeline register with a separate enable, synchronous-reset and asynchronous-reset is available at the read data port to improve the clock-to-out delay.
- There is an independent clock for each port. The memory will be triggered at the rising edge of the clock.
- The true dual-port mode supports an optional feed-through write mode, where the write data also appears on the corresponding read data port.
- Read from both ports at the same location is allowed.
- Read and write on the same location at the same time results in unknown data to be read. **There is no collision prevention or detection.** However, correct data is expected to be written into the memory.

Figure 68 shows a simplified block diagram of the RAM1K18 memory block and Table 6 gives the port descriptions.

The simplified block diagram illustrates the two independent data ports, the pipeline registers, and the feed-through multiplexors.



**Figure 68 • Simplified Block Diagram of RAM1K18**

**Table 6 • Port RAM List for RAM1K18**

| Pin Name     | Pin Direction | Type    | Description          | Polarity |
|--------------|---------------|---------|----------------------|----------|
| A_ADDR[13:0] | Input         | Dynamic | Port A address       |          |
| A_BLK[2:0]   | Input         | Dynamic | Port A block selects | High     |
| A_CLK        | Input         | Dynamic | Port A clock         | Rising   |
| A_DIN[17:0]  | Input         | Dynamic | Port A write data    |          |
| A_DOUT[17:0] | Output        | Dynamic | Port A read data     |          |

**Table 6 • Port RAM List for RAM1K18**

| <b>Pin Name</b> | <b>Pin Direction</b> | <b>Type</b> | <b>Description</b>                                          | <b>Polarity</b> |
|-----------------|----------------------|-------------|-------------------------------------------------------------|-----------------|
| A_WEN[1:0]      | Input                | Dynamic     | Port A write enables (per byte)                             | High            |
| A_WIDTH[2:0]    | Input                | Static      | Port A width/depth mode select                              |                 |
| A_WMODE         | Input                | Static      | Port A feed-through write select                            | High            |
| A_ARST_N        | Input                | Dynamic     | Port A reset (must be tied to 1)                            | Low             |
| A_DOUT_LAT      | Input                | Static      | Port A pipeline register select                             | Low             |
| A_DOUT_ARST_N   | Input                | Dynamic     | Port A pipeline register asynchronous reset                 | Low             |
| A_DOUT_CLK      | Input                | Dynamic     | Port A pipeline register clock (must be tied to A_CLK or 1) | Rising          |
| A_DOUT_EN       | Input                | Dynamic     | Port A pipeline register enable                             | High            |
| A_DOUT_SRST_N   | Input                | Dynamic     | Port A pipeline register synchronous reset                  | Low             |
| <hr/>           |                      |             |                                                             |                 |
| B_ADDR[13:0]    | Input                | Dynamic     | Port B address                                              |                 |
| B_BLK[2:0]      | Input                | Dynamic     | Port B block selects                                        | High            |
| B_CLK           | Input                | Dynamic     | Port B clock                                                | Rising          |
| B_DIN[17:0]     | Input                | Dynamic     | Port B write data                                           |                 |
| B_DOUT[17:0]    | Output               | Dynamic     | Port B read data                                            |                 |
| B_WEN[1:0]      | Input                | Dynamic     | Port B write enables (per byte)                             | High            |
| B_WIDTH[2:0]    | Input                | Static      | Port B width/depth mode select                              |                 |
| B_WMODE         | Input                | Static      | Port B Feed-through write select                            | High            |
| B_ARST_N        | Input                | Dynamic     | Port B reset (must be tied to 1)                            | Low             |
| B_DOUT_LAT      | Input                | Static      | Port B pipeline register select                             | Low             |
| B_DOUT_ARST_N   | Input                | Dynamic     | Port B pipeline register asynchronous reset                 | Low             |
| B_DOUT_CLK      | Input                | Dynamic     | Port B pipeline register clock (must be tied to B_CLK or 1) | Rising          |
| B_DOUT_EN       | Input                | Dynamic     | Port B pipeline register enable                             | High            |
| B_DOUT_SRST_N   | Input                | Dynamic     | Port B pipeline register synchronous reset                  | Low             |
| <hr/>           |                      |             |                                                             |                 |
| A_EN            | Input                | Static      | Port A power down (must be tied to 1)                       | Low             |
| B_EN            | Input                | Static      | Port B power down (must be tied to 1)                       | Low             |
| SII_LOCK        | Input                | Static      | Lock access to SII                                          | High            |
| BUSY            | Output               | Dynamic     | Busy signal from SII                                        | High            |

**Note:** Static inputs are defined at design time and need to be tied to 0 or 1.

## Signal Descriptions for RAM1K18

### A\_WIDTH and B\_WIDTH

Table 7 lists the width/depth mode selections for each port. Two-port mode is in effect when the width of at least one port is 36, and A\_WIDTH indicates the read width while B\_WIDTH indicates the write width. Also, when the write width is 36, the read width must also be 36.

**Table 7 • Width/Depth Mode Selection**

| Depth x Width                | A_WIDTH/B_WIDTH |
|------------------------------|-----------------|
| 16Kx1                        | 000             |
| 8Kx2                         | 001             |
| 4Kx4                         | 010             |
| 2Kx8, 2Kx9                   | 011             |
| 1Kx16, 1Kx18                 | 100             |
| 512x32, 512x36<br>(Two-port) | 101<br>11x      |

### A\_WEN and B\_WEN

Table 8 lists the write/read control signals for each port. Two-port mode is in effect when the width of at least one port is 36, and read operation is always enabled. Also, when the write width is 36, both A\_WEN and B\_WEN must be static.

**Table 8 • Write/Read Operation Select**

| Depth x Width                                     | A_WEN/B_WEN | Result                    |
|---------------------------------------------------|-------------|---------------------------|
| 16Kx1, 8Kx2, 4Kx4,<br>2Kx8, 2Kx9,<br>1Kx16, 1Kx18 | 00          | Perform a read operation  |
| 16Kx1,<br>8Kx2,<br>4Kx4,<br>2Kx8,<br>2Kx9         | 01          | Perform a write operation |
| 1Kx16                                             | 01          | Write [7:0]               |
|                                                   | 10          | Write [16:9]              |
|                                                   | 11          | Write [16:9], [7:0]       |
| 1Kx18                                             | 01          | Write [8:0]               |
|                                                   | 10          | Write [17:9]              |
|                                                   | 11          | Write [17:0]              |

**Table 8 • Write/Read Operation Select**

| Depth x Width              | A_WEN/B_WEN  | Result            |
|----------------------------|--------------|-------------------|
| 512x32<br>(Two-port write) | B_WEN[0] = 1 | Write B_DIN[7:0]  |
|                            | B_WEN[1] = 1 | Write B_DIN[16:9] |
|                            | A_WEN[0] = 1 | Write A_DIN[7:0]  |
|                            | A_WEN[1] = 1 | Write A_DIN[16:9] |
| 512x36<br>(Two-port write) | B_WEN[0] = 1 | Write B_DIN[8:0]  |
|                            | B_WEN[1] = 1 | Write B_DIN[17:9] |
|                            | A_WEN[0] = 1 | Write A_DIN[8:0]  |
|                            | A_WEN[1] = 1 | Write A_DIN[17:9] |

### **A\_ADDR and B\_ADDR**

**Table 9** address buses for the two ports. Fourteen bits are needed to address the 16K independent locations in x1 mode. In wider modes, fewer address bits are used. The required bits are MSB justified and unused LSB bits must be tied to 0. A\_ADDR is synchronized by A\_CLK while B\_ADDR is synchronized to B\_CLK. Two-port mode is in effect when the width of at least one port is 36, and A\_ADDR provides the read address while B\_ADDR provides the write address.

**Table 9 • Address Bus Used and Unused Bits**

| Depth x Width                | A_ADDR/B_ADDR |                                    |
|------------------------------|---------------|------------------------------------|
|                              | Used Bits     | Unused Bits<br>(must be tied to 0) |
| 16Kx1                        | [13:0]        | None                               |
| 8Kx2                         | [13:1]        | [0]                                |
| 4Kx4                         | [13:2]        | [1:0]                              |
| 2Kx8, 2Kx9                   | [13:3]        | [2:0]                              |
| 1Kx16, 1Kx18                 | [13:4]        | [3:0]                              |
| 512x32,<br>512x36 (Two-port) | [13:5]        | [4:0]                              |

## A\_DIN and B\_DIN

**Table 10** lists the data input buses for the two ports. The required bits are LSB justified and unused MSB bits must be tied to 0. Two-port mode is in effect when the width of at least one port is 36, and A\_DIN provides the MSB of the write data while B\_DIN provides the LSB of the write data.

**Table 10 • Data Input Buses Used and Unused Bits**

| Depth x Width              | A_DIN/B_DIN                                                                                     |                                                |
|----------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------------|
|                            | Used Bits                                                                                       | Unused Bits<br>(must be tied to 0)             |
| 16Kx1                      | [0]                                                                                             | [17:1]                                         |
| 8Kx2                       | [1:0]                                                                                           | [17:2]                                         |
| 4Kx4                       | [3:0]                                                                                           | [17:4]                                         |
| 2Kx8                       | [7:0]                                                                                           | [17:8]                                         |
| 2Kx9                       | [8:0]                                                                                           | [17:9]                                         |
| 1Kx16                      | [16:9] is [15:8]<br>[7:0] is [7:0]                                                              | [17]<br>[8]                                    |
| 1Kx18                      | [17:0]                                                                                          | None                                           |
| 512x32<br>(Two-port write) | A_DIN[16:9] is [31:24]<br>A_DIN[7:0] is [23:16]<br>B_DIN[16:9] is [15:8]<br>B_DIN[7:0] is [7:0] | A_DIN[17]<br>A_DIN[8]<br>B_DIN[17]<br>B_DIN[8] |
| 512x36<br>(Two-port write) | A_DIN[17:0] is [35:18]<br>B_DIN[17:0] is [17:0]                                                 | None                                           |

## A\_DOUT and B\_DOUT

**Table 11** lists the data output buses for the two ports. The required bits are LSB justified. Two-port mode is in effect when the width of at least one port is 36, and A\_DOUT provides the MSB of the read data while B\_DOUT provides the LSB of the read data.

**Table 11 • Data Output Buses Used and Unused Bits**

| Depth x Width | A_DOUT/B_DOUT                      |             |
|---------------|------------------------------------|-------------|
|               | Used Bits                          | Unused Bits |
| 16Kx1         | [0]                                | [17:1]      |
| 8Kx2          | [1:0]                              | [17:2]      |
| 4Kx4          | [3:0]                              | [17:4]      |
| 2Kx8          | [7:0]                              | [17:8]      |
| 2Kx9          | [8:0]                              | [17:9]      |
| 1Kx16         | [16:9] is [15:8]<br>[7:0] is [7:0] | [17]<br>[8] |
| 1Kx18         | [17:0]                             | None        |

**Table 11 • Data Output Buses Used and Unused Bits**

| Depth x Width             | A_DOUT/B_DOUT                                                                                       |                                                    |
|---------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------|
|                           | Used Bits                                                                                           | Unused Bits                                        |
| 512x32<br>(Two-port read) | A_DOUT[16:9] is [31:24]<br>A_DOUT[7:0] is [23:16]<br>B_DOUT[16:9] is [15:8]<br>B_DOUT[7:0] is [7:0] | A_DOUT[17]<br>A_DOUT[8]<br>B_DOUT[17]<br>B_DOUT[8] |
| 512x36<br>(Two-port read) | A_DOUT[17:0] is [35:18]<br>B_DOUT[17:0] is [17:0]                                                   | None                                               |

### **A\_BLK and B\_BLK**

Table 12 lists the block port select control signals for the two ports. A\_BLK is synchronized by A\_CLK while B\_BLK is synchronized to B\_CLK. Two-port mode is in effect when the width of at least one port is 36, and A\_BLK controls the read operation while B\_BLK controls the write operation

**Table 12 • Block Port Select**

| Block Port Select Signal | Value            | Result                                                                                                                                                     |
|--------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A_BLK[2:0]               | 111              | Perform read or write operation on Port A. In 36 width mode, perform a read operation from both ports A and B                                              |
| A_BLK[2:0]               | Any one bit is 0 | No operation in memory from Port A. Port A read data will be forced to 0. In 36 width mode, the read data from both ports A and B will be forced to 0.     |
| B_BLK[2:0]               | 111              | Perform read or write operation on Port B. In 36 width mode, perform a write operation to both ports A and B.                                              |
| B_BLK[2:0]               | Any one bit is 0 | No operation in memory from Port B. Port B read data will be forced to 0, unless it is a 36 width mode and write operation to both ports A and B is gated. |

### **A\_WMODE and B\_WMODE**

In true dual-port write mode, each port has a feed-through write option:

- Logic 0 = Read data port holds the previous value.
- Logic 1 = Feed-through, i.e. write data appears on the corresponding read data port. This setting is invalid when the width of at least one port is 36 and the two-port mode is in effect.

### **A\_CLK and B\_CLK**

All signals in ports A and B are synchronous to the corresponding port clock. All address, data, block port select and write enable inputs must be set up before the rising edge of the clock. The read or write operation begins with the rising edge. Two-port mode is in effect when the width of at least one port is 36, and A\_CLK provides the read clock while B\_CLK provides the write clock.

#### **A\_DOUT\_LAT and B\_DOUT\_LAT**

#### **A\_DOUT\_CLK and B\_DOUT\_CLK**

#### **A\_DOUT\_ARST\_N and B\_DOUT\_ARST\_N**

#### **A\_DOUT\_EN and B\_DOUT\_EN**

#### **A\_DOUT\_SRST\_N and B\_DOUT\_SRST\_N**

The A\_DOUT\_LAT and B\_DOUT\_LAT signals select the pipeline registers for the respective port. Two-port mode is in effect when the width of at least one port is 36, and the A\_DOUT register signals control the MSB of the read data while the B\_DOUT register signals control the LSB of the read data.

The pipeline registers have rising edge clock inputs for each port, which must be tied to the respective port clock when used. When the pipeline registers are not being used, they are forced into latch mode and the clock signals should be tied to 1, which makes them transparent.

[Table 13](#) describes the functionality of the control signals on the A\_DOUT and B\_DOUT pipeline registers.

**Table 13 • Truth Table for A\_DOUT and B\_DOUT Registers**

| <u>_ARST_N</u> | <u>_LAT</u> | <u>_CLK</u> | <u>_EN</u> | <u>_SRST_N</u> | <b>D</b> | <b>Q<sub>n+1</sub></b> |
|----------------|-------------|-------------|------------|----------------|----------|------------------------|
| 0              | X           | X           | X          | X              | X        | 0                      |
| 1              | 0           | Not rising  | X          | X              | X        | Q <sub>n</sub>         |
| 1              | 0           | ↑           | 0          | X              | X        | Q <sub>n</sub>         |
| 1              | 0           | ↑           | 1          | 0              | X        | 0                      |
| 1              | 0           | ↑           | 1          | 1              | D        | D                      |
| 1              | 1           | 0           | X          | X              | X        | Q <sub>n</sub>         |
| 1              | 1           | 1           | 0          | X              | X        | Q <sub>n</sub>         |
| 1              | 1           | 1           | 1          | 0              | X        | 0                      |
| 1              | 1           | 1           | 1          | 1              | D        | D                      |

### **A\_EN and B\_EN**

These are active low, power down configuration bits for each port. They must be tied to 1.

### **A\_ARST\_N and B\_ARST\_N**

Always tie these signals to 1.

### **SII\_LOCK**

Control signal, when 1 locks the entire RAM1K18 memory from being accessed by the SII.

### **BUSY**

This output indicates that the RAM1K18 memory is being accessed by the SII.

## RAM64x18

The RAM64x18 block contains 1,152 memory bits and is a three-port memory providing one write port and two read ports. Write operations to the RAM64x18 memory are synchronous. Read operations can be asynchronous or synchronous for either setting up the address and/or reading out the data. Enabling synchronous operation at the read address port improves setup timing for the read address and its enable signals. Enabling synchronous operation at the read data port improves clock-to-out delay. Each data port on the RAM64x18 memory can be independently configured in any combination shown below.

- 64x18, 64x16
- 128x9, 128x8
- 256x4
- 512x2
- 1Kx1

The main features of the RAM64x18 memory block are as follows

- There are two independent read data ports A and B, and one write data port C.
- The write operation is always synchronous. The write address, write data, C block port select and write enable inputs are registered.
- For both read data ports, setting up the address can be synchronous or asynchronous.
- The two read data ports have address registers with a separate enable, synchronous-reset and asynchronous-reset for synchronous mode operation, which can also be configured to be transparent latches for asynchronous mode operation.
- The two read data ports have output registers with a separate enable, synchronous-reset and asynchronous-reset for pipeline mode operation, which can also be configured to be transparent latches for asynchronous mode operation.
- Therefore, there are four read operation modes for ports A and B:
  - Synchronous read address without pipeline registers (sync-async)
  - Synchronous read address with pipeline registers (sync-sync)
  - Asynchronous read address without pipeline registers (async-async)
  - Asynchronous read address with pipeline registers (async-sync)
- Each data port on the RAM64x18 memory can be independently configured in any of the following combinations: 64x18, 64x16, 128x9, 128x8, 256x4, 512x2, and 1Kx1.
- The widths of each port can be different, but they need to be multiples of one another.
- There is an independent clock for each port. The memory will be triggered at the rising edge of the clock.
- Read from both ports A and B at the same location is allowed.
- Read and write on the same location at the same time results in unknown data to be read. **There is no collision prevention or detection.** However, correct data is expected to be written into the memory.

Figure 69 shows a simplified block diagram of the RAM64x18 memory block and Table 14 gives the port descriptions.

The simplified block diagram illustrates the three independent read/write ports and the pipeline registers on the read port.



**Figure 69 • Simplified Block Diagram of RAM64x18**

**Table 14 • Port List for RAM64x18**

| Pin Name      | Pin Direction | Type    | Description                                 | Polarity |
|---------------|---------------|---------|---------------------------------------------|----------|
| A_ADDR[9:0]   | Input         | Dynamic | Port A address                              |          |
| A_BLK[1:0]    | Input         | Dynamic | Port A block selects                        | High     |
| A_WIDTH[2:0]  | Input         | Static  | Port A width/depth mode selection           |          |
| A_DOUT[17:0]  | Output        | Dynamic | Port A read data                            |          |
| A_DOUT_ARST_N | Input         | Dynamic | Port A pipeline register asynchronous reset | Low      |
| A_DOUT_CLK    | Input         | Dynamic | Port A pipeline register clock              | Rising   |
| A_DOUT_EN     | Input         | Dynamic | Port A pipeline register enable             | High     |
| A_DOUT_LAT    | Input         | Static  | Port A pipeline register select             | Low      |
| A_DOUT_SRST_N | Input         | Dynamic | Port A pipeline register synchronous reset  | Low      |
| A_ADDR_CLK    | Input         | Dynamic | Port A address register clock               | Rising   |
| A_ADDR_EN     | Input         | Dynamic | Port A address register enable              | High     |
| A_ADDR_LAT    | Input         | Static  | Port A address register select              | Low      |
| A_ADDR_SRST_N | Input         | Dynamic | Port A address register synchronous reset   | Low      |
| A_ADDR_ARST_N | Input         | Dynamic | Port A address register asynchronous reset  | Low      |

**Table 14 • Port List for RAM64x18**

| Pin Name      | Pin Direction | Type    | Description                                 | Polarity |
|---------------|---------------|---------|---------------------------------------------|----------|
| B_ADDR[9:0]   | Input         | Dynamic | Port B address                              |          |
| B_BLK[1:0]    | Input         | Dynamic | Port B block selects                        | High     |
| B_WIDTH[2:0]  | Input         | Static  | Port B width/depth mode selection           |          |
| B_DOUT[17:0]  | Output        | Dynamic | Port B read data                            |          |
| B_DOUT_ARST_N | Input         | Dynamic | Port B pipeline register asynchronous reset | Low      |
| B_DOUT_CLK    | Input         | Dynamic | Port B pipeline register clock              | Rising   |
| B_DOUT_EN     | Input         | Dynamic | Port B pipeline register enable             | High     |
| B_DOUT_LAT    | Input         | Static  | Port B pipeline register select             | Low      |
| B_DOUT_SRST_N | Input         | Dynamic | Port B pipeline register synchronous reset  | Low      |
| B_ADDR_CLK    | Input         | Dynamic | Port B address register clock               | Rising   |
| B_ADDR_EN     | Input         | Dynamic | Port B address register enable              | High     |
| B_ADDR_LAT    | Input         | Static  | Port B address register select              | Low      |
| B_ADDR_SRST_N | Input         | Dynamic | Port B address register synchronous reset   | Low      |
| B_ADDR_ARST_N | Input         | Dynamic | Port B address register asynchronous reset  | Low      |
| C_ADDR[9:0]   | Input         | Dynamic | Port C address                              |          |
| C_CLK         | Input         | Dynamic | Port C clock                                | Rising   |
| C_DIN[17:0]   | Input         | Dynamic | Port C write data                           |          |
| C_WEN         | Input         | Dynamic | Port C write enable                         | High     |
| C_BLK[1:0]    | Input         | Dynamic | Port C block selects                        | High     |
| C_WIDTH[2:0]  | Input         | Static  | Port C width/depth mode selection           |          |
| A_EN          | Input         | Static  | Port A power down (must be tied to 1)       | Low      |
| B_EN          | Input         | Static  | Port B power down (must be tied to 1)       | Low      |
| C_EN          | Input         | Static  | Port C power down (must be tied to 1)       | Low      |
| SII_LOCK      | Input         | Static  | Lock access to SII                          | High     |
| BUSY          | Output        | Dynamic | Busy signal from SII                        | High     |

**Note:** Static inputs are defined at design time and need to be tied to 0 or 1.

## Signal Descriptions for RAM64x18

### **A\_WIDTH, B\_WIDTH and C\_WIDTH**

Table 15 lists the width/depth mode selections for each port.

**Table 15 • Width/Depth Mode Selection**

| Depth x Width | A_WIDTH/B_WIDTH/C_WIDTH |
|---------------|-------------------------|
| 1Kx1          | 000                     |
| 512x2         | 001                     |
| 256x4         | 010                     |
| 128x8, 128x9  | 011                     |
| 64x16, 64x18  | 1xx                     |

### **C\_WEN**

This is the write enable signal for port C.

## **A\_ADDR, B\_ADDR and C\_ADDR**

Table 16 lists the address buses for each port. 10 bits are required to address 1K independent locations in x1 mode. In wider modes, fewer address bits are used. The required bits are MSB justified and unused LSB bits must be tied to 0.

**Table 16 • Address Buses Used and Unused Bits**

| Depth x Width | A_ADDR/B_ADDR/C_ADDR |                                       |
|---------------|----------------------|---------------------------------------|
|               | Used Bits            | Unused Bits<br>(must be tied to zero) |
| 1Kx1          | [9:0]                | None                                  |
| 512x2         | [9:1]                | [0]                                   |
| 256x4         | [9:2]                | [1:0]                                 |
| 128x8, 128x9  | [9:3]                | [2:0]                                 |
| 64x16, 64x18  | [9:4]                | [3:0]                                 |

## **C\_DIN**

Table 17 lists the write data input for port C. The required bits are LSB justified and unused MSB bits must be tied to 0.

**Table 17 • Data Input Bus Used and Unused Bits**

| Depth x Width | C_DIN           |                                    |
|---------------|-----------------|------------------------------------|
|               | Used Bits       | Unused Bits<br>(must be tied to 0) |
| 1Kx1          | [0]             | [17:1]                             |
| 512x2         | [1:0]           | [17:2]                             |
| 256x4         | [3:0]           | [17:4]                             |
| 128x8         | [7:0]           | [17:8]                             |
| 128x9         | [8:0]           | [17:9]                             |
| 64x16         | [16:9]<br>[7:0] | [17]<br>[8]                        |
| 64x18         | [17:0]          | None                               |

## **A\_DOUT and B\_DOUT**

Table 18 lists the read data output buses for ports A and B. The required bits are LSB justified.

**Table 18 • Data Output Used and Unused Bits**

| <b>Depth x Width</b> | <b>A_DOUT/B_DOUT</b> |                    |
|----------------------|----------------------|--------------------|
|                      | <b>Used Bits</b>     | <b>Unused Bits</b> |
| 1Kx1                 | [0]                  | [17:1]             |
| 512x2                | [1:0]                | [17:2]             |
| 256x4                | [3:0]                | [17:4]             |
| 128x8                | [7:0]                | [17:8]             |
| 128x9                | [8:0]                | [17:9]             |
| 64x16                | [16:9] [7:0]         | [17] [8]           |
| 64x18                | [17:0]               | None               |

## **A\_BLK, B\_BLK and C\_BLK**

Table 19 lists the block port select control signals for the ports.

**Table 19 • Block Port Select**

| <b>Block Port Select Signal</b> | <b>Value</b>     | <b>Result</b>                                                    |
|---------------------------------|------------------|------------------------------------------------------------------|
| A_BLK[1:0]                      | Any one bit is 0 | Port A is not selected and its read data will be forced to zero. |
|                                 | 11               | Perform read operation from port A.                              |
| B_BLK[1:0]                      | Any one bit is 0 | Port B is not selected and its read data will be forced to zero. |
|                                 | 11               | Perform read operation from port B.                              |
| C_BLK[1:0]                      | Any one bit is 0 | Port C is not selected.                                          |
|                                 | 11               | Perform write operation to port C.                               |

## **C\_CLK**

All signals on port C are synchronous to this clock signal. All write address, write data, C block port select and write enable inputs must be set up before the rising edge of the clock. The write operation begins with the rising edge.

**A\_DOUT\_LAT, A\_ADDR\_LAT, B\_DOUT\_LAT and B\_ADDR\_LAT**

**A\_DOUT\_CLK, A\_ADDR\_CLK, B\_DOUT\_CLK and B\_ADDR\_CLK**

**A\_DOUT\_ARST\_N, A\_ADDR\_ARST\_N, B\_DOUT\_ARST\_N and B\_ADDR\_ARST\_N**

**A\_DOUT\_EN, A\_ADDR\_EN, B\_DOUT\_EN and B\_ADDR\_EN**

**A\_DOUT\_SRST\_N, A\_ADDR\_SRST\_N, B\_DOUT\_SRST\_N and B\_ADDR\_SRST\_N**

The \_LAT signals select the registers for the respective port.

The address and pipeline registers have rising edge clock inputs for ports A and B. When both the address and pipeline registers for a port are in use, their clock signals must be tied together. When the registers are not being used, they are forced into latch mode and the clock signals should be tied to 1, which makes them transparent.

**Table 20** describes the functionality of the control signals on the A\_ADDR, B\_ADDR, A\_DOUT and B\_DOUT registers.

**Table 20 • Truth Table for A\_ADDR, B\_ADDR, A\_DOUT and B\_DOUT Registers**

| <u>_ARST_N</u> | <u>_LAT</u> | <u>_CLK</u> | <u>_EN</u> | <u>_SRST_N</u> | <u>D</u> | <u>Q<sub>n+1</sub></u> |
|----------------|-------------|-------------|------------|----------------|----------|------------------------|
| 0              | X           | X           | X          | X              | X        | 0                      |
| 1              | 0           | Not rising  | X          | X              | X        | Q <sub>n</sub>         |
| 1              | 0           | ↑           | 0          | X              | X        | Q <sub>n</sub>         |
| 1              | 0           | ↑           | 1          | 0              | X        | 0                      |
| 1              | 0           | ↑           | 1          | 1              | D        | D                      |
| 1              | 1           | 0           | X          | X              | X        | Q <sub>n</sub>         |
| 1              | 1           | 1           | 0          | X              | X        | Q <sub>n</sub>         |
| 1              | 1           | 1           | 1          | 0              | X        | 0                      |
| 1              | 1           | 1           | 1          | 1              | D        | D                      |

### **A\_EN, B\_EN and C\_EN**

Active low, power down configuration bits for each port. They must be tied to 1.

### **SII\_LOCK**

Control signal, when 1 locks the entire RAM64X18 memory from being accessed by the SII.

### **BUSY**

Output indicates that the RAM64X18 memory is being accessed by the SII.

## MACC

18 bit x 18 bit multiply-accumulate MACC block

The MACC block can accumulate the current multiplication product with a previous result, a constant, a dynamic value, or a result from another MACC block. Each MACC block can also be configured to perform a Dot-product operation. All the signals of the MACC block (except CDIN and CDOUT) have optional registers.



Figure 70 • MACC Ports

**Table 21 • Ports**

| Port Name            | Direction | Type    | Polarity    | Description                                                                                                                                                                                                                                                                                                         |
|----------------------|-----------|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DOTP</b>          | Input     | Static  | High        | Dot-product mode.<br>When DOTP = 1, MACC block performs Dot-product of two pairs of 9-bit operands.<br>When DOTP = 0, it is called the normal mode.                                                                                                                                                                 |
| <b>SIMD</b>          | Input     | Static  |             | Reserved. Must be 0.                                                                                                                                                                                                                                                                                                |
|                      |           |         |             |                                                                                                                                                                                                                                                                                                                     |
| <b>CLK[1:0]</b>      | Input     | Dynamic | Rising edge | Input clocks. <ul style="list-style-type: none"> <li>• CLK[1] is the clock for A[17:9], B[17:9], C[43:18], P[43:18], OVFL_CARRYOUT, ARSHFT17, CDSEL, FDBKSEL and SUB registers.</li> <li>• CLK[0] is the clock for A[8:0], B[8:0], C[17:0], CARRYIN and P[17:0].</li> </ul> In normal mode, ensure CLK[1] = CLK[0]. |
|                      |           |         |             |                                                                                                                                                                                                                                                                                                                     |
| <b>A[17:0]</b>       | Input     | Dynamic | High        | Input data A.                                                                                                                                                                                                                                                                                                       |
| <b>A_BYPASS[1:0]</b> | Input     | Static  | High        | Bypass data A registers. <ul style="list-style-type: none"> <li>• A_BYPASS[1] is for A[17:9]. Connect to 1, if not registered.</li> <li>• A_BYPASS[0] is for A[8:0]. Connect to 1, if not registered.</li> </ul> In normal mode, ensure A_BYPASS[0] = A_BYPASS[1].                                                  |
| <b>A_ARST_N[1:0]</b> | Input     | Dynamic | Low         | Asynchronous reset for data A registers. <ul style="list-style-type: none"> <li>• A_ARST_N[1] is for A[17:9]. Connect to 1, if not registered.</li> <li>• A_ARST_N[0] is for A[8:0]. Connect to 1, if not registered.</li> </ul> In normal mode, ensure A_ARST_N[1] = A_ARST_N[0].                                  |
| <b>A_SRST_N[1:0]</b> | Input     | Dynamic | Low         | Synchronous reset for data A registers. <ul style="list-style-type: none"> <li>• A_SRST_N[1] is for A[17:9]. Connect to 1, if not registered.</li> <li>• A_SRST_N[0] is for A[8:0]. Connect to 1, if not registered.</li> </ul> In normal mode, ensure A_SRST_N[1] = A_SRST_N[0].                                   |

**Table 21 • Ports**

| <b>Port Name</b> | <b>Direction</b> | <b>Type</b> | <b>Polarity</b> | <b>Description</b>                                                                                                                                                                                                                                                                               |
|------------------|------------------|-------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A_EN[1:0]        | Input            | Dynamic     | High            | <p>Enable for data A registers.</p> <ul style="list-style-type: none"> <li>• A_EN[1] is for A[17:9]. Connect to 1, if not registered.</li> <li>• A_EN[0] is for A[8:0]. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure A_EN[1] = A_EN[0].</p>                             |
| B[17:0]          | Input            | Dynamic     | High            | Input data B.                                                                                                                                                                                                                                                                                    |
| B_BYPASS[1:0]    | Input            | Static      | High            | <p>Bypass data B registers.</p> <ul style="list-style-type: none"> <li>• B_BYPASS[1] is for B[17:9]. Connect to 1, if not registered.</li> <li>• B_BYPASS[0] is for B[8:0]. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure B_BYPASS[0] = B_BYPASS[1].</p>                 |
| B_ARST_N[1:0]    | Input            | Dynamic     | Low             | <p>Asynchronous reset for data B registers.</p> <ul style="list-style-type: none"> <li>• B_ARST_N[1] is for B[17:9]. Connect to 1, if not registered.</li> <li>• B_ARST_N[0] is for B[8:0]. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure B_ARST_N[1] = B_ARST_N[0].</p> |
| B_SRST_N[1:0]    | Input            | Dynamic     | Low             | <p>Synchronous reset for data B registers.</p> <ul style="list-style-type: none"> <li>• B_SRST_N[1] is for B[17:9]. Connect to 1, if not registered.</li> <li>• B_SRST_N[0] is for B[8:0]. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure B_SRST_N[1] = B_SRST_N[0].</p>  |
| B_EN[1:0]        | Input            | Dynamic     | High            | <p>Enable for data B registers.</p> <ul style="list-style-type: none"> <li>• B_EN[1] is for B[17:9]. Connect to 1, if not registered.</li> <li>• B_EN[0] is for B[8:0]. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure B_EN[1] = B_EN[0].</p>                             |
|                  |                  |             |                 |                                                                                                                                                                                                                                                                                                  |

**Table 21 • Ports**

| Port Name     | Direction | Type    | Polarity | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|-----------|---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P[43:0]       | Output    |         | High     | <p>Result data.<br/>Normal mode</p> <ul style="list-style-type: none"> <li><math>P = D + (\text{CARRYIN} + C) + (A * B)</math>, when SUB = 0</li> <li><math>P = D + (\text{CARRYIN} + C) - (A * B)</math>, when SUB = 1</li> </ul> <p>Dot-product mode</p> <ul style="list-style-type: none"> <li><math>P = D + (\text{CARRYIN} + C) + 512 * ((A_L * B_H) + (A_H * B_L))</math>, when SUB = 0</li> <li><math>P = D + (\text{CARRYIN} + C) - 512 * ((A_L * B_H) + (A_H * B_L))</math>, when SUB = 1</li> </ul> <p>Notation:</p> <ul style="list-style-type: none"> <li><math>A_L = A[8:0]</math>, <math>A_H = A[17:9]</math></li> <li><math>B_L = B[8:0]</math>, <math>B_H = B[17:9]</math></li> </ul> <p>Refer to <a href="#">Table 24 on page 77</a> to see how operand D is obtained from P, CDIN or 0.</p> |
| OVFL_CARRYOUT | Output    |         | High     | <p>Overflow or CarryOut</p> <ul style="list-style-type: none"> <li>Overflow when OVFL_CARRYOUT_SEL = 0<br/> <math>\text{OVFL\_CARRYOUT} = (\text{SUM}[45] \wedge \text{SUM}[44])   (\text{SUM}[44] \wedge \text{SUM}[43])</math></li> <li>CarryOut when OVFL_CARRYOUT_SEL = 1<br/> <math>\text{OVFL\_CARRYOUT} = C[43] \wedge D[43] \wedge \text{SUM}[44]</math></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P_BYPASS[1:0] | Input     | Static  | High     | <p>Bypass result P registers.</p> <ul style="list-style-type: none"> <li>P_BYPASS[1] is for P[43:18] and OVFL_CARRYOUT. Connect to 1, if not registered.</li> <li>P_BYPASS[0] is for P[17:0]. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure <math>P\_BYPASS[0] = P\_BYPASS[1]</math>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| P_ARST_N[1:0] | Input     | Dynamic | Low      | <p>Asynchronous reset for result P registers.</p> <ul style="list-style-type: none"> <li>P_ARST_N[1] is for P[43:18] and OVFL_CARRYOUT. Connect to 1, if not registered.</li> <li>P_ARST_N[0] is for P[17:0]. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure <math>P\_ARST\_N[1] = P\_ARST\_N[0]</math>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**Table 21 • Ports**

| Port Name     | Direction | Type    | Polarity | Description                                                                                                                                                                                                                                                                                                           |
|---------------|-----------|---------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P_SRST_N[1:0] | Input     | Dynamic | Low      | <p>Synchronous reset for result P registers.</p> <ul style="list-style-type: none"> <li>• P_SRST_N[1] is for P[43:18] and OVFL_CARRYOUT. Connect to 1, if not registered.</li> <li>• P_SRST_N[0] is for P[17:0]. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure P_SRST_N[1] = P_SRST_N[0].</p> |
| P_EN[1:0]     | Input     | Dynamic | High     | <p>Enable for result P registers.</p> <ul style="list-style-type: none"> <li>• P_EN[1] is for P[43:18] and OVFL_CARRYOUT. Connect to 1, if not registered.</li> <li>• P_EN[0] is for P[17:0]. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure P_EN[1] = P_EN[0].</p>                            |
| CDOU[43:0]    | Output    | Cascade | High     | <p>Cascade output of result P.</p> <p>CDOU is the same as P. The entire bus must either be dangling or drive an entire CDIN of another MACC block in cascaded mode.</p>                                                                                                                                               |
| CARRYIN       | Input     | Dynamic | High     | CarryIn for operand C.                                                                                                                                                                                                                                                                                                |
| C[43:0]       | Input     | Dynamic | High     | <p>Routed input for operand C.</p> <p>In Dot-product mode, connect C[8:0] to the CARRYIN.</p>                                                                                                                                                                                                                         |
| C_BYPASS[1:0] | Input     | Static  | High     | <p>Bypass data C registers.</p> <ul style="list-style-type: none"> <li>• C_BYPASS[1] is for C[43:18]. Connect to 1, if not registered.</li> <li>• C_BYPASS[0] is for C[17:0] and CARRYIN. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure C_BYPASS[0] = C_BYPASS[1].</p>                        |
| C_ARST_N[1:0] | Input     | Dynamic | Low      | <p>Asynchronous reset for data C registers.</p> <ul style="list-style-type: none"> <li>• C_ARST_N[1] is for C[43:18]. Connect to 1, if not registered.</li> <li>• C_ARST_N[0] is for C[17:0] and CARRYIN. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure C_ARST_N[1] = C_ARST_N[0].</p>        |

**Table 21 • Ports**

| Port Name       | Direction | Type    | Polarity | Description                                                                                                                                                                                                                                                                                                   |
|-----------------|-----------|---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_SRST_N[1:0]   | Input     | Dynamic | Low      | <p>Synchronous reset for data C registers.</p> <ul style="list-style-type: none"> <li>• C_SRST_N[1] is for C[43:18]. Connect to 1, if not registered.</li> <li>• C_SRST_N[0] is for C[17:0] and CARRYIN. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure C_SRST_N[1] = C_SRST_N[0].</p> |
| C_EN[1:0]       | Input     | Dynamic | High     | <p>Enable for data C registers.</p> <ul style="list-style-type: none"> <li>• C_EN[1] is for C[43:18]. Connect to 1, if not registered.</li> <li>• C_EN[0] is for C[17:0] and CARRYIN. Connect to 1, if not registered.</li> </ul> <p>In normal mode, ensure C_EN[1] = C_EN[0].</p>                            |
| CDIN[43:0]      | Input     | Cascade | High     | <p>Cascaded input for operand D. The entire bus must be driven by an entire CDOUT of another MACC block. In Dot-product mode the CDOUT must also be generated by a MACC block in Dot-product mode.</p> <p>Refer to <a href="#">Table 24 on page 77</a> to see how CDIN is propagated to operand D.</p>        |
| <hr/>           |           |         |          |                                                                                                                                                                                                                                                                                                               |
| ARSHFT17        | Input     | Dynamic | High     | <p>Arithmetic right-shift for operand D. When asserted, a 17-bit arithmetic right-shift is performed on operand D going into the accumulator.</p> <p>Refer to <a href="#">Table 24 on page 77</a> to see how operand D is obtained from P, CDIN or 0.</p>                                                     |
| ARSHFT17_BYPASS | Input     | Static  | High     | Bypass ARSHFT17 register. Connect to 1, if not registered.                                                                                                                                                                                                                                                    |
| ARSHFT17_AL_N   | Input     | Dynamic | Low      | <p>Asynchronous load for ARSHFT17 register. Connect to 1, if not registered.</p> <p>When asserted, ARSHFT17 register is loaded with ARSHFT17_AD.</p>                                                                                                                                                          |
| ARSHFT17_AD     | Input     | Static  | High     | Asynchronous load data for ARSHFT17 register.                                                                                                                                                                                                                                                                 |
| ARSHFT17_SL_N   | Input     | Dynamic | Low      | Synchronous load for ARSHFT17 register. Connect to 1, if not registered. See <a href="#">Table 22 on page 76</a> .                                                                                                                                                                                            |
| ARSHFT17_SD_N   | Input     | Static  | Low      | Synchronous load data for ARSHFT17 register. See <a href="#">Table 22 on page 76</a> .                                                                                                                                                                                                                        |
| ARSHFT17_EN     | Input     | Dynamic | High     | Enable for ARSHFT17 register. Connect to 1, if not registered. See <a href="#">Table 22 on page 76</a> .                                                                                                                                                                                                      |
| <hr/>           |           |         |          |                                                                                                                                                                                                                                                                                                               |

**Table 21 • Ports**

| Port Name      | Direction | Type    | Polarity | Description                                                                                                                                                                                                                                                                                                    |
|----------------|-----------|---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CDSEL</b>   | Input     | Dynamic | High     | Select CDIN for operand D.<br>When CDSEL = 1, propagate CDIN.<br>When CDSEL = 0, propagate 0 or P depending on FDBKSEL.<br>Refer to <a href="#">Table 22 on page 76</a> to see how operand D is obtained from P, CDIN or 0.                                                                                    |
| CDSEL_BYPASS   | Input     | Static  | High     | Bypass CDSEL register. Connect to 1, if not registered.                                                                                                                                                                                                                                                        |
| CDSEL_AL_N     | Input     | Dynamic | Low      | Asynchronous load for CDSEL register.<br>Connect to 1, if not registered.<br>When asserted, CDSEL register is loaded with CDSEL_AD.                                                                                                                                                                            |
| CDSEL_AD       | Input     | Static  | High     | Asynchronous load data for CDSEL register.                                                                                                                                                                                                                                                                     |
| CDSEL_SL_N     | Input     | Dynamic | Low      | Synchronous load for CDSEL register.<br>Connect to 1, if not registered. See <a href="#">Table 22 on page 76</a> .                                                                                                                                                                                             |
| CDSEL_SD_N     | Input     | Static  | Low      | Synchronous load data for CDSEL register.<br>See <a href="#">Table 22 on page 76</a> .                                                                                                                                                                                                                         |
| CDSEL_EN       | Input     | Dynamic | High     | Enable for CDSEL register. Connect to 1, if not registered. See <a href="#">Table 22 on page 76</a> .                                                                                                                                                                                                          |
| <hr/>          |           |         |          |                                                                                                                                                                                                                                                                                                                |
| <b>FDBKSEL</b> | Input     | Dynamic | High     | Select the feedback from P for operand D.<br>When FDBKSEL = 1, propagate the current value of result P register. Ensure P_BYPASS[1] = 0 and CDSEL = 0.<br>When FDBKSEL = 0, propagate 0. Ensure CDSEL = 0.<br>Refer to <a href="#">Table 24 on page 77</a> to see how operand D is obtained from P, CDIN or 0. |
| FDBKSEL_BYPASS | Input     | Static  | High     | Bypass FDBKSEL register. Connect to 1, if not registered.                                                                                                                                                                                                                                                      |
| FDBKSEL_AL_N   | Input     | Dynamic | Low      | Asynchronous load for FDBKSEL register.<br>Connect to 1, if not registered.<br>When asserted, FDBKSEL register is loaded with FDBKSEL_AD.                                                                                                                                                                      |
| FDBKSEL_AD     | Input     | Static  | High     | Asynchronous load data for FDBKSEL register.                                                                                                                                                                                                                                                                   |
| FDBKSEL_SL_N   | Input     | Dynamic | Low      | Synchronous load for FDBKSEL register.<br>Connect to 1, if not registered. See <a href="#">Table 22 on page 76</a> .                                                                                                                                                                                           |
| FDBKSEL_SD_N   | Input     | Static  | Low      | Synchronous load data for FDBKSEL register.<br>See <a href="#">Table 22 on page 76</a> .                                                                                                                                                                                                                       |
| FDBKSEL_EN     | Input     | Dynamic | High     | Enable for FDBKSEL register. Connect to 1, if not registered. See <a href="#">Table 22 on page 76</a> .                                                                                                                                                                                                        |
| <hr/>          |           |         |          |                                                                                                                                                                                                                                                                                                                |

**Table 21 • Ports**

| <b>Port Name</b> | <b>Direction</b> | <b>Type</b> | <b>Polarity</b> | <b>Description</b>                                                                                                         |
|------------------|------------------|-------------|-----------------|----------------------------------------------------------------------------------------------------------------------------|
| <b>SUB</b>       | Input            | Dynamic     | High            | Subtract operation.                                                                                                        |
| SUB_BYPASS       | Input            | Static      | High            | Bypass SUB register. Connect to 1, if not registered.                                                                      |
| SUB_AL_N         | Input            | Dynamic     | Low             | Asynchronous load for SUB register. Connect to 1, if not registered.<br>When asserted, SUB register is loaded with SUB_AD. |
| SUB_AD           | Input            | Static      | High            | Asynchronous load data for SUB register.                                                                                   |
| SUB_SL_N         | Input            | Dynamic     | Low             | Synchronous load for SUB register. Connect to 1, if not registered. See <a href="#">Table 22</a> .                         |
| SUB_SD_N         | Input            | Static      | Low             | Synchronous load data for SUB register. See <a href="#">Table 22</a> .                                                     |
| SUB_EN           | Input            | Dynamic     | High            | Enable for SUB register. Connect to 1, if not registered. See <a href="#">Table 22</a> .                                   |

**Table 22 • Truth Table for Control Registers ARSHFT17, CDSEL, FDBKSEL and SUB**

| <b>_AL_N</b> | <b>_AD</b> | <b>_BYPASS</b> | <b>_CLK</b> | <b>_EN</b> | <b>_SL_N</b> | <b>_SD_N</b>    | <b>D</b> | <b>Q<sub>n+1</sub></b> |
|--------------|------------|----------------|-------------|------------|--------------|-----------------|----------|------------------------|
| 0            | AD         | X              | X           | X          | X            | X               | X        | AD                     |
| 1            | X          | 0              | Not rising  | X          | X            | X               | X        | Q <sub>n</sub>         |
| 1            | X          | 0              | ↑           | 0          | X            | X               | X        | Q <sub>n</sub>         |
| 1            | X          | 0              | ↑           | 1          | 0            | SD <sub>n</sub> | X        | !SD <sub>n</sub>       |
| 1            | X          | 0              | ↑           | 1          | 1            | X               | D        | D                      |
| 1            | X          | 1              | X           | 0          | X            | X               | X        | Q <sub>n</sub>         |
| 1            | X          | 1              | X           | 1          | 0            | SD <sub>n</sub> | X        | !SD <sub>n</sub>       |
| 1            | X          | 1              | X           | 1          | 1            | X               | D        | D                      |

**Table 23 • Truth Table - Data Registers A, B, C, CARRYIN, P and OVFL\_CARRYOUT**

| <u>_ARST_N</u> | <u>_BYPASS</u> | <u>_CLK</u> | <u>_EN</u> | <u>_SRST_N</u> | <u>D</u> | <u>Q<sub>n+1</sub></u> |
|----------------|----------------|-------------|------------|----------------|----------|------------------------|
| 0              | X              | X           | X          | X              | X        | 0                      |
| 1              | 0              | Not rising  | X          | X              | X        | Q <sub>n</sub>         |
| 1              | 0              | ↑           | 0          | X              | X        | Q <sub>n</sub>         |
| 1              | 0              | ↑           | 1          | 0              | X        | 0                      |
| 1              | 0              | ↑           | 1          | 1              | D        | D                      |
| 1              | 1              | X           | 0          | X              | X        | Q <sub>n</sub>         |
| 1              | 1              | X           | 1          | 0              | X        | 0                      |
| 1              | 1              | X           | 1          | 1              | D        | D                      |

**Table 24 • Truth Table - Propagating Data to Operand D**

| <b>FDBKSEL</b> | <b>CDSEL</b> | <b>ARSHFT17</b> | <b>Operand D</b>             |
|----------------|--------------|-----------------|------------------------------|
| 0              | 0            | x               | 44'b0                        |
| x              | 1            | 0               | CDIN[43:0]                   |
| x              | 1            | 1               | {{17{CDIN[43]}},CDIN[43:17]} |
| 1              | 0            | 0               | P[43:0]                      |
| 1              | 0            | 1               | {{17{P[43]}},P[43:17]}       |



---

## A – Product Support

---

Microsemi SoC Products Group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, electronic mail, and worldwide sales offices. This appendix contains information about contacting Microsemi SoC Products Group and using these support services.

### Customer Service

Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization.

From North America, call 800.262.1060

From the rest of the world, call 650.318.4460

Fax, from anywhere in the world, 408.643.6913

### Customer Technical Support Center

Microsemi SoC Products Group staffs its Customer Technical Support Center with highly skilled engineers who can help answer your hardware, software, and design questions about Microsemi SoC Products. The Customer Technical Support Center spends a great deal of time creating application notes, answers to common design cycle questions, documentation of known issues, and various FAQs. So, before you contact us, please visit our online resources. It is very likely we have already answered your questions.

### Technical Support

Visit the Customer Support website ([www.microsemi.com/soc/support/search/default.aspx](http://www.microsemi.com/soc/support/search/default.aspx)) for more information and support. Many answers available on the searchable web resource include diagrams, illustrations, and links to other resources on the website.

### Website

You can browse a variety of technical and non-technical information on the SoC home page, at [www.microsemi.com/soc](http://www.microsemi.com/soc).

### Contacting the Customer Technical Support Center

Highly skilled engineers staff the Technical Support Center. The Technical Support Center can be contacted by email or through the Microsemi SoC Products Group website.

#### Email

You can communicate your technical questions to our email address and receive answers back by email, fax, or phone. Also, if you have design problems, you can email your design files to receive assistance. We constantly monitor the email account throughout the day. When sending your request to us, please be sure to include your full name, company name, and your contact information for efficient processing of your request.

The technical support email address is [soc\\_tech@microsemi.com](mailto:soc_tech@microsemi.com).

## My Cases

Microsemi SoC Products Group customers may submit and track technical cases online by going to [My Cases](#).

## Outside the U.S.

Customers needing assistance outside the US time zones can either contact technical support via email ([soc\\_tech@microsemi.com](mailto:soc_tech@microsemi.com)) or contact a local sales office. [Sales office listings](#) can be found at [www.microsemi.com/soc/company/contact/default.aspx](http://www.microsemi.com/soc/company/contact/default.aspx).

## ITAR Technical Support

For technical support on RH and RT FPGAs that are regulated by International Traffic in Arms Regulations (ITAR), contact us via [soc\\_tech\\_itar@microsemi.com](mailto:soc_tech_itar@microsemi.com). Alternatively, within [My Cases](#), select **Yes** in the ITAR drop-down list. For a complete list of ITAR-regulated Microsemi FPGAs, visit the [ITAR](#) web page.



**Microsemi Corporate Headquarters**  
One Enterprise, Aliso Viejo,  
CA 92656 USA

**Within the USA:** +1 (800) 713-4113  
**Outside the USA:** +1 (949) 380-6100  
**Sales:** +1 (949) 380-6136  
**Fax:** +1 (949) 215-4996

**E-mail:** [sales.support@microsemi.com](mailto:sales.support@microsemi.com)

©2015 Microsemi Corporation. All rights reserved. Microsemi and the Microsemi logo are trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners.

Microsemi Corporation (Nasdaq: MSCC) offers a comprehensive portfolio of semiconductor and system solutions for communications, defense & security, aerospace, and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs, and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; security technologies and scalable anti-tamper products; Ethernet solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Microsemi is headquartered in Aliso Viejo, Calif. and has approximately 3,600 employees globally. Learn more at [www.microsemi.com](http://www.microsemi.com).

Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this document or to any products and services at any time without notice.