

# **Clock Control Block (ALTCLKCTRL) Megafunction**

# **User Guide**



101 Innovation Drive San Jose, CA 95134 www.altera.com

UG-MF9604-3.0

Document last updated for Altera Complete Design Suite version: Document publication date: 10.0 February 2012



© 2012 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, HARDCOPY, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at www.altera.com/common/legal.html. Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.





# **Contents**

| Chapter 1. | About | this | Megafunction |
|------------|-------|------|--------------|
|            |       |      |              |

| Features                                              |     |
|-------------------------------------------------------|-----|
| Device Support                                        | 1–1 |
| Chapter 2. Parameter Settings                         |     |
| MegaWizard Parameter Settings                         |     |
| Command Line Interface Parameters                     |     |
| Chapter 3. Functional Description                     |     |
| Clock Control Block                                   |     |
| Global Clock Control Block                            |     |
| Regional Clock Control Block                          |     |
| External PLL Output Clock Control Block               |     |
| Clock Enable Signals                                  |     |
| Clock Enable Timing                                   |     |
| Connectivity Restrictions                             |     |
| General Restrictions                                  |     |
| Stratix II Devices Restrictions                       |     |
| Design Example: Global Clock Buffer                   |     |
| Functional Simulation in the ModelSim-Altera Software |     |
| ALTCLKCTRL Megafunction Ports                         |     |
| Input Ports                                           |     |
| Output Ports                                          |     |
| Prototypes and Component Declarations                 |     |
| Verilog HDL Prototype                                 |     |
| VHDL Component Declaration                            |     |
| VHDL LIBRARY-USE Declaration                          |     |
|                                                       |     |

#### **Additional Information**

| Document Revision History | Info-1 |
|---------------------------|--------|
| How to Contact Altera     | Info-2 |
| Typographic Conventions   | Info-2 |

# 1. About this Megafunction



The clock control block (ALTCLKCTRL) megafunction is a clock control function provided by the Quartus<sup>®</sup> II MegaWizard<sup>™</sup> Plug-In Manager to easily configure the clock control block in supported devices.

The common applications of using this megafunction are as follows:

- Dynamic clock source selection—When using the clock control block, you can select the dynamic clock source that drives the global clock network. However, only certain combinations of signal sources are supported, as described in "Global Clock Control Block" on page 3–2. You cannot select clock sources dynamically to drive the regional clock networks and the dedicated external clock-out path.
- Dynamic power-down of a clock network—The dynamic clock enable or disable feature allows internal logic to power-down the clock network. When a clock network is powered-down, all the logic fed by that clock network is not toggling, thus the overall power consumption of the device is reduced.

#### **Features**

The ALTCLKCTRL megafunction provides the following additional features:

- Supports specification of operation mode of the clock control block
- Supports specification of the number of input clock sources
- Provides an active high clock enable control input

### **Device Support**

The ALTCLKCTRL megafunction is available for Arria<sup>®</sup>, Cyclone<sup>®</sup>, HardCopy<sup>®</sup>, and Stratix<sup>®</sup> device series.



This section describes the parameter settings for the ALTCLKCTRL megafunction. You can parameterize the megafunction using the MegaWizard Plug-In Manager or the command-line interface (CLI). Altera recommends that you configure the megafunctions using the MegaWizard Plug-In Manager.

**This user guide assumes that you are familiar with megafunctions and how to create them. If you are unfamiliar with Altera**<sup>®</sup> megafunctions, refer to the *Introduction to Megafunctions User Guide*.

## **MegaWizard Parameter Settings**

Table 2–1 provides descriptions of the options available on the individual pages of the ALTCLKCTRL MegaWizard Plug-In Manager.

Table 2–1. ALTCLKCTRL MegaWizard Plug-In Manager Page Options and Description (Part 1 of 3)

| MegaWizard<br>Plug-in<br>Manager<br>Page | Configuration Setting                            | Description                                                                                                                                                                                               |
|------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                                        | Which action do you want to perform?             | You can select from the following options: <b>Create a new</b><br>custom megafunction variation, Edit an existing custom<br>megafunction variation, or Copy an existing custom<br>megafunction variation. |
|                                          | Select a megafunction from the list below        | Select ALTCLKCTRL from the I/O category.                                                                                                                                                                  |
| 2a                                       | Which device family will you be using?           | Specify the device family that you want to use.                                                                                                                                                           |
|                                          | Which type of output file do you want to create? | You can choose AHDL( <b>.tdf</b> ), VHDL( <b>.vhd</b> ), or Verilog HDL ( <b>.v</b> ) as the output file type.                                                                                            |
|                                          | What name do you want for the output file?       | Specify the name of the output file.                                                                                                                                                                      |
|                                          | Return to this page for another create operation | Turn on this option if you want to return to this page to create multiple megafunctions.                                                                                                                  |

