

# LogiCORE IP Interrupt Control (v2.01a)

DS516 March 1, 2011 Product Specification

### Introduction

The Interrupt Control service is a continuation of the Xilinx family of IBM CoreConnect compatible LogiCORE™ products. It provides interrupt capture support for internal IPIF sub-block, as well as support for the connected IP function.

### **Features**

- Parameterized number of interrupts needed by the IP
- Provides both Interrupt Status Register (ISR) and Interrupt Enable Register (IER) functions for the user IP.
- Inclusion/Omission of Priority Encoder
- Inclusion/Omission of Device ISC
- Parameterized number of local IPIF generated interrupt sources.
- Provides both Interrupt Status Register (ISR) and Interrupt Enable Register (IER) functions for the Device level interrupts.
- Supports 32, 64, and 128-bit IPIF data bus widths
- Global Enable/Disable for final interrupt output to the System Interrupt Controller
- Parameterized user IP interrupt capture mode
  - Pass Through (non-inverting)
  - Pass Through (inverting)
  - Registered Level (non-inverting)
  - Registered Level (inverting)
  - Positive edge detect
  - Negative edge detect

|                            | LogiCORE IP Facts Table |                           |                         |               |  |
|----------------------------|-------------------------|---------------------------|-------------------------|---------------|--|
|                            | Core Specifics          |                           |                         |               |  |
| Supported<br>Device Family | (Devi                   | Helper<br>ce Family listi | Core<br>ng not applica  | ble)          |  |
| Supported User Interfaces  | (Suppor                 | Helper<br>ted User IF lis | Core<br>sting not appli | cable)        |  |
|                            | Re                      | esources                  |                         |               |  |
| Configuration              | LUTs                    | FFs                       | DSP<br>Slices           | Block<br>RAMs |  |
| Configuration 1            | Min 18<br>Max 129       | Min 19<br>Max 63          | Min 18<br>Max 129       | 0             |  |
|                            | Provide                 | ed with Co                | re                      |               |  |
| Documentation              |                         |                           | Product Sp              | ecification   |  |
| Design Files               | VHDL                    |                           |                         |               |  |
| Example Design             | Not Provided            |                           |                         | t Provided    |  |
| Test Bench                 |                         |                           | No                      | t Provided    |  |
| Constraints File           |                         |                           | No                      | t Provided    |  |
| Simulation<br>Model        |                         |                           | No                      | t Provided    |  |
|                            | Tested                  | Design Too                | ols                     |               |  |
| Design Entry<br>Tools      |                         |                           | EDK                     | 13.1, XPS     |  |
| Simulation                 |                         |                           | QuestSi                 | m-64 6.6c     |  |
| Synthesis Tools XST        |                         |                           |                         |               |  |
|                            | S                       | upport                    |                         |               |  |
|                            | Provide                 | d by Xilinx, In           | с.                      |               |  |



# **Functional Description**

Most microprocessor systems require peripheral devices to request the attention of the microprocessor through the assertion of interrupt signals. Generally, a central interrupt controller is used to collect the interrupts from various sources and then apply prioritization and masking functions to them per user application programming. The interrupt control service is a simple interrupt controller function that is used to collect interrupts from a user device. These will be generated by device services and the user IP. The interrupt service captures and coalesces these various interrupt signals into a single interrupt output signal that is sent to the system interrupt controller in the microprocessor. The service also provides local registers that the user application can utilize to read interrupt status, set up masking criteria, and perform interrupt clearing for the individual interrupts.

Interrupts may be generated within a device by the user IP and/or other device services. The number of user IP interrupts that need to be captured depends on the function of the IP and is generally quite different from IP to IP. Rather than attempting to accommodate this variable number of interrupt bits into a single register, a hierarchical interrupt capture and reporting scheme is used that is coupled with User parameterization.

The hierarchical interrupt reporting structure shown in Figure 1 is based on the interrupt source controller, sometimes referred to simply as an ISC. An interrupt source controller is a function that captures a number of interrupt input signals and, using masking and logic, coalesces the captured interrupts into a single output single that is sent to the next higher level of interrupt hierarchy.



Figure 1: Interrupt Control Hierarchy

