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

Vhdl. Вопрос С Тактируемостью.


laboshin

Рекомендуемые сообщения

Делаю калькулятор. Один из блоков блок обеспечивающий ввод с клавиатуры многозначных чисел. вот его текст:

library ieee;

use ieee.std_logic_1164.all;

use ieee.std_logic_unsigned.all;

entity num_input_drive is

port(

data_in : in integer range 0 to 15; --расшифрованый скан-код клавиши

clk : in std_logic; --25MGZ

strobe_rise : in std_logic; --фронт сигнала нажатия клавиши

Q_K : in integer range 0 to 15; --скан-код клавиши

data_out : out integer range 0 to 255; --результат

ready : out integer range 0 to 15 --управляющий сигнал для следующего блока

);

end num_input_drive;

architecture Arch of num_input_drive is

CONSTANT ten : integer range 0 to 255 :=10;

signal mem : integer range 0 to 255;

begin

process(clk)

begin

if clk'event and clk='1' then

if(strobe_rise='1')then

case Q_K is

when 4=>

data_out<=mem;mem<=0;ready<=4;

when 15=>

mem<=0;ready<=15;

when 14=>

mem<=0;ready<=14;

when 13=>

mem<=0;ready<=13;

when 12=>

mem<=0;ready<=12;

when 11=>

mem<=0;

ready<=11;

when others =>

mem<= data_in + mem * ten; data_out<= mem;

ready<=0;

end case;

--else data_out<=mem; ready<=1;

end if;

end if;

end process;

end Arch;

Все работает как надо, проблемма в задержке на несколько тактов. Вот временная диаграмма

post-131854-0-50364900-1293489416_thumb.png

Как добиться "синхронного" нажатия кнопки и вывода данных? Спасибо.

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

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

У Вас в коде разумнее бы было в список чувствительности процесса включить не clk, но strobe_rise, так как по нему работает алгоритм. Его фронт запустит процесс, а по фронту clk далее синхронизируйте сигналы.

Сейчас все правильно работает. По фронту clk проверяется логический уровень strobe_rise и если он единица, то работает алгоритм, а если нет - ожидается следующий фронт clk.

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

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

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

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

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

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

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

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

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

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
×
×
  • Создать...