OTA প্যাকেজ তৈরি করুন

A/B সিস্টেম আপডেট বা নন-A/B সিস্টেম আপডেট ব্যবহার করে এমন ডিভাইসগুলির জন্য সম্পূর্ণ এবং বর্ধিত OTA প্যাকেজ তৈরি করতে আপনি build/make/tools/releasetools এ দেওয়া ota_from_target_files টুল ব্যবহার করতে পারেন। টুলটি Android বিল্ড সিস্টেম দ্বারা উত্পাদিত target-files.zip ফাইলটিকে ইনপুট হিসাবে নেয়।

Android 11 বা উচ্চতর সংস্করণে চলমান ডিভাইসগুলির জন্য, আপনি বিভিন্ন SKU সহ একাধিক ডিভাইসের জন্য একটি OTA প্যাকেজ তৈরি করতে পারেন। এটি করার জন্য গতিশীল আঙ্গুলের ছাপগুলি ব্যবহার করার জন্য লক্ষ্য ডিভাইসগুলিকে কনফিগার করা এবং পূর্ব এবং পরবর্তী অবস্থার এন্ট্রিগুলিতে ডিভাইসের নাম এবং আঙুলের ছাপ অন্তর্ভুক্ত করার জন্য OTA মেটাডেটা আপডেট করা প্রয়োজন৷

Android 8.0 নন-A/B ডিভাইসগুলির জন্য ফাইল-ভিত্তিক OTA প্যাকেজগুলিকে অবমূল্যায়ন করেছে, যার পরিবর্তে অবশ্যই ব্লক-ভিত্তিক OTA প্যাকেজগুলি ব্যবহার করতে হবে৷ ব্লক-ভিত্তিক OTA প্যাকেজ বা Android 7.x বা তার নিচের সংস্করণে চলমান ডিভাইসগুলি তৈরি করতে, --block বিকল্পটি ota_from_target_files প্যারামিটারে পাস করুন।

সম্পূর্ণ আপডেট তৈরি করুন

একটি সম্পূর্ণ আপডেট হল একটি OTA প্যাকেজ যা ডিভাইসের সম্পূর্ণ চূড়ান্ত অবস্থা (সিস্টেম, বুট এবং পুনরুদ্ধার পার্টিশন) ধারণ করে। যতক্ষণ পর্যন্ত ডিভাইসটি প্যাকেজ গ্রহণ এবং প্রয়োগ করতে সক্ষম হয়, প্যাকেজটি ডিভাইসের বর্তমান অবস্থা নির্বিশেষে বিল্ড ইনস্টল করতে পারে। উদাহরণস্বরূপ, tardis ডিভাইসের জন্য target-files.zip আর্কাইভ তৈরি করতে নিম্নলিখিত কমান্ডগুলি রিলিজ টুল ব্যবহার করে।

. build/envsetup.sh && lunch tardis-eng
mkdir dist_output
make dist DIST_DIR=dist_output

make dist একটি সম্পূর্ণ OTA প্যাকেজ তৈরি করে ( $OUT এ)। ফলস্বরূপ .zip ফাইলে tardis ডিভাইসের জন্য OTA প্যাকেজ নির্মাণের জন্য প্রয়োজনীয় সবকিছু রয়েছে। আপনি একটি পাইথন বাইনারি হিসাবে ota_from_target_files তৈরি করতে পারেন এবং এটিকে পূর্ণ বা বর্ধিত প্যাকেজ তৈরি করতে কল করতে পারেন।

ota_from_target_files dist_output/tardis-target_files.zip ota_update.zip

ota_from_target_files পাথ $PATH এ সেট আপ করা হয়েছে এবং এর ফলে পাইথন বাইনারি out/ ডিরেক্টরিতে অবস্থিত।

ota_update.zip এখন টেস্ট ডিভাইসে পাঠানোর জন্য প্রস্তুত (সবকিছুই পরীক্ষা কী দিয়ে স্বাক্ষরিত)। ব্যবহারকারীর ডিভাইসের জন্য, প্রকাশের জন্য সাইনিং বিল্ডে বিশদভাবে আপনার নিজস্ব ব্যক্তিগত কী তৈরি করুন এবং ব্যবহার করুন।

ক্রমবর্ধমান আপডেট তৈরি করুন

