मास्टर बूट रिकॉर्ड

एक मास्टर बूट रिकॉर्ड (एमबीआर) एक विशेष प्रकार का बूट क्षेत्र है जो आईबीएम पीसी-संगत और उससे आगे के उपयोग के लिए निश्चित डिस्क या हटाने योग्य ड्राइव जैसे विभाजित कंप्यूटर मॉस स्टोरेज उपकरण की शुरुआत में होता है। MBRs की अवधारणा को 1983 में PC DOS 2.0 के साथ सार्वजनिक रूप से पेश किया गया था।

एमबीआर में यह जानकारी होती है कि कैसे डिस्क के क्षेत्रों को विभाजन में विभाजित किया जाता है, प्रत्येक विभाजन में एक फाइल सिस्टम होता है। एमबीआर में स्थापित ऑपरेटिंग सिस्टम के लिए लोडर के रूप में कार्य करने के लिए निष्पादन योग्य कोड भी होता है - आमतौर पर लोडर के दूसरे चरण पर नियंत्रण पारित करके, या प्रत्येक विभाजन के वॉल्यूम बूट रिकॉर्ड (वीबीआर) के संयोजन के साथ। यह एमबीआर कोड आमतौर पर बूट लोडर के रूप में जाना जाता है।

MBR में विभाजन तालिका का संगठन एक विभाजित डिस्क के अधिकतम पता योग्य भंडारण स्थान को 2 टेबिबाइट (232 × 512 बाइट्स) तक सीमित करता है। 32-बिट अंकगणित या 4096-बाइट सेक्टर मानते हुए इस सीमा को थोड़ा बढ़ाने के दृष्टिकोण आधिकारिक रूप से समर्थित नहीं हैं, क्योंकि वे मौजूदा बूट लोडर और अधिकांश एमबीआर-अनुरूप ऑपरेटिंग सिस्टम और सिस्टम टूल्स के साथ अनुकूलता को तोड़ते हैं, और बाहर उपयोग किए जाने पर गंभीर डेटा भ्रष्टाचार का कारण बन सकते हैं। संकीर्ण रूप से नियंत्रित सिस्टम वातावरण। इसलिए, MBR-आधारित विभाजन योजना नए कंप्यूटरों में GUID विभाजन तालिका (GPT) योजना द्वारा प्रतिस्थापित किए जाने की प्रक्रिया में है। पुराने सिस्टम के लिए बैकवर्ड कम्पैटिबिलिटी का कुछ सीमित रूप प्रदान करने के लिए एक GPT एक MBR के साथ सह-अस्तित्व में हो सकता है।

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

अवलोकन
मार्च 1983 में IBM PC DOS 2.0 के साथ विभाजित मीडिया के लिए समर्थन, और इस तरह मास्टर बूट रिकॉर्ड (MBR) पेश किया गया था, ताकि तत्कालीन नए IBM पर्सनल कंप्यूटर XT की 10 एमबी हार्ड डिस्क का समर्थन किया जा सके, जो अभी भी FAT12 फ़ाइल सिस्टम का उपयोग कर रहा है।. MBR का मूल संस्करण IBM के डेविड लिटन द्वारा जून 1982 में लिखा गया था। विभाजन तालिका चार प्राथमिक विभाजनों तक का समर्थन करती है, जिनमें से DOS केवल एक का उपयोग कर सकता है। यह तब नहीं बदला जब FAT16 को DOS 3.0 के साथ एक नई फाइल सिस्टम के रूप में पेश किया गया। विस्तारित विभाजन के लिए समर्थन, अन्य विभाजनों को रखने के लिए कंटेनर के रूप में उपयोग किया जाने वाला एक विशेष प्राथमिक विभाजन प्रकार, DOS 3.2 के साथ जोड़ा गया था, और एक विस्तारित विभाजन के अंदर नेस्टेड लॉजिकल ड्राइव DOS 3.30 के साथ आया था। चूंकि MS-DOS, PC DOS, OS/2 और Windows कभी भी उन्हें बूट करने के लिए सक्षम नहीं थे, MBR प्रारूप और बूट कोड कार्यक्षमता में लगभग अपरिवर्तित रहे, कुछ तृतीय-पक्ष कार्यान्वयनों को छोड़कर, DOS और OS/ के पूरे युग में 2 1996 तक।

1996 में, 8 जीबी से बड़े डिस्क का समर्थन करने के लिए विंडोज 95बी और डॉस 7.10 में तार्किक ब्लॉक एड्रेसिंग (एलबीए) के लिए समर्थन पेश किया गया था। डिस्क टाइमस्टैम्प भी पेश किए गए थे। यह इस विचार को भी दर्शाता है कि एमबीआर ऑपरेटिंग सिस्टम और फाइल सिस्टम स्वतंत्र होने के लिए है। हालाँकि, MBR के हालिया Microsoft कार्यान्वयन में इस डिज़ाइन नियम को आंशिक रूप से समझौता किया गया था, जो FAT16B और FAT32 विभाजन प्रकार 0x06/0x0B के लिए सिलेंडर-हेड-सेक्टर पहुँच को लागू करता है, जबकि LBA का उपयोग 0x0E/0x0C के लिए किया जाता है।

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

एमबीआर विभाजन प्रविष्टियां और वाणिज्यिक ऑपरेटिंग सिस्टम में उपयोग किए जाने वाले एमबीआर बूट कोड, हालांकि, 32 बिट्स तक सीमित हैं। इसलिए, एमबीआर विभाजन योजना (33-बिट अंकगणित के बिना) द्वारा 512-बाइट क्षेत्रों (चाहे वास्तविक या नकली) का उपयोग करने वाले डिस्क पर समर्थित अधिकतम डिस्क आकार 2 टीआईबी तक सीमित है। नतीजतन, बड़ी डिस्क के लिए एक अलग विभाजन योजना का उपयोग किया जाना चाहिए, क्योंकि वे 2010 से व्यापक रूप से उपलब्ध हो गए हैं। एमबीआर विभाजन योजना इसलिए GUID विभाजन तालिका (GPT) द्वारा अधिक्रमित होने की प्रक्रिया में है। आधिकारिक दृष्टिकोण सुरक्षात्मक एमबीआर को नियोजित करके डेटा अखंडता सुनिश्चित करने से थोड़ा अधिक है। विशेष रूप से, यह ऑपरेटिंग सिस्टम के साथ पश्चगामी संगतता प्रदान नहीं करता है जो GPT योजना का भी समर्थन नहीं करता है। इस बीच, दोनों विभाजन योजनाओं में "समानांतर" और/या पुराने ऑपरेटिंग सिस्टम को जीपीटी से बूट करने की अनुमति देने के लिए डिस्क के पहले भौतिक 2 टीआईबी में स्थित विभाजन को बनाए रखने के लिए हाइब्रिड एमबीआर के कई रूपों को तीसरे पक्ष द्वारा डिजाइन और कार्यान्वित किया गया है। विभाजन भी। इन समाधानों की वर्तमान गैर-मानक प्रकृति कुछ परिदृश्यों में विभिन्न अनुकूलता समस्याओं का कारण बनती है।

MBR में ड्राइव के पहले डिस्क क्षेत्र में स्थित 512 या अधिक बाइट होते हैं।

इसमें इनमें से एक या अधिक हो सकते हैं:
 * स्टोरेज डिवाइस के विभाजन का वर्णन करने वाली एक विभाजन तालिका। इस संदर्भ में बूट सेक्टर को पार्टीशन सेक्टर भी कहा जा सकता है।
 * बूटस्ट्रैप कोड : कॉन्फ़िगर किए गए बूट करने योग्य विभाजन की पहचान करने के निर्देश, फिर एक चेन लोडर के रूप में इसके वॉल्यूम बूट रिकॉर्ड (VBR) को लोड और निष्पादित करें।
 * वैकल्पिक 32-बिट डिस्क टाइमस्टैम्प।
 * वैकल्पिक 32-बिट डिस्क हस्ताक्षर।

डिस्क विभाजन
आईबीएम पीसी डॉस 2.0 ने एमबीआर विभाजन को स्थापित करने और बनाए रखने के लिए  उपयोगिता की शुरुआत की। जब एक स्टोरेज डिवाइस को इस योजना के अनुसार विभाजित किया जाता है, तो इसके MBR में एक विभाजन तालिका होती है, जो विभाजन के रूप में संदर्भित रैखिक क्षेत्रों के स्थान, आकार और अन्य विशेषताओं का वर्णन करती है।

