

Designing with Global Clock Buffers in FPGAs

Jaishankar lyer

FPGAs have resources called Global Clock Buffers and the number of buffers varies from one FPGA technology to another. Global Clock Buffers may be used for high fanout signals like clock, clock enable preset logic and clear logic. Since Global Clock Buffers are dedicated resources in the FPGA architecture, it makes sense to utilize them fully.

In case we do not specifically assign Global Clock Buffers in our design, the software tools may automatically attach a Global Clock Buffer to any input port signal, which directly drives a clock pin. The software may limit the maximum number of Global Clock Buffers, which can be inserted into the synthesized netlist file, based on the architectural capabilities of the device.

In addition, some FPGA tools may allow us to assign Global Clock Buffers to high fanout signals in the constraints file which is passed on as input to the Place & Route tools. This is another way to achieve the same result.

There are two other ways that help you better control the assignment of Global Clock Buffers to the high fanout signals, as explained below :

- 1. By using attribue clock\_buffer
- 2. By Instantiation

# Using Attribute clock\_buffer

It is possible to insert a Global Clock Buffer on any specified input port signal, regardless of whether it is a clock signal or not. Use the "clock\_buffer" attribute as shown below in Example 1, to access this feature. This Global Clock Buffer replaces the input buffer and thus uses a dedicated global buffer pad. This attribute is attached to top-level port signals.

In the example below, a Global Clock Buffer is inserted on the CLR line.

# Example 1

library ieee; use ieee.std\_logic\_1164.all; entity dff is port (data : in STD\_LOGIC;

```
clk
                : in STD_LOGIC;
                : in STD_LOGIC;
          clr
                : out STD_LOGIC) ;
          q
    attribute clock_buffer : boolean;
    attribute clock_buffer of clr : signal is
true;
end dff ;
architecture test of dff is
begin -- test
    process (clk,clr)
     begin
        if clr = '1' then
            q <='0';
         elsif clk'event and clk = '1' then
            q <= data;
        end if;
    end process;
end test ;
```

#### Instantiation

Global Clock Buffers may also be instantiated. This method is best suited to drive a Global Clock Buffer with an internally generated signal or to control the specific type of global buffer used. If, for instance, in an ORCA Series 3 design, we wish to specify the use of CLKCNTLB (bottom) clock controller, then we need to instantiate it as shown in Example 2 below.

# Example 2

```
library ieee;
            use ieee.std_logic_1164.all;
            entity clkcnt is
                    port( data
                                  :in STD_LOGIC;
                           data :in STD_LOGIC;
ck_in :in STD_LOGIC;
                           ck_off :in STD_LOGIC;
                                  :out STD_LOGIC);
                           q
            end clkcnt;
            architecture test of clkcnt is
                   signal clock :STD_LOGIC;
                    component CLKCNTLB
                            port( CLKIN: in STD_LOGIC;
                                   SHUTOFF: in STD_LOGIC;
                                   CLKOUT: out STD_LOGIC);
                    end component;
            begin
            -- Component Instantiation
            CLK_CNTL_BOTTOM: CLKCNTLB port map (CLKIN=>ck_in,
                               SHUTOFF=>ck_off, CLKOUT=>clock);
            process(clock)
            begin
                    if(clock'event and clock='1') then
                            out <= data;
                    end if;
            end process;
            End test;
                The VHDL code in <sup>■</sup>the
                                                           examples
                                                 above
Comit now designs AMBA
compliant interfaces for on-
 chip digital peripherals!
```



#### Design Advantage

can be compiled and synthesized.

#### Overcoming inconsistencies in SDF backannotation Rohan Hubli

During backannotation using SDF files, we may come across situations where the same cell name is referenced differently in the HDL netlist file and the SDF file. This may happen due to differences in hierarchical separators, register names, net names etc.

eg : U31dffrdx1\_reg\_1 -- VHDL/Verilog cell name U31dffrdx1reg\_1 -- SDF cell name

The effect of this is an unsuccessful post-synthesis gate level simulation since the simulator cannot find the reference for the cell being addressed by the design.

We can, of course, write a shell script to identify differences in cell names in the netlist and SDF files and generate files acceptable to the simulator. This method is tedious as it requires manual intervention to identify differences in the files and fix them. As good design practice, we can execute a set of variables before synthesis with Synopsys<sup>®</sup> Design Compiler<sup>™</sup>, which will nullify the inconsistencies in the netlist and SDF file.

For VHDL designs, the Synopsys  $^{\ensuremath{\text{\tiny B}}}$  synthesis variable set will look like this :

bus\_naming\_style="%s<%d>"
default\_name-rules = "sge\_vhdl"
change\_names -hierarchy
vhdlout\_write\_components = FALSE
vhdlout\_write\_top\_configuration = TRUE
vhdlout\_use\_packages = { IEEE.std\_logic\_144 }

For Verilog designs, the Synopsys  $^{\ensuremath{\text{e}}}$  synthesis variable set will look like this :

bus\_naming\_style="%s<%d>" define\_name\_rules my\_rules -allowed "A-Z \_ 1-10" -first\_restricted "A-Z" -restricted "!@#\$%^&\*()" -last\_resticted "\\-" change\_names -rules my\_rules -hierarchy.

This technique ensures a smoother flow during

We build chips, boards, software and systems for you.