একটি বর্ধিত আপডেট হল একটি OTA প্যাকেজ যাতে ডিভাইসে ইতিমধ্যে থাকা ডেটাতে বাইনারি প্যাচ থাকে। ক্রমবর্ধমান আপডেট সহ প্যাকেজগুলি সাধারণত ছোট হয় কারণ তাদের অপরিবর্তিত ফাইলগুলি অন্তর্ভুক্ত করার প্রয়োজন নেই। উপরন্তু, যেহেতু পরিবর্তিত ফাইলগুলি প্রায়শই তাদের পূর্ববর্তী সংস্করণগুলির সাথে খুব মিল থাকে, প্যাকেজটিতে শুধুমাত্র দুটি ফাইলের মধ্যে পার্থক্যগুলির একটি এনকোডিং অন্তর্ভুক্ত করতে হবে।

আপনি কেবলমাত্র সেই ডিভাইসগুলিতে একটি ক্রমবর্ধমান আপডেট প্যাকেজ ইনস্টল করতে পারেন যেখানে প্যাকেজ তৈরিতে সোর্স বিল্ড ব্যবহার করা হয়েছে। একটি ক্রমবর্ধমান আপডেট তৈরি করতে, আপনার পূর্ববর্তী বিল্ড থেকে (যেটি থেকে আপনি আপডেট করতে চান) target_files.zip ফাইলের পাশাপাশি নতুন বিল্ড থেকে target_files.zip ফাইল প্রয়োজন। উদাহরণস্বরূপ, tardis ডিভাইসের জন্য একটি ক্রমবর্ধমান আপডেট তৈরি করতে নিম্নলিখিত কমান্ডগুলি রিলিজ সরঞ্জাম ব্যবহার করে।

ota_from_target_files -i PREVIOUS-tardis-target_files.zip dist_output/tardis-target_files.zip incremental_ota_update.zip

এই বিল্ডটি আগের বিল্ডের মতোই, এবং ইনক্রিমেন্টাল আপডেট প্যাকেজ ( incremental_ota_update.zip ) সংশ্লিষ্ট সম্পূর্ণ আপডেটের চেয়ে অনেক ছোট (60 MB এর পরিবর্তে প্রায় 1 MB)।

ইনক্রিমেন্টাল প্যাকেজের প্রারম্ভিক বিন্দু হিসাবে ব্যবহৃত ঠিক একই পূর্ববর্তী বিল্ড চালানোর জন্য শুধুমাত্র ডিভাইসগুলিতে একটি বর্ধিত প্যাকেজ বিতরণ করুন। PRODUCT_OUT make dist PREVIOUS-tardis-img.zip ( fastboot update PREVIOUS-tardis-target_files.zip নির্মিত, make fastboot flashall দিয়ে ফ্ল্যাশ করা হবে)। অন্য কিছু বিল্ড সহ একটি ডিভাইসে ইনক্রিমেন্টাল প্যাকেজ ইনস্টল করার চেষ্টা করার ফলে একটি ইনস্টলেশন ত্রুটি দেখা দেয়। যখন ইনস্টল ব্যর্থ হয়, ডিভাইসটি একই কাজের অবস্থায় থাকে (পুরানো সিস্টেম চালানো); প্যাকেজটি স্পর্শ করার আগে আপডেট হওয়া সমস্ত ফাইলের পূর্ববর্তী অবস্থা যাচাই করে, তাই ডিভাইসটি অর্ধেক আপগ্রেড অবস্থায় আটকে থাকে না।

সর্বোত্তম ব্যবহারকারীর অভিজ্ঞতার জন্য, প্রতি 3-4টি ক্রমবর্ধমান আপডেটের জন্য একটি সম্পূর্ণ আপডেট অফার করুন। এটি ব্যবহারকারীদের সর্বশেষ রিলিজটি ধরতে এবং ক্রমবর্ধমান আপডেটের দীর্ঘ ইনস্টল ক্রম এড়াতে সহায়তা করে।

একাধিক SKU-এর জন্য OTA প্যাকেজ তৈরি করুন

Android 11 বা উচ্চতর বিভিন্ন SKU সহ একাধিক ডিভাইসের জন্য একটি একক OTA প্যাকেজ ব্যবহার করে সমর্থন করে। এটি করার জন্য গতিশীল আঙ্গুলের ছাপ ব্যবহার করার জন্য লক্ষ্য ডিভাইসগুলিকে কনফিগার করা এবং পূর্ব এবং পরবর্তী অবস্থার এন্ট্রিগুলিতে ডিভাইসের নাম এবং আঙুলের ছাপ অন্তর্ভুক্ত করার জন্য OTA মেটাডেটা (OTA সরঞ্জামগুলি ব্যবহার করে) আপডেট করা প্রয়োজন।

SKU সম্পর্কে