अधिक जटिल विभाजन योजनाओं, जैसे कि विस्तारित बूट रिकॉर्ड (EBRs), BSD डिस्कलेबल, या तार्किक डिस्क प्रबंधक मेटाडेटा विभाजन का वर्णन करने के लिए स्वयं विभाजन में भी डेटा हो सकता है।

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

सेक्टर लेआउट
परिपाटी के अनुसार, एमबीआर विभाजन तालिका योजना में बिल्कुल चार प्राथमिक विभाजन तालिका प्रविष्टियाँ हैं, हालाँकि कुछ ऑपरेटिंग सिस्टम और सिस्टम टूल्स ने इसे पाँच तक बढ़ा दिया है (उन्नत सक्रिय विभाजन (AAP) PTS-DOS 6.60 और DR-DOS 7.07 के साथ), आठ (AST Research और NEC MS-DOS 3.x  और साथ ही   स्पीडस्टोर स्टोरेज डायमेंशन स्पीडस्टोर), या सोलह प्रविष्टियाँ (ऑनट्रैक डिस्क मैनेजर के साथ)।

विभाजन तालिका प्रविष्टियाँ
{| class="wikitable" style="float: right; width: 33%; margin: 1em;" ! colspan="2" style="text-align: center;" | Offset (bytes) !! Field length !! Description
 * + Layout of one 16-byte partition entry (all multi-byte fields are little-endian)
 * 0x00 || || 1 byte || Status or physical drive (bit 7 set is for active or bootable, old MBRs only accept 0x80, 0x00 means inactive, and 0x01–0x7F stand for invalid)
 * 0x01 || || 3 bytes || CHS address of first absolute sector in partition. The format is described by three bytes, see the next three rows.
 * || 0x01 || 1 byte ||
 * || 0x02 || 1 बाइट ||
 * || 0x03 || 1 बाइट ||
 * 0x04 || || 1 बाइट | |-
 * 0x05 || || 3 बाइट || विभाजन में अंतिम निरपेक्ष क्षेत्र का सिलेंडर-हेड-सेक्टर। प्रारूप 3 बाइट्स द्वारा वर्णित है, अगली 3 पंक्तियाँ देखें।
 * || 0x05 || 1 बाइट ||
 * || 0x03 || 1 बाइट ||
 * 0x04 || || 1 बाइट | |-
 * 0x05 || || 3 बाइट || विभाजन में अंतिम निरपेक्ष क्षेत्र का सिलेंडर-हेड-सेक्टर। प्रारूप 3 बाइट्स द्वारा वर्णित है, अगली 3 पंक्तियाँ देखें।
 * || 0x05 || 1 बाइट ||
 * 0x05 || || 3 बाइट || विभाजन में अंतिम निरपेक्ष क्षेत्र का सिलेंडर-हेड-सेक्टर। प्रारूप 3 बाइट्स द्वारा वर्णित है, अगली 3 पंक्तियाँ देखें।
 * || 0x05 || 1 बाइट ||
 * || 0x05 || 1 बाइट ||


 * || 0x06 || 1 बाइट ||
 * || 0x06 || 1 बाइट ||


 * || 0x07 || 1 बाइट ||
 * || 0x07 || 1 बाइट ||


 * 0x08 || || 4 बाइट || विभाजन में पहले निरपेक्ष सेक्टर का तार्किक ब्लॉक एड्रेसिंग
 * 0x0C || || 4 बाइट || विभाजन में क्षेत्रों की संख्या
 * }
 * 0x0C || || 4 बाइट || विभाजन में क्षेत्रों की संख्या
 * }

पीसी एक्सटी के युग से हार्ड डिस्क प्रौद्योगिकी का एक आर्टिफैक्ट, विभाजन तालिका सिलेंडर (डिस्क ड्राइव), डिस्क रीड-एंड-राइट हेड और सेक्टर (सीएचएस एड्रेसिंग) की इकाइयों का उपयोग करके भंडारण माध्यम को उप-विभाजित करती है। ये मान अब आधुनिक डिस्क ड्राइव में उनके हमनाम के अनुरूप नहीं हैं, साथ ही ठोस-राज्य ड्राइव जैसे अन्य उपकरणों में अप्रासंगिक हैं, जिनमें भौतिक रूप से सिलेंडर या हेड नहीं होते हैं।

सीएचएस योजना में, सेक्टर इंडेक्स (लगभग) हमेशा सेक्टर 0 के बजाय सेक्टर 1 के साथ शुरू होता है, और MS-DOS/PC DOS के सभी संस्करणों में त्रुटि के कारण 7.10 तक, हेड्स की संख्या आम तौर पर सीमित होती है 256 के बजाय 255। जब इन क्षेत्रों में फ़िट होने के लिए एक सीएचएस पता बहुत बड़ा होता है, तो टपल (1023, 254, 63) आज आमतौर पर उपयोग किया जाता है, हालांकि पुराने सिस्टम पर, और पुराने डिस्क टूल्स के साथ, सिलेंडर वैल्यू अक्सर मॉड्यूलो के चारों ओर 8 जीबी के करीब सीएचएस बैरियर लपेटा जाता है, जिससे अस्पष्टता और डेटा भ्रष्टाचार का जोखिम होता है। (यदि स्थिति में GPT के साथ डिस्क पर "सुरक्षात्मक" MBR शामिल है, तो Intel के एक्स्टेंसिबल फ़र्मवेयर इंटरफ़ेस विनिर्देश के लिए आवश्यक है कि टपल (1023, 255, 63) का उपयोग किया जाए।) 10-बिट सिलेंडर मान क्रम में दो बाइट्स के भीतर दर्ज किया गया है मूल/विरासत INT 13h BIOS डिस्क एक्सेस रूटीन में कॉल करने की सुविधा के लिए, जहां 16 बिट्स को सेक्टर और सिलेंडर भागों में विभाजित किया गया था, न कि बाइट सीमाओं पर।

