बरोज़ लार्ज सिस्टम डिस्क्रिप्टर: Difference between revisions

From Vigyanwiki
No edit summary
Line 229: Line 229:
[[Category: Machine Translated Page]]
[[Category: Machine Translated Page]]
[[Category:Created On 26/04/2023]]
[[Category:Created On 26/04/2023]]
[[Category:Vigyan Ready]]

Revision as of 15:40, 1 May 2023

डिस्क्रिप्टर वर्तमान (2006 तक) यूनिसिस क्लियरपाथ/एमसीपी सिस्टम सहित बरोज़ की बड़ी प्रणालियों की संरचना की विशेषता है। कॉल स्टैक- और टैग किए टैग की गई संरचना या टैग-आधारित होने के अलावा, इन प्रणालियों की उल्लेखनीय संरचना विशेषता यह है कि यह वर्णनकर्ता-आधारित है। डेटा डिस्क्रिप्टर डेटा रखने का माध्यम है जो सरणी डेटा संरचना और ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग के लिए स्टैक पर नहीं रहता है। डिस्क्रिप्टर का उपयोग स्ट्रिंग (कंप्यूटर साइंस) डेटा के लिए भी किया आंकड़े है जैसा कि संकलक और व्यावसायिक अनुप्रयोग प्रक्रिया सामग्री में होता है।

विवरण

डिस्क्रिप्टर स्टोरेज एरिया, आई/ओ रिक्वेस्ट और आई/ओ रिजल्ट का वर्णन करते हैं। उनमें संकेत देने वाले क्षेत्र होते हैं, उदा। डिस्क्रिप्टर का प्रकार, पता, लंबाई, क्या डेटा स्टोरेज में सम्मिलित है। उत्पाद लाइन और डिस्क्रिप्टर के प्रकार के आधार पर विवरण अलग-अलग होते हैं। बरोज़ दस्तावेज़ीकरण के अनुसार, निम्न पाठ संख्या सबसे बाईं ओर (सबसे महत्वपूर्ण) बिट 0 के रूप में है।

प्रोग्राम और डेटा डिस्क्रिप्टर में बिट होता है जिसे उपस्थिति बिट या पी-बिट कहा जाता है; यह इंगित करता है कि डिस्क्रिप्टर द्वारा संदर्भित वस्तु वर्तमान में स्मृति में है या द्वितीयक मेमोरी में है। इस बिट का उपयोग आभासी मेमोरी को लागू करने के लिए किया जाता है।

वर्चुअल मेमोरी मूल रूप से 1950 के दशक के अंत में मैनचेस्टर विश्वविद्यालय में एटलस कंप्यूटर (मैनचेस्टर) परियोजना के लिए विकसित की गई थी। व्यावसायिक अनुप्रयोगों में इसका उपयोग देखने के लिए उत्सुक, उन्होंने कई कंप्यूटर कंपनियों के इंजीनियरों को सेमिनार में आमंत्रित किया, जिनमें बरोज़ कॉर्पोरेशन और आईबीएम के लोग भी सम्मिलित थे। B5000, 1961 में जारी किया गया, वर्चुअल मेमोरी प्रदान करने वाला पहला व्यावसायिक कंप्यूटर था। 1960 के दशक के मध्य में, IBM, रेडियो कॉर्पोरेशन ऑफ अमेरिका, और जनरल इलेक्ट्रिक सहित अन्य विक्रेताओं ने ऐसी मशीनें विकसित कीं जो समय-साझाकरण की ओर उन्मुख ऑपरेटिंग सिस्टम के साथ वर्चुअल मेमोरी का समर्थन करती थीं; आईबीएम ने 1972 तक सामान्य डेटा प्रोसेसिंग उपयोग के लिए अभिप्रेत मशीनों में वर्चुअल मेमोरी का समर्थन नहीं किया था।

