Can I program a platform independent PLL in VHDL?












5












$begingroup$


Most FPGA developement boards have a 50 MHz clock source onboard. However, the FPGAs are typically able to work faster than this. For multiplying the clock speed it seems to be needed to use a custom vendor specific IP of the FPGA, that must be configured and placed in the design.



Is there a way around this? Can I program/define my own PLL in VHDL, that is preferably synthesized using the internal hard coded PLL blocks of the FPGA and works for Altera and Xilinx without having to manually insert the PLL to a project via MegaWizard & Cons?










share|improve this question









$endgroup$








  • 2




    $begingroup$
    clock generation and distribution is, if you like, a 'level below' the standard logic fabric. There is so much riding on the cross chip skew, and power dissipation associated with huge nets, that it's optimised to the Nth for any particular device, family, vendor etc etc. You could make a generic multiplier, but you'd have to route it through the dedicated clock buffers into the clocking infrastructure, and then it wouldn't perform anything like the dedicated resources. With clocking, you just have to suck up what you're given on a part by part basis.
    $endgroup$
    – Neil_UK
    Jan 21 at 9:22






  • 1




    $begingroup$
    Besides the input @Neil_UK gave, why is the the IP a problem for you? You could just generate the IP than look into the generated files and if you are lucky the part of the code you are looking for isn't enrypted. Also, you can just write a code wrapper, like with constants and generate statements f.E. which instantiates the component depending on your hardware.
    $endgroup$
    – Eggi
    Jan 21 at 10:01










  • $begingroup$
    Yeah, that would be a possibility. However, is there any way to avoid those IP-Managers? Something like "#ifdef XILINX" constructs for actually using the one or the other generated IP dependent? --- Main issue is: I want to avoid using any GUI wizzards, instead have VHDL and other source files that might be generated by some external tool.
    $endgroup$
    – SDwarfs
    Jan 21 at 10:04










  • $begingroup$
    If you want ifdef's you should switch to Verilog. And I agree the Xilinx GUI was great until some @~$£%$ [censored] decided to go back to schematics.
    $endgroup$
    – Oldfart
    Jan 21 at 10:22
















5












$begingroup$


Most FPGA developement boards have a 50 MHz clock source onboard. However, the FPGAs are typically able to work faster than this. For multiplying the clock speed it seems to be needed to use a custom vendor specific IP of the FPGA, that must be configured and placed in the design.



Is there a way around this? Can I program/define my own PLL in VHDL, that is preferably synthesized using the internal hard coded PLL blocks of the FPGA and works for Altera and Xilinx without having to manually insert the PLL to a project via MegaWizard & Cons?










share|improve this question









$endgroup$








  • 2




    $begingroup$
    clock generation and distribution is, if you like, a 'level below' the standard logic fabric. There is so much riding on the cross chip skew, and power dissipation associated with huge nets, that it's optimised to the Nth for any particular device, family, vendor etc etc. You could make a generic multiplier, but you'd have to route it through the dedicated clock buffers into the clocking infrastructure, and then it wouldn't perform anything like the dedicated resources. With clocking, you just have to suck up what you're given on a part by part basis.
    $endgroup$
    – Neil_UK
    Jan 21 at 9:22






  • 1




    $begingroup$
    Besides the input @Neil_UK gave, why is the the IP a problem for you? You could just generate the IP than look into the generated files and if you are lucky the part of the code you are looking for isn't enrypted. Also, you can just write a code wrapper, like with constants and generate statements f.E. which instantiates the component depending on your hardware.
    $endgroup$
    – Eggi
    Jan 21 at 10:01










  • $begingroup$
    Yeah, that would be a possibility. However, is there any way to avoid those IP-Managers? Something like "#ifdef XILINX" constructs for actually using the one or the other generated IP dependent? --- Main issue is: I want to avoid using any GUI wizzards, instead have VHDL and other source files that might be generated by some external tool.
    $endgroup$
    – SDwarfs
    Jan 21 at 10:04










  • $begingroup$
    If you want ifdef's you should switch to Verilog. And I agree the Xilinx GUI was great until some @~$£%$ [censored] decided to go back to schematics.
    $endgroup$
    – Oldfart
    Jan 21 at 10:22














5












5








5





$begingroup$