| MegaWizard<br>Plug-in<br>Manager<br>Page        | Configuration Setting                                                                                          | Description                                                                                                                                                                                                                                         |
|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                 | Currently selected device family                                                                               | Specifies the device family you chose on page 2a.                                                                                                                                                                                                   |
|                                                 | Match project/default                                                                                          | Turn on this option to ensure that the device selected matches the device family that is chosen in the previous page.                                                                                                                               |
|                                                 |                                                                                                                | Specify the ALTCLKCTRL buffering mode. You can select from the following modes:                                                                                                                                                                     |
|                                                 |                                                                                                                | <b>Auto</b> <sup>(1)</sup> —Allows the Compiler to pick the best clock buffer to use.                                                                                                                                                               |
|                                                 |                                                                                                                | For global clock—Allows a clock signal to reach all parts of the chip with the same amount of skew; you can select input port clkselect to switch between the four clock inputs.                                                                    |
| 3                                               | How do you want to use the ALTCLKCTRL?                                                                         | <b>For dual regional clock—half chip</b> <sup>(1)</sup> —Allows a clock signal to reach half of the chip by using two regional clocks to drive two quadrants; only one clock input is accepted.                                                     |
|                                                 |                                                                                                                | For regional clock —quarter chip <sup>(1)</sup> —Allows a clock signal to reach a quadrant of the chip; only one clock input is accepted.                                                                                                           |
|                                                 |                                                                                                                | For external path—Represents the clock path from the outputs of the PLL to the dedicated clock output pins; only one clock output is accepted.                                                                                                      |
|                                                 |                                                                                                                | <b>For periphery clock</b> <sup>(2)</sup> —Allows a clock signal to reach a quadrant or an octant of the chip depending on the device; only one clock input is accepted.                                                                            |
|                                                 | How many clock inputs would you like? <sup>(3)</sup>                                                           | Specify the number of input clock sources for the clock control block. You can specify up to four clock inputs.                                                                                                                                     |
| Create 'ena'  <br>network driv<br>Ensure glitch | Create 'ena' port to enable or disable the clock network driven by this buffer <sup>(2)</sup> , <sup>(4)</sup> | Turn on this option if you want to create an active high<br>clock enable signal to enable or disable the clock<br>network.                                                                                                                          |
|                                                 |                                                                                                                | Turn on this option to implement a glitch-free switchover when you use multiple clock inputs.                                                                                                                                                       |
|                                                 | Ensure glitch-free switchover implementation                                                                   | You must ensure the clock that is currently selected is<br>running before switching to another source. If the<br>selected clock is not running, the glitch-free switchover<br>implementation will not be able to switch to the new<br>clock source. |
|                                                 |                                                                                                                | By default, the <code>clkselect</code> port is set to 00. A clock must be applied to <code>inclk0x</code> for the values on the <code>clkselect</code> ports to be read.                                                                            |

Table 2–1. ALTCLKCTRL MegaWizard Plug-In Manager Page Options and Description (Part 2 of 3)

| MegaWizard<br>Plug-in<br>Manager<br>Page | Configuration Setting | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4                                        | Generate netlist      | Turn on this option if you want to generate a netlist for<br>your third-party EDA synthesis tool to estimate the timing<br>and resource usage of the megafunction. If you turn on<br>this option, a netlist file ( <b>_syn.v</b> ) is generated. This file is<br>a representation of the customized logic used in the<br>Quartus II software and provides connectivity of the<br>architectural elements in the megafunction but may not<br>represent true functionality. |
|                                          |                       | Specify the types of files to be generated. Only the files marked with red check marks are optional.                                                                                                                                                                                                                                                                                                                                                                     |
|                                          |                       | Choose from the following types of files:                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                          |                       | <ul> <li>Variation file <sup>(5)</sup></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                          |                       | AHDL Include file (< function name>.inc)                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                          | Summary Page          | <ul> <li>VHDL component declaration file<br/>(<function name="">.cmp)</function></li> </ul>                                                                                                                                                                                                                                                                                                                                                                              |
| 6                                        |                       | <ul> <li>Quartus II symbol file (&lt;<i>function name</i>&gt;.bsf)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                            |
| -                                        |                       | Instantiation template file (< <i>function name</i> >_inst.v)                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                          |                       | <ul> <li>Verilog HDL black box file (&lt;<i>function name</i>&gt;_bb.v)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                       |
|                                          |                       | <ul> <li>Synthesis area and timing estimation netlist<br/>(_syn.v) <sup>(6)</sup></li> </ul>                                                                                                                                                                                                                                                                                                                                                                             |
|                                          |                       | For more information about the wizard-generated files,<br>refer to Quartus II Help or to the <i>Recommended HDL</i><br><i>Coding Styles</i> chapter in volume 1 of the <i>Quartus II</i><br><i>Handbook</i> .                                                                                                                                                                                                                                                            |

#### Table 2–1. ALTCLKCTRL MegaWizard Plug-In Manager Page Options and Description (Part 3 of 3)

#### Notes to Table 2-1:

(1) This option is not supported in Cyclone II and Cyclone III devices.

(2) This option is not supported in Arria GX, Cyclone II, Cyclone III, Hardcopy II, Stratix II, and Stratix II GX devices.

- (3) You can change the number of clock inputs only if you choose the Auto or For global clock options.
- (4) Not supported if you choose the For periphery clock option.

(5) The Variation file contains wrapper code in the language you specified on page 2a and is automatically generated.

