здравствуйте всем! Начал изучать программируемую логику на примере от Xilinx. Собственно скачал последнюю версию их САПР. Нарисовал схему, но вот просимулировать не получается, вернее не могу понять как создавать тактовые сигналы на входе, что бы в Isim понаблюдать сигналы за отрезок времени t?
Качественное и безопасное устройство, работающее от аккумулятора, должно учитывать его физические и химические свойства, профили заряда и разряда, их изменение во времени и под влиянием различных условий, таких как температура и ток нагрузки. Мы расскажем о литий-ионных аккумуляторных батареях EVE и нескольких решениях от различных китайских компаний, рекомендуемых для разработок приложений с использованием этих АКБ. Представленные в статье китайские аналоги помогут заменить продукцию западных брендов с оптимизацией цены без потери качества.
Начал изучать программируемую логику на примере от Xilinx. Собственно скачал последнюю версию их САПР(XILINX ISE 11.1). Нарисовал схему, но вот про симулировать не получается, вернее не могу понять как создавать тактовые сигналы подаваемые на вход схемы, что бы в ISim понаблюдать сигналы за отрезок времени t на выбранных выводах? в XILINX ISE 10.1 немного все по другому....
Компания EVE выпустила новый аккумулятор серии PLM, сочетающий в себе высокую безопасность, длительный срок службы, широкий температурный диапазон и высокую токоотдачу даже при отрицательной температуре.
Эти аккумуляторы поддерживают заряд при температуре от -40/-20°С (сниженным значением тока), безопасны (не воспламеняются и не взрываются) при механическом повреждении (протыкание и сдавливание), устойчивы к вибрации. Они могут применяться как для автотранспорта (трекеры, маячки, сигнализация), так и для промышленных устройств мониторинга, IoT-устройств.
Сейчас навскидку не скажу -- посмотреть времени нету. Возможно, проблема в том, что просто не подал тактовый сигнал на вход своей схемы. У каждой отладочной платы своя разводка ног ПЛИС, вот и надо посмотреть, на какую генератор завязан.
Сейчас навскидку не скажу -- посмотреть времени нету. Возможно, проблема в том, что просто не подал тактовый сигнал на вход своей схемы. У каждой отладочной платы своя разводка ног ПЛИС, вот и надо посмотреть, на какую генератор завязан.
Или вопрос не об этом?
Ну почти, ты в железе имеешь виду, а я в про симулятор работы, ISim, работал в таком?
Сейчас навскидку не скажу -- посмотреть времени нету. Возможно, проблема в том, что просто не подал тактовый сигнал на вход своей схемы. У каждой отладочной платы своя разводка ног ПЛИС, вот и надо посмотреть, на какую генератор завязан.
Или вопрос не об этом?
Ну почти, ты в железе имеешь виду, а я в про симулятор работы, ISim, работал в таком?
А, в симе... Помню, что с этим долго мучился, но как-то сделал, но в чём проблема была -- убей не помню (тем более что потом я его не использовал -- пока сложные схемы не делал, а посему обходился без симуляции). Посмотреть сейчас, как говорил, времени нет (работа, блин), но если вспомню или время появится -- напишу.
Зарегистрирован: Пт июн 26, 2009 14:31:59 Сообщений: 15 Откуда: Россия г. Ульяновск
Рейтинг сообщения:0
Когда увидел пост обрадовался, подумал что я не один! Сам с неделю назад поставил 11 версию Xilinx ISE.
Насколько я понял из одного файла документации с сайта сигналы задаются с помощью модулей на verilog или vhdl.
Думаю что нужно в этом направлении двигаться. Может сегодня ночью сделаю еще одну попытку.
Когда увидел пост обрадовался, подумал что я не один! Сам с неделю назад поставил 11 версию Xilinx ISE. Насколько я понял из одного файла документации с сайта сигналы задаются с помощью модулей на verilog или vhdl. Думаю что нужно в этом направлении двигаться. Может сегодня ночью сделаю еще одну попытку.
Вдвоем уже проще будет разбираться! Я тоже этот вариант рассматривал, но не пробовал. Завтра тоже сделаю n-ую попытку чтобы понять... А этот файл документации, в котором видел, можешь его выложить, или это было мельком?
Народ! Качайте 11 версию Xilinx ISE! Давайте вместе разбираться!!!
Только что выяснил, что я полный идиот Я ж использовал версию 10.1, а не 11 Так что качаю 11-ю, буду разираться завтра (благо работу спихнул, завтра день свободный).
Зарегистрирован: Пт июн 26, 2009 14:31:59 Сообщений: 15 Откуда: Россия г. Ульяновск
Рейтинг сообщения:0
nick17 писал(а):
Вдвоем уже проще будет разбираться! Я тоже этот вариант рассматривал, но не пробовал. Завтра тоже сделаю n-ую попытку чтобы понять... А этот файл документации, в котором видел, можешь его выложить, или это было мельком?
Кажеться нашел. Осталось только повнимательней почитать!
Ограничения на вложения
Народ! Качайте 11 версию Xilinx ISE! Давайте вместе разбираться!!!
Только что выяснил, что я полный идиот Я ж использовал версию 10.1, а не 11 Так что качаю 11-ю, буду разираться завтра (благо работу спихнул, завтра день свободный).
Давай давай! Вместе веселее и проще будет я думаю!
Зарегистрирован: Пт июн 26, 2009 14:31:59 Сообщений: 15 Откуда: Россия г. Ульяновск
Рейтинг сообщения:0
Все! Я разобрался с проблемой. Я был прав, сигналы задаются с помощью модулей на VHDL и Verilog. Правильнее сказать сигналы можно так задавать. По крайней мере у меня получилось это сделать на VHDL.
Итак: нужно добавить в проект модуль с типом "VHDL Test Bench" ISE сгенерирует компонент в котором все порты будут сопоставлены сигналам и этим сигналам можно будет задавать значения.
Сам еще не силен в этом (портах, сигналах, да и вообще в VHDL и Verilog)
Я спать. Завтра набросаю инструкцию с картинками если кого-нибудь заинтересует…
Все! Я разобрался с проблемой. Я был прав, сигналы задаются с помощью модулей на VHDL и Verilog. Правильнее сказать сигналы можно так задавать. По крайней мере у меня получилось это сделать на VHDL.
Итак: нужно добавить в проект модуль с типом "VHDL Test Bench" ISE сгенерирует компонент в котором все порты будут сопоставлены сигналам и этим сигналам можно будет задавать значения.
Сам еще не силен в этом (портах, сигналах, да и вообще в VHDL и Verilog)
Я спать. Завтра набросаю инструкцию с картинками если кого-нибудь заинтересует…
Спасибо!!! Да уж, что то я недокумекал до этого))) Конечно нужно, хотя и сам щас попробую как ты написал сделать, может и разберусь
Вот как генерят синхросигнал в тестбенче из примера, используемого в обучалке по ISim:
Код:
PROCESS -- clock process for clk_in BEGIN CLOCK_LOOP : LOOP clk_in <= '0'; WAIT FOR PERIOD * 0.5; clk_in <= '1'; WAIT FOR PERIOD * 0.5; END LOOP CLOCK_LOOP; END PROCESS;
Если перевести на русский: на линии clk_in выставляется 0, через полпериода синхронизации (PERIOD определена как константа в коде выше, там она равна 10000 ps, т.е. 10 нс) выставляется 1, через очередные полпериода -- снова нуль и т.д. Частота в данном случае равна 100 МГц, поскольку период установлен равным 10 нс.
А вот моя жутко примитивная схемка (одноразрядный компаратор: выдаёт на выходе 1, если оба входа равны) и тестбенч к ней. Как ни странно, симуляция работает
Это компаратор:
Код:
library IEEE; use IEEE.STD_LOGIC_1164.ALL; use IEEE.STD_LOGIC_ARITH.ALL; use IEEE.STD_LOGIC_UNSIGNED.ALL;
entity Comparator1 is Port ( A : in STD_LOGIC; B : in STD_LOGIC; EQ : out STD_LOGIC); end Comparator1;
architecture Behavioral of Comparator1 is signal P0, P1 : STD_LOGIC; begin EQ <= P0 or P1; P0 <= (not A) and (not B); P1 <= A and B; end Behavioral;
А это тестбенч:
Код:
library IEEE; use IEEE.STD_LOGIC_1164.ALL; use IEEE.STD_LOGIC_ARITH.ALL; use IEEE.STD_LOGIC_UNSIGNED.ALL;
entity Comparator1 is Port ( A : in STD_LOGIC; B : in STD_LOGIC; EQ : out STD_LOGIC); end Comparator1;
architecture Behavioral of Comparator1 is signal P0, P1 : STD_LOGIC; begin EQ <= P0 or P1; P0 <= (not A) and (not B); P1 <A> A, B => B, EQ => EQ );
-- Собственно процесс тестирования stim_proc: process variable Message : line; begin -- Ожидание для выполнения начального сброса схемы wait for 100 ns; -- Первый тест A <= '0'; B <= '0'; wait for 5 ns; if EQ = '1' then Write(Message, "Test 1 PASS"); else Write(Message, "Test 1 FAIL"); end if; WriteLine(Output, Message); wait for 95 ns; -- Второй тест A <= '0'; B <= '1'; wait for 5 ns; if EQ = '0' then Write(Message, "Test 2 PASS"); else Write(Message, "Test 2 FAIL"); end if; WriteLine(Output, Message); wait for 95 ns; -- Третий тест A <= '1'; B <= '0'; wait for 5 ns; if EQ = '0' then Write(Message, "Test 3 PASS"); else Write(Message, "Test 3 FAIL"); end if; WriteLine(Output, Message); wait for 95 ns; -- Четвёртый тест A <= '1'; B <= '1'; wait for 5 ns; if EQ = '1' then Write(Message, "Test 4 PASS"); else Write(Message, "Test 4 FAIL"); end if; WriteLine(Output, Message); wait for 95 ns; -- Тестирование закончено assert false report "Simu1ation Comp1eted" severity failure; end process; END;
Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 5
Вы не можете начинать темы Вы не можете отвечать на сообщения Вы не можете редактировать свои сообщения Вы не можете удалять свои сообщения Вы не можете добавлять вложения