VLSI 설계-VHDL 소개
VHDL은 초고속 집적 회로 하드웨어 설명 언어를 나타냅니다. 데이터 흐름, 동작 및 구조적 모델링 스타일로 디지털 시스템을 모델링하는 데 사용되는 프로그래밍 언어입니다. 이 언어는 VHSIC 프로그램에 따라 국방부 (DoD)를 위해 1981 년에 처음 도입되었습니다.
디자인 설명
VHDL에서 엔티티는 하드웨어 모듈을 설명하는 데 사용됩니다. 엔티티는 다음을 사용하여 설명 할 수 있습니다.
- 엔티티 선언
- Architecture
- Configuration
- 패키지 선언
- 패키지 본체
이것들이 무엇인지 보자?
엔티티 선언
하드웨어 모듈의 이름, 입력 출력 신호 및 모드를 정의합니다.
Syntax −
entity entity_name is
Port declaration;
end entity_name;
엔티티 선언은 'entity'로 시작하고 'end'키워드로 끝나야합니다. 방향은 입력, 출력 또는 입력입니다.
에 | 포트를 읽을 수 있습니다. |
밖 | 포트 작성 가능 |
인아웃 | 포트 읽기 및 쓰기 가능 |
완충기 | 포트는 읽고 쓸 수 있으며 소스는 하나만 가질 수 있습니다. |
Architecture −
구조, 데이터 흐름, 동작 또는 혼합 스타일을 사용하여 아키텍처를 설명 할 수 있습니다.
Syntax −
architecture architecture_name of entity_name
architecture_declarative_part;
begin
Statements;
end architecture_name;
여기에서 아키텍처 본문을 작성할 엔티티 이름을 지정해야합니다. 아키텍처 명령문은 'begin'및 'énd'키워드 안에 있어야합니다. 아키텍처 선언 부분에는 변수, 상수 또는 구성 요소 선언이 포함될 수 있습니다.
데이터 흐름 모델링
이 모델링 스타일에서 엔티티를 통한 데이터 흐름은 동시 (병렬) 신호를 사용하여 표현됩니다. VHDL의 동시 문은 WHEN 및 GENERATE입니다.
그 외에도 연산자 (AND, NOT, +, *, sll 등) 만 사용하는 할당을 사용하여 코드를 구성 할 수도 있습니다.
마지막으로, BLOCK이라고하는 특수한 종류의 할당도 이러한 종류의 코드에 사용할 수 있습니다.
동시 코드에서 다음을 사용할 수 있습니다.
- Operators
- WHEN 문 (WHEN / ELSE 또는 WITH / SELECT / WHEN);
- GENERATE 문;
- BLOCK 문
행동 모델링
이 모델링 스타일에서 문 집합으로서의 엔티티 동작은 지정된 순서대로 순차적으로 실행됩니다. PROCESS, FUNCTION 또는 PROCEDURE 내에 배치 된 문만 순차적입니다.
PROCESSES, FUNCTIONS 및 PROCEDURES는 순차적으로 실행되는 유일한 코드 섹션입니다.
그러나 전체적으로 이러한 블록은 여전히 외부에있는 다른 명령문과 동시에 발생합니다.
동작 코드의 한 가지 중요한 측면은 순차 논리에 국한되지 않는다는 것입니다. 실제로, 우리는 조합 회로뿐만 아니라 순차 회로를 구축 할 수 있습니다.
동작 명령문은 IF, WAIT, CASE 및 LOOP입니다. VARIABLES도 제한되며 순차 코드에서만 사용되어야합니다. VARIABLE은 전역이 될 수 없으므로 해당 값을 직접 전달할 수 없습니다.
구조 모델링
이 모델링에서 엔티티는 상호 연결된 구성 요소의 집합으로 설명됩니다. 구성 요소 인스턴스화 문은 동시 문입니다. 따라서 이러한 명령문의 순서는 중요하지 않습니다. 모델링의 구조적 스타일은 구성 요소 자체 또는 이들이 집합 적으로 나타내는 엔티티의 동작을 암시하지 않고 구성 요소의 상호 연결 (블랙 박스로 표시) 만 설명합니다.
구조적 모델링에서 아키텍처 본문은 선언 부분 (키워드 시작 전)과 명령문 부분 (키워드 시작 후)의 두 부분으로 구성됩니다.
논리 작동 – AND GATE
엑스 | 와이 | 지 |
---|---|---|
0 | 0 | 0 |
0 | 1 | 0 |
1 | 0 | 0 |
1 | 1 | 1 |
VHDL Code:
Library ieee;
use ieee.std_logic_1164.all;
entity and1 is
port(x,y:in bit ; z:out bit);
end and1;
architecture virat of and1 is
begin
z<=x and y;
end virat;
파형
논리 작동 – OR 게이트
엑스 | 와이 | 지 |
---|---|---|
0 | 0 | 0 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 1 |
VHDL Code:
Library ieee;
use ieee.std_logic_1164.all;
entity or1 is
port(x,y:in bit ; z:out bit);
end or1;
architecture virat of or1 is
begin
z<=x or y;
end virat;
파형
논리 작동 – 게이트 아님
엑스 | 와이 |
---|---|
0 | 1 |
1 | 0 |
VHDL Code:
Library ieee;
use ieee.std_logic_1164.all;
entity not1 is
port(x:in bit ; y:out bit);
end not1;
architecture virat of not1 is
begin
y<=not x;
end virat;
파형
논리 동작 – NAND 게이트
엑스 | 와이 | 지 |
---|---|---|
0 | 0 | 1 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 0 |
VHDL Code:
Library ieee;
use ieee.std_logic_1164.all;
entity nand1 is
port(a,b:in bit ; c:out bit);
end nand1;
architecture virat of nand1 is
begin
c<=a nand b;
end virat;
파형
논리 동작 – NOR 게이트
엑스 | 와이 | 지 |
---|---|---|
0 | 0 | 1 |
0 | 1 | 0 |
1 | 0 | 0 |
1 | 1 | 0 |
VHDL Code:
Library ieee;
use ieee.std_logic_1164.all;
entity nor1 is
port(a,b:in bit ; c:out bit);
end nor1;
architecture virat of nor1 is
begin
c<=a nor b;
end virat;
파형
논리 동작 – XOR 게이트
엑스 | 와이 | 지 |
---|---|---|
0 | 0 | 1 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 0 |
VHDL Code:
Library ieee;
use ieee.std_logic_1164.all;
entity xor1 is
port(a,b:in bit ; c:out bit);
end xor1;
architecture virat of xor1 is
begin
c<=a xor b;
end virat;
파형
논리 동작 – X-NOR 게이트
엑스 | 와이 | 지 |
---|---|---|
0 | 0 | 1 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 0 |
VHDL Code:
Library ieee;
use ieee.std_logic_1164.all;
entity xnor1 is
port(a,b:in bit ; c:out bit);
end xnor1;
architecture virat of xnor1 is
begin
c<=not(a xor b);
end virat;