-
Notifications
You must be signed in to change notification settings - Fork 40
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Race condition in Copper code? #86
Comments
I didn't analyzed the copper code, but this style is valid. With blocking assignment copjmp1 will be valid in the same clock cycle (not in the next in case of non-blocking). Synthesizer is aware of such assignment and will synthesize it correct, although synthesized logic will be more complex. |
Thanks a lot for your replay, Sorgelig. I agree that timing will break if we changed it to non-blocking statements. But can we really assume that copjmp1 is assigned 1 before the if statement is evaluated. As far as I understand the Verilog spec, there is no guaranteed evaluation order between the two always blocks. If the if statement is evaluated first, it would be evaluated with an old value of copjmp1. |
Hi, thanks for pointing this out. In implemented design, there should be no issue. The synthesis tool should do 'the right thing', that is, ignore blocking assignment and treat it as a non-blocking. Simulation tools, on the other hand, won't, so this is probably a simulation - synthesis mismatch, and needs to be fixed. (Pull requests are welcome ;) ) |
I'm still a little bit confused about the intended behaviour:
If the synthesis tool ignores the blocking assignments and treats the assignments as non-blocking, this means that:
Is this correct? |
Yes, that looks correct. I would test if first though, just to be sure. While I wrote that the synthesis tool will do the right thing, you shouldn't assume that will always be the case, just that in this specific case it should be* - that is why it is very unwise to use blocking assignments in an edge-sensitive block. *In this specific case, the copjmp1 reg is written in a separate block than the block where it is read, so this should synthesize as non-blocking. |
BTW, if you look at the code, you can see that if |
Yes, you're right, I didn't look at the else part testing clk_ena. So everything must be treated as non-blocking as it is typical for sequential logic. Thanks a lot for your help! I did ask, because I am currently trying to translate the Copper code into a graphical representation that exhibits the state model together with the exact timing, simply to learn the details about Copper. I started out with looking at UAE, but I gave up quickly, because the UAE code has gotten so complex over the years. While looking for alternatives, I stumbled across the Minimig project which I wasn't aware of before. What I've seen so far is very pleasing, and the code is well documented. Great project! |
Looking forward to your work on the vAmiga! |
While reviewing the Copper code, I came across the following two code blocks:
Isn’t there a race condition here, because copjmp1 is written via a blocking assignment and read in the if statement at the same clock event?
The text was updated successfully, but these errors were encountered: