Verilog was used to resolve the complexity of handling gate-level representation. This was first released as a proprietary language in 1985 and later it becomes publically available under IEEE standards.
These are simple examples I have done during the practical Session for Hardware Description Language Module
Sequence/Pattern Detector. This was a simple example used to detect the pattern “1101” using the Mealy method. The mealy method has fewer states than the Moore model. For this, we have for the state using the Mealy Model. S1 = Reset state which comes at initial and in case of the wrong pattern matches like 10, 1100. S2 = the Second state which comes after the initial step with only 1; it has also come after the S4. S3 = Third state which comes only after the S2 and S3 itself thus when 111 once it will interpret again as 11. S4 = Last state which only comes after S3.
- D Flip Flops
This was a simple d flip flops. Using the following methods.
- Synchronous Reset
- Asynchronous Reset
- If/Wait Statement
Shift Register This was to shift register values based on the inputs. This particular register will shift the bits 4 clock cycles. Thus a particular input reaches after 4 clock cycles and also with asynchronous reset.
Frequency Divider Here I divide the main clock frequency by 3(2’b010), thus after every 6 clock cycle, one pulse will come from the new clock. For this, I have used a counter which counts 0 to 2 and after that toggle clock value.
This was a simple ALU that contains a set of 16 operations with +, -, AND, OR, NAND, NOR, XOR, XNOR, and NOT gate.
This divided into sub-modules as
- Arithmetic Unit ( operation with +, -)
- Logic Unit ( operation with AND, OR, NAND, NOR, XOR, XNOR, and NOT gates )
- Mux ( to choose Arithmetic or logic based on the operation selection )
- Sample Process
This was a simple process designed with the help of the following units
- Alu unit (for both Arithmetic and logical calculation)
- Shift unit (shifting values)
- Register (storing values)
- Mux (toggle between values)
This was a simple example of down-counter counts from 8 till 3 and notify 1 when it becomes 5. This works with a clock, a load 8 function, which updates the counter values to eight and an enable function with common general meaning. Instead of previous examples, I have used a new approach based on what I learned recently. It contains three modules
- For main counter operation
- For testing purposes thus inputs and outputs of the original counter are reverted here
- For test bench to make the connection between test and counter