बेलमैक-8: Difference between revisions

From Vigyanwiki
No edit summary
m (11 revisions imported from alpha:बेलमैक-8)
 
(5 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{Short description|8-bit microprocessor}}
{{Short description|8-bit microprocessor}}
{{Infobox CPU
एमएसी-8, जिसे आज '''बेलमैक-8''' के नाम से जाना जाता है, एक [[8-बिट कंप्यूटिंग]] 8-बिट [[माइक्रोप्रोसेसर]] है जिसे [[बेल लैब्स]] द्वारा डिज़ाइन किया गया है। [[वेस्टर्न इलेक्ट्रिक]] में 1977 में डब्लूई212 के रूप में [[CMOS|सीएमओएस]] फॉर्म में आउटपुट प्रारंभ किया गया था। और एमएसी-8 का उपयोग केवल [[4ESS|4ईएसएस]] जैसे एटी&टी उत्पादों में किया जाता था। इस प्रकार से कोई व्यावसायिक [[ डेटा शीट |डेटा शीट]] प्रकाशित नहीं की गई थी, इसलिए इसके परिणामस्वरूप अधिक कम डेटा है। अतः सार्वजनिक में अधिक प्रसिद्ध उपयोग मैक-ट्यूटर [[ कंप्यूटर प्रशिक्षक |कंप्यूटर ट्रेनर]] है, जो की 1979 में प्रवाहित किया गया था।  
|name        = बेलमैक-8
|image        =
|caption      =
|produced-start={{प्रारंभ तिथि और आयु|1977}}
|produced-end =
|slowest      = 2 |slow-unit=MHz
|fastest      = 2 |fast-unit=MHz
|manuf1=[[वेस्टर्न इलेक्ट्रिक]]
|arch        = मैक-8
|transistors  = over 7,000
|numinstructions =
|data-width  = [[8-बिट कंप्यूटिंग|8 बिट्स]]
|address-width=[[16-बिट कंप्यूटिंग|16 बिट्स]]
|pack1=40-pin [[Dual in-line package|DIP]]
|predecessor  =
|successor    = [[बेलमैक-80]]
}}
एमएसी-8, जिसे आज '''बेलमैक-8''' के नाम से जाना जाता है, एक [[8-बिट कंप्यूटिंग]] 8-बिट [[माइक्रोप्रोसेसर]] है जिसे [[बेल लैब्स]] द्वारा डिज़ाइन किया गया है। [[वेस्टर्न इलेक्ट्रिक]] में 1977 में डब्लूई212 के रूप में [[CMOS|सीएमओएस]] फॉर्म में आउटपुट प्रारंभ किया गया था। और एमएसी-8 का उपयोग केवल [[4ESS|4ईएसएस]] जैसे एटी&टी उत्पादों में किया जाता था। इस प्रकार से कोई व्यावसायिक [[ डेटा शीट |डेटा शीट]] प्रकाशित नहीं की गई थी, इसलिए इसके परिणामस्वरूप अधिक कम डेटा है। अतः सार्वजनिक में अधिक प्रसिद्ध उपयोग मैक-ट्यूटर [[ कंप्यूटर प्रशिक्षक |कंप्यूटर प्रशिक्षक]] है, जो की 1979 में प्रवाहित किया गया था।


इस प्रकार से एमएसी-8 विशेष रूप से, बेल की अपनी सी प्रोग्रामिंग लैंग्वेज को उच्च-स्तरीय प्रोग्रामिंग लैंग्वेजो को चलाने के लिए डिज़ाइन किया गया था। और सिस्टम की असामान्य विशेषता यह है कि इसकी [[असेंबलर भाषा|असेंबलर लैंग्वेज]] इच्छापूर्वक सी कोड से मिलती-जुलती लिखी गई थी, जिसमें वेरिएबल्स [[पाश के लिए|लूप]] जैसे उच्च-स्तरीय निर्माणों के लिए समर्थन सम्मिलित था। इसके विपरीत, उस युग के अधिकांश असेंबलरों ने प्रोसेसर के निम्न-स्तरीय [[opcode|ऑपकोड]] पर अधिक सीधे मैप किया और उच्च-स्तरीय सुविधाओं का अभाव था।
इस प्रकार से एमएसी-8 विशेष रूप से, बेल की अपनी सी प्रोग्रामिंग लैंग्वेज को उच्च-स्तरीय प्रोग्रामिंग लैंग्वेजो को चलाने के लिए डिज़ाइन किया गया था। और सिस्टम की असामान्य विशेषता यह है कि इसकी [[असेंबलर भाषा|असेंबलर लैंग्वेज]] इच्छापूर्वक सी कोड से मिलती-जुलती लिखी गई थी, जिसमें वेरिएबल्स [[पाश के लिए|लूप]] जैसे उच्च-स्तरीय निर्माणों के लिए समर्थन सम्मिलित था। इसके विपरीत, उस युग के अधिकांश असेंबलरों ने प्रोसेसर के निम्न-स्तरीय [[opcode|ऑपकोड]] पर अधिक सीधे मैप किया और उच्च-स्तरीय सुविधाओं का अभाव था।  


अतः एमएसी-8 के पश्चात [[BELLMAC-80|बेलमैक-80]] आया, जो की आंतरिक रूप से एमएसी-8 से अधिक भिन्न 32-बिट सिस्टम था, किन्तु सी को चलाने के लिए डिज़ाइन किए जाने की अवधारणा को बनाए रखा था। इसके पश्चात प्रयोगात्मक सीआरआईएसपी डिज़ाइन किया गया, और अंत में 1992 एटी एंड टी हॉबिट, जिसका सीमित व्यावसायिक उपयोग किया गया था।
अतः एमएसी-8 के पश्चात [[BELLMAC-80|बेलमैक-80]] आया, जो की आंतरिक रूप से एमएसी-8 से अधिक भिन्न 32-बिट सिस्टम था, किन्तु सी को चलाने के लिए डिज़ाइन किए जाने की अवधारणा को बनाए रखा था। इसके पश्चात प्रयोगात्मक सीआरआईएसपी डिज़ाइन किया गया, और अंत में 1992 एटी एंड टी हॉबिट, जिसका सीमित व्यावसायिक उपयोग किया गया था।  


