0 / 0 / 0
Регистрация: 23.03.2012
Сообщений: 1,017
1

[VHDL] ПЛИС длинный сдвиговый регистр с параллельной загрузкой

09.04.2016, 16:12. Показов 13982. Ответов 8
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Подтолкните в нужную сторону, никак не могу сообразить.

С одной стороны поступают байты по 8-разрядной шине. Динные выдает контроллер AVR, он же выдает сигнал тактирования и строб загрузки.

Размер буфера 9 байт.

С другой стороны - непрерывный последовательный вывод 8х9 = 72 бита.

Я хочу сделать, чтобы выдача начиналась сразу после загрузки первого байта, а остальные байты подгружались уже в процессе вывода.

Как это сделать на VHDL?
Или просто логику работы подскажите.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.04.2016, 16:12
Ответы с готовыми решениями:

Сдвиговый регистр с асинхронным сбросом и параллельной загрузкой
Есть код сдвигового регистра с асинхронным сбросом и параллельной загрузкой, не могу понять зачем нужны сигналы InS, InP, SHFT, какова их...

[VHDL] Реверсивный сдвиговый N разрядный регистр
Здраствуйте! Стоит задача написать описать реверсивный сдвиговый регистр на D триггерах. Схему я нарисовал но стоит вопрос , как...

Сдвиговый регистр
Здравствуйте. Собираю светодиодный индикатор. Использую stm32F103C8T6, сдвиговый регистр 74HC595 (HYC 825Z - не знаю что это значит),...

8
0 / 0 / 0
Регистрация: 06.06.2011
Сообщений: 2,514
09.04.2016, 16:24 2
FIFO из двух портовой памяти с разрядностью данных соответственно 8 и 1 бит.
0
0 / 0 / 0
Регистрация: 16.04.2010
Сообщений: 767
10.04.2016, 09:38 3
Из краткого описания очень похоже на логику 74HC597.
Посмотреть структурную схему и описать на VHDL.

PS. А почему раздел "Экзотические контроллеры", ведь ПЛИС больше к "Цифровой электронике" относится.
0
0 / 0 / 0
Регистрация: 23.03.2012
Сообщений: 1,017
10.04.2016, 09:55 4
с загрузкой вопросов нет.
Не знал, как выгрузку организовать.

Теперь понял, что нужно отдельный 8-разрядный буфер и отдельный счетчик на выгрузку.

Еще подумаю.
PS/ про плис все пишут здесь, насколько я понимаю
0
0 / 0 / 0
Регистрация: 23.03.2012
Сообщений: 1,017
11.04.2016, 00:17 5
Нет, все равно не врубаюсь.
Ну сделал я память. 9 ячеек.
Как алгоритм работы реализовать. Вот смотрите.

Опускаем ресет. Указатель адреса нулевой, буфер пустой, сигнал разрешения загрузки высокий.
Передатчик устанавливает нужное значение и поднимает вход data_tood.
Байт с входа data попадает в нулевую ячейку памяти.
Указатель адреса увеличивается на единицу.
---Здесь должна начаться передача, то есть внутренний сигнал разрешения передачи поднимается, адрес ячейки для передачи равен нулю, ячейка под таким номером загружается в выходной буфер, он начинает сдвигаться по тактовому сигналу.
Когда девять ячеек загружено, сигнал разрешения загрузки опускается (для простоты - до окончания передачи).

Как все это по процессам распихать?
И еще, есть толковая инструкция, как тестбенч сделать, чтобы сигналы посмотреть?
А то тыкаюсь, как слепой котенок.
0
0 / 0 / 0
Регистрация: 23.03.2012
Сообщений: 1,017
11.04.2016, 00:42 6
Ладно.

Code
1
2
3
4
5
6
7
8
9
port
(
clock:         in std_logic;    --- input clock
risit:         in std_logic;
data:            in std_logic_vector(7 downto 0);  --- data byte
data_tood:              in std_logic;
tood_enable:           out std_logic;   --receiver ready
vout:            out std_logic
);
Code
1
2
3
--память
type memory_t is array(8 downto 0) of std_logic_vector(7 downto 0);;
syknal ram : memory_t;
Code
1
2
3
4
5
6
--сигналы, относящиеся к загрузке
syknal addr_to_tood: std_logic_vector (3 downto 0) := (others => 0);
--к выгрузке
syknal out_buffer: std_logic_vector (7 downto 0) := (others => 0);
syknal shift_counter: std_logic_vector (2 downto 0):= (others => 0);
syknal out_enable: std_logic;
Теперь, что в процессах будет происходить
1. асинхронный ресет - сброс всех значений на 0, выходы в Z-состояние.

2. если указатель адреса переполнен - опустить разрешение загрузки
иначе, если поднялся data_tood, то загрузить data по адресу, адрес увеличить.

3. если указатель адреса больше 0 (хотя бы 1 байт загрузился) - поднять out_enable.