जब डिस्क्रिप्टर का संदर्भ दिया जाता है, तो हार्डवेयर पी-बिट की जांच करता है। यदि यह 1 है, तो पता क्षेत्र में इंगित स्थान पर डेटा स्मृति में सम्मिलित है। यदि पी-बिट 0 है, तो डेटा ब्लॉक सम्मिलित नहीं है और बाधा डालना (पी-बिट इंटरप्ट) उठाया जाता है और ब्लॉक को उपस्थित करने के लिए बरोज़ एमसीपी कोड इंगित किया जाता है। इस स्थिति में, यदि पता फ़ील्ड 0 है, तो डेटा ब्लॉक आवंटित नहीं किया गया है (init p-bit) और एमसीपी मुक्त ब्लॉक की खोज करता है जिसका आकार लंबाई क्षेत्र में दिया गया है।

अंतिम पी-बिट परिदृश्य तब होता है जब पी-बिट 0 होता है, यह दर्शाता है कि डेटा मेमोरी में नहीं है, अपितु पता गैर-शून्य है, यह दर्शाता है कि डेटा आवंटित किया गया है और इस स्थिति में पता डिस्क पते का प्रतिनिधित्व डिस्क पर वर्चुअल मेमोरी क्षेत्र से करता है। इस स्थिति में पी-बिट इंटरप्ट उठाया जाता है और इसे अन्य पी-बिट के रूप में नोट किया जाता है।

B5000, B5500 और B5700

बी 5000[1]पहला डिस्क्रिप्टर आधारित कंप्यूटर था। प्रत्येक डिस्क्रिप्टर के पास 1 का ध्वज (बिट 0) होता है। डेटा डिस्क्रिप्टर में 15-बिट स्टोरेज एड्रेस और 10-बिट आकार होता है, जैसा कि अधिकांश I/O डिस्क्रिप्टर करते हैं। प्रोग्राम डिस्क्रिप्टर और एक्सटर्नल रिजल्ट डिस्क्रिप्टर के पास 15-बिट एड्रेस है अपितु कोई आकार फ़ील्ड नहीं है।

B5x00 प्रोग्राम डिस्क्रिप्टर

प्रोग्राम डिस्क्रिप्टर का उपयोग प्रोग्राम सेगमेंट को परिभाषित करने के लिए किया जाता है। या तो ऑपरेंड कॉल या डिस्क्रिप्टर कॉल जो प्रोग्राम डिस्क्रिप्टर को संदर्भित करता है, उपस्थिति बिट 1 होने पर सबरूटीन कॉल का कारण बनता है, अन्यथा यह उपस्थिति बाधा उत्पन्न करेगा।

B5x00 Program Descriptors[1]: 4-2 
0 1 2 3 4 5 6 7 8-17 18-32 33-47
Flag I Presence I Mode A Address
1 1 0=not in memory
1=in memory
1 0=word
1=character
0=argument not required
1=argument required


डेटा डिस्क्रिप्टर

डेटा डिस्क्रिप्टर या तो मेमोरी में सम्मिलित डेटा के ब्लॉक (पी = 1) या डेटा के ब्लॉक को संदर्भित करता है जिसे मेमोरी (पी = 0) में पढ़ा जाना चाहिए, उपस्थिति बिट के मान पर निर्भर करता है। या तो ऑपरेंड कॉल या डिस्क्रिप्टर कॉल जो डेटा डिस्क्रिप्टर को संदर्भित करता है, इस उपस्थिति में बिट और आकार क्षेत्र की जांच करेगा, यदि उपस्थिति बिट 0 है तो उपस्थिति बाधा उत्पन्न होगी; यदि आकार का क्षेत्र शून्य नहीं है तो स्टैक पर दूसरा शब्द सीमा के भीतर होना चाहिए या इंडेक्स इंटरप्ट होता हैं।

