[1] CH1 컴퓨터 추상화 및 관련 기술 < 하드웨어 관점 >
Computer Architecture/컴퓨터 구조2022. 1. 11. 18:39[1] CH1 컴퓨터 추상화 및 관련 기술 < 하드웨어 관점 >

" 케이스를 열고 " 이제까지 프로그램 밑에서 동작하는 소프트웨어를 살펴보았으니 컴퓨터 케이스를 열고 그 아래에 있는 하드웨어에 대해 살펴봅시다. 모든 컴퓨터의 하드웨어는 데이터 입력, 데이터 출력, 데이터 처리, 데이터 저장의 네 가지 기본 기능을 수행합니다. 컴퓨터의 주요 구성 요소 중에는 마이크 같이 입력장치(input device)와 스피커 강튼 출력장치(output device)가 있다. 입력장치는 컴퓨터에 데이터를 공급하고, 출력장치는 사용자에게 계산 결과를 보여 주는 역할을 한다. ★ 컴퓨터의 고전적 구성 요소 다섯 가지는 입력, 출력, 메모리, 데이터패스(datapath), 제어유닛이다. 이 중 뒤의 2개를 합쳐서 프로세서라고 부르기도 한다. 밑의 그림은 컴퓨터의 표준 구성을 보여 주는 그..

[0] 컴퓨터 추상화 및 관련 기술 < 컴퓨터구조를 왜 배워야하는 것인가 >
Computer Architecture/컴퓨터 구조2022. 1. 11. 15:52[0] 컴퓨터 추상화 및 관련 기술 < 컴퓨터구조를 왜 배워야하는 것인가 >

컴퓨터 구조 - 컴퓨터 과학에서 컴퓨터 시스템의 기능, 조직, 구현에 대한 법칙과 방법을 통칭한다. - 또 다른 정의로는 명령어 집합 구조(ISA), 마이크로아키텍쳐 설계, 논리 설계 및 구현을 의미한다. 컴퓨터 구조를 통해 다음에 관한 문제에 답할 수 있는 능력을 갖추게 됩니다. 1.C나 Java같은 상위 수준 언어로 작성된 프로그램이 어떻게 하드웨어 언어로 번역되며, 하드웨어는 번역된 프로그램을 어떻게 실행 하는가? - 이 개념들을 잘 파악하면 프로그램 성능에 영향을 미치는 하드웨어와 소프트웨어 양쪽의 특성을 이해할 수 있다. 2.소프트웨어와 하드웨어 사이의 인터페이스는 무엇이며, 소프트웨어는 어떻게 필요한 일을 하드웨어에게 지시하는가? - 이 개념은 여러 종류의 소프트웨어 작성 방법을 이해 하는데 ..

[17] CH9 레지스터
Computer Architecture/논리회로2022. 1. 9. 20:41[17] CH9 레지스터

- Clock의 rising edge마다 오른쪽으로 하나씩 시프트 - Serial out과 Parallel out의 차이는 출력이 무엇인지만 차이가 있다. - MUX는 게이트 조합 등으로 만들 수 있으며 기호로 쉽게 오른쪽과 같이 표시한다. - load=1일때 d0->q1, d1->q1, d2->q2, d3->q3로 로드 - load=0 일때 d0->q0. q0->q1, q1->q2, q2->q3로 시프트 d0=1, d1=0, d2=0, d3=1 일때의 파형 < Bidirectional ..

[16] CH8 순차논리회로 < FSM+Counter 응용 설계 >
Computer Architecture/논리회로2022. 1. 9. 19:30[16] CH8 순차논리회로 < FSM+Counter 응용 설계 >

- Synchronizer : 신호를 클럭에 동기시키며 Metastability방지를 위함. - Debouncer : 기계적 진동때문에 1이나 0으로 안정된 값을 바로 갖지 못하므로 이러한 채터(chatter)또는 바운스(bounce)를 제거한다. - Level to pulse converter : 여러 클럭 사이클 동안 1또는0이 입력되므로 신호를 한 클럭 동안에만 1이나 0이 되는것이 필요한 경우에 사용한다. - 버튼을 누르는 동작은 사람의 개념으로는 잠깐이지만 매우 오랫동안 1이 유지되기 때문에 이를 펄스 신호로 바꾸어 처리하면 편리한 경우가 있다. - idel 상태 : 1을 받아들일 수 있는 ..

[15] CH8 순차논리회로 < 카운터 FSM 설계-3 >
Computer Architecture/논리회로2022. 1. 9. 15:27[15] CH8 순차논리회로 < 카운터 FSM 설계-3 >

