DVD - Lecture 2: Verilog

  Рет қаралды 36,461

Adi Teman

Adi Teman

Күн бұрын

Пікірлер: 55
@AdiTeman
@AdiTeman 2 жыл бұрын
Note that there is a typo on Slide 16 (42:00). A latch should have the "d" input in the sensitivity list, so for a correct latch it should be: always@(d or en) or just always@* Thanks to Nour Daghlas for noticing this.
@nguyenduykhoi7819
@nguyenduykhoi7819 2 жыл бұрын
Your explanation is clear and this course is created. Thank you very much!
@AdiTeman
@AdiTeman 2 жыл бұрын
Glad it was helpful!
@suprajithhs5609
@suprajithhs5609 4 жыл бұрын
This is a wonderful channel. This video is such a great resource to learn and relearn some of the tricky bits of Verilog. Regarding reg vs wire, I love what they did with SystemVerilog: everything is a "logic"! Thank you for the videos.
@AdiTeman
@AdiTeman 4 жыл бұрын
Thanks for the kind words. Indeed, System Verilog improves on many of the things that Verilog was not so good at. That being said, unfortunately, some tools still have trouble with various System Verilog constructs (especially interfaces) and this can give us chip designers quite a headache at different parts of the flow - sometimes even making us regret our decision to use the advanced features... In any case, I decided to teach Verilog in this course as it is still more universal, it is used in the structural (gate-level) output, and in general, it's not "all that" different. Glad you enjoyed.
@little_explorers2866
@little_explorers2866 4 жыл бұрын
@@AdiTeman plz do video about system verilog
@AdiTeman
@AdiTeman 3 жыл бұрын
Maybe will do so some day. Thanks for the suggestion.
@misuh9097
@misuh9097 2 жыл бұрын
Great comprehensive lectures. Thank you very much! One minor remark on slide 23, the else next_state CNTDN, perhaps count=='b0 should be used in the if statement instead of count==4'b0000 for the code to work with different counter widths.
@AdiTeman
@AdiTeman 2 жыл бұрын
Good point! Thanks.
@hossamfadeel
@hossamfadeel 4 жыл бұрын
I really appreciate your efforts. Very Clear and Constructive. Keep Going. Thumps Up.
@AdiTeman
@AdiTeman 3 жыл бұрын
Thank you, I will
@ramakishan7323
@ramakishan7323 3 жыл бұрын
Thank you Mr. Teeman for amazing lecture
@AdiTeman
@AdiTeman 3 жыл бұрын
You are very welcome
@digvijaysingh4738
@digvijaysingh4738 5 жыл бұрын
Professor, the explanation in the videos is amazing. I am taking a PD and ESL course in university and the lectures help a lot. It would be really helpful for everyone if you could get your other digital design course lectures translated in English.
@AdiTeman
@AdiTeman 5 жыл бұрын
Thanks for the kind words. I would love to record the other courses in English, but I unfortunately don't have the time to do it right now. I hope that I will be able to do this in the future.
@ibrahimmohamed1839
@ibrahimmohamed1839 5 жыл бұрын
Thanks Dr. Adam Teman for this useful lecture
@AdiTeman
@AdiTeman 5 жыл бұрын
You're welcome :)
@AhmedAshraf-hg7gy
@AhmedAshraf-hg7gy 5 жыл бұрын
I really loved your style of explanation, how great this lecture !! keep it on
@AdiTeman
@AdiTeman 5 жыл бұрын
Thank you!
@chepurivenkatesh8238
@chepurivenkatesh8238 3 жыл бұрын
Thanks you very much professor. These lectures helped me a lot in my interviews
@AdiTeman
@AdiTeman 3 жыл бұрын
You are very welcome
@ashwinsingh1325
@ashwinsingh1325 5 жыл бұрын
Hi professor, I was wondering why you needed to define overflow condition at 58:51 using: if(count==(1
@AdiTeman
@AdiTeman 5 жыл бұрын
Yes, indeed, this is to make the code parametric. For the zero vector, most simulators and synthesizers will pad with zeros, so we didn't need to write anything "fancy', but for the ones, this is a little trick to create a parametric ones vector.
@chadwinters4285
@chadwinters4285 4 жыл бұрын
@@AdiTeman Hello. I'm coming from the VHDL world where there is the syntax like count=(count'range=>'1') to accomplish what you did to check for the '1111' condition. Out of curiosity, why didn't you use something like {COUNTER_WIDTH-1{1'b1}} to get the '1111' which is still parametric ?
@AdiTeman
@AdiTeman 3 жыл бұрын
Sorry for the late reply. Your question got away from me :) I think this could have been done as well. Just a habit of writing RTL in one way or another (tricks you pick up along the way). Any of these shorthands that work are fine.
@yunzhongwang1655
@yunzhongwang1655 2 жыл бұрын
Hello, Professor, thanks for your great lectures, at around (38:00), why a latch will be inferred without an "else " statement? This question bothers me a lot, could you please give me some help? Thanks!
@AdiTeman
@AdiTeman 2 жыл бұрын
Hi Yunzhong, Let me try to explain. Combinatorial logic does not know how to "remember" things - for that you need a register (flip flop or latch). An assign statement is entered when anything in the sensitivity list (RHS) changes and has to decide what the new state of anything on the LHS is. If you have a clear answer to that for every possibility, then all is well. But if you don't have a clear answer, you have to "keep" whatever was there before, requiring "memory" or in other words - a latch. To try and better illustrate this, I will use the example of the lecture. The sensitivity list includes "sel" - so anytime "sel" changes, the always block will be initiated. Inside the always block we have "out" on the LHS. Therefore, the always block must "decide" what to drive onto "out" for every reason the always block was entered. The first statement "if (sel)" means that if sel=1 (e.g., sel toggled from 0 to 1), it will drive "a" onto "out". But what happens if sel==0? Well, the "else" takes care of that, but what if there was no "else"? The always block still has to decide what to drive onto "out". Should it drive "a"? No, that's only when sel==1. Should it drive "b"? No, why should it? The answer is, it should drive whatever it was driving before. How? By remembering what it was driving before. How could this be synthesized? Add a latch to the output of "out". The enable of the latch would be "sel". If sel==1 then the preceding logic (the mux) is propagated. If sel==0, the latch is closed and therefore whatever was there before is kept on the output. Hope that clarifies this point.
@yunzhongwang1655
@yunzhongwang1655 2 жыл бұрын
@@AdiTeman Thanks a lot for your kind explanation, and I have understood it.😄
@nourdaghlas9397
@nourdaghlas9397 2 жыл бұрын
Hi! First of all thank you for all the effort you put in the lectures and slides. They're amazing. I have a question -- At 42:00 you mentioned that the Verilog in that section is a latch, but suppose 'en' goes positive and 'd' gets passed to 'q', if 'd' changes while 'en' is positive, will that trigger assigning 'q' again or would you have to add 'd' into the sensitivity list for it to actually behave as a latch? Or is it understood that as long as 'en' is positive, 'q
@AdiTeman
@AdiTeman 2 жыл бұрын
You are 100% correct. This is a bug in the slide. For a true latch, the enable and the data should be in the sensitivity list. So if you were to write the code as in the slide, this would require some additional logic from the synthesizer. I will try to fix it at some point (unfortunately, the built in editing tools in KZbin don't allow this type of editing, so I need to rerender and upload it...). Thanks again for the comment!
@nourdaghlas9397
@nourdaghlas9397 2 жыл бұрын
​@@AdiTeman Thank you for confirming. I'm not much of a verilog person so I'm sorry I couldn't test it myself. If I may suggest, adding whatever corrections for a video in a pinned comment would be a good place for all to see since I'd wager most people at least do get a look at the first(pinned) comment as they're usually reserved for important info regarding the video. Otherwise all the effort in upkeeping the lessons is of course much appreciated! :)
@AdiTeman
@AdiTeman 2 жыл бұрын
Thanks again. I wasn't aware of this capability. I have added a comment and pinned it (at least until I have a chance to fix and upload a new video)
@СеменМоскаленко-ь7и
@СеменМоскаленко-ь7и 3 жыл бұрын
Really good lectures, thanks from Russia
@AdiTeman
@AdiTeman 3 жыл бұрын
Your welcome. It's my pleasure!
@iliachakarov7285
@iliachakarov7285 7 ай бұрын
Now this lecture I like!! gj
@AdiTeman
@AdiTeman 7 ай бұрын
Glad to hear that!
@AmeenAltajer
@AmeenAltajer 4 жыл бұрын
Great series, thank you so much.
@AdiTeman
@AdiTeman 4 жыл бұрын
You're very welcome!
@swastikkhuntia3283
@swastikkhuntia3283 3 жыл бұрын
Great lectures sir🙇‍♂️🙇‍♂️Much obliged for your effort. Have been constantly following your lectures. One thing that struck my mind at around 59:00 , that instead of doing the shift operation and -1 for detecting overflow, couldn't we have used a reduction & operator, and reduction ~& for overflow during down counting? I think it would have been a bit simpler. Your lessions are great sir😁😁
@AdiTeman
@AdiTeman 3 жыл бұрын
Yes, something like that could for sure be done. In fact, there are many tricks that veteran designers play to "fancify" their code. I just wanted to show one such example. That being said, note that when using these alternative ways to write something: 1) You need to carefully verify it to make sure you weren't too sophisticated for yourself... 2) You should think about the synthesis implications of your coding style. I go over some examples of this in the next lectures. Some coding styles could lead to more complex hardware or hardware that is not 100% equivalent, so make sure to think about this when using such tricks. 3) Sometimes writing "fancy" code makes it harder to read and therefore, harder to maintain and debug. If you do these tricks, make sure to comment/document them clearly or you will be sorry when you return to this line of code later on.
@cmeditz9988
@cmeditz9988 2 жыл бұрын
Sir can u make a vedio on how to use spyglass and design compiler for lintingand synthesis
@AdiTeman
@AdiTeman 2 жыл бұрын
I will indeed add it to my wish list of videos to make.
@ykrishnateja8871
@ykrishnateja8871 3 жыл бұрын
Hello Professor, In the expression count==(1
@hongle-pr7mo
@hongle-pr7mo 3 жыл бұрын
Hi professor, thank you for a very throughout lecture. I was wondering if is there any ways that I could get the powerpoint of the lectures. The attached link in the description does not work.
@AdiTeman
@AdiTeman 3 жыл бұрын
Hi Hong Le, Indeed, the faculty website is down due to security concerns. If you need to access the slides in the meantime, please email me at adam.teman@biu.ac.il and tell me which slide decks you need. I also may move them to a different server if it is not resolved soon. Thank for your interest, Adi
@AdiTeman
@AdiTeman 3 жыл бұрын
My faculty website is back online www.eng.biu.ac.il/temanad/teaching/
@HsinYuChang_chy1982
@HsinYuChang_chy1982 3 жыл бұрын
Thank you so much. It helps me a lot.
@AdiTeman
@AdiTeman 3 жыл бұрын
Glad to hear that!
@TNTsundar
@TNTsundar 3 жыл бұрын
Great lecture! I wonder if this covers almost all the aspects of Verilog. In other words, the language seems to be using a small set of keywords and constructs unlink C like programming language where there are much more detailed construct and ideas that are frequently employed in drivers, firmware and applications.
@AdiTeman
@AdiTeman 3 жыл бұрын
Hi Sundar, In no way does this lecture cover all that is available in Verilog. There are pretty thick books for that. But I tried to narrow it down to the 80% (maybe more) that is most often used for RTL coding and basic testbenching. If you can conceive this very limited content, you can pretty much start coding. The nooks and crannies to do more tricky stuff are easily searchable on the web or in a text book, but I don't think they're at all necessary when starting and the more syntax, the more confusing things get. So I decided to skip all of that for an introductory lecture, and let stack overflow provide you with the rest :)
@TNTsundar
@TNTsundar 3 жыл бұрын
@@AdiTeman Thank you for the response. Your lecture is very easy to understand and provides a good introduction to HDL. Please keep it going.
@gauravdewangan2765
@gauravdewangan2765 3 жыл бұрын
Thank you so much sir.
@AdiTeman
@AdiTeman 3 жыл бұрын
Most welcome
@amitr24
@amitr24 5 жыл бұрын
Thanks!
DVD - Lecture 3: Logic Synthesis - Part 1
1:16:27
Adi Teman
Рет қаралды 54 М.
DVD - Lecture 2b: Verilog Syntax
29:29
Adi Teman
Рет қаралды 11 М.
coco在求救? #小丑 #天使 #shorts
00:29
好人小丑
Рет қаралды 120 МЛН
Quando A Diferença De Altura É Muito Grande 😲😂
00:12
Mari Maria
Рет қаралды 45 МЛН
How to write Synthesizeable RTL
34:52
Adi Teman
Рет қаралды 19 М.
Intro to Verilog and ModelSim, Part1
30:23
Peter Mathys
Рет қаралды 53 М.
IC Design &  Manufacturing Process : Beginners Overview to VLSI
32:07
Systemverilog Academy
Рет қаралды 155 М.
DVD - Lecture 4: Logic Synthesis - Part II
1:20:22
Adi Teman
Рет қаралды 22 М.
DVD Lecture 11: Sign Off and Chip Finishing - Part 2
29:43
Adi Teman
Рет қаралды 5 М.
DVD - Lecture 10: Packaging and I/O Circuits
53:56
Adi Teman
Рет қаралды 22 М.
How AI Got a Reality Check
8:53
Bloomberg Originals
Рет қаралды 42 М.
Google’s Quantum Chip: Did We Just Tap Into Parallel Universes?
9:34
CUDA Programming - C/C++ Basics
1:21:34
TAUVOD
Рет қаралды 89 М.
Verilog Basics
9:42
Paul Franzon
Рет қаралды 215 М.