डिवाइस कॉन्फ़िगरेशन

बाहरी स्टोरेज को vold init service और StorageManagerService सिस्टम सेवा के कॉम्बिनेशन से मैनेज किया जाता है. बाहरी स्टोरेज के फ़िज़िकल वॉल्यूम को माउंट करने की सुविधा, vold की मदद से मैनेज की जाती है. यह ऐप्लिकेशन के लिए मीडिया को तैयार करने से पहले, उसे स्टैजिंग ऑपरेशन के ज़रिए तैयार करता है.

ध्यान दें: Android 8.0 में, MountService क्लास का नाम बदलकर StorageManagerService कर दिया गया था.

फ़ाइल मैपिंग

Android 4.2.2 और उससे पहले के वर्शन के लिए, डिवाइस के हिसाब से बनाई गई vold.fstab कॉन्फ़िगरेशन फ़ाइल, sysfs डिवाइसों से फ़ाइल सिस्टम के माउंट पॉइंट तक मैपिंग तय करती है. साथ ही, हर लाइन इस फ़ॉर्मैट का पालन करती है:

dev_mount <label> <mount_point> <partition> <sysfs_path> [flags]
  • label: वॉल्यूम का लेबल.
  • mount_point: फ़ाइल सिस्टम का वह पाथ जहां वॉल्यूम को माउंट करना है.
  • partition: पार्टीशन नंबर (1 से शुरू), या इस्तेमाल किए जा सकने वाले पहले पार्टीशन के लिए 'अपने-आप'.
  • sysfs_path: उन डिवाइसों के एक या एक से ज़्यादा sysfs पाथ जो यह माउंट पॉइंट दे सकते हैं. स्पेस से अलग किए गए हों और हर एक / से शुरू होना चाहिए.
  • flags: फ़्लैग की सूची, कॉमा लगाकर अलग की गई हो. यह सूची देना ज़रूरी नहीं है. इसमें / नहीं होना चाहिए. संभावित वैल्यू में nonremovable और encryptable शामिल हैं.

Android 4.3 और उसके बाद के वर्शन के लिए, init, vold, और रिकवरी के इस्तेमाल की जाने वाली अलग-अलग fstab फ़ाइलों को /fstab.<device> फ़ाइल में एक साथ जोड़ दिया गया था. vold से मैनेज किए जाने वाले बाहरी स्टोरेज वॉल्यूम के लिए, एंट्री का यह फ़ॉर्मैट होना चाहिए:

<src> <mnt_point> <type> <mnt_flags> <fs_mgr_flags>
  • src: sysfs में मौजूद पाथ (आम तौर पर /sys पर माउंट किया जाता है), जो उस डिवाइस पर ले जाता है जो माउंट पॉइंट उपलब्ध करा सकता है. पाथ, / से शुरू होना चाहिए.
  • mount_point: फ़ाइल सिस्टम का वह पाथ जहां वॉल्यूम को माउंट करना है.
  • type: वॉल्यूम पर फ़ाइल सिस्टम का टाइप. बाहरी कार्ड के लिए, आम तौर पर यह vfat होता है.
  • mnt_flags: Vold इस फ़ील्ड को अनदेखा करता है और इसे defaults पर सेट किया जाना चाहिए
  • fs_mgr_flags: Vold, यूनिफ़ाइड fstab में उन सभी लाइनों को अनदेखा करता है जिनमें इस फ़ील्ड में voldmanaged= फ़्लैग शामिल नहीं होता. इस फ़्लैग के बाद, कार्ड की जानकारी देने वाला लेबल और पार्टीशन नंबर या auto शब्द होना चाहिए. उदाहरण के लिए: voldmanaged=sdcard:auto. अन्य फ़्लैग के तौर पर nonremovable, encryptable=sdcard, noemulatedsd, और encryptable=userdata का इस्तेमाल किया जा सकता है.

कॉन्फ़िगरेशन की जानकारी

फ़्रेमवर्क लेवल और उससे ऊपर के बाहरी स्टोरेज इंटरैक्शन को StorageManagerService के ज़रिए मैनेज किया जाता है. Android 6.0 में कॉन्फ़िगरेशन में हुए बदलावों (जैसे कि storage_list.xml संसाधन ओवरले को हटाना) की वजह से, कॉन्फ़िगरेशन की जानकारी को दो कैटगरी में बांटा गया है.

