निम्नलिखित निर्देशों को सही तरीके से निष्पादित करने के लिए मुझे कितने स्टालों की आवश्यकता है। मैं जो कुछ किया उसके साथ थोड़ा उलझन में हूं, इसलिए मैं विशेषज्ञों के जवाब देखने के लिए यहां हूं।विधानसभा में पाइपलाइनिंग
lw $1,0($2);
beq $1,$2,Label;
ध्यान दें कि जांच होगी कि शाखा होगी या नहीं, डीकोडिंग चरण में किया जाएगा। लेकिन इस मामले में $ 1 है जो बीक निर्देश के लिखने के चरण के बाद अद्यतन किया जाएगा। तो क्या हमें स्मृति चरण में स्मृति से नए डेटा को बीक निर्देश के डीकोडिंग चरण में अग्रेषित करने की आवश्यकता है।
स्टेज इस तरह जाना:
यदि: निर्देश प्राप्त कर रहा है; ID: निर्देश को डिकोड नहीं पूर्व: निष्पादन/ALU चरण सदस्य: स्मृति से डाटा पढ़ने पश्चिम बंगाल: गंतव्य में संग्रहीत डेटा रजिस्टर
यह मैं अब तक क्या किया है है।
जब एलडब्ल्यू निष्पादन चरण में होता है और डीकोडिंग चरण में बीक होता है, तो स्थिति खराब हो जाती है और एक बुलबुला बनाया जाता है। अब एमडब्ल्यू मेम स्टेज में है और बीक्यू अभी भी बुलबुले के कारण डीकोडिंग चरण में है, फिर भी स्टॉलिंग हालत सच हो गई है और दूसरा स्टाल हो गया है। और अब एलडब्ल्यू डब्ल्यूबी में है (वापस लिखें) और बीक डीकोडिंग चरण में है लेकिन अभी भी मूल्य $ 1 का डब्लूबीबी चरण के अंत में अपडेट होगा जिसका अंततः मतलब है कि बीक अभी भी $ 1 के गलत मूल्य के साथ काम करेगा।
"जांचें कि शाखा होगी या नहीं" - जो आपकी जांच का मतलब है। Http://www.csc.gatech.edu/~copeland/3055-00/lab/lab-2/MIPS_pipes.JPEG शाखा के अनुसार EX में किया गया है; और नए पीसी को एमईएम में पीसी रजिस्टर के लिए भेजा जाता है। – osgx
देरी हुई शाखा के कारण आपको 1 अतिरिक्त स्टॉल जोड़ना होगा। तो आपको 7 स्टालों की आवश्यकता होगी। – Blood
यह 7 स्टालों कैसे बनता है ?? अधिकांश स्टालों में 2 – Alfred