(6) The synthesis area and timing estimation netlist file (\_syn.v) is automatically generated if the Generate netlist option on page 4 is turned on.

# **Command Line Interface Parameters**

Expert users can choose to instantiate and parameterize the megafunction through the command-line interface using the clear box generator command. This method requires you to have command-line scripting knowledge.

**For more information about using the clear box generator, refer to the** *Introduction to Megafunctions User Guide*.

Table 2–2 lists the parameters for the ALTCLKCTRL megafunction.

| Parameter Name                                 | Туре    | Required | Comments                                                                                                                                                                                                                                                                           |                               |                                                            |
|------------------------------------------------|---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------------------------------------------------------------|
|                                                |         |          | This para                                                                                                                                                                                                                                                                          | meter specifie                | s the operation mode. The values are:                      |
|                                                |         |          |                                                                                                                                                                                                                                                                                    | Value                         | Signal Selection                                           |
|                                                |         |          |                                                                                                                                                                                                                                                                                    | AUTO                          | Auto-selected clock<br>(default value)                     |
|                                                | Ctring  | Vee      |                                                                                                                                                                                                                                                                                    | GCLK                          | Global clock                                               |
| clock_type                                     | String  | res      |                                                                                                                                                                                                                                                                                    | LCLK                          | Regional clock                                             |
|                                                |         |          |                                                                                                                                                                                                                                                                                    | EXTCLK                        | External clock                                             |
|                                                |         |          |                                                                                                                                                                                                                                                                                    | SIDE_CLK                      | Dual-regional clock                                        |
|                                                |         |          | The clks clock_ty                                                                                                                                                                                                                                                                  | elect and en<br>ype parameter | a ports are unavailable if the r is set to <b>EXTCLK</b> . |
| ena_register_mode                              | String  | No       | Register mode for the ena port. Values are <b>NONE</b> ,<br><b>FALLING_EDGE</b> , and <b>DOUBLE_REGISTER</b> . Only available in<br>Stratix III and Stratix IV devices.                                                                                                            |                               |                                                            |
| lpm_hint                                       | String  | No       | Allows you to specify Altera-specific parameters in VHDL Design Files (. <b>vhd</b> ). The default value is <b>UNUSED</b> .                                                                                                                                                        |                               |                                                            |
| lpm_type                                       | String  | No       | Identifies the library of parameterized modules (LPM) entity name in VHDL Design Files ( <b>.vhd</b> ).                                                                                                                                                                            |                               |                                                            |
| intended_device_family                         | String  | No       | Used for modeling and behavioral simulation purposes. Create the ALTCLKCTRL megafunction with the MegaWizard Plug-In Manager to get the value for this parameter.                                                                                                                  |                               |                                                            |
| implement_in_les                               | String  | No       | Specifies if you want the clock control unit to be implemented using logic elements (LEs). Values are " <b>ON</b> " or " <b>OFF</b> ". The default setting is " <b>OFF</b> ".                                                                                                      |                               |                                                            |
| number_of_clocks                               | Integer | Yes      | Specifies the number of global-type clock inputs. Values are numeric type (1 to 4). For other clock types, only one clock input is accepted.                                                                                                                                       |                               |                                                            |
| use_glitch_free_switch_over<br>_implementation | String  | No       | Specifies if you want to implement a glitch-free switchover<br>when you use multiple clock inputs. Values are " <b>ON</b> " and<br>" <b>OFF</b> ". If ommited, the default setting is " <b>OFF</b> ".                                                                              |                               |                                                            |
| width_select                                   | Integer | Yes      | Specifies the width of the clock select when you use multiple clock inputs. The clock select inputs dynamically selects the clock source that drives the clock network. The values are <b>1</b> or <b>2</b> . If ommited, the default value is <b>1</b> , which means 1-bit width. |                               |                                                            |

Table 2–2. ALTCLKCTRL Megafunction Parameters



This chapter describes the functional description and the design examples of the ALTCLKCTRL megafunction. This section also includes the prototype, component declarations, and the ports descriptions of the ALTCLKCTRL megafunction. You can use the ports to customize the ALTCLKCTRL megafunction according to your application.

## **Clock Control Block**

A clock control block is a dynamic clock buffer that allows you to enable and disable the clock network and dynamically switch between multiple sources to drive the clock network. Table 3–1 shows the clock control block and the devices that support it.

Table 3–1. Clock Buffers that Drive the Clock Control Block

| Clock Control<br>Block                  | Arria GX | Stratix IV | Stratix III  | Stratix II | Stratix II GX | Cyclone III | Cyclone II | HardCopy II  |
|-----------------------------------------|----------|------------|--------------|------------|---------------|-------------|------------|--------------|
| Global Clock<br>Network                 | ~        | ~          | $\checkmark$ | ~          | ~             | ~           | ~          | ~            |
| Dual Regional<br>Clock Network          | ~        | ~          | $\checkmark$ | ~          | ~             | _           | _          | $\checkmark$ |
| Regional<br>Clock Network               | ~        | ~          | $\checkmark$ | ~          | ~             | _           | _          | $\checkmark$ |
| Dedicated<br>External Clock<br>Out Path | ~        | ~          | ~            | ~          | ~             | ~           | ~          | ~            |
| For Periphery<br>Clock                  | —        | ~          | —            | —          | _             | _           | —          | —            |

