HDL Coder generates VHD Files for Sample and Hold Blocks
조회 수: 1 (최근 30일)
이전 댓글 표시
Hi, I'm using Sample and Hold Blocks in my design. When I generate the VHDL Code, I get files named like "controlss_block.vhd" for the Sample and Hold Blocks. Flatten Hierachy is enabled in the HDL Block Settings and the blocks are in a Subsystem. I tried to put 4 of them in the "main" Subsystem for which the VHDL Code is generated. In this case, only 1 VHD file is generated for the Sample and Hold Blocks, and it is named like the name of the block and not "controlss_block.vhd".
The second issue is, that I have sin/cos functions, which are implemented in an CORDIC. Also for these blocks seperate VHD files are generated. How can I prevent this?
The used MATLAB version is 2015b.
Best Regards
댓글 수: 0
답변 (1개)
Kiran Kintali
2021년 5월 22일
Attached model has several Sample and Hold Blocks in addition to Sin function configured to use CORDIC architecture.
The flatten hierarchy option works as expected during HDL Code generation.
>> hdlsaveparams('simplifiedModel_SH_21a/DUT')
%% Set Model 'simplifiedModel_SH_21a' HDL parameters
hdlset_param('simplifiedModel_SH_21a', 'HDLSubsystem', 'simplifiedModel_SH_21a');
% Set SubSystem HDL parameters
hdlset_param('simplifiedModel_SH_21a/DUT', 'FlattenHierarchy', 'on');
>>
>> makehdl('simplifiedModel_SH_21a/DUT')
### Generating HDL for 'simplifiedModel_SH_21a/DUT'.
### Using the config set for model simplifiedModel_SH_21a for HDL code generation parameters.
### Running HDL checks on the model 'simplifiedModel_SH_21a'.
### Begin compilation of the model 'simplifiedModel_SH_21a'...
### Applying HDL optimizations on the model 'simplifiedModel_SH_21a'...
### The code generation and optimization options you have chosen have introduced additional pipeline delays.
### The delay balancing feature has automatically inserted matching delays for compensation.
### The DUT requires an initial pipeline setup latency. Each output port experiences these additional delays.
### Output port 1: 12 cycles.
### Output port 2: 12 cycles.
### Begin model generation.
### Model generation complete.
### Begin VHDL Code Generation for 'simplifiedModel_SH_21a'.
### Working on simplifiedModel_SH_21a/DUT/Sin as hdlsrc\simplifiedModel_SH_21a\Sin.vhd.
### Working on simplifiedModel_SH_21a/DUT as hdlsrc\simplifiedModel_SH_21a\DUT.vhd.
### Generating package file hdlsrc\simplifiedModel_SH_21a\DUT_pkg.vhd.
### Code Generation for 'simplifiedModel_SH_21a' completed.
### Creating HDL Code Generation Check Report DUT_report.html
### HDL check for 'simplifiedModel_SH_21a' complete with 0 errors, 0 warnings, and 1 messages.
### HDL code generation complete.
>>
.
>> find_system('simplifiedModel_SH_21a/DUT')
ans =
26×1 cell array
{'simplifiedModel_SH_21a/DUT' }
{'simplifiedModel_SH_21a/DUT/IN1' }
{'simplifiedModel_SH_21a/DUT/IN2' }
{'simplifiedModel_SH_21a/DUT/IN3' }
{'simplifiedModel_SH_21a/DUT/IN4' }
{'simplifiedModel_SH_21a/DUT/Data Type Conversion'}
{'simplifiedModel_SH_21a/DUT/SS1' }
{'simplifiedModel_SH_21a/DUT/SS1/IN2' }
{'simplifiedModel_SH_21a/DUT/SS1/IN1' }
{'simplifiedModel_SH_21a/DUT/SS1/SH2' } % SAMPLE and HOLD
{'simplifiedModel_SH_21a/DUT/SS1/TSS1' }
{'simplifiedModel_SH_21a/DUT/SS1/TSS1/input' }
{'simplifiedModel_SH_21a/DUT/SS1/TSS1/Trigger' }
{'simplifiedModel_SH_21a/DUT/SS1/TSS1/output' }
{'simplifiedModel_SH_21a/DUT/SS1/Unit Delay2' }
{'simplifiedModel_SH_21a/DUT/SS1/Unit Delay3' }
{'simplifiedModel_SH_21a/DUT/SS1/OUT1' }
{'simplifiedModel_SH_21a/DUT/SS2' }
{'simplifiedModel_SH_21a/DUT/SS2/In1' }
{'simplifiedModel_SH_21a/DUT/SS2/In2' }
{'simplifiedModel_SH_21a/DUT/SS2/SH1' } % SAMPLE and HOLD
{'simplifiedModel_SH_21a/DUT/SS2/Unit Delay2' }
{'simplifiedModel_SH_21a/DUT/SS2/Out1' }
{'simplifiedModel_SH_21a/DUT/Sin' } % SIN (CORDIC)
{'simplifiedModel_SH_21a/DUT/OUT1' }
{'simplifiedModel_SH_21a/DUT/OUT2' }
>>
댓글 수: 0
참고 항목
카테고리
Help Center 및 File Exchange에서 HDL Coder에 대해 자세히 알아보기
제품
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!