पिकोब्लेज़: Difference between revisions

From Vigyanwiki
(Created page with "पिकोब्लेज़ उनके एफपीजीए और सीपीएलडी उत्पादों में उपयोग के लिए [...")
 
No edit summary
Line 1: Line 1:
पिकोब्लेज़ उनके [[एफपीजीए]] और [[सीपीएलडी]] उत्पादों में उपयोग के लिए [[Xilinx]] के तीन मुफ्त [[ नरम माइक्रोप्रोसेसर ]] कोर की एक श्रृंखला का पदनाम है। वे 8-बिट [[ जोखिम ]] आर्किटेक्चर पर आधारित हैं और [[विरटेक्स 4]] एफपीजीए के परिवार पर प्रति सेकंड 100 मिलियन निर्देशों तक की गति तक पहुंच सकते हैं। केंद्रीय प्रसंस्करण इकाई में परिधीय उपकरणों की एक विस्तृत श्रृंखला तक पहुंच के लिए 8-बिट पता और डेटा पोर्ट होता है। कोर का लाइसेंस उनके निःशुल्क उपयोग की अनुमति देता है, भले ही केवल Xilinx उपकरणों पर, और वे [[ प्रोग्रामिंग उपकरण ]] के साथ आते हैं। तृतीय-पक्ष उपकरण मेडियाट्रोनिक्स और अन्य से उपलब्ध हैं। इसके अलावा [[PacoBlaze]], कोर का एक व्यवहारिक और उपकरण स्वतंत्र कार्यान्वयन मौजूद है और BSD लाइसेंस के तहत जारी किया गया है। पॉलोब्लेज़ [[अपाचे लाइसेंस]] के तहत एक खुला स्रोत वीएचडीएल कार्यान्वयन है।
पिकोब्लेज़ उनके [[एफपीजीए]] और [[सीपीएलडी]] उत्पादों में उपयोग के लिए [[Xilinx]] के तीन मुफ्त [[ नरम माइक्रोप्रोसेसर | सॉफ्ट  माइक्रोप्रोसेसर]] कोर की एक श्रृंखला का पदनाम है। वे 8-बिट [[ जोखिम | आरआईएससी]] आर्किटेक्चर पर आधारित हैं और [[विरटेक्स 4]] एफपीजीए के वर्ग पर प्रति सेकंड 100 मिलियन निर्देशों तक की गति तक पहुंच सकते हैं। केंद्रीय प्रसंस्करण इकाई में परिधीय उपकरणों की एक विस्तृत श्रृंखला तक पहुंच के लिए 8-बिट एड्रेस और डेटा पोर्ट होता है। कोर का लाइसेंस उनके निःशुल्क उपयोग की अनुमति देता है, तथापि केवल Xilinx उपकरणों पर, और वे [[ प्रोग्रामिंग उपकरण | प्रोग्रामिंग टूल]] के साथ आते हैं। तृतीय-पक्ष उपकरण मेडियाट्रोनिक्स और अन्य से उपलब्ध हैं। इसके अतिरिक्त [[PacoBlaze|पाकोब्लेज़]], कोर का एक व्यवहारिक और उपकरण स्वतंत्र कार्यान्वयन उपस्थित है और बीएसडी लाइसेंस के अनुसार जारी किया गया है। पॉलोब्लेज़ [[अपाचे लाइसेंस]] के अनुसार एक विवर्त स्रोत वीएचडीएल कार्यान्वयन है।


