एंबेडेड सिस्टम - निर्देश

कार्यक्रम का प्रवाह क्रमबद्ध तरीके से होता है, एक निर्देश से अगले निर्देश तक, जब तक कि एक नियंत्रण हस्तांतरण निर्देश निष्पादित नहीं किया जाता है। विधानसभा भाषा में विभिन्न प्रकार के नियंत्रण हस्तांतरण निर्देश में सशर्त या बिना शर्त कूद और कॉल निर्देश शामिल हैं।

लूप और जंप निर्देश

8051 में लूपिंग

निर्देशों के अनुक्रम को एक निश्चित संख्या में बार-बार दोहराना कहा जाता है loop। एक निर्देशDJNZ reg, labelलूप ऑपरेशन करने के लिए उपयोग किया जाता है। इस निर्देश में, एक रजिस्टर को 1 से घटाया जाता है; यदि यह शून्य नहीं है, तो लेबल द्वारा निर्दिष्ट लक्ष्य पते पर 8051 कूदता है।

लूप की शुरुआत से पहले रजिस्टर को पुनरावृत्ति की संख्या के लिए काउंटर के साथ लोड किया जाता है। इस निर्देश में, रजिस्टरों में गिरावट और कूदने का निर्णय दोनों को एक निर्देश में जोड़ा गया है। रजिस्टर R0-R7 में से कोई भी हो सकता है। काउंटर एक रैम लोकेशन भी हो सकता है।

उदाहरण

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 labelकेवल 256 पुनरावृत्तियों तक सीमित है। यदि एक सशर्त कूद नहीं लिया जाता है, तो कूद के बाद निर्देश निष्पादित किया जाता है।

एक लूप के अंदर लूपिंग

जब हम दूसरे लूप के अंदर एक लूप का उपयोग करते हैं, तो इसे ए कहा जाता है nested loop। दो रजिस्टरों का उपयोग गिनती को पकड़ने के लिए किया जाता है जब अधिकतम गिनती 256 तक सीमित होती है। इसलिए हम इस विधि का उपयोग 256 से अधिक बार दोहराने के लिए करते हैं।

Example

एक कार्यक्रम के लिए लिखें -

  • 55H मान के साथ संचायक लोड करें।
  • एसीसी को 700 बार पूरक करें।

Solution- चूंकि 700 255 (किसी भी रजिस्टर की अधिकतम क्षमता) से अधिक है, दो रजिस्टरों का उपयोग गिनती रखने के लिए किया जाता है। निम्न कोड दिखाता है कि गिनती के लिए दो रजिस्टर, आर 2 और आर 3 का उपयोग कैसे करें।

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 कूदो अगर ए = ०
JNZ कूदो अगर A if 0
DJNZ कमी और कूद अगर रजिस्टर if 0
CJNE A, डेटा कूदो अगर A ≠ डेटा
CJNE reg, # दाता अगर बाइट। डेटा कूदो
जे.सी. कूदो अगर CY = 1
JNC कूदो अगर CY if 1
जेबी कूदो अगर बिट = 1
JNB कूदो अगर बिट = 0
JBC जंप करें यदि बिट = 1 और स्पष्ट बिट
  • JZ (jump if A = 0)- इस निर्देश में, संचायक की सामग्री की जाँच की जाती है। यदि यह शून्य है, तो 8051 लक्ष्य पते पर कूदता है। JZ निर्देश केवल संचायक के लिए उपयोग किया जा सकता है, यह किसी अन्य रजिस्टर पर लागू नहीं होता है।

  • JNZ (jump if A is not equal to 0)- इस निर्देश में, संचायक की सामग्री को गैर-शून्य होने की जाँच की जाती है। यदि यह शून्य नहीं है, तो 8051 लक्ष्य पते पर कूदता है।

  • JNC (Jump if no carry, jumps if CY = 0)- ध्वज (या PSW) रजिस्टर में कैरी फ्लैग बिट का उपयोग निर्णय लेने के लिए किया जाता है कि क्या "JNC लेबल" कूदना है या नहीं। सीपीयू कैरी फ्लैग को यह देखने के लिए देखता है कि क्या यह उठाया गया है (CY = 1)। यदि यह नहीं उठाया जाता है, तो सीपीयू लेबल के पते से निर्देशों को लाने और निष्पादित करना शुरू कर देता है। यदि 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 3-बाइट अनुदेश है जिसमें पहला बाइट opcode का प्रतिनिधित्व करता है, और दूसरा और तीसरा बाइट लक्ष्य स्थान के 16-बिट पते का प्रतिनिधित्व करता है। 2-बाइट लक्ष्य पता 0000 से FFFFH तक किसी भी मेमोरी लोकेशन पर जाने की अनुमति देता है।

  • SJMP (short jump)- यह एक 2-बाइट अनुदेश है जहां पहला बाइट opcode है और दूसरा बाइट लक्ष्य स्थान का सापेक्ष पता है। रिश्तेदार का पता 00H से FFH तक होता है जो आगे और पीछे की छलांग में विभाजित होता है; वर्तमान पीसी (प्रोग्राम काउंटर) के पते के सापेक्ष मेमोरी के भीतर -128 से 1212 बाइट्स है। आगे की छलांग के मामले में, लक्ष्य पता वर्तमान पीसी से 127 बाइट्स के स्थान के भीतर हो सकता है। बैकवर्ड जंप के मामले में, लक्ष्य पता वर्तमान पीसी से -128 बाइट्स में हो सकता है।

