임베디드 시스템-레지스터
레지스터는 처리 할 데이터 또는 가져올 데이터를 가리키는 주소 일 수있는 정보를 일시적으로 저장하기 위해 CPU에서 사용됩니다. 8051에는 MSB (최상위 비트) D7에서 LSB (최하위 비트) D0까지 8 비트 데이터 유형이 하나 있습니다. 8 비트 데이터 유형의 경우 8 비트보다 큰 데이터 유형은 처리되기 전에 8 비트 청크로 분할되어야합니다.
8051의 가장 널리 사용되는 레지스터는 A (누산기), B, R0-R7, DPTR (데이터 포인터) 및 PC (프로그램 카운터)입니다. DPTR 및 PC를 제외한 모든 레지스터는 8 비트입니다.
8051의 저장 레지스터
여기서는 다음 유형의 저장 레지스터에 대해 설명합니다.
- Accumulator
- R 레지스터
- B 레지스터
- 데이터 포인터 (DPTR)
- 프로그램 카운터 (PC)
- 스택 포인터 (SP)
어큐뮬레이터
누산기 레지스터 A는 모든 산술 및 논리 연산에 사용됩니다. 누산기가 없으면 각 계산의 모든 결과 (더하기, 곱하기, 시프트 등)가 주 메모리에 저장됩니다. 주 메모리에 대한 액세스는 누산기와 같은 레지스터에 대한 액세스보다 느립니다. 대용량 주 메모리에 사용되는 기술은 레지스터에 사용되는 기술보다 느리지 만 저렴하기 때문입니다.
"R"레지스터
"R"레지스터는 R0, R1 ~ R7의 8 개 레지스터 세트입니다. 이러한 레지스터는 많은 작업에서 보조 또는 임시 저장 레지스터로 작동합니다. 10과 20의 합의 예를 고려하십시오. 변수 10을 누산기에 저장하고 다른 변수 20을 레지스터 R4에 저장하십시오. 추가 작업을 처리하려면 다음 명령을 실행하십시오.
ADD A,R4
이 명령어를 실행하면 누산기에 값 30이 포함됩니다. 따라서 "R"레지스터는 매우 중요한 보조 또는 helper registers. 이러한 "R"레지스터가 아니라면 누산기만으로는 유용하지 않습니다. "R"레지스터는 값의 임시 저장을 의미합니다.
다른 예를 들어 보겠습니다. R1과 R2의 값을 더한 다음 결과에서 R3과 R4의 값을 뺍니다.
MOV A,R3 ;Move the value of R3 into the accumulator
ADD A,R4 ;Add the value of R4
MOV R5,A ;Store the resulting value temporarily in R5
MOV A,R1 ;Move the value of R1 into the accumulator
ADD A,R2 ;Add the value of R2
SUBB A,R5 ;Subtract the value of R5 (which now contains R3 + R4)
보시다시피 R5를 사용하여 R3과 R4의 합을 일시적으로 유지했습니다. 물론 이것은 (R1 + R2) – (R3 + R4)를 계산하는 가장 효율적인 방법은 아니지만 값을 임시로 저장하는 방법으로 "R"레지스터를 사용하는 방법을 보여줍니다.
"B"레지스터
"B"레지스터는 8 비트 (1 바이트) 값을 보유 할 수 있다는 점에서 누산기와 매우 유사합니다. "B"레지스터는 두 개의 8051 명령어에서만 사용됩니다.MUL AB 과 DIV AB. A를 다른 숫자로 빠르고 쉽게 곱하거나 나누려면 다른 숫자를 "B"에 저장하고이 두 가지 지침을 사용할 수 있습니다. MUL 및 DIV 명령어를 사용하는 것 외에도 "B"레지스터는 9 번째 R 레지스터처럼 또 다른 임시 저장 레지스터로 자주 사용됩니다.
데이터 포인터
DPTR (Data Pointer)은 8051의 유일한 사용자 액세스 가능한 16 비트 (2 바이트) 레지스터입니다. 누산기, R0–R7 레지스터 및 B 레지스터는 1 바이트 값 레지스터입니다. DPTR은 데이터를 가리키는 데 사용됩니다. 8051에서 DPTR로 표시된 주소를 사용하여 외부 메모리에 액세스하는 데 사용됩니다. DPTR은 사용 가능한 유일한 16 비트 레지스터이며 2 바이트 값을 저장하는 데 자주 사용됩니다.
프로그램 카운터
프로그램 카운터 (PC)는 메모리에서 실행할 다음 명령을 찾을 수있는 위치를 8051에 알려주는 2 바이트 주소입니다. PC는 8051이 초기화 될 때 0000h에 시작하고 명령이 실행 된 후 매번 증가합니다. PC가 항상 1 씩 증가하는 것은 아닙니다. 일부 명령어는 2 바이트 또는 3 바이트가 필요할 수 있습니다. 이 경우 PC는 2 또는 3 씩 증가합니다.
Branch, jump, 및 interrupt연산은 다음 순차 위치가 아닌 주소로 프로그램 카운터를로드합니다. 파워 온 리셋을 활성화하면 레지스터의 모든 값이 손실됩니다. 이것은 리셋시 PC의 값이 0이라는 것을 의미하며, CPU가 ROM 위치 0000에서 첫 번째 opcode를 가져 오도록합니다. 이는 CPU가 0000 위치를 찾을 것으로 예상하기 때문에 upcode의 첫 번째 바이트를 ROM 위치 0000에 배치해야 함을 의미합니다. 첫 번째 지시.
스택 포인터 (SP)
DPTR 및 PC를 제외한 모든 레지스터와 마찬가지로 스택 포인터는 8 비트 (1 바이트) 값을 보유 할 수 있습니다. 스택 포인터는 스택에서 다음 값을 제거 할 위치를 알려줍니다. 값이 스택으로 푸시되면 SP 값이 증가한 다음 결과 메모리 위치에 값이 저장됩니다. 값이 스택에서 튀어 나오면 SP에서 지정한 메모리 위치에서 값이 반환 된 다음 SP 값이 감소합니다.
이 작동 순서는 중요합니다. SP는 8051이 초기화되면 07h로 초기화됩니다. 값이 동시에 스택에 푸시되면 8051이 먼저 SP 값 (07h에서 08h로)을 증가시킨 다음 푸시 된 값을 해당 메모리에 저장하기 때문에 값이 내부 RAM 주소 08h에 저장됩니다. 주소 (08h). SP는 PUSH, POP, ACALL, LCALL, RET 및 RETI의 6 가지 명령에 의해 8051에 의해 직접 수정됩니다.
8051의 ROM 공간
8051의 일부 제품군에는 4K 바이트의 온칩 ROM (예 : 8751, AT8951) 만 있습니다. 일부는 AT89C52와 같은 8K ROM을 가지고 있으며 Dallas Semiconductor와 같은 32K 바이트 및 64K 바이트 온칩 ROM을 가진 일부 제품군이 있습니다. 기억해야 할 점은 8051의 프로그램 카운터가 16 비트 레지스터 (0000에서 FFFF 주소)이기 때문에 8051 제품군의 어떤 구성원도 64K 바이트 이상의 opcode에 액세스 할 수 없다는 것입니다.
8051 내부의 프로그램 ROM의 첫 번째 위치는 0000H의 주소를 갖지만 마지막 위치는 칩의 ROM 크기에 따라 다를 수 있습니다. 8051 제품군 중 AT8951에는 0000 (첫 번째 위치)에서 0FFFH (마지막 위치)까지의 메모리 주소를 갖는 $ k 바이트의 온칩 ROM이 있습니다.
8051 플래그 비트 및 PSW 레지스터
PSW (프로그램 상태 어) 레지스터는 8 비트 레지스터입니다. flag register. 8 비트 폭이지만 6 비트 만 사용됩니다. 사용되지 않은 두 비트는user-defined flags. 4 개의 플래그가 호출됩니다.conditional flags이는 명령어가 실행 된 후 발생하는 조건을 나타냅니다. 이 4 개는CY (나르다), AC (보조 캐리), P (패리티) 및 OV(과다). RS0 및 RS1 비트는 뱅크 레지스터를 변경하는 데 사용됩니다. 다음 그림은 프로그램 상태 워드 레지스터를 보여줍니다.
PSW 레지스터에는 CPU의 현재 상태를 반영하는 상태 비트가 포함되어 있습니다.
CY | CA | F0 | RS1 | RS0 | OV | - | 피 |
---|
CY | PSW.7 | 캐리 플래그 |
AC | PSW.6 | 보조 캐리 플래그 |
F0 | PSW.5 | 일반 용도로 사용자가 플래그 0을 사용할 수 있습니다. |
RS1 | PSW.4 | 뱅크 선택기 비트 1 등록 |
RS0 | PSW.3 | 뱅크 선택기 비트 0 등록 |
OV | PSW.2 | 오버플로 플래그 |
- | PSW.1 | 사용자 정의 가능한 FLAG |
피 | PSW.0 | 패리티 플래그. 누산기에서 1 비트의 짝수 / 홀수를 나타 내기 위해 명령주기 동안 하드웨어에 의해 설정 / 삭제됩니다. |
RS0 및 RS1 비트를 사용하여 해당 레지스터 뱅크 비트를 선택할 수 있습니다.
RS1 | RS2 | 은행 등록 | 주소 |
---|---|---|---|
0 | 0 | 0 | 00H-07H |
0 | 1 | 1 | 08H-0FH |
1 | 0 | 2 | 10H-17H |
1 | 1 | 삼 | 18H-1FH |
CY, the carry flag−이 캐리 플래그는 D7 비트에서 수행 될 때마다 설정됩니다 (1). 8 비트 더하기 또는 빼기 작업 후에 영향을받습니다. "SETB C"및 "CLR C"와 같은 명령에 의해 직접 1 또는 0으로 재설정 할 수도 있습니다. 여기서 "SETB"는 세트 비트 캐리를 나타내고 "CLR"은 클리어 캐리를 나타냅니다.
AC, auxiliary carry flag− ADD 또는 SUB 작동 중에 D3 및 D4에서 캐리가 발생하면 AC 비트가 설정됩니다. 그렇지 않으면 지워집니다. 이진 코드 십진 산술을 수행하는 명령어에 사용됩니다.
P, the parity flag− 패리티 플래그는 누산기 레지스터에서만 1의 수를 나타냅니다. A 레지스터에 홀수 1이 포함되어 있으면 P = 1입니다. 1이 짝수 인 경우 P = 0입니다.
OV, the overflow flag−이 플래그는 부호있는 숫자 연산의 결과가 너무 커서 상위 비트가 부호 비트로 넘칠 때마다 설정됩니다. 부호있는 산술 연산에서 오류를 감지하는 데만 사용됩니다.
예
다음 명령어에서 9CH 및 64H를 추가 한 후 CY, AC 및 P 플래그의 상태를 표시합니다.
MOV A, # 9CH
A, # 64H 추가
Solution: 9C 10011100
+64 01100100
100 00000000
CY = 1 since there is a carry beyond D7 bit
AC = 0 since there is a carry from D3 to D4
P = 0 because the accumulator has even number of 1's