बेलमैक-8: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
{{Short description|8-bit microprocessor}} | {{Short description|8-bit microprocessor}} | ||
एमएसी-8, जिसे आज '''बेलमैक-8''' के नाम से जाना जाता है, एक [[8-बिट कंप्यूटिंग]] 8-बिट [[माइक्रोप्रोसेसर]] है जिसे [[बेल लैब्स]] द्वारा डिज़ाइन किया गया है। [[वेस्टर्न इलेक्ट्रिक]] में 1977 में डब्लूई212 के रूप में [[CMOS|सीएमओएस]] फॉर्म में आउटपुट प्रारंभ किया गया था। और एमएसी-8 का उपयोग केवल [[4ESS|4ईएसएस]] जैसे एटी&टी उत्पादों में किया जाता था। इस प्रकार से कोई व्यावसायिक [[ डेटा शीट |डेटा शीट]] प्रकाशित नहीं की गई थी, इसलिए इसके परिणामस्वरूप अधिक कम डेटा है। अतः सार्वजनिक में अधिक प्रसिद्ध उपयोग मैक-ट्यूटर [[ कंप्यूटर प्रशिक्षक |कंप्यूटर ट्रेनर]] है, जो की 1979 में प्रवाहित किया गया था। | एमएसी-8, जिसे आज '''बेलमैक-8''' के नाम से जाना जाता है, एक [[8-बिट कंप्यूटिंग]] 8-बिट [[माइक्रोप्रोसेसर]] है जिसे [[बेल लैब्स]] द्वारा डिज़ाइन किया गया है। [[वेस्टर्न इलेक्ट्रिक]] में 1977 में डब्लूई212 के रूप में [[CMOS|सीएमओएस]] फॉर्म में आउटपुट प्रारंभ किया गया था। और एमएसी-8 का उपयोग केवल [[4ESS|4ईएसएस]] जैसे एटी&टी उत्पादों में किया जाता था। इस प्रकार से कोई व्यावसायिक [[ डेटा शीट |डेटा शीट]] प्रकाशित नहीं की गई थी, इसलिए इसके परिणामस्वरूप अधिक कम डेटा है। अतः सार्वजनिक में अधिक प्रसिद्ध उपयोग मैक-ट्यूटर [[ कंप्यूटर प्रशिक्षक |कंप्यूटर ट्रेनर]] है, जो की 1979 में प्रवाहित किया गया था। | ||
Line 44: | Line 26: | ||
आठ मोड के मुख्य सेट में रजिस्टर/रजिस्टर, मेमोरी में बेस एड्रेस पर या उससे रजिस्टर करना (अप्रत्यक्ष), बेस एड्रेस पर या उससे रजिस्टर करना और साथ ही ऑफसेट (अनुक्रमित) और ऑटो-इंक्रीमेंटिंग सम्मिलित है, जिसने चयनित b रजिस्टर के मान एक में जोड़ता और फिर उस स्थान पर डेटा को एक्सेस करता है। यह अंतिम मोड मेमोरी में बेस एड्रेस रखकर और फिर उसी रजिस्टर नंबर के साथ ऑपकोड को बार-बार कॉल करके मेमोरी पर लूप प्रयुक्त करने के लिए उपयोगी था, जिससे यह बिना किसी स्पष्ट निर्देश के बढ़ जाता था। यदि किसी भी निबल को मान 15 पर सेट किया गया था, तो आठ मोड का अर्थ परिवर्तित हो जाता है। इस स्तिथि में, स्रोत अब 16 रजिस्टरों में से नहीं था, किन्तु मोड के बेस पर या तो प्रोग्राम काउंटर या स्टैक काउंटर था, जबकि गंतव्य अधिकतर आर15 को संदर्भित करता था किन्तु एड्रेस एसपी से लिए गए थे। इसके पश्चात मोडों का उपयोग अधिकतर सशर्त शाखाओं के साथ किया गया था, इस प्रकार से उदाहरण के लिए, निर्देश को स्रोत में मान के बेस पर वर्तमान पीसी से आगे एन स्थानों पर आगे बढ़ने की अनुमति दी गई थी।{{sfn|TUTOR|1979|p=3.3}} भिन्न-भिन्न निर्देश, पीयूएसएच और पीओपी और बीयूएमपी और डीईबीयूएमपी, क्रमशः स्टैक पॉइंटर या रजिस्टर पॉइंटर को बढ़ाते और घटाते हैं।{{sfn|Winfield|1978|p=499}} | आठ मोड के मुख्य सेट में रजिस्टर/रजिस्टर, मेमोरी में बेस एड्रेस पर या उससे रजिस्टर करना (अप्रत्यक्ष), बेस एड्रेस पर या उससे रजिस्टर करना और साथ ही ऑफसेट (अनुक्रमित) और ऑटो-इंक्रीमेंटिंग सम्मिलित है, जिसने चयनित b रजिस्टर के मान एक में जोड़ता और फिर उस स्थान पर डेटा को एक्सेस करता है। यह अंतिम मोड मेमोरी में बेस एड्रेस रखकर और फिर उसी रजिस्टर नंबर के साथ ऑपकोड को बार-बार कॉल करके मेमोरी पर लूप प्रयुक्त करने के लिए उपयोगी था, जिससे यह बिना किसी स्पष्ट निर्देश के बढ़ जाता था। यदि किसी भी निबल को मान 15 पर सेट किया गया था, तो आठ मोड का अर्थ परिवर्तित हो जाता है। इस स्तिथि में, स्रोत अब 16 रजिस्टरों में से नहीं था, किन्तु मोड के बेस पर या तो प्रोग्राम काउंटर या स्टैक काउंटर था, जबकि गंतव्य अधिकतर आर15 को संदर्भित करता था किन्तु एड्रेस एसपी से लिए गए थे। इसके पश्चात मोडों का उपयोग अधिकतर सशर्त शाखाओं के साथ किया गया था, इस प्रकार से उदाहरण के लिए, निर्देश को स्रोत में मान के बेस पर वर्तमान पीसी से आगे एन स्थानों पर आगे बढ़ने की अनुमति दी गई थी।{{sfn|TUTOR|1979|p=3.3}} भिन्न-भिन्न निर्देश, पीयूएसएच और पीओपी और बीयूएमपी और डीईबीयूएमपी, क्रमशः स्टैक पॉइंटर या रजिस्टर पॉइंटर को बढ़ाते और घटाते हैं।{{sfn|Winfield|1978|p=499}} | ||
नियंत्रण स्थानांतरण फ़ंक्शन लॉजिक निर्देश के समान हैं किन्तु वैकल्पिक ऑपकोड की कमी है, और ऑफसेट जैसी वस्तु को निष्पादित करने के लिए केवल रजिस्टर मान की आवश्यकता होती है क्योंकि बेस एड्रेस सामान्य रूप से प्रोग्राम काउंटर होता है। जिसमे अनकंडीशनल जंप, सबरूटीन कॉल और रिटर्न के लिए केवल ही गंतव्य की आवश्यकता होती है या किसी की भी आवश्यकता नहीं होती है। और सशर्त शाखाओं के स्तिथि में, केवल ही रजिस्टर का उपयोग करने की आवश्यकता है, क्योंकि कुछ भी वापस नहीं लिखा जा रहा है, इसलिए डी/एस बाइट के निचले निबल का उपयोग यह इंगित करने के लिए किया गया था कि 16 भिन्न-भिन्न स्थितियों में से किसका परीक्षण किया जाना चाहिए, जैसे कि क्या संकेतित स्थान पर मान शून्य है. नियमो में विशिष्ट ऋणात्मक , शून्य, कैरी और ओवरफ्लो स्थितियां सम्मिलित थीं, किन्तु इसमें यह भी सम्मिलित था कि क्या सभी मान विषम हैं या नहीं (255) या यहां तक कि क्या अन्य के मध्य व्यवधान सक्षम है।{{sfn|TUTOR|1979|p=3.4}} | नियंत्रण स्थानांतरण फ़ंक्शन लॉजिक निर्देश के समान हैं किन्तु वैकल्पिक ऑपकोड की कमी है, और ऑफसेट जैसी वस्तु को निष्पादित करने के लिए केवल रजिस्टर मान की आवश्यकता होती है क्योंकि बेस एड्रेस सामान्य रूप से प्रोग्राम काउंटर होता है। जिसमे अनकंडीशनल जंप, सबरूटीन कॉल और रिटर्न के लिए केवल ही गंतव्य की आवश्यकता होती है या किसी की भी आवश्यकता नहीं होती है। और सशर्त शाखाओं के स्तिथि में, केवल ही रजिस्टर का उपयोग करने की आवश्यकता है, क्योंकि कुछ भी वापस नहीं लिखा जा रहा है, इसलिए डी/एस बाइट के निचले निबल का उपयोग यह इंगित करने के लिए किया गया था कि 16 भिन्न-भिन्न स्थितियों में से किसका परीक्षण किया जाना चाहिए, जैसे कि क्या संकेतित स्थान पर मान शून्य है. नियमो में विशिष्ट ऋणात्मक, शून्य, कैरी और ओवरफ्लो स्थितियां सम्मिलित थीं, किन्तु इसमें यह भी सम्मिलित था कि क्या सभी मान विषम हैं या नहीं (255) या यहां तक कि क्या अन्य के मध्य व्यवधान सक्षम है।{{sfn|TUTOR|1979|p=3.4}} | ||
===प्रोग्रामिंग === | ===प्रोग्रामिंग === | ||
Line 67: | Line 49: | ||
यह कोड 100 बाइट्स मेमोरी को अलग रखता है और इसे नाम {{code|array}} निर्दिष्ट करता है. वह {{code|sum}} रूटीन फिर का एड्रेस खोजे{{code|array}} मेमोरी में, परिणामी योग को रखने के लिए रजिस्टर a1 को साफ़ करता है, और फिर b0 में एड्रेस को बढ़ाते हुए प्रविष्टियों को a1 में जोड़ने वाले सरणी पर लूप करता है। संकलित होने पर, <nowiki>''</nowiki>वेरिएबल्स<nowiki>''</nowiki> b0, a1 और a2 को रजिस्टरों में रखा जाएगा और विभिन्न ऑपरेशनों को आईएसए ऑपकोड में अनुवादित किया जाएगा - उदाहरण के लिए, {{code|a1 {{=}} 0;}} का असाइनमेंट एड्रेसिंग सेट के साथ {{code|MOVE}} निर्देश में परिवर्तन दिया जाएगा जिससे गंतव्य आर रजिस्टर हो और स्रोत स्थिर मान शून्य हो। वह को इंडेक्स वेरिएबल {{code|a2}} के स्रोत के रूप में अन्य रजिस्टरों का उपयोग करके {{code|for}} को मैक्रो के रूप में प्रयुक्त किया जाएगा।{{sfn|Rovegno|1978|p=2255}} लैंग्वेज में संरचनाएं, परिवर्तनीय परिभाषाएं, फ़ंक्शन और c की अधिकांश अन्य विशेषताएं सम्मिलित हैं।{{sfn|Rovegno|1978|p=2256}}{{sfn|Winfield|1978|p=502}} | यह कोड 100 बाइट्स मेमोरी को अलग रखता है और इसे नाम {{code|array}} निर्दिष्ट करता है. वह {{code|sum}} रूटीन फिर का एड्रेस खोजे{{code|array}} मेमोरी में, परिणामी योग को रखने के लिए रजिस्टर a1 को साफ़ करता है, और फिर b0 में एड्रेस को बढ़ाते हुए प्रविष्टियों को a1 में जोड़ने वाले सरणी पर लूप करता है। संकलित होने पर, <nowiki>''</nowiki>वेरिएबल्स<nowiki>''</nowiki> b0, a1 और a2 को रजिस्टरों में रखा जाएगा और विभिन्न ऑपरेशनों को आईएसए ऑपकोड में अनुवादित किया जाएगा - उदाहरण के लिए, {{code|a1 {{=}} 0;}} का असाइनमेंट एड्रेसिंग सेट के साथ {{code|MOVE}} निर्देश में परिवर्तन दिया जाएगा जिससे गंतव्य आर रजिस्टर हो और स्रोत स्थिर मान शून्य हो। वह को इंडेक्स वेरिएबल {{code|a2}} के स्रोत के रूप में अन्य रजिस्टरों का उपयोग करके {{code|for}} को मैक्रो के रूप में प्रयुक्त किया जाएगा।{{sfn|Rovegno|1978|p=2255}} लैंग्वेज में संरचनाएं, परिवर्तनीय परिभाषाएं, फ़ंक्शन और c की अधिकांश अन्य विशेषताएं सम्मिलित हैं।{{sfn|Rovegno|1978|p=2256}}{{sfn|Winfield|1978|p=502}} | ||
चूँकि सिस्टम नया था, और माइक्रोप्रोसेसरों की पूरी अवधारणा एटी&टी के लिए नवीन थी, कंपनी ने एमएसी-ट्यूटर [[सिंगल-बोर्ड कंप्यूटर]] भी प्रस्तुत किया जिसका उपयोग परीक्षण और डेवलपमेंट के लिए किया जा सकता था। और यूनिक्स टूल का उपयोग प्रोग्राम बनाने, उसे मैक-ट्यूटर पर डाउनलोड करने, चलाने और डीबग करने और यूनिक्स की ओर स्थिति वापस भेजने के लिए किया जा सकता है।{{sfn|Winfield|1978|p=503}} मूल मैक-ट्यूटर में 2 kB की [[रैंडम एक्सेस मेमोरी]], बेसिक हार्डवेयर नियंत्रण कार्यों के साथ 2 kB की [[ केवल पढ़ने के लिये मेमोरी |आरओएम]] , 1 kB [[प्रोग्रामयोग्य ROM|पीआरओएम]] चिप्स के लिए तीन सॉकेट, 28-बटन कैलकुलेटर-प्रकार का कीबोर्ड (4 बाय 7), और सम्मिलित थे। डिस्प्ले जिसमें आठ | चूँकि सिस्टम नया था, और माइक्रोप्रोसेसरों की पूरी अवधारणा एटी&टी के लिए नवीन थी, कंपनी ने एमएसी-ट्यूटर [[सिंगल-बोर्ड कंप्यूटर]] भी प्रस्तुत किया जिसका उपयोग परीक्षण और डेवलपमेंट के लिए किया जा सकता था। और यूनिक्स टूल का उपयोग प्रोग्राम बनाने, उसे मैक-ट्यूटर पर डाउनलोड करने, चलाने और डीबग करने और यूनिक्स की ओर स्थिति वापस भेजने के लिए किया जा सकता है।{{sfn|Winfield|1978|p=503}} मूल मैक-ट्यूटर में 2 kB की [[रैंडम एक्सेस मेमोरी]], बेसिक हार्डवेयर नियंत्रण कार्यों के साथ 2 kB की [[ केवल पढ़ने के लिये मेमोरी |आरओएम]], 1 kB [[प्रोग्रामयोग्य ROM|पीआरओएम]] चिप्स के लिए तीन सॉकेट, 28-बटन कैलकुलेटर-प्रकार का कीबोर्ड (4 बाय 7), और सम्मिलित थे। डिस्प्ले जिसमें आठ 7-सेगमेंट एलईडी हैं। ऑनबोर्ड इंटरफेस में [[कैसेट टेप]], [[कंप्यूटर टर्मिनल]] के लिए दो आरएस-232 और एक 32-पिन बस विस्तारक सम्मिलित थे जिनका उपयोग अधिक मेमोरी या मेमोरी-मैप किए गए डिवाइस को जोड़ने के लिए किया जा सकता था।{{sfn|TUTOR|1979|p=1.1}} | ||
==कार्यान्वयन == | ==कार्यान्वयन == |
Revision as of 11:52, 20 September 2023
एमएसी-8, जिसे आज बेलमैक-8 के नाम से जाना जाता है, एक 8-बिट कंप्यूटिंग 8-बिट माइक्रोप्रोसेसर है जिसे बेल लैब्स द्वारा डिज़ाइन किया गया है। वेस्टर्न इलेक्ट्रिक में 1977 में डब्लूई212 के रूप में सीएमओएस फॉर्म में आउटपुट प्रारंभ किया गया था। और एमएसी-8 का उपयोग केवल 4ईएसएस जैसे एटी&टी उत्पादों में किया जाता था। इस प्रकार से कोई व्यावसायिक डेटा शीट प्रकाशित नहीं की गई थी, इसलिए इसके परिणामस्वरूप अधिक कम डेटा है। अतः सार्वजनिक में अधिक प्रसिद्ध उपयोग मैक-ट्यूटर कंप्यूटर ट्रेनर है, जो की 1979 में प्रवाहित किया गया था।
इस प्रकार से एमएसी-8 विशेष रूप से, बेल की अपनी सी प्रोग्रामिंग लैंग्वेज को उच्च-स्तरीय प्रोग्रामिंग लैंग्वेजो को चलाने के लिए डिज़ाइन किया गया था। और सिस्टम की असामान्य विशेषता यह है कि इसकी असेंबलर लैंग्वेज इच्छापूर्वक सी कोड से मिलती-जुलती लिखी गई थी, जिसमें वेरिएबल्स लूप जैसे उच्च-स्तरीय निर्माणों के लिए समर्थन सम्मिलित था। इसके विपरीत, उस युग के अधिकांश असेंबलरों ने प्रोसेसर के निम्न-स्तरीय ऑपकोड पर अधिक सीधे मैप किया और उच्च-स्तरीय सुविधाओं का अभाव था।
अतः एमएसी-8 के पश्चात बेलमैक-80 आया, जो की आंतरिक रूप से एमएसी-8 से अधिक भिन्न 32-बिट सिस्टम था, किन्तु सी को चलाने के लिए डिज़ाइन किए जाने की अवधारणा को बनाए रखा था। इसके पश्चात प्रयोगात्मक सीआरआईएसपी डिज़ाइन किया गया, और अंत में 1992 एटी एंड टी हॉबिट, जिसका सीमित व्यावसायिक उपयोग किया गया था।
विवरण
डिज़ाइन अवधारणाएँ
इस प्रकार से एमएसी-8, एटी&टी के चल रहे सी मशीन प्रोजेक्ट द्वारा निर्मित किया जाने वाला प्रथम डिज़ाइन है जो की 1975 में प्रारंभ हुआ था। इसका उद्देश्य ऐसे प्रोसेसर डिज़ाइन तैयार करना था जो सीधे उच्च स्तरीय लैंग्वेजो, विशेष रूप से बेल की अपनी सी प्रोग्रामिंग लैंग्वेज को चला सकते है।[1][2]
उन प्रोग्रामों में उचित प्रदर्शन प्रदान करने के लिए जिनमें अनेक फ़ंक्शन कॉल का प्रभुत्व है, उच्च संख्या में प्रोसेसर रजिस्टर होना महत्वपूर्ण है। ये छोटी मात्रा में हाई-स्पीड मेमोरी हैं जिन्हें बिना किसी समय दंड के एक्सेस किया जा सकता है, मुख्य मेमोरी के विपरीत जिसमें सामान्यतः कुछ देरी होती है। और रजिस्टरों का उपयोग करने से डेटा को फ़ंक्शन के अंदर और बाहर अधिक तीव्रता से पारित किया जा सकता है। किंतु आवश्यक ट्रांजिस्टर की संख्या और शेष चिप से उनके कनेक्शन के स्तिथि में रजिस्टर अधिक बहुमान हैं। इस प्रकार से बेल के लक्ष्यों और उपलब्ध प्रक्रिया प्रौद्योगिकी को देखते हुए, ऑन-चिप रजिस्टरों की संख्या उनकी आवश्यकताओं के लिए अधिक कम होती है।[3][2]
इसके अतिरिक्त, सी मशीन अवधारणा अपने रजिस्टरों को मुख्य मेमोरी में रखती है।[2] और 1960 के दशक के उत्तरार्ध में मिनीकंप्यूटर क्षेत्र में यह असामान्य नहीं था, जहां सेंट्रल प्रोसेसिंग यूनिट (सीपीयू) की तुलना में कोर मेमोरी अपेक्षाकृत तीव्र थी, जिसका अर्थ है कि डेटा तक पहुंचने में केवल एक-चक्र की देरी थी। अनेक रजिस्टरों का महत्व धीमी पहुंच की तुलना में किसी भी ऋणात्मक भाग की भरपाई करता है। चूंकि वे माइक्रोप्रोसेसर जिन्हें टेक्सास इंस्ट्रूमेंट्स टीएमएस9900 जैसे पुराने मिनी कंप्यूटर की तरह कार्य करने के लिए डिज़ाइन किया गया था, प्रायः इस अवधारणा का उपयोग करते थे। किन्तु मैक-8 ने भी इस पैटर्न का पालन किया, जिसमे रजिस्टरों को दर्शाने के लिए सोलह मेमोरी स्थानों के ब्लॉक का उपयोग किया था, और रजिस्टर पॉइंटर, या आरपी के साथ मेमोरी में ब्लॉक की प्रारंभिक का चयन किया था। इसका अर्थ यह था कि कंपाइलर मेमोरी में मान लिखकर, आरपी को उनकी ओर निरुपित करने के लिए ले जाकर, और फिर फ़ंक्शन पर जाकर डेटा को फ़ंक्शन में पास कर सकता है। किन्तु जब फ़ंक्शन समाप्त हो गया, तो कंपाइलर ने मशीन को उसकी पिछली स्थिति में वापस लाने के लिए आरपी को उसके पहले मान में परिवर्तन कर दिया है।[4] इस अवधारणा को रजिस्टर विंडो के रूप में जाना जाता है। एमओएस 6502 जैसे निश्चित संख्या में हार्डवेयर रजिस्टरों वाले उन डिज़ाइनों में, इस प्रकार के फ़ंक्शन कॉल के लिए सामान्यतः रजिस्टरों में डेटा को मुख्य मेमोरी या कॉल स्टैक में लिखे जाने की आवश्यकता होती है, दोनों को मेमोरी तक पहुंचने के लिए अनेक चक्रों की आवश्यकता होती है।[5]
इस प्रकार से सिस्टम में चार सार्वजनिक हार्डवेयर रजिस्टर भी सम्मिलित थे। ये 16-बिट प्रोग्राम काउंटर (पीसी), स्टैक पॉइंटर (एसपी), रजिस्टर पॉइंटर (आरपी) और कंडीशन रजिस्टर (सीआर) थे, जिन्हें सामान्यतः अन्य प्लेटफार्मों पर स्टेटस रजिस्टर के रूप में जाना जाता है। इसमें दो आंतरिक 8-बिट रजिस्टर भी सम्मिलित हैं जिनका उपयोग केवल वर्तमान निर्देश के प्रोसेसिंग के समय किया जाता है, निर्देश रजिस्टर (आईआर) जिसमें अंतिम पढ़ा गया निर्देश ऑपकोड होता है, और डी/एस रजिस्टर जो गंतव्य और स्रोत रजिस्टर संख्याओं, 0 से दो निबल्स में 15 को स्टोर्ड करता है। इसके अतिरिक्त, एक 16-बिट एड्रेस वैल्यू और उसके 8-बिट डेटा को प्रोसेसिंग के समय लॉक कर दिया गया था।[4]
अतः सिस्टम में एड्रेस अनुवाद के लिए समर्पित अलग, सरलीकृत, गणित इकाई, एड्रेस अंकगणितीय इकाई (एएयू) सम्मिलित थी। यह बस में या आंतरिक रजिस्टरों से एड्रेस को पढ़ या लिख सकता है, या मुख्य अंकगणितीय लॉजिक यूनिट (एएलयू) से स्वतंत्र, ऑफसेट और इंडेक्सिंग कर सकता है। और रजिस्टरों को मेमोरी में लोड करने का कारण एएयू के लिए स्थान खाली करना था। इसने इसे एएलयू का उपयोग न करते हुए विभिन्न प्रकार के एड्रेसिंग मोड को प्रस्तुत करने की अनुमति दी और इस प्रकार अधिक सम्मिश्र मोड के लिए चक्र विलंब से पीड़ित होना हैं।[6] क्योंकि एड्रेस 16-बिट थे, और प्रायः स्टोरेज के लिए रजिस्टरों का उपयोग किया जाता था, निर्देशों को संबोधित करते हुए सदैव रजिस्टरों को जोड़े में पढ़ा और लिखा जाता था। इन स्तिथियों में, उन्हें ''बेस रजिस्टर'' या ''बी रजिस्टर'' के रूप में संदर्भित किया गया था, और केवल 8-बिट मान का उपयोग करने वाले निर्देशों को "ए रजिस्टर" के रूप में जाना जाता था। चूंकि रजिस्टर सदैव मेमोरी में 16-बिट होते थे, रजिस्टर केवल जोड़ी के कम बाइट का उपयोग करते थे।[7] कुछ सीमा तक अस्पष्ट करने वाला तथ्य यह है कि जब डाक्यूमेंटेशन में इसका उल्लेख किया गया, तो a रजिस्टरों को आर दर्शाया गया था, जबकि b रजिस्टरों को b दर्शाया गया था।[8]
निर्देश सेट
एमएसी-8 इंस्ट्रक्शन सेट आर्किटेक्चर (आईएसए) को तीन व्यापक सेटों, अंकगणित और लॉजिकल, नियंत्रण स्थानांतरण (शाखाओं में), और विशेष में विभाजित किया गया था।[6]
अंकगणित और लॉजिकल निर्देशों में या दो ओपेरंड होते थे, जिनमें से प्रत्येक रजिस्टर, मेमोरी स्थान की ओर संकेत करता था, या तत्काल मान (स्थिर) रखता था। निर्देश को बाइट में रखा गया था, जिसमें ऊपरी पांच बिट्स में ऑपकोड और निचले तीन में एड्रेसिंग मोड था, जो दर्शाता था कि ऑपरेंड (यदि कोई हो) कहां रखे गए थे। इस प्रकार से उदाहरण के लिए, अतिरिक्त निर्देश यह संकेत दे सकता है कि वह मोड को 0 (रजिस्टर-टू-रजिस्टर) पर सेट करके रुपये (सोर्स) में मान को आरडी (अनुक्रमित) में जोड़ना चाहता था। यदि मान आर1 और आर2 में थे, तो डी/एस बाइट 00010010 पर सेट किया जाएगा।[9] वैकल्पिक रूप से, वही जोड़ना मोड 6 का उपयोग कर सकता है, जो स्रोत b रजिस्टर में मान को मेमोरी स्थान में मान के साथ दूसरे रजिस्टर (अप्रत्यक्ष एड्रेसिंग) में मान से ऑफसेट कर देता है। इस स्तिथि में, डी/एस रजिस्टर में 16-बिट स्रोत रजिस्टर, बीएस सम्मिलित है, और गंतव्य गंतव्य रजिस्टर, आरडी रखता है।[6][8]
आठ मोड के मुख्य सेट में रजिस्टर/रजिस्टर, मेमोरी में बेस एड्रेस पर या उससे रजिस्टर करना (अप्रत्यक्ष), बेस एड्रेस पर या उससे रजिस्टर करना और साथ ही ऑफसेट (अनुक्रमित) और ऑटो-इंक्रीमेंटिंग सम्मिलित है, जिसने चयनित b रजिस्टर के मान एक में जोड़ता और फिर उस स्थान पर डेटा को एक्सेस करता है। यह अंतिम मोड मेमोरी में बेस एड्रेस रखकर और फिर उसी रजिस्टर नंबर के साथ ऑपकोड को बार-बार कॉल करके मेमोरी पर लूप प्रयुक्त करने के लिए उपयोगी था, जिससे यह बिना किसी स्पष्ट निर्देश के बढ़ जाता था। यदि किसी भी निबल को मान 15 पर सेट किया गया था, तो आठ मोड का अर्थ परिवर्तित हो जाता है। इस स्तिथि में, स्रोत अब 16 रजिस्टरों में से नहीं था, किन्तु मोड के बेस पर या तो प्रोग्राम काउंटर या स्टैक काउंटर था, जबकि गंतव्य अधिकतर आर15 को संदर्भित करता था किन्तु एड्रेस एसपी से लिए गए थे। इसके पश्चात मोडों का उपयोग अधिकतर सशर्त शाखाओं के साथ किया गया था, इस प्रकार से उदाहरण के लिए, निर्देश को स्रोत में मान के बेस पर वर्तमान पीसी से आगे एन स्थानों पर आगे बढ़ने की अनुमति दी गई थी।[8] भिन्न-भिन्न निर्देश, पीयूएसएच और पीओपी और बीयूएमपी और डीईबीयूएमपी, क्रमशः स्टैक पॉइंटर या रजिस्टर पॉइंटर को बढ़ाते और घटाते हैं।[6]
नियंत्रण स्थानांतरण फ़ंक्शन लॉजिक निर्देश के समान हैं किन्तु वैकल्पिक ऑपकोड की कमी है, और ऑफसेट जैसी वस्तु को निष्पादित करने के लिए केवल रजिस्टर मान की आवश्यकता होती है क्योंकि बेस एड्रेस सामान्य रूप से प्रोग्राम काउंटर होता है। जिसमे अनकंडीशनल जंप, सबरूटीन कॉल और रिटर्न के लिए केवल ही गंतव्य की आवश्यकता होती है या किसी की भी आवश्यकता नहीं होती है। और सशर्त शाखाओं के स्तिथि में, केवल ही रजिस्टर का उपयोग करने की आवश्यकता है, क्योंकि कुछ भी वापस नहीं लिखा जा रहा है, इसलिए डी/एस बाइट के निचले निबल का उपयोग यह इंगित करने के लिए किया गया था कि 16 भिन्न-भिन्न स्थितियों में से किसका परीक्षण किया जाना चाहिए, जैसे कि क्या संकेतित स्थान पर मान शून्य है. नियमो में विशिष्ट ऋणात्मक, शून्य, कैरी और ओवरफ्लो स्थितियां सम्मिलित थीं, किन्तु इसमें यह भी सम्मिलित था कि क्या सभी मान विषम हैं या नहीं (255) या यहां तक कि क्या अन्य के मध्य व्यवधान सक्षम है।[10]
प्रोग्रामिंग
एमएसी-8 को सी में प्रोग्राम करने के लिए डिज़ाइन किया गया था, और बेल ने क्रॉस-कंपाइलिंग समर्थन और पीडीपी-11 पर यूनिक्स पर चलने वाले एम8एसआईएम सिम्युलेटर की प्रस्तुति की है।[11] पीडीपी-11 पर चलने वाला पीएलएआईडी सिस्टम, केबल कनेक्शन का उपयोग करके एमएसी-8 सिस्टम के लिए डिबगर समर्थन प्रदान करता है। उन अनुप्रयोगों के लिए जिन्हें प्रत्यक्ष असेंबली लैंग्वेज प्रोग्रामिंग की आवश्यकता होती है, सिस्टम ने बहुत ही भिन्न प्रकार की लैंग्वेज का उपयोग किया है जो इच्छापूर्वक सी की तरह दिखने के लिए लिखी गई थी।[12] इस प्रकार से सिस्टम के परिचय से उदाहरण:
#define NBYTES 100
char array[NBYTES];
sum()
{
b0 = &array;
a1 = 0;
for (a2 = 0; a2 < NBYTES; ++a2) {
a1 =+ b0;
++b0;
}
}
यह कोड 100 बाइट्स मेमोरी को अलग रखता है और इसे नाम array
निर्दिष्ट करता है. वह sum
रूटीन फिर का एड्रेस खोजेarray
मेमोरी में, परिणामी योग को रखने के लिए रजिस्टर a1 को साफ़ करता है, और फिर b0 में एड्रेस को बढ़ाते हुए प्रविष्टियों को a1 में जोड़ने वाले सरणी पर लूप करता है। संकलित होने पर, ''वेरिएबल्स'' b0, a1 और a2 को रजिस्टरों में रखा जाएगा और विभिन्न ऑपरेशनों को आईएसए ऑपकोड में अनुवादित किया जाएगा - उदाहरण के लिए, a1 = 0;
का असाइनमेंट एड्रेसिंग सेट के साथ MOVE
निर्देश में परिवर्तन दिया जाएगा जिससे गंतव्य आर रजिस्टर हो और स्रोत स्थिर मान शून्य हो। वह को इंडेक्स वेरिएबल a2
के स्रोत के रूप में अन्य रजिस्टरों का उपयोग करके for
को मैक्रो के रूप में प्रयुक्त किया जाएगा।[12] लैंग्वेज में संरचनाएं, परिवर्तनीय परिभाषाएं, फ़ंक्शन और c की अधिकांश अन्य विशेषताएं सम्मिलित हैं।[13][11]
चूँकि सिस्टम नया था, और माइक्रोप्रोसेसरों की पूरी अवधारणा एटी&टी के लिए नवीन थी, कंपनी ने एमएसी-ट्यूटर सिंगल-बोर्ड कंप्यूटर भी प्रस्तुत किया जिसका उपयोग परीक्षण और डेवलपमेंट के लिए किया जा सकता था। और यूनिक्स टूल का उपयोग प्रोग्राम बनाने, उसे मैक-ट्यूटर पर डाउनलोड करने, चलाने और डीबग करने और यूनिक्स की ओर स्थिति वापस भेजने के लिए किया जा सकता है।[14] मूल मैक-ट्यूटर में 2 kB की रैंडम एक्सेस मेमोरी, बेसिक हार्डवेयर नियंत्रण कार्यों के साथ 2 kB की आरओएम, 1 kB पीआरओएम चिप्स के लिए तीन सॉकेट, 28-बटन कैलकुलेटर-प्रकार का कीबोर्ड (4 बाय 7), और सम्मिलित थे। डिस्प्ले जिसमें आठ 7-सेगमेंट एलईडी हैं। ऑनबोर्ड इंटरफेस में कैसेट टेप, कंप्यूटर टर्मिनल के लिए दो आरएस-232 और एक 32-पिन बस विस्तारक सम्मिलित थे जिनका उपयोग अधिक मेमोरी या मेमोरी-मैप किए गए डिवाइस को जोड़ने के लिए किया जा सकता था।[15]
कार्यान्वयन
डब्लूई212 में 7,000 से अधिक ट्रांजिस्टर का उपयोग किया गया था और इसे 5 माइक्रोन सीएमओएस प्रक्रिया पर कार्यान्वित किया गया था, जिसके परिणामस्वरूप 220x230 मिल्स का डाई प्राप्त हुआ।[16] यह सामान्यतः 12 वी और 2 मेगाहर्ट्ज पर चलता था, जिसके परिणामस्वरूप 200 मिलीवाट ड्रॉ होता था,[16] जो 6502 या जेड80 जैसे समकालीन प्रोसेसर से अधिक कम था। ट्रांजिस्टर-ट्रांजिस्टर लॉजिक (टीटीएल) भागों को पॉवर देने के लिए 5 वी पर दूसरी आपूर्ति की भी आवश्यकता थी जो शेष कंप्यूटर हार्डवेयर के साथ इंटरफेस करती थी।[16]
इस प्रकार से सीएमओएस को उपस्तिथ एनएमओएस लॉजिक डिजाइनों की तुलना में इसके कम पॉवर उपयोग के साथ-साथ ही चिप पर एनएमओएस और पीएमओएस ट्रांजिस्टर दोनों रखने की क्षमता के लिए चुना गया था, जिससे डिजाइनरों को लगा कि यह अधिक लचीलापन प्रदान करता है।[9] एएलयू सीएमओएस में प्रयुक्त करने के लिए अधिक सम्मिश्र था, जिसके लिए उनके द्वारा उपयोग किए जाने वाले एनएमओएस कार्यान्वयन के दोगुने क्षेत्र की आवश्यकता होती है। चूँकि इसके परिणामस्वरूप पॉवर अपव्यय में वृद्धि हुई, इस प्रकार से उदाहरण के लिए, मेमोरी एक्सेस के समय, सिस्टम ने उस अवधि के समय एएलयू को पॉवर हटा दी, जब इसका उपयोग नहीं किया जा रहा था। चूँकि एएलयू लगभग 20% समय ही सक्रिय था, यह महत्वपूर्ण पॉवर सेविंग का प्रतिनिधित्व करता था।[16]
इसे 16-पिन एड्रेस बस और 8-पिन डेटा बस के साथ 40-पिन डीआईपी पैकेज में पैक किया गया था, जिसका अर्थ है कि कोई भी मुख्य पिन मल्टीप्लेक्स नहीं था और डेटा को ही चक्र में पढ़ा जा सकता था। इनपुट/आउटपुट मेमोरी-मैप्ड I/O और पोर्ट-मैप्ड I/O था और इंटेल 8080 की तरह भिन्न-भिन्न पिन का उपयोग नहीं करता था। दो पिन डायरेक्ट मेमोरी एक्सेस (डीएमए) प्रदान करते थे; डीएमए की इच्छा रखने वाला डिवाइस डीएमएआरईक्यू को नीचे खींचेगा, और जब प्रोसेसर बस को छोड़ने के लिए तैयार होगा तो यह डीएमएकेके को नीचे खींचकर इसका संकेत देगा। डिवाइस तब तक मेमोरी तक पहुंच सकता है जब तक उसे आवश्यकता हो और डीएमए आरईक्यू प्रवाहित करके संकेत दिया कि यह समाप्त हो गया है। अन्य तीन पिन, एस1 से एस3, सीपीयू की आंतरिक स्थिति और किसी भी इरर की स्थिति का संकेत देते हैं। शेष पिन पॉवर, इंटरप्ट कंट्रोल और क्लॉक पिन का विशिष्ट मिश्रण थे।[17]
डब्लूई212 के कम से कम तीन वर्जन a से c तक उपस्तिथ हैं। और पैकेजिंग के अतिरिक्त, इनके मध्य के अंतर का किसी भी उपलब्ध संदर्भ में वर्णन नहीं किया गया है।
उपयोग एवं प्रभाव
इस प्रकार से मैक-ट्यूटर सिस्टम के अतिरिक्त, डब्लूई212 का उल्लेख अनेक एटी एंड टी उत्पादों में किया गया है, जिनमें अन्य के अतिरिक्त, 4ईएसएस स्विच[18] और एसएलसी-96 सब्सक्राइबर लूप कैरियर भी सम्मिलित है।[19]
चूंकि बेलमैक-8 का उपयोग अपेक्षाकृत कम था, सी और इसी तरह की लैंग्वेजो को चलाने के लिए विशेष रूप से प्रोसेसर को डिजाइन करने की मूल अवधारणा को अगले दशक में बेल द्वारा निरंतर सर्च किया गया था। निम्नलिखित बेलमैक-80 मूलतः सी मशीन का 32-बिट कंप्यूटिंग कार्यान्वयन था। एमिटर-युग्मित लॉजिक में उच्च-प्रदर्शन डिज़ाइन का प्रयास छोड़ दिया गया था और 1986 में सीआरआईएसपी के रूप में सरल कार्यान्वयन तैयार किया गया था, जिससे प्रदर्शन की लगभग 7.7 वीएएक्स यूनिट प्राप्त हुई।[20]
एटी एंड टी ने मोबाइल कंप्यूटिंग के लिए कम-पॉवर अनुप्रयोगों की ओर पुनः ध्यान केंद्रित करते हुए सी मशीन प्रयासों के लक्ष्य को परिवर्तित करने का निर्णय लिया था। इससे एटी एंड टी हॉबिट डिज़ाइन का निर्माण किया गया था, प्रथम वर्जन, एटी एंड टी 92010, 1992 में प्रवाहित किया गया था।[21] और बाज़ार में सफलता की कमी के कारण एटी&टी को 1993 में हॉबिट को बाज़ार से वापस लेना पड़ा था [22] और इसके साथ ही सी मशीन का डेवलपमेंट समाप्त हो गया था।
संदर्भ
उद्धरण
- ↑ Winfield 1978, p. 494.
- ↑ 2.0 2.1 2.2 Ditzel & McLellan 1982, p. 48.
- ↑ Winfield 1978, p. 495.
- ↑ 4.0 4.1 Winfield 1978, p. 496.
- ↑ Osborne & Kane 1981, p. 10.1, 10.21.
- ↑ 6.0 6.1 6.2 6.3 Winfield 1978, p. 499.
- ↑ TUTOR 1979, p. 3.1.
- ↑ 8.0 8.1 8.2 TUTOR 1979, p. 3.3.
- ↑ 9.0 9.1 Winfield 1978, p. 500.
- ↑ TUTOR 1979, p. 3.4.
- ↑ 11.0 11.1 Winfield 1978, p. 502.
- ↑ 12.0 12.1 Rovegno 1978, p. 2255.
- ↑ Rovegno 1978, p. 2256.
- ↑ Winfield 1978, p. 503.
- ↑ TUTOR 1979, p. 1.1.
- ↑ 16.0 16.1 16.2 16.3 Winfield 1978, p. 501.
- ↑ Winfield 1978, p. 498.
- ↑ Hoppner et al. 1981, p. 1134.
- ↑ Canniff 1981, p. 124.
- ↑ Ditzel et al. 1987, p. 309.
- ↑ Ryan, Bob (February 1993). "संचार व्यक्तिगत हो जाता है". Byte. pp. 169–170, 172, 174, 176. Retrieved 27 March 2023.
- ↑ Gassée, Jean-Louis (2019-01-31). "टेक में 50 वर्ष भाग 15. बनें: संकल्पना से मृत्यु के निकट तक". Medium (in English). Retrieved 2020-08-31.
ग्रन्थसूची
- Winfield, Herbert (July 1978). "MAC-8: A Microprocessor for Telecommunication Applications". The Western Electric Engineer. 21.
- Ditzel, David; McLellan, Hubert (April 1982). "Register allocation for free: The C machine stack cache". ACM SIGPLAN Notices. 17 (4): 48–56. doi:10.1145/960120.801825.
- Ditzel, David; McLellan, Hubert; Berenbaum, Alan D. (1987). "The hardware architecture of the CRISP microprocessor". Proceedings of the 14th annual international symposium on Computer architecture - ISCA '87. pp. 309–319. doi:10.1145/30350.30385. ISBN 0818607769. S2CID 14954824. Retrieved 28 March 2023.
- Rovegno, H.D. (July–August 1978). "Unix Time-Sharing System: A Support Environment for MAC-8 Systems". Bell System Technical Journal. 57 (6): 2251–2263. doi:10.1002/j.1538-7305.1978.tb02152.x. S2CID 33739380.
- Hoppner, K.M.; Mann, H.; Panyko, S.F.; Van Zweden, J. (July–August 1981). "4ESS: Digital Interface" (PDF). Bell System Technical Journal. 60 (6): 1131–1166. doi:10.1002/j.1538-7305.1981.tb03401.x. S2CID 34441812.
- Canniff, R.J. (February 1981). "A Digital Concentrator for the SCL-96 System". Bell System Technical Journal. 60 (2): 123–158. doi:10.1002/j.1538-7305.1981.tb00235.x.
- MAC-TUTOR Reference Manual (PDF). AT&T. July 1979.
- Osborne, Adam; Kane, Gerry (1981). Osborne 4 & 8-Bit Microprocessor Handbook. Osborne/McGraw-Hill. ISBN 0-931988-42-X.