একটি SKU এর বিন্যাস হল সম্মিলিত বিল্ড প্যারামিটার মানগুলির একটি পরিবর্তন এবং এটি সাধারণত বর্তমান build_fingerprint প্যারামিটারগুলির একটি অঘোষিত উপসেট। OEMs একটি SKU-এর জন্য CDD-অনুমোদিত বিল্ড প্যারামিটারগুলির যেকোন সংমিশ্রণ ব্যবহার করতে পারে এবং সেই SKUগুলির জন্য একটি একক চিত্রও ব্যবহার করতে পারে। উদাহরণস্বরূপ, নিম্নলিখিত SKU এর একাধিক বৈচিত্র রয়েছে:

SKU = <product><device><modifierA><modifierB><modifierC>
  • modifierA হল ডিভাইস স্তর (যেমন প্রো, প্রিমিয়াম বা প্লাস)
  • modifierB হল হার্ডওয়্যারের ভিন্নতা (যেমন রেডিও)
  • modifierC হল সেই অঞ্চল, যা সাধারণ হতে পারে (যেমন NA, EMEA, বা CHN ) বা দেশ- বা ভাষা-নির্দিষ্ট (যেমন JPN, ENG, বা CHN)

অনেক OEM একাধিক SKU-এর জন্য একটি একক ছবি ব্যবহার করে, তারপর ডিভাইস বুট হওয়ার পরে রানটাইমে চূড়ান্ত পণ্যের নাম এবং ডিভাইসের ফিঙ্গারপ্রিন্ট সংগ্রহ করে। এই প্রক্রিয়াটি প্ল্যাটফর্ম ডেভেলপমেন্ট প্রক্রিয়াকে সহজ করে, ছোটখাটো কাস্টমাইজেশনের সাথে ডিভাইসগুলিকে সক্ষম করে কিন্তু সাধারণ ছবিগুলি (যেমন tardis এবং tardispro ) শেয়ার করার জন্য বিভিন্ন পণ্যের নাম।

ডাইনামিক ফিঙ্গারপ্রিন্ট ব্যবহার করুন

একটি আঙ্গুলের ছাপ হল বিল্ড প্যারামিটারগুলির একটি সংজ্ঞায়িত সংকলন যেমন ro.product.brand , ro.product.name , এবং ro.product.device ৷ একটি ডিভাইসের ফিঙ্গারপ্রিন্ট সিস্টেম পার্টিশন ফিঙ্গারপ্রিন্ট থেকে প্রাপ্ত করা হয় এবং ডিভাইসে চলমান ছবি (এবং বাইট) এর একটি অনন্য শনাক্তকারী হিসেবে ব্যবহৃত হয়। একটি ডায়নামিক ফিঙ্গারপ্রিন্ট তৈরি করতে, ডিভাইস বুট করার সময় বুটলোডার ভেরিয়েবলের মান পেতে ডিভাইসের build.prop ফাইলে ডায়নামিক লজিক ব্যবহার করুন, তারপর সেই ডিভাইসের জন্য একটি ডাইনামিক ফিঙ্গারপ্রিন্ট তৈরি করতে সেই ডেটা ব্যবহার করুন।

উদাহরণস্বরূপ, tardis এবং tardispro ডিভাইসগুলির জন্য গতিশীল আঙ্গুলের ছাপ ব্যবহার করতে, নীচের চিত্রের মতো নিম্নলিখিত ফাইলগুলি আপডেট করুন৷

  • নিম্নলিখিত লাইনটি ধারণ করতে odm/etc/build_std.prop ফাইলটি আপডেট করুন।

    ro.odm.product.device=tardis
    
  • নিম্নলিখিত লাইন ধারণ করতে odm/etc/build_pro.prop ফাইলটি আপডেট করুন।

    ro.odm.product.device=tardispro
    
  • নিম্নলিখিত লাইনগুলি ধারণ করতে odm/etc/build.prop ফাইলটি আপডেট করুন৷

    ro.odm.product.device=tardis
    import /odm/etc/build_${ro.boot.product.hardware.sku}.prop
    

এই লাইনগুলি ro.boot.product.hardware.sku বুটলোডার প্রপার্টির (যা শুধুমাত্র পঠনযোগ্য) মানের উপর ভিত্তি করে ডিভাইসের নাম, ফিঙ্গারপ্রিন্ট এবং ro.build.fingerprint মানগুলি গতিশীলভাবে সেট করে।

OTA প্যাকেজ মেটাডেটা আপডেট করুন