An interrupt-event signal is a transient condition that needs to be captured by an interrupt source controller and held until there is an explicit acknowledgement (actually a clear operation) by the user application. An interrupt-active signal is defined as an interrupt signal that is captured and held (until actively cleared) by a lower-level ISC. Interrupt active signals do not need to be recaptured at the next higher level of interrupt hierarch. An interrupt structure for an example user device that is maximally populated with interrupts is shown in Figure 2.



In the lower half of the diagram, the device interrupt source controller is shown. It is the function of the device ISC to output the single device interrupt signal to the system interrupt controller in the microprocessor via the Dev\_Intr\_Out output port. It is the highest level of interrupt hierarchy for the device. The device registers also provide control and status information that are used to mask and discover the source of interrupts within the device, or both.

User interrupts are generally captured and controlled in the IP ISC. The IP ISC captures interrupt events directly from the User IP per the capture mode specified by the C\_IP\_INTR\_MODE\_ARRAY parameter. The number of user IP interrupts needed (N) is inferred from the number of entries in the C\_IP\_INTR\_MODE\_ARRAY parameter. The IP ISC then coalesces the IP interrupts into a single interrupt active signal that is output the to the Device ISC.



Figure 2: Example User Device Interrupt Hierarchy

The device ISE may be parameterized out of the interrupt control service by setting C\_INCLUDE\_DEV\_ISE = false. In this case the only source of interrupts is the IP ISC. This option, which reduces hardware cost and software accesses, is shown in Figure 3.





Figure 3: Example with Device ISE Removed

# **User IP Interrupt Capture Mode**

There are 6 User IP interrupt capture modes. These are summarized in Table 1. The interrupt capture mode is set via the C\_IP\_INTR\_MODE\_ARRAY parameter.

Table 1: User IP Capture Mode

| Capture<br>Mode | Description                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | Pass Through (non-inverting): This mode passes through the interrupt event without capturing the event. This mode is used for situations where the interrupt event is actually captured in the User's IP. In this mode, to clear the interrupt, the event must be cleared at the user IP.                                                                                             |
| 2               | Pass Through (inverting): This mode passes through the interrupt and as it is doing so, inverts the level of the interrupt event. This mode is used for active low interrupt events. Like in mode 1, this mode is used for situation where the interrupt event is actually captured in the user's IP. In this mode, to clear the interrupt, the event must be cleared at the user IP. |
| 3               | Registered Level (non-inverting): This mode captures the interrupt event based on the level input from the user IP. This interrupt mode does not require the interrupt event to be captured in the user IP, but does require the interrupt event to maintain the active level (logical 1) a minimum of 2 Bus2IP_Clk cycles to be captured by the ISC.                                 |
| 4               | Registered Level (inverting): This mode captures the interrupt event based on the level input from the User IP. This interrupt mode does not require the interrupt event to be captured in the User IP, but does require the interrupt event to maintain the active level (logical 0) a minimum of 2 Bus2IP_Clk cycles to be captured by the ISC.                                     |
| 5               | <b>Positive Edge Detect</b> : This mode captures the interrupt event on the rising edge of the event. This interrupt mode does not require the interrupt event to be captured in the User IP.                                                                                                                                                                                         |
| 6               | <b>Negative Edge Detect</b> : This mode captures the interrupt event on the falling edge of the event. This interrupt mode does not require the interrupt event to be captured in the User IP.                                                                                                                                                                                        |



# **Parameters**

The Interrupt Control device can be parameterized for individual application. Table 2 shows the Interrupt Control parameters. Allowable Parameter Combinations

Table 2: Interrupt control Design Parameters

