Verilog may appear to be "simple" for beginner because it is a loosely-typed language and its syntax is somewhat to that of C. In reality, Verilog is really a complex language and many intricate details and features are buried in the language standard (i.e., LRM, Language Reference Manual). Sometimes these details are counter-intuitive and cause unexpected behaviors (for example, the expressions "(a+b)>>1" and "(0+a+b)>>1" are likely to return different results). This book systematically lists and discusses these gotchas, provides guidelines to avoid these traps, and helps you to develop reliable and robust Verilog codes. It can save you many, many debugging hours down the road. Though somewhat expensive, this book is a valuable reference for serious Verilog developers. A simplified version of this book appears as a conference paper. You can search the web and take a look and decide whether it fits you need.
Ссылка удалена правообладателем ---- The book removed at the request of the copyright holder.