Глава 3
Объекты VHDL:Сигнал
Содержание главы 3
3.1. Краткий обзор Главы
3.2. Введение в Сигналы
3.2.1. Понятие Сигнала
3.2.2. Сигналы в Электронных Приборах
3.2.3. Значение Электрических Сигналов
3.3. Основные Типы Сигналов
3.3.1. Отдельный Сигнал против Многократных Сигналов
3.3.2. Типы Сигнала: bit и bit_vector
3.3.3. Ширина Шины и Порядок Битов
3.4. Объявление Сигналов
3.4.1. Внешний против Внутренних Сигналов
3.4.2. Объявление Сигналов Интерфейса
3.4.3. Направление Потока информации: Режим Порта
3.4.4. Декларация Внутренних Сигналов
3.4.5. Видимость Сигналов
Резюме
3.1. Краткий обзор Главы
Перед изложением главного предмета этой главы обратим ваше внимание, что мы собираемся определять, модель и способ проектирования электронных приборов. Одно из определений электронных приборов состоит в том что “ они - системы для преобразования электрических сигналов ”. По этой причине сигналы являются наиболее важными компонентами электронных систем. Без сигналов, переносящих информацию от одной цепи к другой, не выполнялось бы никакое вычисление.
Общая сигналов была представлена в Секции 2. В этой главе мы приведем примеры из каждодневной жизни, которые показывают что сигналы существуют не только в электронных приборах. Позже, однако, мы ограничимся исключительно на электронных сигналах.
Секция 3 вводит два важных классификационных признака сигналов:
Прежде, чем любой сигнал может быть использован в VHDL проекте, в его спецификации, он должен быть объявлен. Четвертая Секция посвящена этому вопросу. Эта глава будет готовить Вас для написания ваших первых VHDL спецификаций просто и доходчиво.
3.2.1. Концепция Сигнала
Ключевые вопросы:
Одно из наиболее важных явлений в мире - процесс связи. Мы разделяем много информации с другими людьми. Связь всегда включает в себя передачу информации от источника до адресата, и хотя имеются много способов делать это, сигналы вот то что общее для всех них
Позвольте нам напоминать обыденное значение слова сигнал. Всякий раз, когда мы говорим, что кто - то послал сигнал к кому – то, то под этим понимается, что информация была передана. Следовательно, мы можем сказать, что сигнал - носитель элемента информации.
Вообще, сигнал - физическое явление, которое может изменяться в пространстве и вовремени, и изменения могут быть определены некоторыми формальными способами. Среди примеров таких явлений - электрические сигналы (мощность и напряжение), механические сигналы, оптические сигналы, и т.д.
Рисунок справа показывает отдельные примеры сигналов в реальной жизни.
Примеры:
Рисунок:
3.2.2. Сигналы в Электронных Приборах
Ключевые вопросы:
Связь не ограничена живыми созданиями. Машины могут также связываться. Например, термочувствительный элемент может сообщать цепи управления, когда температура достигает некоторого уровня так, чтобы эта цепь могла включать кондиционер.
В качестве другого примера, давайте рассмотрим персональный компьютер. Он состоит из центрального процессора и нескольких дополнительных устройств, которые являются необходимыми для связи с ним, а именно : клавиатура, монитор, "мышь ", или принтер. Самостоятельно каждый из этих элементов бесполезен. Однако, когда эти приборы соединены соответствующими кабелями, система может функционировать полностью. Это наблюдение ведет к заключению, что элементы компьютера должны иметь линии транзитного сигнала, чтобы сформировать рабочую систему. Из-за этого, каждый провод, кабель или дорожка печатной платы будет трактоваться как электрический сигнал.
Имеются много способов классифицировать сигналы. Например, они могут быть классифицированы как сигналы, несущие информацию или внутри прибора или между электронными элементами. Это базовая классификация сигнала, принятая в VHDL.
Примеры:
Рисунок:
3.2.3. Значение Электрических СигналовКлючевые вопросы:
Электрические сигналы играют ключевую роль в действии электронных элементов. Фактически, трудно вообразить прибор, который не посылает или получает некоторые сигналы. По этой причине, сигналы - наиболее существенные объекты любого электронного прибора. С тех пор как разработан язык VHDL, чтобы описать действие полных систем, сигналы играют важную роль в описании связи между цепями или блоками.
Сигналы допускают анализ временных зависимостей внутри VHDL системы. Кроме того, в отличие от переменных в классических языках программирования типа Паскаль или C, VHDL сигналы содержат информацию как о прошлых, так и настоящих их значениях. Эта информация называется историей сигнала.
Все эти свойства помещают сигналы среди наиболее важных понятий в VHDL. Это - то, почему мы начинаем наше введение в язык VHDL с описания сигналов.
Физически, электрический сигнал - поток электронов, которые являются подверженными воздействию общим законами физики. Однако, при программировании на VHDL Вы не должны волноваться относительно этих законов, потому что логический синтез и другие инструментальные средства поддержки будут автоматически заботиться о физическом рисунке схемы. Все, что Вы должны делать, это определить функциональные возможности и требуемые характеристики цепи.
Примеры:
Рисунок:
3.3.1. Единичный сигнал против множественного сигнала Ключевые вопросы:
Электронные проекты основаны на компонентах и сигнальных линиях, соединяющих эти компоненты. Сигнальные линии могут быть выполнены или как отдельные или как многопроводные линии связи.
Однопроводная связь представлена сигнальной линией, которая имеет единственное двоичное значение в любой момент. Примером такого сигнала может быть датчик меток времени, которые синхронизируют все блоки внутри системы.
Некоторые проекты включают множественные сигналы, названные шинами или векторами, которые передают информацию как комбинацию некоторых двоичных значений. Когда Вы слышите относительно процессора в 32-разряда то, это означает, что шина передачи данных несет 32 бита двоичных данных в любой момент.
Примеры:
Рисунок:
3.3.2. Типы Сигнала: bit и bit_vectorКлючевые вопросы:
" Единичный сигнал " и "вектор" – описательные имена. Так как формальная спецификация сигналов требуется, для того чтобы позволить нам рассматривать два основных типа сигналов, которые могут использоваться, чтобы определить любой сигнал.
Два типа сигнала, которые допускаются спецификацией VHDL, названы bit (битом) (для единичных сигналов) и bit_vector (бит_вектор)(для шин). В обоих случаях каждая сигнальная линия может быть или '0' или '1'. В случае bit_vector, также необходимо определять ширину.
Примеры:
Рисунок:
3.3.3. Ширина Шины и Порядок Битов
Ключевые вопросы:
В случае единичного провода все просто; Вы можете только говорить " этот сигнал, имеет р тип bit". Префикс bit сообщает что это все. Однако, описание шин – более комплексно. Во-первых, мы должны указать, что это – множественный сигнал, прибавляя слово: _vector, при этом формируется утверждение bit_vector.
Во-вторых, ширина шины и порядок линий или битов должен быть явно задан в списке. Например, это составляет главное различие , является ли разряд номер 7 старшим значащим битом (MSB), а номер 0 - самый младшим битом (LSB) в шине, или наоборот. Эта информация обеспечивается через диапазон вектора, которая всегда указывается в круглой скобках, например (7 downto 0). Диапазон вектора определяется в VHDL путем использования двух ключевых слов: или TO или DOWNTO. Первый служит для определения увеличивающегося диапазона (когда левая граница более низкая чем правая), а другой определяет уменьшающиеся диапазоны (когда левая граница выше чем правая).
Примеры:
Диапазон шины может быть определен четырьмя различными способами. Однако, только два из них правильны (и имеют смысл). Четырех-разрядная шина может быть правильно определена как:
Два неправильных технических данных диапазона шины могли быть написаны как:
Рисунок:
3.4.1. Внешний против Внутренних Сигналов
Ключевые вопросы:
Сигналы могут быть классифицированы как внутренние или как внешние:
Поскольку Вы можете помнить из предыдущей главы, подобное различие которое существует между сущностью и единицами архитектуры проекта. Фактически, внешние сигналы объявлены только в сущности, а внутренние сигналы определены исключительно в архитектуре.
Примеры:
При использовании упрощенной функциональной блок-схемы центрального процессора Вы можете классифицировать сигналы как внутренние или как внешние.
3.4.2. Объявление Сигналов Интерфейса
Ключевые вопросы:
Сигналы, соединяющие систему с окружающей средой названы портами и определены в секции сущности портов, которая определяет интерфейс системы. Каждый сигнал, который соединяет систему с внешним миром, определен как порт внутри сущности.
Каждый сигнал должен иметь уникальное название (например. Clock1 или DataBUS [0 to7]) и тип (например bit или bit_vector). Однако, порт должен иметь кроме того направление потока информации которое называется mode. Этому объясняется на следующей странице.
Заметьте: Вы можете объявлять начальную значение для каждого сигнала порта.
Примеры:
Позвольте нам объявлять порты ЦЕНТРАЛЬНОГО ПРОЦЕССОРА. Этот пример показывает только общую идею и не должны трактоваться как реальная спецификация VHDL.
entity Central_Processing_Unit is
port( Input_CPU : mode bit_vector (31 downto 0);
Output_CPU : mode bit_vector (31 downto 0));
end Central_Processing_Unit;
И более детальный пример памяти ROM:
entity ROM_Memory is
port (A_ROM : mode bit_vector (3 downto 0); -- Address
CS_ROM : mode bit := ' 0' ; -- Chip Select
D_ROM : mode bit_vector (7 downto 0));-- Data
end ROM_Memory;
Рисунок:
3.4.3. Направление Потока информации: MODE Порта
Ключевые вопросы:
В циркулирующем направлении потока информации Мы должны определить, является ли частный сигнал входом, выходом или двунаправленным. Направление сигнала должно быть явно задано. Если это не определено, то по умолчанию объявляется как вход. Для установления направление сигнала в VHDL осуществляется приписывание соответствующей mode к каждому сигналу интерфейса. Следовательно, декларация порта имеет следующий синтаксис:
port_name : mode port_type
Несмотря на то, что VHDL поддерживает пять mode сигнала: IN, OUT, INOUT, BUFFER, и LINKAGE, рекомендуется, чтобы Вы использовали только первые три, т.к. последние два не поддержаны инструментальными средствами синтеза.
Типичные mode сигнала:
Примеры:
Теперь мы способны закончить сущность из предыдущей страницы с присущими mode:
Entity Central_Processing_Unit is
port( Input_CPU : in bit_vector (31 downto 0);
Output_CPU : out bit_vector (31 downto 0));
end Central_Processing_Unit;
entity ROM_Memory is
port (A_ROM : in bit_vector (3 downto 0); -- Address
CS_ROM : in bit; -- Chip Select
D_ROM : out bit_vector (7 downto 0));-- Data
end ROM_Memory;
Данные могут быть или написаны в память RAM или читать из нее. Это обозначено способом inout:
entity RAM_Memory is
port (A_RAM : in bit_vector (3 downto 0); -- Address
CS_RAM : in bit; -- Chip Select
D_RAM : inout bit_vector (7 downto 0));-- Data
end RAM_Memory;
Рисунок:
3.4.4. Декларация Внутренних Сигналов
Ключевые вопросы:
Сущность определяет интерфейс системы с внешним миром, а архитектура описывает все то, что постоянно находится внутри системы. Внутренние сигналы не исключение, и чтобы отличить их от других объектов в VHDL коде, ключевое слово signal должно использоваться в каждой декларации.
Заметьте: ключевое слово signal не нужно около порта, потому что каждый порт - по определению сигнал.
Заметьте: Внутренние сигналы не требуют декларации mode (in, out или inout).
Заметьте: возможно определить начальное значение для внутреннего сигнала.
Примеры:
Для того, чтобы облегчать связь между подсистемами центрального процессора (ROM памятью, RAM памятью, I/O блоками) мы должны определить внутренние сигналы для адреса, данных, и шин управления. Так как они - внутренние сигналы, их декларация расположена внутри архитектуры:
architecture Behavior_CPU OF Central_Processing_Unit is
-- Architecture declarative part
signal Address : bit_vector (31 downto 0);
signal Data : bit_vector (15 downto 0);
signal Control : bit_vector (10 downto 0) := " 00011101101" ;
begin
-- Architecture statements part
end Behavior_CPU;
Рисунок:
3.4.5. Видимость Сигналов
Ключевые вопросы:
"Видимость" каждого сигнала определена местом, в котором он объявлен:
Эти правила следуют непосредственно из иерархических принципов проекта: если что – ни будь объявлено на одном иерархическом уровне, то это будет видимо только в этой части проекта и во всех его более низких уровнях.
Примеры:
Рисунок:
Резюме
Сигналы - первичные объекты аппаратных систем и эквивалентны на "проводам". Они представляют каналы связи среди разных частей системы. Сигналы и связанные VHDL механизмы такие как назначения сигнала, задержек, и т.д. используются для моделирования типичных элементов оборудования типа параллелизма, инерционного распространения сигнала, шины с множественными источниками управления, и т.д. Каждый сигнал имеет историю своих значений и может иметь многократное управление, каждое из которых назначает текущее значение и будущие проектные величины. Все параметры сигнала доступны посредством атрибутов сигнала.