| Generic | Parameter Name                            | Feature / Description                                                                                           | Allowable Values                                                                                                                                                                      | Default<br>Value | VHDL Type              |
|---------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------|
| GI      | C_NUM_CE                                  | Sizes the interrupt_RdCE and Interrupt_WrCe ports. Specifies the number of chip enables required for registers. | 16 for C_IPIF_DBUS_<br>WIDTH = 32<br>8 for C_IPIF_DBUS_<br>WIDTH = 64<br>4 for C_IPIF_DBUS_<br>WIDTH = 128                                                                            | 4                | Integer                |
| G2      | C_NUM_IPIF_<br>IRPT_SRC                   | Number of device Level Interrupts                                                                               | 4 to 128 <sup>(4)</sup>                                                                                                                                                               | 4                | Integer                |
| G3      | C_IP_INTR_<br>MODE_ARRAY                  | Capture mode for IP interrupts. This array also sets the number of IP interrupts to capture <sup>(1)</sup> .    | 1 = Pass Through (non-inverting) 2 = Pass Through (inverting) 3 = Registered Level (non-inverting) 4 = Registered Level (inverting) 5 = Positive Edge Detect 6 = Negative Edge Detect | (1,2)            | INTEGER_<br>ARRAY_TYPE |
| G4      | C_INCLUDE_<br>DEV_PENCODER <sup>(1)</sup> | Device Priority Encoder feature Inclusion/Omission                                                              | true=Include Priority<br>Encoder <sup>(1)</sup><br>false=Omit Priority<br>Encoder                                                                                                     | false            | Boolean                |
| G5      | C_INCLUDE_DEV_I<br>SC                     | Device ISC feature<br>Inclusion/Omission                                                                        | true=Include Device ISC<br>false=Omit Device ISC                                                                                                                                      | false            | Boolean                |
| G6      | C_IPIF_DWIDTH                             | IPIF Data Bus Width                                                                                             | 32, 64, or 128                                                                                                                                                                        | 128              | Integer                |

#### Notes:

**Table 3: Allowable Parameter Combinations** 

| Dependent Parameter    | Affected Parameter |                   | Dependency Description |                                                                                 |
|------------------------|--------------------|-------------------|------------------------|---------------------------------------------------------------------------------|
| C_INCLUDE_DEV_PENCODER | G4                 | C_INCLUDE_DEV_ISC | G5                     | If G5 is set to False, G4 is not used.                                          |
| C_NUM_CE               | G1                 | C_IPIF_WIDTH      | G6                     | If G6 = 32, set G1 = 16.<br>If G6 = 64, set G1 = 7.<br>If G6 = 128, set G1 = 4. |

<sup>1.</sup> C\_INCLUDE\_DEV\_PENCODER is only valid if the device ISC is included, i.e. C\_INCLUDE\_DEV\_ISC=true



# I/O Signals

The Interrupt Control device has 2 interfaces. These are the Host Bus Interface (IPIF), and the User IP interface (IP). The I/O signals for the design are listed in Table 4.

Table 4: I/O Signals

