Перейти к содержанию
    

чайницкий вопрос про счетчик

Подскажите, пожалуйста, почему этот простой счетчик, считающий туда-сюда, симулируется на MAX7000s, а на Stratix, к примеру, не работает?

Quartus 8.1 Web Edition

LIBRARY ieee;
USE ieee.std_logic_1164.all;
USE ieee.std_logic_arith.all;
USE IEEE.std_logic_unsigned.all;
ENTITY lpm_counter0 IS
    PORT
    (
        clk        : IN STD_LOGIC;
        q        : OUT STD_LOGIC_VECTOR (3 DOWNTO 0)
    );
END lpm_counter0;


ARCHITECTURE SYN OF lpm_counter0 IS

    SIGNAL summ    : STD_LOGIC_VECTOR (3 DOWNTO 0);
    signal equal : STD_LOGIC;
    signal updown : STD_LOGIC;
begin
    
    q <= summ;
    equal <= '1' when summ = "1111" or summ = "0000" else '0';
    updown <= not updown when rising_edge(equal);
    
process(clk)
    begin
    if rising_edge(clk) and updown = '0' then 
        summ <= summ + "0001";
    elsif rising_edge(clk) and updown = '1' then
        summ <= summ - "0001";
    end if;
end process;



END SYN;

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Так это - того, тут же ошибка в кодировании:

process(clk)
    begin
    if rising_edge(clk) and updown = '0' then 
        summ <= summ + "0001";
    elsif rising_edge(clk) and updown = '1' then
        summ <= summ - "0001";
    end if;
end process;

Попробуйте так:

process(clk) begin
    if rising_edge(clk) then
        if updown = '0' then 
            summ <= summ + "0001";
        else    -- updown = '1'
            summ <= summ - "0001";
        end if;
    end if;
end process;

Почитайте более детально, что такое Rising_edge и 'Event.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Да, сспасибо, так правильнее несомненно. Но ничего не изменилось, при задании MAX7000 оно симулируется, а на других девайсах нет. Наверное дело в каких-то настройках проекта

 

на древних плисах симулируется, а на более поздних я пытаюсь просто скомпилировать и симулировать этот же проект, и он не работает. Гугл не помогает

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

2 kostage

updown <= not updown when rising_edge(equal);

асинхра однако, может в этом проблема ?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

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

 

так-то лучше

 

LIBRARY ieee;

USE ieee.std_logic_1164.all;

USE ieee.std_logic_arith.all;

USE IEEE.std_logic_unsigned.all;

ENTITY lpm_counter0 IS

PORT

(

clk : IN STD_LOGIC ;

q : OUT STD_LOGIC_VECTOR (3 DOWNTO 0);

equal : inout STD_LOGIC;

updown :inout STD_LOGIC );

END lpm_counter0;

 

 

ARCHITECTURE SYN OF lpm_counter0 IS

 

SIGNAL summ : STD_LOGIC_VECTOR (3 DOWNTO 0);

 

begin

 

q <= summ;

equal <= '1' when summ = "1111" or summ = "0000" else '0';

process(clk) begin

if falling_edge(clk) then

if summ = "0000" or summ = "1111" then

updown <= not updown;

end if;

end if;

end process;

 

process(clk) begin

if rising_edge(clk) then

if updown = '0' then

summ <= summ + "0001";

else -- updown = '1'

summ <= summ - "0001";

end if;

end if;

end process;

 

 

END SYN;

 

Электронихх способствует просветлению

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Электронихх способствует просветлению

Вообще во всех софтовых инструментах есть шаблоны. Изобретать велосипед неплохо, но прежде чем выкладывать опусы в форуме проще посмотреть шаблоны... Где они находятся я написал в "Кратком Курсе"... Это у меня на сайте, в статьях.

Ну и есть лабораторные работы по курсам повышения квалификации, у Альтеры точно выложено...

Удачи!

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Спасибо! Да и еще надо контролировать вместе с суммой и направление счета

 

process(clk) begin

if falling_edge(clk) then

if summ = "0000" and updown = '0' then

updown <= not updown;

elsif summ = "1111" and updown = '1' then

updown <= not updown;

end if;

end if;

end process;

 

Изменено пользователем kostage

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
К сожалению, ваш контент содержит запрещённые слова. Пожалуйста, отредактируйте контент, чтобы удалить выделенные ниже слова.
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...