Most FPGA developement boards have a 50 MHz clock source onboard. However, the FPGAs are typically able to work faster than this. For multiplying the clock speed it seems to be needed to use a custom vendor specific IP of the FPGA, that must be configured and placed in the design.



Is there a way around this? Can I program/define my own PLL in VHDL, that is preferably synthesized using the internal hard coded PLL blocks of the FPGA and works for Altera and Xilinx without having to manually insert the PLL to a project via MegaWizard & Cons?










share|improve this question









$endgroup$




Most FPGA developement boards have a 50 MHz clock source onboard. However, the FPGAs are typically able to work faster than this. For multiplying the clock speed it seems to be needed to use a custom vendor specific IP of the FPGA, that must be configured and placed in the design.



Is there a way around this? Can I program/define my own PLL in VHDL, that is preferably synthesized using the internal hard coded PLL blocks of the FPGA and works for Altera and Xilinx without having to manually insert the PLL to a project via MegaWizard & Cons?







fpga vhdl pll






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Jan 21 at 9:11









SDwarfsSDwarfs

47029




47029








  • 2




    $begingroup$
    clock generation and distribution is, if you like, a 'level below' the standard logic fabric. There is so much riding on the cross chip skew, and power dissipation associated with huge nets, that it's optimised to the Nth for any particular device, family, vendor etc etc. You could make a generic multiplier, but you'd have to route it through the dedicated clock buffers into the clocking infrastructure, and then it wouldn't perform anything like the dedicated resources. With clocking, you just have to suck up what you're given on a part by part basis.
    $endgroup$
    – Neil_UK
    Jan 21 at 9:22






  • 1




    $begingroup$
    Besides the input @Neil_UK gave, why is the the IP a problem for you? You could just generate the IP than look into the generated files and if you are lucky the part of the code you are looking for isn't enrypted. Also, you can just write a code wrapper, like with constants and generate statements f.E. which instantiates the component depending on your hardware.
    $endgroup$
    – Eggi
    Jan 21 at 10:01










  • $begingroup$
    Yeah, that would be a possibility. However, is there any way to avoid those IP-Managers? Something like "#ifdef XILINX" constructs for actually using the one or the other generated IP dependent? --- Main issue is: I want to avoid using any GUI wizzards, instead have VHDL and other source files that might be generated by some external tool.
    $endgroup$
    – SDwarfs
    Jan 21 at 10:04










  • $begingroup$
    If you want ifdef's you should switch to Verilog. And I agree the Xilinx GUI was great until some @~$£%$ [censored] decided to go back to schematics.
    $endgroup$
    – Oldfart
    Jan 21 at 10:22














  • 2




    $begingroup$
    clock generation and distribution is, if you like, a 'level below' the standard logic fabric. There is so much riding on the cross chip skew, and power dissipation associated with huge nets, that it's optimised to the Nth for any particular device, family, vendor etc etc. You could make a generic multiplier, but you'd have to route it through the dedicated clock buffers into the clocking infrastructure, and then it wouldn't perform anything like the dedicated resources. With clocking, you just have to suck up what you're given on a part by part basis.
    $endgroup$
    – Neil_UK
    Jan 21 at 9:22






  • 1




    $begingroup$
    Besides the input @Neil_UK gave, why is the the IP a problem for you? You could just generate the IP than look into the generated files and if you are lucky the part of the code you are looking for isn't enrypted. Also, you can just write a code wrapper, like with constants and generate statements f.E. which instantiates the component depending on your hardware.
    $endgroup$
    – Eggi
    Jan 21 at 10:01










  • $begingroup$
    Yeah, that would be a possibility. However, is there any way to avoid those IP-Managers? Something like "#ifdef XILINX" constructs for actually using the one or the other generated IP dependent? --- Main issue is: I want to avoid using any GUI wizzards, instead have VHDL and other source files that might be generated by some external tool.
    $endgroup$
    – SDwarfs
    Jan 21 at 10:04










  • $begingroup$
    If you want ifdef's you should switch to Verilog. And I agree the Xilinx GUI was great until some @~$£%$ [censored] decided to go back to schematics.
    $endgroup$
    – Oldfart
    Jan 21 at 10:22








2




2




