repo2/papilioduo/pll/pll_pal.vhd @ 446
327 | markw | -- file: pll_pal.vhd
|
|
--
|
|||
-- (c) Copyright 2008 - 2011 Xilinx, Inc. All rights reserved.
|
|||
--
|
|||
-- This file contains confidential and proprietary information
|
|||
-- of Xilinx, Inc. and is protected under U.S. and
|
|||
-- international copyright and other intellectual property
|
|||
-- laws.
|
|||
--
|
|||
-- DISCLAIMER
|
|||
-- This disclaimer is not a license and does not grant any
|
|||
-- rights to the materials distributed herewith. Except as
|
|||
-- otherwise provided in a valid license issued to you by
|
|||
-- Xilinx, and to the maximum extent permitted by applicable
|
|||
-- law: (1) THESE MATERIALS ARE MADE AVAILABLE "AS IS" AND
|
|||
-- WITH ALL FAULTS, AND XILINX HEREBY DISCLAIMS ALL WARRANTIES
|
|||
-- AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING
|
|||
-- BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-
|
|||
-- INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and
|
|||
-- (2) Xilinx shall not be liable (whether in contract or tort,
|
|||
-- including negligence, or under any other theory of
|
|||
-- liability) for any loss or damage of any kind or nature
|
|||
-- related to, arising under or in connection with these
|
|||
-- materials, including for any direct, or any indirect,
|
|||
-- special, incidental, or consequential loss or damage
|
|||
-- (including loss of data, profits, goodwill, or any type of
|
|||
-- loss or damage suffered as a result of any action brought
|
|||
-- by a third party) even if such damage or loss was
|
|||
-- reasonably foreseeable or Xilinx had been advised of the
|
|||
-- possibility of the same.
|
|||
--
|
|||
-- CRITICAL APPLICATIONS
|
|||
-- Xilinx products are not designed or intended to be fail-
|
|||
-- safe, or for use in any application requiring fail-safe
|
|||
-- performance, such as life-support or safety devices or
|
|||
-- systems, Class III medical devices, nuclear facilities,
|
|||
-- applications related to the deployment of airbags, or any
|
|||
-- other applications that could lead to death, personal
|
|||
-- injury, or severe property or environmental damage
|
|||
-- (individually and collectively, "Critical
|
|||
-- Applications"). Customer assumes the sole risk and
|
|||
-- liability of any use of Xilinx products in Critical
|
|||
-- Applications, subject only to applicable laws and
|
|||
-- regulations governing limitations on product liability.
|
|||
--
|
|||
-- THIS COPYRIGHT NOTICE AND DISCLAIMER MUST BE RETAINED AS
|
|||
-- PART OF THIS FILE AT ALL TIMES.
|
|||
--
|
|||
------------------------------------------------------------------------------
|
|||
-- User entered comments
|
|||
------------------------------------------------------------------------------
|
|||
-- None
|
|||
--
|
|||
------------------------------------------------------------------------------
|
|||
-- "Output Output Phase Duty Pk-to-Pk Phase"
|
|||
-- "Clock Freq (MHz) (degrees) Cycle (%) Jitter (ps) Error (ps)"
|
|||
------------------------------------------------------------------------------
|
|||
-- CLK_OUT1____56.615______0.000______50.0______305.664____206.192
|
|||
--
|
|||
------------------------------------------------------------------------------
|
|||
-- "Input Clock Freq (MHz) Input Jitter (UI)"
|
|||
------------------------------------------------------------------------------
|
|||
-- __primary______________32____________0.010
|
|||
library ieee;
|
|||
use ieee.std_logic_1164.all;
|
|||
use ieee.std_logic_unsigned.all;
|
|||
use ieee.std_logic_arith.all;
|
|||
use ieee.numeric_std.all;
|
|||
library unisim;
|
|||
use unisim.vcomponents.all;
|
|||
entity pll_pal is
|
|||
port
|
|||
(-- Clock in ports
|
|||
CLK_IN1 : in std_logic;
|
|||
-- Clock out ports
|
|||
CLK_OUT1 : out std_logic;
|
|||
-- Status and control signals
|
|||
RESET : in std_logic;
|
|||
LOCKED : out std_logic
|
|||
);
|
|||
end pll_pal;
|
|||
architecture xilinx of pll_pal is
|
|||
attribute CORE_GENERATION_INFO : string;
|
|||
attribute CORE_GENERATION_INFO of xilinx : architecture is "pll_pal,clk_wiz_v3_6,{component_name=pll_pal,use_phase_alignment=true,use_min_o_jitter=false,use_max_i_jitter=false,use_dyn_phase_shift=false,use_inclk_switchover=false,use_dyn_reconfig=false,feedback_source=FDBK_AUTO,primtype_sel=PLL_BASE,num_out_clk=1,clkin1_period=31.250,clkin2_period=31.250,use_power_down=false,use_reset=true,use_locked=true,use_inclk_stopped=false,use_status=false,use_freeze=false,use_clk_valid=false,feedback_type=SINGLE,clock_mgr_type=AUTO,manual_override=false}";
|
|||
-- Input clock buffering / unused connectors
|
|||
signal clkin1 : std_logic;
|
|||
-- Output clock buffering / unused connectors
|
|||
signal clkfbout : std_logic;
|
|||
signal clkfbout_buf : std_logic;
|
|||
signal clkout0 : std_logic;
|
|||
signal clkout1_unused : std_logic;
|
|||
signal clkout2_unused : std_logic;
|
|||
signal clkout3_unused : std_logic;
|
|||
signal clkout4_unused : std_logic;
|
|||
signal clkout5_unused : std_logic;
|
|||
-- Unused status signals
|
|||
begin
|
|||
-- Input buffering
|
|||
--------------------------------------
|
|||
clkin1_buf : IBUFG
|
|||
port map
|
|||
(O => clkin1,
|
|||
I => CLK_IN1);
|
|||
-- Clocking primitive
|
|||
--------------------------------------
|
|||
-- Instantiation of the PLL primitive
|
|||
-- * Unused inputs are tied off
|
|||
-- * Unused outputs are labeled unused
|
|||
pll_base_inst : PLL_BASE
|
|||
generic map
|
|||
(BANDWIDTH => "OPTIMIZED",
|
|||
CLK_FEEDBACK => "CLKFBOUT",
|
|||
COMPENSATION => "SYSTEM_SYNCHRONOUS",
|
|||
DIVCLK_DIVIDE => 1,
|
|||
CLKFBOUT_MULT => 23,
|
|||
CLKFBOUT_PHASE => 0.000,
|
|||
CLKOUT0_DIVIDE => 13,
|
|||
CLKOUT0_PHASE => 0.000,
|
|||
CLKOUT0_DUTY_CYCLE => 0.500,
|
|||
CLKIN_PERIOD => 31.250,
|
|||
REF_JITTER => 0.010)
|
|||
port map
|
|||
-- Output clocks
|
|||
(CLKFBOUT => clkfbout,
|
|||
CLKOUT0 => clkout0,
|
|||
CLKOUT1 => clkout1_unused,
|
|||
CLKOUT2 => clkout2_unused,
|
|||
CLKOUT3 => clkout3_unused,
|
|||
CLKOUT4 => clkout4_unused,
|
|||
CLKOUT5 => clkout5_unused,
|
|||
-- Status and control signals
|
|||
LOCKED => LOCKED,
|
|||
RST => RESET,
|
|||
-- Input clock control
|
|||
CLKFBIN => clkfbout_buf,
|
|||
CLKIN => clkin1);
|
|||
-- Output buffering
|
|||
-------------------------------------
|
|||
clkf_buf : BUFG
|
|||
port map
|
|||
(O => clkfbout_buf,
|
|||
I => clkfbout);
|
|||
clkout1_buf : BUFG
|
|||
port map
|
|||
(O => CLK_OUT1,
|
|||
I => clkout0);
|
|||
end xilinx;
|