how to use local parameter in HDL Coder toolbox?
    3 次查看(过去 30 天)
  
       显示 更早的评论
    
Dear MATLAB Support Team,
I am currently working on developing an UART transmitter block in Simulink. Within this block, I require two parameters: CLOCK_FREQ and BAUD_RATE, which are essential for calculating the DIVIDER parameter, given by CLOCK_FREQ / BAUD_RATE.
While I have learned how to generate parameters using HDL Coder, I am facing confusion regarding the generation of the local parameter DIVIDER, which will be utilized within a counter block. I aim to produce Verilog code similar to the following:
- -  - - - - - -
parameter BAUD_RATE = 9600;
parameter CLOCK_FREQ = 100000000;
localparam DIVIDER = CLOCK_FREQ / BAUD_RATE;
if (clk_divider == DIVIDER) begin
    // Further implementation
end
-  - - - - - - - - 
However, the generated code I am obtaining differs:
- - - - -  - - - - -  - -
parameter integer BAUD_RATE = 9600;
parameter integer CLOCK_FREQ = 100000000;
assign DIVIDER_out1 = 32'b00000000000000000010100010110001;
- - -  - -   - -  -   - -  - 
How can I use BAUD_RATE and CLOCK_FREQ within the module to generate other parameters?
The Constant Block setting is as follows:

0 个评论
回答(1 个)
  kiyoko
    
 2024-5-7
        Unfortunately, HDL Coder does not support the generation of "localparam". "Generate Parameterized HDL Code for Constant and Gain Blocks" is only compatible with "parameter".
As an alternative, if you have custom HDL code, you can use the DocBlock block to integrate that custom HDL code into your design.
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