सीएचएस एड्रेसिंग की सीमाओं के कारण, एलबीए, या लॉजिकल ब्लॉक एड्रेसिंग का उपयोग करने के लिए एक संक्रमण किया गया था। विभाजन की लंबाई और विभाजन प्रारंभ पता दोनों विभाजन तालिका प्रविष्टियों में 32-बिट मात्रा के रूप में संग्रहीत क्षेत्र मान हैं। क्षेत्र का आकार 512 (29) बाइट्स पर निश्चित माना जाता था, और चिपसेट, बूट सेक्टर, ऑपरेटिंग सिस्टम, डेटाबेस इंजन, विभाजन उपकरण, बैकअप और फाइल सिस्टम उपयोगिताओं और अन्य सॉफ़्टवेयर सहित महत्वपूर्ण घटकों की एक विस्तृत श्रृंखला का यह मान कठिन था- कोडित। 2009 के अंत से, 4096-बाइट सेक्टरों (4Kn या उन्नत प्रारूप) को नियोजित करने वाले डिस्क ड्राइव उपलब्ध हैं, हालांकि इनमें से कुछ ड्राइव के लिए सेक्टर का आकार अभी भी 512 बाइट्स के रूप में हार्ड-में रूपांतरण के माध्यम से होस्ट सिस्टम को रिपोर्ट किया गया था। ड्राइव फर्मवेयर और 512 एमुलेशन ड्राइव ((512e) के रूप में संदर्भित।

चूंकि ब्लॉक पते और आकार 32 बिट्स का उपयोग करके MBR की विभाजन तालिका में संग्रहीत किए जाते हैं, अधिकतम आकार, साथ ही उच्चतम प्रारंभ पता, 512-बाइट सेक्टर (वास्तविक या अनुकरणीय) वाले ड्राइव का उपयोग करने वाले विभाजन का 2 TiB से अधिक नहीं हो सकता है। −512 बाइट्स (2199023255040 बाइट्स या 4294967295 (232−1) सेक्टर × 512 (29) बाइट्स प्रति सेक्टर)। इस क्षमता सीमा को कम करना जीपीटी के विकास के लिए प्रमुख प्रेरणाओं में से एक था।

चूंकि विभाजन जानकारी एमबीआर विभाजन तालिका में शुरुआती ब्लॉक पते और लंबाई का उपयोग करके संग्रहीत की जाती है, इसलिए सिद्धांत रूप में विभाजन को इस तरह से परिभाषित करना संभव हो सकता है कि 512-बाइट क्षेत्रों के साथ डिस्क के लिए आवंटित स्थान कुल आकार 4 देता है। TiB, यदि एक को छोड़कर सभी विभाजन 2 TiB सीमा से नीचे स्थित हैं और अंतिम विभाजन को 232−1 को शुरू करने या बंद करने के रूप में निर्दिष्ट किया गया है और 232−1 तक के आकार को निर्दिष्ट करता है, जिससे एक विभाजन को परिभाषित किया जाता है जिसके लिए 33 की बजाय आवश्यकता होती है एक्सेस किए जाने वाले सेक्टर एड्रेस के लिए 32 बिट्स। हालाँकि, व्यवहार में, केवल कुछ LBA-48-सक्षम ऑपरेटिंग सिस्टम, जिसमें Linux, FreeBSD और Windows 7 शामिल हैं, जो 64-बिट सेक्टर पतों का आंतरिक रूप से उपयोग करते हैं, वास्तव में इसका समर्थन करते हैं। कोड स्थान की कमी और एमबीआर विभाजन तालिका की प्रकृति के कारण केवल 32 बिट्स, बूट सेक्टरों का समर्थन करने के लिए, भले ही एलबीए-28 के बजाय एलबीए-48 का समर्थन करने के लिए सक्षम किया गया हो, अक्सर 32-बिट गणनाओं का उपयोग करते हैं, जब तक कि वे विशेष रूप से समर्थन करने के लिए डिज़ाइन नहीं किए जाते हैं LBA-48 की पूर्ण पता श्रेणी या केवल 64-बिट प्लेटफॉर्म पर चलने का इरादा है। आंतरिक रूप से 32-बिट सेक्टर पतों का उपयोग करने वाला कोई भी बूट कोड या ऑपरेटिंग सिस्टम पतों को इस विभाजन तक पहुँचने के लिए चारों ओर लपेट देगा और इसके परिणामस्वरूप सभी विभाजनों पर गंभीर डेटा भ्रष्टाचार होगा।

डिस्क के लिए जो 512 बाइट्स के अलावा एक सेक्टर आकार प्रस्तुत करता है, जैसे USB बाहरी ड्राइव, वहाँ भी सीमाएँ हैं। 4096 के एक सेक्टर आकार के परिणामस्वरूप एक विभाजन के आकार में आठ गुना वृद्धि होती है जिसे MBR का उपयोग करके परिभाषित किया जा सकता है, जिससे आकार में 16 TiB (232 × 4096 बाइट्स) तक के विभाजन की अनुमति मिलती है। Windows XP की तुलना में हाल के संस्करण बड़े सेक्टर आकारों के साथ-साथ Mac OS X का समर्थन करते हैं, और लिनक्स ने 2.6.31 या 2.6.32, के बाद से बड़े सेक्टर आकारों का समर्थन किया है, लेकिन बूट लोडर, विभाजन के साथ समस्याएँ उपकरण और कंप्यूटर BIOS कार्यान्वयन कुछ सीमाएँ प्रस्तुत करते हैं, क्योंकि वे अक्सर सेक्टर बफ़र्स के लिए केवल 512 बाइट्स आरक्षित करने के लिए हार्ड-वायर्ड होते हैं, जिससे मेमोरी बड़े सेक्टर आकारों के लिए अधिलेखित हो जाती है। इससे अप्रत्याशित व्यवहार भी हो सकता है, और इसलिए जब अनुकूलता और मानक अनुरूपता एक मुद्दा हो तो इससे बचना चाहिए।

जहां एक डेटा स्टोरेज डिवाइस को GPT योजना के साथ विभाजित किया गया है, मास्टर बूट रिकॉर्ड में अभी भी एक विभाजन तालिका होगी, लेकिन इसका एकमात्र उद्देश्य GPT के अस्तित्व को इंगित करना और केवल MBR विभाजन तालिका योजना को समझने वाले उपयोगिता कार्यक्रमों को रोकना है। डिस्क पर मुक्त स्थान के रूप में वे अन्यथा जो देखेंगे, उसमें कोई भी विभाजन बनाना, जिससे गलती से GPT मिटा दिया जाएगा।

सिस्टम बूटस्ट्रैपिंग
आईबीएम पीसी-संगत कंप्यूटरों पर, बूटस्ट्रैपिंग फर्मवेयर (रीड ऑनली मैमोरी BIOS के भीतर निहित) मास्टर बूट रिकॉर्ड को लोड और निष्पादित करता है। PC/XT (टाइप 5160) ने Intel 8088 कंप्यूटर प्रोसेसर का उपयोग किया। संगत बने रहने के लिए, सभी x86 आर्किटेक्चर सिस्टम एक ऑपरेटिंग मोड में माइक्रोप्रोसेसर से शुरू होते हैं जिसे वास्तविक मोड कहा जाता है। BIOS MBR को स्टोरेज डिवाइस से भौतिक मेमोरी में पढ़ता है, और फिर यह माइक्रोप्रोसेसर को बूट कोड की शुरुआत के लिए निर्देशित करता है। चूंकि BIOS वास्तविक मोड में चलता है, जब MBR प्रोग्राम निष्पादित होना शुरू होता है तो प्रोसेसर वास्तविक मोड में होता है, और इसलिए MBR की शुरुआत में वास्तविक-मोड मशीन कोड शामिल होने की उम्मीद है।

चूंकि BIOS बूटस्ट्रैप रूटीन लोड करता है और भौतिक डिस्क से ठीक एक सेक्टर चलाता है, बूट कोड के साथ MBR में विभाजन तालिका होने से MBR प्रोग्राम के डिज़ाइन को सरल करता है। इसमें एक छोटा प्रोग्राम होता है जो लक्षित विभाजन के वॉल्यूम बूट रिकॉर्ड (वीबीआर) को लोड करता है। नियंत्रण तब इस कोड को दिया जाता है, जो वास्तविक ऑपरेटिंग सिस्टम को लोड करने के लिए जिम्मेदार होता है। इस प्रक्रिया को चेन लोडिंग के रूप में जाना जाता है।

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

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

उन मशीनों पर जो x86 प्रोसेसर का उपयोग नहीं करते हैं, या x86 मशीनों पर गैर-BIOS फ़र्मवेयर जैसे कि ओपन फ़र्मवेयर या एक्स्टेंसिबल फ़र्मवेयर इंटरफ़ेस (EFI) फ़र्मवेयर, यह डिज़ाइन अनुपयुक्त है, और MBR सिस्टम बूटस्ट्रैप के हिस्से के रूप में उपयोग नहीं किया जाता है। इसके बजाय EFI फर्मवेयर सीधे GPT विभाजन योजना और FAT फाइल सिस्टम प्रारूप को समझने में सक्षम है, और EFI सिस्टम विभाजन में फाइलों के रूप में रखे प्रोग्राम को लोड और चलाता है। यदि GPT विभाजन तालिका योजना का उपयोग किया गया है, तो MBR केवल उसी हद तक शामिल होगा, जिसमें संगतता उद्देश्यों के लिए एक विभाजन तालिका शामिल हो सकती है।

कुछ एमबीआर प्रतिस्थापन कोड है जो ईएफआई फर्मवेयर के बूटस्ट्रैप का अनुकरण करता है, जो गैर-ईएफआई मशीनों को जीपीटी विभाजन योजना का उपयोग करके डिस्क से बूट करने में सक्षम बनाता है। यह एक GPT का पता लगाता है, प्रोसेसर को सही ऑपरेटिंग मोड में रखता है, और इस कार्य को पूरा करने के लिए EFI संगत कोड को डिस्क से लोड करता है।

डिस्क पहचान
बूटस्ट्रैप कोड और विभाजन तालिका के अतिरिक्त, मास्टर बूट रिकॉर्ड में डिस्क हस्ताक्षर हो सकते हैं। यह एक 32-बिट मान है जिसका उद्देश्य विशिष्ट रूप से डिस्क माध्यम की पहचान करना है (जैसा कि डिस्क इकाई के विपरीत है - दो आवश्यक रूप से हटाने योग्य हार्ड डिस्क के लिए समान नहीं हैं)।

डिस्क हस्ताक्षर विंडोज एनटी संस्करण 3.5 द्वारा पेश किया गया था, लेकिन अब इसका उपयोग कई ऑपरेटिंग सिस्टमों द्वारा किया जाता है, जिसमें लिनक्स कर्नेल संस्करण 2.6 और बाद में शामिल है। Linux उपकरण NT डिस्क हस्ताक्षर का उपयोग यह निर्धारित करने के लिए कर सकते हैं कि मशीन किस डिस्क से बूट हुई है। विंडोज एनटी (और बाद में माइक्रोसॉफ्ट ऑपरेटिंग सिस्टम) उस ओएस के तहत कंप्यूटर से जुड़े किसी भी डिस्क पर सभी विभाजनों के लिए एक इंडेक्स के रूप में डिस्क हस्ताक्षर का उपयोग करता है; ये हस्ताक्षर विंडोज रजिस्ट्री कुंजियों में रखे जाते हैं, मुख्य रूप से डिस्क विभाजन और ड्राइव अक्षरों के बीच लगातार मैपिंग को संग्रहित करने के लिए। बूट करने योग्य Windows NT (या बाद के) विभाजन के स्थान का वर्णन करने के लिए इसका उपयोग Windows NT BOOT.INI फ़ाइलों में भी किया जा सकता है (हालांकि अधिकांश ऐसा नहीं करते हैं)। एक कुंजी (कई के बीच), जहां Windows 2000/XP रजिस्ट्री में NT डिस्क हस्ताक्षर दिखाई देते हैं, वह है:

विंडोज एनटी (और बाद में माइक्रोसॉफ्ट ऑपरेटिंग सिस्टम) उस ओएस के तहत कंप्यूटर से जुड़े किसी भी डिस्क पर सभी विभाजनों के लिए एक इंडेक्स के रूप में डिस्क हस्ताक्षर का उपयोग करता है; ये हस्ताक्षर विंडोज रजिस्ट्री कुंजियों में रखे जाते हैं, मुख्य रूप से डिस्क विभाजन और ड्राइव अक्षरों के बीच लगातार मैपिंग को संग्रहित करने के लिए। बूट करने योग्य Windows NT (या बाद के) विभाजनों के स्थान का वर्णन करने के लिए इसका उपयोग Windows NT BOOT.INI फ़ाइलों में भी किया जा सकता है (हालांकि अधिकांश ऐसा नहीं करते हैं)। एक कुंजी (कई के बीच), जहां Windows 2000/XP रजिस्ट्री में NT डिस्क हस्ताक्षर दिखाई देते हैं, वह है:

HKEY_LOCAL_MACHINE\SYSTEM\MountedDevices\

यदि MBR ​​में संग्रहीत डिस्क का हस्ताक्षर A8 E1 B9 D2 (उस क्रम में) था और इसका पहला विभाजन लॉजिकल ड्राइव C: Windows के अंतर्गत था, तो कुंजी मान  के अंतर्गत   डेटा होगा:

ए8 ई1 बी9 डी2 00 7ई 00 00 00 00 00 00

पहले चार बाइट्स को डिस्क सिग्नेचर कहा जाता है। (अन्य कुंजियों में, ये बाइट्स MBR सेक्टर में पाए जाने वाले क्रम से विपरीत क्रम में प्रकट हो सकते हैं।) इसके बाद आठ और बाइट्स होते हैं, जो 64-बिट पूर्णांक बनाते हैं, छोटे-अंत संकेतन में, जिनका उपयोग बाइट ऑफ़सेट का पता लगाने के लिए किया जाता है। इस विभाजन का। इस मामले में, 00 7E हेक्साडेसिमल मान 0x7E00 (32,256) के अनुरूप है। इस धारणा के तहत कि विचाराधीन ड्राइव 512 बाइट्स के एक सेक्टर आकार की रिपोर्ट करता है, फिर इस बाइट को 512 से विभाजित करके 63 परिणाम देता है, जो कि भौतिक सेक्टर नंबर (या LBA) है जिसमें विभाजन का पहला सेक्टर होता है (उपयोग किए गए सेक्टर काउंट के विपरीत) सीएचएस टुपल्स के सेक्टर वैल्यू में, जो एक से गिना जाता है, पूर्ण या एलबीए सेक्टर वैल्यू शून्य से शुरू होता है)।

