

# 논리회로

논리회로 = 조합회로(combational logic)

+ 순차회로(sequential logic)

&, |, ~, ^, +, -, \*, /, >, >=, <, <=, ==, !=, <<, >> : ALU

# 덧셈기 구현

반가산기 알고리즘



반가산기 회로



$$S = A \text{ xor } B$$

$$C = A \text{ and } B$$

module HA



## module HA 구현 (게이트 수준 구현, 모듈 정의하기)

```
HA.v
module HA(
    input A,
    input B,
    output S,
    output C
);

    assign S = A ^ B;
    assign C = A & B;

endmodule
```

다음 작업을 수행합니다.

1. Comb\_logic 프로젝트에 [Add Sources] 메뉴를 이용하여 HA.v 파일 추가
2. 모듈 이름은 HA, 포트는 A, B, S, C로 구성하며 A, B는 input, S, C는 output으로 설정
3. HA.v 파일을 마우스 오른쪽 버튼을 누른 후, [Set as Top] 모듈로 설정합니다.
4. 합성을 진행합니다.
5. [Layout]--[I/O Planning] 메뉴를 선택합니다. 핀을 다음과 같이 할당합니다.  
A(V16)  
B(V17)  
S(U16)  
C(E19)
6. 전압은 3.3V로 합니다.
7. 구현을 합니다.
8. 비트스트림을 생성한 후, 보드에 다운로드 받아 테스트합니다.

## 전가산기 알고리즘

| $\overline{A}$ | A | B | $C_i$ | S | $C_o$ | $(A \oplus B) \oplus C_i$ |
|----------------|---|---|-------|---|-------|---------------------------|
|                | 0 | 0 | 0     | 0 | 0     |                           |
|                | 0 | 0 | 1     | 1 | 0     | S                         |
|                | 0 | 1 | 0     | 1 | 0     |                           |
|                | 0 | 1 | 1     | 0 | 1     |                           |
|                | 1 | 0 | 0     | 1 | 0     |                           |
|                | 1 | 0 | 1     | 0 | 1     |                           |
|                | 1 | 1 | 0     | 0 | 1     |                           |
|                | 1 | 1 | 1     | 1 | 1     |                           |

전가산기 회로



$$S = (A \text{ xor } B) \text{ xor } Ci$$

$$Co = (A \text{ and } B) \text{ or } (Ci \text{ and } (A \text{ xor } B))$$



## 전가산기 구현

### 모듈 경계 정하기



### 전선 이름 정하기



FA 구현하기(구조적 구현, 모듈 사용하기)

내부 와이어 선언, 와이어 연결

```
FA.v
module FA(
    input A,
    input B,
    input Ci,
    output S,
    output Co
```

```

);
wire w1, w2, w3;

HA ha_1(.A(A), .B(B), .S(w1), .C(w2));
HA ha_2(.A(w1), .B(Ci), .S(S), .C(w3));
assign Co = w2 | w3;

endmodule

```

다음 작업을 수행합니다.

1. Comb\_logic 프로젝트에 [Add Sources] 메뉴를 이용하여 FA.v 파일 추가
2. 모듈 이름은 FA, 포트는 A, B, Ci, S, Co로 구성하며 A, B, Ci는 input, S, Co는 output으로 설정
3. FA.v 파일을 마우스 오른쪽 버튼을 누른 후, [Set as Top] 모듈로 설정합니다.
4. 합성을 진행합니다.
5. [Layout]--[I/O Planning] 메뉴를 선택합니다. 핀을 다음과 같이 할당합니다.  
 A(V16)  
 B(V17)  
 Ci(R12)  
 S(U16)  
 Co(E19)
6. 구현을 합니다.
7. 비트스트림을 생성한 후, 보드에 다운로드 받아 테스트합니다.



## 덧셈기] 4 비트(버스 선언과 사용)

A 4 BIT RIPPLE CARRY ADDER



FA - Full Adders  
 B - Data 2  
 C - Carry

A - Data 1  
 S - Sum



```

ADD_4.v
module ADD_4(
  input [3:0] A,
  input [3:0] B,
  input Ci,
  output [3:0] S,
  output Co
);
  wire [2:0] w;

```

```

FA fa_3(.A(A[3]), .B(B[3]), .Ci(w[2]), .S(S[3]), .Co(Co));
FA fa_2(A[2], B[2], w[1], S[2], w[2]);
FA fa_1(A[1], B[1], w[0], S[1], w[1]);
FA fa_0(A[0], B[0], Ci, S[0], w[0]);

endmodule

```

다음 작업을 수행합니다.

1. Comb\_logic 프로젝트에 [Add Sources] 메뉴를 이용하여 ADD\_4.v 파일 추가
2. 모듈 이름은 ADD\_4, 포트는 A, B, Ci, S, Co로 구성하며 A, B, Ci는 input, S, Co는 output으로 설정, A, B, S은 4비트 버스로 설정



3. ADD\_4.v 파일을 마우스 오른쪽 버튼을 누른 후, [Set as Top] 모듈로 설정합니다.
4. 합성을 진행합니다.
5. 핀을 다음과 같이 할당합니다.  
A3~A0(W17,W16,V16,V17)  
B3~B0(W13,W14,V15,W15)  
Ci(R2)  
S3~S0(V19,U19,E19,U16)  
Co(W18)
6. 구현을 합니다.
7. 비트스트림을 생성한 후, 보드에 다운로드 받아 테스트합니다.





