

# Maximize ispMACH 5000VG and ispLSI 5000VE Functionality with Dual-OR Macrocells

July 2001 Technical Note TN1006

#### Introduction

Coming close to the macrocell limit? Why not double the number of functions used by your dual-OR output capability of the macrocells. This applications note shows two ways to implement the dual-OR function in the I/O architecture. The first method locks pins and signals to the same macrocell, and the second method groups signals together and lets the compiler assign the dual-OR functions for you.

### **Method 1: Locking Pins**

This method forces two functions into a macrocell by locking pins and nodes. In the example found in Appendix A, the output "reg\_out" is locked to Pin B13. The node "un3\_comb\_latch\_out" is locked to Macrocell E0, the same macrocell as Pin B13 uses. To lock pins:

1) Open the Constraint Editor as shown below and click the Loc (Location Assignment) button



2) The Location Assignment Window will open, as shown below. Select Output/Bidi and Buried Node. It is usually easiest to lock pins first. Once a pin assignment has been chosen, click the Add button to lock the pin. Following this, the buried node can be locked to the same macrocell using the same procedure.



- 3) Save the changes and close the Constraint Editor.
- 4) To verify both functions are using the same macrocell, look at the number of two-function macrocells used in the section Device Resource Summary in the report file. Also in the report file you can look at the GLB\_E\_CLUSTER\_TABLE, as shown below. The number '2' in the cluster table entry shows that the macrocell is implementing two functions, and the number 1 shows the macrocell implementing a single function.



## **Method 2: Grouping Pins**

The second method to implement the dual-OR function within a macrocell is by grouping more than 32 signals into same GLB. This forces the compiler to implement two functions in macrocells. In the following example, found in Appendix B, signals are grouped into GLB A. To group pins:

1) Open the Constraint Editor as shown below and click the Grp (Group Assignment) button.



2) The Group Assignment Window will open, as shown below. Select Output/Bidi and Buried Node. Select a group name for the output pins. Then select the GLB to group it to. Followed by clicking the Add button. The same procedure can be used for buried nodes.



- 3 Save your changes and close the Constraint Editor.
- 4) To verify both functions are using the same macrocell, look at the number of two-function macrocells used in the section Device Resource Summary in the report file. Also in the report file you can look at the GLB\_E\_CLUSTER\_TABLE, as shown below. The number '2' in the cluster table entry shows that the macrocell is implementing two functions, and the number '1' shows the macrocell implementing a single function.



#### **Summary**

By taking advantage of the ispMACH 5000VG and ispLSI 5000V family dual-OR output of the macrocells, Lattice's ispLEVER™ Development System software assigns up to two logic functions for a given macrocell. The first example simply locks the pin function and the macrocell feedback function to the same macrocell. The second example lets the software assign dual function as needed when the user forces more than 32 functions in a GLB.

The design examples show a latch function implemented with the combinatorial path of the dual OR and a register function with the remaining dual OR path. Although this capability can greatly increase the logic functions, the functions must be of small product term (PT) usage. The general recommendation is to selectively use these features where a few simple registers or latches must be added to already packed design. The software provides the maximum flexibility by allowing the user to implement any two (register or combinatorial) functions within the macrocell.

#### **Technical Support Assistance**

Hotline: 1-800-LATTICE (Domestic)

1-408-826-6002 (International)

e-mail: techsupport@latticesemi.com

# **Appendix A Locking VHDL Code**

```
library ieee;
use ieee.std_logic_1164.all;
entity comb is
              (reg in: in std logic;
 port
              comb_latch_din, comb_le: in std_logic;
              sysclk: in std_logic;
              reg_out: out std_logic);
end comb;
architecture comb_list of comb is
begin
process (sysclk) -- clock name is in sensitivity list
              variable comb_latch_out: std_logic;
begin
 if rising_edge(sysclk) then
              reg_out <= reg_in or comb_latch_out;</pre>
 end if;
 comb_latch_out := (comb_latch_din and (not(comb_le))) or (comb_latch_out and comb_le);
end process;
end comb_list;
```

### **Appendix B Grouping VHDL Code**