The global clock network allows a clock signal (or other global signals) to reach all parts of the chip with a similar amount of skew. The regional clock network allows a signal to reach one quadrant of the chip (though half of the chip can be reached by driving two quadrants). The external clock-out path represents the clock path from the outputs of the phase-locked loop (PLL) to the dedicated PLL\_OUT pins. The ALTCLKCTRL megafunction also provides glitch-free implementation for multiple clock input signals.

You must ensure the clock that is currently selected is running before switching to another source. If the selected clock is not running, the glitch-free switchover implementation will not be able to switch to the new clock source.

### **Global Clock Control Block**

When a clock control block is configured to drive a global clock network, you can select the clock source statically or you can control the selection dynamically by using internal logic to drive multiplexer selector inputs. When selecting the clock source statically, you can set the clock source to any of the inputs. For example, you can use the dedicated CLK pin, internal logic, and PLL outputs.

When selecting the clock source dynamically, you can select two PLL outputs (such as c0 or c1), a combination of clock pins, or PLL outputs. Figure 3–1 shows a clock control block and the possible sources that can drive the global clock network in a Stratix II device.



#### Figure 3–1. Global Clock Control Block in Stratix II Devices

#### Notes to Figure 3-1:

- (1) You can dynamically control these clock select signals through internal logic only when the device is operating in user mode.
- (2) You can only set these clock select signals through a configuration file and cannot be dynamically controlled during user-mode operation.

### **Regional Clock Control Block**

When the clock control block is configured to drive a regional clock network, you can only control the clock source selection statically. You can set any inputs to the clock select multiplexer as the clock source. Figure 3–2 shows a clock control block configured to drive a regional clock network in a Stratix II device.

#### Figure 3–2. Regional Clock Control Block in Stratix II Devices



#### Notes to Figure 3-2:

- (1) You can only control these clock select signals through a configuration file and cannot be dynamically controlled during user-mode operation.
- (2) Only the CLKn pins on the top and bottom of the device feed to the regional clock control blocks.

The unused global and regional clock networks are powered down automatically in the configuration file generated by the Quartus II software. The dynamic clock enable feature allows the internal logic to control the power for the GCLK and RCLK networks. You can enable or disable the clock network with the ALTCLKCTRL megafunction.

### **External PLL Output Clock Control Block**

When the clock control block is configured to drive the dedicated external clock out, you can only control the clock source selection statically. You can only set the PLL outputs as the clock source. Figure 3–3 shows a clock control block configured to drive a dedicated external clock out for Stratix II devices.

Figure 3–3. External PLL Output Clock Control Block in Stratix II Devices (1)



#### Notes to Figure 3-3:

- (1) The clock control block feeds to a multiplexer within the PLL\_OUT pin's I/O element (IOE). The PLL\_OUT pin is a dualpurpose pin. Therefore, this multiplexer selects either an internal signal or the output of the clock control block.
- (2) You can only set these clock select signals through the configuration file and cannot be dynamically controlled during user-mode operation.

### **Clock Enable Signals**

In Stratix II devices, the clock enable signals are supported at the clock network level. This allows you to enable or disable the GCLK and RCLK networks, or the PLL\_OUT pins, which is useful for applications that require low power or sleep mode. Figure 3–4 shows how the ena clock enable signal is implemented.

#### Figure 3–4. Clock Enable Implementation in Stratix II Devices



### **Clock Enable Timing**

Figure 3–5 shows a functional timing waveform example for clock-output enable. Clock enable is synchronous with the falling edge of the input clock.

#### Figure 3–5. Clock Enable Timing



### **Connectivity Restrictions**

The following section describes the restrictions associated with the signal sources that can drive the inclk[] input.

#### **General Restrictions**

- The inclk[] ports that you use must be consistent with the clkselect[] ports that you use. For more information about how clkselect[1..0] maps to inclk[0.3]x, refer to Table 3–4 on page 3–9.
- When you are using multiple input sources, the inclk[]ports can only be driven by the dedicated clock input pins and the PLL clock outputs. Dedicated clock input pins must feed only inclk[0] and inclk[1], while the PLL clock outputs must feed only inclk[2] and inclk[3].
- If the clock control block feeds any inclk[] port of another clock control block, both must be able to be reduced to a single clock control block of equivalent functionality.
- When you are using the glitch free switchover feature, the clock you are switching from must be active. If it is not active, the switchover circuit will not be able to transition from the clock you originally selected.

#### **Stratix II Devices Restrictions**

- When connecting dedicated clock input pins to inclk0x and inclk1x, you must connect the low order CLK pin to inclk0x and the high order CLK pin to inclk1x. For example, if you are connecting CLK14p and CLK15p to a clock control block, CLK14p must connect to inclk0x and CLK15p must connect to inclk1x. The Quartus II software has the ability in most cases to swap ports as required, but this can help to solve errors that you may encounter in the Quartus II fitter.
- When connecting PLL output ports to inclk2x and inclk3x, you must connect the low order PLL port to inclk2x and the high order PLL port to inclk3x. For example, if you are connecting PLL output ports C0 and C1 to a clock control block, C0 must connect to inclk2x and C1 must connect to inclk3x. The Quartus II software has the ability in most cases to swap ports as required, but this can help to solve errors that you may encounter in the Quartus II fitter.