감산기 알고리즘



## 감산기 구현



```
module SUB_4(
    input [3:0] A,
    input [3:0] B,
    output [3:0] R
);
    wire [3:0] tB;
    assign tB = ~B;

    ADD_4 ADD_4_0(.A(A), .B(tB), .S(R), .Ci(1));

endmodule
```

다음 작업을 수행합니다.

- Comb\_logic 프로젝트에 [Add Sources] 메뉴를 이용하여 SUB\_4.v 파일 추가
- 모듈 이름은 SUB\_4, 포트는 A, B, R로 구성하며 A, B는 input, R은 output으로 설정, A, B, R은 4비트 버스로 설정
- SUB\_4.v 파일을 마우스 오른쪽 버튼을 누른 후, [Set as Top] 모듈로 설정합니다.
- 합성을 진행합니다.
- 핀을 다음과 같이 할당합니다.  
A3~A0(W17,W16,V16,V17)  
B3~B0(W13,W14,V15,W15)  
R3~R0(V19,U19,E19,U16)
- 구현을 합니다.
- 비트스트림을 생성한 후, 보드에 다운로드 받아 테스트합니다.



## 비교기 알고리즘

```
if(A==B)  
if(A!=B)  
if(A>B)  
if(A>=B)  
if(A<B)  
if(A<=B)
```

```
if(A==B) <=> A-B == 0  
if(A!=B) <=> A-B != 0  
if(A>B) <=> A-B > 0  
if(A>=B) <=> A-B >= 0  
if(A<B) <=> A-B < 0  
if(A<=B) <=> A-B <= 0
```

A-B == 0 <=> A-B=R==0 <=> R[3]==0이 고 R[2]==0이 고 R[1]==0이 고 R[0]==0  
A-B != 0 <=> A-B=R!=0 <=> R[3]==1거나 R[2]==1거나 R[1]==1거나 R[0]==1  
A-B > 0 <=> A-B=R>0 <=> R[3]==0이 고(R[2]==1거나R[1]==1거나R[0]==1)  
A-B >= 0 <=> A-B=R>=0 <=> R[3]==0  
A-B < 0 <=> A-B=R<0 <=> R[3]==1  
A-B <= 0 <=> A-B=R<=0 <=> R[3]==1거나(R[2]==0이 고 R[1]==0이 고 R[0]==0)

R[3]==0이 고 R[2]==0이 고 R[1]==0이 고 R[0]==0 <=>  
T\_equ = ~R[3] & ~R[2] & ~R[1] & ~R[0] = ~(R[3] | R[2] | R[1] | R[0])

R[3]==1거나 R[2]==1거나 R[1]==1거나 R[0]==1 <=>  
T\_neq = R[3] | R[2] | R[1] | R[0] = ~T\_equ

R[3]==0이 고(R[2]==1거나R[1]==1거나R[0]==1) <=>  
T\_gth = ~R[3] & (R[2] | R[1] | R[0])

R[3]==0 <=>  
T\_gte = ~R[3]

R[3]==1 <=>  
T\_lth = R[3] = ~T\_gte

R[3]==1거나(R[2]==0이 고 R[1]==0이 고 R[0]==0) <=>

$$T_{lte} = R[3] \mid (\sim R[2] \& \sim R[1] \& \sim R[0]) = \sim T_{gth}$$

$R[3]==0$ 이고  $R[2]==0$ 이고  $R[1]==0$ 이고  $R[0]==0$ 이면  $T_{equ} = 1$

비교기 회로



## 비교기와 if문



## 어셈블리 언어의 종류



## 비교기 구현

```
module CMP_4(
    input [3:0] A, input [3:0] B,
    output Tequ, output Tneq, output Tgth,
    output Tlth, output Tgte, output Tlte);

    wire [3:0] tR;
    SUB_4 SUB_4_0(.A(A), .B(B), .R(tR));
    assign Tequ = ~(tR[3]|tR[2]|tR[1]|tR[0]); // Tequ
    assign Tneq = ~Tequ; // Tneq
    assign Tgth = ~tR[3] & (tR[2]|tR[1]|tR[0]);
    assign Tlth = tR[3];
    assign Tgte = ~tR[3];
    assign Tlte = Tlth | Tequ;

endmodule
```

다음 작업을 수행합니다.

1. Comb\_logic 프로젝트에 [Add Sources] 메뉴를 이용하여 CMP\_4.v 파일 추가
2. 모듈 이름은 CMP\_4, 포트는 A, B, Tequ, Tneq, Tgth, Tlth, Tgte, Tlte로 구성하며 A, B는 input, Tequ, Tneq, Tgth, Tlth, Tgte, Tlte은 output으로 설정, A, B는 4비트 버스로

## 설정

3. CMP\_4.v 파일을 마우스 오른쪽 버튼을 누른 후, [Set as Top] 모듈로 설정합니다.

4. 합성을 진행합니다.

5. 핀을 다음과 같이 할당합니다.

A3~A0(W17,W16,V16,V17)

B3~B0(W13,W14,V15,W15)

Tequ,Tneq,Tgth,Tlth,Tgte,Tlte(U15,W18,V19,U19,E19,U16)

6. 구현을 합니다.

7. 비트스트림을 생성한 후, 보드에 다운로드 받아 테스트합니다.



## BASYS 3 핀 번호