यदि इस डिस्क में डिस्क सिग्नेचर के बाद मान 00 F8 93 71 02 के साथ एक और विभाजन था (उदाहरण के तहत, कुंजी मान, यह बाइट ऑफ़सेट 0x00027193F800 ($10,495,457,280$) पर शुरू होगा, जो कि पहला बाइट भी है भौतिक क्षेत्र की$20,498,940$।

विंडोज विस्टा से शुरू करते हुए, डिस्क सिग्नेचर को बूट कॉन्फ़िगरेशन डेटा (BCD) स्टोर में भी स्टोर किया जाता है, और बूट प्रक्रिया इस पर निर्भर करती है। यदि डिस्क हस्ताक्षर बदलता है, पाया नहीं जा सकता है या कोई विरोध है, तो विंडोज़ बूट करने में असमर्थ है। जब तक विंडोज को छद्म डिस्क हस्ताक्षर के रूप में उन्नत सक्रिय विभाजन प्रविष्टि के एलबीए पते के अतिव्यापी हिस्से का उपयोग करने के लिए मजबूर नहीं किया जाता है, तब तक विंडोज़ का उपयोग पीटीएस-डॉस 7 और डीआर-डॉस 7.07 की उन्नत सक्रिय विभाजन सुविधा के साथ विरोधाभासी है, विशेष रूप से यदि उनका बूट कोड डिस्क के पहले 8 GB के बाहर स्थित है, इसलिए LBA एड्रेसिंग का उपयोग किया जाना चाहिए।

प्रोग्रामिंग विचार
MBR की उत्पत्ति PC XT में हुई थी। आईबीएम पीसी-संगत कंप्यूटर endianness | लिटिल-एंडियन हैं, जिसका अर्थ है कि कंप्यूटर प्रोसेसर दो या दो से अधिक बाइट्स को कम से कम महत्वपूर्ण बाइट पहले मेमोरी में संग्रहीत करता है। मीडिया पर एमबीआर का प्रारूप इस परिपाटी को दर्शाता है। इस प्रकार, एमबीआर हस्ताक्षर डिस्क संपादक में अनुक्रम के रूप में दिखाई देगा. BIOS में बूटस्ट्रैप अनुक्रम पहले मान्य MBR को लोड करेगा जो इसे कंप्यूटर की भौतिक मेमोरी में स्मृति पता पर मिलता है 0x0000:0x7C00. एमबीआर कॉपी की शुरुआत में निष्पादन को निर्देशित करने के लिए BIOS कोड में निष्पादित अंतिम निर्देश उस पते पर कूद जाएगा। अधिकांश BIOS के लिए प्राथमिक सत्यापन ऑफ़सेट पर हस्ताक्षर है 0x01FE, हालाँकि एक BIOS कार्यान्वयनकर्ता अन्य जाँचों को शामिल करना चुन सकता है, जैसे कि यह सत्यापित करना कि MBR ​​में डिस्क की रिपोर्ट की गई क्षमता से परे क्षेत्रों को संदर्भित किए बिना एक वैध विभाजन तालिका शामिल है।

BIOS के लिए, रिमूवेबल (जैसे फ्लॉपी) और फिक्स्ड डिस्क अनिवार्य रूप से समान हैं। या तो, BIOS मीडिया के पहले भौतिक क्षेत्र को निरपेक्ष पते पर RAM में पढ़ता है 0x7C00, लोड किए गए सेक्टर के अंतिम दो बाइट्स में हस्ताक्षर की जांच करता है, और फिर, यदि सही हस्ताक्षर पाया जाता है, तो जंप (JMP) निर्देश के साथ सेक्टर के पहले बाइट पर नियंत्रण स्थानांतरित करता है। एकमात्र वास्तविक अंतर जो BIOS बनाता है वह यह है कि (डिफ़ॉल्ट रूप से, या यदि बूट क्रम कॉन्फ़िगर करने योग्य नहीं है) यह पहली निश्चित डिस्क से बूट करने का प्रयास करने से पहले पहली हटाने योग्य डिस्क से बूट करने का प्रयास करता है। BIOS के दृष्टिकोण से, RAM में वॉल्यूम बूट रिकॉर्ड को MBR लोड करने की क्रिया ठीक वैसी ही है, जैसे ऑपरेटिंग सिस्टम लोडर के ऑब्जेक्ट कोड को RAM में लोड करने वाली फ़्लॉपी डिस्क वॉल्यूम बूट रिकॉर्ड की क्रिया। किसी भी मामले में, BIOS लोड किया गया प्रोग्राम ऑपरेटिंग सिस्टम को लोड करने की श्रृंखला के काम के बारे में जा रहा है।

जबकि एमबीआर बूट सेक्टर कोड भौतिक पते पर लोड होने की उम्मीद करता है 0x0000:0x7C00, भौतिक पते से सभी स्मृति 0x0000:0x0501 (पता 0x0000:0x0500 फीनिक्स BIOS द्वारा उपयोग किया जाने वाला अंतिम है) प्रति 0x0000:0x7FFF, बाद में आराम किया 0x0000:0xFFFF (और कभी - कभी तक 0x9000:0xFFFF)—‌पहले 640  KB का अंत—‌रियल मोड में उपलब्ध है. ई> BIOS इंटरप्ट कॉल यह निर्धारित करने में मदद कर सकता है कि कितनी मेमोरी को सुरक्षित रूप से आवंटित किया जा सकता है (डिफ़ॉल्ट रूप से, यह स्मृति विभाजन से केबी में आधार मेमोरी आकार को पढ़ता है: ऑफ़सेट स्थान 0x0040:0x0013, लेकिन यह अन्य निवासी प्री-बूट सॉफ़्टवेयर जैसे कि BIOS ओवरले, रिमोट प्रोग्राम लोडर कोड या वायरस द्वारा उपलब्ध मेमोरी की रिपोर्ट की गई मात्रा को कम करने के लिए लगाया जा सकता है ताकि बूट सेक्टर जैसे अन्य बूट स्टेज सॉफ़्टवेयर को ओवरराइट करने से रोका जा सके)।

512-बाइट एमबीआर के अंतिम 66 बाइट्स विभाजन तालिका और अन्य जानकारी के लिए आरक्षित हैं, इसलिए एमबीआर बूट सेक्टर प्रोग्राम 446 बाइट्स मेमोरी या उससे कम में फिट होने के लिए पर्याप्त छोटा होना चाहिए।

एमबीआर कोड विभाजन तालिका की जांच करता है, एक उपयुक्त विभाजन का चयन करता है और उस प्रोग्राम को लोड करता है जो बूट प्रक्रिया के अगले चरण का प्रदर्शन करेगा, आमतौर पर INT 13h BIOS इंटरप्ट कॉल का उपयोग करके। MBR बूटस्ट्रैप कोड लोड करता है और चलाता है (एक बूट लोडर- या ऑपरेटिंग सिस्टम पर निर्भर) वॉल्यूम बूट रिकॉर्ड कोड जो सक्रिय विभाजन की शुरुआत में स्थित होता है। वॉल्यूम बूट रिकॉर्ड 512-बाइट सेक्टर के भीतर फिट होगा, लेकिन एमबीआर कोड के लिए अतिरिक्त सेक्टरों को एक सेक्टर से अधिक लंबे बूट लोडर को समायोजित करने के लिए लोड करना सुरक्षित है, बशर्ते कि वे सेक्टर आकार के बारे में कोई अनुमान न लगाएं। वास्तव में, पते पर कम से कम 1 KB RAM उपलब्ध है 0x7C00 प्रत्येक IBM XT- और AT-श्रेणी की मशीन में, इसलिए 1 KB सेक्टर का उपयोग बिना किसी समस्या के किया जा सकता है। एमबीआर की तरह, वॉल्यूम बूट रिकॉर्ड सामान्य रूप से पते पर लोड होने की अपेक्षा करता है 0x0000:0x7C00. यह इस तथ्य से निकला है कि वॉल्यूम बूट रिकॉर्ड डिजाइन अविभाजित मीडिया पर उत्पन्न हुआ, जहां वॉल्यूम बूट रिकॉर्ड सीधे BIOS बूट प्रक्रिया द्वारा लोड किया जाएगा; जैसा ऊपर बताया गया है, BIOS एमबीआर और वॉल्यूम बूट रिकॉर्ड (वीबीआर) का इलाज करता है बिल्कुल एक जैसे। चूंकि यह वही स्थान है जहां एमबीआर लोड किया गया है, एमबीआर के पहले कार्यों में से एक स्वयं को स्मृति में कहीं और स्थानांतरित करना है। स्थानांतरण पता एमबीआर द्वारा निर्धारित किया जाता है, लेकिन यह अक्सर होता है 0x0000:0x0600 (MS-DOS/PC DOS, OS/2 और Windows MBR कोड के लिए) या 0x0060:0x0000 (अधिकांश DR-DOS MBRs)। (भले ही ये दोनों खंडित पते वास्तविक मोड में एक ही भौतिक मेमोरी पते को हल करते हैं, Apple डार्विन को बूट करने के लिए, MBR को स्थानांतरित किया जाना चाहिए 0x0000:0x0600 के बजाय 0x0060:0x0000, चूँकि कोड DS पर निर्भर करता है: MBR द्वारा प्रदान की गई विभाजन प्रविष्टि के लिए SI सूचक, लेकिन यह ग़लती से इसे संदर्भित करता है 0x0000: केवल एसआई। यह महत्वपूर्ण है कि मेमोरी में अन्य पतों को स्थानांतरित न किया जाए क्योंकि कई वॉल्यूम बूट रिकॉर्ड उनकी बूट फ़ाइल लोड करते समय एक निश्चित मानक मेमोरी लेआउट ग्रहण करेंगे।

ए में स्थिति क्षेत्र विभाजन तालिका रिकॉर्ड का उपयोग सक्रिय विभाजन को इंगित करने के लिए किया जाता है। मानक-अनुरूप एमबीआर केवल एक विभाजन को सक्रिय चिह्नित करने की अनुमति देगा और एक वैध विभाजन तालिका के अस्तित्व को निर्धारित करने के लिए इसे विवेक-जांच के हिस्से के रूप में उपयोग करेगा। यदि एक से अधिक पार्टीशन को सक्रिय चिह्नित किया गया है, तो वे एक त्रुटि संदेश प्रदर्शित करेंगे। कुछ गैर-मानक एमबीआर इसे एक त्रुटि स्थिति के रूप में नहीं मानेंगे और केवल पंक्ति में पहले चिह्नित विभाजन का उपयोग करेंगे। परंपरागत रूप से, के अलावा अन्य मूल्य 0x00 (सक्रिय नहीं) और 0x80 (सक्रिय) अमान्य थे और बूटस्ट्रैप प्रोग्राम उनका सामना करने पर एक त्रुटि संदेश प्रदर्शित करेगा। हालाँकि, प्लग एंड प्ले BIOS विशिष्टता और BIOS बूट विशिष्टता (BBS) ने अन्य उपकरणों को 1994 से बूट करने योग्य बनने की अनुमति दी। नतीजतन, MS-DOS 7.10 (Windows 95B) और उच्चतर की शुरुआत के साथ, MBR ने सेट बिट 7 को सक्रिय फ़्लैग के रूप में मानना ​​शुरू कर दिया और मूल्यों के लिए एक त्रुटि संदेश दिखाया 0x01..0x7F केवल। यह बाद में संबंधित विभाजन के VBR को लोड करते समय उपयोग की जाने वाली भौतिक ड्राइव इकाई के रूप में प्रविष्टि का इलाज करना जारी रखता है, जिससे अब अन्य बूट ड्राइव भी स्वीकार किए जाते हैं 0x80 वैध के रूप में, हालाँकि, MS-DOS ने इस एक्सटेंशन का उपयोग स्वयं नहीं किया। विभाजन तालिका में वास्तविक भौतिक ड्राइव संख्या को संग्रहीत करने से आमतौर पर पश्चगामी संगतता समस्याएँ नहीं होती हैं, क्योंकि मान इससे भिन्न होगा 0x80 केवल पहले वाले के अलावा अन्य ड्राइव पर (जो पहले बूट करने योग्य नहीं है, वैसे भी)। हालाँकि, अन्य ड्राइव को बूट करने के लिए सक्षम सिस्टम के साथ भी, एक्सटेंशन अभी भी सार्वभौमिक रूप से काम नहीं कर सकता है, उदाहरण के लिए, भौतिक ड्राइव के BIOS असाइनमेंट के बाद जब ड्राइव को हटा दिया जाता है, जोड़ा या स्वैप किया जाता है। इसलिए, BIOS बूट विशिष्टता (BBS) के अनुसार, विभाजन तालिका में प्रविष्टि का उपयोग करने के बजाय मूल रूप से BIOS द्वारा प्रदान किए गए डीएल मान पर पारित करने के लिए सक्रिय ध्वज के रूप में बिट 7 को स्वीकार करने वाले आधुनिक एमबीआर के लिए यह सबसे अच्छा अभ्यास है।

BIOS से MBR इंटरफ़ेस
MBR को मेमोरी लोकेशन पर लोड किया जाता है 0x0000:0x7C00 और निम्नलिखित सी पी यू रजिस्टरों के साथ जब पूर्व बूटस्ट्रैप लोडर (सामान्य रूप से BIOS में प्रारंभिक कार्यक्रम लोडर) इसे जंप करके निष्पादन पास करता है 0x0000:0x7C00 सीपीयू के वास्तविक मोड में।
 * सीएस रजिस्टर:आईपी ​​रजिस्टर = 0x0000:0x7C00 (हल किया गया)
 * कुछ कॉम्पैक BIOS ग़लती से उपयोग करते हैं 0x07C0:0x0000 बजाय। हालांकि यह वास्तविक मोड मेमोरी में एक ही स्थान पर हल होता है, यह गैर-मानक है और इससे बचा जाना चाहिए, क्योंकि एमबीआर कोड कुछ रजिस्टर मूल्यों को मानता है या स्थानांतरित करने के लिए नहीं लिखा जाता है, अन्यथा काम नहीं कर सकता है।


 * DL IBM BIOS के साथ-साथ अधिकांश अन्य BIOS द्वारा समर्थित है। Toshiba T1000 BIOS इसे ठीक से समर्थन नहीं करने के लिए जाना जाता है, और कुछ पुराने Wyse 286 BIOS निश्चित डिस्क के लिए DL मानों को 2 से अधिक या बराबर का उपयोग करते हैं (जिससे BIOS के भौतिक ड्राइव नंबरों के बजाय DOS के तहत लॉजिकल ड्राइव नंबरों को दर्शाते हैं)। हटाने योग्य ड्राइव के रूप में कॉन्फ़िगर की गई यूएसबी स्टिक आमतौर पर डीएल = का असाइनमेंट प्राप्त करती हैं 0x80, 0x81, आदि। हालाँकि, कुछ दुर्लभ BIOS गलत तरीके से उन्हें डीएल = के तहत प्रस्तुत किया 0x01, जैसे कि उन्हें सुपरफ्लॉपी के रूप में कॉन्फ़िगर किया गया हो।
 * एक मानक अनुरूप BIOS इससे बड़ी या बराबर संख्या निर्दिष्ट करता है 0x80 विशेष रूप से फिक्स्ड डिस्क / रिमूवेबल ड्राइव और पारंपरिक रूप से केवल मान 0x80 तथा 0x00 बूट के दौरान भौतिक ड्राइव इकाइयों के रूप में पारित किया गया। परिपाटी के अनुसार, केवल निश्चित डिस्क/हटाने योग्य ड्राइव का विभाजन किया जाता है, इसलिए, पारंपरिक रूप से एक एमबीआर केवल डीएल मान देख सकता था 0x80. कई एमबीआर को डीएल वैल्यू को अनदेखा करने और हार्ड-वायर्ड वैल्यू के साथ काम करने के लिए कोडित किया गया था (सामान्य रूप से 0x80), वैसे भी।
 * प्लग एंड प्ले BIOS विशिष्टता और BIOS बूट विशिष्टता (BBS) 1994 से अन्य उपकरणों को भी बूट करने योग्य बनाने की अनुमति देते हैं। बाद में सिफारिश की गई है कि एमबीआर और वीबीआर कोड को आंतरिक रूप से हार्डवेयर्ड डिफ़ॉल्ट के बजाय डीएल का उपयोग करना चाहिए। जहां तक ​​एमबीआर कोड का संबंध है, यह विभिन्न गैर-मानक असाइनमेंट (उपरोक्त उदाहरण देखें) के साथ संगतता भी सुनिश्चित करेगा।
 * एल टोरिटो (सीडी-रोम मानक) विनिर्देश के बाद बूट करने योग्य सीडी-रोम में इस इंटरफ़ेस पर फ्लॉपी या सुपरफ्लॉपी के रूप में होने के लिए BIOS द्वारा माउंट की गई डिस्क छवियां हो सकती हैं। डीएल का मान 0x00 तथा 0x01 संरक्षित क्षेत्र रन टाइम इंटरफेस एक्सटेंशन सेवाएं (पार्टियां) और विश्वसनीय कंप्यूटिंग समूह (टीसीजी) BIOS एक्सटेंशन द्वारा भी उपयोग किया जा सकता है अन्यथा अदृश्य तक पहुंचने के लिए विश्वसनीय मोड में पार्टियों के विभाजन, हार्ड डिस्क के होस्ट संरक्षित क्षेत्र (HPA) के अंतिम भौतिक क्षेत्र में बूट इंजीनियरिंग एक्सटेंशन रिकॉर्ड (BEER) के माध्यम से स्थित डिस्क छवि फ़ाइलें। जबकि फ्लॉपी या सुपरफ्लॉपी का अनुकरण करने के लिए डिज़ाइन किया गया है, एमबीआर कोड इन गैर-मानक डीएल मूल्यों को स्वीकार करते हुए कम से कम ऑपरेटिंग सिस्टम के बूट चरण में विभाजित मीडिया की छवियों का उपयोग करने की अनुमति देता है।
 * एल टोरिटो (सीडी-रोम मानक) विनिर्देश के बाद बूट करने योग्य सीडी-रोम में इस इंटरफ़ेस पर फ्लॉपी या सुपरफ्लॉपी के रूप में होने के लिए BIOS द्वारा माउंट की गई डिस्क छवियां हो सकती हैं। डीएल का मान 0x00 तथा 0x01 संरक्षित क्षेत्र रन टाइम इंटरफेस एक्सटेंशन सेवाएं (पार्टियां) और विश्वसनीय कंप्यूटिंग समूह (टीसीजी) BIOS एक्सटेंशन द्वारा भी उपयोग किया जा सकता है अन्यथा अदृश्य तक पहुंचने के लिए विश्वसनीय मोड में पार्टियों के विभाजन, हार्ड डिस्क के होस्ट संरक्षित क्षेत्र (HPA) के अंतिम भौतिक क्षेत्र में बूट इंजीनियरिंग एक्सटेंशन रिकॉर्ड (BEER) के माध्यम से स्थित डिस्क छवि फ़ाइलें। जबकि फ्लॉपी या सुपरफ्लॉपी का अनुकरण करने के लिए डिज़ाइन किया गया है, एमबीआर कोड इन गैर-मानक डीएल मूल्यों को स्वीकार करते हुए कम से कम ऑपरेटिंग सिस्टम के बूट चरण में विभाजित मीडिया की छवियों का उपयोग करने की अनुमति देता है।


 * डीएच रजिस्टर बिट 5 = 0: INT 13h के माध्यम से समर्थित डिवाइस; अन्य: परवाह नहीं है (शून्य होना चाहिए)। DH कुछ IBM BIOS द्वारा समर्थित है।
 * कुछ अन्य रजिस्टरों में आमतौर पर कुछ रजिस्टर वैल्यू (डीएस, ईएस, एसएस = 0x0000; एसपी = 0x0400) मूल IBM ROM BIOSes के साथ, लेकिन इस पर भरोसा करने के लिए कुछ भी नहीं है, क्योंकि अन्य BIOS अन्य मानों का उपयोग कर सकते हैं। इसी वजह से आईबीएम, माइक्रोसॉफ्ट, डिजिटल रिसर्च आदि के एमबीआर कोड ने कभी इसका फायदा नहीं उठाया। बूट सेक्टरों में इन रजिस्टर मूल्यों पर भरोसा करने से चेन-बूट परिदृश्यों में भी समस्या हो सकती है।

प्लग करें और खेलें BIOS या BBS समर्थन वाले सिस्टम, DL के अतिरिक्त PnP डेटा के लिए संकेतक प्रदान करेंगे: * डीएल = बूट ड्राइव यूनिट (ऊपर देखें)
 * डीआई रजिस्टर:DI रजिस्टर = पॉइंट टू स्थापना जांच संरचना


 * यह जानकारी एमबीआर में बूट लोडर (या वीबीआर, यदि पारित हो जाती है) को सक्रिय रूप से BIOS या एक निवासी PnP / BBS BIOS ओवरले के साथ बूट ऑर्डर को कॉन्फ़िगर करने के लिए मेमोरी में ओवरले करने की अनुमति देती है, आदि, हालांकि, यह जानकारी है अधिकांश मानक एमबीआर और वीबीआर द्वारा अनदेखा किया गया। आदर्श रूप से, लोडेड ऑपरेटिंग सिस्टम द्वारा बाद में उपयोग के लिए ES:DI को VBR पर भेज दिया जाता है, लेकिन PnP-सक्षम ऑपरेटिंग सिस्टम में आमतौर पर PnP BIOS प्रविष्टि बिंदु को बाद में पुनः प्राप्त करने के लिए फ़ॉलबैक विधियाँ भी होती हैं। ताकि अधिकांश ऑपरेटिंग सिस्टम इस पर भरोसा न करें।

एमबीआर से वीबीआर इंटरफ़ेस
सम्मेलन के अनुसार, एक मानक अनुरूप एमबीआर मेमोरी स्थान पर लोड किए गए सफलतापूर्वक लोड किए गए वीबीआर को निष्पादन पास करता है 0x0000:0x7C00, पर कूद कर 0x0000:0x7C00 सीपीयू के वास्तविक मोड में निम्नलिखित रजिस्टरों को बनाए रखा जाता है या विशेष रूप से स्थापित किया जाता है:
 * सीएस: आईपी = 0x0000:0x7C00 (लगातार)
 * डीएल = बूट ड्राइव यूनिट (ऊपर देखें)
 * एमएस-डॉस 2.0-7.0 / पीसी डॉस 2.0-6.3 MBRs प्रविष्टि पर प्राप्त DL मान को पारित नहीं करते हैं, बल्कि वे भौतिक बूट ड्राइव इकाई के रूप में चयनित प्राथमिक विभाजन के विभाजन तालिका प्रविष्टि में बूट स्थिति प्रविष्टि का उपयोग करते हैं। चूंकि यह सम्मेलन द्वारा है, 0x80 अधिकांश एमबीआर विभाजन तालिकाओं में, यह तब तक नहीं बदलेगा जब तक कि BIOS पंक्ति में पहली निश्चित डिस्क/हटाने योग्य ड्राइव के अलावा किसी भौतिक डिवाइस को बूट करने का प्रयास नहीं करता। यही कारण है कि ये ऑपरेटिंग सिस्टम दूसरी हार्ड डिस्क आदि को बूट नहीं कर सकते हैं। कुछ FDISK उपकरण द्वितीयक डिस्क पर भी विभाजन को सक्रिय के रूप में चिह्नित करने की अनुमति देते हैं। इस स्थिति में, यह जानते हुए कि ये ऑपरेटिंग सिस्टम वैसे भी अन्य ड्राइव को बूट नहीं कर सकते हैं, उनमें से कुछ पारंपरिक रूप से निश्चित मान का उपयोग करना जारी रखते हैं 0x80 सक्रिय मार्कर के रूप में, जबकि अन्य वर्तमान में निर्दिष्ट भौतिक ड्राइव यूनिट के अनुरूप मानों का उपयोग करते हैं (0x81, 0x82), जिससे कम से कम सिद्धांत रूप में अन्य ड्राइव से बूटिंग की अनुमति मिलती है। वास्तव में, यह कई एमबीआर कोड के साथ काम करेगा, जो बूट स्थिति प्रविष्टि के सेट बिट 7 को सक्रिय ध्वज के रूप में जोर देने के बजाय लेते हैं 0x80हालाँकि, MS-DOS/PC DOS MBRs के निश्चित मूल्य को स्वीकार करने के लिए हार्ड-वायर्ड हैं 0x80 केवल। विभाजन तालिका में वास्तविक भौतिक ड्राइव संख्या को संग्रहीत करने से भी समस्याएँ पैदा होंगी, जब भौतिक ड्राइव का BIOS असाइनमेंट बदलता है, उदाहरण के लिए जब ड्राइव को हटाया जाता है, जोड़ा जाता है या स्वैप किया जाता है। इसलिए, एक सामान्य एमबीआर के लिए बिट 7 को सक्रिय ध्वज के रूप में स्वीकार करना और अन्यथा केवल वीबीआर का उपयोग करना और पास करना, मूल रूप से BIOS द्वारा प्रदान किया गया डीएल मान अधिकतम लचीलेपन की अनुमति देता है। MS-DOS 7.1 - 8.0 MBR बिट 7 को सक्रिय ध्वज और किसी भी मान के रूप में मानने के लिए बदल गए हैं 0x01..0x7F अमान्य के रूप में, लेकिन वे अभी भी BIOS द्वारा प्रदान किए गए DL मान का उपयोग करने के बजाय विभाजन तालिका से भौतिक ड्राइव इकाई लेते हैं। DR-DOS 7.07 विस्तारित MBR बिट 7 को सक्रिय ध्वज के रूप में मानते हैं और डिफ़ॉल्ट रूप से BIOS DL मान का उपयोग करते हैं और पास करते हैं (गैर-मानक मान सहित) 0x00..0x01 कुछ BIOS द्वारा विभाजित मीडिया के लिए भी उपयोग किया जाता है), लेकिन वे LOADER और REAL/32 के संयोजन के साथ-साथ MBR के विस्तृत व्यवहार को बदलने के लिए वैकल्पिक बूट विधियों का समर्थन करने के लिए एक विशेष #NEWLDR कॉन्फ़िगरेशन ब्लॉक भी प्रदान करते हैं, ताकि यह विभाजन तालिका से प्राप्त ड्राइव मानों के साथ भी काम कर सकता है (LOADER और AAPs के संयोजन के साथ महत्वपूर्ण, NEWLDR ऑफ़सेट देखें ), Wyse गैर-मानक ड्राइव इकाइयों का अनुवाद करें 0x02..0x7F प्रति 0x80..0xFD, और वैकल्पिक रूप से ड्राइव मान को ठीक करें (ऑफ़सेट   विस्तारित BIOS पैरामीटर ब्लॉक (EBPB) में या सेक्टर ऑफसेट पर    ) लोड किए गए वीबीआर में उन्हें निष्पादन पास करने से पहले (देखें NEWLDR ऑफ़सेट  )—यह अन्य बूट लोडर को NEWLDR को चेन-लोडर के रूप में उपयोग करने की अनुमति देता है, फ्लाई पर इसकी इन-मेमोरी छवि को कॉन्फ़िगर करता है और NEWLDR के माध्यम से VBRs, EBRs, या AAPs की लोडिंग को टनल करता है।


 * DH और ES की सामग्री: DI को पूर्ण प्लग-एंड-प्ले समर्थन (ऊपर देखें) के लिए MBR द्वारा संरक्षित किया जाना चाहिए, हालाँकि, MS-DOS 2.0 - 8.0 / PC DOS 2.0 - 6.3 सहित कई MBRs और Windows NT/2000/XP, नहीं। (यह आश्चर्यजनक नहीं है, क्योंकि DOS के वे संस्करण प्लग-एंड-प्ले BIOS मानक से पहले के हैं, और पिछले मानकों और सम्मेलनों ने DL के अलावा किसी अन्य रजिस्टर को संरक्षित करने की कोई आवश्यकता नहीं बताई है।) कुछ MBRs डीएच को 0 पर सेट करें।

एमबीआर कोड कई कार्यान्वयनों में वीबीआर को अतिरिक्त जानकारी देता है:
 * DS:SI = सक्रिय VBR के अनुरूप 16-बाइट MBR विभाजन तालिका प्रविष्टि (स्थानांतरित MBR में) को इंगित करता है। पीसी-एमओएस 5.1 बूट करने के लिए इस पर निर्भर करता है यदि विभाजन तालिका में कोई विभाजन बूट करने योग्य के रूप में फ़्लैग नहीं किया गया है। लोडर के संयोजन के साथ, बहुउपयोगकर्ता डॉस और रीयल/32 बूट सेक्टर सक्रिय विभाजन के बूट सेक्टर का पता लगाने के लिए इसका उपयोग करते हैं (या अन्य बूटस्ट्रैप लोडर जैसे IBMBIO.LDR डिस्क पर एक निश्चित स्थिति पर) यदि बूट फ़ाइल (LOADER.SYS) कर सकता है नहीं मिला। पीटीएस-डॉस 6.6 और S/DOS 1.0 इसे अपने उन्नत सक्रिय विभाजन (AAP) सुविधा के संयोजन में उपयोग करते हैं। LOADER और AAPs के लिए समर्थन के अलावा, DR-DOS 7.07 अपने दोहरे CHS/LBA VBR कोड का उपयोग करते समय आवश्यक INT 13h एक्सेस विधि का निर्धारण करने के लिए इसका उपयोग कर सकता है और यह विभाजन प्रविष्टि में बूट ड्राइव/स्टेटस फ़्लैग फ़ील्ड को इसके अनुसार अपडेट करेगा प्रभावी रूप से उपयोग किए जाने वाले डीएल मूल्य। Apple डार्विन बूटलोडर्स (Apple's,  , और डेविड इलियट के  ) इस सूचक पर भी निर्भर करते हैं, लेकिन इसके अतिरिक्त वे डीएस का उपयोग नहीं करते हैं, लेकिन इसे सेट करने के लिए मानते हैं 0x0000 बजाय। यदि यह धारणा गलत है तो यह समस्याएँ पैदा करेगा। OS/2 का MBR कोड, MS-DOS 2.0 से 8.0, PC DOS 2.0 से 7.10 और Windows NT/2000/XP भी यही इंटरफ़ेस प्रदान करते हैं, हालाँकि ये सिस्टम इसका उपयोग नहीं करते हैं। Windows Vista/7 MBRs अब यह DS:SI सूचक प्रदान नहीं करते हैं। जबकि कुछ एक्सटेंशन केवल 16-बाइट पार्टीशन टेबल एंट्री पर ही निर्भर करते हैं, अन्य एक्सटेंशन के लिए पूरे 4 (या 5 एंट्री) पार्टीशन टेबल की भी आवश्यकता हो सकती है।
 * डीएस: बीपी रजिस्टर = वैकल्पिक रूप से सक्रिय वीबीआर के अनुरूप 16-बाइट एमबीआर विभाजन तालिका प्रविष्टि (स्थानांतरित एमबीआर में) को इंगित करता है। यह DS:SI (ऊपर देखें) द्वारा प्रदान किए गए पॉइंटर के समान है और MS-DOS 2.0-8.0, PC DOS 2.0-7.10, Windows NT/2000/XP/Vista/7 MBRs द्वारा प्रदान किया गया है. हालाँकि, यह अधिकांश तृतीय-पक्ष MBRs द्वारा समर्थित नहीं है।

DR-DOS 7.07 के तहत विस्तारित MBR द्वारा और LOADER के संयोजन में एक विस्तारित इंटरफ़ेस वैकल्पिक रूप से प्रदान किया जा सकता है:
 * AX रजिस्टर = मैजिक सिग्नेचर इस NEWLDR एक्सटेंशन की मौजूदगी को दर्शाता है (0x0EDC)
 * डीएल = बूट ड्राइव यूनिट (ऊपर देखें)
 * DS:SI = प्रयुक्त 16-बाइट MBR विभाजन तालिका प्रविष्टि की ओर इशारा करता है (ऊपर देखें)
 * ES:BX रजिस्टर = बूट सेक्टर की शुरुआत या NEWLDR सेक्टर इमेज (आमतौर पर 0x7C00)
 * सीएक्स रजिस्टर = आरक्षित

जीपीटी के संयोजन के साथ, एक उन्नत डिस्क ड्राइव विशिष्टता (ईडीडी) 4 हाइब्रिड एमबीआर प्रस्ताव इंटरफ़ेस के लिए एक और विस्तार की सिफारिश करता है: * ईएक्स रजिस्टर = 0x54504721
 * डीएल = बूट ड्राइव यूनिट (ऊपर देखें)
 * DS:SI = हाइब्रिड एमबीआर हैंडओवर स्ट्रक्चर की ओर इशारा करता है, जिसमें 16-बाइट डमी एमबीआर पार्टीशन टेबल एंट्री होती है (ऑफसेट पर बूट फ्लैग को छोड़कर सभी बिट्स सेट के साथ) 0x00 और विभाजन प्रकार ऑफसेट पर 0x04) इसके बाद अतिरिक्त डेटा। यह पुराने DS के साथ आंशिक रूप से संगत है: ऊपर चर्चा की गई SI एक्सटेंशन, यदि केवल 16-बाइट विभाजन प्रविष्टि है, तो इन पुराने एक्सटेंशन के लिए संपूर्ण विभाजन तालिका की आवश्यकता नहीं है।
 * चूँकि पुराने ऑपरेटिंग सिस्टम (उनके VBRs सहित) इस विस्तार का समर्थन नहीं करते हैं और न ही वे 2 TiB बाधा से परे क्षेत्रों को संबोधित करने में सक्षम हैं, एक GPT-सक्षम हाइब्रिड बूट लोडर को अभी भी 16-बाइट डमी MBR विभाजन तालिका प्रविष्टि का अनुकरण करना चाहिए यदि बूट विभाजन पहले 2 TiB के भीतर स्थित है।


 * ES:DI = इंगित करता है स्थापना जांच संरचना (ऊपर देखें)

सामग्री का संपादन और प्रतिस्थापन
यद्यपि विभिन्न डिस्क संपादकों का उपयोग करके सीधे एमबीआर सेक्टर में बाइट्स में हेरफेर करना संभव है, एमबीआर को कार्य कोड के निश्चित सेट लिखने के लिए उपकरण हैं। एमएस-डॉस 5.0 के बाद से, प्रोग्राम  स्विच शामिल है , जो MBR कोड को फिर से लिखेगा। विंडोज 2000 और विन्डोज़ एक्सपी के तहत, रिकवरी कंसोल का उपयोग स्टोरेज डिवाइस में नया एमबीआर कोड लिखने के लिए किया जा सकता है।   आज्ञा। विंडोज विस्टा और विंडोज 7 के तहत, पुनर्प्राप्ति पर्यावरण का उपयोग नए एमबीआर कोड को लिखने के लिए किया जा सकता है   आज्ञा। कुछ तृतीय-पक्ष उपयोगिताओं का उपयोग विभाजन तालिकाओं की सामग्री को सीधे संपादित करने के लिए भी किया जा सकता है (हेक्साडेसिमल या डिस्क/सेक्टर संपादकों के ज्ञान की आवश्यकता के बिना), जैसे एमबीआर विज़ार्ड।

एक POSIX कमांड है जिसका उपयोग आमतौर पर स्टोरेज डिवाइस पर किसी भी स्थान को पढ़ने या लिखने के लिए किया जाता है, जिसमें MBR शामिल है। Linux में, ms-sys का उपयोग Windows MBR को स्थापित करने के लिए किया जा सकता है। GRUB और LILO (बूट लोडर) परियोजनाओं में MBR क्षेत्र के लिए कोड लिखने के उपकरण हैं, अर्थात्  तथा. GRUB लीगेसी इंटरएक्टिव कंसोल MBR को लिख सकता है, इसका उपयोग करके  तथा   आदेश, लेकिन वर्तमान में GRUB2 की आवश्यकता है   एक ऑपरेटिंग सिस्टम के भीतर से चलाने के लिए।

विभिन्न प्रोग्राम प्राथमिक विभाजन तालिका और विस्तारित विभाजन में तार्किक विभाजन दोनों का बैकअप बनाने में सक्षम हैं।

लिनक्स  (SystemRescueCD पर) प्राथमिक और विस्तारित विभाजन तालिका का बैकअप सहेजने में सक्षम है। यह एक फाइल बनाता है जिसे टेक्स्ट एडिटर में पढ़ा जा सकता है, या इस फाइल का उपयोग sfdisk द्वारा प्राथमिक/विस्तारित विभाजन तालिका को पुनर्स्थापित करने के लिए किया जा सकता है। विभाजन तालिका का बैकअप लेने के लिए एक उदाहरण कमांड है   और पुनर्स्थापित करना है. विभाजन तालिका को एक डिस्क से दूसरी डिस्क में इस तरह से कॉपी करना संभव है, मिररिंग की स्थापना के लिए उपयोगी है, लेकिन sfdisk बिना संकेत/चेतावनियों के कमांड को निष्पादित करता है.

यह भी देखें

 * विस्तारित बूट रिकॉर्ड (ईबीआर)
 * वॉल्यूम बूट रिकॉर्ड (वीबीआर)
 * GUID विभाजन तालिका (GPT)
 * BIOS बूट विभाजन
 * EFI सिस्टम विभाजन
 * बूट इंजीनियरिंग एक्सटेंशन रिकॉर्ड (BEER)
 * मेजबान संरक्षित क्षेत्र (HPA)
 * डिवाइस कॉन्फ़िगरेशन ओवरले (DCO)
 * Apple विभाजन मानचित्र (APM)
 * अमिगा कठोर डिस्क ब्लॉक (आरडीबी)
 * सामग्री की मात्रा तालिका (VTOC)
 * बीएसडी डिस्कलेबल
 * बूट लोडर
 * डिस्क क्लोनिंग
 * रिकवरी डिस्क
 * जीएनयू जुदा
 * विभाजन संरेखण

अग्रिम पठन

 * 
 * 
 * 
 * 

इस पेज में लापता आंतरिक लिंक की सूची

 * आईबीएम पर्सनल कंप्यूटर एक्सटी
 * बीएसडी डिस्कलेबल
 * विभाजन प्रकार
 * ठोस राज्य ड्राइव
 * भौतिक स्मृति
 * फाइल आवन्टन तालिका
 * छोटा एंडियन
 * स्व-स्थानांतरण
 * सेब डार्विन
 * एल टोरिटो (मानक सीडी-रोम)
 * मेजबान संरक्षित क्षेत्र
 * एन रजिस्टर
 * एमबीआर विभाजन तालिका
 * एक्स रजिस्टर
 * बीएक्स रजिस्टर
 * बढ़ी हुई डिस्क ड्राइव विशिष्टता
 * लिलो (बूट लोडर)
 * Apple विभाजन का नक्शा

बाहरी संबंध

 * Article on master boot record
 * The MBR and how it fits into the BIOS boot process