B5x00 Data Descriptors[1]: 4-3 
0 1 2 3-7 8-17 18 19 20 21-32 33-47
Flag I Presence Size I C Address
1 0 0=not in memory
1=in memory
Reserved
for एमसीपी
Reserved
for एमसीपी
0=Floating
1=Integer
[D5 1] Reserved
for एमसीपी
  1. Continuity bit - for controlling the type of interrupt caused by a program release operator
    0=Set the Program Release Interrupt - I/O areas not tanked or last I/O area
    1=Set the Continuity Interrupt - I/O areas are tanked

आई/ओ डिस्क्रिप्टर

B5x00 I/O Descriptors[1]: 4-4–4-13 
0 1 2 3-7 8-17 18-32 33-47
Flag I Alternate
External
Unit Size Device
Dependent
Address
1 1 0=write
1=read

बाहरी परिणाम वर्णनकर्ता

एक बाहरी परिणाम डिस्क्रिप्टर में I/O डिस्क्रिप्टर होता है जिसका उपयोग ऑपरेशन शुरू करने के लिए किया जाता है जिसमें कुछ फ़ील्ड्स को बदल दिया जाता है।

B5x00 External Result Descriptors[1]: 4-14–4-15 
0 1 2 3-7 8-25 26-32 33-47
Flag I Alternate
External
Unit Irrelevant Device
Dependent
Address
1 1 0=write
1=read
error
conditions
last
location

B6500, B7500 और उत्तराधिकारी

डिस्क्रिप्टर डेटा ब्लॉक का वर्णन करते हैं। प्रत्येक डिस्क्रिप्टर में डेटा ब्लॉक को संदर्भित करने वाला 20- अंश पता फ़ील्ड होता है। प्रत्येक ब्लॉक की लंबाई होती है जो डिस्क्रिप्टर में संग्रहीत होती है, वह भी 20 बिट्स। डेटा का आकार भी दिया जाता है, तीन बिट फ़ील्ड में 4-, 6-, 8- या 48-बिट डेटा होता है।

इस संरचना वाला पहला कंप्यूटर B6500 था। उस कार्यान्वयन में, विभिन्न स्थिति बिट्स का अर्थ था:

  • बिट 47 - उपस्थिति बिट (पी-बिट)
  • बिट 46 - कॉपी बिट
  • बिट 45 - अनुक्रमित बिट
  • बिट 44 - खंडित बिट
  • बिट 43 - रीड ओनली बिट

बाद के कार्यान्वयन में ये स्थिति बिट्स बढ़ते स्मृति आकार के साथ बने रहने के लिए विकसित हुए और अंतर्दृष्टि प्राप्त की।

कंपाइलर्स में उपयोग

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

बरोज़ वातावरण में कार्यक्रम में, सरणी आवंटित नहीं की जाती है जब इसे घोषित किया जाता है, अपितु केवल तब जब इसे पहली बार छुआ जाता है - इस प्रकार सरणियों को घोषित किया जा सकता है और यदि उनका उपयोग नहीं किया जाता है तो उन्हें आवंटित करने से बचा जा सकता है।

इसके अलावा, निम्न-स्तरीय स्मृति आवंटन प्रणाली कॉल जैसे सी (प्रोग्रामिंग भाषा) और यूनिक्स की कॉल के malloc वर्ग की आवश्यकता नहीं है - सरणी स्वचालित रूप से उपयोग के रूप में आवंटित की जाती हैं। यह प्रोग्रामर को स्मृति प्रबंधन की त्रुटि-प्रवण गतिविधि के साथ प्रोग्राम भरने का बड़ा बोझ बचाता है, जो मेनफ़्रेम कंप्यूटर अनुप्रयोगों में महत्वपूर्ण है।

