इंटेल 8253: Difference between revisions
From Vigyanwiki
(Created page with "{{Short description|Programmable interval timer IC}} {{Use dmy dates|date=July 2013}} thumb|इंटेल C8253 Image:Intel 8253 and 8...") |
No edit summary |
||
| Line 1: | Line 1: | ||
{{Short description|Programmable interval timer IC}} | {{Short description|Programmable interval timer IC}} | ||
[[Image:Ic-photo-Intel--C8253.JPG|thumb|इंटेल C8253]] | [[Image:Ic-photo-Intel--C8253.JPG|thumb|इंटेल C8253]] | ||
[[Image:Intel 8253 and 8254.svg|thumb|इंटेल 8253 प्रोग्रामयोग्य अंतराल टाइमर। Intel 8254 में समान पिनआउट है।]][[इंटेल]] 8253 और 8254 [[प्रोग्रामयोग्य अंतराल टाइमर]] (पीआईटी) हैं, जो तीन 16-बिट काउंटर का उपयोग करके समय और गिनती कार्य करते हैं।<ref name=i82c54/> | [[Image:Intel 8253 and 8254.svg|thumb|इंटेल 8253 प्रोग्रामयोग्य अंतराल टाइमर। Intel 8254 में समान पिनआउट है।]][[इंटेल]] 8253 और 8254 [[प्रोग्रामयोग्य अंतराल टाइमर]] (पीआईटी) हैं, जो तीन 16-बिट काउंटर का उपयोग करके समय और गिनती कार्य करते हैं।<ref name=i82c54/> | ||
825x परिवार मुख्य रूप से [[Intel 8080]]/[[Intel 8085]]-प्रोसेसर के लिए डिज़ाइन किया गया था, लेकिन बाद में x86 संगत सिस्टम में उपयोग किया गया। 825x चिप्स, या | 825x परिवार मुख्य रूप से [[Intel 8080]]/[[Intel 8085]]-प्रोसेसर के लिए डिज़ाइन किया गया था, लेकिन बाद में x86 संगत सिस्टम में उपयोग किया गया। 825x चिप्स, या बड़ी चिप में एम्बेडेड समकक्ष सर्किट, सभी [[आईबीएम पीसी संगत]] और वेक्टर -06 सी जैसे सोवियत कंप्यूटरों में पाए जाते हैं। | ||
पीसी कंपैटिबल्स में, टाइमर चैनल 0 को [[ व्यवधान अनुरोध (पीसी आर्किटेक्चर) ]] -0 (उच्चतम प्राथमिकता हार्डवेयर इंटरप्ट) को सौंपा गया है। टाइमर चैनल 1 को DRAM रिफ्रेश के लिए असाइन किया गया है (कम से कम 80386 से पहले के शुरुआती मॉडल में)। टाइमर चैनल 2 [[पीसी स्पीकर]] को सौंपा गया है। | पीसी कंपैटिबल्स में, टाइमर चैनल 0 को [[ व्यवधान अनुरोध (पीसी आर्किटेक्चर) ]] -0 (उच्चतम प्राथमिकता हार्डवेयर इंटरप्ट) को सौंपा गया है। टाइमर चैनल 1 को DRAM रिफ्रेश के लिए असाइन किया गया है (कम से कम 80386 से पहले के शुरुआती मॉडल में)। टाइमर चैनल 2 [[पीसी स्पीकर]] को सौंपा गया है। | ||
इंटेल 82c54 ([[सीएमओएस]] लॉजिक के लिए सी) वेरिएंट 10 मेगाहर्ट्ज क्लॉक सिग्नल तक संभालता है।<ref name=i82c54/> | इंटेल 82c54 ([[सीएमओएस]] लॉजिक के लिए सी) वेरिएंट 10 मेगाहर्ट्ज क्लॉक सिग्नल तक संभालता है।<ref name=i82c54/> | ||
==इतिहास== | ==इतिहास== | ||
8253 का वर्णन 1980 इंटेल कंपोनेंट डेटा कैटलॉग प्रकाशन में किया गया है। 8254, जिसे उच्च क्लॉक स्पीड रेटिंग के साथ 8253 के सुपरसेट के रूप में वर्णित किया गया है, की 1982 इंटेल कंपोनेंट डेटा कैटलॉग में प्रारंभिक डेटा शीट है। | 8253 का वर्णन 1980 इंटेल कंपोनेंट डेटा कैटलॉग प्रकाशन में किया गया है। 8254, जिसे उच्च क्लॉक स्पीड रेटिंग के साथ 8253 के सुपरसेट के रूप में वर्णित किया गया है, की 1982 इंटेल कंपोनेंट डेटा कैटलॉग में प्रारंभिक डेटा शीट है। | ||
8254 को एचएमओएस में लागू किया गया है और इसमें रीड बैक कमांड 8253 पर उपलब्ध नहीं है, और | 8254 को एचएमओएस में लागू किया गया है और इसमें रीड बैक कमांड 8253 पर उपलब्ध नहीं है, और ही काउंटर को इंटरलीव करने के लिए पढ़ने और लिखने की अनुमति देता है।<ref>{{cite book |author1=Deepali A. Godse |author2=Atul P. Godse |title=उन्नत माइक्रोप्रोसेसर|publisher=Technical Publications |year=2007 |isbn=978-81-89411-33-6 |page=74}}</ref> | ||
आधुनिक पीसी कंपेटिबल, या तो चिप सीपीयू या [[साउथब्रिज (कंप्यूटिंग)]] पर सिस्टम का उपयोग करते समय आमतौर पर बैकवर्ड संगतता और इंटरऑपरेबिलिटी के लिए पूर्ण 8254 संगतता लागू करते हैं।<ref>http://pdf.datasheetcatalog.com/datasheet/Intel/mXvqwzr.pdf {{Bare URL PDF|date=March 2022}}</ref> रीड बैक कमांड मल्टीकोर सीपीयू और जीपीयू के साथ इंटरऑपरेबिलिटी के लिए | आधुनिक पीसी कंपेटिबल, या तो चिप सीपीयू या [[साउथब्रिज (कंप्यूटिंग)]] पर सिस्टम का उपयोग करते समय आमतौर पर बैकवर्ड संगतता और इंटरऑपरेबिलिटी के लिए पूर्ण 8254 संगतता लागू करते हैं।<ref>http://pdf.datasheetcatalog.com/datasheet/Intel/mXvqwzr.pdf {{Bare URL PDF|date=March 2022}}</ref> रीड बैक कमांड मल्टीकोर सीपीयू और जीपीयू के साथ इंटरऑपरेबिलिटी के लिए महत्वपूर्ण I/O सुविधा है। | ||
=== वेरिएंट === | === वेरिएंट === | ||
-55°C से +125°C के तापमान रेंज के साथ Intel M8253 का सैन्य संस्करण है, जिसमें ±10% 5V पावर सहनशीलता भी है।<ref>Intel Corporation, "Focus Components: Military Intelligence: Timers, EPROMs, Leadless Chip Carriers", Solutions, March/April 1983, Page 12.</ref> उपलब्ध 82C53 CMOS संस्करण को ओकी इलेक्ट्रिक इंडस्ट्री|ओकी इलेक्ट्रॉनिक इंडस्ट्री कंपनी लिमिटेड को आउटसोर्स किया गया था।<ref>Intel Corporation, "NewsBit: Intel Licenses Oki on CMOS Version of Several Products", Solutions, July/August 1984, Page 1.</ref> Intel 82C54 का उपलब्ध पैकेज संस्करण 1986 की पहली तिमाही में सैंपलिंग के 28-पिन चिप_कैरियर#प्लास्टिक-लीडेड_चिप_कैरियर में था।<ref>Ashborn, Jim; "Advanced Packaging: A Little Goes A Long Way", Intel Corporation, Solutions, January/February 1986, Page 2</ref> | -55°C से +125°C के तापमान रेंज के साथ Intel M8253 का सैन्य संस्करण है, जिसमें ±10% 5V पावर सहनशीलता भी है।<ref>Intel Corporation, "Focus Components: Military Intelligence: Timers, EPROMs, Leadless Chip Carriers", Solutions, March/April 1983, Page 12.</ref> उपलब्ध 82C53 CMOS संस्करण को ओकी इलेक्ट्रिक इंडस्ट्री|ओकी इलेक्ट्रॉनिक इंडस्ट्री कंपनी लिमिटेड को आउटसोर्स किया गया था।<ref>Intel Corporation, "NewsBit: Intel Licenses Oki on CMOS Version of Several Products", Solutions, July/August 1984, Page 1.</ref> Intel 82C54 का उपलब्ध पैकेज संस्करण 1986 की पहली तिमाही में सैंपलिंग के 28-पिन चिप_कैरियर#प्लास्टिक-लीडेड_चिप_कैरियर में था।<ref>Ashborn, Jim; "Advanced Packaging: A Little Goes A Long Way", Intel Corporation, Solutions, January/February 1986, Page 2</ref> | ||
== विशेषताएँ == | == विशेषताएँ == | ||
[[Image:Intel 8253 block diagram.svg|thumb|का ब्लॉक आरेख {{nowrap|Intel 8253}}]]टाइमर में तीन काउंटर हैं, जिनकी संख्या 0 से 2 है।<ref name="Intel 8254">{{cite web |title=8254/82C54: Introduction to Programmable Interval Timer |url=http://www.intel.com:80/design/archives/periphrl/docs/7203.htm |publisher=Intel Corporation |archive-url=https://web.archive.org/web/20161122073424/http://www.intel.com:80/design/archives/periphrl/docs/7203.htm |accessdate=21 August 2011|archive-date=22 November 2016 }}</ref> प्रत्येक चैनल को छह मोड में से | [[Image:Intel 8253 block diagram.svg|thumb|का ब्लॉक आरेख {{nowrap|Intel 8253}}]]टाइमर में तीन काउंटर हैं, जिनकी संख्या 0 से 2 है।<ref name="Intel 8254">{{cite web |title=8254/82C54: Introduction to Programmable Interval Timer |url=http://www.intel.com:80/design/archives/periphrl/docs/7203.htm |publisher=Intel Corporation |archive-url=https://web.archive.org/web/20161122073424/http://www.intel.com:80/design/archives/periphrl/docs/7203.htm |accessdate=21 August 2011|archive-date=22 November 2016 }}</ref> प्रत्येक चैनल को छह मोड में से में संचालित करने के लिए प्रोग्राम किया जा सकता है। बार प्रोग्राम हो जाने पर, चैनल स्वतंत्र रूप से काम करते हैं।<ref name=i82c54>{{cite web |archive-url=https://web.archive.org/web/20150603122044/http://download.intel.com/design/archives/periphrl/docs/23124406.pdf |archive-date=3 June 2015 |url=http://download.intel.com/design/archives/periphrl/docs/23124406.pdf |url-status=dead |title=Intel 82C54 CHMOS Programmabe Interval Timer |type=datasheet |access-date=26 November 2012 }}</ref> | ||
प्रत्येक काउंटर में दो इनपुट पिन होते हैं - सीएलके ([[ घड़ी ]] इनपुट) और गेट - और डेटा आउटपुट के लिए | प्रत्येक काउंटर में दो इनपुट पिन होते हैं - सीएलके ([[ घड़ी ]] इनपुट) और गेट - और डेटा आउटपुट के लिए पिन, आउट। तीन काउंटर एक-दूसरे से स्वतंत्र 16-बिट डाउन काउंटर हैं, और इन्हें केंद्रीय प्रसंस्करण इकाई द्वारा आसानी से पढ़ा जा सकता है।<ref>{{cite web |title=MSM 82c53 Datasheet |url=http://www.sharpmz.org/download/8253.pdf}}</ref> | ||
* डेटा बस बफ़र में माइक्रोप्रोसेसर और आंतरिक रजिस्टरों के बीच डेटा बस को बफ़र करने का तर्क होता है। इसमें 8 इनपुट पिन हैं, जिन्हें आमतौर पर D7..D0 के रूप में लेबल किया जाता है, जहां D7 [[सबसे महत्वपूर्ण बिट]] है। | * डेटा बस बफ़र में माइक्रोप्रोसेसर और आंतरिक रजिस्टरों के बीच डेटा बस को बफ़र करने का तर्क होता है। इसमें 8 इनपुट पिन हैं, जिन्हें आमतौर पर D7..D0 के रूप में लेबल किया जाता है, जहां D7 [[सबसे महत्वपूर्ण बिट]] है। | ||
* रीड/राइट लॉजिक में 5 पिन होते हैं, जो नीचे सूचीबद्ध हैं।{{overline|X}} दर्शाता है कि X | * रीड/राइट लॉजिक में 5 पिन होते हैं, जो नीचे सूचीबद्ध हैं।{{overline|X}} दर्शाता है कि X सक्रिय निम्न सिग्नल है। | ||
** {{overline|RD}}: संकेत पढ़ें | ** {{overline|RD}}: संकेत पढ़ें | ||
** {{overline|WR}}: संकेत लिखें | ** {{overline|WR}}: संकेत लिखें | ||
| Line 36: | Line 31: | ||
* कंट्रोल वर्ड रजिस्टर में प्रोग्राम की गई जानकारी होती है जिसे ([[माइक्रोप्रोसेसर]] द्वारा) डिवाइस पर भेजा जाएगा। यह परिभाषित करता है कि पीआईटी का प्रत्येक चैनल तार्किक रूप से कैसे काम करता है। इन बंदरगाहों तक प्रत्येक पहुंच में लगभग 1 µs का समय लगता है। | * कंट्रोल वर्ड रजिस्टर में प्रोग्राम की गई जानकारी होती है जिसे ([[माइक्रोप्रोसेसर]] द्वारा) डिवाइस पर भेजा जाएगा। यह परिभाषित करता है कि पीआईटी का प्रत्येक चैनल तार्किक रूप से कैसे काम करता है। इन बंदरगाहों तक प्रत्येक पहुंच में लगभग 1 µs का समय लगता है। | ||
काउंटरों को आरंभ करने के लिए, माइक्रोप्रोसेसर को इस रजिस्टर में | काउंटरों को आरंभ करने के लिए, माइक्रोप्रोसेसर को इस रजिस्टर में नियंत्रण शब्द (सीडब्ल्यू) लिखना होगा। यह रीड/राइट लॉजिक ब्लॉक के पिन के लिए उचित मान सेट करके और फिर डेटा/बस बफर ब्लॉक में नियंत्रण शब्द भेजकर किया जा सकता है। | ||
नियंत्रण शब्द रजिस्टर में 8 बिट्स हैं, जिन्हें D7..D0 लेबल किया गया है (D7 सबसे महत्वपूर्ण बिट है)। डिकोडिंग कुछ जटिल है. अधिकांश मान तीन काउंटरों में से | नियंत्रण शब्द रजिस्टर में 8 बिट्स हैं, जिन्हें D7..D0 लेबल किया गया है (D7 सबसे महत्वपूर्ण बिट है)। डिकोडिंग कुछ जटिल है. अधिकांश मान तीन काउंटरों में से के लिए पैरामीटर सेट करते हैं: | ||
* सबसे महत्वपूर्ण दो बिट्स (यदि 11 नहीं) उस काउंटर रजिस्टर का चयन करें जिस पर कमांड लागू होता है। | * सबसे महत्वपूर्ण दो बिट्स (यदि 11 नहीं) उस काउंटर रजिस्टर का चयन करें जिस पर कमांड लागू होता है। | ||
* अगले दो बिट्स (यदि 00 नहीं हैं) उस प्रारूप का चयन करें जिसका उपयोग काउंटर रजिस्टर में बाद में पढ़ने/लिखने की पहुंच के लिए किया जाएगा। इसे आमतौर पर | * अगले दो बिट्स (यदि 00 नहीं हैं) उस प्रारूप का चयन करें जिसका उपयोग काउंटर रजिस्टर में बाद में पढ़ने/लिखने की पहुंच के लिए किया जाएगा। इसे आमतौर पर ऐसे मोड पर सेट किया जाता है जहां एक्सेस सबसे कम-महत्वपूर्ण और सबसे-महत्वपूर्ण बाइट्स के बीच वैकल्पिक होता है। 8253 और 8254 के बीच अंतर यह है कि पहले वाले में आंतरिक बिट था जो पढ़ने और लिखने दोनों को प्रभावित करता था, इसलिए यदि प्रारूप 2-बाइट पर सेट किया गया था, तो lsbyte को पढ़ने से निम्नलिखित लेखन को msbyte पर निर्देशित किया जाएगा। 8254 में पढ़ने और लिखने के लिए अलग-अलग बिट्स का उपयोग किया गया। | ||
* अगले तीन बिट्स उस मोड का चयन करें जिसमें काउंटर काम करेगा। | * अगले तीन बिट्स उस मोड का चयन करें जिसमें काउंटर काम करेगा। | ||
* सबसे कम महत्वपूर्ण बिट यह चुनता है कि काउंटर बाइनरी या [[बाइनरी-कोडित दशमलव]] में काम करेगा या नहीं। (बीसीडी गिनती लगभग कभी भी उपयोग नहीं की जाती है और इसे एमुलेटर या साउथब्रिज में ठीक से लागू नहीं किया जा सकता है।) | * सबसे कम महत्वपूर्ण बिट यह चुनता है कि काउंटर बाइनरी या [[बाइनरी-कोडित दशमलव]] में काम करेगा या नहीं। (बीसीडी गिनती लगभग कभी भी उपयोग नहीं की जाती है और इसे एमुलेटर या साउथब्रिज में ठीक से लागू नहीं किया जा सकता है।) | ||
| Line 46: | Line 41: | ||
हालाँकि, दो अन्य रूप भी हैं: | हालाँकि, दो अन्य रूप भी हैं: | ||
* किसी दिए गए टाइमर के लिए गिनती को लॉक करें। अगला रीड, रीड के समय काउंटर वैल्यू लौटाने के बजाय, लैच कमांड के पल में काउंटर वैल्यू लौटाएगा। रीड पूरा होने के बाद, बाद में पढ़ा गया वर्तमान काउंटर लौटा देगा। जब लैच कमांड का उपयोग किया जाता है, तो मोड और बीसीडी स्थिति नहीं बदली जाती है। | * किसी दिए गए टाइमर के लिए गिनती को लॉक करें। अगला रीड, रीड के समय काउंटर वैल्यू लौटाने के बजाय, लैच कमांड के पल में काउंटर वैल्यू लौटाएगा। रीड पूरा होने के बाद, बाद में पढ़ा गया वर्तमान काउंटर लौटा देगा। जब लैच कमांड का उपयोग किया जाता है, तो मोड और बीसीडी स्थिति नहीं बदली जाती है। | ||
* (केवल 8254) एकाधिक टाइमर के लिए स्थिति को लॉक करें और/या गिनती करें। यह बिटमैप का उपयोग करके | * (केवल 8254) एकाधिक टाइमर के लिए स्थिति को लॉक करें और/या गिनती करें। यह बिटमैप का उपयोग करके साथ कई लैच कमांड की अनुमति देता है। साथ ही, वर्तमान चैनल कॉन्फ़िगरेशन को गिनती के अतिरिक्त वापस पढ़ा जा सकता है। | ||
{| class="wikitable" style="text-align: center;" | {| class="wikitable" style="text-align: center;" | ||
| Line 279: | Line 274: | ||
|align=left| Read-back command applies to counter 0 | |align=left| Read-back command applies to counter 0 | ||
|} | |} | ||
पीआईटी सेट करते समय, माइक्रोप्रोसेसर पहले | पीआईटी सेट करते समय, माइक्रोप्रोसेसर पहले नियंत्रण संदेश भेजता है, फिर पीआईटी को गिनती संदेश भेजता है। गिनती की प्रक्रिया पीआईटी को ये संदेश प्राप्त होने के बाद शुरू होगी, और, कुछ मामलों में, अगर यह गेट इनपुट [[संकेत किनारा]] बढ़ते सिग्नल किनारे का पता लगाता है। | ||
स्थिति बाइट प्रारूप. बिट 7 सॉफ़्टवेयर को OUT पिन की वर्तमान स्थिति की निगरानी करने की अनुमति देता है। बिट 6 इंगित करता है कि गिनती कब पढ़ी जा सकती है; जब यह बिट 1 होता है, तो गिनती तत्व अभी तक लोड नहीं हुआ है और प्रोसेसर द्वारा वापस पढ़ा नहीं जा सकता है। बिट्स 5 से 0 नियंत्रण रजिस्टर में लिखे गए अंतिम बिट्स के समान हैं। | स्थिति बाइट प्रारूप. बिट 7 सॉफ़्टवेयर को OUT पिन की वर्तमान स्थिति की निगरानी करने की अनुमति देता है। बिट 6 इंगित करता है कि गिनती कब पढ़ी जा सकती है; जब यह बिट 1 होता है, तो गिनती तत्व अभी तक लोड नहीं हुआ है और प्रोसेसर द्वारा वापस पढ़ा नहीं जा सकता है। बिट्स 5 से 0 नियंत्रण रजिस्टर में लिखे गए अंतिम बिट्स के समान हैं। | ||
{| class="wikitable" style="text-align: center;" | {| class="wikitable" style="text-align: center;" | ||
| Line 320: | Line 315: | ||
|align=left| Counter mode bits, as defined for the control word register | |align=left| Counter mode bits, as defined for the control word register | ||
|} | |} | ||
== ऑपरेशन मोड == | == ऑपरेशन मोड == | ||
| Line 327: | Line 321: | ||
सभी मोड GATE इनपुट के प्रति संवेदनशील हैं, GATE उच्च के कारण सामान्य ऑपरेशन होता है, लेकिन GATE कम का प्रभाव मोड पर निर्भर करता है: | सभी मोड GATE इनपुट के प्रति संवेदनशील हैं, GATE उच्च के कारण सामान्य ऑपरेशन होता है, लेकिन GATE कम का प्रभाव मोड पर निर्भर करता है: | ||
* मोड 0 और 4: GATE कम होने पर गिनती निलंबित कर दी जाती है, और GATE अधिक होने पर गिनती फिर से शुरू हो जाती है। | * मोड 0 और 4: GATE कम होने पर गिनती निलंबित कर दी जाती है, और GATE अधिक होने पर गिनती फिर से शुरू हो जाती है। | ||
* मोड 1 और 5: GATE के बढ़ते किनारे की गिनती शुरू होती है। गिनती को प्रभावित किए बिना GATE नीचे जा सकता है, लेकिन | * मोड 1 और 5: GATE के बढ़ते किनारे की गिनती शुरू होती है। गिनती को प्रभावित किए बिना GATE नीचे जा सकता है, लेकिन और बढ़ती बढ़त शुरुआत से ही गिनती को फिर से शुरू कर देगी। | ||
* मोड 2 और 3: गेट लो फोर्स को तुरंत हाई आउट करें (क्लॉक पल्स की प्रतीक्षा किए बिना) और काउंटर को रीसेट करता है (अगली क्लॉक गिरने वाले किनारे पर)। जब GATE फिर से ऊपर चला जाता है, तो गिनती फिर से शुरू हो जाती है। | * मोड 2 और 3: गेट लो फोर्स को तुरंत हाई आउट करें (क्लॉक पल्स की प्रतीक्षा किए बिना) और काउंटर को रीसेट करता है (अगली क्लॉक गिरने वाले किनारे पर)। जब GATE फिर से ऊपर चला जाता है, तो गिनती फिर से शुरू हो जाती है। | ||
| Line 333: | Line 327: | ||
मोड 0 का उपयोग सॉफ्टवेयर नियंत्रण के तहत सटीक समय विलंब उत्पन्न करने के लिए किया जाता है। इस मोड में, काउंटर इसमें लोड किए गए प्रारंभिक COUNT मान से 0 तक गिनती शुरू कर देगा। गिनती दर इनपुट घड़ी आवृत्ति के बराबर है। | मोड 0 का उपयोग सॉफ्टवेयर नियंत्रण के तहत सटीक समय विलंब उत्पन्न करने के लिए किया जाता है। इस मोड में, काउंटर इसमें लोड किए गए प्रारंभिक COUNT मान से 0 तक गिनती शुरू कर देगा। गिनती दर इनपुट घड़ी आवृत्ति के बराबर है। | ||
कंट्रोल वर्ड लिखे जाने के बाद OUT पिन को कम सेट किया जाता है, और COUNT प्रोग्राम होने के बाद गिनती | कंट्रोल वर्ड लिखे जाने के बाद OUT पिन को कम सेट किया जाता है, और COUNT प्रोग्राम होने के बाद गिनती घड़ी चक्र शुरू होती है। काउंटर 0 तक पहुंचने तक OUT कम रहता है, जिस बिंदु पर OUT को तब तक उच्च सेट किया जाएगा जब तक कि काउंटर पुनः लोड न हो जाए या नियंत्रण शब्द न लिखा जाए। काउंटर चारों ओर से लपेटता है <code>0xFFFF</code> आंतरिक रूप से और गिनती जारी रहती है, लेकिन OUT पिन फिर कभी नहीं बदलता है। सामान्य गणना के लिए गेट सिग्नल को उच्च स्तर पर सक्रिय रहना चाहिए। यदि गेट नीचे चला जाता है, तो गिनती रोक दी जाती है, और फिर से ऊपर जाने पर गिनती फिर से शुरू हो जाती है। | ||
नई गिनती की पहली बाइट गिनती रजिस्टर में लोड होने पर पिछली गिनती को रोक देती है। | नई गिनती की पहली बाइट गिनती रजिस्टर में लोड होने पर पिछली गिनती को रोक देती है। | ||
=== मोड 1 (001): प्रोग्रामयोग्य | === मोड 1 (001): प्रोग्रामयोग्य शॉट === | ||
इस मोड में 8253 का उपयोग [[मोनोस्टेबल मल्टीवाइब्रेटर]] के रूप में किया जा सकता है। GATE इनपुट का उपयोग ट्रिगर इनपुट के रूप में किया जाता है। | इस मोड में 8253 का उपयोग [[मोनोस्टेबल मल्टीवाइब्रेटर]] के रूप में किया जा सकता है। GATE इनपुट का उपयोग ट्रिगर इनपुट के रूप में किया जाता है। | ||
प्रारंभ में OUT उच्च होगा। एक-शॉट पल्स शुरू करने के लिए ट्रिगर के बाद क्लॉक पल्स पर OUT कम हो जाएगा, और जब तक काउंटर शून्य तक नहीं पहुंच जाता तब तक कम रहेगा। फिर OUT उच्च स्तर पर जाएगा और अगले ट्रिगर के बाद CLK पल्स तक उच्च बना रहेगा। | प्रारंभ में OUT उच्च होगा। एक-शॉट पल्स शुरू करने के लिए ट्रिगर के बाद क्लॉक पल्स पर OUT कम हो जाएगा, और जब तक काउंटर शून्य तक नहीं पहुंच जाता तब तक कम रहेगा। फिर OUT उच्च स्तर पर जाएगा और अगले ट्रिगर के बाद CLK पल्स तक उच्च बना रहेगा। | ||
नियंत्रण शब्द और प्रारंभिक गणना लिखने के बाद, काउंटर सशस्त्र है। | नियंत्रण शब्द और प्रारंभिक गणना लिखने के बाद, काउंटर सशस्त्र है। ट्रिगर के परिणामस्वरूप काउंटर लोड होता है और अगले सीएलके पल्स पर आउट कम सेट होता है, इस प्रकार एक-शॉट पल्स शुरू होता है। एन की प्रारंभिक गणना के परिणामस्वरूप अवधि में एक-शॉट पल्स एन सीएलके चक्र प्राप्त होगा। | ||
वन-शॉट पुनः ट्रिगर करने योग्य है, इसलिए किसी भी ट्रिगर के बाद एन सीएलके पल्स के लिए आउट कम रहेगा। एक-शॉट पल्स को काउंटर में समान गिनती दोबारा लिखे बिना दोहराया जा सकता है। GATE का OUT पर कोई प्रभाव नहीं पड़ता. यदि ऑनशॉट पल्स के दौरान काउंटर पर | वन-शॉट पुनः ट्रिगर करने योग्य है, इसलिए किसी भी ट्रिगर के बाद एन सीएलके पल्स के लिए आउट कम रहेगा। एक-शॉट पल्स को काउंटर में समान गिनती दोबारा लिखे बिना दोहराया जा सकता है। GATE का OUT पर कोई प्रभाव नहीं पड़ता. यदि ऑनशॉट पल्स के दौरान काउंटर पर नई गिनती लिखी जाती है, तो वर्तमान वन-शॉट प्रभावित नहीं होता है जब तक कि काउंटर को फिर से चालू न किया जाए। उस स्थिति में, काउंटर को नई गिनती के साथ लोड किया जाता है और नई गिनती समाप्त होने तक वनशॉट पल्स जारी रहता है। | ||
=== मोड 2 (X10): दर जनरेटर === | === मोड 2 (X10): दर जनरेटर === | ||
इस मोड में, डिवाइस डिवाइड-बाय-एन काउंटर के रूप में कार्य करता है, जिसका उपयोग आमतौर पर वास्तविक समय घड़ी व्यवधान उत्पन्न करने के लिए किया जाता है। | इस मोड में, डिवाइस डिवाइड-बाय-एन काउंटर के रूप में कार्य करता है, जिसका उपयोग आमतौर पर वास्तविक समय घड़ी व्यवधान उत्पन्न करने के लिए किया जाता है। | ||
अन्य तरीकों की तरह, COUNT भेजे जाने के बाद गिनती प्रक्रिया अगला घड़ी चक्र शुरू कर देगी। तब तक OUT ऊंचा रहेगा जब तक काउंटर 1 तक नहीं पहुंच जाता, और | अन्य तरीकों की तरह, COUNT भेजे जाने के बाद गिनती प्रक्रिया अगला घड़ी चक्र शुरू कर देगी। तब तक OUT ऊंचा रहेगा जब तक काउंटर 1 तक नहीं पहुंच जाता, और क्लॉक पल्स के लिए कम हो जाएगा। अगले चक्र में, गिनती पुनः लोड की जाती है, OUT फिर से उच्च हो जाता है, और पूरी प्रक्रिया खुद को दोहराती है। | ||
उच्च दालों के बीच का समय काउंटर के रजिस्टर में पूर्व निर्धारित गिनती पर निर्भर करता है, और निम्न सूत्र का उपयोग करके गणना की जाती है: | उच्च दालों के बीच का समय काउंटर के रजिस्टर में पूर्व निर्धारित गिनती पर निर्भर करता है, और निम्न सूत्र का उपयोग करके गणना की जाती है: | ||
| Line 369: | Line 363: | ||
यह मोड मोड 4 के समान है। हालाँकि, गिनती प्रक्रिया GATE इनपुट द्वारा ट्रिगर होती है। | यह मोड मोड 4 के समान है। हालाँकि, गिनती प्रक्रिया GATE इनपुट द्वारा ट्रिगर होती है। | ||
कंट्रोल वर्ड और COUNT प्राप्त करने के बाद, आउटपुट हाई सेट कर दिया जाएगा। | कंट्रोल वर्ड और COUNT प्राप्त करने के बाद, आउटपुट हाई सेट कर दिया जाएगा। बार जब डिवाइस GATE इनपुट पर बढ़ते किनारे का पता लगा लेता है, तो यह गिनती शुरू कर देगा। जब काउंटर 0 पर पहुंचता है, तो आउटपुट घड़ी चक्र के लिए कम हो जाएगा - उसके बाद यह GATE के अगले बढ़ते किनारे पर चक्र को दोहराने के लिए फिर से उच्च हो जाएगा। | ||
== आईबीएम पीसी प्रोग्रामिंग == | == आईबीएम पीसी प्रोग्रामिंग == | ||
8253 का उपयोग 1981 में उनकी शुरूआत के बाद से आईबीएम पीसी संगतों में किया गया था।<ref>{{cite web |url=http://www.microsoft.com/whdc/system/sysinternals/mm-timer.mspx |title=मल्टीमीडिया टाइमर समर्थन प्रदान करने के लिए दिशानिर्देश|website=[[Microsoft]] |date=20 September 2002 |accessdate=2010-10-13}}</ref> आधुनिक समय में, इस PIT को x[[86]] PC में | 8253 का उपयोग 1981 में उनकी शुरूआत के बाद से आईबीएम पीसी संगतों में किया गया था।<ref>{{cite web |url=http://www.microsoft.com/whdc/system/sysinternals/mm-timer.mspx |title=मल्टीमीडिया टाइमर समर्थन प्रदान करने के लिए दिशानिर्देश|website=[[Microsoft]] |date=20 September 2002 |accessdate=2010-10-13}}</ref> आधुनिक समय में, इस PIT को x[[86]] PC में अलग चिप के रूप में शामिल नहीं किया गया है। बल्कि, इसकी कार्यक्षमता मदरबोर्ड चिपसेट के साउथब्रिज (कंप्यूटिंग) के हिस्से के रूप में शामिल है। आधुनिक चिपसेट में, यह परिवर्तन x86 I/O एड्रेस स्पेस में PIT के रजिस्टरों तक काफ़ी तेज़ पहुंच के रूप में दिखाई दे सकता है। | ||
सभी पीसी संगत पीआईटी को 105/88 = 1.193 की क्लॉक दर पर संचालित करते हैं{{overline|18}} मेगाहर्ट्ज, {{frac|3}} [[एनटीएससी]] [[ रंग-विस्फोट ]] फ्रीक्वेंसी जो सिस्टम क्लॉक (14.31818 मेगाहर्ट्ज) को 12 से विभाजित करने से आती है। यह सबसे पहले [[ रंग ग्राफ़िक्स एडाप्टर ]] पीसी का होल्डओवर है - उन्होंने | सभी पीसी संगत पीआईटी को 105/88 = 1.193 की क्लॉक दर पर संचालित करते हैं{{overline|18}} मेगाहर्ट्ज, {{frac|3}} [[एनटीएससी]] [[ रंग-विस्फोट ]] फ्रीक्वेंसी जो सिस्टम क्लॉक (14.31818 मेगाहर्ट्ज) को 12 से विभाजित करने से आती है। यह सबसे पहले [[ रंग ग्राफ़िक्स एडाप्टर ]] पीसी का होल्डओवर है - उन्होंने ही [[क्रिस्टल थरथरानवाला]] से सभी आवश्यक आवृत्तियों को प्राप्त किया, और टीवी आउटपुट को संभव बनाने के लिए, इस ऑसिलेटर को एनटीएससी रंग सबकैरियर आवृत्ति के गुणक पर चलाना था। यह आवृत्ति, 2 से विभाजित है<sup>16</sup> (सबसे बड़ा विभाजक जो 8253 सक्षम है) [[MS-DOS]] और संबंधित ऑपरेटिंग सिस्टम में उपयोग किए जाने वाले ≈18.2 Hz टाइमर इंटरप्ट का उत्पादन करता है। | ||
मूल आईबीएम पीसी में, काउंटर 0 का उपयोग टाइमकीपिंग व्यवधान उत्पन्न करने के लिए किया जाता है। काउंटर 1 का उपयोग [[DRAM]] मेमोरी के रिफ्रेश को ट्रिगर करने के लिए किया जाता है। काउंटर 2 का उपयोग पीसी स्पीकर के माध्यम से टोन उत्पन्न करने के लिए किया जाता है। | मूल आईबीएम पीसी में, काउंटर 0 का उपयोग टाइमकीपिंग व्यवधान उत्पन्न करने के लिए किया जाता है। काउंटर 1 का उपयोग [[DRAM]] मेमोरी के रिफ्रेश को ट्रिगर करने के लिए किया जाता है। काउंटर 2 का उपयोग पीसी स्पीकर के माध्यम से टोन उत्पन्न करने के लिए किया जाता है। | ||
नए मदरबोर्ड में [[उन्नत कॉन्फ़िगरेशन और पावर इंटरफ़ेस]] (एसीपीआई) के माध्यम से अतिरिक्त काउंटर, स्थानीय उन्नत प्रोग्रामयोग्य इंटरप्ट कंट्रोलर पर | नए मदरबोर्ड में [[उन्नत कॉन्फ़िगरेशन और पावर इंटरफ़ेस]] (एसीपीआई) के माध्यम से अतिरिक्त काउंटर, स्थानीय उन्नत प्रोग्रामयोग्य इंटरप्ट कंट्रोलर पर काउंटर और [[उच्च परिशुद्धता इवेंट टाइमर]] शामिल हैं। [[ CPU ]] ही [[टाइम स्टाम्प काउंटर]] की सुविधा भी प्रदान करता है। | ||
पीसी पर टाइमर0 (चिप) का पता पोर्ट 40h..43h पर है और दूसरे टाइमर1 (चिप) का पता 50h..53h पर है। | पीसी पर टाइमर0 (चिप) का पता पोर्ट 40h..43h पर है और दूसरे टाइमर1 (चिप) का पता 50h..53h पर है। | ||
| Line 385: | Line 379: | ||
x86 पीसी पर, कई वीडियो कार्ड BIOS और सिस्टम BIOS अपने स्वयं के उपयोग के लिए दूसरे काउंटर को पुन: प्रोग्राम करेंगे। रीप्रोग्रामिंग आम तौर पर वीडियो मोड में बदलाव के दौरान होती है, जब वीडियो BIOS निष्पादित किया जा सकता है, और सिस्टम प्रबंधन मोड और पावर सेविंग स्थिति में परिवर्तन के दौरान, जब सिस्टम BIOS निष्पादित किया जा सकता है। यह कई x86 सिस्टमों पर टाइमर के दूसरे काउंटर के किसी भी गंभीर वैकल्पिक उपयोग को रोकता है। | x86 पीसी पर, कई वीडियो कार्ड BIOS और सिस्टम BIOS अपने स्वयं के उपयोग के लिए दूसरे काउंटर को पुन: प्रोग्राम करेंगे। रीप्रोग्रामिंग आम तौर पर वीडियो मोड में बदलाव के दौरान होती है, जब वीडियो BIOS निष्पादित किया जा सकता है, और सिस्टम प्रबंधन मोड और पावर सेविंग स्थिति में परिवर्तन के दौरान, जब सिस्टम BIOS निष्पादित किया जा सकता है। यह कई x86 सिस्टमों पर टाइमर के दूसरे काउंटर के किसी भी गंभीर वैकल्पिक उपयोग को रोकता है। | ||
जैसा कि ऊपर कहा गया है, चैनल 0 को | जैसा कि ऊपर कहा गया है, चैनल 0 को काउंटर के रूप में लागू किया गया है। आमतौर पर, काउंटर का प्रारंभिक मान कंट्रोल को बाइट्स भेजकर सेट किया जाता है, फिर डेटा I/O पोर्ट रजिस्टर करता है (36h का मान पोर्ट 43h पर भेजा जाता है, फिर कम बाइट पोर्ट 40h पर भेजा जाता है, और उच्च बाइट के लिए फिर से पोर्ट 40h भेजा जाता है) . काउंटर शून्य तक गिनती करता है, फिर सीपीयू को [[ हार्डवेयर व्यवधान ]] (आईआरक्यू 0, आईएनटी 8) भेजता है। फिर काउंटर अपने प्रारंभिक मूल्य पर रीसेट हो जाता है और फिर से उलटी गिनती शुरू कर देता है। सबसे तेज़ संभव व्यवधान आवृत्ति मेगाहर्ट्ज़ के आधे से थोड़ा अधिक है। सबसे धीमी संभावित आवृत्ति, जो आमतौर पर MS-DOS या संगत ऑपरेटिंग सिस्टम चलाने वाले कंप्यूटरों द्वारा उपयोग की जाती है, लगभग 18.2 Hz है। इन वास्तविक मोड ऑपरेटिंग सिस्टम के तहत, BIOS वास्तविक मोड पते 0040:006c में प्राप्त होने वाली INT 8 कॉल की संख्या जमा करता है, जिसे प्रोग्राम द्वारा पढ़ा जा सकता है। | ||
जैसे ही टाइमर उलटी गिनती करता है, इसके मूल्य को सीधे इसके I/O पोर्ट को दो बार पढ़कर भी पढ़ा जा सकता है, पहले कम बाइट के लिए, और फिर उच्च बाइट के लिए। हालाँकि, फ्री-रनिंग काउंटर एप्लिकेशन जैसे कि x86 पीसी में, पहले नियंत्रण रजिस्टर में वांछित चैनल के लिए [[ कुंडी (इलेक्ट्रॉनिक्स) ]] कमांड लिखना आवश्यक है, ताकि पढ़े गए दोनों बाइट्स ही मान के हों। | |||
2002 के माइक्रोसॉफ्ट दस्तावेज़ के अनुसार, क्योंकि इस हार्डवेयर [8254] को पढ़ने और लिखने के लिए आईओ पोर्ट के माध्यम से संचार की आवश्यकता होती है, प्रोग्रामिंग में कई चक्र लगते हैं, जो ओएस के लिए अत्यधिक महंगा है। इस वजह से, व्यवहार में एपेरियोडिक कार्यक्षमता का उपयोग नहीं किया जाता है।<ref>[http://msdn.microsoft.com/en-us/library/windows/hardware/gg463347.aspx Guidelines For Providing Multimedia Timer Support]</ref> | |||
== यह भी देखें == | == यह भी देखें == | ||
* [[LAPIC]] | * [[LAPIC]] प्रोग्रामयोग्य टाइमर प्रदान करता है | ||
*[[एचपीईटी]] | *[[एचपीईटी]] | ||
== संदर्भ == | == संदर्भ == | ||
{{Reflist}} | {{Reflist}} | ||
== अग्रिम पठन == | == अग्रिम पठन == | ||
*{{cite book |last1=Gilluwe |first1=Frank Van |title=The Undocumented PC: A Programmer's Guide to I/O, CPUs, and Fixed Memory Areas |date=1997 |publisher=Addison-Wesley |isbn=978-0-201-47950-8 |edition=second, illustrated|url=https://books.google.com/books?id=WEiJQgAACAAJ}} | *{{cite book |last1=Gilluwe |first1=Frank Van |title=The Undocumented PC: A Programmer's Guide to I/O, CPUs, and Fixed Memory Areas |date=1997 |publisher=Addison-Wesley |isbn=978-0-201-47950-8 |edition=second, illustrated|url=https://books.google.com/books?id=WEiJQgAACAAJ}} | ||
== बाहरी संबंध == | == बाहरी संबंध == | ||
* [http://bochs.sourceforge.net/techspec/intel-82c54-timer.pdf.gz 82C54 Datasheet] | * [http://bochs.sourceforge.net/techspec/intel-82c54-timer.pdf.gz 82C54 Datasheet] | ||
Revision as of 17:13, 7 December 2023
Error creating thumbnail:
इंटेल C8253
File:Intel 8253 and 8254.svg
इंटेल 8253 प्रोग्रामयोग्य अंतराल टाइमर। Intel 8254 में समान पिनआउट है।
इंटेल 8253 और 8254 प्रोग्रामयोग्य अंतराल टाइमर (पीआईटी) हैं, जो तीन 16-बिट काउंटर का उपयोग करके समय और गिनती कार्य करते हैं।[1]