For more information about valid connectivity configurations, refer to the *Clocking* section of the PLL chapter in the handbook of the device family you are using. Each global and regional resource has a clock control block. Use the information shown in the *Clocking* section of the handbook to determine the valid dedicated clock pin and PLL output port resources which can feed any global or regional resource through a clock control block.

Table 3–2 summarizes which ports are used by the different clock control block types. If a port is not available for a particular clock network, clock control block placement is restricted to only the clock network types that support that port.

| Port           | Global             | Regional          | External Clock    |
|----------------|--------------------|-------------------|-------------------|
| inclk[30]      | Has all four ports | Has only inclk[0] | Has only inclk[0] |
| clkselect[1:0] | Yes                | No                | No                |
| ena            | Yes                | Yes               | Yes               |
| outclk         | Yes                | Yes               | Yes               |

Table 3–2. ALTCLKCTRL Megafunction Clock Control Block Port Usage

As shown in Table 3–2, all clock buffer types support the clock enable feature, while only the global clock network supports the dynamic clock source selection feature.

If the CLOCK\_TYPE value is set to **AUTO**, the Quartus II software selects the clock control block type that meets all the requirements. For example, if you use the dynamic clock source selection and the clock control block feeds a pin, a global clock control block is used. Similarly, if the clock control block feeds a pin that cannot be reached by the PLL using an external clock output path (in other words, not a dedicated clock path), a global clock network is used. In this case, a warning message about the "irregular" path to the pin is issued.

You can also instantiate a clock block in HDL without specifying the clock\_type parameter or setting the clock type to the default value, **Auto**, and use a global signal assignment in the assignment editor to control the clock resource. This method allows you to change the clock resource without resynthesizing the design. In the assignment editor, use the following assignment example:

<instantiation name>|altclkctrl\_<unique\_part>:auto\_generated|outclk.

# **Design Example: Global Clock Buffer**

This design example uses the ALTCLKCTRL megafunction to select clock signals from the PLL outputs and dedicated clock pins in the Stratix II device. This example uses the MegaWizard Plug-In Manager in the Quartus II software.

In this example, perform the following:

- Generate a clock control block using the ALTCLKCTRL megafunction in the MegaWizard Plug-In Manager
- Simulate the design in the ModelSim<sup>®</sup>-Altera software

The design examples are available for download from the following locations:

- On the Documentation: Quartus II Development Software page, expand the Using Megafunctions section and then expand the I/O section.
- On the Documentation: User Guides section of the Altera website.

To select clock signals from the PLL outputs and dedicated clock pins in the Stratix II device, follow these steps:

- 1. Open altclkctrl\_DesignExample.zip and extract altclkctrl\_ex.qar.
- 2. In the Quartus II software, open **altclkctrl\_ex.qar** and restore the archive file into your working directory.
- 3. Open the top-level file, altclkctrl\_ex.bdf.
- 4. Double-click on a blank area in the schematic.
- 5. In the Symbol window, click on the **MegaWizard Plug-In Manager** button. Page 1 of the MegaWizard Plug-In Manager appears.
- 6. Select Create a new custom megafunction variation.
- 7. Click Next. Page 2a of the MegaWizard Plug-In Manager appears.
- 8. In the MegaWizard Plug-In Manager pages, select or verify the configuration settings shown in Table 3–3. Click **Next** to advance from one page to the next.

Table 3–3. Configuration Settings for ALTCLKCTRL Design Example (Part 1 of 2)

| MegaWizard<br>Plug-in<br>Manager Page | Configuration Setting                                                          | Value            |
|---------------------------------------|--------------------------------------------------------------------------------|------------------|
|                                       | Which megafunction would you like to customize?                                | ALTCLKCTRL       |
| 0.0                                   | Which device family will you be using?                                         | Stratix II       |
| Zd                                    | Which type of output file do you want to create?                               | AHDL             |
|                                       | What name do you want for the output file?                                     | clkctrl_gclk     |
|                                       | Currently selected device family                                               | Stratix II       |
|                                       | Match project/default                                                          | Selected         |
|                                       | How do you want to use the altclkctrl?                                         | For global clock |
| 3                                     | How many clock inputs would you like?                                          | 4                |
|                                       | Create 'ena' port to enable or disable the clock network driven by this buffer | Selected         |
|                                       | Ensure glitch-free switchover implementation                                   | Selected         |

| MegaWizard<br>Plug-in<br>Manager Page | Configuration Setting                        | Value    |
|---------------------------------------|----------------------------------------------|----------|
| 4                                     | Generate netlist                             | Selected |
|                                       | Variation file                               | Selected |
|                                       | AHDL Include file                            | Selected |
|                                       | VHDL component declaration file              | Selected |
| 5                                     | Quartus II symbol file                       | Selected |
|                                       | Instantiation template file                  | Selected |
|                                       | Verilog HDL black-box file                   | Selected |
|                                       | Synthesis area and timing estimation netlist | Selected |

 Table 3–3. Configuration Settings for ALTCLKCTRL Design Example (Part 2 of 2)

