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.
Blocking assignments - FPGA Tutorial
From the course: Learning Verilog for FPGA Development
Blocking assignments
- At this point, I've shown you procedural blocks using blocking assignments exclusively. It's time to learn what blocking and non-blocking means in Verilog. Consider this module called logic which outputs the expression built in lines 31 through 33. This is the or operation between the expressions in line 31 and 32. and this is totally possible with blocking assignments. Notice that the blocking assignment operator is the equal character. Blocking means that any further line of code will be evaluated after this line is evaluated. It has no particular effect on timing. It simply means that the expressions are built in the sequence of the code. I want to be clear on this so I'll say it once more. The order of the lines of code is not the order of the signal changes in time. It's only showing the trajectory of the signals in the circuit. Time is not blocked. The compiler is. Conversely, non-blocking means that…
Practice while you learn with exercise files
Download the files the instructor uses to teach the course. Follow along and learn by watching, listening and practicing.
Contents
-
-
-
-
Verilog modules4m 13s
-
(Locked)
Instantiating modules4m 49s
-
(Locked)
Gates and primitives3m 3s
-
(Locked)
Registers and wires1m 46s
-
(Locked)
Range specification4m 30s
-
(Locked)
Numbers and constants4m 53s
-
(Locked)
Always blocks52s
-
(Locked)
The if-else statement2m 2s
-
(Locked)
Case statements2m 24s
-
(Locked)
Boolean algebra expressions56s
-
(Locked)
Continuous assignments2m 23s
-
(Locked)
Blocking assignments3m 20s
-
(Locked)
Nonblocking assignments3m 49s
-
(Locked)
Challenge: From schematic to code2m 16s
-
(Locked)
Solution: From schematic to code4m 31s
-
-
-
-
-