Intel® Quartus® Prime Software
Intel® Quartus® Prime Design Software, Design Entry, Synthesis, Simulation, Verification, Timing Analysis, System Design (Platform Designer, formerly Qsys)
16808 Discussions

TimeQuest can't analysis the clock from the PLL

NuvKFC
New Contributor I
2,796 Views

The problem is as follows.

I need a MUX to switch the clock between normal mode and test mode. And I don't care about any transient state when clock switching. 

The ending shows the design. 'pll_c4_sw' is the switched output clock. Some IP use 'pll_c4_sw' as a clock.  'pll_c4' is the clock from the PLL. 'clk_pin' is the input clock from the combinational circuit.

( I use ALTPLL to generate pll_c0~pll_c5.

 

Unfortunately, Quartus13.1 tell me that "PLL "pll|altpll_component|auto_generated|pll1" has parameters clk4_multiply_by and clk4_divide_by specified but port CLK[4] is not connected." when I use the Stratix III device. TimeQuest can't also analysis the timing on pll_c4 becuse TimeQuest can't find pll_c4 which is equal to clk[4] after Fitter.

 

Could someone please  tell me what happen there? Thank you very much.

 

Design:

        assign pll_c4_sw = sel? pll_c4 : clk_pin;

NuvKFC_0-1624438775748.png

SDC command:

create_generated_clock -name pll_c4 -source [get_pins pll|altpll_component|auto_generated|pll1|inclk[0]] -multiply_by 1 -divide_by 4 [get_pins pll|altpll_component|auto_generated|pll1|clk[4]]

0 Kudos
1 Solution
NuvKFC
New Contributor I
2,655 Views

Hi SyafieqS_Intel, finally, I use the command, /*synthesis keep */, to keep relative port so that TimeQuest can find the CLK[4] port of the PLL.

The CLK[4] port of the PLL in post-fit is "pll|altpll_component|auto_generated|pll1|clk[4]". Thank you, SyafieqS_Intel, very much.

View solution in original post

0 Kudos
8 Replies
sstrell
Honored Contributor III
2,777 Views

Are you saying the design doesn't synthesize?  Maybe you have illegal PLL settings.

Can you show screenshots of the parameter editor (Megawizard)?

0 Kudos
NuvKFC
New Contributor I
2,764 Views

Hi sstrell, thank for your suggestion.

The design can be synthesized and APR. Unfortunately, Quartus13.1 miss the CLK[4] port of PLL after Fitter so that  TimeQuest can't find the CLK[4] port of PLL to analysis. Following pictures are the PLL Megawizard and PLL usage. The differences among clocks of PLL only are the multiply parameter and divide parameter. I don't know what's wrong here.

 

Warning: CLK[4] isn't connected.

NuvKFC_6-1624501750918.png

 

PLL Megawizard:

NuvKFC_0-1624501185682.pngNuvKFC_1-1624501239517.pngNuvKFC_2-1624501297933.png

 

PLL usage:

NuvKFC_4-1624501423147.png

NuvKFC_5-1624501447281.png

 

 

0 Kudos
sstrell
Honored Contributor III
2,733 Views

What is the logic for sel to the mux?  If it's not switching, the clock may have been optimized away.  As you can see, clock 4 doesn't even show up in the PLL usage report.  This is why I suggested previously to add a clock control block and use the switching there instead of creating a mux like this.

You can try to confirm the clock was optimized away by looking at the post-fit Technology Map Viewer and see if you see the clock coming out of the PLL at all.  You could also check the compilation report for warning messages about the clock being optimized away or other reasons why it may have disappeared.

0 Kudos
NuvKFC
New Contributor I
2,722 Views

Hi sstrell, thank for your suggestion.

The 'sel' signal is from a register. It can be read or write by CPU. The 'sel' signal can be toggled. How to check that Quartus will optimize this signal?

 

Unfortunately, Quartus tells me that I can't use ALTCLKCTRL Megawizard function to switch clock because Quartus said that the 'clk_pin' signal is from a COMBOUT so that Quartus can't synthesis it. Can I do something else to fix this?

 

OK, I will try to check in post-fit by the Technology Map Viewer and warning messages. Could you please give some hint about how to check warning messages' by your experience? I only can find the warning message like the following picture when I key in the keyword 'pll*clk'.

NuvKFC_0-1624593776662.png

 

Thank you very much.

0 Kudos
SyafieqS
Employee
2,669 Views

Hi Kfc,


May I know if there is any updates?




0 Kudos
NuvKFC
New Contributor I
2,656 Views

Hi SyafieqS_Intel, finally, I use the command, /*synthesis keep */, to keep relative port so that TimeQuest can find the CLK[4] port of the PLL.

The CLK[4] port of the PLL in post-fit is "pll|altpll_component|auto_generated|pll1|clk[4]". Thank you, SyafieqS_Intel, very much.

0 Kudos
SyafieqS
Employee
2,634 Views

I’m glad that your question has been addressed, I now transition this thread to community support. If you have a new question, feel free to open a new thread to get the support from Intel experts. Otherwise, the community users will continue to help you on this thread. Thank you.


0 Kudos
NuvKFC
New Contributor I
2,575 Views

Hi SyafieqS_Intel, OK, no problem,. Thank you very much.

0 Kudos
Reply