- 9. Click **Finish**. The clkctrl\_gclk module is now built.
- 10. In the Symbol window, click **OK**.
- 11. Move the mouse to align the clkctrl\_gclk symbol with the existing ports in the **altclkctrl\_ex.bdf**. Click to place the symbol. You have now completed the design file.
- 12. On the File menu, click **Save**.
- 13. Run a full compilation.

### **Functional Simulation in the ModelSim-Altera Software**

Simulate the clock control block design in the ModelSim-Altera software to generate a waveform display of the device behavior. You should be familiar with the ModelSim-Altera software before using the design examples. To get started with the ModelSim-Altera software, refer to the ModelSim-Altera Software Support page on the Altera website. The support page includes links to such topics as installation, usage, and troubleshooting.

Set up and simulate the design in the ModelSim-Altera software by performing the following steps:

- 1. Unzip the altclkctrl\_ex\_msim.zip file to any working directory on your PC.
- 2. Start the ModelSim-Altera software.
- 3. On the File menu, click Change Directory.
- 4. Select the folder in which you unzipped the files.
- 5. Click OK.
- 6. On the Tools menu, select TCL, then click Execute Macro.
- 7. Select the **altclkctrl\_ex\_msim.do** file and click **Open**. The **altclkctrl\_ex\_msim.do** file is a script file for the ModelSim-Altera software to automate all the necessary settings for the simulation.
- 8. Verify the results shown in the Waveform Viewer window with the expected waveform in Figure 3–6.

You can rearrange signals, remove signals, add signals, and change the radix by modifying the script in **altclkctrl\_ex\_msim.do** accordingly.

Figure 3–6 shows the expected simulation results in the ModelSim-Altera software.



Figure 3–6. ModelSim-Altera Simulation Waveforms

The objective of the functional simulation waveform is to highlight the dynamic clock switching process. The design example uses four clock input ports named inclk3*x*, inclk2*x*, inclk1*x*, and inclk0*x* with the output enable port named ena. Output is enabled when the ena port is asserted.

The megafunction uses a built-in multiplexer to output the selected clock at outlck based on the value of clkselect[1..0]. Observe the behavior of the clkout signal whenever the value of clkselect[1..0] changes. When the clkselect[1..0] value is "00", the inclk0x signal is output to outclk port. When the clkselect[1..0] signal changes to "01", the outclk port takes the value of the inclk1x signal. This behavior is described in Table 3–4. The value of clkselect[1..0] determines the signal selection of outclk.

| clkselect[10] | outcik  |
|---------------|---------|
| 00            | inclk0x |
| 01            | inclk1x |
| 10            | inclk2x |
| 11            | inclk3x |

Table 3–4. Clock Input Selection

# **ALTCLKCTRL Megafunction Ports**

Table 3–5 and Table 3–6 lists the input and output ports for the ALTCLKCTRL megafunction.

### **Input Ports**

| Table 3–5. | ALTCLKCTRL            | Megafunction | Input Ports  |
|------------|-----------------------|--------------|--------------|
|            | <b>AEI OENO I IIE</b> | mogaranotion | input i oito |

| Port Name   | Required | Description                                                                                                             | Comments                                                                                                                                                                              |  |
|-------------|----------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|             |          | Input that dynamically selects<br>the clock source to drive the<br>clock network that is driven by<br>the clock buffer. | Input port[1 downto 0] wide.                                                                                                                                                          |  |
|             |          |                                                                                                                         | If omitted, the default is <b>GND</b> .                                                                                                                                               |  |
|             |          |                                                                                                                         | If this signal is connected, only the global clock<br>network can be driven by this clock control block.                                                                              |  |
| clkselect[] | No       |                                                                                                                         | Binary Value Signal Selection                                                                                                                                                         |  |
|             |          |                                                                                                                         | 00 inclk[0]                                                                                                                                                                           |  |
|             |          |                                                                                                                         | 01 inclk[1]                                                                                                                                                                           |  |
|             |          |                                                                                                                         | 10 inclk[2]                                                                                                                                                                           |  |
|             |          |                                                                                                                         | 11 inclk[3]                                                                                                                                                                           |  |
|             |          |                                                                                                                         | If omitted, the default value is $\mathbf{V}_{cc}$ ,                                                                                                                                  |  |
| ena         | No       | Clock enable of the clock buffer                                                                                        | This option cannot be used for the external clock output path in Cyclone <sup>®</sup> II device, and periphery clock network path in Stratix <sup>®</sup> III and Stratix IV devices. |  |
| inclk[]     | Yes      | Clock input of the clock buffer                                                                                         | Input port [3 DOWNTO 0] wide.                                                                                                                                                         |  |
|             |          |                                                                                                                         | You can specify up to four clock inputs, inclk[3:0].                                                                                                                                  |  |
|             |          |                                                                                                                         | Clock pins, clock outputs from the PLL, and core signals can drive the inclk[] port.                                                                                                  |  |
|             |          |                                                                                                                         | Multiple clock inputs are only supported for the global and auto-selected clock networks.                                                                                             |  |

