हार्डवेयर सॉफ्टवेयर ट्रेडऑफ़
हार्डवेयर लागत को कम करने के लिए कई तरीके हैं। एक तरीका यह है कि संचार सहायता और नेटवर्क को प्रसंस्करण नोड में कम कसकर और संचार विलंबता और अधिभोग को बढ़ाने के लिए एकीकृत किया जाए।
एक अन्य तरीका हार्डवेयर के बजाय सॉफ्टवेयर में स्वचालित प्रतिकृति और सुसंगतता प्रदान करना है। उत्तरार्द्ध विधि मुख्य मेमोरी में प्रतिकृति और सुसंगतता प्रदान करती है, और विभिन्न प्रकार की बारीकियों पर निष्पादित कर सकती है। यह नोड्स और इंटरकनेक्ट के लिए ऑफ-द-शेल्फ शेल्फ पार्ट्स के उपयोग की अनुमति देता है, हार्डवेयर लागत को कम करता है। इससे प्रोग्रामर पर अच्छा प्रदर्शन हासिल करने का दबाव पड़ता है।
आराम स्मृति संगति मॉडल
एक साझा पता स्थान के लिए मेमोरी संगतता मॉडल उस क्रम में बाधाओं को परिभाषित करता है जिसमें एक ही या अलग-अलग स्थानों में स्मृति संचालन एक दूसरे के संबंध में निष्पादित होते हैं। असल में, किसी भी सिस्टम लेयर जो एक साझा एड्रेस स्पेस नामकरण मॉडल को सपोर्ट करता है, उसके पास एक मेमोरी कंसिस्टेंसी मॉडल होना चाहिए जिसमें प्रोग्रामर का इंटरफेस, यूजर-सिस्टम इंटरफेस और हार्डवेयर-सॉफ्टवेयर इंटरफेस शामिल हो। सॉफ़्टवेयर जो उस परत के साथ इंटरैक्ट करता है, उसे अपने मेमोरी मेमोरी मॉडल के बारे में पता होना चाहिए।
सिस्टम विनिर्देशों
किसी आर्किटेक्चर का सिस्टम स्पेसिफिकेशन, मेमोरी ऑपरेशंस के ऑर्डरिंग और रीऑर्डरिंग को निर्दिष्ट करता है और वास्तव में इससे कितना प्रदर्शन प्राप्त किया जा सकता है।
कार्यक्रम क्रम में छूट का उपयोग करते हुए कुछ विनिर्देश मॉडल निम्नलिखित हैं -
Relaxing the Write-to-Read Program Order- मॉडल का यह वर्ग हार्डवेयर को लिखने के संचालन की विलंबता को दबाने की अनुमति देता है जो प्रथम-स्तरीय कैश मेमोरी में याद किया गया था। जब लिखने की चूक लिखने वाले बफर में होती है और अन्य प्रोसेसर से दिखाई नहीं देती है, तो प्रोसेसर यह पढ़ सकता है कि उसकी कैश मेमोरी में कौन सी हिट है या एक भी रीड जो कि कैश मेमोरी में छूट जाती है।
Relaxing the Write-to-Read and Write-to-Write Program Orders- विभिन्न स्थानों पर पिछले बकाया लिखने के लिए अनुमति देने से राइटिंग मुख्य मेमोरी को अपडेट करने से पहले कई राइट्स को लिखने वाले बफर में विलय करने की अनुमति देता है। इस प्रकार एकाधिक लेखन अतिव्याप्त हो जाता है और क्रम से बाहर दिखाई देता है। प्रेरणा का उद्देश्य प्रोसेसर के ब्रेक समय पर विलंबता लिखने के प्रभाव को कम करना है, और अन्य प्रोसेसर के लिए नए डेटा मानों को बनाकर प्रोसेसर के बीच संचार दक्षता को बढ़ाना है।
Relaxing All Program Orders- कोई प्रोग्राम ऑर्डर किसी प्रक्रिया के भीतर डेटा और नियंत्रण निर्भरता को छोड़कर डिफ़ॉल्ट रूप से आश्वस्त नहीं होता है। इस प्रकार, लाभ यह है कि एक ही समय में कई पढ़े गए अनुरोध बकाया हो सकते हैं, और प्रोग्राम ऑर्डर में बाद में लिखकर बाईपास किया जा सकता है, और खुद को ऑर्डर से पूरा कर सकते हैं, हमें रीड लेटेंसी को छिपाने की अनुमति देता है। इस प्रकार के मॉडल गतिशील रूप से अनुसूचित प्रोसेसर के लिए विशेष रूप से उपयोगी होते हैं, जो कि पिछले रीड मिसेज को अन्य मेमोरी संदर्भों में जारी रख सकते हैं। वे कई री-ऑर्डरिंग की अनुमति देते हैं, यहां तक कि कंपाइल ऑप्टिमाइज़ेशन द्वारा किए गए एक्सेस को भी समाप्त कर देते हैं।
प्रोग्रामिंग इंटरफ़ेस
प्रोग्रामिंग इंटरफेस यह मान लेते हैं कि प्रोग्राम ऑर्डर को सिंक्रोनाइज़ेशन ऑपरेशंस के बीच में बनाए रखने की ज़रूरत नहीं है। यह सुनिश्चित किया जाता है कि सभी सिंक्रनाइज़ेशन ऑपरेशन स्पष्ट रूप से लेबल किए गए हैं या इस तरह से पहचाने जाते हैं। रनटाइम लाइब्रेरी या कंपाइलर इन सिंक्रोनाइज़ेशन ऑपरेशंस को सिस्टम स्पेसिफिकेशन के लिए उपयुक्त ऑर्डर-प्रोटेक्शन ऑपरेशंस में तब्दील करता है।
सिस्टम तब भी क्रमिक रूप से लगातार निष्पादन का आश्वासन देता है, भले ही यह किसी भी तरह से एक प्रक्रिया के भीतर एक स्थान पर निर्भरता को बाधित किए बिना इच्छाओं के सिंक्रनाइज़ेशन संचालन के बीच संचालन को पुन: व्यवस्थित कर सकता है। यह संकलक को इच्छित इच्छाओं के लिए सिंक्रनाइज़ेशन बिंदुओं के बीच संकलक के पर्याप्त लचीलेपन की अनुमति देता है, और प्रोसेसर को अपने मेमोरी मॉडल द्वारा अनुमत के रूप में कई पुन: व्यवस्थित करने के लिए भी अनुदान देता है। प्रोग्रामर के इंटरफ़ेस में, कमज़ोरी मॉडल कम से कम उतना कमज़ोर होना चाहिए जितना कि हार्डवेयर इंटरफ़ेस, लेकिन इसकी आवश्यकता समान नहीं है।
अनुवाद तंत्र
अधिकांश माइक्रोप्रोसेसरों में, एक सिंक्रनाइज़ेशन के रूप में लेबल किए गए प्रत्येक ऑपरेशन से पहले और / या बाद में एक उपयुक्त मेमोरी बाधा निर्देश डालने के लिए तंत्र मात्रा बनाए रखने के लिए लेबल का अनुवाद। यह अलग-अलग लोड / स्टोर के साथ निर्देशों को सहेजता है जो दर्शाता है कि अतिरिक्त निर्देशों को लागू करने और बचने के लिए क्या आदेश हैं। हालांकि, चूंकि ऑपरेशन आम तौर पर अनियंत्रित होते हैं, यह ऐसा तरीका नहीं है जो अब तक अधिकांश माइक्रोप्रोसेसरों ने लिया है।
आगामी क्षमता सीमाएँ
हमने उन प्रणालियों को डिसकस किया है जो प्रोसेसर कैश मेमोरी में केवल हार्डवेयर में स्वचालित प्रतिकृति और सुसंगतता प्रदान करते हैं। एक प्रोसेसर कैश, इसे स्थानीय मुख्य मेमोरी में पहले दोहराया जाने के बिना, दूर से आवंटित डेटा को सीधे संदर्भ में दोहराता है।
इन प्रणालियों के साथ एक समस्या यह है कि स्थानीय प्रतिकृति के लिए गुंजाइश हार्डवेयर कैश तक सीमित है। यदि किसी ब्लॉक को कैश मेमोरी से बदल दिया जाता है, तो उसे फिर से जरूरत पड़ने पर रिमोट मेमोरी से लाना पड़ता है। इस खंड में चर्चा की गई प्रणालियों का मुख्य उद्देश्य प्रतिकृति क्षमता की समस्या को हल करना है, लेकिन अभी भी हार्डवेयर और दक्षता के लिए कैश ब्लॉकों की बारीक बारीकियों में सुसंगतता प्रदान करना है।
तृतीयक कैश
प्रतिकृति क्षमता की समस्या को हल करने के लिए, एक विधि एक बड़े लेकिन धीमी रिमोट एक्सेस कैश का उपयोग करना है। यह कार्यक्षमता के लिए आवश्यक है, जब मशीन के नोड्स स्वयं छोटे पैमाने के मल्टीप्रोसेसर होते हैं और बस प्रदर्शन के लिए बड़े किए जा सकते हैं। यह स्थानीय प्रोसेसर कैश मेमोरी से प्रतिस्थापित किए गए प्रतिकृति दूरस्थ ब्लॉक भी रखेगा।
कैश-केवल मेमोरी आर्किटेक्चर (COMA)
COMA मशीनों में, पूरे मुख्य मेमोरी में प्रत्येक मेमोरी ब्लॉक में एक हार्डवेयर टैग जुड़ा होता है। कोई निश्चित नोड नहीं है जहां मेमोरी ब्लॉक के लिए हमेशा स्थान आवंटित करने का आश्वासन दिया जाता है। डेटा गतिशील रूप से माइग्रेट होता है या उन नोड्स की मुख्य यादों में दोहराया जाता है जो उन्हें एक्सेस / आकर्षित करते हैं। जब एक रिमोट ब्लॉक एक्सेस किया जाता है, तो इसे आकर्षण मेमोरी में दोहराया जाता है और कैश में लाया जाता है, और हार्डवेयर द्वारा दोनों स्थानों पर संगत रखा जाता है। एक डेटा ब्लॉक किसी भी आकर्षण मेमोरी में निवास कर सकता है और एक से दूसरे में आसानी से स्थानांतरित हो सकता है।
हार्डवेयर की लागत कम करना
लागत कम करने का अर्थ है मौजूदा हार्डवेयर पर चलने वाले सॉफ़्टवेयर के लिए विशेष हार्डवेयर की कुछ कार्यक्षमता को स्थानांतरित करना। सॉफ़्टवेयर के लिए हार्डवेयर मेमोरी में मुख्य मेमोरी में प्रतिकृति और सुसंगतता का प्रबंधन करना बहुत आसान है। कम लागत वाली विधियाँ मुख्य मेमोरी में प्रतिकृति और सुसंगतता प्रदान करती हैं। कुशलता से नियंत्रित किए जाने के लिए, सहायता के अन्य कार्यात्मक घटकों में से प्रत्येक को हार्डवेयर विशेषज्ञता और एकीकरण से लाभान्वित किया जा सकता है।
अनुसंधान प्रयासों का उद्देश्य विभिन्न दृष्टिकोणों के साथ लागत को कम करना है, जैसे विशेष हार्डवेयर में अभिगम नियंत्रण करना, लेकिन सॉफ्टवेयर और कमोडिटी हार्डवेयर को अन्य गतिविधियाँ प्रदान करना। एक अन्य दृष्टिकोण सॉफ्टवेयर में एक्सेस कंट्रोल का प्रदर्शन करना है, और कमोडिटी नोड्स और नेटवर्क पर कोई विशेष हार्डवेयर समर्थन के साथ एक सुसंगत साझा पता स्थान अमूर्त आवंटित करने के लिए डिज़ाइन किया गया है।
समानांतर सॉफ्टवेयर के लिए निहितार्थ
रिलैक्स्ड मेमोरी कंसिस्टेंसी मॉडल की जरूरत है कि समानांतर प्रोग्राम वांछित परस्पर विरोधी एक्सेस को सिंक्रोनाइज़ेशन पॉइंट के रूप में लेबल करते हैं। एक प्रोग्रामिंग भाषा कुछ चर को सिंक्रोनाइज़ेशन के रूप में लेबल करने के लिए समर्थन प्रदान करती है, जिसे तब कंपाइलर द्वारा उपयुक्त ऑर्डर-प्रोटेक्शन इंस्ट्रक्शन में अनुवादित किया जाएगा। संकलकों को साझा मेमोरी में एक्सेस के पुन: व्यवस्थित करने पर रोक लगाने के लिए, कंपाइलर अपने आप से लेबल का उपयोग कर सकता है।