임베디드 시스템-지침

프로그램의 흐름은 제어 전송 명령이 실행되지 않는 한 한 명령에서 다음 명령으로 순차적으로 진행됩니다. 어셈블리 언어의 다양한 유형의 제어 전송 명령에는 조건부 또는 무조건 점프 및 호출 명령이 포함됩니다.

루프 및 점프 지침

8051에서 반복

일련의 명령을 특정 횟수만큼 반복하는 것을 loop. 지침DJNZ reg, label루프 작업을 수행하는 데 사용됩니다. 이 명령어에서 레지스터는 1 씩 감소합니다. 0이 아니면 8051은 레이블이 참조하는 대상 주소로 점프합니다.

레지스터는 루프가 시작되기 전에 반복 횟수에 대한 카운터와 함께로드됩니다. 이 명령어에서는 레지스터 감소와 점프 결정이 모두 단일 명령어로 결합됩니다. 레지스터는 R0–R7 중 하나 일 수 있습니다. 카운터는 RAM 위치가 될 수도 있습니다.

Multiply 25 by 10 using the technique of repeated addition.

Solution− 곱셈기만큼 곱셈을 반복적으로 더하여 곱셈을 수행 할 수 있습니다. 예를 들면

25 * 10 = 250 (FAH)

25 + 25 + 25 + 25 + 25 + 25 + 25 + 25 + 25 + 25 = 250

MOV A,#0             ;A = 0,clean ACC 
   MOV R2,#10           ; the multiplier is replaced in R2 
   Add A,#25            ;add the multiplicand to the ACC 
	
AGAIN:DJNZ R2, 
AGAIN:repeat  until R2 = 0 (10 times) 

   MOV R5 , A           ;save A in R5 ;R5 (FAH)

Drawback in 8051 − 명령어를 사용한 반복 동작 DJNZ Reg label256 회 반복으로 만 제한됩니다. 조건부 점프가 수행되지 않으면 점프 이후의 명령이 실행됩니다.

루프 내부에서 반복

다른 루프 내부에서 루프를 사용하면 nested loop. 최대 개수가 256 개로 제한 될 때 개수를 유지하기 위해 두 개의 레지스터가 사용됩니다. 따라서이 방법을 사용하여 256 회 이상 동작을 반복합니다.

Example

프로그램 작성-

  • 55H 값으로 어큐뮬레이터를로드합니다.
  • ACC를 700 번 보완합니다.

Solution− 700은 255 (레지스터의 최대 용량)보다 크므로 두 개의 레지스터가 카운트를 유지하는 데 사용됩니다. 다음 코드는 카운트에 두 개의 레지스터 R2와 R3을 사용하는 방법을 보여줍니다.

MOV A,#55H            ;A = 55H 
	
NEXT: MOV R3,#10         ;R3 the outer loop counter 
AGAIN:MOV R2,#70         ;R2 the inner loop counter 

   CPL A                 ;complement

기타 조건부 점프

다음 표는 8051에서 사용 된 조건부 점프를 나열합니다.

교수 동작
JZ A = 0이면 점프
JNZ A ≠ 0이면 점프
DJNZ 레지스터 ≠ 0 인 경우 감소 및 점프
CJNE A, 데이터 A ≠ 데이터이면 점프
CJNE reg, #data 바이트 ≠ 데이터이면 점프
JC CY = 1이면 점프
JNC CY ≠ 1이면 점프
JB 비트 = 1이면 점프
JNB 비트 = 0이면 점프
JBC 비트 = 1이면 점프하고 비트를 지 웁니다.
  • JZ (jump if A = 0)−이 지침에서는 누산기의 내용을 확인합니다. 0이면 8051은 대상 주소로 점프합니다. JZ 명령어는 누산기에만 사용할 수 있으며 다른 레지스터에는 적용되지 않습니다.

  • JNZ (jump if A is not equal to 0)−이 명령어에서 누산기의 내용이 0이 아닌지 확인합니다. 0이 아니면 8051은 대상 주소로 점프합니다.

  • JNC (Jump if no carry, jumps if CY = 0)− 플래그 (또는 PSW) 레지스터의 Carry 플래그 비트는 "JNC 레이블"점프 여부를 결정하는 데 사용됩니다. CPU는 캐리 플래그가 올라 갔는지 확인합니다 (CY = 1). 올라가지 않으면 CPU는 레이블 주소에서 명령을 가져와 실행하기 시작합니다. CY = 1이면 점프하지 않고 JNC 아래의 다음 명령을 실행합니다.

  • JC (Jump if carry, jumps if CY = 1) − CY = 1이면 대상 주소로 점프합니다.

  • JB (jump if bit is high)

  • JNB (jump if bit is low)

