Поддержка генерации HDL-кода

Можно использовать Simulink® для быстрого прототипирования аппаратных проектов. Блоки LTE HDL Toolbox™, когда используется с HDL Coder™, поддерживают генерацию HDL-кода. Инструменты HDL Coder генерируют независимый от цели синтезируемый Verilog® и код VHDL® для программирования FPGA или прототипирования ASIC и проекта.

Поддержка генерации HDL-кода в LTE HDL Toolbox

Большинство блоков в LTE HDL Toolbox поддерживает генерацию HDL-кода.

Следующие блоки для симуляции только и не поддержаны для генерации HDL-кода:

  • Структурируйте к выборкам

  • Выборки, чтобы структурировать

  • Кадр FIL к выборкам

  • Выборки FIL, чтобы структурировать

Другие блоки, поддерживающие генерацию HDL-кода

Другие продукты MathWorks® также включают блоки, поддержанные для генерации HDL-кода, которую можно использовать, чтобы создать проект.

В браузере Библиотеки Simulink можно найти библиотеки блоков поддерживаемыми для генерации HDL-кода в HDL Coder, Communications Toolbox HDL Support и библиотеках блоков DSP System Toolbox HDL Support.

Чтобы создать библиотеку поддержанных HDL блоков от всех ваших установленных продуктов, введите hdllib в командной строке MATLAB®. Эта команда требует лицензии HDL Coder.

Обратитесь к страницам Supported Blocks (HDL Coder) для реализаций блока, свойств и ограничений для генерации HDL-кода.

Потоковая передача демонстрационного интерфейса в HDL

Передающий потоком демонстрационный тип данных шины управления, используемый блоками LTE HDL Toolbox, сглажен в отдельные сигналы в HDL.

В VHDL интерфейс объявляется как:

  PORT( clk             :   IN    std_logic;
        reset           :   IN    std_logic;
        enb             :   IN    std_logic;
        in0             :   IN    std_logic_vector(7 DOWNTO 0); -- uint8
        in1_start       :   IN    std_logic;
        in1_end         :   IN    std_logic;
        in1_valid       :   IN    std_logic;
        out0            :   OUT   std_logic_vector(7 DOWNTO 0); -- uint8
        out1_start      :   OUT   std_logic;
        out1_end        :   OUT   std_logic;
        out1_valid      :   OUT   std_logic
        );

В Verilog интерфейс объявляется как:

  input   clk;
  input   reset;
  input   enb;
  input   [7:0] in0;  // uint8
  input   in1_start;
  input   in1_end;
  input   in1_valid;
  output  [7:0] out0;  // uint8
  output  out1_start;
  output  out1_end;
  output  out1_valid;

Похожие темы