| Port | Signal Name                                            | Interface | I/O | Description                                                                                                                      |
|------|--------------------------------------------------------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------|
| P1   | Bus2IP_Reset                                           | IPIF      | I   | Active high reset signal                                                                                                         |
| P2   | Bus2IP_Clk                                             | IPIF      | I   | Input synchronization clock from the IPIF Bus clock.                                                                             |
| Р3   | Bus2IP_Data(0 to <b>C_IPIF_WIDTH</b> - 1)              | IPIF      | I   | Input Data Bus used for manipulating the Interrupt Registers                                                                     |
| P4   | Bus2IP_BE(0 to C_IPIF_WIDTH/8 - 1)                     | IPIF      | I   | IPIF Byte Enable bus                                                                                                             |
| P5   | Interrupt_RdCE(0 to <b>C_NUM_CE</b> - 1)               | IPIF      | I   | Active high read chip enable                                                                                                     |
| P6   | Interrupt_WrCE(0 to C_INTERRUPT_REG_NUM - 1            | IPIF      | I   | Active high write chip enable                                                                                                    |
| P7   | IPIF_Reg_Interrupts(0 to 1)                            | IPIF      | I   | Active high interrupt inputs from the IPIF internal functions that need to be latched by the device Interrupt Source Controller. |
| P8   | IPIF_LvI_Interrupts(0 to C_NUM_IPIF_IRPT_SRC - 1)      | IPIF      | I   | Active high level interrupt inputs from IPIF internal functions to the device Interrupt Source Controller.                       |
| P9   | IP2Bus_IntrEvent(0 to C_IP_INTR_MODE_ARRAY'length - 1) | IP        | I   | Interrupt signals from the User IP to the IP Interrupt Source Controller                                                         |
| P10  | Intr2Bus_DevIntr                                       | IPIF      | 0   | Active high interrupt output to be sent to the System Interrupt Controller (INTC)                                                |
| P11  | Intr2Bus_DBus(0 to <b>C_IPIF_DWIDTH</b> - 1)           | IPIF      | 0   | Output Data Bus used during register read operations                                                                             |
| P12  | Intr2Bus_WrAck                                         | IPIF      | 0   | Active high signal indicating that the requested write operation has completed using the data input on the Bus2IP_Data bus.      |
| P13  | Intr2Bus_RdAck                                         | IPIF      | 0   | Active high signal indicating that the requested read data is being output on the Intr2Bus_DBus.                                 |
| P14  | Intr2Bus_Error                                         | IPIF      | 0   | This signal is always set to '0'.                                                                                                |
| P15  | Intr2Bus_Retry                                         | IPIF      | 0   | This signal is always set to '0'.                                                                                                |
| P16  | Intr2Bus_ToutSup                                       | IPIF      | 0   | This signal is always set to '0'.                                                                                                |

# **Parameter - Port Dependencies**

The parameterization of the device has effects on some of the I/O port sizes. These are indicated in the port definitions presented in Table 4.



# **Register Summary**

The following section discusses the user application interface to the registers provided by the Interrupt Controller.

Table 5: Interrupt Control Channel Register Summary

| Register Name Abbreviation                      |                                     | Address Offset from Base<br>Address Assignment (1) | Access                              |  |  |  |
|-------------------------------------------------|-------------------------------------|----------------------------------------------------|-------------------------------------|--|--|--|
| Device Interrupt Source Controller              |                                     |                                                    |                                     |  |  |  |
| Device Interrupt Status Register                | DEVICE_ISR                          | 0x00                                               | Read/Toggle on Write <sup>(2)</sup> |  |  |  |
| Device Interrupt Pending Register               | DEVICE_IPR                          | 0x04                                               | Read                                |  |  |  |
| Device Interrupt Enable Register                | DEVICE_IER                          | 0x08                                               | Read/Write                          |  |  |  |
| Device Interrupt ID Register (Priority Encoder) | DEVICE_IIR                          | 0x18                                               | Read                                |  |  |  |
| Global Interrupt Enable                         | DEVICE_GIE                          | 0x1C                                               | Read/Write                          |  |  |  |
|                                                 | User IP Interrupt Source Controller |                                                    |                                     |  |  |  |
| IP Interrupt Status Register                    | IPISR                               | 0x20                                               | Read/Toggle on Write <sup>(2)</sup> |  |  |  |
| IP Interrupt Enable Register                    | IPIER                               | 0x28                                               | Read/Write                          |  |  |  |

#### Notes:

- The Base Address is assigned by C\_ARD\_ADDR\_RANGE\_ARRAY generic for the OPB or PLB IPIF utilizing the Interrupt Control service.
- 2. Toggle each bit position to which a 1 is written

# **Register Description**

### **Device Interrupt Status Register (offset 0x00)**

The device Interrupt Status Register shown in Figure 4 gives the interrupt status for the device. This register is fixed at 32 bits wide and each utilized bit within the register is set to 1 whenever the corresponding interrupt input (IPIF\_Lvl\_Interrupts and IPIF\_Reg\_Interrupts) has met the interrupt capture criteria. Unlike the IP Interrupt Status Register, the capture mode for this register is fixed. DEV\_REG\_IS(0) and DEV\_REG\_IS(1) (mapped from IPIF\_Reg\_Interrupts(0) and IPIF\_Reg\_Interrupts(1) ports respectively) are captured with a sample and hold high mode. This means that if the input interrupt is sampled to be 1 at a rising edge of a Bus2IP\_Clk pulse, the register bit is set to a 1 and held until the user interrupt service routine clears it to a 0. The remaining bits within the register, DEV\_LVL\_IS(), (mapped from IPIF\_Lvl\_Interrupts ports) are passed through. Any additional sample and hold operation is not necessary in this register because once asserted, the bits are held by the source of the interrupt. These interrupts must be cleared at the source function.

The number of active bits in the DEVICE\_ISR allocated for level interrupts is determined by the user parameter, C\_NUM\_IPIF\_IRPT\_SRC. Bits of IPIF\_Lvl\_Interrupts are assigned in increasing order, starting with 0, to decreasing bit positions in the status register, starting with C\_IPIF\_DWIDTH-2.





Figure 4: Device Interrupt Status Register

Table 6: Status Register Description

| Bit(s)                     | Name          | Core Access             | Reset<br>Value | Description                                                                                                                                                                                                                                                                   |
|----------------------------|---------------|-------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31                         | DEV_REG_IS(0) | Read/Toggle<br>on Write | 0              | Device Registered Interrupt Status 0: 0 = No interrupt is captured 1 = Interrupt is captured                                                                                                                                                                                  |
| 30                         | DEV_REG_IS(1) | Read/Toggle<br>on Write | 0              | Device Registered Interrupt Status 1: 0 = No interrupt is captured 1 = Interrupt is captured                                                                                                                                                                                  |
| 29                         | IPIR          | Read                    | 0              | IP Interrupt Request: This interrupt indicates that a User IP interrupt input on the IP2Bus_IntrEvent bus has been captured in the IP Interrupt Status Register and is enabled via the IP Interrupt Enable Register 0 = No interrupt is captured 1 = IP interrupt is captured |
| (N <sup>(1)</sup> ) to 28  | DEV_LVL_IS    | Read                    | zeros          | Device Level Interrupts: 0 = No interrupt is asserted 1 = Interrupt is asserted                                                                                                                                                                                               |
| 0 to (N <sup>(1)</sup> -1) | Unused        | Read                    | zeros          | Reserved                                                                                                                                                                                                                                                                      |

#### Notes:

- 1.  $N = 29 C_NUM_IPIF_IRPT_SRC$ .
- Writing a 1 to a bit position within the register changes the corresponding bit position in the register to the toggle state. This
  mechanism avoids the requirement on the User Interrupt Service routing to perform a Read/Modify/Write operation to clear a single
  bit within the register.

### **Device Interrupt Pending Register (offset 0x04)**

The device Interrupt Pending Register shown in Figure 5 is a read-only value that is the logical AND of the Device Interrupt Status Register and the Device Interrupt Enable Register on a bit-by-bit basis. Therefore, the Interrupt Pending Register will report only captured interrupts that are also enabled by the corresponding bit in the Interrupt Enable Register.



Figure 5: Device Interrupt Pending Register



| Table 7 | 7: | Device | Interrupt | <b>Pending</b> | Register | Register |
|---------|----|--------|-----------|----------------|----------|----------|
|---------|----|--------|-----------|----------------|----------|----------|

| Bit(s)                     | Name          | Core Access | Reset Value | Description                                                                                                     |
|----------------------------|---------------|-------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| 31                         | DEV_REG_IP(0) | Read        | '0'         | Device Registered Interrupt Pending 0: '0' = No enabled interrupt is pending '1' = Enabled Interrupt is pending |
| 30                         | DEV_REG_IP(1) | Read        | '0'         | Device Registered Interrupt Pending 1: '0' = No enabled interrupt is pending '1' = Enabled Interrupt is pending |
| 29                         | IPIRP         | Read        | '0'         | IP Interrupt Request Pending: '0' = No enabled interrupt is pending '1' = Enabled Interrupt is pending          |
| (N <sup>(1)</sup> ) to 28  | DEV_LVL_IP    | Read        | zeros       | Level Interrupts Pending: '0' = No enabled interrupt is pending '1' = Enabled Interrupt is pending              |
| 0 to (N <sup>(1)</sup> -1) | Unused        | Read        | zeros       | Reserved                                                                                                        |

#### Notes:

# **Device Interrupt Enable Register (offset 0x08)**

The Device Interrupt Enable Register shown in Figure 6 determines which interrupt sources in the Device Interrupt Status Register are allowed to generate interrupts to the system.



Figure 6: Device Interrupt Enable Register

<sup>1.</sup> N = (C\_IPIF\_DWIDTH-3) - C\_NUM\_IPIF\_IRPT\_SRC. C\_NUM\_IPIF\_IRPT\_SRC must be less than or equal to C\_IPIF\_DWIDTH-3.



| Bit(s)                     | Name          | Core Access | Reset Value | Description                                                                        |
|----------------------------|---------------|-------------|-------------|------------------------------------------------------------------------------------|
| 31                         | DEV_REG_IE(0) | Read/Write  | '0'         | Device Registered Interrupt Enable 0: '0' = Mask Interrupt '1' = Enabled Interrupt |
| 30                         | DEV_REG_IE(1) | Read/Write  | '0'         | Device Registered Interrupt Enable 1: '0' = Mask Interrupt '1' = Enabled Interrupt |
| 29                         | IPIRE         | Read/Write  | '0'         | IP Interrupt Request Enable '0' = Mask Interrupt '1' = Enabled Interrupt           |
| (N <sup>(1)</sup> ) to 28  | DEV_LVL_IE    | Read/Write  | zeros       | Device Level Interrupts Enable: '0' = Mask Interrupt '1' = Enabled Interrupt       |
| 0 to (N <sup>(1)</sup> -1) | Unused        | Read        | zeros       | Reserved                                                                           |

Table 8: Device Interrupt Enable Register

#### Notes:

### **Device Interrupt ID Register (offset 0x18)**

The Device Interrupt ID Register shown in Figure 7 is an ordinal value output of a priority encoder. The value indicates which interrupt source, if any, has a pending interrupt. A value of 0x80 indicates that there are no pending interrupts, otherwise, the value gives the bit position in the Device Interrupt Pending Register (DIPR) of the highest priority interrupt that is pending.

The priority is highest for the interrupt bit in the LSB position (bit31), which reports as ID value 0x00, and decreases in priority (an increases in reported ID value) for each successively more significant position (i.e. going left).r



Figure 7: Device Interrupt ID Register

Table 9: Device Interrupt ID Register Description

| Bit(s)  | Name | Core Access | Reset Value | Description                                                                                                                                |
|---------|------|-------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 24 - 31 | IID  | Read        | 0x80        | Interrupt ID:  0x80 - The DIPR has no pending interrupts  Otherwise - The ordinal ID of the highest-priority pending interrupt in the DIPR |
| 0 - 23  |      | Read        | zeros       | Unused                                                                                                                                     |

N = (C\_IPIF\_DWIDTH-3) - C\_NUM\_IPIF\_IRPT\_SRC. C\_NUM\_IPIF\_IRPT\_SRC must be less than or equal to C\_IPIF\_DWIDTH-3.



## Device Global Interrupt Enable Register (offset 0x1C)

The Global Interrupt Enable Interrupt Register shown in Figure 8 has a single defined bit, in the high-order position, that is used to globally enable the final interrupt output form the Interrupt Control service to the Dev\_Intr\_out output port.



Figure 8: Device Global Interrupt Enable Register

Table 10: Device Global Interrupt Enable Register Description

| Bit(s) | Name | Core Access | Reset Value | Description                                                                                                       |
|--------|------|-------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| 0      | GIE  | Read/Write  | '0'         | Global Interrupt Enable  0 = Interrupts disabled; no interrupt possible from this device.  1 = Interrupts enabled |
| 1 - 31 |      | Read        | zeros       | Unused                                                                                                            |

# IP Interrupt Status Register (offset = 0x20)

The IP Interrupt Status Register (IPISR) shown in Figure 9 is the interrupt capture register for the user IP. It is part of the interrupt service. The IPISR captures interrupts input from the user IP on the IP2Bus\_IntrEvent input port. The number of active bits in the IPISR, as well as the capture mode for each, is determined by the user entries for the parameter C\_IP\_INTR\_MODE\_ARRAY. Bits of IP2Bus\_IntrEvent are assigned in increasing order, starting with 0, to decreasing bit positions in the status register, starting with 31.



Figure 9: IP Interrupt Status Register

Table 11: IP Interrupt Status Register Description

| Bit(s) | Name  | Core Access                         | Reset Value | Description                                                         |
|--------|-------|-------------------------------------|-------------|---------------------------------------------------------------------|
| 0 - 31 | IS(i) | Read/Toggle on Write <sup>(1)</sup> | zeros       | Interrupt Status: 1 = Interrupt Captured 0 = Interrupt Not Captured |

### Notes:

Writing a 1 to a bit position within the register changes the corresponding bit position in the register to the toggle state. This
mechanism over-rides the requirement on the user interrupt service routing to perform a Read/Modify/Write operation to clear a
single bit within the register.



## IP Interrupt Enable Register (offset 0x28)

The IP Interrupt Enable Register shown in Figure 10 has an enable bit for each defined bit of the IP Interrupt Status Register.



Figure 10: IP Interrupt Enable Register

Table 12: IP Interrupt Enable Register Description

| Bit(s) | Name  | Core Access | Reset Value | Description                                                  |
|--------|-------|-------------|-------------|--------------------------------------------------------------|
| 0 - 31 | IE(i) | Read/Write  | zeros       | Interrupt Status: 1 = Interrupt Enabled 0 = Interrupt Masked |

# **FPGA Design Application Hints**

# **Single Entry in Unconstrained Array Parameters**

The DMA parameterization employes generics that are defined as unconstrained arrays, such as arrays whose size is left unbound at declaration and fixed later by the user. This is the underlying VHDL mechanism that allows the DMA to grow or shrink to the size required by the application. The size of the unconstrained array and its element values are fixed simultaneously by the user by assigning to the array a constant aggregate which is a list of values enclosed in parentheses and separated by commas.

The list can take either of two forms, *positional association*, in which the values at indices in the array are populated by the aggregate elements as they appear, left to right, or *named association*, in which each value populates an index to which it is explicitly assigned by being proceeded by "INDX =>". Thus, the following positional and named aggregates are identical: (4,3,9) and (0=>4,1=>3,2=>9).

For aggregates with a single element, positional association is not allowed because the syntax would be ambiguous with a parenthesized expression. The following example shows the incorrect and the correct way to associate a single element to an unconstrained array.

Incorrect:

C\_IP\_INTR\_MODE\_ARRAY => (1); --VHDL positional association NOT allowed because it would be ambiguous.

Correct:

C\_IP\_INTR\_MODE\_ARRAY => (0=> 1); -- VHDL named association instead.

# **Target Technology**

The Interrupt Control core is targeted for the Virtex-5 devices.



### **Device Utilization and Performance Benchmarks**

The Interrupt Control benchmarks for a Virtex-5 FPGA are shown in Table 13.

Table 13: Performance and Resource Utilization Benchmarks

| Parameter Values  |                        |                     |               | Device Resources |                  |            |                         |
|-------------------|------------------------|---------------------|---------------|------------------|------------------|------------|-------------------------|
| C_INCLUDE_DEV_ISC | C_INCLUDE_DEV_PENCODER | C_NUM_IPIF_IRPT_SRC | C_IPIF_DWIDTH | Slices           | Slice Flip-Flops | Slice LUTs | fMAX_REG <sup>(1)</sup> |
| false             | false                  | 4                   | 32            | 18               | 19               | 22         | 162.3                   |
| false             | false                  | 29                  | 32            | 18               | 19               | 22         | 162.3                   |
| false             | false                  | 29                  | 64            | 19               | 19               | 22         | 210.3                   |
| true              | false                  | 29                  | 64            | 72               | 53               | 208        | 156.4                   |
| true              | true                   | 29                  | 64            | 121              | 53               | 173        | 197.4                   |
| true              | true                   | 29                  | 128           | 129              | 53               | 192        | 187.8                   |

#### Notes:

2. C\_IP\_INTR\_MODE\_ARRAY = (1, 2, 3, 4, 5, 6) for all configurations

### **Reference Documents**

None

# **Support**

Xilinx provides technical support for this LogiCORE product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support of product if implemented in devices that are not defined in the documentation, if customized beyond that allowed in the product documentation, or if changes are made to any section of the design labeled *DO NOT MODIFY*.

<sup>1.</sup> Fmax represents the maximum frequency of the Interrupt Control service in a standalone configuration. The actual maximum frequency will depend on the entire system and may be greater or less than what is recorded in this table. Thus Fmax should be used purely as a reference and a rough measure of the relative affects various configurations have on the operating frequency.



# **Revision History**

| Date     | Version | Revision                                      |  |
|----------|---------|-----------------------------------------------|--|
| 7/2/08   | 1.0     | Initial Xilinx release                        |  |
| 4/15/09  | 2.01    | Added Device Support and Required Tools Link. |  |
| 3/1/2011 | 2.1     | Updated to v2.01a for the 13.1 release.       |  |

# **Notice of Disclaimer**

Xilinx is providing this product documentation, hereinafter "Information," to you "AS IS" with no warranty of any kind, express or implied. Xilinx makes no representation that the Information, or any particular implementation thereof, is free from any claims of infringement. You are responsible for obtaining any rights you may require for any implementation based on the Information. All specifications are subject to change without notice. XILINX EXPRESSLY DISCLAIMS ANY WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE INFORMATION OR ANY IMPLEMENTATION BASED THEREON, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF INFRINGEMENT AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Except as stated herein, none of the Information may be copied, reproduced, distributed, republished, downloaded, displayed, posted, or transmitted in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of Xilinx.