Вопросы настройки, программирования, прошивки микроконтроллеров и микросхем программируемой логики
Тема закрыта

AHDL, помогите с реализацией

Пн июл 02, 2012 13:05:30

Имея 2 регистра (>>1 бита), задать соединения входов и выходов одного в зависимости от значения второго (значения второго регистра берутся группами по несколько бит).
Заранее благодарен.

Re: AHDL, помогите с реализацией

Пн июл 02, 2012 18:19:13

Посадите все входы второго регистра на землю. Таким образом, будет реализована зависимость типа f(x)=0. Если не устраивает, перечитайте свой пост на предмет можно-ли его понять без телепатии.

Re: AHDL, помогите с реализацией

Вт июл 03, 2012 09:05:44

Имея первый регистр на 16 бит и второй на 64, нужно чтоб входы и выходы первого коммутировались в зависимости от состояния групп второго (по 4 бита).
Если: состояние второго :B'xxxx xxxx 1111 xxxx ...' , то 3-й вход первого соединить с 15-м выходом первого.
Будте добры, как реализовать? :shock:

Re: AHDL, помогите с реализацией

Вт июл 03, 2012 10:23:17

Я так полагаю, что имелось ввиду нечто такое:
Код:
INCLUDE "mux.inc";

SUBDESIGN ahd (
   selector[63..0] : INPUT;
   dat_i[15..0]    : INPUT;
   dat_o[15..0]     : OUTPUT;
)

BEGIN

FOR I IN 0 TO 15 GENERATE
    dat_o[I] = mux( .data = dat_i[], .sel = selector[ I*4+3 .. I*4 ])
               WITH( WIDTH=16, WIDTHS=4);
END GENERATE;

END;
Только сигналы коммутируются не со внешних входов входов на выходы, а выходы брошены назад на входы через регистр:
Код:
INCLUDE "mux.inc";

SUBDESIGN ahd (
   clk             : INPUT;
   selector[63..0] : INPUT;
   dat_o[15..0]     : OUTPUT;
)

VARIABLE
    rg[15..0] : DFF;

BEGIN
    dat_o[] = rg[];
    rg[].clk = clk;

FOR I IN 0 TO 15 GENERATE
    rg[I].d = mux( .data = dat_o[], .sel = selector[ I*4+3 .. I*4 ])
               WITH( WIDTH=16, WIDTHS=4);
END GENERATE;

END;
Само оно смысл еще имеет («crossbar switch»), а вот выходы на входы замыкать как-то странно, получается вещь, состояние которой не зависит ни от каких входов. Обратных связей, как в генераторе псевдослучайного числа, -- нет. У альтеры при включении все триггера сброшены, так что тут на все входы будут поступать нули.
Можно, конечно, таким образом пофантазировать на тему случайного состояния триггеров при включении и генерации таким образом какого-то шума, но всё равно странно.

Re: AHDL, помогите с реализацией

Вт июл 03, 2012 11:11:58

Подразумевается, что этакая коммутация будет зависеть от некоего значения, заранее хранящегося в другом месте.

Благодарю за помощь!)
Тема закрыта