Android 12 और इसके बाद के वर्शन पर लॉन्च होने वाले डिवाइस, mm_events
का इस्तेमाल करते हैं. यह मेमोरी से जुड़े आंकड़ों का एक सेट है. जब सिस्टम पर मेमोरी का दबाव पड़ता है, तब ये आंकड़े समय-समय पर कैप्चर किए जाते हैं. mm_events
को perfetto
ट्रेसिंग मेकेनिज़्म के साथ इंटिग्रेट किया गया है. साथ ही, यह सिर्फ़ तब चालू होता है, जब मेमोरी पर दबाव पड़ता है. इसलिए, इसकी वजह से परफ़ॉर्मेंस पर पड़ने वाला असर कम होता है. आंकड़े इकट्ठा करने की प्रोसेस तब शुरू होती है, जब कर्नल के kswapd
, direct reclaim,
या compaction
मैकेनिज़्म चालू हो जाते हैं. यह प्रोसेस, कॉन्फ़िगर किए जा सकने वाले समय तक चालू रहती है, ताकि नियमित अंतराल पर आंकड़े कैप्चर किए जा सकें.
बग रिपोर्ट फ़ाइल करते समय, सिस्टम की मेमोरी की स्थिति का एक बार का स्नैपशॉट देने के बजाय, mm_events
मेमोरी के इस्तेमाल से जुड़े आंकड़ों का छोटा सा इतिहास दिखाता है. इससे यह पता चलता है कि मेमोरी पर कितना दबाव पड़ा. कैप्चर किए गए आंकड़ों को यहां दी गई टेबल में दिखाया गया है.
vmstat फ़ील्ड
nr_free_pages | nr_slab_reclaimable |
nr_slab_unreclaimable | nr_active_file |
nr_inactive_file | nr_active_anon |
nr_inactive_anon | workingset_refault |
workingset_activate | nr_file_pages |
pgpgin | pgpgout |
pswpin | pswpout |
pgsteal_kswapd_dma | pgsteal_kswapd_normal |
pgsteal_kswapd_movable | pgsteal_direct_dma |
pgsteal_direct_normal | pgsteal_direct_movable |
pgscan_kswapd_dma | pgscan_kswapd_normal |
pgscan_kswapd_movable | pgscan_direct_dma |
pgscan_direct_normal | pgscan_direct_movable |
compact_migrate_scanned | compact_free_scanned |
mm से जुड़े ट्रेस इवेंट
vmscan/mm_vmscan_kswapd_wake | vmscan/mm_vmscan_kswapd_sleep |
vmscan/mm_vmscan_direct_reclaim_begin | vmscan/mm_vmscan_direct_reclaim_end |
compaction/mm_compaction_begin | compaction/mm_compaction_end |
mm_events डेटा का विश्लेषण करना
अगर mm_events
चालू है, तो डिवाइस में मेमोरी की समस्या शुरू होने के तुरंत बाद कैप्चर किए गए इवेंट की गड़बड़ी की रिपोर्ट में, mm_events
के पिछले डेटा के आंकड़े शामिल होते हैं. यह डेटा, mm_events
में ज़िप की गई रिपोर्ट के तौर पर होता हैFS/data/misc/perfetto-traces/bugreport/systrace.pftrace.
Perfetto यूज़र इंटरफ़ेस (यूआई) का इस्तेमाल करके, विश्लेषण के लिए vmstat
डेटा और ftrace
इवेंट, दोनों देखे जा सकते हैं.
vmstat डेटा
systrace.pftrace
डेटा को टाइमलाइन पर ग्राफ़ के तौर पर देखने के लिए, systrace.pftrace
फ़ाइल को Perfetto यूज़र इंटरफ़ेस (यूआई) पर अपलोड करें. जैसा कि पहले फ़िगर में दिखाया गया है:vmstat
पहली इमेज. vmstat के ग्राफ़िकल डेटा की टाइमलाइन.
ftrace इवेंट
कैप्चर किए गए ftrace
mm_events
को टाइमलाइन पर ग्राफ़ के तौर पर नहीं दिखाया जाता. इन्हें देखने के लिए, क्वेरी एसक्यूएल टैब पर क्लिक करें. यह टैब, दूसरी इमेज में दिखाए गए तरीके से दिखता है:
दूसरी इमेज. इसे ऐक्सेस करने के लिए, क्वेरी (एसक्यूएल) पर क्लिक करें.
mm_events कुकी चालू करना
mm_events को चालू करने के लिए, वेंडर init.rc
से sysprop persist.mm_events.enabled=true
सेट करें.
mm_events की मेमोरी और सीपीयू के इस्तेमाल को कम करने के लिए, ये तरीके अपनाए जाते हैं:
mm-events ftrace
इंस्टेंस, हर सीपीयू के लिए 4 केबी बफ़र का इस्तेमाल करता है.kmem_activity
ट्रिगर को हर मिनट में सिर्फ़ एक बार ट्रिगर किया जा सकता है.- एक समय में सिर्फ़ एक
mm-events
ट्रेस सेशन चालू किया जा सकता है.
पसंद के मुताबिक बनाएं
mm_events
, perfetto
ट्रेस कॉन्फ़िगरेशन फ़ाइल का इस्तेमाल करता है. इससे यह तय किया जाता है कि ट्रेसिंग सेशन के दौरान, कौनसे आंकड़े कैप्चर करने हैं.
/vendor/etc/mm_events.cfg
में, Perfetto के लिए कस्टम ट्रेस कॉन्फ़िगरेशन दिया जा सकता है.
उपलब्ध ट्रेस कॉन्फ़िगरेशन फ़ील्ड के बारे में जानने के लिए, Perfetto के दस्तावेज़ देखें.
ट्रेस कॉन्फ़िगरेशन के उदाहरण के लिए, यह mm_events.cfg
उदाहरण देखें.
यह पक्का करने के लिए कि मेमोरी प्रेशर की वजह से ट्रेस ट्रिगर हो जाए, स्निपेट में ट्रेस कॉन्फ़िगरेशन में शामिल किए जाने वाले ज़रूरी फ़ील्ड दिखाए गए हैं:
# Ensures only 1 tracing session with this key can be active
unique_session_name: "perfetto_mm_events_session"
# If a trace with bugreport_score > 0 is running,
# the captured data is made available in the zipped bugreport
# at FS/data/misc/perfetto-traces/bugreport/systrace.pftrace
bugreport_score: 100
trigger_config {
trigger_mode: START_TRACING
trigger_timeout_ms: 3600000 # 1 hour
triggers {
# kmem_activity trigger gets activated when memory pressure
# is detected
name: "kmem_activity"
stop_delay_ms: 360000 # 6 mins
}
}
इस कॉन्फ़िगरेशन में, mm_events
, Perfetto kmem_activity
ट्रिगर करता है. इसके बाद, Perfetto ट्रेस सेशन, vm_stats
और ftrace
मेमोरी इवेंट कैप्चर करना शुरू कर देता है. यह प्रोसेस, कॉन्फ़िगर की गई stop_delay_ms
अवधि (36,000 मि॰से॰ यानी 6 मिनट) के खत्म होने तक चलती है.
ट्रिगर टाइमआउट को बड़ी वैल्यू पर सेट किया जाता है. इस मामले में, यह वैल्यू एक घंटा है. साथ ही,
mm_events config
इसे समय-समय पर फिर से चालू किया जाता है, ताकि यह पक्का किया जा सके कि mm_events
हमेशा चालू रहे. इसके बाद, एक बग रिपोर्ट जनरेट होती है. इसमें पहली इमेज और दूसरी इमेज में दिखाया गया डेटा शामिल होता है.