- 주파수를 나누는 블록 - 예를들어, 100MHz/2 = 50MHz로 클럭이 느려짐 - 반대로 주기는 늘어남 1/100MHz =10ns, 1/50MHz =20ㅜㄴ - 디지털 회로로 쉽게 만들 수 있음 - 매 클럭 에지마다 값을 바꾸기 때문에 입력 클럭을 2분주한 클럭을 발생 - 00>01>10>11로 변하는 카운터가 11이 되었을 때만 last=1 - last =1일 경우에만 clkout이 반전된다. - 000>001> -- > 100>000로 변하는 카운터 - 100이 되었을 때만 last=1이고 다음 클럭에서 clkout반전됨 - 2비트 오른쪽 shift regist..

[14] CH8 순차논리회로 < 카운터 FSM 설계-2 >
Computer Architecture/논리회로2022. 1. 9. 15:02[14] CH8 순차논리회로 < 카운터 FSM 설계-2 >

- 입력 up=1일때 00 > 01 >10 >11 > 00 - 입력 up=0일때 11 > 10 > 01 > 00 > 11 - 카운터가 11이고 up=1이거나, 카운터가 00이고 up =0일때 last =1 - en =1일 경우에만 카운트하는 2비트 그레이 카운터 - TV의 채널이 4개있다고 가정하자(0,1,2,3) - 채널 UP버튼을 누를때마다 증가 , down누를때마다 감소 - UP과 DN을 누르지 않거나 동시에 누르면 채널은 변하지 않는다. HDL를 사용한 디지털 설계에서는 실제로 JK F/F또는 T F/F를 사용하지 않고 D F/F를 사용..

[13] CH8 순차논리회로 < 카운터 FSM 설계 >
Computer Architecture/논리회로2022. 1. 9. 14:28[13] CH8 순차논리회로 < 카운터 FSM 설계 >

1. 상태 다이어그램(state diagram)을 그린다. 2. 상태표(state table)을 작성한다. 3. 다음상태와 출력신호를 카르노맵으로 축약한다. 4. 회로도(schematic)를 작성한다. 5. 타이밍 다이어그램으로 동작을 확인한다. - 00 > 01 > 10 > 11 > 00 > 01과 같이 값을 세는 카운터의 설계 1. State diagram의 작성 - 0부터 9까지 그리고 다시 0부터 카운트 9일때는 last=1이 되는 카운터

[12] CH8 순차논리회로 < 비동기-동기 카운터, FSM >
Computer Architecture/논리회로2022. 1. 9. 14:09[12] CH8 순차논리회로 < 비동기-동기 카운터, FSM >

Synchronous(동기) 회로 - 모든 F/F이 동시에 동작. 즉, clock의 rising edge에 동시 동작한다. - 모든 F/F의 clk단자에 같은 clock 신호가 입력된다. - 설계가 쉽다. Asynchronous(비동기) 회로 - 모든 F/F이 동시에 동작하지 않는다. - 모든 F/F의 clk단자에 같은 clock신호가 입력되지 않는다. - 설계가 어렵다. - 경우에 따라서는 속도 향상 효과가 있다. - 비동기 회로의 문제점 중 하나인 지연시간이 포함된다. - 원인 : 카운터의 모든 플립플롭이 동시에 변하지 않는다. - 단점 : 변하는 중간에 다른..

[11] CH8 순차논리회로 < 플립플롭(Filp-Flops) >
Computer Architecture/논리회로2022. 1. 8. 12:38[11] CH8 순차논리회로 < 플립플롭(Filp-Flops) >

- Clock신호는 주기적인 square wave - Clock 신호는 의미있는 정보를 보낸다기 보다는 타이밍을 맞추기 위해 사용 - Clock에 맞추어 Latch 또는 플립플롭들이 동시에 정보를 저장한다. - 플립플롭은 Clock신호가 변화하는 시점인 edge(엣지)에 맞추어 동작한다. (Edge - sensitive) - Latch는 엣지가 아니라 Clock 신호 값의 수준(EN)에 맞추어 동작한다.(Level - sensitive) - Rising edge에 맞추어 동작하는 플립플롭을 rising edge triggered F/F이라고 한다. - Falling edge에 맞추어 동작하는 플립플롭을 falling edge triggered F/F이라고 한다..

[10] CH8 순차논리회로 < 래치(Latch) >
Computer Architecture/논리회로2022. 1. 6. 21:46[10] CH8 순차논리회로 < 래치(Latch) >

조합 회로(Combinational Logic) - 값을 저장하지 못함 - 클럭을 사용하지 않음 - 입력의 변화가 출력에 바로 반영됨 - 예) 가산기,(디)멀티플렉서,디코더,인코더 etc 순차회로(Sequential Logic) - 값을 저장하는 래치,플립플롭,레지스터(플립플롭의 모임),메모리 등의 소자가 있어 현재상태를 저장 - 클럭을 사용하여 값을 저장 - 입력이 변화해도 주로 클럭의 에지에서 값이 저장된다. - 예) 카운터,레지스터,클럭 분배기,FSM etc - Set : S신호가 0일 때 Q값은 1 - Reset : R신호가 0일 때 Q값은 0 - S,R신호는 0일때 활성화되는 active low신호입니다. < SR La..

image