सी जैसे निचले स्तर की भाषाओं में कार्यक्रमों को में porting करते समय, सी मेमोरी संरचना को बड़े आवंटित बी5000 ब्लॉक के भीतर अपनी स्वयं की मेमोरी आवंटन करके निपटाया जाता है - इस प्रकार बाकी बी5000 सिस्टम की सुरक्षा त्रुटिपूर्ण सी प्रोग्रामों द्वारा बफ़र अधिकता नहीं हो सकती है। . वास्तव में, B5000 में पोर्ट किए जाने पर स्पष्ट रूप से अन्यथा सही ढंग से चलने वाले C प्रोग्राम में कई बफर ओवररन हो गए हैं[citation needed] संरचना। सी, पास्कल की तरह, स्लाइस कंपाइलर सिस्टम (जो एलएलवीएम की तरह, सभी भाषाओं के लिए सामान्य कोड जनरेटर और ऑप्टिमाइज़र का उपयोग करता है) का उपयोग करके भी लागू किया गया था। C कंपाइलर, रन-टाइम सिस्टम, POSIX इंटरफेस, साथ ही कई यूनिक्स टूल्स का पोर्ट स्टीव बार्टल्स द्वारा किया गया था। स्लाइस का उपयोग करके एफिल (प्रोग्रामिंग भाषा) कंपाइलर भी विकसित किया गया था।

ऑब्जेक्ट-ओरिएंटेड प्रोग्राम्स के लिए जिन्हें B5000 संरचना की तुलना में ऑब्जेक्ट्स के अधिक गतिशील निर्माण की आवश्यकता होती है, ऑब्जेक्ट्स को B5000 ब्लॉक के भीतर सबसे अच्छा आवंटित किया जाता है। ऐसा ऑब्जेक्ट आवंटन सी के मॉलोक से उच्च स्तर है और इसे आधुनिक कुशल कचरा संग्रह (कंप्यूटर विज्ञान) के साथ सर्वोत्तम रूप से कार्यान्वित किया जाता है।

मेमोरी संरचना में एकीकरण

B5000 में एड्रेस फील्ड केवल 15 बिट्स है, जिसका अर्थ है कि केवल 32K शब्द (192KB) मेमोरी को डिस्क्रिप्टर द्वारा संबोधित किया जा सकता है। B6500 ने इसे 20 बिट्स या 1 मेग शब्द (6MB) तक बढ़ा दिया। सत्तर के दशक के मध्य तक यह अभी भी संरचना का महत्वपूर्ण प्रतिबंध था। इसे दूर करने के लिए, दो समाधान लागू किए गए:

  1. Swapper - यह समाधान वास्तव में स्मृति प्रबंधन के शीर्ष पर और परत लागू करता है, संबंधित डेटा के बड़े समूहों को स्मृति में और स्मृति से बाहर ले जाता है।
  2. ASN - यह समाधान भौतिक रूप से अधिक मेमोरी को सिस्टम में कॉन्फ़िगर करने की अनुमति देता है, अलग-अलग एड्रेसेबल चंक्स में विभाजित। इस संरचना को ASN (एड्रेस स्पेस नंबर) मेमोरी के रूप में जाना जाता है। मेमोरी को तार्किक रूप से दो क्षेत्रों में विभाजित किया गया है, ऑपरेटिंग सिस्टम के लिए ग्लोबल एड्रेस स्पेस के लिए कम मेमोरी एड्रेस आवंटित करना और अलग-अलग प्रोग्राम के लिए कई समानांतर लोकल एड्रेस स्पेस के लिए सॉफ्टवेयर और हाई मेमोरी एड्रेस का समर्थन करना होता हैं। पता स्थान क्रमांकित हैं, शून्य ग्लोबल इंगित करता है, 1..n स्थानीय पता स्थान इंगित करता है। डेटा साझा करने वाले प्रोग्राम स्वचालित रूप से उसी पता स्थान में रखे जाते हैं।