$begingroup$
clock generation and distribution is, if you like, a 'level below' the standard logic fabric. There is so much riding on the cross chip skew, and power dissipation associated with huge nets, that it's optimised to the Nth for any particular device, family, vendor etc etc. You could make a generic multiplier, but you'd have to route it through the dedicated clock buffers into the clocking infrastructure, and then it wouldn't perform anything like the dedicated resources. With clocking, you just have to suck up what you're given on a part by part basis.
$endgroup$
– Neil_UK
Jan 21 at 9:22




$begingroup$
clock generation and distribution is, if you like, a 'level below' the standard logic fabric. There is so much riding on the cross chip skew, and power dissipation associated with huge nets, that it's optimised to the Nth for any particular device, family, vendor etc etc. You could make a generic multiplier, but you'd have to route it through the dedicated clock buffers into the clocking infrastructure, and then it wouldn't perform anything like the dedicated resources. With clocking, you just have to suck up what you're given on a part by part basis.
$endgroup$
– Neil_UK
Jan 21 at 9:22




1




1




$begingroup$
Besides the input @Neil_UK gave, why is the the IP a problem for you? You could just generate the IP than look into the generated files and if you are lucky the part of the code you are looking for isn't enrypted. Also, you can just write a code wrapper, like with constants and generate statements f.E. which instantiates the component depending on your hardware.
$endgroup$
– Eggi
Jan 21 at 10:01




$begingroup$
Besides the input @Neil_UK gave, why is the the IP a problem for you? You could just generate the IP than look into the generated files and if you are lucky the part of the code you are looking for isn't enrypted. Also, you can just write a code wrapper, like with constants and generate statements f.E. which instantiates the component depending on your hardware.
$endgroup$
– Eggi
Jan 21 at 10:01












$begingroup$
Yeah, that would be a possibility. However, is there any way to avoid those IP-Managers? Something like "#ifdef XILINX" constructs for actually using the one or the other generated IP dependent? --- Main issue is: I want to avoid using any GUI wizzards, instead have VHDL and other source files that might be generated by some external tool.
$endgroup$
– SDwarfs
Jan 21 at 10:04




$begingroup$
Yeah, that would be a possibility. However, is there any way to avoid those IP-Managers? Something like "#ifdef XILINX" constructs for actually using the one or the other generated IP dependent? --- Main issue is: I want to avoid using any GUI wizzards, instead have VHDL and other source files that might be generated by some external tool.
$endgroup$
– SDwarfs
Jan 21 at 10:04












$begingroup$
If you want ifdef's you should switch to Verilog. And I agree the Xilinx GUI was great until some @~$£%$ [censored] decided to go back to schematics.
$endgroup$
– Oldfart
Jan 21 at 10:22




$begingroup$
If you want ifdef's you should switch to Verilog. And I agree the Xilinx GUI was great until some @~$£%$ [censored] decided to go back to schematics.
$endgroup$
– Oldfart
Jan 21 at 10:22










1 Answer
1






active

oldest

votes


















4












$begingroup$

You can do this by including vendor specific primitives in your code.



Both Xilinx and Altera have PLL primitives that can be instantiated in the source code with no gui.



Xilinx:
PLL2_ADV and PLL_BASE (from page 351 onward)



Altera:
altpll User guide



While the Altera AltPLL IP does have a gui (and they highly recommend you use it, due to the wide range of PLL configuration parameters they have available), you don't actually have to use the GUI. Or, you can use the GUI once and then just keep the vhdl file it generates. I tested this by removing the IP gui file (.qip) from the project and added the source only, and it synthesized fine.



In both cases, you'll need to include the libraries at the top of your code.



-- Altera
LIBRARY altera_mf;
USE altera_mf.all;


-- Xilinx
LIBRARY UNISIM;
USE UNISIM.vcomponents.all;


The biggest issue is differentiating between vendors. The --pragma directive doesn't have a way to distinguish between vendors, so you'll need to use generate statements to do so. See this answer for more info about that: what is #define equivalent in VHDL






share|improve this answer