==विवरण==
==विवरण ==


===डिज़ाइन अवधारणाएँ===
===डिज़ाइन अवधारणाएँ ===
इस प्रकार से एमएसी-8, एटी&टी के चल रहे सी मशीन प्रोजेक्ट द्वारा निर्मित किया जाने वाला प्रथम डिज़ाइन है जो की 1975 में प्रारंभ हुआ था। इसका उद्देश्य ऐसे प्रोसेसर डिज़ाइन तैयार करना था जो सीधे [[उच्च स्तरीय भाषा|उच्च स्तरीय लैंग्वेजो]], विशेष रूप से बेल की अपनी सी प्रोग्रामिंग लैंग्वेज को चला सकते है।{{sfn|Winfield|1978|p=494}}{{sfn|Ditzel|McLellan|1982|p=48}}
इस प्रकार से एमएसी-8, एटी&टी के चल रहे सी मशीन प्रोजेक्ट द्वारा निर्मित किया जाने वाला प्रथम डिज़ाइन है जो की 1975 में प्रारंभ हुआ था। इसका उद्देश्य ऐसे प्रोसेसर डिज़ाइन तैयार करना था जो सीधे [[उच्च स्तरीय भाषा|उच्च स्तरीय लैंग्वेजो]], विशेष रूप से बेल की अपनी सी प्रोग्रामिंग लैंग्वेज को चला सकते है।{{sfn|Winfield|1978|p=494}}{{sfn|Ditzel|McLellan|1982|p=48}}


उन प्रोग्रामों में उचित प्रदर्शन प्रदान करने के लिए जिनमें अनेक [[फ़ंक्शन कॉल]] का प्रभुत्व है, उच्च संख्या में [[प्रोसेसर रजिस्टर]] होना महत्वपूर्ण है। ये छोटी मात्रा में हाई-स्पीड मेमोरी हैं जिन्हें बिना किसी समय दंड के एक्सेस किया जा सकता है, मुख्य मेमोरी के विपरीत जिसमें सामान्यतः कुछ देरी होती है। और रजिस्टरों का उपयोग करने से डेटा को फ़ंक्शन के अंदर और बाहर अधिक तीव्रता से पारित किया जा सकता है। किंतु आवश्यक ट्रांजिस्टर की संख्या और बाकी चिप से उनके कनेक्शन के स्तिथि में रजिस्टर अधिक बहुमान हैं। इस प्रकार से बेल के लक्ष्यों और उपलब्ध प्रक्रिया प्रौद्योगिकी को देखते हुए, ऑन-चिप रजिस्टरों की संख्या उनकी आवश्यकताओं के लिए अधिक कम होती है।{{sfn|Winfield|1978|p=495}}{{sfn|Ditzel|McLellan|1982|p=48}}
उन प्रोग्रामों में उचित प्रदर्शन प्रदान करने के लिए जिनमें अनेक [[फ़ंक्शन कॉल]] का प्रभुत्व है, उच्च संख्या में [[प्रोसेसर रजिस्टर]] होना महत्वपूर्ण है। ये छोटी मात्रा में हाई-स्पीड मेमोरी हैं जिन्हें बिना किसी समय दंड के एक्सेस किया जा सकता है, मुख्य मेमोरी के विपरीत जिसमें सामान्यतः कुछ देरी होती है। और रजिस्टरों का उपयोग करने से डेटा को फ़ंक्शन के अंदर और बाहर अधिक तीव्रता से पारित किया जा सकता है। किंतु आवश्यक ट्रांजिस्टर की संख्या और शेष चिप से उनके कनेक्शन के स्तिथि में रजिस्टर अधिक बहुमान हैं। इस प्रकार से बेल के लक्ष्यों और उपलब्ध प्रक्रिया प्रौद्योगिकी को देखते हुए, ऑन-चिप रजिस्टरों की संख्या उनकी आवश्यकताओं के लिए अधिक कम होती है।{{sfn|Winfield|1978|p=495}}{{sfn|Ditzel|McLellan|1982|p=48}}  