Note − 모든 조건부 점프는 짧은 점프라는 점에 유의해야합니다. 즉, 대상 주소는 프로그램 카운터 내용의 –128 ~ +127 바이트 내에 있어야합니다.

무조건 점프 지침

8051에는 두 가지 무조건 점프가 있습니다.

  • LJMP (long jump)− LJMP는 첫 번째 바이트가 opcode를 나타내고 두 번째 및 세 번째 바이트가 대상 위치의 16 비트 주소를 나타내는 3 바이트 명령어입니다. 2 바이트 대상 주소는 0000에서 FFFFH까지 모든 메모리 위치로 점프 할 수 있도록하는 것입니다.

  • SJMP (short jump)− 첫 번째 바이트가 opcode이고 두 번째 바이트가 대상 위치의 상대 주소 인 2 바이트 명령어입니다. 상대 주소의 범위는 00H에서 FFH까지이며 앞으로 및 뒤로 점프로 나뉩니다. 즉, 현재 PC의 주소 (프로그램 카운터)에 상대적인 메모리 –128 ~ +127 바이트 이내입니다. 순방향 점프의 경우 대상 주소는 현재 PC에서 127 바이트의 공간 내에있을 수 있습니다. 역방향 점프의 경우 대상 주소는 현재 PC에서 –128 바이트 이내 일 수 있습니다.

짧은 점프 주소 계산

모든 조건부 점프 (JNC, JZ 및 DJNZ)는 2 바이트 명령어이기 때문에 짧은 점프입니다. 이 명령어에서 첫 번째 바이트는 opcode를 나타내고 두 번째 바이트는 상대 주소를 나타냅니다. 대상 주소는 항상 프로그램 카운터 값에 상대적입니다. 대상 주소를 계산하기 위해 두 번째 바이트가 점프 바로 아래의 명령어 PC에 추가됩니다. 아래 주어진 프로그램을 살펴보십시오-

Line   PC    Op-code   Mnemonic   Operand 
1      0000               ORG       0000 
2      0000  7800         MOV       R0,#003  
3      0002  7455         MOV       A,#55H0 
4      0004  6003         JZ        NEXT 
5      0006  08           INC       R0 
6      0007  04   AGAIN:  INC       A 
7      0008  04           INC       A 
8      0009  2477 NEXT:   ADD       A, #77h 
9      000B  5005         JNC       OVER 
10     000D  E4           CLR       A
11     000E  F8           MOV       R0, A 
12     000F  F9           MOV       R1, A 
13     0010  FA          MOV       R2, A 
14     0011  FB           MOV       R3, A 
15     0012  2B   OVER:   ADD       A, R3 
16     0013  50F2         JNC       AGAIN 
17     0015  80FE HERE:   SJMP      HERE 
18     0017             END

역방향 점프 대상 주소 계산

전진 점프의 경우 변위 값은 0 ~ 127 (16 진수로 00 ~ 7F) 사이의 양수입니다. 그러나 뒤로 점프하는 경우 변위는 0에서 –128 사이의 음수 값입니다.

통화 지침

CALL은 서브 루틴 또는 메소드를 호출하는 데 사용됩니다. 서브 루틴은 자주 수행해야하는 작업이나 작업을 수행하는 데 사용됩니다. 이것은 프로그램을 더 구조화하고 메모리 공간을 절약합니다. LCALL과 ACALL의 두 가지 명령이 있습니다.

LCALL (긴 전화)

LCALL은 첫 번째 바이트가 opcode를 나타내고 두 번째 및 세 번째 바이트가 대상 서브 루틴의 주소를 제공하는 데 사용되는 3 바이트 명령어입니다. LCALL은 8051의 64K 바이트 주소 공간 내에서 사용 가능한 서브 루틴을 호출하는 데 사용할 수 있습니다.

호출 된 서브 루틴을 실행 한 후 해당 지점으로 성공적으로 복귀하기 위해 CPU는 스택의 LCALL 바로 아래에 명령어 주소를 저장합니다. 따라서 서브 루틴이 호출되면 제어가 해당 서브 루틴으로 전송되고 프로세서는 PC (프로그램 카운터)를 스택에 저장하고 새 위치에서 명령을 가져 오기 시작합니다. RET (return) 명령은 서브 루틴 실행을 마친 후 제어를 호출자에게 다시 전송합니다. 모든 서브 루틴은 RET를 마지막 명령어로 사용합니다.

ACALL (절대 호출)

ACALL은 3 바이트 인 LCALL과 달리 2 바이트 명령어입니다. 2 바이트 중 11 비트 만 주소로 사용되기 때문에 서브 루틴의 대상 주소는 2K 바이트 내에 있어야합니다. ACALL과 LCALL의 차이점은 LCALL의 대상 주소는 8051의 64K 바이트 주소 공간 내에있을 수 있고 CALL의 대상 주소는 2K 바이트 범위 내에 있다는 것입니다.