$endgroup$













  • $begingroup$
    Thanks! This should work for me. Also thanks for the pointers to the #define-equivalents.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:34






  • 1




    $begingroup$
    One global generic definition of "IS_XILINX" or "IS_ALTERA" and a if-generate at the target system specific locations (as suggested by the linked Q&A) should do the trick. A global quick to find configuration point is acceptable in my setup.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:38












  • $begingroup$
    @SDwarfs Just to be clear, the answer to the question in the title you wrote is no. Different "platforms", even those from the same vendor, may have different ways of specifying and configuring their PLLs. The approach suggested here works as long as you provide options for all "platforms".
    $endgroup$
    – Elliot Alderson
    Jan 21 at 14:37










  • $begingroup$
    @Elliot: Sure, that's surely why they provide the IP Wizards instead of giving us just the VHDL libraries. But, in a way this could be used to write a library that supports multiple FPGA variants having a common interface, where you only need to take care to change some generic constants to the right settings. It's not platform independent, but allows for better compatibility.
    $endgroup$
    – SDwarfs
    Jan 21 at 16:53











Your Answer





StackExchange.ifUsing("editor", function () {
return StackExchange.using("mathjaxEditing", function () {
StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix) {
StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
});
});
}, "mathjax-editing");

StackExchange.ifUsing("editor", function () {
return StackExchange.using("schematics", function () {
StackExchange.schematics.init();
});
}, "cicuitlab");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "135"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2felectronics.stackexchange.com%2fquestions%2f418048%2fcan-i-program-a-platform-independent-pll-in-vhdl%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









4












$begingroup$

You can do this by including vendor specific primitives in your code.



Both Xilinx and Altera have PLL primitives that can be instantiated in the source code with no gui.



Xilinx:
PLL2_ADV and PLL_BASE (from page 351 onward)



Altera:
altpll User guide



While the Altera AltPLL IP does have a gui (and they highly recommend you use it, due to the wide range of PLL configuration parameters they have available), you don't actually have to use the GUI. Or, you can use the GUI once and then just keep the vhdl file it generates. I tested this by removing the IP gui file (.qip) from the project and added the source only, and it synthesized fine.



In both cases, you'll need to include the libraries at the top of your code.



-- Altera
LIBRARY altera_mf;
USE altera_mf.all;


-- Xilinx
LIBRARY UNISIM;
USE UNISIM.vcomponents.all;


The biggest issue is differentiating between vendors. The --pragma directive doesn't have a way to distinguish between vendors, so you'll need to use generate statements to do so. See this answer for more info about that: what is #define equivalent in VHDL






share|improve this answer











$endgroup$













  • $begingroup$
    Thanks! This should work for me. Also thanks for the pointers to the #define-equivalents.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:34






  • 1




    $begingroup$
    One global generic definition of "IS_XILINX" or "IS_ALTERA" and a if-generate at the target system specific locations (as suggested by the linked Q&A) should do the trick. A global quick to find configuration point is acceptable in my setup.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:38












  • $begingroup$
    @SDwarfs Just to be clear, the answer to the question in the title you wrote is no. Different "platforms", even those from the same vendor, may have different ways of specifying and configuring their PLLs. The approach suggested here works as long as you provide options for all "platforms".
    $endgroup$
    – Elliot Alderson
    Jan 21 at 14:37










  • $begingroup$
    @Elliot: Sure, that's surely why they provide the IP Wizards instead of giving us just the VHDL libraries. But, in a way this could be used to write a library that supports multiple FPGA variants having a common interface, where you only need to take care to change some generic constants to the right settings. It's not platform independent, but allows for better compatibility.
    $endgroup$
    – SDwarfs
    Jan 21 at 16:53
















4












$begingroup$

You can do this by including vendor specific primitives in your code.



Both Xilinx and Altera have PLL primitives that can be instantiated in the source code with no gui.



Xilinx:
PLL2_ADV and PLL_BASE (from page 351 onward)



Altera:
altpll User guide



While the Altera AltPLL IP does have a gui (and they highly recommend you use it, due to the wide range of PLL configuration parameters they have available), you don't actually have to use the GUI. Or, you can use the GUI once and then just keep the vhdl file it generates. I tested this by removing the IP gui file (.qip) from the project and added the source only, and it synthesized fine.



In both cases, you'll need to include the libraries at the top of your code.



-- Altera
LIBRARY altera_mf;
USE altera_mf.all;


-- Xilinx
LIBRARY UNISIM;
USE UNISIM.vcomponents.all;


