Синхронное поведение подсистемы с блоком Госконтроля

Что такое блок Госконтроля?

Когда вы имеете блоки с состоянием и имеете, включают или сбрасывают порты в подсистеме, используют Synchronous режим блока State Control к:

  • Обеспечьте эффективный, включают и сбрасывают поведение симуляции на оборудовании.

  • Сгенерируйте более чистый HDL-код и используйте меньше ресурсов на оборудовании.

Можно добавить блок State Control в Simulink® модель на любом уровне в иерархии модели. То, как вы устанавливаете блок State Control, влияет на поведение симуляции других блоков в подсистеме, которые имеют состояние.

  • Для синхронного аппаратного поведения симуляции, набор State control к Synchronous.

  • Для поведения симуляции Simulink по умолчанию, набор State control к Classic.

Блочные режимы Госконтроля

ФункциональностьСинхронный режимКлассический режим
Установка блока State ControlУстановка блока по умолчанию, когда вы добавляете блок из библиотеки блоков Подсистем HDL. Поведение симуляции совпадает с подсистемой, которая не использует блок State Control.
Поведение симуляции Simulink
  • Инициализируйте метод: Инициализирует состояния.

  • Метод Update: состояния Обновлений.

  • Выходной метод: Вычисляет выходные значения.

Метод обновления только обновляет состояния. Выходной метод вычисляет выходные значения на каждом временном шаге.

Например, когда вы включили подсистемы, изменения выходного значения, когда разрешать сигнал является низким, когда это обрабатывает новые входные значения. Выходное значение совпадает с выходом от Classic режим, когда включают сигнал, становится высоким.

Обновления метода обновления утверждают и вычисляют выходные значения.

Например, когда вы включили подсистемы, выходное значение считается устойчивое, когда разрешать сигнал является низким и изменяется только, когда разрешать сигнал становится высоким.

Поведение симуляции HDLБолее эффективный на оборудовании.Менее эффективный на оборудовании.
Поведение генерации HDL-кода

Сгенерированный HDL-код более чист и использует меньше ресурсов на оборудовании.

Например, когда вы включили подсистемы, HDL Coder™ не генерирует обходные регистры для каждого обновления состояния и использует меньше аппаратных ресурсов.

Сгенерированный HDL-код не является столь же чистым и использует больше аппаратных ресурсов.

Например, когда вы включили подсистемы, HDL Coder генерирует обходные регистры для каждого обновления состояния и использует больше ресурсов.

Чтобы узнать больше, когда можно будет использовать блок State Control, смотрите Госконтроль.

Синхронный значок для подсистем при помощи синхронного режима

Чтобы видеть, использует ли подсистема в вашей модели Simulink синхронную семантику:

  • Символ S отображен на подсистеме, чтобы указать на синхронное поведение.

  • Если вы дважды кликаете подсистему SynchronousStateControl, значок S отображен в редакторе Simulink, чтобы указать, что блоки в подсистеме используют синхронную аппаратную семантику.

SynchronousStateControl и подсистемы ClassicStateControl используют блок Delay с внешним сбросом и разрешать портом в Synchronous и Classic режимы соответственно.

Сгенерируйте HDL-код с блоком Госконтроля

Следующая таблица показывает сравнение HDL-кода, сгенерированного от блока Delay для Classic и Synchronous режимы блока State Control.

ФункциональностьСинхронный режимКлассический режим
Генерация HDL-кода. Настройки применяются:
  • Language: Verilog

  • Reset type: Synchronous