Android 5.x और उससे पहले के वर्शन

डिवाइस के हिसाब से storage_list.xml कॉन्फ़िगरेशन फ़ाइल, आम तौर पर frameworks/base ओवरले के ज़रिए दी जाती है. इससे स्टोरेज डिवाइसों के एट्रिब्यूट और सीमाओं के बारे में पता चलता है. <StorageList> एलिमेंट में एक या एक से ज़्यादा <storage> एलिमेंट होते हैं. इनमें से एक एलिमेंट को मुख्य के तौर पर मार्क किया जाना चाहिए. <storage> एट्रिब्यूट में ये शामिल हैं:

  • mountPoint: इस माउंट का फ़ाइल सिस्टम पाथ.
  • storageDescription: स्ट्रिंग रिसॉर्स, जो इस माउंट के बारे में बताता है.
  • primary: अगर यह माउंट, मुख्य बाहरी स्टोरेज है, तो यह वैल्यू 'सही' होगी.
  • removable: अगर इस माउंट में, एसडी कार्ड जैसे हटाए जा सकने वाले मीडिया का इस्तेमाल किया जा रहा है, तो यह वैल्यू 'सही' होगी.
  • emulated: अगर यह माउंट एमुलेट किया गया है और इसे इंटरनल स्टोरेज से बैकअप किया गया है, तो यह वैल्यू 'सही' होगी. ऐसा, शायद FUSE डेमन का इस्तेमाल करके किया गया हो.
  • mtp-reserve: एमटीपी को मुफ़्त स्टोरेज के लिए, कितने एमबी स्टोरेज को रिज़र्व करना चाहिए. इसका इस्तेमाल सिर्फ़ तब किया जाता है, जब माउंट को 'इम्यूलेट किया गया' के तौर पर मार्क किया गया हो.
  • allowMassStorage: अगर इस माउंट को यूएसबी स्टोरेज के ज़रिए शेयर किया जा सकता है, तो इसकी वैल्यू 'सही' होगी.
  • maxFileSize: फ़ाइल का ज़्यादा से ज़्यादा साइज़ एमबी में.

डिवाइस, केस-इन्सेंसिव और अनुमति के बिना काम करने वाले फ़ाइल सिस्टम को एमुलेट करके, बाहरी स्टोरेज उपलब्ध करा सकते हैं. system/core/sdcard में मौजूद FUSE डेमन की मदद से, इसे लागू करने का एक तरीका उपलब्ध है. इसे डिवाइस के हिसाब से init.rc सेवा के तौर पर जोड़ा जा सकता है:

# virtual sdcard daemon running as media_rw (1023)
service sdcard /system/bin/sdcard <source_path> <dest_path> 1023 1023
    class late_start

यहां source_path, बैकअप के लिए इस्तेमाल किया जाने वाला डिवाइस का स्टोरेज है और dest_path, टारगेट माउंट पॉइंट है.

डिवाइस के हिसाब से init.rc स्क्रिप्ट कॉन्फ़िगर करते समय, EXTERNAL_STORAGE एनवायरमेंट वैरिएबल को प्राइमरी बाहरी स्टोरेज के पाथ के तौर पर तय करना होगा. /sdcard पाथ भी एक ही जगह पर ले जाना चाहिए. ऐसा, हो सकता है कि यह किसी सिमलिंक के ज़रिए हो. अगर कोई डिवाइस, प्लैटफ़ॉर्म के अपडेट के बीच बाहरी स्टोरेज की जगह में बदलाव करता है, तो सिमलिंक बनाए जाने चाहिए, ताकि पुराने पाथ काम करते रहें.

Android 6.0