The biggest issue is differentiating between vendors. The --pragma directive doesn't have a way to distinguish between vendors, so you'll need to use generate statements to do so. See this answer for more info about that: what is #define equivalent in VHDL






share|improve this answer











$endgroup$













  • $begingroup$
    Thanks! This should work for me. Also thanks for the pointers to the #define-equivalents.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:34






  • 1




    $begingroup$
    One global generic definition of "IS_XILINX" or "IS_ALTERA" and a if-generate at the target system specific locations (as suggested by the linked Q&A) should do the trick. A global quick to find configuration point is acceptable in my setup.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:38












  • $begingroup$
    @SDwarfs Just to be clear, the answer to the question in the title you wrote is no. Different "platforms", even those from the same vendor, may have different ways of specifying and configuring their PLLs. The approach suggested here works as long as you provide options for all "platforms".
    $endgroup$
    – Elliot Alderson
    Jan 21 at 14:37










  • $begingroup$
    @Elliot: Sure, that's surely why they provide the IP Wizards instead of giving us just the VHDL libraries. But, in a way this could be used to write a library that supports multiple FPGA variants having a common interface, where you only need to take care to change some generic constants to the right settings. It's not platform independent, but allows for better compatibility.
    $endgroup$
    – SDwarfs
    Jan 21 at 16:53














4












4








4





$begingroup$

You can do this by including vendor specific primitives in your code.



Both Xilinx and Altera have PLL primitives that can be instantiated in the source code with no gui.



Xilinx:
PLL2_ADV and PLL_BASE (from page 351 onward)



Altera:
altpll User guide



While the Altera AltPLL IP does have a gui (and they highly recommend you use it, due to the wide range of PLL configuration parameters they have available), you don't actually have to use the GUI. Or, you can use the GUI once and then just keep the vhdl file it generates. I tested this by removing the IP gui file (.qip) from the project and added the source only, and it synthesized fine.



In both cases, you'll need to include the libraries at the top of your code.



-- Altera
LIBRARY altera_mf;
USE altera_mf.all;


-- Xilinx
LIBRARY UNISIM;
USE UNISIM.vcomponents.all;


The biggest issue is differentiating between vendors. The --pragma directive doesn't have a way to distinguish between vendors, so you'll need to use generate statements to do so. See this answer for more info about that: what is #define equivalent in VHDL






share|improve this answer











$endgroup$



You can do this by including vendor specific primitives in your code.



Both Xilinx and Altera have PLL primitives that can be instantiated in the source code with no gui.



Xilinx:
PLL2_ADV and PLL_BASE (from page 351 onward)



Altera:
altpll User guide



While the Altera AltPLL IP does have a gui (and they highly recommend you use it, due to the wide range of PLL configuration parameters they have available), you don't actually have to use the GUI. Or, you can use the GUI once and then just keep the vhdl file it generates. I tested this by removing the IP gui file (.qip) from the project and added the source only, and it synthesized fine.



In both cases, you'll need to include the libraries at the top of your code.



-- Altera
LIBRARY altera_mf;
USE altera_mf.all;


-- Xilinx
LIBRARY UNISIM;
USE UNISIM.vcomponents.all;


The biggest issue is differentiating between vendors. The --pragma directive doesn't have a way to distinguish between vendors, so you'll need to use generate statements to do so. See this answer for more info about that: what is #define equivalent in VHDL







share|improve this answer














share|improve this answer



share|improve this answer








edited Jan 21 at 10:43

























answered Jan 21 at 10:30









stanristanri

4,46411849




