এই পৃষ্ঠাটি অ্যান্ড্রয়েড ডিভাইসের জন্য কাস্টম কার্নেল তৈরির প্রক্রিয়ার বিবরণ দেয়। এই নির্দেশাবলী আপনাকে সঠিক উৎস নির্বাচন, কার্নেল তৈরি এবং অ্যান্ড্রয়েড ওপেন সোর্স প্রজেক্ট (AOSP) থেকে তৈরি একটি সিস্টেম ইমেজে ফলাফল এম্বেড করার প্রক্রিয়ার মাধ্যমে গাইড করে।
আপনি Repo ব্যবহার করে আরও সাম্প্রতিক কার্নেল উত্সগুলি অর্জন করতে পারেন; আপনার সোর্স চেকআউটের রুট থেকে build/build.sh
চালিয়ে আরও কনফিগারেশন ছাড়াই সেগুলি তৈরি করুন।
উৎস ডাউনলোড করুন এবং টুল তৈরি করুন
সাম্প্রতিক কার্নেলের জন্য, উৎস, টুলচেইন এবং স্ক্রিপ্ট তৈরি করতে repo
ব্যবহার করুন। কিছু কার্নেলের (উদাহরণস্বরূপ, পিক্সেল 3 কার্নেল) একাধিক গিট রিপোজিটরি থেকে উৎসের প্রয়োজন হয়, অন্যদের (উদাহরণস্বরূপ, সাধারণ কার্নেল) শুধুমাত্র একটি উৎসের প্রয়োজন হয়। repo
পদ্ধতি ব্যবহার করে একটি সঠিক উৎস ডিরেক্টরি সেটআপ নিশ্চিত করে।
উপযুক্ত শাখার জন্য উৎস ডাউনলোড করুন:
mkdir android-kernel && cd android-kernel
repo init -u https://android.googlesource.com/kernel/manifest -b BRANCH
repo sync
পূর্ববর্তী `repo init` কমান্ডের সাথে ব্যবহার করা যেতে পারে এমন রেপো শাখার ( BRANCH ) তালিকার জন্য, কার্নেল শাখা এবং তাদের বিল্ড সিস্টেম দেখুন।
পিক্সেল ডিভাইসের জন্য কার্নেল ডাউনলোড এবং কম্পাইল করার বিষয়ে বিস্তারিত জানার জন্য, পিক্সেল কার্নেল তৈরি করা দেখুন।
কার্নেল তৈরি করুন
বেজেল (ক্লিফ) দিয়ে তৈরি করুন
Android 13 Bazel এর সাথে বিল্ডিং কার্নেল চালু করেছে।
aarch64 আর্কিটেকচারের জন্য GKI কার্নেলের জন্য একটি ডিস্ট্রিবিউশন তৈরি করতে, Android 13 এর আগে একটি Android কমন কার্নেল শাখা দেখুন এবং তারপরে নিম্নলিখিত কমান্ডটি চালান:
tools/bazel run //common:kernel_aarch64_dist [-- --destdir=$DIST_DIR]
তারপরে কার্নেল বাইনারি, মডিউল এবং সংশ্লিষ্ট ছবিগুলি $DIST_DIR
ডিরেক্টরিতে অবস্থিত। যদি --destdir
অনির্দিষ্ট হয়, আর্টিফ্যাক্টের অবস্থানের জন্য কমান্ডের আউটপুট দেখুন। বিস্তারিত জানার জন্য, AOSP-এ ডকুমেন্টেশন দেখুন।
build.sh (উত্তরাধিকার) দিয়ে তৈরি করুন
অ্যান্ড্রয়েড 12-এ বা তার নিচের শাখাগুলির জন্য বা ক্লিফ ছাড়া শাখাগুলির জন্য:
build/build.sh
কার্নেল বাইনারি, মডিউল এবং সংশ্লিষ্ট ইমেজ out/ BRANCH /dist
ডিরেক্টরিতে অবস্থিত।
ভার্চুয়াল ডিভাইসের জন্য বিক্রেতা মডিউল তৈরি করুন
Android 13 build.sh
প্রতিস্থাপন করে Bazel (Kleaf) এর সাথে বিল্ডিং কার্নেল চালু করেছে।
virtual_device
মডিউলগুলির জন্য একটি বিতরণ তৈরি করতে, চালান:
tools/bazel run //common-modules/virtual-device:virtual_device_x86_64_dist [-- --destdir=$DIST_DIR]
বেজেল দিয়ে অ্যান্ড্রয়েড কার্নেল তৈরির বিষয়ে আরও বিশদ বিবরণের জন্য, দেখুন। ক্লিফ - বেজেল দিয়ে অ্যান্ড্রয়েড কার্নেল তৈরি করা ।
পৃথক আর্কিটেকচারের জন্য Kleaf সমর্থন সম্পর্কে বিস্তারিত জানতে, ডিভাইস এবং কার্নেলের জন্য Kleaf সমর্থন দেখুন।
build.sh (লেগ্যাসি) দিয়ে ভার্চুয়াল ডিভাইসের জন্য ভেন্ডর মডিউল তৈরি করুন
অ্যান্ড্রয়েড 12 কাটলফিশ এবং গোল্ডফিশ একত্রিত হয়, তাই তারা একই কার্নেল ভাগ করে: virtual_device
। সেই কার্নেলের মডিউলগুলি তৈরি করতে, এই বিল্ড কনফিগারেশনটি ব্যবহার করুন:
BUILD_CONFIG=common-modules/virtual-device/build.config.virtual_device.x86_64 build/build.sh
অ্যান্ড্রয়েড 11 GKI প্রবর্তন করেছে, যা কার্নেলটিকে একটি Google-রক্ষণাবেক্ষণ করা কার্নেল চিত্র এবং বিক্রেতা রক্ষণাবেক্ষণ-মডিউলগুলিতে আলাদা করে, যা আলাদাভাবে নির্মিত।
এই উদাহরণটি একটি কার্নেল ইমেজ কনফিগারেশন দেখায়:
BUILD_CONFIG=common/build.config.gki.x86_64 build/build.sh
এই উদাহরণটি একটি মডিউল কনফিগারেশন দেখায় (কাটলফিশ এবং এমুলেটর):
BUILD_CONFIG=common-modules/virtual-device/build.config.cuttlefish.x86_64 build/build.sh
কার্নেল চালান
কাস্টম-নির্মিত কার্নেল চালানোর একাধিক উপায় রয়েছে। নিম্নলিখিত বিভিন্ন উন্নয়ন দৃশ্যের জন্য উপযুক্ত পরিচিত উপায়.
অ্যান্ড্রয়েড ইমেজ বিল্ডে এম্বেড করুন
AOSP গাছের মধ্যে সংশ্লিষ্ট কার্নেল বাইনারি অবস্থানে Image.lz4-dtb
অনুলিপি করুন এবং বুট চিত্রটি পুনর্নির্মাণ করুন।
বিকল্পভাবে, make bootimage
ব্যবহার করার সময় TARGET_PREBUILT_KERNEL
ভেরিয়েবলটি সংজ্ঞায়িত করুন (বা অন্য কোনো make
কমান্ড লাইন যা বুট ইমেজ তৈরি করে)। device/common/populate-new-device.sh
এর মাধ্যমে সেট আপ করায় এই ভেরিয়েবলটি সমস্ত ডিভাইস দ্বারা সমর্থিত। যেমন:
export TARGET_PREBUILT_KERNEL=DIST_DIR/Image.lz4-dtb
ফাস্টবুট দিয়ে ফ্ল্যাশ এবং বুট কার্নেল
একটি বুট ইমেজ তৈরি এবং বুট করার প্রক্রিয়াটিকে স্ট্রিমলাইন করার জন্য সাম্প্রতিকতম ডিভাইসগুলিতে একটি বুটলোডার এক্সটেনশন রয়েছে।
ফ্ল্যাশিং ছাড়া কার্নেল বুট করতে:
adb reboot bootloader
fastboot boot Image.lz4-dtb
এই পদ্ধতিটি ব্যবহার করে, কার্নেলটি আসলে ফ্ল্যাশ হয় না এবং রিবুট জুড়ে টিকে থাকে না।
কাটলফিশে কার্নেল চালান
আপনি Cuttlefish ডিভাইসে আপনার পছন্দের আর্কিটেকচারে কার্নেল চালাতে পারেন।
কার্নেল আর্টিফ্যাক্টগুলির একটি নির্দিষ্ট সেট সহ একটি কাটলফিশ ডিভাইস বুট করতে, প্যারামিটার হিসাবে লক্ষ্য কার্নেল আর্টিফ্যাক্টগুলির সাথে cvd create
কমান্ডটি চালান। নিম্নলিখিত উদাহরণ কমান্ড common-android14-6.1
কার্নেল ম্যানিফেস্ট থেকে একটি arm64 লক্ষ্যের জন্য কার্নেল আর্টিফ্যাক্ট ব্যবহার করে।
cvd create \
-kernel_path=/$PATH/$TO/common-android14-6.1/out/android14-6.1/dist/Image \
-initramfs_path=/$PATH/$TO/common-android14-6.1/out/android14-6.1/dist/initramfs.img
আরও তথ্যের জন্য, Cuttlefish-এর উপর কার্নেল তৈরি করুন দেখুন।
কার্নেল বিল্ড কাস্টমাইজ করুন
ক্লিফ বিল্ডের জন্য কার্নেল বিল্ড কাস্টমাইজ করতে, ক্লিফ ডকুমেন্টেশন দেখুন।
build.sh (উত্তরাধিকার) দিয়ে কার্নেল বিল্ড কাস্টমাইজ করুন
build/build.sh
জন্য, বিল্ড প্রক্রিয়া এবং ফলাফল পরিবেশের পরিবর্তনশীল দ্বারা প্রভাবিত হতে পারে। তাদের বেশিরভাগই ঐচ্ছিক এবং প্রতিটি কার্নেল শাখা একটি সঠিক ডিফল্ট কনফিগারেশনের সাথে আসা উচিত। সর্বাধিক ব্যবহৃত হয় এখানে তালিকাভুক্ত করা হয়. একটি সম্পূর্ণ (এবং আপ-টু-ডেট) তালিকার জন্য, build/build.sh
দেখুন।
পরিবেশ পরিবর্তনশীল | বর্ণনা | উদাহরণ |
---|---|---|
BUILD_CONFIG | কনফিগার ফাইল তৈরি করুন যেখান থেকে আপনি বিল্ড এনভায়রনমেন্ট শুরু করবেন। রেপো রুট ডিরেক্টরির সাপেক্ষে অবস্থানটি অবশ্যই সংজ্ঞায়িত করা উচিত। build.config তে ডিফল্ট।সাধারণ কার্নেলের জন্য বাধ্যতামূলক। | BUILD_CONFIG=common/build.config.gki.aarch64 |
CC | ওভাররাইড কম্পাইলার ব্যবহার করতে হবে। build.config দ্বারা সংজ্ঞায়িত ডিফল্ট কম্পাইলারে ফিরে আসে। | CC=clang |
DIST_DIR | কার্নেল বিতরণের জন্য বেস আউটপুট ডিরেক্টরি। | DIST_DIR=/path/to/my/dist |
OUT_DIR | কার্নেল বিল্ডের জন্য বেস আউটপুট ডিরেক্টরি। | OUT_DIR=/path/to/my/out |
SKIP_DEFCONFIG | make defconfig এড়িয়ে যান | SKIP_DEFCONFIG=1 |
SKIP_MRPROPER | এড়িয়ে যান make mrproper | SKIP_MRPROPER=1 |
স্থানীয় বিল্ডের জন্য কাস্টম কার্নেল কনফিগারেশন
অ্যান্ড্রয়েড 14 এবং তার উপরে, আপনি কার্নেল কনফিগারগুলি কাস্টমাইজ করতে ডিফকনফিগ টুকরা ব্যবহার করতে পারেন। defconfig টুকরা উপর Kleaf ডকুমেন্টেশন দেখুন.
বিল্ড কনফিগারেশনের সাথে স্থানীয় বিল্ডের জন্য কাস্টম কার্নেল কনফিগারেশন (লিগেসি)
অ্যান্ড্রয়েড 13 এবং নীচে, নিম্নলিখিত দেখুন।
আপনার যদি কার্নেল কনফিগারেশন বিকল্পটি নিয়মিত পরিবর্তন করার প্রয়োজন হয়, উদাহরণস্বরূপ, একটি বৈশিষ্ট্যের উপর কাজ করার সময়, অথবা যদি আপনার বিকাশের উদ্দেশ্যে একটি বিকল্প সেট করার প্রয়োজন হয়, আপনি স্থানীয় পরিবর্তন বা বিল্ড কনফিগারেশনের অনুলিপি বজায় রেখে সেই নমনীয়তা অর্জন করতে পারেন।
ভেরিয়েবল POST_DEFCONFIG_CMDS একটি বিবৃতিতে সেট করুন যা স্বাভাবিক make defconfig
ধাপ সম্পন্ন হওয়ার পরে মূল্যায়ন করা হয়। যেহেতু build.config
ফাইলগুলি বিল্ড এনভায়রনমেন্টে সোর্স করা হয়, build.config
এ সংজ্ঞায়িত ফাংশনগুলিকে পোস্ট-defconfig কমান্ডের অংশ হিসাবে বলা যেতে পারে।
একটি সাধারণ উদাহরণ হল বিকাশের সময় ক্রসহ্যাচ কার্নেলের জন্য লিঙ্ক টাইম অপ্টিমাইজেশান (LTO) নিষ্ক্রিয় করা। LTO রিলিজ করা কার্নেলের জন্য উপকারী হলেও, বিল্ড টাইমে ওভারহেড উল্লেখযোগ্য হতে পারে। build/build.sh
ব্যবহার করার সময় স্থানীয় build.config
এ যোগ করা নিম্নোক্ত স্নিপেটটি ক্রমাগতভাবে LTO অক্ষম করে।
POST_DEFCONFIG_CMDS="check_defconfig && update_debug_config"
function update_debug_config() {
${KERNEL_DIR}/scripts/config --file ${OUT_DIR}/.config \
-d LTO \
-d LTO_CLANG \
-d CFI \
-d CFI_PERMISSIVE \
-d CFI_CLANG
(cd ${OUT_DIR} && \
make O=${OUT_DIR} $archsubarch CC=${CC} CROSS_COMPILE=${CROSS_COMPILE} olddefconfig)
}
কার্নেল সংস্করণ সনাক্ত করুন
আপনি দুটি উত্স থেকে তৈরি করার জন্য সঠিক সংস্করণ সনাক্ত করতে পারেন: AOSP গাছ এবং সিস্টেম চিত্র।
AOSP গাছ থেকে কার্নেল সংস্করণ
AOSP ট্রিতে প্রি-বিল্ট কার্নেল সংস্করণ রয়েছে। গিট লগ কমিট বার্তার অংশ হিসাবে সঠিক সংস্করণ প্রকাশ করে:
cd $AOSP/device/VENDOR/NAME
git log --max-count=1
যদি কার্নেল সংস্করণটি গিট লগে তালিকাভুক্ত না থাকে তবে নীচে বর্ণিত হিসাবে সিস্টেম চিত্র থেকে এটি পান।
সিস্টেম ইমেজ থেকে কার্নেল সংস্করণ
একটি সিস্টেম ইমেজে ব্যবহৃত কার্নেল সংস্করণ নির্ধারণ করতে, কার্নেল ফাইলের বিরুদ্ধে নিম্নলিখিত কমান্ডটি চালান:
file kernel
Image.lz4-dtb
ফাইলগুলির জন্য, চালান:
grep -a 'Linux version' Image.lz4-dtb
একটি বুট ইমেজ তৈরি করুন
কার্নেল বিল্ড এনভায়রনমেন্ট ব্যবহার করে একটি বুট ইমেজ তৈরি করা সম্ভব।
init_boot সহ ডিভাইসগুলির জন্য একটি বুট চিত্র তৈরি করুন
init_boot
পার্টিশন সহ ডিভাইসগুলির জন্য, বুট ইমেজ কার্নেলের সাথে তৈরি করা হয়। initramfs
ইমেজ বুট ইমেজে এম্বেড করা নেই।
উদাহরণস্বরূপ, ক্লিফের সাথে, আপনি এর সাথে GKI বুট চিত্র তৈরি করতে পারেন:
tools/bazel run //common:kernel_aarch64_dist [-- --destdir=$DIST_DIR]
build/build.sh
(লেগ্যাসি) দিয়ে, আপনি GKI বুট ইমেজ তৈরি করতে পারেন:
BUILD_CONFIG=common/build.config.gki.aarch64 build/build.sh
GKI বুট চিত্রটি $DIST_DIR এ অবস্থিত।
init_boot ছাড়া ডিভাইসের জন্য একটি বুট চিত্র তৈরি করুন (উত্তরাধিকার)
init_boot
পার্টিশন ছাড়া ডিভাইসের জন্য, আপনার একটি ramdisk বাইনারি প্রয়োজন, যেটি আপনি একটি GKI বুট ইমেজ ডাউনলোড করে আনপ্যাক করে পেতে পারেন। সংশ্লিষ্ট Android রিলিজ থেকে যেকোন GKI বুট ইমেজ কাজ করবে।
tools/mkbootimg/unpack_bootimg.py --boot_img=boot-5.4-gz.img
mv $KERNEL_ROOT/out/ramdisk gki-ramdisk.lz4
টার্গেট ফোল্ডারটি কার্নেল ট্রি (বর্তমান কার্যকারী ডিরেক্টরি) এর শীর্ষ-স্তরের ডিরেক্টরি।
আপনি যদি AOSP মেইন দিয়ে ডেভেলপ করে থাকেন, তাহলে আপনি ci.android.com- এ aosp_arm64 বিল্ড থেকে ramdisk-recovery.img
বিল্ড আর্টিফ্যাক্ট ডাউনলোড করতে পারেন এবং সেটিকে আপনার রামডিস্ক বাইনারি হিসেবে ব্যবহার করতে পারেন।
যখন আপনার কাছে একটি ramdisk বাইনারি থাকে এবং আপনি কার্নেল বিল্ডের রুট ডিরেক্টরিতে এটিকে gki-ramdisk.lz4
এ কপি করেন, আপনি সম্পাদন করে একটি বুট ইমেজ তৈরি করতে পারেন:
BUILD_BOOT_IMG=1 SKIP_VENDOR_BOOT=1 KERNEL_BINARY=Image GKI_RAMDISK_PREBUILT_BINARY=gki-ramdisk.lz4 BUILD_CONFIG=common/build.config.gki.aarch64 build/build.sh
আপনি যদি x86-ভিত্তিক আর্কিটেকচারের সাথে কাজ করেন, তাহলে Image
bzImage
দিয়ে এবং aarch64
x86_64
দিয়ে প্রতিস্থাপন করুন :
BUILD_BOOT_IMG=1 SKIP_VENDOR_BOOT=1 KERNEL_BINARY=bzImage GKI_RAMDISK_PREBUILT_BINARY=gki-ramdisk.lz4 BUILD_CONFIG=common/build.config.gki.x86_64 build/build.sh
এই ফাইলটি $KERNEL_ROOT/out/$KERNEL_VERSION/dist
আর্টিফ্যাক্ট ডিরেক্টরিতে অবস্থিত।
বুট চিত্রটি out/<kernel branch>/dist/boot.img
এ অবস্থিত।