HDL Coder generated Verilog code for 2-D LUT block propogates X in Vivado Simulator

18 visualizzazioni (ultimi 30 giorni)
When generating HDL code with HDL Coder for a 2-D Look Up Table block, I observed different behavior between VHDL and Verilog for the same lookup table access:
  • In VHDL, the generated code uses
to_integer(add_cast + resize(mul_temp, 32))
which ensures that everything is resized into a 32-bit signed domain, producing a deterministic index.
  • In Verilog, however, the generated code was:
$signed({1'b0, prelookup_idx}) + alpha2_D_Lookup_Table_mul_temp_2
Here, prelookup_idx is only 2 bits, while mul_temp_2 is 35 bits signed. The result is a 35-bit signed expression, and if any bit in the operands propagates X, the whole lookup table output becomes X in Vivado simulator.
Solution
To mimic the VHDL resize behavior, the Verilog code needs explicit truncation and casting:
wire signed [31:0] add_cast_2 = $signed({{30{1'b0}}, prelookup_idx});
wire signed [31:0] mul_temp_2_resized = alpha2_D_Lookup_Table_mul_temp_2[31:0];
wire signed [31:0] idx2 = add_cast_2 + mul_temp_2_resized;
assign alpha2_D_Lookup_Table_tableout3 = alpha2_D_Lookup_Table_7[idx2[5:0]];
With this change:
  • The 35-bit value is truncated to 32 bits (matching the VHDL resize).
  • The addition is performed in a 32-bit signed domain.
  • The X propagation issue in Verilog simulation disappears.
Conclusion
There is a subtle difference between HDL Coder’s VHDL and Verilog backends regarding resize handling.
  • VHDL always produces a deterministic integer with resize + to_integer.
  • Verilog can leave the expression at a wider signed width, which increases the chance of X propagation.
Explicit truncation/casting in Verilog aligns its behavior with VHDL and resolves the simulation mismatch.
HDL Coder version is 25.1.

Risposte (2)

Kiran Kintali
Kiran Kintali il 12 Set 2025
Could you please share the sample model?
The input types and block parameters are essential for generating HDL code.
Additionally, the testbench surrounding the subsystem shown in the image helps reproduce the simulation behavior, making it easier to validate the design.
  1 Commento
albs975
albs975 il 15 Ott 2025
Hi. The code is generated from Jacobi SVD Optimized for HDL example. I will attach the generated original code and updated version by me. Relative hierarchy under example model is included in the codes. Thanks.

Accedi per commentare.


Kiran Kintali
Kiran Kintali il 18 Ott 2025
Could you please share your test model along with the version of MATLAB you are using?
We tested with R2025b using the attached model (types selected based on your HDL code), but we did not observe any 'X' propagation in the generated code or testbench using HDL Coder.
  4 Commenti
Kiran Kintali
Kiran Kintali il 24 Ott 2025
Thank you for the follow-up. We’ve confirmed that a technical support case has been raised regarding this issue. The MathWorks Support Team will respond directly, and we’ll continue to follow up with you to ensure it’s resolved. The issues here involves AMD Vivado Simulator that needs additional investigation.

Accedi per commentare.

Categorie

Scopri di più su Code Generation in Help Center e File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by