इसके अतिरिक्त, सी मशीन अवधारणा अपने रजिस्टरों को मुख्य मेमोरी में रखती है।{{sfn|Ditzel|McLellan|1982|p=48}} और 1960 के दशक के उत्तरार्ध में मिनीकंप्यूटर क्षेत्र में यह असामान्य नहीं था, जहां सेंट्रल प्रोसेसिंग यूनिट (सीपीयू) की तुलना में [[कोर मेमोरी]] अपेक्षाकृत तीव्र थी, जिसका अर्थ है कि डेटा तक पहुंचने में केवल एक-चक्र की देरी थी। अनेक रजिस्टरों का महत्व धीमी पहुंच की तुलना में किसी भी नकारात्मक भाग की भरपाई करता है। चूंकि वे माइक्रोप्रोसेसर जिन्हें टेक्सास इंस्ट्रूमेंट्स टीएमएस9900 जैसे पुराने [[मिनी कंप्यूटर]] की तरह कार्य करने के लिए डिज़ाइन किया गया था, प्रायः इस अवधारणा का उपयोग करते थे। किन्तु मैक-8 ने भी इस पैटर्न का पालन किया, जिसमे रजिस्टरों को दर्शाने के लिए सोलह मेमोरी स्थानों के ब्लॉक का उपयोग किया था, और रजिस्टर पॉइंटर, या आरपी के साथ मेमोरी में ब्लॉक की प्रारंभिक का चयन किया था। इसका अर्थ यह था कि [[ संकलक |कंपाइलर]] मेमोरी में मान लिखकर, आरपी को उनकी ओर इंगित करने के लिए ले जाकर, और फिर फ़ंक्शन पर जाकर डेटा को फ़ंक्शन में पास कर सकता है। किन्तु जब फ़ंक्शन समाप्त हो गया, तो कंपाइलर ने मशीन को उसकी पिछली स्थिति में वापस लाने के लिए आरपी को उसके पहले मान में परिवर्तन कर दिया है।{{sfn|Winfield|1978|p=496}} इस अवधारणा को [[रजिस्टर विंडो]] के रूप में जाना जाता है। [[एमओएस 6502]] जैसे निश्चित संख्या में हार्डवेयर रजिस्टरों वाले उन डिज़ाइनों में, इस प्रकार के फ़ंक्शन कॉल के लिए सामान्यतः रजिस्टरों में डेटा को मुख्य मेमोरी या [[कॉल स्टैक]] में लिखे जाने की आवश्यकता होती है, दोनों को मेमोरी तक पहुंचने के लिए अनेक चक्रों की आवश्यकता होती है।{{sfn|Osborne|Kane|1981|p=10.1, 10.21}}
इसके अतिरिक्त, सी मशीन अवधारणा अपने रजिस्टरों को मुख्य मेमोरी में रखती है।{{sfn|Ditzel|McLellan|1982|p=48}} और 1960 के दशक के उत्तरार्ध में मिनीकंप्यूटर क्षेत्र में यह असामान्य नहीं था, जहां सेंट्रल प्रोसेसिंग यूनिट (सीपीयू) की तुलना में [[कोर मेमोरी]] अपेक्षाकृत तीव्र थी, जिसका अर्थ है कि डेटा तक पहुंचने में केवल एक-चक्र की देरी थी। अनेक रजिस्टरों का महत्व धीमी पहुंच की तुलना में किसी भी ऋणात्मक भाग की भरपाई करता है। चूंकि वे माइक्रोप्रोसेसर जिन्हें टेक्सास इंस्ट्रूमेंट्स टीएमएस9900 जैसे पुराने [[मिनी कंप्यूटर]] की तरह कार्य करने के लिए डिज़ाइन किया गया था, प्रायः इस अवधारणा का उपयोग करते थे। किन्तु मैक-8 ने भी इस पैटर्न का पालन किया, जिसमे रजिस्टरों को दर्शाने के लिए सोलह मेमोरी स्थानों के ब्लॉक का उपयोग किया था, और रजिस्टर पॉइंटर, या आरपी के साथ मेमोरी में ब्लॉक की प्रारंभिक का चयन किया था। इसका अर्थ यह था कि [[ संकलक |कंपाइलर]] मेमोरी में मान लिखकर, आरपी को उनकी ओर निरुपित करने के लिए ले जाकर, और फिर फ़ंक्शन पर जाकर डेटा को फ़ंक्शन में पास कर सकता है। किन्तु जब फ़ंक्शन समाप्त हो गया, तो कंपाइलर ने मशीन को उसकी पिछली स्थिति में वापस लाने के लिए आरपी को उसके पहले मान में परिवर्तन कर दिया है।{{sfn|Winfield|1978|p=496}} इस अवधारणा को [[रजिस्टर विंडो]] के रूप में जाना जाता है। [[एमओएस 6502]] जैसे निश्चित संख्या में हार्डवेयर रजिस्टरों वाले उन डिज़ाइनों में, इस प्रकार के फ़ंक्शन कॉल के लिए सामान्यतः रजिस्टरों में डेटा को मुख्य मेमोरी या [[कॉल स्टैक]] में लिखे जाने की आवश्यकता होती है, दोनों को मेमोरी तक पहुंचने के लिए अनेक चक्रों की आवश्यकता होती है।{{sfn|Osborne|Kane|1981|p=10.1, 10.21}}  


इस प्रकार से सिस्टम में चार सार्वजनिक हार्डवेयर रजिस्टर भी सम्मिलित थे। ये 16-बिट प्रोग्राम काउंटर (पीसी), स्टैक पॉइंटर (एसपी), रजिस्टर पॉइंटर (आरपी) और कंडीशन रजिस्टर (सीआर) थे, जिन्हें सामान्यतः अन्य प्लेटफार्मों पर [[ स्थिति रजिस्टर |स्टेटस रजिस्टर]] के रूप में जाना जाता है। इसमें दो आंतरिक 8-बिट रजिस्टर भी सम्मिलित हैं जिनका उपयोग केवल वर्तमान निर्देश के प्रोसेसिंग के समय किया जाता है, निर्देश रजिस्टर (आईआर) जिसमें अंतिम पढ़ा गया निर्देश ऑपकोड होता है, और डी/एस रजिस्टर जो गंतव्य और स्रोत रजिस्टर संख्याओं, 0 से दो [[ कुतरना |निबल्स]] में 15 को स्टोर्ड करता है। इसके अतिरिक्त, एक 16-बिट एड्रेस वैल्यू और उसके 8-बिट डेटा को प्रोसेसिंग के समय लॉक कर दिया गया था।{{sfn|Winfield|1978|p=496}}
इस प्रकार से सिस्टम में चार सार्वजनिक हार्डवेयर रजिस्टर भी सम्मिलित थे। ये 16-बिट प्रोग्राम काउंटर (पीसी), स्टैक पॉइंटर (एसपी), रजिस्टर पॉइंटर (आरपी) और कंडीशन रजिस्टर (सीआर) थे, जिन्हें सामान्यतः अन्य प्लेटफार्मों पर [[ स्थिति रजिस्टर |स्टेटस रजिस्टर]] के रूप में जाना जाता है। इसमें दो आंतरिक 8-बिट रजिस्टर भी सम्मिलित हैं जिनका उपयोग केवल वर्तमान निर्देश के प्रोसेसिंग के समय किया जाता है, निर्देश रजिस्टर (आईआर) जिसमें अंतिम पढ़ा गया निर्देश ऑपकोड होता है, और डी/एस रजिस्टर जो गंतव्य और स्रोत रजिस्टर संख्याओं, 0 से दो [[ कुतरना |निबल्स]] में 15 को स्टोर्ड करता है। इसके अतिरिक्त, एक 16-बिट एड्रेस वैल्यू और उसके 8-बिट डेटा को प्रोसेसिंग के समय लॉक कर दिया गया था।{{sfn|Winfield|1978|p=496}}  