```
library ieee;
use ieee.std logic 1164.all;
entity comb is
 port
               (rea in: in std loaic:
               comb latch din, comb le: in std logic;
               sysclk: in std logic;
               reg_out: out std_logic_vector(16 downto 0);
               test_out: out std_logic);
end comb;
architecture comb_list of comb is
begin
process (sysclk) -- clock name is in sensitivity list
 variable comb latch out : std logic vector(31 downto 0);
begin
 if rising edge(sysclk) then
               reg out(0) \leq reg in or comb latch out(0);
               reg_out(1) <= reg_in or comb_latch_out(1);</pre>
               reg out(2) \leftarrow reg in or comb latch out(2);
               reg_out(3) <= reg_in or comb_latch_out(3);</pre>
               reg out(4) \leq reg in or comb latch out(4);
               reg out(5) \leftarrow reg in or comb latch out(5);
               reg out(6) \leq reg in or comb latch out(6);
               reg_out(7) <= reg_in or comb_latch_out(7);</pre>
               reg_out(8) <= reg_in or comb_latch_out(8);</pre>
               reg_out(9) <= reg_in or comb_latch_out(9);</pre>
               reg out(10) \leq reg in or comb latch out(10);
               reg out(11) \leq reg in or comb latch out(11);
               reg_out(12) <= reg_in or comb_latch_out(12);</pre>
               reg out(13) \leftarrow reg in or comb latch out(13);
               reg_out(14) <= reg_in or comb_latch_out(14);
               reg out(15) \leq reg in or comb latch out(15);
               reg_out(16) <= reg_in or comb_latch_out(16);</pre>
  end if;
```

test\_out <= comb\_latch\_out(0) and comb\_latch\_out(1) and comb\_latch\_out(2) and comb\_latch\_out(3) and comb latch out(4) and comb latch out(5) and comb latch out(6) and comb latch out(7) and comb latch out(8) and comb latch out(9) and comb latch out(10) and comb latch out(11) and comb latch out(12) and comb latch out(13) and comb latch out(14) and comb latch out(15) and comb latch out(16) and comb latch out(17) and comb\_latch\_out(18) comb latch out(19) and comb latch out(20) and and comb\_latch\_out(23) comb\_latch\_out(24) comb latch out(21) and comb latch out(22) and and and comb\_latch\_out(25) and comb\_latch\_out(26) and comb\_latch\_out(27) and comb\_latch\_out(28) and comb\_latch\_out(29) and comb\_latch\_out(30);

end comb\_list;

```
comb latch out(0) := (comb latch din and (not(comb le))) or (comb latch out(0) and comb le);
 comb latch out(1) := (comb latch din and (not(comb le))) or (comb latch out(1) and comb le);
 comb_latch_out(2) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(2) and comb_le);
 comb_latch_out(3) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(3) and comb_le);
 comb latch out(4) := (comb latch din and (not(comb le))) or (comb latch out(4) and comb le);
 comb_latch_out(5) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(5) and comb_le);
 comb_latch_out(6) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(6) and comb_le);
 comb latch out(7) := (comb latch din and (not(comb le))) or (comb latch out(7) and comb le);
 comb latch out(8) := (comb latch din and (not(comb le))) or (comb latch out(8) and comb le);
 comb_latch_out(9) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(9) and comb_le);
 comb latch out(10) := (comb latch din and (not(comb le))) or (comb latch out(10) and comb le);
 comb_latch_out(11) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(11) and comb_le);
 comb latch out(12) := (comb latch din and (not(comb le))) or (comb latch out(12) and comb le);
 comb latch out(13) := (comb latch din and (not(comb le))) or (comb latch out(13) and comb le);
 comb latch out(14) := (comb latch din and (not(comb le))) or (comb latch out(14) and comb le);
 comb latch out(15) := (comb latch din and (not(comb le))) or (comb latch out(15) and comb le);
 comb_latch_out(16) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(16) and comb_le);
 comb_latch_out(17) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(17) and comb_le);
 comb latch out(18) := (comb latch din and (not(comb le))) or (comb latch out(18) and comb le);
 comb latch out(19) := (comb latch din and (not(comb le))) or (comb latch out(19) and comb le);
 comb_latch_out(20) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(20) and comb_le);
 comb latch out(21) := (comb latch din and (not(comb le))) or (comb latch out(21) and comb le);
 comb_latch_out(22) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(22) and comb_le);
 comb latch out(23) := (comb latch din and (not(comb le))) or (comb latch out(23) and comb le);
 comb latch out(24) := (comb latch din and (not(comb le))) or (comb latch out(24) and comb le);
 comb latch out(25) := (comb latch din and (not(comb le))) or (comb latch out(25) and comb le);
 comb latch out(26) := (comb latch din and (not(comb le))) or (comb latch out(26) and comb le);
 comb_latch_out(27) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(27) and comb_le);
 comb_latch_out(28) := (comb_latch_din and (not(comb_le))) or (comb_latch_out(28) and comb_le);
 comb latch out(29) := (comb latch din and (not(comb le))) or (comb latch out(29) and comb le);
 comb latch out(30) := (comb latch din and (not(comb le))) or (comb latch out(30) and comb le);
end process;
```