### **Output Ports**

#### Table 3–6. ALTCLKCTRL Megafunction Output Ports

| Port Name | Required | Description                 | Comments |
|-----------|----------|-----------------------------|----------|
| outclk    | Yes      | Output of the clock buffer. | —        |

### **Prototypes and Component Declarations**

This section describes the prototypes and component declarations of the ALTCLKCTRL megafunction.

### **Verilog HDL Prototype**

You can locate the following Verilog HDL prototype in the Verilog Design File (.v) **altera\_mf.v** in the *<Quartus II installation directory>*\**eda\synthesis** directory.

```
module altclkctrl
```

```
#( parameter
               clock_type = "AUTO",
   parameter
               intended_device_family = "unused",
   parameter
               ena_register_mode = "falling edge",
   parameter
               implement_in_les = "OFF",
   parameter
              number_of_clocks = 4,
               use_glitch_free_switch_over_implementation = "OFF",
   parameter
              width_clkselect = 2,
   parameter
              lpm_type = "altclkctrl",
   parameter
   parameter lpm_hint = "unused")
   input
                   [width_clkselect-1:0] clkselect,
(
           wire
   input
           wire
                   ena,
                   [number_of_clocks-1:0] inclk,
   input
           wire
   output wire
                   outclk)/* synthesis syn_black_box=1 */;
endmodule //altclkctrl
```

### **VHDL Component Declaration**

The following VHDL component declaration is located in the VHDL Design File (.vhd) altera\_mf\_components.vhd in the <*Quartus II installation directory*>\libraries\vhdl\altera\_mf directory.

```
component altclkctrl
generic (
    clock_type:string := "AUTO";
    intended_device_family:string := "unused";
    ena_register_mode:string := "falling edge";
    implement_in_les:string := "OFF";
    number_of_clocks:natural := 4;
    use_glitch_free_switch_over_implementation:string := "OFF";
    width_clkselect:natural := 2;
    lpm_hint:string := "UNUSED";
    lpm_type:string := "altclkctrl"
    );
    port(
```

```
clkselect:in std_logic_vector(width_clkselect-1 downto 0) :=
(others => '0');
    ena: in std_logic := '1';
    inclk: in std_logic_vector(number_of_clocks-1 downto 0) :=
(others => '0');
    outclk:out std_logic
    );
end component;
```

### **VHDL LIBRARY-USE Declaration**

The VHDL LIBRARY-USE declaration is not required if you use the VHDL component declaration.

```
LIBRARY altera_mf;
USE altera_mf.altera_mf_components.all;
```



This chapter provides additional information about the document and Altera.

# **Document Revision History**

The following table lists the revision history for this document.

| Date              | Version | Changes                                                                                                                                                                                                                                                                   |  |
|-------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| February 0010     | 2.0     | <ul> <li>Updated information for switchover usage.</li> </ul>                                                                                                                                                                                                             |  |
| February 2012 3.0 |         | <ul> <li>Added a note about assigning clock type through assignment editor.</li> </ul>                                                                                                                                                                                    |  |
| September 2010    | 2.5     | Updated ports and parameters                                                                                                                                                                                                                                              |  |
|                   |         | <ul> <li>Updated the following sections:</li> </ul>                                                                                                                                                                                                                       |  |
|                   |         | <ul> <li>"Device Family Support" section</li> </ul>                                                                                                                                                                                                                       |  |
|                   |         | <ul> <li>"Introduction" section</li> </ul>                                                                                                                                                                                                                                |  |
|                   |         | <ul> <li>"General Description" section</li> </ul>                                                                                                                                                                                                                         |  |
|                   |         | <ul> <li>"Design Example: Global Clock Buffer" section</li> </ul>                                                                                                                                                                                                         |  |
|                   |         | <ul> <li>"Functional Simulation in the ModelSim-Altera Software" section</li> </ul>                                                                                                                                                                                       |  |
|                   |         | <ul> <li>"This chapter describes the prototype, component declaration, ports, and parameters<br/>of the ALTCLKCTRL megafunction. These ports and parameters are available to<br/>customize the ALTCLKCTRL megafunction according to your application." section</li> </ul> |  |
|                   |         | <ul> <li>"How to Contact Altera" section</li> </ul>                                                                                                                                                                                                                       |  |
|                   |         | Removed the following sections:                                                                                                                                                                                                                                           |  |
| December 2008     | 2.4     | <ul> <li>"Resource Utilization &amp; Performance" section</li> </ul>                                                                                                                                                                                                      |  |
|                   |         | <ul> <li>"Software and System Requirements" section</li> </ul>                                                                                                                                                                                                            |  |
|                   |         | <ul> <li>"Inferring Megafunctions from HDL Code" section</li> </ul>                                                                                                                                                                                                       |  |
|                   |         | <ul> <li>"Instantiating Megafunctions in HDL Code or Schematic Designs" section</li> </ul>                                                                                                                                                                                |  |
|                   |         | <ul> <li>"Identifying a Megafunction after Compilation" section</li> </ul>                                                                                                                                                                                                |  |
|                   |         | <ul> <li>"SignalTap II Embedded Logic Analyzer" section</li> </ul>                                                                                                                                                                                                        |  |
|                   |         | <ul> <li>Removed all screenshots in the "MegaWizard Plug-In Manager Page Descriptions"<br/>section</li> </ul>                                                                                                                                                             |  |
|                   |         | <ul> <li>Reorganized the "MegaWizard Plug-In Manager Page Descriptions" section into table<br/>format.</li> </ul>                                                                                                                                                         |  |
|                   |         | <ul> <li>Renamed "About this User Guide" section to "Additional Information" and moved the<br/>section to the end of the user guide.</li> </ul>                                                                                                                           |  |
| May 2007          |         | Updated for Quartus II software version 7.1, including:                                                                                                                                                                                                                   |  |
|                   | 2.3     | <ul> <li>Added information on Cyclone<sup>®</sup> III and Arria<sup>®</sup> GX device support</li> </ul>                                                                                                                                                                  |  |
|                   |         | <ul> <li>Added Referenced Documents section</li> </ul>                                                                                                                                                                                                                    |  |
| March 2007        | 2.2     | Added Cyclone III device to list of supported devices.                                                                                                                                                                                                                    |  |
| December 2006     | 2.1     | Updated device family support to include Stratix <sup>®</sup> III devices.                                                                                                                                                                                                |  |