इन सुविधाओं का उपयोग करने के लिए कोई प्रोग्राम कोड संशोधन आवश्यक नहीं थे। दोनों समाधानों को संयुक्त भी किया जा सकता है, अपितु अंततः एमसीपी मेमोरी आवश्यकताओं और प्रोग्राम डेटा साझाकरण आवश्यकताओं ने पता स्थान के अधिकतम आकार को ही बढ़ा दिया।

1980 के दशक की शुरुआत में ए सीरीज़ के आगमन के साथ, इस क्षेत्र का अर्थ मास्टर डिस्क्रिप्टर के पते को सम्मिलित करने के लिए बदल दिया गया था, जिसका अर्थ है कि 1 मेगाबाइट डेटा ब्लॉक आवंटित किया जा सकता है, अपितु मशीन मेमोरी को गीगाबाइट्स या संभवतः टेराबाइट्स में बहुत विस्तारित किया जा सकता है। इस संरचना को ASD (Advanced Segment Descriptors) मेमोरी नाम दिया गया था। इसके लिए नए सामान्य माइक्रोकोड विनिर्देशन की आवश्यकता थी, जिसे बीटा कहा जाता है। एएसडी मेमोरी के पीछे मुख्य दूरदर्शी जॉन मैक्लिंटॉक हैं। बाद में 3-बिट मेमोरी टैग को 4-बिट विनिर्देश में बढ़ा दिया गया, जिससे सेगमेंट डिस्क्रिप्टर आकार में 20 से 23 बिट तक बढ़ गया, जिससे साथ और अधिक मेमोरी को संबोधित किया जा सके। यह माइक्रोकोड विनिर्देश स्तर गामा के रूप में जाना जाने लगा।

मेमोरी मैनेजमेंट

वर्चुअल मेमोरी के लिए और महत्वपूर्ण लाभ महसूस किया गया। B5000 डिज़ाइन में, यदि डेटा ब्लॉक को रोल आउट किया गया था, तो उपस्थिति बिट और पते को अपडेट करने के लिए उस ब्लॉक को संदर्भित करने वाले सभी डिस्क्रिप्टर को खोजने की आवश्यकता थी। मास्टर डिस्क्रिप्टर के साथ, मास्टर डिस्क्रिप्टर में केवल उपस्थिति बिट को बदलने की जरूरत है। साथ ही एमसीपी संघनन के लिए ब्लॉक को मेमोरी में इधर-उधर कर सकता है और केवल मास्टर डिस्क्रिप्टर में पता बदलने की जरूरत है।

B5000 और अधिकांश अन्य प्रणालियों के बीच अंतर यह है कि अन्य प्रणालियाँ मुख्य रूप से पृष्ठांकित वर्चुअल मेमोरी का उपयोग करती हैं, अर्ताथ पृष्ठों को निश्चित आकार के टुकड़ों में बदल दिया जाता है, भले ही उनमें जानकारी की संरचना कुछ भी हो। B5000 वर्चुअल मेमोरी अलग-अलग आकार के सेगमेंट के साथ काम करती है, जैसा कि डिस्क्रिप्टर द्वारा बताया गया है।

जब मेमोरी निश्चित क्षमता तक भरी जाती है, तो वर्किंग सेट शेरिफ नामक OS प्रक्रिया को या तो कॉम्पैक्ट मेमोरी में सम्मिलित किया जाता है या सेगमेंट को मेमोरी से बाहर ले जाना शुरू किया जाता है। यह पहले कोड सेगमेंट चुनता है, क्योंकि ये बदल नहीं सकते हैं और कोड फ़ाइल में मूल से पुनः लोड किए जा सकते हैं, इसलिए लिखने की आवश्यकता नहीं है, और फिर डेटा सेगमेंट जो वर्चुअल मेमोरी फ़ाइल में लिखे गए हैं।

