EROFS

EROFS, रीड-ओनली फ़ाइल सिस्टम है. इसे Linux 4.19 में लॉन्च किया गया था. यह डेटा को कम करने और डुप्लीकेट डेटा हटाने की सुविधा देता है. साथ ही, इसे डेटा पढ़ने की परफ़ॉर्मेंस के लिए ऑप्टिमाइज़ किया गया है.

EROFS और अन्य कंप्रेस किए गए फ़ाइल सिस्टम के बीच मुख्य अंतर यह है कि EROFS, फ़ाइलों को बिना किसी बदलाव के डिकंप्रेस कर सकता है. कंप्रेस किया गया डेटा, ब्लॉक के आखिर में स्टोर किया जाता है, ताकि उसे उसी पेज में अनकंप्रेस किया जा सके. EROFS इमेज में, 99% से ज़्यादा ब्लॉक इस स्कीम का इस्तेमाल कर सकते हैं. इससे का इस्तेमाल करें.

EROFS फ़ॉर्मैट में इमेज को कंप्रेस करने की ज़रूरत नहीं होती. हालांकि, कंप्रेशन का इस्तेमाल करते समय, इमेज औसतन करीब 25% छोटी होती हैं. सबसे ज़्यादा कंप्रेस करने पर, इमेज का साइज़ 45% तक कम हो सकता है.

EROFS, रैंडम और क्रम से ऐक्सेस करने के समय, दूसरे फ़ाइल सिस्टम की तुलना में बेहतर परफ़ॉर्म करता है. भले ही, डेटा को कंप्रेस किया गया हो या नहीं.

बिल्ड में बदलाव करें

EROFS को चालू करने के लिए, BoardConfig.mk में फ़ाइल सिस्टम टाइप erofs का इस्तेमाल करें. उदाहरण के लिए:

BOARD_SYSTEMIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE := erofs
BOARD_SYSTEM_DLKMIMAGE_FILE_SYSTEM_TYPE := erofs

fstab में हुए बदलाव

fstab टाइप erofs है और सिर्फ़ ro माउंट करने की ज़रूरत है. EXT4 पर आधारित GSI इमेज की जांच करने की सुविधा बनाए रखने के लिए, /system. के लिए दो fstab एंट्री का इस्तेमाल किया जा सकता है

उदाहरण के लिए:

system    /system    erofs   ro              wait,slotselect,avb=vbmeta_system,logical,first_stage_mount
system    /system    ext4    ro,barrier=1    wait,slotselect,avb=vbmeta_system,logical,first_stage_mount

कंप्रेशन ट्यूनिंग

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

BOARD_EROFS_PCLUSTER_SIZE := 262144

इससे PCLUSTER या वैरिएबल लंबाई वाले ब्लॉक का साइज़, 262144 बाइट पर सेट हो जाता है. नंबर 4096 का गुणांक होना चाहिए. इस दर पर कम मुनाफ़ा होता है ज़्यादा वैल्यू और ज़्यादा वैल्यू का इस्तेमाल करने पर, पढ़े जाने की परफ़ॉर्मेंस घट सकती है. यह डिवाइस हार्डवेयर.

कंप्रेस करने की सुविधा बंद करें

डिफ़ॉल्ट रूप से, कंप्रेस करने का स्कीम lz4hc होता है. कंप्रेस करने की सुविधा बंद करने के लिए, इनका इस्तेमाल करें:

BOARD_EROFS_COMPRESSOR := none

इसे हर पार्टीशन के हिसाब से भी बदला जा सकता है. उदाहरण के लिए:

BOARD_SYSTEMIMAGE_EROFS_COMPRESSOR := none

डुप्लीकेट कॉपी हटाने की तकनीक

EROFS, डुप्लीकेट ब्लॉक को इस फ़्लैग के साथ शेयर कर सकता है:

BOARD_EROFS_SHARE_DUP_BLOCKS := true

Android 13 और उसके बाद के वर्शन में, इस फ़्लैग का इस्तेमाल करने के लिए, कंप्रेस करने की सुविधा बंद होनी चाहिए.

ऑनलाइन ट्रैवल एजेंसी (ओटीए) पर असर

Android 13 के बाद, वर्चुअल A/B के साथ EROFS पूरी तरह से काम करता है. ओटीए पैकेज LZ4 को बेहतर तरीक़े से डीकंप्रेस करके, जनरेटर से डेल्टा जनरेट किया जा सकता है स्ट्रीम करता है. जब तक सोर्स और टारगेट, दोनों प्लैटफ़ॉर्म का इस्तेमाल करता रहता है OTA पैकेज की तरह ही, OTA पैकेज का साइज़ EXT4 पर आधारित OTA. भले ही, src या dst बिल्ड एक जैसे LZ4 का इस्तेमाल न करता हो लाइब्रेरी, ओटीए साइज़ पर थोड़ा ही असर डालना चाहिए.