একটি OTA প্যাকেজে একটি মেটাডেটা ফাইল থাকে ( META-INF/com/android/metadata ) যা OTA প্যাকেজের পূর্বশর্ত এবং পোস্টকন্ডিশন সহ প্যাকেজটি বর্ণনা করে। উদাহরণস্বরূপ, নিম্নলিখিত কোডটি tardis ডিভাইসকে লক্ষ্য করে একটি OTA প্যাকেজের মেটাডেটা ফাইল।

post-build=google/tardis/tardis:11/RP1A.200521.001/6516341:userdebug/dev-keys
post-build-incremental=6516341
post-sdk-level=30
post-security-patch-level=2020-07-05
post-timestamp=1590026334
pre-build=google/tardis/tardis:11/RP1A.200519.002.A1/6515794:userdebug/dev-keys
pre-build-incremental=6515794
pre-device=tardis

pre-device , pre-build-incremental , এবং pre-build মানগুলি OTA প্যাকেজ ইনস্টল করার আগে একটি ডিভাইসের অবশ্যই থাকা অবস্থাকে সংজ্ঞায়িত করে। OTA প্যাকেজ ইন্সটল হওয়ার পরে একটি ডিভাইসের প্রত্যাশিত অবস্থার post-build-incremental এবং post-build মানগুলি নির্ধারণ করে। pre- এবং post- ক্ষেত্রগুলির মানগুলি নিম্নলিখিত সংশ্লিষ্ট বিল্ড বৈশিষ্ট্যগুলি থেকে প্রাপ্ত হয়।

  • pre-device মানটি ro.product.device বিল্ড প্রপার্টি থেকে নেওয়া হয়েছে।
  • pre-build-incremental এবং post-build-incremental মানগুলি ro.build.version.incremental বিল্ড প্রোপার্টি থেকে নেওয়া হয়েছে।
  • pre-build এবং post-build মানগুলি ro.build.fingerprint বিল্ড প্রপার্টি থেকে নেওয়া হয়েছে।

অ্যান্ড্রয়েড 11 বা উচ্চতর চলমান ডিভাইসগুলিতে, আপনি ডিভাইসের গতিশীল ফিঙ্গারপ্রিন্ট তৈরিতে ব্যবহৃত রানটাইম ভেরিয়েবলের মান ধারণ করে এমন একটি ফাইলের পাথ নির্দিষ্ট করতে OTA টুলগুলিতে --boot_variable_file ফ্ল্যাগ ব্যবহার করতে পারেন। তারপরে ডেটাটি OTA মেটাডেটা আপডেট করতে ব্যবহার করা হয় ডিভাইসের নাম এবং আঙুলের ছাপকে pre- এবং post- অবস্থাতে অন্তর্ভুক্ত করতে (পাইপ অক্ষর ব্যবহার করে | ডিলিমিটার হিসাবে)। --boot_variable_file পতাকায় নিম্নলিখিত সিনট্যাক্স এবং বর্ণনা রয়েছে।

  • সিনট্যাক্স: --boot_variable_file <path>
  • বর্ণনা: ro.boot.* বৈশিষ্ট্যের সম্ভাব্য মান ধারণ করে এমন একটি ফাইলের পাথ নির্দিষ্ট করে। যখন কিছু ro.product.* বৈশিষ্ট্য আমদানি বিবৃতি দ্বারা ওভাররাইড করা হয় তখন সম্ভাব্য রানটাইম ফিঙ্গারপ্রিন্ট গণনা করতে ব্যবহৃত হয়। ফাইলটি প্রতি লাইনে একটি বৈশিষ্ট্য আশা করে যেখানে প্রতিটি লাইনের নিম্নলিখিত বিন্যাস রয়েছে: prop_name=value1,value2

উদাহরণস্বরূপ, যখন প্রপার্টি ro.boot.product.hardware.sku=std,pro , tardis এবং tardispro ডিভাইসগুলির জন্য OTA মেটাডেটা নীচে দেখানো হয়েছে৷

post-build=google/tardis/tardis:11/<suffix>|google/tardis/tardispro:11/<suffix>
pre-build=google/tardis/tardis:11/<suffix>|google/tardis/tardispro:11/<suffix>
pre-device=tardis|tardispro

Android 10 চালিত ডিভাইসগুলিতে এই কার্যকারিতা সমর্থন করতে, রেফারেন্স বাস্তবায়ন দেখুন। এই পরিবর্তন তালিকা শর্তসাপেক্ষে build.prop ফাইলে import বিবৃতি পার্স করে, যা সম্পত্তি ওভাররাইডগুলিকে স্বীকৃত হতে এবং চূড়ান্ত OTA মেটাডেটাতে প্রতিফলিত করতে সক্ষম করে।