अतः सिस्टम में पता अनुवाद के लिए समर्पित अलग, सरलीकृत, गणित इकाई, पता अंकगणितीय इकाई (एएयू) सम्मिलित थी। यह बस में या आंतरिक रजिस्टरों से एड्रेस को पढ़ या लिख ​​सकता है, या मुख्य [[अंकगणितीय तर्क इकाई|अंकगणितीय लॉजिक यूनिट]] (एएलयू) से स्वतंत्र, ऑफसेट और इंडेक्सिंग कर सकता है। और रजिस्टरों को मेमोरी में लोड करने का कारण एएयू के लिए स्थान खाली करना था। इसने इसे एएलयू का उपयोग न करते हुए विभिन्न प्रकार के [[संबोधन मोड|एड्रेसिंग मोड]] को प्रस्तुत करने की अनुमति दी और इस प्रकार अधिक सम्मिश्र मोड के लिए चक्र विलंब से पीड़ित होना हैं।{{sfn|Winfield|1978|p=499}} क्योंकि एड्रेस 16-बिट थे, और प्रायः स्टोरेज के लिए रजिस्टरों का उपयोग किया जाता था, निर्देशों को संबोधित करते हुए सदैव रजिस्टरों को जोड़े में पढ़ा और लिखा जाता था। इन स्तिथियों में, उन्हें <nowiki>''</nowiki>बेस रजिस्टर<nowiki>''</nowiki> या <nowiki>''</nowiki>बी रजिस्टर<nowiki>''</nowiki> के रूप में संदर्भित किया गया था, और केवल 8-बिट मान का उपयोग करने वाले निर्देशों को "ए रजिस्टर" के रूप में जाना जाता था। चूंकि रजिस्टर सदैव मेमोरी में 16-बिट होते थे, रजिस्टर केवल जोड़ी के कम बाइट का उपयोग करते थे।{{sfn|TUTOR|1979|p=3.1}} कुछ सीमा तक भ्रमित करने वाला तथ्य यह है कि जब डाक्यूमेंटेशन में इसका उल्लेख किया गया, तो रजिस्टरों को आर दर्शाया गया था, जबकि बी रजिस्टरों को बी दर्शाया गया था।{{sfn|TUTOR|1979|p=3.3}}
अतः सिस्टम में एड्रेस अनुवाद के लिए समर्पित अलग, सरलीकृत, गणित इकाई, एड्रेस अंकगणितीय इकाई (एएयू) सम्मिलित थी। यह बस में या आंतरिक रजिस्टरों से एड्रेस को पढ़ या लिख ​​सकता है, या मुख्य [[अंकगणितीय तर्क इकाई|अंकगणितीय लॉजिक यूनिट]] (एएलयू) से स्वतंत्र, ऑफसेट और इंडेक्सिंग कर सकता है। और रजिस्टरों को मेमोरी में लोड करने का कारण एएयू के लिए स्थान खाली करना था। इसने इसे एएलयू का उपयोग न करते हुए विभिन्न प्रकार के [[संबोधन मोड|एड्रेसिंग मोड]] को प्रस्तुत करने की अनुमति दी और इस प्रकार अधिक सम्मिश्र मोड के लिए चक्र विलंब से पीड़ित होना हैं।{{sfn|Winfield|1978|p=499}} क्योंकि एड्रेस 16-बिट थे, और प्रायः स्टोरेज के लिए रजिस्टरों का उपयोग किया जाता था, निर्देशों को संबोधित करते हुए सदैव रजिस्टरों को जोड़े में पढ़ा और लिखा जाता था। इन स्तिथियों में, उन्हें <nowiki>''</nowiki>बेस रजिस्टर<nowiki>''</nowiki> या <nowiki>''</nowiki>बी रजिस्टर<nowiki>''</nowiki> के रूप में संदर्भित किया गया था, और केवल 8-बिट मान का उपयोग करने वाले निर्देशों को "ए रजिस्टर" के रूप में जाना जाता था। चूंकि रजिस्टर सदैव मेमोरी में 16-बिट होते थे, रजिस्टर केवल जोड़ी के कम बाइट का उपयोग करते थे।{{sfn|TUTOR|1979|p=3.1}} कुछ सीमा तक अस्पष्ट करने वाला तथ्य यह है कि जब डाक्यूमेंटेशन में इसका उल्लेख किया गया, तो a रजिस्टरों को आर दर्शाया गया था, जबकि b रजिस्टरों को b दर्शाया गया था।{{sfn|TUTOR|1979|p=3.3}}  


===निर्देश सेट===
===निर्देश सेट ===
एमएसी-8 [[ अनुदेश सेट वास्तुकला |इंस्ट्रक्शन सेट आर्किटेक्चर]] (आईएसए) को तीन व्यापक सेटों, अंकगणित और लॉजिकल, नियंत्रण स्थानांतरण (शाखाओं में), और विशेष में विभाजित किया गया था।{{sfn|Winfield|1978|p=499}}
एमएसी-8 [[ अनुदेश सेट वास्तुकला |इंस्ट्रक्शन सेट आर्किटेक्चर]] (आईएसए) को तीन व्यापक सेटों, अंकगणित और लॉजिकल, नियंत्रण स्थानांतरण (शाखाओं में), और विशेष में विभाजित किया गया था।{{sfn|Winfield|1978|p=499}}  