4,46411849












  • $begingroup$
    Thanks! This should work for me. Also thanks for the pointers to the #define-equivalents.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:34






  • 1




    $begingroup$
    One global generic definition of "IS_XILINX" or "IS_ALTERA" and a if-generate at the target system specific locations (as suggested by the linked Q&A) should do the trick. A global quick to find configuration point is acceptable in my setup.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:38












  • $begingroup$
    @SDwarfs Just to be clear, the answer to the question in the title you wrote is no. Different "platforms", even those from the same vendor, may have different ways of specifying and configuring their PLLs. The approach suggested here works as long as you provide options for all "platforms".
    $endgroup$
    – Elliot Alderson
    Jan 21 at 14:37










  • $begingroup$
    @Elliot: Sure, that's surely why they provide the IP Wizards instead of giving us just the VHDL libraries. But, in a way this could be used to write a library that supports multiple FPGA variants having a common interface, where you only need to take care to change some generic constants to the right settings. It's not platform independent, but allows for better compatibility.
    $endgroup$
    – SDwarfs
    Jan 21 at 16:53


















  • $begingroup$
    Thanks! This should work for me. Also thanks for the pointers to the #define-equivalents.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:34






  • 1




    $begingroup$
    One global generic definition of "IS_XILINX" or "IS_ALTERA" and a if-generate at the target system specific locations (as suggested by the linked Q&A) should do the trick. A global quick to find configuration point is acceptable in my setup.
    $endgroup$
    – SDwarfs
    Jan 21 at 12:38












  • $begingroup$
    @SDwarfs Just to be clear, the answer to the question in the title you wrote is no. Different "platforms", even those from the same vendor, may have different ways of specifying and configuring their PLLs. The approach suggested here works as long as you provide options for all "platforms".
    $endgroup$
    – Elliot Alderson
    Jan 21 at 14:37










  • $begingroup$
    @Elliot: Sure, that's surely why they provide the IP Wizards instead of giving us just the VHDL libraries. But, in a way this could be used to write a library that supports multiple FPGA variants having a common interface, where you only need to take care to change some generic constants to the right settings. It's not platform independent, but allows for better compatibility.
    $endgroup$
    – SDwarfs
    Jan 21 at 16:53
















$begingroup$
Thanks! This should work for me. Also thanks for the pointers to the #define-equivalents.
$endgroup$
– SDwarfs
Jan 21 at 12:34




$begingroup$
Thanks! This should work for me. Also thanks for the pointers to the #define-equivalents.
$endgroup$
– SDwarfs
Jan 21 at 12:34




1




1




$begingroup$
One global generic definition of "IS_XILINX" or "IS_ALTERA" and a if-generate at the target system specific locations (as suggested by the linked Q&A) should do the trick. A global quick to find configuration point is acceptable in my setup.
$endgroup$
– SDwarfs
Jan 21 at 12:38






$begingroup$
One global generic definition of "IS_XILINX" or "IS_ALTERA" and a if-generate at the target system specific locations (as suggested by the linked Q&A) should do the trick. A global quick to find configuration point is acceptable in my setup.
$endgroup$
– SDwarfs
Jan 21 at 12:38














$begingroup$
@SDwarfs Just to be clear, the answer to the question in the title you wrote is no. Different "platforms", even those from the same vendor, may have different ways of specifying and configuring their PLLs. The approach suggested here works as long as you provide options for all "platforms".
$endgroup$
– Elliot Alderson
Jan 21 at 14:37




$begingroup$
@SDwarfs Just to be clear, the answer to the question in the title you wrote is no. Different "platforms", even those from the same vendor, may have different ways of specifying and configuring their PLLs. The approach suggested here works as long as you provide options for all "platforms".
$endgroup$
– Elliot Alderson
Jan 21 at 14:37












$begingroup$
@Elliot: Sure, that's surely why they provide the IP Wizards instead of giving us just the VHDL libraries. But, in a way this could be used to write a library that supports multiple FPGA variants having a common interface, where you only need to take care to change some generic constants to the right settings. It's not platform independent, but allows for better compatibility.
$endgroup$
– SDwarfs
Jan 21 at 16:53




$begingroup$
@Elliot: Sure, that's surely why they provide the IP Wizards instead of giving us just the VHDL libraries. But, in a way this could be used to write a library that supports multiple FPGA variants having a common interface, where you only need to take care to change some generic constants to the right settings. It's not platform independent, but allows for better compatibility.
$endgroup$
– SDwarfs
Jan 21 at 16:53


















draft saved

draft discarded




















































Thanks for contributing an answer to Electrical Engineering Stack Exchange!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


Use MathJax to format equations. MathJax reference.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2felectronics.stackexchange.com%2fquestions%2f418048%2fcan-i-program-a-platform-independent-pll-in-vhdl%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Mario Kart Wii

The Binding of Isaac: Rebirth/Afterbirth

What does “Dominus providebit” mean?