Android 9 বুটলোডার বুট কারণ স্পেসিফিকেশন নিম্নলিখিত পরিবর্তন অন্তর্ভুক্ত.
বুট কারণ
একটি ডিভাইস কেন রিবুট হয়েছে তা নির্ধারণ করতে একটি বুটলোডার অনন্যভাবে উপলব্ধ হার্ডওয়্যার এবং মেমরি রিসোর্স ব্যবহার করে, তারপর এটির লঞ্চের জন্য অ্যান্ড্রয়েড কার্নেল কমান্ড লাইনে androidboot.bootreason=<reason>
যোগ করে সেই সংকল্পটি যোগাযোগ করে। init
তারপর অ্যান্ড্রয়েড প্রপার্টি bootloader_boot_reason_prop
( ro.boot.bootreason
) এ প্রচার করতে এই কমান্ড লাইনটি অনুবাদ করে। Android 12 বা উচ্চতর সংস্করণের সাথে লঞ্চ করা ডিভাইসগুলির জন্য, কার্নেল সংস্করণ 5.10 বা তার বেশি ব্যবহার করে, androidboot.bootreason=<reason>
কার্নেল কমান্ড লাইনের পরিবর্তে bootconfig এ যোগ করা হয়।
বুট কারণ স্পেসিফিকেশন
অ্যান্ড্রয়েডের পূর্ববর্তী রিলিজগুলি একটি বুট কারণের ফর্ম্যাট নির্দিষ্ট করে যেটিতে কোনও স্পেস ব্যবহার করা হয়নি, সমস্ত ছোট হাতের অক্ষর ছিল, কিছু প্রয়োজনীয়তা অন্তর্ভুক্ত ছিল (যেমন kernel_panic
, watchdog
, cold
/ warm
/ hard
রিপোর্ট করার জন্য), এবং যা অন্যান্য অনন্য কারণে ভাতা দেয়৷ এই ঢিলেঢালা স্পেসিফিকেশনের ফলে শত শত কাস্টম (এবং কখনও কখনও অর্থহীন) বুট কারণ স্ট্রিং ছড়িয়ে পড়ে, যার ফলে একটি নিয়ন্ত্রণহীন পরিস্থিতির সৃষ্টি হয়। বর্তমান অ্যান্ড্রয়েড রিলিজ অনুযায়ী, বুটলোডার দ্বারা দাখিল করা প্রায় অপ্রত্যাশিত বা অর্থহীন সামগ্রীর নিছক গতি bootloader_boot_reason_prop
এর জন্য কমপ্লায়েন্স সমস্যা তৈরি করেছে।
অ্যান্ড্রয়েড 9 রিলিজের সাথে, অ্যান্ড্রয়েড টিম স্বীকার করে যে লিগ্যাসি bootloader_boot_reason_prop
যথেষ্ট গতি আছে এবং রানটাইমে পুনরায় লেখা যাবে না। বুট কারণের স্পেসিফিকেশনের যেকোন উন্নতি অবশ্যই বুটলোডার ডেভেলপারদের সাথে মিথস্ক্রিয়া এবং বিদ্যমান সিস্টেমে পরিবর্তনের মাধ্যমে হতে হবে। সেই লক্ষ্যে অ্যান্ড্রয়েড টিম হল:
- বুটলোডার ডেভেলপারদের উৎসাহিত করতে তাদের সাথে জড়িত হওয়া:
-
bootloader_boot_reason_prop
কে ক্যানোনিকাল, পার্সযোগ্য এবং স্বীকৃত কারণ প্রদান করুন। -
system/core/bootstat/bootstat.cpp
kBootReasonMap
তালিকায় অংশগ্রহণ করুন।
-
-
system_boot_reason_prop
(sys.boot.reason
) এর একটি নিয়ন্ত্রিত এবং রানটাইম-পুনঃলিখনযোগ্য উৎস যোগ করা হচ্ছে। সিস্টেম অ্যাপ্লিকেশানগুলির একটি সীমিত সেট (যেমনbootstat
এবংinit
) এই সম্পত্তিটি পুনরায় লিখতে পারে, তবে সমস্ত অ্যাপগুলিকে এটি পড়ার জন্য সেপলিসি অধিকার দেওয়া যেতে পারে। - সিস্টেম বুট কারণ বৈশিষ্ট্য
system_boot_reason_prop
এ বিষয়বস্তু বিশ্বাস করার আগে userdata মাউন্ট না হওয়া পর্যন্ত অপেক্ষা করার জন্য ব্যবহারকারীদের বুট কারণ সম্পর্কে অবহিত করা।
এত দেরি কেন? যদিও bootloader_boot_reason_prop
বুটের প্রথম দিকে উপলব্ধ থাকে, এটিকে প্রয়োজনের ভিত্তিতে অ্যান্ড্রয়েড নিরাপত্তা নীতি দ্বারা অবরুদ্ধ করা হয় কারণ এটি ভুল, অপব্যবহারযোগ্য এবং নন-ক্যাননিক্যাল তথ্য উপস্থাপন করে। বেশিরভাগ ক্ষেত্রে, শুধুমাত্র বুট সিস্টেমের গভীর জ্ঞান থাকা ডেভেলপারদের এই তথ্য অ্যাক্সেস করতে হবে। system_boot_reason_prop
এর সাথে বুট কারণের জন্য একটি পরিমার্জিত, পার্সযোগ্য এবং ক্যানোনিকাল API শুধুমাত্র ব্যবহারকারীর ডেটা মাউন্ট করার পরেই নির্ভরযোগ্যভাবে এবং সঠিকভাবে তোলা যেতে পারে। বিশেষভাবে:
- ব্যবহারকারীর ডেটা মাউন্ট করার আগে ,
system_boot_reason_prop
bootloader_boot_reason_prop
থেকে মান থাকবে। - ব্যবহারকারীর ডেটা মাউন্ট করার পরে ,
system_boot_reason_prop
সঙ্গতিপূর্ণ হতে বা আরও সঠিক তথ্য প্রতিবেদন করতে আপডেট করা হতে পারে।
এই কারণে, অ্যান্ড্রয়েড 9 বুট কারণটি আনুষ্ঠানিকভাবে অধিগ্রহণ করার আগে সময়কাল বাড়িয়ে দেয়, এটিকে অবিলম্বে বুটে ( bootloader_boot_reason_prop
সহ) থেকে ব্যবহারকারীর ডেটা মাউন্ট করার পরেই উপলব্ধ হতে পরিবর্তন করে ( system_boot_reason_prop
এর সাথে)।
বুটস্ট্যাট যুক্তি নির্ভর করে আরও তথ্যপূর্ণ এবং অনুগত bootloader_boot_reason_prop
এর উপর। যখন সেই বৈশিষ্ট্যটি একটি অনুমানযোগ্য বিন্যাস ব্যবহার করে, তখন এটি সমস্ত নিয়ন্ত্রিত রিবুট এবং শাটডাউন পরিস্থিতিতে নির্ভুলতা উন্নত করে, যা পরিমার্জিত করে এবং system_boot_reason_prop
এর সঠিকতা এবং অর্থকে প্রসারিত করে।
ক্যানোনিকাল বুট কারণ বিন্যাস
Android 9-এ bootloader_boot_reason_prop
এর ক্যানোনিকাল বুট কারণ বিন্যাস নিম্নলিখিত সিনট্যাক্স ব্যবহার করে:
<reason>,<subreason>,<detail>…
বিন্যাস নিয়ম:
- লোয়ার কেস
- কোন ফাঁকা নেই (আন্ডারলাইন ব্যবহার করুন)
- সমস্ত মুদ্রণযোগ্য অক্ষর
- কমা দ্বারা বিভক্ত
reason
,subreason
এবং এক বা একাধিকdetail
উদাহরণ।- একটি প্রয়োজনীয়
reason
যা ডিভাইসটিকে রিবুট বা শাটডাউন করার জন্য সর্বোচ্চ অগ্রাধিকারের কারণ উপস্থাপন করে। - একটি ঐচ্ছিক
subreason
যা ডিভাইসটিকে কেন রিবুট বা শাটডাউন করতে হয়েছিল (বা কে ডিভাইসটি রিবুট বা শাটডাউন করেছে) তার একটি সংক্ষিপ্ত সারাংশ উপস্থাপন করে। - এক বা একাধিক ঐচ্ছিক
detail
মান। একটিdetail
একটি সাবসিস্টেমের দিকে নির্দেশ করতে পারে যা নির্ধারণ করতে কোন নির্দিষ্ট সিস্টেমটিsubreason
পরিণত হয়েছিল। আপনি একাধিকdetail
মান নির্দিষ্ট করতে পারেন, যা সাধারণত গুরুত্বের অনুক্রম অনুসরণ করা উচিত। যাইহোক, সমান গুরুত্বের একাধিকdetail
মান রিপোর্ট করাও গ্রহণযোগ্য।
- একটি প্রয়োজনীয়
bootloader_boot_reason_prop
এর জন্য একটি খালি মান বেআইনি বলে বিবেচিত হয় (যেহেতু এটি অন্য এজেন্টদেরকে বুট কারণের পরে ইনজেক্ট করতে দেয়)।
কারণ প্রয়োজনীয়তা
reason
জন্য প্রদত্ত মান (প্রথম স্প্যান, সমাপ্তির আগে বা কমা) অবশ্যই কার্নেল, শক্তিশালী এবং ভোঁতা কারণে বিভক্ত নিম্নলিখিত সেটের হতে হবে:
- কার্নেল সেট:
- "
watchdog"
-
"kernel_panic"
- "
- শক্তিশালী সেট:
-
"recovery"
-
"bootloader"
-
- ভোঁতা সেট:
-
"cold"
। সাধারণত মেমরি সহ সমস্ত ডিভাইসের সম্পূর্ণ রিসেট নির্দেশ করে। -
"hard"
। সাধারণত নির্দেশ করে যে হার্ডওয়্যারটির স্টেট রিসেট আছে এবংramoops
অবিরাম বিষয়বস্তু ধরে রাখা উচিত। -
"warm"
। সাধারণত মেমরি নির্দেশ করে এবং ডিভাইসগুলি কিছু অবস্থা ধরে রাখে, এবংramoops
(কার্নেলেpstore
ড্রাইভার দেখুন) ব্যাকিং স্টোরে স্থায়ী বিষয়বস্তু থাকে। -
"shutdown"
-
"reboot"
। সাধারণতramoops
স্টেট অজানা এবং হার্ডওয়্যার স্টেট অজানা। এই মানটি একটি ক্যাচল কারণcold
,hard
এবংwarm
মানগুলি ডিভাইসের রিসেটের গভীরতা সম্পর্কে সূত্র প্রদান করে।
-
বুটলোডারদের অবশ্যই একটি কার্নেল সেট বা একটি ভোঁতা সেট reason
প্রদান করতে হবে, এবং যদি এটি নির্ধারণ করা যায় তবে একটি subreason
প্রদান করতে দৃঢ়ভাবে উত্সাহিত করা হয়। উদাহরণ স্বরূপ, একটি পাওয়ার কী দীর্ঘক্ষণ প্রেস করে যাতে ramoops
ব্যাকআপ থাকতে পারে বা নাও থাকতে পারে বুট কারণ "reboot,longkey"
।
কোনো প্রথম-স্প্যান reason
কোনো subreason
বা detail
অংশ হতে পারে না। যাইহোক, যেহেতু কার্নেল সেট কারণগুলি ব্যবহারকারীর স্থান দ্বারা উত্পাদিত করা যায় না, তাই "watchdog"
একটি ভোঁতা সেট কারণের পরে উত্সের বিশদ সহ (উদাহরণস্বরূপ, "reboot,watchdog,service_manager_unresponsive"
, বা "reboot,software,watchdog"
)।
বুট কারণগুলির পাঠোদ্ধার করার জন্য বিশেষজ্ঞ অভ্যন্তরীণ জ্ঞানের প্রয়োজন হবে না এবং/অথবা একটি স্বজ্ঞাত প্রতিবেদনের সাথে মানুষের পাঠযোগ্য হওয়া উচিত। উদাহরণ: "shutdown,vbxd"
(খারাপ), "shutdown,uv"
(ভাল), "shutdown,undervoltage"
(পছন্দের)।
কারণ-সাবব্রেজন সমন্বয়
অ্যান্ড্রয়েড reason
একটি সেট সংরক্ষণ করে - subreason
সংমিশ্রণ যা স্বাভাবিক ব্যবহারে ওভারলোড করা উচিত নয় কিন্তু যদি সংমিশ্রণটি সংশ্লিষ্ট অবস্থাকে সঠিকভাবে প্রতিফলিত করে তবে কেস-বাই-কেস ভিত্তিতে ব্যবহার করা যেতে পারে। সংরক্ষিত সংমিশ্রণের উদাহরণগুলির মধ্যে রয়েছে:
-
"reboot,userrequested"
-
"shutdown,userrequested"
-
"shutdown,thermal"
(thermald
থেকে) -
"shutdown,battery"
-
"shutdown,battery,thermal"
(BatteryStatsService
থেকে) -
"reboot,adb"
-
"reboot,shell"
-
"reboot,bootloader"
-
"reboot,recovery"
আরো বিস্তারিত জানার জন্য, system/core/bootstat/bootstat.cpp
এ kBootReasonMap
এবং Android সোর্স রিপোজিটরিতে সংশ্লিষ্ট গিট চেঞ্জলগ ইতিহাস দেখুন।
বুট কারণ রিপোর্ট করুন
সমস্ত বুট কারণ, হয় বুটলোডার থেকে বা ক্যানোনিকাল বুট কারণে রেকর্ড করা, system/core/bootstat/bootstat.cpp
এর kBootReasonMap
বিভাগে রেকর্ড করা আবশ্যক। kBootReasonMap
তালিকা হল অনুগত এবং লিগ্যাসি অসঙ্গতিপূর্ণ কারণগুলির মিশ্রণ। বুটলোডার ডেভেলপারদের এখানে শুধুমাত্র নতুন কমপ্লায়েন্ট কারণ নিবন্ধন করা উচিত (এবং অসঙ্গতিপূর্ণ কারণ নিবন্ধন করা উচিত নয় যদি না পণ্যটি ইতিমধ্যেই পাঠানো হয় এবং পরিবর্তন করা না হয়)।
আমরা দৃঢ়ভাবে system/core/bootstat/bootstat.cpp
এ বিদ্যমান, সঙ্গতিপূর্ণ এন্ট্রিগুলি ব্যবহার করার এবং একটি অসঙ্গতিপূর্ণ স্ট্রিং ব্যবহার করার আগে সংযম অনুশীলন করার পরামর্শ দিই। একটি নির্দেশিকা হিসাবে, এটি হল:
- বুটলোডার থেকে
"kernel_panic"
রিপোর্ট করতে ঠিক আছে , কারণbootstat
ক্যানোনিকালsystem_boot_reason_prop
এ সাবরিজনগুলি পরিমার্জন করতেkernel_panic signatures
জন্যramoops
পরিদর্শন করতে সক্ষম হতে পারে। - বুটলোডার থেকে
kBootReasonMap
এ (যেমন"panic")
একটি অসঙ্গতিপূর্ণ স্ট্রিং রিপোর্ট করা ঠিক নয় , কারণ এটি শেষ পর্যন্তreason
পরিমার্জন করার ক্ষমতাকে ভেঙে দেবে।
উদাহরণস্বরূপ, যদি kBootReasonMap
"wdog_bark"
থাকে, তাহলে একজন বুটলোডার বিকাশকারীর উচিত:
-
"watchdog,bark"
-এ পরিবর্তন করুন এবংkBootReasonMap
এ তালিকায় যোগ করুন। - যারা প্রযুক্তির সাথে অপরিচিত তাদের জন্য
"bark"
এর অর্থ কী তা বিবেচনা করুন এবং আরও অর্থপূর্ণsubreason
উপলব্ধ কিনা তা নির্ধারণ করুন।
বুট কারণ সম্মতি যাচাই করুন
এই সময়ে, অ্যান্ড্রয়েড একটি সক্রিয় CTS পরীক্ষা প্রদান করে না যা একটি বুটলোডার প্রদান করতে পারে এমন সমস্ত সম্ভাব্য বুট কারণ সঠিকভাবে ট্রিগার বা পরিদর্শন করতে পারে; অংশীদাররা এখনও সামঞ্জস্য নির্ধারণের জন্য একটি প্যাসিভ পরীক্ষা চালানোর চেষ্টা করতে পারে।
ফলস্বরূপ, বুটলোডার কমপ্লায়েন্সের জন্য বুটলোডার ডেভেলপারদের স্বেচ্ছায় উপরে বর্ণিত নিয়ম ও নির্দেশিকাগুলির স্পিরিট মেনে চলতে হবে। আমরা এই ধরনের ডেভেলপারদেরকে AOSP (বিশেষ করে system/core/bootstat/bootstat.cpp
তে) অবদান রাখতে এবং বুট কারণ সংক্রান্ত সমস্যাগুলি নিয়ে আলোচনার জন্য একটি ফোরাম হিসাবে এই সুযোগটি ব্যবহার করার জন্য অনুরোধ করি৷