अंकगणित और लॉजिकल निर्देशों में या दो [[ ओपेरंड |ओपेरंड]] होते थे, जिनमें से प्रत्येक रजिस्टर, मेमोरी स्थान की ओर संकेत करता था, या तत्काल मान (स्थिर) रखता था। निर्देश को बाइट में रखा गया था, जिसमें ऊपरी पांच बिट्स में ऑपकोड और निचले तीन में एड्रेसिंग मोड था, जो दर्शाता था कि ऑपरेंड (यदि कोई हो) कहां रखे गए थे। इस प्रकार से उदाहरण के लिए, अतिरिक्त निर्देश यह संकेत दे सकता है कि वह मोड को 0 (रजिस्टर-टू-रजिस्टर) पर सेट करके रुपये ('''स्रोत''') में मान को आरडी ('''गंतव्य''') में जोड़ना चाहता था। यदि मान आर1 और आर2 में थे, तो डी/एस बाइट 00010010 पर सेट किया जाएगा।{{sfn|Winfield|1978|p=500}} वैकल्पिक रूप से, वही जोड़ना मोड 6 का उपयोग कर सकता है, जो स्रोत बी रजिस्टर में मान को मेमोरी स्थान में मान के साथ दूसरे रजिस्टर (अप्रत्यक्ष एड्रेसिंग) में मान से ऑफसेट कर देता है। इस स्तिथि में, डी/एस रजिस्टर में 16-बिट स्रोत रजिस्टर, बीएस सम्मिलित है, और गंतव्य गंतव्य रजिस्टर, आरडी रखता है।{{sfn|Winfield|1978|p=499}}{{sfn|TUTOR|1979|p=3.3}}
अंकगणित और लॉजिकल निर्देशों में या दो [[ ओपेरंड |ओपेरंड]] होते थे, जिनमें से प्रत्येक रजिस्टर, मेमोरी स्थान की ओर संकेत करता था, या तत्काल मान (स्थिर) रखता था। निर्देश को बाइट में रखा गया था, जिसमें ऊपरी पांच बिट्स में ऑपकोड और निचले तीन में एड्रेसिंग मोड था, जो दर्शाता था कि ऑपरेंड (यदि कोई हो) कहां रखे गए थे। इस प्रकार से उदाहरण के लिए, अतिरिक्त निर्देश यह संकेत दे सकता है कि वह मोड को 0 (रजिस्टर-टू-रजिस्टर) पर सेट करके रुपये (सोर्स) में मान को आरडी (अनुक्रमित) में जोड़ना चाहता था। यदि मान आर1 और आर2 में थे, तो डी/एस बाइट 00010010 पर सेट किया जाएगा।{{sfn|Winfield|1978|p=500}} वैकल्पिक रूप से, वही जोड़ना मोड 6 का उपयोग कर सकता है, जो स्रोत b रजिस्टर में मान को मेमोरी स्थान में मान के साथ दूसरे रजिस्टर (अप्रत्यक्ष एड्रेसिंग) में मान से ऑफसेट कर देता है। इस स्तिथि में, डी/एस रजिस्टर में 16-बिट स्रोत रजिस्टर, बीएस सम्मिलित है, और गंतव्य गंतव्य रजिस्टर, आरडी रखता है।{{sfn|Winfield|1978|p=499}}{{sfn|TUTOR|1979|p=3.3}}  


आठ मोड के मुख्य सेट में रजिस्टर/रजिस्टर, मेमोरी में बेस एड्रेस पर या उससे रजिस्टर करना (अप्रत्यक्ष), बेस एड्रेस पर या उससे रजिस्टर करना और साथ ही ऑफसेट (अनुक्रमित) और ऑटो-इंक्रीमेंटिंग सम्मिलित है, जिसने चयनित बी रजिस्टर के मान एक में जोड़ता और फिर उस स्थान पर डेटा को एक्सेस करता है। यह अंतिम मोड मेमोरी में बेस एड्रेस रखकर और फिर उसी रजिस्टर नंबर के साथ ऑपकोड को बार-बार कॉल करके मेमोरी पर लूप प्रयुक्त करने के लिए उपयोगी था, जिससे यह बिना किसी स्पष्ट निर्देश के बढ़ जाता था। यदि किसी भी निबल को मान 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}}  


===प्रोग्रामिंग===
===प्रोग्रामिंग ===
एमएसी-8 को सी में प्रोग्राम करने के लिए डिज़ाइन किया गया था, और बेल ने क्रॉस-कंपाइलिंग समर्थन और [[PDP-11|पीडीपी-11]] पर [[यूनिक्स]] पर चलने वाले एम8एसआईएम सिम्युलेटर की प्रस्तुति की है।{{sfn|Winfield|1978|p=502}} पीडीपी-11 पर चलने वाला पीएलएआईडी सिस्टम, केबल कनेक्शन का उपयोग करके एमएसी-8 सिस्टम के लिए [[डिबगर]] समर्थन प्रदान करता है। उन अनुप्रयोगों के लिए जिन्हें प्रत्यक्ष असेंबली लैंग्वेज प्रोग्रामिंग की आवश्यकता होती है, सिस्टम ने बहुत ही भिन्न प्रकार की लैंग्वेज का उपयोग किया है जो इच्छापूर्वक सी की तरह दिखने के लिए लिखी गई थी।{{sfn|Rovegno|1978|p=2255}} इस प्रकार से सिस्टम के परिचय से उदाहरण:
एमएसी-8 को सी में प्रोग्राम करने के लिए डिज़ाइन किया गया था, और बेल ने क्रॉस-कंपाइलिंग समर्थन और [[PDP-11|पीडीपी-11]] पर [[यूनिक्स]] पर चलने वाले एम8एसआईएम सिम्युलेटर की प्रस्तुति की है।{{sfn|Winfield|1978|p=502}} पीडीपी-11 पर चलने वाला पीएलएआईडी सिस्टम, केबल कनेक्शन का उपयोग करके एमएसी-8 सिस्टम के लिए [[डिबगर]] समर्थन प्रदान करता है। उन अनुप्रयोगों के लिए जिन्हें प्रत्यक्ष असेंबली लैंग्वेज प्रोग्रामिंग की आवश्यकता होती है, सिस्टम ने बहुत ही भिन्न प्रकार की लैंग्वेज का उपयोग किया है जो इच्छापूर्वक सी की तरह दिखने के लिए लिखी गई थी।{{sfn|Rovegno|1978|p=2255}} इस प्रकार से सिस्टम के परिचय से उदाहरण:  


