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.cppkBootReasonMapতালিকায় অংশগ্রহণ করুন।
-
-
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_propbootloader_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 তে) অবদান রাখতে এবং বুট কারণ সংক্রান্ত সমস্যাগুলি নিয়ে আলোচনার জন্য একটি ফোরাম হিসাবে এই সুযোগটি ব্যবহার করার জন্য অনুরোধ করি৷