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

Дешифровка Слова Длиной 256 Бит В Буквы По 8 Бит И Передача Букв На Логику Схемы


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

Привет всем, я к вам за помощью. Собственно я студент.

Передо мной (в рамках моего курсача по шифрованию) стоит задача: слово длиной 256 бит разбить на буквы и последовательно отправить буквы на обработку логики схемы (на шифрование).

Как я представляю это в голове?

1 - Получить слово по шине и записать его в ЗУ (естественно придётся использовать не одно ЗУ)

2 - Как-то считать первые 4 бит - 4 бита это кодированная буква - отправить её через шину в 4 провода на обработку далее

3 - Получить сигнал разрешения считывания следующей буквы, считать её и отправить снова в схему

Собственно вопрос: Как я могу организовать последовательное считывание букв из слова в шину, при условии что у меня слово будет размазано по ЗУ?

Планируется разместить сколько-то букв слова в одном ЗУ (на вскидку 256/4 - 64 буквы в слове, значит надо взять четыре 4х разрядных ЗУ - 16 букв в одном ЗУ, 16х4 = 64).

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

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

Это ты на МК хочешь делать?

Возьми восем 32-разрядных регистра, запиши в них свои 256 бит. Затем сделай цикл по регистрам и внутри цикл по каждым 4 битам. И так ты последовательно их все переберёшь.

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

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

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

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

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

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

Это ты на МК хочешь делать?

Возьми восем 32-разрядных регистра, запиши в них свои 256 бит. Затем сделай цикл по регистрам и внутри цикл по каждым 4 битам. И так ты последовательно их все переберёшь.

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

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

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

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

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

Ну тогда счётчик и сдвиговый регистр тебе помогут.

А если просто счётчиком (просто я не очень понимаю работу сдвигового регистра)?

сделать шести разрядный счётчик, его выходы подвести к своим 4ём четырёхразрядным ОЗУ, первые два бита использовать для выбора нужного ОЗУ (конъюнкцию и дизъюнкцию использовать как обнуление выходного сигнала с памяти), остальные 4 бита для извлечения информации из ОЗУ. соответственно не забыть в этом счётчике предусмотреть запрет работы (хотя по идее с этим и тактовая частота справится на все сто).

А в качестве ОЗУ взять кр155ру2. Как такая идея?

http://www.microshemca.ru/RU2/

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

Да, короче сделал развязку с счётчиком и взял ещё дешифратор + немного логических элементов.

Суть какая:

4 ОЗУ хранят у меня 64 буквы по 4 бита каждая.

Я делаю счётчик на 6 разрядов, в этом счётчике, первые два разряда использую для определения номера ОЗУ, оставшиеся 4 разряда для определения ячейки памяти в выбранном ОЗУ. То есть "010010" - означает открыть в "01" ОЗУ адрес "0010".

Как я обнуляю левые сигналы понятно - использую логическое И, сигнала с ОЗУ "01" и сигнала выбора. Сигнал выбора реализует дешифратор, на него подаётся как раз вот эти "01", он их дешифрует в один из своих выходов и на этом выходе выдаёт единицу, которая потом как раз и идёт в логическое И.

Как я вывожу сигнал с одной из четырёх шин ОЗУ? Использую логическое ИЛИ всех шин. Везде кроме одной из шин стоят нули, в той которая нужна, стоят данные, их мы и берём).

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

В заголовке было

Буквы По 8 Бит

Куда делись ещё четыре?

Никогда не спорьте с дураком - люди могут не заметить между вами разницы

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

Выложите полное название задания и наработанную схему.

На теперешний момент насколько я понял всё сводится к разбиению 256 разрядов на куски по 8 бит. С этой задачей легко и просто справятся 8 мультиплексоров 32х1. Да, таких в природе не существует, нужно будет собрать из нескольких существующих. Перебирая один за другим с помощью дешифратора, будем выдавать на выходящую шину байты букв. Тактировать от генератора. Первым импульсом можно записать входное слово в регистры, с ОЗУ морока.

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

Я не раздаю удочки. Я продаю рыбу.

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

В заголовке было

Куда делись ещё четыре?

Пока решил сделать 4, потом подниму до 8ми - главное сейчас понять как вообще делать.

Выложите полное название задания и наработанную схему.

На теперешний момент насколько я понял всё сводится к разбиению 256 разрядов на куски по 8 бит. С этой задачей легко и просто справятся 8 мультиплексоров 32х1. Да, таких в природе не существует, нужно будет собрать из нескольких существующих. Перебирая один за другим с помощью дешифратора, будем выдавать на выходящую шину байты букв. Тактировать от генератора. Первым импульсом можно записать входное слово в регистры, с ОЗУ морока.

Да, разбиение 256 битов записанных в памяти на куски по 4 бита (по 8 бит, это потом, сейчас для простоты разбил по 4ём битам).

Я сделал таким образом: post-191182-0-45452200-1432120678_thumb.jpg.

Оно вроде будет справляться с поставленной задачей.

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

Половина микросхем - лишние. Выходы ОЗУ соединяются напрямую между собой.

Никогда не спорьте с дураком - люди могут не заметить между вами разницы

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

Половина микросхем - лишние. Выходы ОЗУ соединяются напрямую между собой.

Выходы специально для наглядности разбил - мне кажется, так проще будет понять тем, кто когда-нибудь сюда заглянет из студентов)

А по минимизации микросхемы можно чуть подробнее рассказать: что по вашему мнению лишнее и почему?

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

Я же написал, одноимённые выходы ОЗУ нужно просто соединить между собой. Всё, что нарисовано правее - лишнее.

Вы вообще представляете, как наращивается память?

Никогда не спорьте с дураком - люди могут не заметить между вами разницы

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

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

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

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

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

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

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

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

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

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

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