<syntaxhighlight lang="c">
<syntaxhighlight lang="c">
Line 65: Line 47:
}
}
</syntaxhighlight>
</syntaxhighlight>
यह कोड 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}} लैंग्वेज में संरचनाएं, परिवर्तनीय परिभाषाएं, फ़ंक्शन और सी की अधिकांश अन्य विशेषताएं सम्मिलित हैं।{{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), और सम्मिलित थे। डिस्प्ले जिसमें आठ [[7-सेगमेंट]] एलईडी हैं। ऑनबोर्ड इंटरफेस में [[कैसेट टेप]], [[कंप्यूटर टर्मिनल]] के लिए दो आरएस-232 और एक 32-पिन बस विस्तारक सम्मिलित थे जिनका उपयोग अधिक मेमोरी या मेमोरी-मैप किए गए डिवाइस को जोड़ने के लिए किया जा सकता था।{{sfn|TUTOR|1979|p=1.1}}
चूँकि सिस्टम नया था, और माइक्रोप्रोसेसरों की पूरी अवधारणा एटी&टी के लिए नवीन थी, कंपनी ने एमएसी-ट्यूटर [[सिंगल-बोर्ड कंप्यूटर]] भी प्रस्तुत किया जिसका उपयोग परीक्षण और डेवलपमेंट के लिए किया जा सकता था। और यूनिक्स टूल का उपयोग प्रोग्राम बनाने, उसे मैक-ट्यूटर पर डाउनलोड करने, चलाने और डीबग करने और यूनिक्स की ओर स्थिति वापस भेजने के लिए किया जा सकता है।{{sfn|Winfield|1978|p=503}} मूल मैक-ट्यूटर में 2 kB की [[रैंडम एक्सेस मेमोरी]], बेसिक हार्डवेयर नियंत्रण कार्यों के साथ 2 kB की [[ केवल पढ़ने के लिये मेमोरी |आरओएम]], 1 kB [[प्रोग्रामयोग्य ROM|पीआरओएम]] चिप्स के लिए तीन सॉकेट, 28-बटन कैलकुलेटर-प्रकार का कीबोर्ड (4 बाय 7), और सम्मिलित थे। डिस्प्ले जिसमें आठ 7-सेगमेंट एलईडी हैं। ऑनबोर्ड इंटरफेस में [[कैसेट टेप]], [[कंप्यूटर टर्मिनल]] के लिए दो आरएस-232 और एक 32-पिन बस विस्तारक सम्मिलित थे जिनका उपयोग अधिक मेमोरी या मेमोरी-मैप किए गए डिवाइस को जोड़ने के लिए किया जा सकता था।{{sfn|TUTOR|1979|p=1.1}}  


==कार्यान्वयन==
==कार्यान्वयन ==
[[File:WE 212B BELLMAC-8 die.JPG|thumb|right|एमएसी-8 डाई का फोटोग्राफ।]]डब्लूई212 में 7,000 से अधिक ट्रांजिस्टर का उपयोग किया गया था और इसे 5 माइक्रोन सीएमओएस प्रक्रिया पर कार्यान्वित किया गया था, जिसके परिणामस्वरूप 220x230 मिल्स का डाई प्राप्त हुआ।{{sfn|Winfield|1978|p=501}} यह सामान्यतः 12 वी और 2 मेगाहर्ट्ज पर चलता था, जिसके परिणामस्वरूप 200 मिलीवाट ड्रॉ होता था,{{sfn|Winfield|1978|p=501}} जो 6502 या जेड80 जैसे समकालीन प्रोसेसर से अधिक कम था। [[ ट्रांजिस्टर-ट्रांजिस्टर तर्क |ट्रांजिस्टर-ट्रांजिस्टर लॉजिक]] (टीटीएल) भागों को पॉवर देने के लिए 5 वी पर दूसरी आपूर्ति की भी आवश्यकता थी जो बाकी कंप्यूटर हार्डवेयर के साथ इंटरफेस करती थी।{{sfn|Winfield|1978|p=501}}
[[File:WE 212B BELLMAC-8 die.JPG|thumb|right|एमएसी-8 डाई का फोटोग्राफ।]]डब्लूई212 में 7,000 से अधिक ट्रांजिस्टर का उपयोग किया गया था और इसे 5 माइक्रोन सीएमओएस प्रक्रिया पर कार्यान्वित किया गया था, जिसके परिणामस्वरूप 220x230 मिल्स का डाई प्राप्त हुआ।{{sfn|Winfield|1978|p=501}} यह सामान्यतः 12 वी और 2 मेगाहर्ट्ज पर चलता था, जिसके परिणामस्वरूप 200 मिलीवाट ड्रॉ होता था,{{sfn|Winfield|1978|p=501}} जो 6502 या जेड80 जैसे समकालीन प्रोसेसर से अधिक कम था। [[ ट्रांजिस्टर-ट्रांजिस्टर तर्क |ट्रांजिस्टर-ट्रांजिस्टर लॉजिक]] (टीटीएल) भागों को पॉवर देने के लिए 5 वी पर दूसरी आपूर्ति की भी आवश्यकता थी जो शेष कंप्यूटर हार्डवेयर के साथ इंटरफेस करती थी।{{sfn|Winfield|1978|p=501}}  


इस प्रकार से सीएमओएस को उपस्तिथ [[एनएमओएस तर्क|एनएमओएस लॉजिक]] डिजाइनों की तुलना में इसके कम पॉवर उपयोग के साथ-साथ ही चिप पर एनएमओएस और पीएमओएस ट्रांजिस्टर दोनों रखने की क्षमता के लिए चुना गया था, जिससे डिजाइनरों को लगा कि यह अधिक लचीलापन प्रदान करता है।{{sfn|Winfield|1978|p=500}} एएलयू सीएमओएस में प्रयुक्त करने के लिए अधिक सम्मिश्र था, जिसके लिए उनके द्वारा उपयोग किए जाने वाले एनएमओएस कार्यान्वयन के दोगुने क्षेत्र की आवश्यकता होती है। चूँकि इसके परिणामस्वरूप पॉवर अपव्यय में वृद्धि हुई, इस प्रकार से उदाहरण के लिए, मेमोरी एक्सेस के समय, सिस्टम ने उस अवधि के समय एएलयू को पॉवर हटा दी, जब इसका उपयोग नहीं किया जा रहा था। चूँकि एएलयू लगभग 20% समय ही सक्रिय था, यह महत्वपूर्ण पॉवर सेविंग का प्रतिनिधित्व करता था।{{sfn|Winfield|1978|p=501}}
इस प्रकार से सीएमओएस को उपस्तिथ [[एनएमओएस तर्क|एनएमओएस लॉजिक]] डिजाइनों की तुलना में इसके कम पॉवर उपयोग के साथ-साथ ही चिप पर एनएमओएस और पीएमओएस ट्रांजिस्टर दोनों रखने की क्षमता के लिए चुना गया था, जिससे डिजाइनरों को लगा कि यह अधिक लचीलापन प्रदान करता है।{{sfn|Winfield|1978|p=500}} एएलयू सीएमओएस में प्रयुक्त करने के लिए अधिक सम्मिश्र था, जिसके लिए उनके द्वारा उपयोग किए जाने वाले एनएमओएस कार्यान्वयन के दोगुने क्षेत्र की आवश्यकता होती है। चूँकि इसके परिणामस्वरूप पॉवर अपव्यय में वृद्धि हुई, इस प्रकार से उदाहरण के लिए, मेमोरी एक्सेस के समय, सिस्टम ने उस अवधि के समय एएलयू को पॉवर हटा दी, जब इसका उपयोग नहीं किया जा रहा था। चूँकि एएलयू लगभग 20% समय ही सक्रिय था, यह महत्वपूर्ण पॉवर सेविंग का प्रतिनिधित्व करता था।{{sfn|Winfield|1978|p=501}}  


इसे 16-पिन एड्रेस बस और 8-पिन डेटा बस के साथ 40-पिन [[ दोहरी इन-लाइन पैकेज |डीआईपी पैकेज]] में पैक किया गया था, जिसका अर्थ है कि कोई भी मुख्य पिन मल्टीप्लेक्स नहीं था और डेटा को ही चक्र में पढ़ा जा सकता था। इनपुट/आउटपुट मेमोरी-मैप्ड I/O और पोर्ट-मैप्ड I/O था और [[इंटेल 8080]] की तरह भिन्न-भिन्न पिन का उपयोग नहीं करता था। दो पिन [[प्रत्यक्ष मेमोरी एक्सेस|डायरेक्ट मेमोरी एक्सेस]] (डीएमए) प्रदान करते थे; डीएमए की इच्छा रखने वाला डिवाइस डीएमएआरईक्यू को नीचे खींचेगा, और जब प्रोसेसर बस को छोड़ने के लिए तैयार होगा तो यह डीएमएकेके को नीचे खींचकर इसका संकेत देगा। डिवाइस तब तक मेमोरी तक पहुंच सकता है जब तक उसे आवश्यकता हो और डीएमए आरईक्यू प्रवाहित करके संकेत दिया कि यह समाप्त हो गया है। अन्य तीन पिन, एस1 से एस3, सीपीयू की आंतरिक स्थिति और किसी भी इरर की स्थिति का संकेत देते हैं। बाकी पिन पॉवर, इंटरप्ट कंट्रोल और क्लॉक पिन का विशिष्ट मिश्रण थे।{{sfn|Winfield|1978|p=498}}
इसे 16-पिन एड्रेस बस और 8-पिन डेटा बस के साथ 40-पिन [[ दोहरी इन-लाइन पैकेज |डीआईपी पैकेज]] में पैक किया गया था, जिसका अर्थ है कि कोई भी मुख्य पिन मल्टीप्लेक्स नहीं था और डेटा को ही चक्र में पढ़ा जा सकता था। इनपुट/आउटपुट मेमोरी-मैप्ड I/O और पोर्ट-मैप्ड I/O था और [[इंटेल 8080]] की तरह भिन्न-भिन्न पिन का उपयोग नहीं करता था। दो पिन [[प्रत्यक्ष मेमोरी एक्सेस|डायरेक्ट मेमोरी एक्सेस]] (डीएमए) प्रदान करते थे; डीएमए की इच्छा रखने वाला डिवाइस डीएमएआरईक्यू को नीचे खींचेगा, और जब प्रोसेसर बस को छोड़ने के लिए तैयार होगा तो यह डीएमएकेके को नीचे खींचकर इसका संकेत देगा। डिवाइस तब तक मेमोरी तक पहुंच सकता है जब तक उसे आवश्यकता हो और डीएमए आरईक्यू प्रवाहित करके संकेत दिया कि यह समाप्त हो गया है। अन्य तीन पिन, एस1 से एस3, सीपीयू की आंतरिक स्थिति और किसी भी इरर की स्थिति का संकेत देते हैं। शेष पिन पॉवर, इंटरप्ट कंट्रोल और क्लॉक पिन का विशिष्ट मिश्रण थे।{{sfn|Winfield|1978|p=498}}


डब्लूई212 के कम से कम तीन वर्जन से सी तक उपस्तिथ हैं। और पैकेजिंग के अतिरिक्त, इनके मध्य के अंतर का किसी भी उपलब्ध संदर्भ में वर्णन नहीं किया गया है।
डब्लूई212 के कम से कम तीन वर्जन a से c तक उपस्तिथ हैं। और पैकेजिंग के अतिरिक्त, इनके मध्य के अंतर का किसी भी उपलब्ध संदर्भ में वर्णन नहीं किया गया है।


==उपयोग एवं प्रभाव==
==उपयोग एवं प्रभाव==
इस प्रकार से मैक-ट्यूटर सिस्टम के अतिरिक्त, डब्लूई212 का उल्लेख अनेक एटी एंड टी उत्पादों में किया गया है, जिनमें अन्य के अतिरिक्त, 4ईएसएस स्विच{{sfn|Hoppner|Mann|Panyko|Van Zweden|1981|p=1134}} और SLC-96 [[ सब्सक्राइबर लूप वाहक |सब्सक्राइबर लूप कैरियर]] भी सम्मिलित है।{{sfn|Canniff|1981|p=124}}
इस प्रकार से मैक-ट्यूटर सिस्टम के अतिरिक्त, डब्लूई212 का उल्लेख अनेक एटी एंड टी उत्पादों में किया गया है, जिनमें अन्य के अतिरिक्त, 4ईएसएस स्विच{{sfn|Hoppner|Mann|Panyko|Van Zweden|1981|p=1134}} और एसएलसी-96 [[ सब्सक्राइबर लूप वाहक |सब्सक्राइबर लूप कैरियर]] भी सम्मिलित है।{{sfn|Canniff|1981|p=124}}


चूंकि बेलमैक-8 का उपयोग अपेक्षाकृत कम था, सी और इसी तरह की लैंग्वेजो को चलाने के लिए विशेष रूप से प्रोसेसर को डिजाइन करने की मूल अवधारणा को अगले दशक में बेल द्वारा निरंतर सर्च किया गया था। निम्नलिखित बेलमैक-80 मूलतः सी मशीन का [[32-बिट कंप्यूटिंग]] कार्यान्वयन था। एमिटर-युग्मित लॉजिक में उच्च-प्रदर्शन डिज़ाइन का प्रयास छोड़ दिया गया था और 1986 में सीआरआईएसपी के रूप में सरल कार्यान्वयन तैयार किया गया था, जिससे प्रदर्शन की लगभग 7.7 वीएएक्स यूनिट प्राप्त हुई।{{sfn|Ditzel|McLellan||Berenbaum|1987|p=309}}
चूंकि बेलमैक-8 का उपयोग अपेक्षाकृत कम था, सी और इसी तरह की लैंग्वेजो को चलाने के लिए विशेष रूप से प्रोसेसर को डिजाइन करने की मूल अवधारणा को अगले दशक में बेल द्वारा निरंतर सर्च किया गया था। निम्नलिखित बेलमैक-80 मूलतः सी मशीन का [[32-बिट कंप्यूटिंग]] कार्यान्वयन था। एमिटर-युग्मित लॉजिक में उच्च-प्रदर्शन डिज़ाइन का प्रयास छोड़ दिया गया था और 1986 में सीआरआईएसपी के रूप में सरल कार्यान्वयन तैयार किया गया था, जिससे प्रदर्शन की लगभग 7.7 वीएएक्स यूनिट प्राप्त हुई।{{sfn|Ditzel|McLellan||Berenbaum|1987|p=309}}


एटी एंड टी ने मोबाइल कंप्यूटिंग के लिए कम-पॉवर अनुप्रयोगों की ओर पुनः ध्यान केंद्रित करते हुए सी मशीन प्रयासों के लक्ष्य को परिवर्तित करने का निर्णय लिया था। इससे एटी एंड टी हॉबिट डिज़ाइन का निर्माण किया गया था, प्रथम वर्जन, एटी एंड टी 92010, 1992 में प्रवाहित किया गया था।<ref name="byte199302_hobbit">{{ cite magazine | url=https://archive.org/details/BYTE-1993-02/page/n188/mode/1up | title=संचार व्यक्तिगत हो जाता है| magazine=Byte | last1=Ryan | first1=Bob | date=February 1993 | access-date=27 March 2023 | pages=169–170,172,174,176 }}</ref> और बाज़ार में सफलता की कमी के कारण एटी&टी को 1993 में हॉबिट को बाज़ार से वापस लेना पड़ा<ref>{{Cite web |last=Gassée |first=Jean-Louis|date=2019-01-31 |title=टेक में 50 वर्ष भाग 15. बनें: संकल्पना से मृत्यु के निकट तक|url=https://mondaynote.com/50-years-in-tech-part-15-be-from-concept-to-near-death-f69c64d8725e |access-date=2020-08-31|website=Medium|language=en}}</ref> और इसके साथ ही सी मशीन का डेवलपमेंट समाप्त हो गया था।
एटी एंड टी ने मोबाइल कंप्यूटिंग के लिए कम-पॉवर अनुप्रयोगों की ओर पुनः ध्यान केंद्रित करते हुए सी मशीन प्रयासों के लक्ष्य को परिवर्तित करने का निर्णय लिया था। इससे एटी एंड टी हॉबिट डिज़ाइन का निर्माण किया गया था, प्रथम वर्जन, एटी एंड टी 92010, 1992 में प्रवाहित किया गया था।<ref name="byte199302_hobbit">{{ cite magazine | url=https://archive.org/details/BYTE-1993-02/page/n188/mode/1up | title=संचार व्यक्तिगत हो जाता है| magazine=Byte | last1=Ryan | first1=Bob | date=February 1993 | access-date=27 March 2023 | pages=169–170,172,174,176 }}</ref> और बाज़ार में सफलता की कमी के कारण एटी&टी को 1993 में हॉबिट को बाज़ार से वापस लेना पड़ा था <ref>{{Cite web |last=Gassée |first=Jean-Louis|date=2019-01-31 |title=टेक में 50 वर्ष भाग 15. बनें: संकल्पना से मृत्यु के निकट तक|url=https://mondaynote.com/50-years-in-tech-part-15-be-from-concept-to-near-death-f69c64d8725e |access-date=2020-08-31|website=Medium|language=en}}</ref> और इसके साथ ही सी मशीन का डेवलपमेंट समाप्त हो गया था।


==संदर्भ==
==संदर्भ==
Line 180: Line 162:
[[Category: Machine Translated Page]]
[[Category: Machine Translated Page]]
[[Category:Created On 12/08/2023]]
[[Category:Created On 12/08/2023]]
[[Category:Vigyan Ready]]

Latest revision as of 07:21, 23 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]

कार्यान्वयन

एमएसी-8 डाई का फोटोग्राफ।

डब्लूई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] और इसके साथ ही सी मशीन का डेवलपमेंट समाप्त हो गया था।

संदर्भ

उद्धरण

  1. Winfield 1978, p. 494.
  2. 2.0 2.1 2.2 Ditzel & McLellan 1982, p. 48.
  3. Winfield 1978, p. 495.
  4. 4.0 4.1 Winfield 1978, p. 496.
  5. Osborne & Kane 1981, p. 10.1, 10.21.
  6. 6.0 6.1 6.2 6.3 Winfield 1978, p. 499.
  7. TUTOR 1979, p. 3.1.
  8. 8.0 8.1 8.2 TUTOR 1979, p. 3.3.
  9. 9.0 9.1 Winfield 1978, p. 500.
  10. TUTOR 1979, p. 3.4.
  11. 11.0 11.1 Winfield 1978, p. 502.
  12. 12.0 12.1 Rovegno 1978, p. 2255.
  13. Rovegno 1978, p. 2256.
  14. Winfield 1978, p. 503.
  15. TUTOR 1979, p. 1.1.
  16. 16.0 16.1 16.2 16.3 Winfield 1978, p. 501.
  17. Winfield 1978, p. 498.
  18. Hoppner et al. 1981, p. 1134.
  19. Canniff 1981, p. 124.
  20. Ditzel et al. 1987, p. 309.
  21. Ryan, Bob (February 1993). "संचार व्यक्तिगत हो जाता है". Byte. pp. 169–170, 172, 174, 176. Retrieved 27 March 2023.
  22. Gassée, Jean-Louis (2019-01-31). "टेक में 50 वर्ष भाग 15. बनें: संकल्पना से मृत्यु के निकट तक". Medium (in English). Retrieved 2020-08-31.


ग्रन्थसूची