реклама на сайте
подробности

 
 
> массив на триггерах, как это объяснить синтезатору
zcost
сообщение Aug 28 2007, 06:28
Сообщение #1


Участник
*

Группа: Новичок
Сообщений: 19
Регистрация: 12-04-07
Пользователь №: 26 979



Как объяснить синтезатору, что нужно массив выполнить на триггерах для Спартана-3.

Объявляю массивы:

subtype data_type is STD_LOGIC_VECTOR( 15 downto 0 );
type data_array_type is array( 0 to 7 ) of data_type;

signal mem_wr_8x16: data_array_type;
signal mem_rd_8x16: data_array_type;

Но ISE9.1 упорно пытается организовать массивы с помощью RAM,а хотелось бы это сделать на триггерах, память нужна для других целей.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
sazh
сообщение Aug 28 2007, 10:30
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 2 435
Регистрация: 6-10-04
Из: Петербург
Пользователь №: 804



Конечно странно. что средствами пакета вы не можете дать указания синтезатору во что укладывать. в регистр или память. Но я не об этом.
По большому счету ведь все едино как массив данных скомпонован, одномерный или двумерный.
Наверно и у Вас стандартная ситуация. Накопить n 16 разрядных слов данных и сбросить разом.
Можно это как двумерный массив описать. Можно как одномерный. Просто пример. Может интересно будет.

entity shift_rga is
Port (
clk : in STD_LOGIC;
load : in STD_LOGIC;
data_in : in STD_LOGIC_VECTOR (15 downto 0);
data_outa : out STD_LOGIC_VECTOR (127 downto 0);
data_outb : out STD_LOGIC_VECTOR (127 downto 0)
);
end shift_rga;

architecture Behavioral of shift_rga is

signal outa : std_logic_vector(127 downto 0);
signal outb : std_logic_vector(127 downto 0);

begin

process (clk)
begin
if clk'event and clk = '1' then
if load = '1' then
outa <= outa(111 downto 0) & data_in;
outb <= data_in & outb(127 downto 16);
end if;
end if;
end process;

data_outa <= outa;
data_outb <= outb;

end Behavioral;
Go to the top of the page
 
+Quote Post
zcost
сообщение Aug 28 2007, 10:59
Сообщение #3


Участник
*

Группа: Новичок
Сообщений: 19
Регистрация: 12-04-07
Пользователь №: 26 979



Цитата(sazh @ Aug 28 2007, 13:30) *
Конечно странно. что средствами пакета вы не можете дать указания синтезатору во что укладывать. в регистр или память. Но я не об этом.
По большому счету ведь все едино как массив данных скомпонован, одномерный или двумерный.
Наверно и у Вас стандартная ситуация. Накопить n 16 разрядных слов данных и сбросить разом.
Можно это как двумерный массив описать. Можно как одномерный. Просто пример. Может интересно будет.

entity shift_rga is
Port (
clk : in STD_LOGIC;
load : in STD_LOGIC;
data_in : in STD_LOGIC_VECTOR (15 downto 0);
data_outa : out STD_LOGIC_VECTOR (127 downto 0);
data_outb : out STD_LOGIC_VECTOR (127 downto 0)
);
end shift_rga;

architecture Behavioral of shift_rga is

signal outa : std_logic_vector(127 downto 0);
signal outb : std_logic_vector(127 downto 0);

begin

process (clk)
begin
if clk'event and clk = '1' then
if load = '1' then
outa <= outa(111 downto 0) & data_in;
outb <= data_in & outb(127 downto 16);
end if;
end if;
end process;

data_outa <= outa;
data_outb <= outb;

end Behavioral;


В принципе проблему решил.
А за пример спасибо. Не совсем то, но мысль весьма интересная. Вполне может в будущем пригодиться.

Цитата(vetal @ Aug 28 2007, 13:45) *
хм...а чем не нравится размещение в озу?
Взять озу размером 2х пока копим одну половинку - работаем сдругой. "Быстрое копирование" получается путем изменения старшего бита адреса...все очень даже удобно.


Согласен, что удобно, только с памятью в проекте напряг.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- zcost   массив на триггерах   Aug 28 2007, 06:28
- - AJIEKCEu   Цитата(zcost @ Aug 28 2007, 10:28) Как об...   Aug 28 2007, 06:50
|- - zcost   Цитата(AJIEKCEu @ Aug 28 2007, 09:50) Име...   Aug 28 2007, 08:38
|- - Boris_TS   Цитата(zcost @ Aug 28 2007, 12:38) Не смо...   Sep 3 2007, 05:55
- - zcost   Нужно именно на тригеррах, так как возникает в дал...   Aug 28 2007, 07:14
|- - andrew_b   Цитата(zcost @ Aug 28 2007, 11:14) Нужно ...   Aug 28 2007, 07:16
|- - zcost   Цитата(andrew_b @ Aug 28 2007, 10:16) Зав...   Aug 28 2007, 07:54
|- - andrew_b   Цитата(zcost @ Aug 28 2007, 11:54) Имеетс...   Aug 28 2007, 08:14
- - AJIEKCEu   ЦитатаНужно именно на тригеррах, так как возникает...   Aug 28 2007, 08:14
|- - zcost   Цитата(AJIEKCEu @ Aug 28 2007, 11:14) Не ...   Aug 28 2007, 08:23
|- - AJIEKCEu   Цитата(zcost @ Aug 28 2007, 12:23) Действ...   Aug 28 2007, 08:29
- - sazh   Если нужно как регистры, почему нельзя сразу описа...   Aug 28 2007, 09:25
|- - zcost   Цитата(sazh @ Aug 28 2007, 12:25) Если ну...   Aug 28 2007, 10:15
- - vetal   хм...а чем не нравится размещение в озу? Взять озу...   Aug 28 2007, 10:45


Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 21st July 2025 - 10:33
Рейтинг@Mail.ru


Страница сгенерированна за 0.01373 секунд с 7
ELECTRONIX ©2004-2016