शॉर्ट जंप एड्रेस की गणना

सभी सशर्त जंप (JNC, JZ, और DJNZ) शॉर्ट जंप हैं क्योंकि वे 2-बाइट निर्देश हैं। इन निर्देशों में, पहला बाइट opcode का प्रतिनिधित्व करता है और दूसरा बाइट सापेक्ष पते का प्रतिनिधित्व करता है। लक्ष्य पता हमेशा प्रोग्राम काउंटर के मूल्य के सापेक्ष होता है। लक्ष्य पते की गणना करने के लिए, कूदने के तुरंत बाद दूसरे बाइट को निर्देश के पीसी में जोड़ा जाता है। नीचे दिए गए कार्यक्रम पर एक नज़र डालें -

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 (हेक्स में 00 से 7F) के बीच एक सकारात्मक संख्या है। हालाँकि, एक पिछड़ी छलांग के लिए, विस्थापन 0 से -128 तक का नकारात्मक मान है।

कॉल निर्देश

कॉल का उपयोग सबरूटीन या विधि को कॉल करने के लिए किया जाता है। सबरूटीन्स का उपयोग ऑपरेशन या कार्यों को करने के लिए किया जाता है जिन्हें अक्सर निष्पादित करने की आवश्यकता होती है। यह एक प्रोग्राम को अधिक संरचित बनाता है और मेमोरी स्पेस को बचाता है। दो निर्देश हैं - LCALL और ACALL।

LCALL (लंबी कॉल)

LCALL एक 3-बाइट अनुदेश है जहां पहला बाइट opcode का प्रतिनिधित्व करता है और दूसरा और तीसरा बाइट्स लक्ष्य सबरूटीन का पता प्रदान करने के लिए उपयोग किया जाता है। LCALL का उपयोग सबरूटीन्स को कॉल करने के लिए किया जा सकता है जो कि 8051 के 64K-बाइट एड्रेस स्पेस में उपलब्ध हैं।

कहा जाता है कि सबरूटीन के निष्पादन के बाद बिंदु पर एक सफल वापसी करने के लिए, सीपीयू स्टैक पर तुरंत LCALL के नीचे दिए गए निर्देश का पता बचाता है। इस प्रकार, जब एक सबरूटीन कहा जाता है, तो नियंत्रण को उस सबरूटीन में स्थानांतरित कर दिया जाता है, और प्रोसेसर पीसी (प्रोग्राम काउंटर) को स्टैक पर सहेजता है और नए स्थान से निर्देश प्राप्त करना शुरू कर देता है। निर्देश आरईटी (वापसी) सबरूटीन के निष्पादन को समाप्त करने के बाद नियंत्रण वापस कॉलर को स्थानांतरित करता है। हर उपरांत अंतिम निर्देश के रूप में RET का उपयोग करता है।

ACALL (पूर्ण कॉल)

ACALL एक 2-बाइट अनुदेश है, LCALL के विपरीत जो 3 बाइट्स है। सबरूटीन का लक्ष्य पता 2K बाइट्स के भीतर होना चाहिए क्योंकि 2 बाइट्स में से केवल 11 बिट्स पते के लिए उपयोग किए जाते हैं। ACALL और LCALL के बीच का अंतर यह है कि LCALL का लक्ष्य पता 8051 के 64K-बाइट्स पता स्थान के भीतर कहीं भी हो सकता है, जबकि CALL का लक्ष्य पता 2K-बाइट सीमा के भीतर है।