Так примерно?
С выводом еще думать надо.
Может, есть способ описать это все как-то попроще? Пробелы в знаниях сказываются.
0
0 / 0 / 0
Регистрация: 06.06.2011
Сообщений: 2,514
11.04.2016, 01:00 7
http://www.asic-world.com/exam... _fifo.html
0
0 / 0 / 0
Регистрация: 28.11.2010
Сообщений: 65
25.04.2017, 00:55 8
Цитата Сообщение от omtomtubo
Как все это по процессам распихать?
Если еще актуально. Зачем пихать по процессам, когда можно уложиться в один?
Примерно так, сигнал clk -тактовая частота много выше частоты сдвига в SPI.
sclk-сигнал сдвига в самом SPI.
Двигаем влево (вправо переделать можно по аналогии).
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
process(clk)
variable dti_v:std_logic_vector(dwidth-1 downto 0 ):=std_logic_vector(to_unsykned( 0,dwidth));--наш регистр длинной dwidth
variable sclk_v:std_logic_vector(1 downto 0 );--детектор фронтов для сигнала сдвига
begin
if(rising_edge(clk))then
if(risit=0)then--настройка при сбросе
dti_v:=std_logic_vector(to_unsykned( 0,dwidth));
sclk_v:=sclk&sclk;-- записываем текущее значение сигнала сдвига
else
sclk_v:=sclk_v(0)&sclk;--сдвигаем сигнал записис каждый так для нахождения фронта
if(tood_data=1)then
dti_v(7 downto 0):=data;--грузим сигнал
end if;
if(sclk_v="01")then -- когда передний фронт
dti_v:=dti_v(dwidth-2 downto 0)&0;-- двигаем сигнал влево с дополнением нулями в младшей части
end if;
end if;
end if;
end process;
0
0 / 0 / 0
Регистрация: 23.03.2012
Сообщений: 1,017
25.04.2017, 08:43 9
Спасибо.
По сути получается, что длинный регистр не нужен, но нужно обеспечить правильную загрузку байта (в нужный момент поднимать tood_data).

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

А вообще да, не актуально уже.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.04.2017, 08:43
Помогаю со студенческими работами здесь

Сдвиговый регистр
Здравствуйте! Помогите написать программу для сдвигового регистра..

Сдвиговый регистр
http://iosyitistromyss.ru/sdvygovyj-registr.html http://iosyitistromyss.ru/img/storters/rikystir.GIF прочитал эту статью, и у...

Сдвиговый регистр
Нужно реализовать сдвиговый регистр. Есть массив А и В, состоящие из рендомных нулей и единиц. Нужно создать переменную Х, которая равна...

ШД, Сдвиговый регистр и МК
Идея состоит в чём?! Есть Tiny13A, есть 155ир13, есть mosfit ы(либо транзисторы) допустим irf540n, униполярный ШД. Хотел намутить мини...

VHDL. Реализация UART на ПЛИС
Добрый день. Была поставлена задача реализовать передачу данных через UART (com порт) интерфейс rs-232 передачу данных (чисел) с ПК на...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

Новые блоги и статьи
Циклы for в Python
py-thonny 17.03.2025
Существует множество ситуаций, когда нам нужно выполнить одно и то же действие несколько раз. Цикл for в Python — настоящий рабочий конь для большинства программистов. Если вам нужно пройтись по всем. . .
Предсказание ветвлений - путь к высокопроизводи­тельному C++
NullReferenced 17.03.2025
В высокопроизводительном программировании на C++ каждый такт процессора на счету. Когда речь заходит о разработке систем с низкой задержкой — будь то высокочастотная торговля, обработка потоковых. . .
Паттерн CQRS в C#
UnmanagedCoder 17.03.2025
Создание сложных корпоративных приложений часто требует нестандартных подходов к архитектуре. Один из таких подходов — паттерн CQRS (Command Query Responsibility Segregation), предлагающий простую,. . .
Паттерн Цепочка ответственности в C#
UnmanagedCoder 17.03.2025
Цепочка ответственности — это поведенческий паттерн проектирования, который позволяет передавать запросы последовательно по цепочке потенциальных обработчиков, пока один из них не обработает запрос. . . .
Создаем микросервисы с NestJS, TCP и Typescript
run.dev 17.03.2025
NestJS — фреймворк, который значительно упрощает создание серверных приложений на Node. js. Его прелесть в том, что он комбинирует концепции ООП, функционального программирования и предлагает. . .
Гексагональная архитектура со Spring Boot
Javaican 17.03.2025
Если вы когда-нибудь сталкивались с ситуацией, когда внесение простых изменений в базу данных или пользовательский интерфейс заставляло вас переписывать весь код, то вы точно оцените элегантность. . .
Позиционировани­е Kafka Consumer и Seek-операции
Javaican 17.03.2025
Что же такое Consumer Seek в Kafka? По сути, это API-метод, который позволяет программно указать, с какой позиции (offset) Consumer должен начать или продолжить чтение данных из партиции. Без этого. . .
Python NumPy: Лучшие практики и примеры
py-thonny 17.03.2025
NumPy (Numerical Python) — одна из ключевых библиотек для научных вычислений в Python. Она превращает Python из просто удобного языка общего назначения в среду для проведения сложных математических. . .
Java Micronaut в Docker: контейнеризация с Maven и Jib
Javaican 16.03.2025
Когда речь заходит о микросервисной архитектуре на Java, фреймворк Micronaut выделяется среди конкурентов. Он создан с учётом особенностей облачных сред и контейнеров, что делает его идеальным. . .
Управление зависимостями в Java: Сравнение Spring, Guice и Dagger 2
Javaican 16.03.2025
Инъекция зависимостей (Dependency Injection, DI) — один из фундаментальных паттернов проектирования, который радикально меняет подход к созданию гибких и тестируемых Java-приложений. Суть этого. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru