명령 주기: 두 판 사이의 차이

위키백과, 우리 모두의 백과사전.
내용 삭제됨 내용 추가됨
편집 요약 없음
편집 요약 없음
4번째 줄: 4번째 줄:
기계어 명령어 하나를 실행하기 위해 최대 4개의 단계가 필요하며, 각 단계는 CPU의 [[클럭 신호]]에 동기되어 동작한다. 각 단계는 각각 몇개의 클럭 펄스가 필요하며, 각 마이크로프로세서마다 다르다. 하나의 명령어를 실행하기 위해 단계적으로 나뉜 과정이 한 사이클이 된다. 각 단계는 [[마이크로코드]]의 프로그램과 제어회로인 마이크로시퀀서(microsequencer)에 의해 실행된다. [[RISC]]는 각 단계가 단순화 되어 있지만, 블럭 전송 명령어(메모리 블럭 전송)이 존재하는 CPU가 있으므로 마지막 사이클에서 다량의 데이터 전송이 되는 경우도 있다.<ref name="ARM InstuctionSet">{{웹 인용|언어=en|url=http://infocenter.arm.com/help/topic/com.arm.doc.qrc0001m/QRC0001_UAL.pdf|제목=ARM and Thumb-2 Instruction Set Quick Reference Card|확인날짜=2015-06-20}}</ref> 이런 경우 많은 클럭이 필요하다. [[CISC]]에는 없는 기능이다.
기계어 명령어 하나를 실행하기 위해 최대 4개의 단계가 필요하며, 각 단계는 CPU의 [[클럭 신호]]에 동기되어 동작한다. 각 단계는 각각 몇개의 클럭 펄스가 필요하며, 각 마이크로프로세서마다 다르다. 하나의 명령어를 실행하기 위해 단계적으로 나뉜 과정이 한 사이클이 된다. 각 단계는 [[마이크로코드]]의 프로그램과 제어회로인 마이크로시퀀서(microsequencer)에 의해 실행된다. [[RISC]]는 각 단계가 단순화 되어 있지만, 블럭 전송 명령어(메모리 블럭 전송)이 존재하는 CPU가 있으므로 마지막 사이클에서 다량의 데이터 전송이 되는 경우도 있다.<ref name="ARM InstuctionSet">{{웹 인용|언어=en|url=http://infocenter.arm.com/help/topic/com.arm.doc.qrc0001m/QRC0001_UAL.pdf|제목=ARM and Thumb-2 Instruction Set Quick Reference Card|확인날짜=2015-06-20}}</ref> 이런 경우 많은 클럭이 필요하다. [[CISC]]에는 없는 기능이다.


초기의 마이크로프로세서(4004,8080,Z80, 6800,...)는 한개의 기계어 명령어의 명령 주기가 완료될 때까지 다음 명령을 읽지 않았다. 그러나 발전과정에서 속도를 높이기 위해 한개의 명령어가 완료되기 전에 다음 명령어를 읽는 프리페치(pre-fetch)을 하고 연속적으로 요구동작을 하도록 동작한다. 보통 메모리의 기계어 코드가 끝나면 다음 번지의 메모리 기계어 명령어가 실행되므로 PC레지스터(Program Counter,또는 IP 레지스터라고도 함)를 사용하여 다음 명령어를 미리 읽는다. 그러나 조건 점프명령(인텔 x86의 JEQ, ARM의 BEQ 명령어)은 다음 주소로 점프하지 않을 수도 있으므로 다시 페치해야 한다. 인텔의 80486, ARM 등의 CPU에서 프리페치를 사용한다.
초기의 마이크로프로세서(4004, 8080, Z80, 6800, ...)는 한개의 기계어 명령어의 명령 주기가 완료될 때까지 다음 명령을 읽지 않았다. 그러나 발전과정에서 속도를 높이기 위해 한개의 명령어가 완료되기 전에 다음 명령어를 읽는 프리페치(pre-fetch)을 하고 연속적으로 요구동작을 하도록 동작한다. 보통 메모리의 기계어 코드가 끝나면 다음 번지의 메모리 기계어 명령어가 실행되므로 PC레지스터(Program Counter,또는 IP 레지스터라고도 함)를 사용하여 다음 명령어를 미리 읽는다. 그러나 조건 점프명령(인텔 x86의 JEQ, ARM의 BEQ 명령어)은 다음 주소로 점프하지 않을 수도 있으므로 다시 페치해야 한다. 인텔의 80486, ARM 등의 CPU에서 프리페치를 사용한다.


== 사용되는 회로 ==
== 사용되는 회로 ==

2021년 7월 28일 (수) 07:32 판

명령 실행 주기 도표

명령 주기(命令週期, 영어: instruction cycle, machine cycle)는 마이크로프로세서(CPU)가 메모리로부터 프로그램 된 한개의 기계어 명령어를 가져와 어떠한 동작을 요구하는지를 결정하고 명령어가 요구하는 동작들을 수행하는 과정이다. 컴퓨터의 기본적인 동작 순환이다. 한개의 기계어 명령어가 완료되면 다음 메모리의 기계어가 수행되므로 중앙 처리 장치(CPU)는 시동에서부터 컴퓨터가 꺼질 때까지 이러한 순환을 계속 되풀이한다. 따라서 이를 CPU 사이클이라고도 부른다. CPU의 동작을 하는 한 명령 주기는 계속 반복되어 전력을 소비한다. 전력소모를 줄이거나 기타 CPU를 멈출 필요가 있다면, 아이들모드(idle mode) 또는 슬립모드(sleep mode) 기계어 명령을 실행하면 CPU는 인터럽트가 들어올 때까지 멈추어 명령 주기를 멈추게 할 수 있다.

기계어 명령어 하나를 실행하기 위해 최대 4개의 단계가 필요하며, 각 단계는 CPU의 클럭 신호에 동기되어 동작한다. 각 단계는 각각 몇개의 클럭 펄스가 필요하며, 각 마이크로프로세서마다 다르다. 하나의 명령어를 실행하기 위해 단계적으로 나뉜 과정이 한 사이클이 된다. 각 단계는 마이크로코드의 프로그램과 제어회로인 마이크로시퀀서(microsequencer)에 의해 실행된다. RISC는 각 단계가 단순화 되어 있지만, 블럭 전송 명령어(메모리 블럭 전송)이 존재하는 CPU가 있으므로 마지막 사이클에서 다량의 데이터 전송이 되는 경우도 있다.[1] 이런 경우 많은 클럭이 필요하다. CISC에는 없는 기능이다.

초기의 마이크로프로세서(4004, 8080, Z80, 6800, ...)는 한개의 기계어 명령어의 명령 주기가 완료될 때까지 다음 명령을 읽지 않았다. 그러나 발전과정에서 속도를 높이기 위해 한개의 명령어가 완료되기 전에 다음 명령어를 읽는 프리페치(pre-fetch)을 하고 연속적으로 요구동작을 하도록 동작한다. 보통 메모리의 기계어 코드가 끝나면 다음 번지의 메모리 기계어 명령어가 실행되므로 PC레지스터(Program Counter,또는 IP 레지스터라고도 함)를 사용하여 다음 명령어를 미리 읽는다. 그러나 조건 점프명령(인텔 x86의 JEQ, ARM의 BEQ 명령어)은 다음 주소로 점프하지 않을 수도 있으므로 다시 페치해야 한다. 인텔의 80486, ARM 등의 CPU에서 프리페치를 사용한다.

사용되는 회로

명령이 순환하는 동안 CPU에 사용되는 회로는 다음과 같다:

  • 프로그램 계수기 (PC) - 다음에 실행할 명령어에 대한 메모리 주소를 추적하는 증분 계수기이다.
  • 기억 장치 주소 레지스터 (MAR) - 다음에 실행할 명령어의 메모리에 있는 주소를 보관한다.
  • 기억 장치 데이터 레지스터 (MDR) - 메모리로부터 페치(fetch)되어 cpu가 처리할 준비가 된 데이터나 메모리에 저장되어 대기 중인 데이터를 보관하는 양방향 레지스터이다.
  • 현재 명령어 레지스터 (CIR) - 메모리로부터 페치(fetch)되는 명령어를 일시적으로 보관하는 영역이다.
  • 제어 장치 (CU) - 데이터 소스 레지스터와 특별한 산술 명령과 같은 기계 자원을 선택하여 CIR의 프로그램 명령을 디코딩하고 이러한 자원의 활성화를 도와 준다.
  • 산술 논리 장치 (ALU) - 수치 및 논리 연산을 수행한다.

명령 주기

명령 주기는 명령어에 따라 특성이 다르므로 4개의 명령어 주기를 다 필요하지 않는 경우도 있다. 초기의 CISC 마이크로프로세서는 다음의 명령주기가 확연히 구분된다. RISC로 발달하면서 명령어의 단순화하면서 각 사이클을 단순화 하는 경향이 있다.

각 컴퓨터의 CPU는 서로 다른 명령어 집합에 기반하여 각기 다른 사이클을 지니고 있으나 다음과 비슷한 순환을 가진다 (이 주기는 계속 반복된다):

  1. 명령어 페치
    첫 번째 단계인 명령어 페치 단계를 페치 사이클(fetch cycle)로 부른다. 이 단계는 각 명령에 동일한 작업을 수행한다. 페치 사이클은 opcode를 포함하는 명령어(instruction word)로부터 명령(instruction)을 처리한다.
  2. 명령어 디코딩
    두 번째 단계는 디코딩으로 부른다. 메모리로부터 페치된 opcode는 다음 단계를 위해 디코딩되며 적절한 레지스터로 이동된다.
  3. 유효한 주소 읽기
    세 번째 단계인 유효한 주소 읽기는 어떠한 명령인지를 결정하는 단계이다. 이것이 메모리 명령이라면 이 컴퓨터 단계에서 직접 메모리 명령인지 간접 메모리 명령인지를 확인한다:
    • 직접 메모리 명령 - 아무것도 처리하지 않는다.
    • 간접 메모리 명령 - 유효 주소를 메모리로부터 읽어들인다.
    이것이 입출력 명령이나 레지스터 명령이라면 컴퓨터는 이에 대한 종류를 확인하고 명령을 실행한다.
  4. 명령 실행
    네 번째 단계는 실행 사이클이다. 이 단계는 각 명령에 따라 변동된다.
    실행 사이클의 첫 번째 단계는 프로세스-메모리(Process-Memory)이다. 데이터는 CPU와 입출력 모듈 사이를 오고간다.
    그 다음 단계는 데이터-프로세싱(Data-Processing)이며 데이터 참조에서 논리 명령뿐 아니라 수치 명령도 이용한다. 그 다음 단계는 중심 변경(Central alteration)으로, 점프(jump) 명령과 같은 명령의 연속이다. 마지막 단계는 다른 모든 단계에서 나온 모든 명령을 아우른다.

같이 보기

각주

  1. “ARM and Thumb-2 Instruction Set Quick Reference Card” (PDF) (영어). 2015년 6월 20일에 확인함. 

참조