здравствуйте всем! Начал изучать программируемую логику на примере от Xilinx. Собственно скачал последнюю версию их САПР. Нарисовал схему, но вот просимулировать не получается, вернее не могу понять как создавать тактовые сигналы на входе, что бы в Isim понаблюдать сигналы за отрезок времени t?
Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ очень важен контроль процесса заряда и разряда для избегания воздействия внешнего зарядного напряжения после достижения 100% заряда. Инженеры КОМПЭЛ подготовили список таких решений от разных производителей.
Начал изучать программируемую логику на примере от 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;
Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 8
Вы не можете начинать темы Вы не можете отвечать на сообщения Вы не можете редактировать свои сообщения Вы не можете удалять свои сообщения Вы не можете добавлять вложения