상태 레지스터 또는 플래그 레지스터는 마이크로프로세서에서 다양한 산술 연산 결과의 상태를 알려주는 플래그 비트들이 모인 레지스터이다.

주로, 조건문과 같은 실행 순서의 분기에 사용된다.


상태 레지스터 플래그

상태 레지스터에는 다음과 같은 플래그들이 있다.

플래그 기호이름의미
Z제로 플래그연산 결과가 0일 경우에 참이 된다.
C캐리 플래그부호 없는 숫자의 연산 결과가 비트 범위를 넘어섰을 때 참이 된다.
A보조 캐리 플래그연산 결과 하위 니블(4bits)에서 비트 범위를 넘어섰을 때 참이 된다. 이진화 십진법(BCD) 연산에 사용된다.
V / O / W오버플로 플래그부호 있는 숫자의 연산 결과가 비트 범위를 넘어섰을 때 참이 된다.
N / S네거티브 플래그, 사인 플래그연산 결과가 음수일 때 참이 된다.
I / E인터럽트 플래그이 플래그가 참일 경우에만 인터럽트 요구를 받아들인다. 일반적으로 관리자 모드에서만 값을 변경 할 수 있다.
P패리티 플래그연산 결과에서 1로된 비트의 수가 짝수일 경우 참이 된다.
D디렉션 플래그문자열 조작에서 참일 경우 주소 레지스터 값이 자동으로 감소하고, 거짓일 경우 자동으로 증가한다.
D / T디버그 플래그, 트랩 플래그참일 경우 한 명령이 실행할 때마다 인터럽트가 발생한다. 디버깅에 사용된다.



https://ko.wikipedia.org/wiki/%EC%83%81%ED%83%9C_%EB%A0%88%EC%A7%80%EC%8A%A4%ED%84%B0

반응형

+ Recent posts