| Date           | Version | Changes                                           |
|----------------|---------|---------------------------------------------------|
|                |         | Updated for Quartus II version 6.0, including     |
| October 2006   | 2.0     | <ul> <li>Screen shots</li> </ul>                  |
|                |         | <ul> <li>ModelSim section in Chapter 2</li> </ul> |
| September 2004 | 1.0     | Initial release                                   |

## **How to Contact Altera**

To locate the most up-to-date information about Altera products, refer to the following table.

| Contact <sup>(1)</sup>         | Contact Method | Address                   |
|--------------------------------|----------------|---------------------------|
| Technical support              | Website        | www.altera.com/support    |
| Technical training             | Website        | www.altera.com/training   |
| rechinical training            | Email          | custrain@altera.com       |
| Product literature             | Website        | www.altera.com/literature |
| Nontechnical support (general) | Email          | nacomp@altera.com         |
| (software licensing)           | Email          | authorization@altera.com  |

#### Note to Table:

(1) You can also contact your local Altera sales office or sales representative.

# **Typographic Conventions**

The following table shows the typographic conventions this document uses.

| Visual Cue                                | Meaning                                                                                                                                                                                                                       |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bold Type with Initial Capital<br>Letters | Indicate command names, dialog box titles, dialog box options, and other GUI labels. For example, <b>Save As</b> dialog box. For GUI elements, capitalization matches the GUI.                                                |
| bold type                                 | Indicates directory names, project names, disk drive names, file names, file name extensions, software utility names, and GUI labels. For example, <b>\qdesigns</b> directory, <b>D:</b> drive, and <b>chiptrip.gdf</b> file. |
| Italic Type with Initial Capital Letters  | Indicate document titles. For example, Stratix IV Design Guidelines.                                                                                                                                                          |
|                                           | Indicates variables. For example, $n + 1$ .                                                                                                                                                                                   |
| italic type                               | Variable names are enclosed in angle brackets (< >). For example, <i><file name=""></file></i> and <i><project name="">.pof</project></i> file.                                                                               |
| Initial Capital Letters                   | Indicate keyboard keys and menu names. For example, the Delete key and the Options menu.                                                                                                                                      |
| "Subheading Title"                        | Quotation marks indicate references to sections in a document and titles of Quartus II Help topics. For example, "Typographic Conventions."                                                                                   |

| Visual Cue                               | Meaning                                                                                                                                                                                |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          | Indicates signal, port, register, bit, block, and primitive names. For example, data1, tdi, and input. The suffix n denotes an active-low signal. For example, resetn.                 |
| Courier type                             | Indicates command line commands and anything that must be typed exactly as it appears. For example, c:\qdesigns\tutorial\chiptrip.gdf.                                                 |
|                                          | Also indicates sections of an actual file, such as a Report File, references to parts of files (for example, the AHDL keyword SUBDESIGN), and logic function names (for example, TRI). |
| 4                                        | An angled arrow instructs you to press the Enter key.                                                                                                                                  |
| 1., 2., 3., and<br>a., b., c., and so on | Numbered steps indicate a list of items when the sequence of the items is important, such as the steps listed in a procedure.                                                          |
|                                          | Bullets indicate a list of items when the sequence of the items is not important.                                                                                                      |
| 17                                       | The hand points to information that requires special attention.                                                                                                                        |
| ?                                        | The question mark directs you to a software help system with related information.                                                                                                      |
|                                          | The feet direct you to another document or website with related information.                                                                                                           |
|                                          | The multimedia icon directs you to a related multimedia presentation.                                                                                                                  |
| CAUTION                                  | A caution calls attention to a condition or possible situation that can damage or destroy the product or your work.                                                                    |
| WARNING                                  | A warning calls attention to a condition or possible situation that can cause you injury.                                                                                              |
|                                          | The envelope links to the Email Subscription Management Center page of the Altera website, where you can sign up to receive update notifications for Altera documents.                 |