स्टोरेज सबसिस्टम का कॉन्फ़िगरेशन अब डिवाइस के हिसाब से fstab फ़ाइल में सेट किया जाता है. साथ ही, ज़्यादा डाइनैमिक व्यवहार के लिए, कई पुरानी स्टैटिक कॉन्फ़िगरेशन फ़ाइलों/वैरिएबल को हटा दिया गया है:

  • storage_list.xml संसाधन ओवरले को हटा दिया गया है और फ़्रेमवर्क अब इसका इस्तेमाल नहीं करता. vold से स्टोरेज डिवाइसों का पता चलने पर, अब उन्हें डाइनैमिक तौर पर कॉन्फ़िगर किया जाता है.
  • EMULATED_STORAGE_SOURCE/TARGET एनवायरमेंट वैरिएबल हटा दिए गए हैं. अब Zygote, उपयोगकर्ता के हिसाब से माउंट पॉइंट कॉन्फ़िगर करने के लिए, इनका इस्तेमाल नहीं करता. इसके बजाय, अब उपयोगकर्ता के हिसाब से GIDs की मदद से, उपयोगकर्ता को अलग किया जाता है. साथ ही, रनटाइम के दौरान vold, प्राइमरी शेयर किया गया स्टोरेज माउंट करता है.
    • डेवलपर, इस्तेमाल के उदाहरण के आधार पर, डाइनैमिक या स्टैटिक तौर पर पाथ बनाना जारी रख सकते हैं. पाथ में यूनीक आइडेंटिटी (यूयूआईडी) शामिल करने से, हर कार्ड की पहचान की जा सकती है, ताकि डेवलपर को जगह की जानकारी साफ़ तौर पर दी जा सके. (उदाहरण के लिए, /storage/ABCD-1234/report.txt, /storage/DCBA-4321/report.txt से अलग फ़ाइल है.)
  • हार्ड कोड की गई FUSE सेवाओं को, डिवाइस के हिसाब से init.rc फ़ाइलों से हटा दिया गया है. इसके बजाय, ज़रूरत पड़ने पर vold से डाइनैमिक तौर पर फ़ोक्ड किया जाता है.

कॉन्फ़िगरेशन में इन बदलावों के अलावा, Android 6.0 में डिवाइस के स्टोरेज को डिवाइस के साथ इस्तेमाल किए जा सकने वाले स्टोरेज के तौर पर इस्तेमाल करने की सुविधा भी शामिल है. Android 6.0 वाले डिवाइसों के लिए, किसी भी फ़िज़िकल मीडिया को पोर्टेबल के तौर पर देखा जाता है.

एडॉप्टेबल स्टोरेज

fstab में, इस्तेमाल किए जा सकने वाले स्टोरेज डिवाइस की जानकारी देने के लिए, fs_mgr_flags फ़ील्ड में encryptable=userdata एट्रिब्यूट का इस्तेमाल करें. यहां एक सामान्य परिभाषा दी गई है:

/devices/platform/mtk-msdc.1/mmc_host*           auto      auto     defaults
voldmanaged=sdcard1:auto,encryptable=userdata

स्टोरेज डिवाइस को इस्तेमाल करने पर, प्लैटफ़ॉर्म उसमें मौजूद कॉन्टेंट मिटा देता है और एक GUID पार्टीशन टेबल लिखता है. इस टेबल में दो पार्टीशन होते हैं:

  • एक छोटा खाली android_meta पार्टीशन, जिसे आने वाले समय में इस्तेमाल करने के लिए रिज़र्व किया गया है. पार्टीशन टाइप का GUID, 19A710A2-B3CA-11E4-B026-10604B889DCF है.
  • एक बड़ा android_ext पार्टीशन, जिसे dm-crypt का इस्तेमाल करके एन्क्रिप्ट किया गया है और जिसे कर्नेल की क्षमताओं के आधार पर, ext4 या f2fs का इस्तेमाल करके फ़ॉर्मैट किया गया है. पार्टीशन टाइप का GUID, 193D1EA4-B3CA-11E4-B075-10604B889DCF है.

पोर्टेबल संग्रहण

fstab में, voldmanaged एट्रिब्यूट वाले स्टोरेज डिवाइसों को डिफ़ॉल्ट रूप से पोर्टेबल माना जाता है. ऐसा तब तक होता है, जब तक encryptable=userdata जैसे किसी दूसरे एट्रिब्यूट की जानकारी नहीं दी जाती. उदाहरण के लिए, यहां यूएसबी ओटीजी डिवाइसों के लिए सामान्य परिभाषा दी गई है:

/devices/*/xhci-hcd.0.auto/usb*             auto            auto    defaults
                                                    voldmanaged=usb:auto

प्लैटफ़ॉर्म, माउंट करने से पहले फ़ाइल सिस्टम टाइप का पता लगाने के लिए blkid का इस्तेमाल करता है. साथ ही, फ़ाइल सिस्टम काम न करने पर, उपयोगकर्ता मीडिया को फ़ॉर्मैट करने का विकल्प चुन सकते हैं.