पिकोब्लेज़ डिज़ाइन को मूल रूप से KCPSM नाम दिया गया था जो कॉन्स्टेंट (K) कोडेड प्रोग्रामेबल स्टेट मशीन (पूर्व में केन चैपमैन की PSM) के लिए है। केन चैपमैन Xilinx सिस्टम डिजाइनर थे जिन्होंने माइक्रोकंट्रोलर को तैयार और कार्यान्वित किया।<ref name=pb>{{cite web|url=http://www.xilinx.com/support/documentation/application_notes/xapp213.pdf|title=PicoBlaze 8-bit Microcontroller|publisher=Xilinx, Inc.|access-date=2007-06-25}}</ref>
पिकोब्लेज़ डिज़ाइन को मूल रूप से केसीपीएसएम नाम दिया गया था जो कॉन्स्टेंट (K) कोडेड प्रोग्रामेबल स्टेट मशीन (पूर्व में केन चैपमैन की पीएसएम) के लिए है। केन चैपमैन Xilinx सिस्टम डिजाइनर थे जिन्होंने माइक्रोकंट्रोलर को तैयार और कार्यान्वित किया गया था।<ref name=pb>{{cite web|url=http://www.xilinx.com/support/documentation/application_notes/xapp213.pdf|title=PicoBlaze 8-bit Microcontroller|publisher=Xilinx, Inc.|access-date=2007-06-25}}</ref>




==तत्कालीकरण==
==तत्कालीकरण==


[[वीएचडीएल]] में पिकोब्लेज़ माइक्रोकंट्रोलर को इंस्टेंट करते समय, संबंधित केसीपीएसएम घटक नाम का उपयोग किया जाना चाहिए।<ref name=ug>{{cite web|url=http://www.xilinx.com/bvdocs/userguides/ug129.pdf|title=PicoBlaze 8-bit Embedded Microcontroller User Guide|publisher=Xilinx, Inc.|access-date=2007-06-25|url-status=dead|archive-url=https://web.archive.org/web/20070927185738/http://www.xilinx.com/bvdocs/userguides/ug129.pdf|archive-date=2007-09-27}}</ref> उदाहरण के लिए, PicoBlaze3 प्रोसेसर के लिए:
[[वीएचडीएल]] में पिकोब्लेज़ माइक्रोकंट्रोलर को इंस्टेंट करते समय, संबंधित केसीपीएसएम घटक नाम का उपयोग किया जाना चाहिए।<ref name=ug>{{cite web|url=http://www.xilinx.com/bvdocs/userguides/ug129.pdf|title=PicoBlaze 8-bit Embedded Microcontroller User Guide|publisher=Xilinx, Inc.|access-date=2007-06-25|url-status=dead|archive-url=https://web.archive.org/web/20070927185738/http://www.xilinx.com/bvdocs/userguides/ug129.pdf|archive-date=2007-09-27}}</ref> उदाहरण के लिए, पिकोब्लेज़3 प्रोसेसर के लिए:
<syntaxhighlight lang="vhdl">
<syntaxhighlight lang="vhdl">
component kcpsm3 is
component kcpsm3 is
Line 28: Line 28:
==प्रदर्शन==
==प्रदर्शन==


सभी निर्देश दो घड़ी चक्रों में निष्पादित होते हैं, जिससे मुख्य निर्देश सेट का प्रदर्शन निश्चित हो जाता है। व्यवधान प्रतिक्रिया पांच घड़ी चक्र से अधिक नहीं है। संसाधन अनुकूलन के रूप में, Xilinx FPGAs पर इस ब्लॉक के दोहरे पोर्ट कार्यान्वयन का लाभ उठाते हुए, दो PicoBlaze कोर के लिए समान 1k x 18 अनुदेश PROM साझा करना संभव है।
सभी निर्देश दो घड़ी चक्रों में निष्पादित होते हैं, जिससे मुख्य निर्देश सेट का प्रदर्शन निश्चित हो जाता है। व्यवधान प्रतिक्रिया पांच घड़ी चक्र से अधिक नहीं है। संसाधन अनुकूलन के रूप में, Xilinx एफपीजीए पर इस ब्लॉक के दोहरे पोर्ट कार्यान्वयन का लाभ उठाते हुए, दो पिकोब्लेज़ कोर के लिए समान 1k x 18 अनुदेश PROM साझा करना संभव है।


==वास्तुकला नोट्स==
==आर्किटेक्चरल नोट्स==
Xilinx ने PicoBlaze को केवल 96 FPGA स्लाइस की आवश्यकता के रूप में दस्तावेज़ित किया है। छोटे कार्यान्वयन का आकार आंशिक रूप से निर्देश अनुक्रमण पक्ष (प्रोग्राम काउंटर, कॉल-रिटर्न स्टैक, निहित स्टैक पॉइंटर, और इंटरप्ट इनेबल बिट) को निष्पादन पक्ष (एएलयू, रजिस्टर फ़ाइल, स्क्रैचपैड रैम, जेड) से काफी कठोर पृथक्करण के माध्यम से प्राप्त किया जाता है। /सी स्थिति बिट्स)। सशर्त JUMP और CALL निर्देशों द्वारा परीक्षण किए जाने पर गणना पक्ष से अनुक्रमण पक्ष तक प्रवाहित होने वाली एकमात्र जानकारी शून्य और ALU स्थिति बिट्स होती है। कंप्यूटेड जंप या फ़ंक्शन पॉइंटर्स को लागू करना संभव नहीं है{{dubious|date=November 2022}}. अनुक्रमण पक्ष से निष्पादन पक्ष तक प्रवाहित होने वाली एकमात्र जानकारी ऑपरेंड फ़ील्ड हैं: गंतव्य रजिस्टर (4 बिट्स), एएलयू ऑपकोड (छह बिट्स), वैकल्पिक स्रोत रजिस्टर (4 बिट्स), वैकल्पिक 8-बिट तत्काल मूल्य/पोर्ट-पता, वैकल्पिक 6-बिट स्क्रैचपैड पता। स्टैक पॉइंटर के मूल्य, 31-एंट्री स्टैक की सामग्री, इंटरप्ट इनेबल बिट या प्रोग्राम मेमोरी की सामग्री का निरीक्षण करने के लिए कोई तंत्र नहीं है।
Xilinx ने पिकोब्लेज़ को केवल 96 एफपीजीए स्लाइस की आवश्यकता के रूप में डॉक्यूमेंट किया है। छोटे कार्यान्वयन का आकार आंशिक रूप से निर्देश अनुक्रमण पक्ष (प्रोग्राम काउंटर, कॉल-रिटर्न स्टैक, निहित स्टैक पॉइंटर, और इंटरप्ट इनेबल बिट) को निष्पादन पक्ष (एएलयू, रजिस्टर फ़ाइल, स्क्रैचपैड रैम, जेड) से अधिक कठोर पृथक्करण के माध्यम से प्राप्त किया जाता है। /सी स्थिति बिट्स) नियमित जम्प और कॉल निर्देशों द्वारा परीक्षण किए जाने पर गणना पक्ष से अनुक्रमण पक्ष तक प्रवाहित होने वाली एकमात्र जानकारी शून्य और एएलयू स्थिति बिट्स होती है। कंप्यूटेड जंप या फ़ंक्शन पॉइंटर्स को प्रयुक्त करना संभव नहीं है{{dubious|date=November 2022}}. अनुक्रमण पक्ष से निष्पादन पक्ष तक प्रवाहित होने वाली एकमात्र जानकारी ऑपरेंड फ़ील्ड हैं: गंतव्य रजिस्टर (4 बिट्स), एएलयू ऑपकोड (छह बिट्स), वैकल्पिक स्रोत रजिस्टर (4 बिट्स), वैकल्पिक 8-बिट तत्काल मूल्य/पोर्ट-एड्रेस , वैकल्पिक 6-बिट स्क्रैचपैड एड्रेस स्टैक पॉइंटर के मूल्य, 31-एंट्री स्टैक की सामग्री, इंटरप्ट इनेबल बिट या प्रोग्राम मेमोरी की सामग्री का निरीक्षण करने के लिए कोई क्रियाविधि नहीं है।


निर्देश अनुक्रमण पक्ष में कोई योजक शामिल नहीं है, इसलिए सापेक्ष शाखाएं और स्थिति स्वतंत्र कोड संभव नहीं हैं। सभी जंप और कॉल पते पूर्ण हैं{{dubious|date=November 2022}}.
निर्देश अनुक्रमण पक्ष में कोई योजक सम्मिलित नहीं है, इसलिए सापेक्ष शाखाएं और स्थिति स्वतंत्र कोड संभव नहीं हैं। सभी जंप और कॉल एड्रेस पूर्ण हैं{{dubious|date=November 2022}}.


पिकोब्लेज़ [[सी (प्रोग्रामिंग भाषा)]] जैसी संकलित भाषाओं में प्रोग्रामिंग के लिए खराब रूप से अनुकूल है।<ref>{{cite book|author=Pong P. Chu|title=FPGA Prototyping by VHDL Examples: Xilinx Spartan-3 Version|isbn=978-0-470-18531-5|year=2008|publisher=Wiley & Sons}}</ref> फ़ंक्शन पॉइंटर्स के लिए समर्थन की कमी के अलावा{{dubious|date=November 2020}}, स्टैक-आधारित कॉलिंग कन्वेंशन में तेजी लाने के लिए कोई निर्देश या एड्रेसिंग मोड नहीं हैं। पिकोब्लेज़ के लिए PUSH या POP को लागू करने के लिए दो निर्देशों की आवश्यकता होती है और सॉफ़्टवेयर-नामित स्टैक पॉइंटर से सापेक्ष एड्रेसिंग को लागू करने के लिए दो निर्देशों की आवश्यकता होती है। पिकोब्लेज़ हाथ से अनुकूलित रजिस्टर-आधारित कॉलिंग कन्वेंशन के लिए बेहतर अनुकूल है। यह [[फोर्थ (प्रोग्रामिंग भाषा)]] जैसे डेटा स्टैक के उपयोग को नहीं रोकता है, और वास्तव में पिकोब्लेज़ इस दृष्टिकोण के लिए उपयुक्त है, अगर 64-बाइट स्क्रैचपैड मेमोरी पर्याप्त स्थान प्रदान करती है।
पिकोब्लेज़ [[सी (प्रोग्रामिंग भाषा)|सी (प्रोग्रामिंग लैंग्वेज )]] जैसी संकलित लैंग्वेज में प्रोग्रामिंग के लिए खराब रूप से अनुकूल है।<ref>{{cite book|author=Pong P. Chu|title=FPGA Prototyping by VHDL Examples: Xilinx Spartan-3 Version|isbn=978-0-470-18531-5|year=2008|publisher=Wiley & Sons}}</ref> फ़ंक्शन पॉइंटर्स के लिए समर्थन की कमी के अतिरिक्त {{dubious|date=November 2020}}, स्टैक-आधारित कॉलिंग कन्वेंशन में तेजी लाने के लिए कोई निर्देश या एड्रेसिंग मोड नहीं हैं। पिकोब्लेज़ के लिए पुश  या पॉप को प्रयुक्त करने के लिए दो निर्देशों की आवश्यकता होती है और सॉफ़्टवेयर-नामित स्टैक पॉइंटर से सापेक्ष एड्रेसिंग को प्रयुक्त करने के लिए दो निर्देशों की आवश्यकता होती है। पिकोब्लेज़ हाथ से अनुकूलित रजिस्टर-आधारित कॉलिंग कन्वेंशन के लिए उत्तम अनुकूल है। यह [[फोर्थ (प्रोग्रामिंग भाषा)|फोर्थ (प्रोग्रामिंग लैंग्वेज )]] जैसे डेटा स्टैक के उपयोग को नहीं रोकता है, और वास्तव में पिकोब्लेज़ इस दृष्टिकोण के लिए उपयुक्त है, यदि 64-बाइट स्क्रैचपैड मेमोरी पर्याप्त स्थान प्रदान करती है।


==यह भी देखें==
==यह भी देखें                                                                                                                                             ==


* [[ MicroBlaze ]]
* [[ MicroBlaze | माइक्रोब्लेज़]]


==बाहरी संबंध==
==बाहरी संबंध==


Processor and derivatives:
Processor and derivatives:
* [https://web.archive.org/web/20030501203653/http://www.xilinx.com/picoblaze/ PicoBlaze on the Xilinx website]
* [https://web.archive.org/web/20030501203653/http://www.xilinx.com/picoblaze/ पिकोब्लेज़ on the Xilinx website]
* [http://www.xilinx.com/support/documentation/ip_documentation/ug129.pdf PicoBlaze user manual]
* [http://www.xilinx.com/support/documentation/ip_documentation/ug129.pdf पिकोब्लेज़ user manual]
* [https://web.archive.org/web/20060911010008/http://www.xilinx.com/ipcenter/processor_central/picoblaze/picoblaze_user_resources.htm PicoBlaze user resources]
* [https://web.archive.org/web/20060911010008/http://www.xilinx.com/ipcenter/processor_central/picoblaze/picoblaze_user_resources.htm पिकोब्लेज़ user resources]
* [http://pwo.fpga.be/coursematerial.html     Implementation of picoblaze in LabVIEW FPGA on the Xilinx Spartan 3E Starter board]
* [http://pwo.fpga.be/coursematerial.html Implementation of पिकोब्लेज़ in LabVIEW FPGA on the Xilinx Spartan 3E Starter board]
* [http://bleyer.org/pacoblaze                PacoBlaze: an open source synthesizable and behavioral Verilog clone of PicoBlaze]
* [http://bleyer.org/pacoblaze                PacoBlaze: an open source synthesizable and behavioral Verilog clone of PicoBlaze]
* [http://bleyer.org/pacoblaze/picoblaze.pdf PacoBlaze implementation description]
* [http://bleyer.org/pacoblaze/picoblaze.pdf PacoBlaze implementation description]
Line 54: Line 54:


Tools:
Tools:
* [http://code.google.com/p/pblazasm         Open source Picoblaze assembler]
* [http://code.google.com/p/pblazasm Open source पिकोब्लेज़ assembler]
* [http://www.ivysim.com/picoblaze/debug/     PicoBlaze Debugger, Software and RTL Hardware development with ModelSim]
* [http://www.ivysim.com/picoblaze/debug/ पिकोब्लेज़ Debugger, Software and RTL Hardware development with ModelSim]
* [http://www.moravia-microsystems.com/multitarget-development-system/            MDS,      Professional IDE for Linux and Windows]
* [http://www.moravia-microsystems.com/multitarget-development-system/            MDS,      Professional IDE for Linux and Windows]
* [http://www.fautronix.com/fidex            FIDEx,      an assembler IDE for Linux, MAC and Windows]
* [http://www.fautronix.com/fidex            FIDEx,      an assembler IDE for Linux, MAC and Windows]
Line 61: Line 61:
* [https://web.archive.org/web/20051027185700/http://www.mediatronix.com/tools/index.htm pBlazIDE,  an assembler IDE for Windows]
* [https://web.archive.org/web/20051027185700/http://www.mediatronix.com/tools/index.htm pBlazIDE,  an assembler IDE for Windows]
* [http://www.xs4all.nl/~marksix              kpicosim,  an open source assembler IDE for Linux]
* [http://www.xs4all.nl/~marksix              kpicosim,  an open source assembler IDE for Linux]
* [http://code.google.com/p/opbasm           Opbasm,    Cross-platform Open Picoblaze macro assembler for kcpsm3 and kcpsm6]
* [http://code.google.com/p/opbasm Opbasm,    Cross-platform Open पिकोब्लेज़ macro assembler for kcpsm3 and kcpsm6]
* [https://picoblaze-simulator.sourceforge.io PicoBlaze Simulator in JavaScript]
* [https://picoblaze-simulator.sourceforge.io पिकोब्लेज़ Simulator in JavaScript]




Line 69: Line 69:
{{reflist}}
{{reflist}}
;Bibliography
;Bibliography
* Ivanov Vl. '''[http://www.cit.iit.bas.bg/CIT_2015/v-15-5s/11_Vladimir_Ivanov-edited-md-Gotovo.pdf Using a PicoBlaze Processor to Traffic Light Control.]''' Cybernetics and Information Technologies, 15, 5, Marin Drinov, 2015, Online {{ISSN|1314-4081}}, {{doi|10.1515/cait-2015-0023}}, pp.&nbsp;131 – 139. SJR:0.212
* Ivanov Vl. '''[http://www.cit.iit.bas.bg/CIT_2015/v-15-5s/11_Vladimir_Ivanov-edited-md-Gotovo.pdf Using a पिकोब्लेज़ Processor to Traffic Light Control.]''' Cybernetics and Information Technologies, 15, 5, Marin Drinov, 2015, Online {{ISSN|1314-4081}}, {{doi|10.1515/cait-2015-0023}}, pp.&nbsp;131 – 139. SJR:0.212
{{RISC-based processor architectures}}
{{RISC-based processor architectures}}
{{Soft microprocessors}}
{{Soft microprocessors}}

Revision as of 12:27, 13 August 2023

पिकोब्लेज़ उनके एफपीजीए और सीपीएलडी उत्पादों में उपयोग के लिए Xilinx के तीन मुफ्त सॉफ्ट माइक्रोप्रोसेसर कोर की एक श्रृंखला का पदनाम है। वे 8-बिट आरआईएससी आर्किटेक्चर पर आधारित हैं और विरटेक्स 4 एफपीजीए के वर्ग पर प्रति सेकंड 100 मिलियन निर्देशों तक की गति तक पहुंच सकते हैं। केंद्रीय प्रसंस्करण इकाई में परिधीय उपकरणों की एक विस्तृत श्रृंखला तक पहुंच के लिए 8-बिट एड्रेस और डेटा पोर्ट होता है। कोर का लाइसेंस उनके निःशुल्क उपयोग की अनुमति देता है, तथापि केवल Xilinx उपकरणों पर, और वे प्रोग्रामिंग टूल के साथ आते हैं। तृतीय-पक्ष उपकरण मेडियाट्रोनिक्स और अन्य से उपलब्ध हैं। इसके अतिरिक्त पाकोब्लेज़, कोर का एक व्यवहारिक और उपकरण स्वतंत्र कार्यान्वयन उपस्थित है और बीएसडी लाइसेंस के अनुसार जारी किया गया है। पॉलोब्लेज़ अपाचे लाइसेंस के अनुसार एक विवर्त स्रोत वीएचडीएल कार्यान्वयन है।

पिकोब्लेज़ डिज़ाइन को मूल रूप से केसीपीएसएम नाम दिया गया था जो कॉन्स्टेंट (K) कोडेड प्रोग्रामेबल स्टेट मशीन (पूर्व में केन चैपमैन की पीएसएम) के लिए है। केन चैपमैन Xilinx सिस्टम डिजाइनर थे जिन्होंने माइक्रोकंट्रोलर को तैयार और कार्यान्वित किया गया था।[1]


तत्कालीकरण

वीएचडीएल में पिकोब्लेज़ माइक्रोकंट्रोलर को इंस्टेंट करते समय, संबंधित केसीपीएसएम घटक नाम का उपयोग किया जाना चाहिए।[2] उदाहरण के लिए, पिकोब्लेज़3 प्रोसेसर के लिए:

component kcpsm3 is
  port (
    address       : out std_logic_vector(9 downto 0);
    instruction   : in std_logic_vector(17 downto 0);
    port_id       : out std_logic_vector(7 downto 0);
    write_strobe  : out std_logic;
    out_port      : out std_logic_vector(7 downto 0);
    read_strobe   : out std_logic;
    in_port       : in std_logic_vector(7 downto 0);
    interrupt     : in std_logic;
    interrupt_ack : out std_logic;
    reset         : in std_logic;
    clk           : in std_logic
    );
end component;


प्रदर्शन

सभी निर्देश दो घड़ी चक्रों में निष्पादित होते हैं, जिससे मुख्य निर्देश सेट का प्रदर्शन निश्चित हो जाता है। व्यवधान प्रतिक्रिया पांच घड़ी चक्र से अधिक नहीं है। संसाधन अनुकूलन के रूप में, Xilinx एफपीजीए पर इस ब्लॉक के दोहरे पोर्ट कार्यान्वयन का लाभ उठाते हुए, दो पिकोब्लेज़ कोर के लिए समान 1k x 18 अनुदेश PROM साझा करना संभव है।

आर्किटेक्चरल नोट्स

Xilinx ने पिकोब्लेज़ को केवल 96 एफपीजीए स्लाइस की आवश्यकता के रूप में डॉक्यूमेंट किया है। छोटे कार्यान्वयन का आकार आंशिक रूप से निर्देश अनुक्रमण पक्ष (प्रोग्राम काउंटर, कॉल-रिटर्न स्टैक, निहित स्टैक पॉइंटर, और इंटरप्ट इनेबल बिट) को निष्पादन पक्ष (एएलयू, रजिस्टर फ़ाइल, स्क्रैचपैड रैम, जेड) से अधिक कठोर पृथक्करण के माध्यम से प्राप्त किया जाता है। /सी स्थिति बिट्स) नियमित जम्प और कॉल निर्देशों द्वारा परीक्षण किए जाने पर गणना पक्ष से अनुक्रमण पक्ष तक प्रवाहित होने वाली एकमात्र जानकारी शून्य और एएलयू स्थिति बिट्स होती है। कंप्यूटेड जंप या फ़ंक्शन पॉइंटर्स को प्रयुक्त करना संभव नहीं है[dubious ]. अनुक्रमण पक्ष से निष्पादन पक्ष तक प्रवाहित होने वाली एकमात्र जानकारी ऑपरेंड फ़ील्ड हैं: गंतव्य रजिस्टर (4 बिट्स), एएलयू ऑपकोड (छह बिट्स), वैकल्पिक स्रोत रजिस्टर (4 बिट्स), वैकल्पिक 8-बिट तत्काल मूल्य/पोर्ट-एड्रेस , वैकल्पिक 6-बिट स्क्रैचपैड एड्रेस स्टैक पॉइंटर के मूल्य, 31-एंट्री स्टैक की सामग्री, इंटरप्ट इनेबल बिट या प्रोग्राम मेमोरी की सामग्री का निरीक्षण करने के लिए कोई क्रियाविधि नहीं है।

निर्देश अनुक्रमण पक्ष में कोई योजक सम्मिलित नहीं है, इसलिए सापेक्ष शाखाएं और स्थिति स्वतंत्र कोड संभव नहीं हैं। सभी जंप और कॉल एड्रेस पूर्ण हैं[dubious ].

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

यह भी देखें

बाहरी संबंध

Processor and derivatives:

Tools:


संदर्भ

Notes
  1. "PicoBlaze 8-bit Microcontroller" (PDF). Xilinx, Inc. Retrieved 2007-06-25.
  2. "PicoBlaze 8-bit Embedded Microcontroller User Guide" (PDF). Xilinx, Inc. Archived from the original (PDF) on 2007-09-27. Retrieved 2007-06-25.
  3. Pong P. Chu (2008). FPGA Prototyping by VHDL Examples: Xilinx Spartan-3 Version. Wiley & Sons. ISBN 978-0-470-18531-5.
Bibliography