`timescale 1 ns / 1 ns

module SynchronousStateControl
          (
           clk,
           reset,
           enb,
           DataIn,
           EnableIn,
           ResetIn,
           DataOut
          );


  input   clk;
  input   reset;
  input   enb;
  input   signed [7:0] DataIn;  // int8
  input   EnableIn;
  input   ResetIn;
  output  signed [7:0] DataOut;  // int8


  reg signed [7:0] Delay_Synchronous_reg [0:1];  // sfix8 [2]
  wire signed [7:0] Delay_Synchronous_reg_next [0:1];  // sfix8 [2]
  wire signed [7:0] Delay_Synchronous_out1;  // int8


  always @(posedge clk)
    begin : Delay_Synchronous_process
      if (reset == 1'b1 || ResetIn == 1'b1) begin
        Delay_Synchronous_reg[0] <= 8'sb00000000;
        Delay_Synchronous_reg[1] <= 8'sb00000000;
      end
      else begin
        if (enb && EnableIn) begin
          Delay_Synchronous_reg[0] <= Delay_Synchronous_reg_next[0];
          Delay_Synchronous_reg[1] <= Delay_Synchronous_reg_next[1];
        end
      end
    end

  assign Delay_Synchronous_out1 = Delay_Synchronous_reg[1];
  assign Delay_Synchronous_reg_next[0] = DataIn;
  assign Delay_Synchronous_reg_next[1] = Delay_Synchronous_reg[0];



  assign DataOut = Delay_Synchronous_out1;

endmodule  // SynchronousStateControl




  • Сгенерированный HDL-код более чист и требует меньшего количества аппаратных ресурсов, когда HDL Coder не генерирует обходные регистры.

  • Метод обновления только обновляет состояния.


`timescale 1 ns / 1 ns

module ClassicStateControl
          (
           clk,
           reset,
           enb,
           DataIn,
           EnableIn,
           ResetIn,
           DataOut
          );


  input   clk;
  input   reset;
  input   enb;
  input   signed [7:0] DataIn;  // int8
  input   EnableIn;
  input   ResetIn;
  output  signed [7:0] DataOut;  // int8


  reg signed [7:0] Delay_Synchronous_bypass;  // sfix8
  reg signed [7:0] Delay_Synchronous_reg [0:1];  // sfix8 [2]
  wire signed [7:0] Delay_Synchronous_bypass_next;  // sfix8
  wire signed [7:0] Delay_Synchronous_reg_next [0:1];  // sfix8 [2]
  wire signed [7:0] Delay_Synchronous_delay_out;  // sfix8
  wire signed [7:0] Delay_Synchronous_out1;  // int8


  always @(posedge clk)
    begin : Delay_Synchronous_process
      if (reset == 1'b1 || ResetIn == 1'b1) begin
        Delay_Synchronous_bypass <= 8'sb00000000;
        Delay_Synchronous_reg[0] <= 8'sb00000000;
        Delay_Synchronous_reg[1] <= 8'sb00000000;
      end
      else begin
        if (enb && EnableIn) begin
          Delay_Synchronous_bypass <= Delay_Synchronous_bypass_next;
          Delay_Synchronous_reg[0] <= Delay_Synchronous_reg_next[0];
          Delay_Synchronous_reg[1] <= Delay_Synchronous_reg_next[1];
        end
      end
    end

  assign Delay_Synchronous_delay_out = (ResetIn == 1'b1 ? 8'sb00000000 :
              Delay_Synchronous_reg[1]);
  assign Delay_Synchronous_out1 = (EnableIn == 1'b1 ? Delay_Synchronous_delay_out :
              Delay_Synchronous_bypass);
  assign Delay_Synchronous_bypass_next = Delay_Synchronous_delay_out;
  assign Delay_Synchronous_reg_next[0] = DataIn;
  assign Delay_Synchronous_reg_next[1] = Delay_Synchronous_reg[0];



  assign DataOut = Delay_Synchronous_out1;

endmodule  // ClassicStateControl


  • Сгенерированный HDL-код менее более чист и требует большего количества аппаратных ресурсов, когда HDL Coder генерирует обходные регистры.

  • Обновления метода обновления утверждают и вычисляют выходные значения.

Включите и аппаратное поведение симуляции сброса

Обратитесь к вышеупомянутой модели Simulink, которая показывает блок Delay, который использует Classic и Synchronous режимы блока State Control. Следующая схема показывает ModelSim® поведение симуляции для блока Delay.

  • Когда сигнал ResetIn высок, DataClassic и сигналы DataSynchronous производят тот же выход.

  • Когда и ResetIn и сигналы EnableIn являются низкими, сигнал DataSynchronous содержит свое значение и изменяется только, когда сигнал EnableIn становится высоким в следующем активном фронте синхроимпульса. Значения сигналов DataClassic изменяются, когда сигнал EnableIn является низким, когда он обрабатывает новые входные значения. Значения сигналов DataClassic совпадают со значениями сигналов DataSynchronous, когда EnableIn становится высоким.

Для получения информации о том, как сгенерировать HDL-код и симулировать ваш проект в ModelSim, видит, Генерируют HDL-код из Модели Simulink.

Смотрите также