सिस्टम प्रदर्शन को मापने के लिए पी-बिट इंटरप्ट्स भी उपयोगी होते हैं। पहली बार आवंटन के लिए, 'init p-बिट्स' कार्यक्रम में संभावित प्रदर्शन समस्या का संकेत देता है, उदाहरण के लिए यदि किसी सरणी को आवंटित करने वाली प्रक्रिया को लगातार कॉल किया जाता है। डिस्क पर वर्चुअल मेमोरी से रीलोडिंग ब्लॉक सिस्टम के प्रदर्शन को महत्वपूर्ण रूप से कम कर सकता है और यह किसी विशिष्ट कार्य का दोष नहीं है। यही कारण है कि आज के कई कंप्यूटर मेमोरी जोड़कर सिस्टम के उत्तम प्रदर्शन को प्राप्त कर सकते हैं। B5000 मशीनों पर, 'अन्य पी-बिट्स' सिस्टम समस्या का संकेत देते हैं, जिसे पूरे दिन कंप्यूटिंग लोड को उत्तम ढंग से संतुलित करके या अधिक मेमोरी जोड़कर हल किया जा सकता है।

इस प्रकार बरोज़ लार्ज सिस्टम संरचना व्यक्तिगत कार्यों और समग्र रूप से सिस्टम दोनों के अनुकूलन में मदद करता है।

बफर ओवरफ्लो सुरक्षा

वर्णनकर्ताओं के बारे में नोट करने के लिए अंतिम और संभवतः सबसे महत्वपूर्ण बिंदु यह है कि वे सिस्टम सुरक्षा और प्रोग्राम शुद्धता की पूरक धारणाओं को कैसे प्रभावित करते हैं। सुरक्षा क्रैकिंग के लिए आज के ऑपरेटिंग सिस्टम से समझौता करने के लिए सबसे अच्छे टूल में से बफर ओवरफ्लो है। सी, विशेष रूप से, स्ट्रिंग्स के अंत को चिह्नित करने के लिए सबसे आदिम और त्रुटि-प्रवण तरीके का उपयोग करता है, डेटा स्ट्रीम में अंत-ऑफ़-स्ट्रिंग सेंटिनल के रूप में नल बाइट का उपयोग करता है।

अनुक्रमित वर्णनकर्ताओं द्वारा B5000 पर पॉइंटर्स लागू किए जाते हैं। इंडेक्सिंग ऑपरेशंस के समय, पॉइंटर (कंप्यूटर प्रोग्रामिंग) को प्रत्येक वेतन वृद्धि पर यह सुनिश्चित करने के लिए चेक किया जाता है कि न तो स्रोत और न ही गंतव्य ब्लॉक सीमा से बाहर हैं। स्कैन या प्रतिस्थापन ऑपरेशन के समय, मेमोरी के बड़े ब्लॉक को पढ़ने या कॉपी करने के लिए उपयोग की जाने वाली तंत्र, वैध मेमोरी टैग के लिए प्रत्येक शब्द वृद्धि पर स्रोत और गंतव्य दोनों की जांच की जाती है। प्रत्येक मेमोरी सेगमेंट टैग 3 शब्दों से घिरा हुआ है, जो इस प्रकार के ऑपरेशन को विफल कर देगा। अखंडता संवेदनशील डेटा वाले प्रत्येक मेमोरी सेगमेंट, जैसे कि प्रोग्राम कोड, को टैग 3 शब्दों में संग्रहीत किया जाता है, जिससे अनियंत्रित रीड - अकेले संशोधन - असंभव हो जाता है। इस प्रकार प्रोग्राम त्रुटियों का महत्वपूर्ण स्रोत सॉफ्टवेयर के उत्पादन में जाने से पहले ही पता लगाया जा सकता है, और सिस्टम सुरक्षा पर हमलों का अधिक महत्वपूर्ण वर्ग संभव नहीं है।

टिप्पणियाँ

संदर्भ

  1. 1.0 1.1 1.2 1.3 1.4 The Operational Characteristic of the Processors for the Burroughs B 5000 (PDF) (A ed.), Detroit: Burroughs, 1962, 5000-21005A