From the course: Learning Verilog for FPGA Development

Unlock the full course today

Join today to access over 24,000 courses taught by industry experts.

Initial and always blocks

Initial and always blocks

- [Narrator] Now let me remind you about a very important detail of Verilog test bench modules. Everything works concurrently because we are describing hardware after all. Every line of code and every block of code work concurrently. This includes gates and module instances, registers and wires, but more importantly, all initial blocks work concurrently, so you may include several of these in a single module. Always blocks also operate concurrently with everything else. Yes, procedural blocks, the ones enclosed by begin and end, may have sequential parts, but this sequence only refers to the auditor of the assignments and delays expressed with the pound operator. So in any test bench module we could have several initial blocks, some module instantiations, then an always block, then more initial blocks and so on. The order of these blocks doesn't change the behavior of the simulation or the module. Again, the order…

Contents