I have been reading through various questions on here, as I am learning VHDL and always looking to improve. However, this comment made me curious:
I was told, in my brief VHDL course at university, that separate processes was best form, to separate the synchronous aspects.
Obviously this is personal preference, but I was hoping that some more experienced users may be able to shed some light on the pros/cons, with their own preferences? Is one more common than the other?
Thanks!
I'm in the keep it separate camp. In my code I have a single synchronous process which does reset and clocking behaviour. Everything else is async. A register process looks something like this:
Things I like:
Negatives:
Things I don't quite understand from Martin's answer:
I change the type of my state variable (i.e. add an enum) and move on. Exactly the same as in unified style.
In split style you already have the registered and unregistered versions. They are the input and output to the register process. No extra work at all.
Well, as it was me that said what you've linked to... I'd better comment :)
Bad things (IMHO) if you put things in separate processes:
Good things:
My opinion is that edicts like you heard ("keep it separate") stem from the days when synthesisers weren't very good at differentiating the logic from the flops, so putting just the flops in clocked processes made sense.
Furthermore, that approach matched the way people of that era drew schematic diagrams before they had HDLs.
These days, synthesisers can deal with arbitrarily complex logic in clocked processes. And I can write it the way that makes sense without having to be explicit about where each tiny bit of logic sits. Only when timing is really tight do I have to think really hard about placing flops and logic in just the right places.
My "rules" are:
A lot like writing software :)