Verilog HDL의 모듈은 다음과 같습니다.
처음에 module을 먼저 선언해주고
이용한 변수의 종류와 이름을 선언해줍니다. C언어와 크게 다를게 없습니다.
그 다음에는 어떤 function을 할지 구성해주고 디자인 해준 후
endmodule로 모듈을 종료하는 방식입니다.
Verilog에서 숫자와 문자열은 다음과 같이 표현을 하고
논리 연산 기호는 다음과 같습니다.
논리값 0은 거짓 상태를 뜻하고 1은 참인 상태를 의미합니다. 그리고 x는 알수 없는
논리 값, z는 하이 임피던스 상태인데 이 것은 쉽게 표현하면 단자에 아무것도 연결
안된 상태라고 보시면됩니다.
넷(Net)은 wire인데 소자간의 물리적인 연결을 추상화 한 것이고 default 초기값은 z
입니다.
다음을 wire로 표현 하면
wire a;
wire b, c;
wire d=1'b0;
과 같이 기술할수 있습니다.
레지스터(Reg)는 데이터 값을 저장할 수 있는 변수를 지정할 때 사용합니다.
배열은 reg 또는 wire 선을 이용하여 선언합니다.
reg [7:0] mema[0:255]; // 8비트 레지스터 256개의 mema 메모리
Parameter는 데이터형에 속하지 않는 상수값을 표현할 때 사용합니다.
주로 회로의 비트 크기 또는 지연값을 지정하기 위해 사용됩니다.
parameter DATA_WIDTH = 8;
parameter RAM_DEPTH = 16;
과 같이 기술하여 사용합니다.
그럼 예제로 half-adder를 구현을 해보기전에
half-adder란 두 개의 비트를 더하여 합(sum)과 올림자(Carry)를 구하는 것 입니다.
0+0 = 0
0+1 = 1
1+0 = 1
이 때 까지 sum값은 그데로 0 또는 1이고 Carry는 올림수 가 없으므로 0이 됩니다.
하지만 1+1=10(이진수) 이 되는데 이 때 Carry값이 1이 되고 sum값은 0이 되는
block도 입니다. 그래서 이것을 논리회로로 표현해보면
다음과 같은 block도를 가집니다.
그럼 이 half-adder를 구현 하는 예제는 다음시간 까지 과제로 하고 오늘 study 를
마치겠습니다.
과제는 Quartus2를 이용하여 직접 구현하여 파형까지 확인 해보도록 합시다!
'꿈을 쫓자 > Soc, Verilog 스터디' 카테고리의 다른 글
디지털 시스템, 그리고 Verilog HDL 기초지식 #1 (0) | 2018.07.03 |
---|