نگاهی عمیق به اندروید Q با مهندسان توسعه‌ اندروید

اندروید Q مرکز توجه اخبار گوگل در کنفرانس Google I/O بود و مانند همیشه توجه کاربران و کارشناسان را به عضو بعدی خانواده‌ی اندروید جلب کرد. آرس‌تکنیکا به رسم رویدادهای قبلی گوگل مصاحبه‌ای با مهندسان داخلی اندروید داشت تا اطلاعاتی دقیق‌تر از نسخه‌ی بعدی این سیستم‌عامل کسب کند. مصاحبه علاوه بر پرداختن به اندروید Q، پروژه‌ی مهندسی بزرگ‌‌تر گوگل موسوم به Project Mainline را هم پوشش می‌دهد. هدف اصلی مین‌لاین، ایجاد امکان به‌رورزسانی بخش‌های اصلی سیستم‌عامل بدون به‌روزرسانی کلی برای گوگل و حتی تولیدکننده‌های دیگر گوشی هوشمند است. با نگاهی اولیه به توضیح پروژه‌ی مذکور، متوجه اهمیت فنی و خبری آن می‌شویم.

 

دیو برک (Dave Burke) به‌عنوان معاون ارشد بخش مهندسی اندروید شناخته می‌شود. از نگاه رسانه‌ها او دانشنامه‌ای کامل از اندروید است که همیشه پاسخ‌هایی کاربردی به سؤال‌های پیرامون سیستم‌عامل موبایلی گوگل دارد. ایلیان مالکو (Iliyan Malchev) کارشناس دیگر این مصاحبه است که به‌عنوان مهندس ارشد در اندروید، مدیر Project Treble و همه‌ی بخش‌های مرتبط با هماهنگ‌سازی لینوکس فعالیت می‌کند.

در مصاحبه‌ی امسال آرس‌تکنیکا پیرامون سیستم‌عامل اندروید، انوار گولوم (Anwar Ghuloum) هم حضور داشت که مدیر ارشد مهندسی اندروید و همچنین مدیر پروژه‌ی مین‌لاین است. مین‌لاین در کنفرانس امسال به‌عنوان «پروژه‌ی بزرگ بعدی در به‌روزرسانی اندروید» مطرح شد و به‌نوعی مهم‌ترین خبر رویداد بود.

در ادامه‌ی این مقاله‌ به مصاحبه‌ی آرس‌تکنیکا با مهندسان و مدیران ارشد گوگل پیرامون سیستم‌عامل جدید و پروژه‌ی مین‌لاین می‌پردازیم. پیش از ورود به مصاحبه،‌ ابتدا تاریخچه‌ای از Mainline را بررسی می‌کنیم.

Android Q / اندروید کیو

پروژه‌ی Mainline، تغییر مسیری اساسی در توسعه‌ی اندروید

گوگل از سال‌ها پیش قصد داشت تا اندروید را به سیستم‌عاملی تبدیل کند که قابلیت به‌روزرسانی بخش‌به‌بخش داشته باشد. در سال‌های ابتدایی عمر اندروید، اپلیکیشن‌های اختصاصی گوگل و اپلیکیشن‌های سیستمی در اپ‌استور اندروید منتشر می‌شدند. درنتیجه گوگل می‌توانست قابلیت‌های متعدد را هر زمان که تمایل داشت، ارائه دهد. سپس Google Play Services از راه رسید که بسیاری از APIهای توسعه‌ای را به اپ استور اندروید فرستاد. از آن زمان، به‌روزرسانی‌های مرتبط با توسعه‌دهنده‌ها در API توسط گوگل ارائه می‌شدند. در اندروید ۸، شاهد معرفی Project Treble بودیم که سیستم‌عامل را از پشتیبانی سخت‌افزاری جدا کرد. درنتیجه گوگل یک قدم به توسعه‌ی آسان‌تر به‌روزرسانی‌ها نزدیک‌تر شد.

بزرگ‌ترین راهکار گوگل برای ماژولار کردن اندروید در اندروید Q و به‌نام مین‌لاین مطرح شد. در پروژه‌ی جدید رویکردی مشابه روزهای ابتدایی اندروید پیش گرفته می‌شود و این بار، قطعات هسته‌ای سیستم‌عامل به پلی‌استور می‌روند. درواقع مین‌لاین از لایه‌های سطحی اپلیکیشن عمیق‌تر می‌رود و قطعاتی مرتبط‌تر با کارایی سیستم همچون فریمورک‌های رسانه‌ای و ART به‌صورت جداگانه به‌روزرسانی می‌شوند.

پروژه‌ی مین‌لاین در ادامه‌ی ماژولارسازی سیستم‌عامل اندروید معرفی شد

پلی استور همیشه اپلیکیشن‌ها را به‌صورت پکیج‌های APK ارائه داده است. دراین‌میان برای بسیاری از قطعاتی که در پروژه‌ی مین‌لاین ماژولار می‌شوند، چنین رویکردی ممکن نخواهد بود و نمی‌توان آن‌ها را به‌صورت APK منتشر کرد. سیستم APK برای کاربردهای مبتنی بر سیستم یا سمت کاربر طراحی شد و محدودیت‌هایی در بخش‌های مرتبط با مجوزهای کاربری یا اجرا در مرحله‌ی بوت سیستم دارد.

گوگل برای ماژولار کردن قطعات سیستمی اندروید، به راهکاری کاربردی‌تر از APK به‌نام APEX رسید. فایل‌های APEX قابلیت کسب دسترسی‌های روت را دارند و در همان مراحل راه‌اندازی اولیه شروع به کار می‌کنند. درنتیجه امکان به‌روزرسانی‌های قطعات بیشتر سیستم را به گوگل یا تولیدکننده‌های دیگر می‌دهند. درنهایت نتیجه می‌گیریم که APK برای سطوح دسترسی کاربر و سیستم طراحی شد و APEX قطعات هسته‌ای‌تر سیستم را پوشش می‌دهد. در جدول زیر نمونه‌‌ای از پکیج‌های مربوطه را مشاهده می‌کنید.

اندروید q

ماژول‌های پروژه‌ی مین‌لاین در آینده بخش‌های بیشتری از سیستم اندروید را اشغال خواهند کرد. گوگل اکنون و در نسخه‌های ابتدایی اندروید Q، روی سه بخش متمرکز شده است: پایداری، امنیت و حریم خصوصی. به‌هرحال با نگاهی به جدول بالا متوجه برنامه‌های گوگل در اولویت‌بندی ماژول‌سازی از بخش‌های متعدد اندروید می‌شویم. همین جدول اولین سؤال‌ها را پیرامون برنامه‌ی توسعه‌ی پروژه‌ی مین‌لاین ایجاد می‌کند.

در انتخاب اولویت ماژول‌های سیستمی اندروید در مین‌لاین، چه اصولی را مدنظر قرار می‌دهید؟

انوار گولوم: طرح ایده‌آل ما، الزامی بودن بخش‌بندی همه‌ی قطعات است. روش کاری ما در ماژول‌‌بندی بخش‌ها مبتنی بر همکاری با تولیدکننده‌های دستگاه بود. ما به آن‌ها اعلام کردیم که پروژه‌ای در دست توسعه داریم و درخواست همکاری دادیم. تولیدکننده‌ها برنامه‌‌های توسعه‌ای و درخواست‌های آتی خود را اعلام کردند و ما بر حسب همان نیازها، اولویت‌بندی ماژول‌ها را انجام دادیم. به‌مرور بخش‌های دیگری به ماژول‌های الزامی اضافه می‌شوند. چنین رویکردی به ما امکان می‌دهد تا به‌مرور با تولیدکننده‌ها هماهنگ شویم، ما قصد نداریم که روند توسعه در شرکت‌های تولیدکننده‌ی تجهیزات را با مشکل مواجه کنیم. رویکرد کنونی به نیروهای این شرکت‌ها امکان می‌دهد تا به‌مرور با روند به‌روزرسانی ماژولی همراه شوند.

دیو برک: من تصور می‌کنم که بخش مهمی از این پروژه، به همکاری با شرکا وابسته خواهد بود. منظور من از شرکا، تولیدکننده‌ها هستند. آن‌ها تغییراتی را در دستگاه‌های محصول خود ایجاد می‌کنند و ما قصد داریم تغییرات را به‌مرور با رویکرد مین‌لاین هماهنگ کنیم. چنین روندی درنهایت به ثبات می‌رسد، اما قطعا به کمی زمان نیاز دارد.

گولوم: قطعا برای هماهنگی بیشتر به ارائه‌ی قابلیت‌های بیشتر نیاز داریم. روندی که ما در سال گذشته با ارائه‌های متعدد پیش گرفتیم و در سال گذشته، بیش از ۱۰ سال قبل انتقال داده و قابلیت داشتیم.

با بررسی بخشی از پاسخ‌های مهندسان گوگل و برنامه‌ی شرکت در پروژه‌ی مین‌لاین این تصور ایجاد می‌شود که گوگل در پی کسب مجدد مالکیت برخی از کدهای هسته‌ای سیستم از تولیدکننده‌ها است. در صورت صحیح بودن این تصور، گوگل تصمیم دارد تا همه‌ی شخصی‌سازی‌هایی که قبلا توسط تولیدکننده‌ها به سیستم اضافه می‌شد، به بخش اصلی کدهای اوپن‌منبع اندروید اضافه شود تا همه از آن‌ها استفاده کنند.

اندروید q

برای تصور بهتر برنامه‌ی گوگل در اولویت‌بندی ماژول‌ها تصور کنید که غول موتور جست‌وجو از تمامی اعضای اکوسیستم اندروید چنین سوالی را بپرسد: «آیا قصد دارید نحوه‌ی کار بخش DNS را شخصی‌سازی کنید؟». اگر پاسخ منفی باشد، نسخه‌ی گوگل در آن بخش سیستمی به‌عنوان نسخه‌ی الزامی شناخته می‌شود. در صورت ارائه‌ی پاسخ مثبت از سوی تولیدکننده‌ها (یعنی نیاز به شخصی‌سازی بخشی خاص در سیستم‌عامل)، همه‌ی تغییرات تولیدکننده به مرکز پروژه‌ی اوپن منبع اندروید (AOSP) ارائه می‌شوند و درنهایت با هماهنگی با تغییرات دیگر، به نسخه‌ی گوگل تبدیل خواهند شد. پاسخ نهایی گولوم یعنی ارائه‌‌‌ی به‌روزرسانی‌های متعدد و شخصی‌سازی در یک سال گذشته، نشان از رویکرد رو‌ به جلوی گوگل دارد. درنهایت کدهای بیشتری به AOSP ارسال می‌شوند و به‌مرور کار تولیدکننده‌ها در به‌روزرسانی‌های سیستمی کمتر می‌شود.

انتخاب اولویت برای ساخت ماژول‌ها، اولین چالش تیم توسعه‌ی اندروید بود

گولوم: ما به تیم‌های خود توضیح دادیم که با استفاده از ماژول‌های مین‌لاین، به‌روزرسانی‌ها تنها ماهی یک بار باید انجام شوند. به‌علاوه آن‌ها همکاری بیشتری با شرکت خواهند داشت. درنتیجه توسعه‌ی کدها، برنامه‌ریزی و بسیاری بخش‌های دیگر با همکاری انجام خواهد شد. افراد حاضر در تیم‌های گوگل از شنیدن این برنامه بسیار خشنود شدند.

آیا می‌توانیم انتشار به‌روزرسانی یک بار در ماه را به‌عنوان برنامه‌ی اصلی مین‌لاین در نظر بگیریم؟

گولوم: چنین رویکردی با روندهای قبلی ما هماهنگ خواهد بود و زمان‌بندی به‌روزرسانی‌ امنیتی نیز همین‌گونه است. برخی از قطعات ماژولی مین‌لاین نیز در دسته‌بندی امنیت قرار می‌گیرند. بخش رسانه‌ای نیز شامل کدک‌های اساسی و بخش‌های اجرایی متعدد می‌شود. ما در ماژول‌سازی این بخش نگاهی به آسیب‌پذیری‌های رایج سال گذشته داشتیم و نزدیک به ۴۰ درصد از آسیب‌پذیری وصله‌های امنیتی در بخش رسانه‌ای دیده می‌شدند. درنهایت نتیجه گرفتیم که بار به‌روزرسانی‌ها را از دوش تولیدکننده‌ها برداریم.

در توضیح پاسخ گولوم باید بدانید که موتور پخش رسانه‌ای اندروید وظیفه‌ی بارگذاری همه‌ی فایل‌های خطرناک از سرتاسر وب را بر عهده دارد و امنیت در چنین رویکردی همیشه یک چالش مهم در اکوسیستم بوده است. موتور پخش رسانه‌ای اندروید به‌نام Stagefright شناخته می‌شود و در سال ۲۰۱۵ اخبار مهمی را از آسیب‌پذیری‌های اجرای کد مخرب از راه دور به خود اختصاص داد. به‌روزرسانی‌های ماهیانه‌ی بخش امنیتی از همان زمان شروع شدند.

اندروید q

گوگل درحال‌حاضر به‌روزرسانی‌های امنیتی را هر ماه در AOSP ارائه می‌کند و آن‌ها را به تولیدکننده‌ها می‌دهد. این رویکرد هنوز عالی به نظر نمی‌رسد و همه‌ی گوشی‌ها، از به‌روزرسانی‌های ماهیانه پشتیبانی نمی‌کنند. درنتیجه همه‌ی گوشی‌های اندرویدی به‌روزرسانی‌های امنیتی را ماهی یک بار دریافت نمی‌کنند. پاسخ گولوم نشان می‌دهد که گوگل رویکرد بررسی به‌روزرسانی‌ها را بر عهده می‌گیرد و ارائه‌ی آن‌ها را نیز خودش به‌صورت منظم به کل اکوسیستم انجام می‌دهد.

برک: مسئله‌ی مهم دیگر، آسان‌سازی فعالیت توسعه‌دهنده‌ها در اکوسیستم اندروید خواهد بود. یکی از چالش‌هایی که عموما در رویکرد توسعه‌دهنده‌ها دیده می‌شود، رفتارها و رویکردهای متنوع در بخش‌های گوناگون سیستم‌عامل است. درواقع حتی در محصولات یک تولیدکننده‌هم بعضا عملکردهای متنوع بخش‌ها دیده می‌شود. فریم‌ورک رسانه‌ای یکی از مهم‌ترین بخش‌هایی بود که در نگرانی‌ توسعه‌دهنده‌ها دیدیم. درنهایت پایداری بیشتر بین نسخه‌های متعدد سیستم‌عامل برای توسعه‌دهنده‌ها هم بهتر خواهد بود. چنین رویکردی منجر به کاهش خطاها می‌شود و مسئولیت‌ آن‌ها نیز کاهش خواهد یافت. درنهایت اپلیکیشن‌های باکیفیت‌تری می‌بینیم که به‌نفع کاربران هم خواهد بود.

گولوم: من در سخنرانی از اصطلاح «ثبات باگ» برای این رویکرد استفاده کردم (برک تأیید می‌کند). ماژولی به‌نام ANGLE در برنامه‌ها وجود دارد که یک OpenGL پیاده‌سازی شده در Vulcan است. درحال‌حاضر این ماژول جزو دسته‌ی بخش‌های الزامی برای سازنده‌ها قرار می‌گیرد، اما توسعه‌دهنده‌ها الزامی به استفاده از آن ندارند. ما قصد داریم تا به روندی هماهنگ در ارائه‌ی چنین بخش‌هایی دست یابیم. قطعا درنهایت ادعای انتشار نرم‌افزار بدون باگ نداریم (چون هیچ‌نر‌م‌افزاری بدون باگ نیست)، اما به‌هرحال کاهش درگیری‌های متنوع و متفاوت توسعه‌دهنده‌ها با نسخه‌های گوناگون سیستم‌عامل منجر به آسا‌ن‌تر شدن فعالیت آن‌ها می‌شود.

برک: جنبه‌ای دیگر از فرایندهای فوق نشان می‌دهد که هماهنگی بیشتری با آن‌ها رخ خواهد داد. به‌عنوان مثال به چالش‌های پیش‌آمده برای سیستم GPS در ماه آوریل دقت کنید. هواپیماهای متعددی به‌خاطر نا‌هماهنگی با تغییرات جدید دچار چالش شدند. درواقع مشکلات نرم‌افزاری همیشه وجود دارند و همه به‌دنبال راهی برای حل کردن سریع‌تر آن‌ها هستند. خصوصا در مواردی همچون کتابخانه‌‌ی ما، Conscript یا کتابخانه‌ی SSL و TLS، به‌روزرسانی و رفع مشکلات در اولویت بالایی قرار دارد. چنین مواردی با به‌روزرسانی حل می‌شوند. خصوصا در مواقعی که مجوز نرم‌افزاری باطل شود یا ارائه‌کننده‌ی مجوز به فعالیت‌های خود خاتمه دهد، به‌روزرسانی‌های هماهنگ کارگشا خواهد بود.

اندروید q

ایلیان مالکو: سال‌ها پیش باگی در کتابخانه‌ی برنامه‌نویسی C اندروید موسوم به Bionic مشاهده شد که یکی از شرکای ما آن را شناسایی کرد. در اثر باگ مذکور، مشکلاتی در اپلیکیشن‌های متنوع و بازی‌ها ایجاد می‌شد. شناسایی چنین مواردی پیش از ارائه‌ی نهایی نرم‌افزار بسیار مشکل است.

گولوم: تا پیش از شناسایی باگ بالا، توسعه‌دهنده‌ها تا چند سال باید با آن کار می‌کردند تا زمانی یک وصله برای باگ منتشر شود. چنین رخدادهایی برای بسیاری از اپلیکیشن‌های اولیه‌ی ما نیز پیش می‌آمد.

آیا به‌روزرسانی آزمایشی برای کاربران Beta Q عرضه شد؟

گولوم: بله ما از زمان انتشار نسخه‌ی بتا، ارائه‌ی به‌روزرسانی را هم شروع کردیم. دستگاه‌های کاربران بتا ری‌استارت می‌شد چون ما به‌روزرسانی‌ها را ارائه و بررسی می‌کردیم. البته این روند تنها در فاز بتا اجرا می‌شود. پس از ارائه‌ی نسخه‌ی نهایی اندروید Q دیگر خبری از ری‌استارت‌های مکرر به‌خاطر به‌روزرسانی نیست و دستگاه تنها با انتخاب خود کاربر ری‌استارت می‌شود. به‌هرحال تاکنون به‌روزرسانی‌های متعددی ارائه شده‌اند و نمونه‌های امنیتی نیز به‌صورت ماهانه اجرا می‌شوند. در نسخه‌های نهایی فرایندهای به‌روزرسانی در پس‌زمینه اجرا می‌شوند و مزاحم فعالیت کاربر نخواهند بود.

برک: نکته‌ی مهمی درباره‌ی پروژه‌ی مین‌لاین وجود دارد که شاید در مقاله و پست‌های وبلاگی قابل توضیح نباشد. مین‌لاین را می‌توان مهم‌ترین تغییر مسیر در تاریخ توسعه‌ی نرم‌افزارهای سیستم‌عامل نامید. در وضعیت کنونی اندروید، ما محتوای مرجع یا گاهی اوقات محصولی کامل را ارائه می‌‌کنیم که می‌تواند همان سیستم‌عامل و محصولی شبیه به پیکسل باشد. سپس کد اصلی که به‌‌صورت متن‌باز توسعه می‌یابد، در اختیار شرکا قرار می‌گیرد. شرکایی همچون وان‌پلاس کد را از ما می‌گیرند و دستگاه‌های مورد نظر خود را می‌سازند. البته درواقع ما کد متن‌باز را ارائه می‌کنیم و آن‌ها کد را از همان محل متن‌باز دریافت می‌کنند. درنتیجه‌ی چنین روندی مقیاس‌دهی اکوسیستم رخ می‌دهد.

با ماژولار شدن سیستم‌عامل، وظیفه‌ی نگه‌داری آن بیشتر بر عهده تیم اصلی اندروید خواهد بود

وقتی مدلی مانند مین‌لاین اجرا شود و در آن کدهای مشابهی برای ماژول‌ها داشته باشیم، ما یعنی تیم اندروید کد نهایی را عرضه می‌کنیم. درنتیجه ما مسئول کدهای اجراشده در همه‌ی دستگاه‌ها خواهیم بود. درنتیجه وقتی یک باگ در محصول یکی از تولیدکننده‌ها ظاهر می‌شود، به ما هم منتقل خواهد شد. درنهایت حل باگ و ارائه‌ی مجدد کدها بر عهده‌ی تیم اندروید است.

ما برای دسترسی به مدل بالا مجبور بودیم که توانایی‌‌های مهندسی و فرایندهای خودکار بررسی را بهبود دهیم. بسیاری فرایندهای توسعه‌ای دیگر هم به‌روزرسانی و تقویت شدند و به‌نوعی تمام فرایندهای کاری هدف بازطراحی و بازسازی قرار گرفتند.

اندروید q

به نظر می‌رسد شما برنامه‌ای جدی برای توسعه و استفاده از مین‌لاین در آینده دارید.

برک: بله من فکر می‌کنم که فعالیت‌ها در مین‌لاین به‌مرور افزایش می‌یابد. ما به این پروژه مانند یک پروژه‌‌ی متن‌باز نگاه می‌کنیم و خود را عضوی از آن می‌دانیم که باید با همکاری دیگر شرکا برای بهبودش تلاش کنیم. به‌هرحال زیرساخت موجود امکان همکاری بیشتر و توسعه‌های آتی را فراهم می‌کند. در نسخه‌های کنونی که به‌همراه دستگاه‌هایی همچون پیکسل ۳ ارائه شد، تغییرات مشهود ماژولار شدن سیستم‌عامل را مشاهده می‌کنید.

ما اعتقاد زیادی به متن‌باز بودن پروژه و اکوسیستمی مبتنی بر همکاری داریم. به‌علاوه اعتقاد داریم تولیدکننده‌ها باید توانایی متفاوت عمل کردن را داشته باشند. به‌هرحال برای اجرای چنین برنامه‌هایی باید بین همه‌ی تصورات و انتظارهای خود از اکوسیستم تعادل برقرار کنیم. البته بخش‌های زیادی وجود دارند که توسط تولیدکننده‌ها تغییر نمی‌کنند و از میان آن‌ها می‌توان کتابخانه‌ی Conscript را نام برد. تبدیل کردن موارد این‌چنینی به ماژول، دستگاه‌های کاربران را امن‌تر می‌کند. به‌علاوه باگ‌ها کمتر و کار برای توسعه‌دهنده‌ها راحت‌تر می‌شود.

گولوم: درباره‌ی قابلیت‌ تغییر یا شخصی‌سازی ماژو‌ل‌ها باید بگویم که ماژول‌ها عموما در بخش‌های مرتبط با امنیت یا حریم خصوصی انتخاب شدند یا در دسته‌ای بودند که تولیدکننده‌ها تمایلی به تغییرات آن‌چنانی در آن‌ها نداشتند. به‌عنوان مثال قابلیت‌های رسانه‌ای جزو بخشی هستند که افزونه‌های متعددی از سوی شرکت‌ها در آن‌ها ارائه می‌شود. به‌همین دلیل ما امکان ایجاد تغییرات را در آن می‌دهیم. همکاران ما در اکوسیستم اندروید می‌توانند APEXهای اختصاصی خود را برای سیستم رسانه عرضه کنند که در کنار فایل APEX اصلی ارائه خواهد شد.

برک: بله ما از مدل افزونه‌ای استفاده خواهیم کرد. درنتیجه یک هسته‌ی مشترک به وجود خواهد آمد و ماژول‌های کاربردی به آن اضافه می‌شوند. 

درنتیجه ما مثلا ماژولی به‌نام Samsung media خواهیم داشت که احتمالا امکانات اضافه‌تری به کاربر می‌دهد.

برک: بله، شاید شرکتی تمایل داشته باشد تا قابلیت‌هایی همچون Dolby Vision یا Dolby Atoms را به ماژول رسانه‌ای اضافه کند.

گولوم: شاید هم کدک‌های رسانه‌ای توسط شرکت‌ها ارائه شوند که ما در ماژول خود از آن‌ها پشتیبانی نمی‌کنیم.

اندروید q

پس آن‌ها کاربردهای اولیه‌ AOSP را خواهند داشت و در ادامه جزئیات مورد نظر خود را به آن اضافه می‌کنند.

گولوم: جالب است که ما به‌صورت کلی به سمت همین رویکرد حرکت می‌کردیم. اگر به بخش نرم‌افزاری باتری تطبیقی دقت کنید که سال گذشته اجرا کردیم، متوجه رویکرد مشابه می‌شوید. ما تعدادی API سیستمی داشتیم که یک مدل مبتنی بر هوش مصنوعی توانایی ارتباط با آن را داشت. سیستم حاصل به‌نوعی اقدامات بعدی کاربر را پیش‌بینی می‌کند. تولیدکننده‌های دستگاه‌های اندرویدی اکنون می‌توانند آن بخش را به‌طور کامل جایگزین کنند. اکنون ما به‌جای رویکرد قبلی و پچ کردن کل کدها، پایه‌های اولیه را در اختیار شرکت‌ها قرار می‌دهیم که قابلیت توسعه‌ی آتی براساس آن را خواهند داشت. این رویکرد در آینده بیشتر پی گرفته می‌شود.

برک: به‌نظر من باید نامی جدید برای این روش توسعه‌ی نرم‌افزاری انتخاب شود. وقتی شما در ۲۰ سال پیش یک نرم‌افزار می‌نوشتید، آن را در سی‌دی رام قرار می‌دادید و عرضه می‌کردید. برای پشتیبانی‌های آتی نیز سرویس‌هایی وجود داشت. در مدل جدید، نرم‌افزار ارائه می‌شود و با بهره‌گیری از ابزارهای از راه دور، فرایندهای بررسی، عیب‌یابی، رفع اشکال و به‌روزرسانی رخ می‌دهند. در چنین رویکردی باید فرایندهای تست و بررسی با سرعت و شدت بالایی انجام شوند. به‌هرحال روش جدید نیاز به نام جدید هم دارد و شاید بتوان آن را «توسعه‌ی نرم‌افزاری مدرن» نامید.

گولوم: پیش‌رونده؟

برک: توسعه‌ی نرم‌افزاری پیش‌رونده. البته این اصطلاح معنای متفاوتی دارد. به‌عنوان مثال اگر سیستم‌عامل‌های دیگر را در نظر بگیرید و مثلا یک باگ در بخش رسانه‌ای آن‌ها ایجاد شود، باید کل سیستم‌عامل را به‌روزرسانی کنند. چنین رویکردی قطعا پیش‌رونده نیست. ازطرفی ما در حال حاضر اندروید را در بخش‌های متنوع به‌روزرسانی می‌کنیم. مثلا اپلیکیشن‌های گوگل مرتبا به‌روزرسانی می‌شوند یا Google Play Services به‌صورت منظم به‌روزرسانی دریافت می‌کند. درواقع ما اکنون نیز رویکردی پیش‌رونده داریم.

چه پیش‌نیازهایی برای پشتیبانی از مین‌لاین وجود دارد؟ آیا گوشی‌های مجهز به اندروید Q ملزم به رعایت آن هستند؟

گولوم: بله، هر گوشی که با اندروید Q عرضه شود، باید از مین‌لاین پشتیبانی کند. برخی ماژول‌ها هم هستند که در دستگاه‌های به‌روزرسانی شده به اندروید Q الزامی خواهند بود. دستگاه‌هایی که به اندروید Q به‌روزرسانی می‌شوند باید ExtServices و Permissions Controller را به‌عنوان ماژول داشته باشند چون این بخش‌ها هم‌اکنون توسط گوگل ساین شده‌ و برای عرضه در سیستم‌عامل‌ها به تولیدکننده‌ها ارائه شده‌اند. درنتیجه در به‌روزرسانی جدید شاهد حضور آن‌ها خواهیم بود.

اندروید q

در توضیح فرایند ساین باید بدانید که ساین کردن آخرین مرحله‌ی پایانی پیش از توزیع اپلیکیشن است. درنتیجه ساین شدن ماژول‌های بالا یعنی آن‌ها در اختیار گوگل قرار دارند و تولیدکننده‌های اجازه‌ی تغییرشان را نخواهند داشت. 

درباره‌ی ExtServices توضیح دهید. به‌نظر نمی‌رسد از سال‌ها پیش تغییری در آن ایجاد کرده باشید.

گولوم: در توضیح ساده، این ماژول مجموعه‌ای از مواردی است که قصد داریم در فرایندهای سیستمی همیشه در حال اجرا، به‌روزرسانی کنیم. در توضیح دقیق‌تر، بخش‌‌هایی مرتبط با حریم خصوصی در ماژول وجود دارد که ما باید امکان به‌روزرسانی و رفع باگ‌ آن‌ها یا حتی تغییر سیاست‌های موجود را داشته باشیم. به‌عنوان مثال بخش‌هایی از پر کردن خودکار فیلد فرم‌ها در آن وجود دارد. بخش‌هایی از مین‌لاین در ماژول ExtServices وجود دارد که قابلیت به‌روزرسانی هم دارند. به‌عنوان مثال می‌توان به ناظر داخل دستگاهی مین‌لاین اشاره کرد.

شما برای دستگاه‌هایی که حافظه‌ی رم پایینی دارند در پشتیبانی از مین‌لاین استثناء قائل شده‌اید.

گولوم: مشکل اصلی حافظه‌ی رم نیست و حافظه‌ی داخلی مهم‌تر است. بسیاری از دستگاه‌ها با حافظه‌ی رم پایین، خصوصا نمونه‌های ۵۱۲ مگابایتی و یک گیگابایتی، حافظه‌ی داخلی پایینی دارند.

برک: ماژول APEX باید با پارتیشن‌‌بندی‌های داده‌ای در دستگاه حضور داشته باشد. درنتیجه وقتی پارتیشن‌های سیستمی جایگزین می‌شوند، درواقع فضای اشغالی دو برابر می‌شود.

نام‌گذاری APEX

در بخشی از مصاحبه، برک مسئله‌ی نام‌گذاری فایل‌های جدید یعنی APEX را مطرح می‌کند که طبق ادعای نویسنده‌ی آرس و سند رسمی مین‌لاین، مخفّفی برای Android Pony Express است. در ادامه مهندسان گوگل داستان انتخاب این اسم را شرح می‌دهند.

مالکو: من به شما اطمینان می‌دهم که در انتخاب این اسم زیبا نقش مهمی داشتم. ما ابتدا می‌خواستیم اصطلاح NPK را به‌عنوان مخففی برای Native PacKage استفاده کنیم. همکاران دیگر ما همچون جارز و دیان هک‌بورن نیز در نام‌گذاری نقش داشتند. هک‌بورن از معماران قدیمی اندروید است و در مخالفت با NPK گفت که شباهت زیادی با APK دارد. سپس نام‌های دیگری ارائه شدند و من در نهایت APEX یا Android Pony Express را پیشنهاد دادم.

اندروید q

درواقع Android Pony Express عبارتی تقریبا طنز برای توضیح دادن APEX محسوب می‌شود. ما می‌توانستیم از Android Portable Exchange استفاده کنیم، اما بار جذابیت عبارت کنونی بیشتر بود.

دیسک زنده‌ی لینوکس برای اندروید

پس از بررسی مین‌لاین و جزئیات آن، به بخش دیگری از رونمایی‌های رویداد Google I/O می‌رسیم که نمایشی اولیه از قابلیت جدیدی در اندروید Q داشت. این قابلیت به‌نام Dynamic System Update شناخته می‌شود که در نمونه‌های آزمایشی اندروید دیده شد. در تعریف ساده قابلیت جدید حالت بوت دوگانه را به سیستم‌عامل می‌دهد. کاربر با استفاده از آن می‌تواند پس از ریبوت کردن دستگاه از یک نسخه‌ی اندروید، وارد نسخه‌ی دیگر شود. چنین قابلیتی برای توسعه‌دهنده‌ها، تولیدکننده‌ها، متخصصان و دیگر افرادی که تمایل به تغییر سریع نسخه‌ی اندروید دارند، مفید خواهد بود.

در نسخه‌های بعدی قابلیت بوت دوگانه‌ی اندروید آسان‌تر می‌شود

قابلیت جدید اندروید Q شباهت زیادی به دستاوردهای قبلی Project Treble دارد. دستگاه آزمایشی گوگل در رویداد I/O بین یک نسخه‌ی نهایی اندروید و یک Generic System Image از سیستم‌عامل یا GSI تغییر حالت می‌داد. اندروید قبلا به‌عنوان یک سیستم‌عامل امبدد شناخته می‌شد که سیستم‌عامل و پشتیبانی از سخت‌افزار آن داخل یک ایمیج تکی قرار داشتند. در پروژه‌ی Treble، سیستم‌عامل از پشتیبانی سخت‌افزاری جدا شد و عبارت GSI به‌وجود آمد. با استفاده از GSI، پشتیبانی سخت‌افزاری اندروید شباهت کمتری به یک سیستم‌عامل امبدد خواهد داشت و بیشتر بهویندوز یا لینوکس شبیه می‌شود. درنهایت نسخه‌ای از سیستم‌عامل داریم که روی دستگاه‌های متعددی کار می‌کند.

از زمان انتشار اندروید ۸ یا Oreo، پشتیبانی از Treble و بوت کردن حالت GSI یکی از پیش‌نیازهای پشتیبانی اندروید محسوب می‌شود. گوگل حتی نسخه‌ای GSI از اندروید Q بتا را عرضه کرد. به‌هرحال با پیشرفت این موارد، احتمالا سال آینده و در زمان عرضه‌ی اندروید R شاهد قابلیت بوت دوگانه به آن بدون نیاز به پاک کردن نسخه‌های قبلی خواهیم بود.

درباره‌ی قابلیت بوت زنده توضیح دهید.

مالکو: ما ابتدا نام Live Image یا Live Boot را برای قابلیت جدید انتخاب کردیم. روش کار قابلیت جدید به‌گونه‌ای بود که حالتی شبیه به دیسک زنده‌ی لینوکس را القا می‌کند. سپس تیم ما در ماه‌های اکتبر تا نوامبر گذشته آن را بازنویسی کردند و به محصولی بهتر رسیدیم.

اندروید q

برک: دلیل بازنویسی کامل قابلیت، فشارهای تیم امنیتی اندروید بود. آن‌ها تیم توسعه را مجبور به بازنویسی کدها کردند. ما تیم امنیتی بسیار قوی داریم که بسیار عالی هستند و به بهتر شدن اندروید کمک شایانی می‌کنند.

مالکو: پس از بازنویسی برخی از خصوصیت‌های قابلیت جدید تغییر کرد و ما با تغییر نام به Android on Tap رسیدیم. سپس به تیم‌های اختصاصی انتخاب نام در گوگل مراجعه کردیم و آن‌ها گفتند که نام انتخابی آن‌چنان توصیفی نیست. درنهایت به Dynamic System Updates رسیدیم.

در نسخه‌های دمو هم همین نام به چشم می‌خورد. قابلیت جدید چگونه کار می‌کند؟ آیا پارتیشن مجزایی برای اجرای بوت دوم داریم؟

مالکو: خیر، البته یکی از پیش‌نیازهای اندروید Q با هدف آسان‌تر کردن به‌روزرسانی‌ها و با نام پارتیشن‌های داینامیکی معرفی می‌شود. آن اسم ارتباطی به این بخش ندارد، اما مکانیزم آن‌ها تقریبا شبیه خواهد بود. پارتیشن‌های داینامیکی امکان تغییر ابعاد پارتیشن را در به‌روزرسانی‌های OTA ایجاد می‌کنند تا بدون ایجاد خلل در عملکرد سیستم‌عامل، تغییرات اعمال شود.

با توجه به پاسخ بالا و در بررسی‌ نمونه‌های اولیه به این نتیجه می‌رسیم که پارتیشن‌بندی پویا برای به‌روزرسانی آسان‌تر دستگاه‌های ارزان، کاربردی خواهد بود. هر دستگاه اندرویدی دو پارتیشن اصلی دارد. یکی به‌نام پارتیشن System شناخته می‌شود که سیستم‌عامل کارخانه‌ای در آن قرار دارد. این پارتیشن تنها ازطریق به‌روزرسانی‌های سیستمی یا همان OTA تغییر می‌کند. پارتیشن بعدی Data نام دارد که فایل‌های کاربر در آن قرار می‌گیرند.

درحال‌حاضر ابعاد پارتیشن‌های داخلی دستگاه‌های اندرویدی در کارخانه تنظیم می‌شود و ثابت می‌ماند. چنین تنظیماتی تأثیر زیادی روی دستگاه‌های پرچم‌دار با حافظه‌ی بسیار زیاد ندارد، اما برای دستگاه‌های ارزانی همچون نسخه‌های Android Go که تنها هشت گیگابایت حافظه دارند، تنظیم پارتیشن دشوار خواهد بود. کارخانه باید به‌گونه‌ای حافظه را پارتیشن‌بندی کند که فضای مناسب برای فایل‌‌های سیستمی وجود داشته باشد و همچنین، فضا برای فایل‌های کاربر و به‌روزرسانی‌های بعدی سیستم‌عامل نیز فراهم شود.

قابلیت تغییر ابعاد پارتیشن‌ها، نگرانی تولیدکننده‌ها را در تخصیص فضا برای به‌روزرسانی‌های آتی از بین می‌برد. آن‌ها می‌توانند در زمان عرضه‌ی محصول، پارتیشن بزرگی را برای داده به کاربر ارائه کنند و بعدا در صورت نیاز به به‌روزرسانی، ابعاد پارتیشن سیستمی را تغییر دهند. 

مالکو: مکانیزم عملکردی این‌گونه است که ما بلوک‌های مورد نظر را از حافظه جمع می‌کنیم و از آن‌ها پارتیشن‌های منطقی می‌سازیم. همین مکانیزم را برای Dynamic System Updates نیز به‌کار می‌بریم و دو فایل سیستمی ایجاد می‌کنیم.

برک: یکی از فایل‌ها شامل ایمیج سیستم می‌شود و دیگری برای داده‌های کاربر استفاده خواهد شد. درواقع یک پارتیشن مجازی خواهیم داشت.

android q

مالکو: بله، یکی برای سیستم و دیگری برای داده‌ها استفاده می‌شود. پس از ساخت پارتیشن از بلوک‌های مورد نظر، GSI را روی آن نصب می‌کنیم. سپس پارتیشن داده‌‌ی کاربر به‌صورت یک پارتیشن هالی F2FS یا EXT4 ایجاد می‌شود. در مرحله‌ی بعدی تنظیماتی ایجاد می‌شود که طبق آن، init (بخشی از فرایند بوت اندروید) جریان بوت را از پارتیشن ذخیره‌شده هدایت می‌کند. در تعریف ساده کاربر می‌تواند دستگاه را از پارتیشن جدید بوت، آن را پاک کرده و بدون آسیب به سیستم‌عامل اصلی، نسخه‌های جدید اندروید را امتحان کند.

قابلیت جدید شباهت زیادی به ماشین مجازی دارد.

برک: بله شبیه به ماشین مجازی خواهد بود، منتهی دستگاه به‌صورت کامل در نسخه‌ی مورد نظر بوت می‌شود.

آیا نسخه‌ی اضافه‌ی اندروید برای کاربر دائمی خواهد بود؟ درواقع آیا می‌توانند همیشه از آن استفاده کنند؟

مالکو: همان‌ طور که دیو (برک) توضیح داد، ما نمی‌خواهیم کاربران در قابلیت جدید گرفتار شوند. درنتیجه وقتی دستگاه را ریبوت کنند به نسخه‌ی اصلی اندروید وارد خواهند شد. البته قابلیتی برای بوت کردن به نسخه‌ی دوم هم وجود دارد، اما کاربر برای آن منظور باید تنظیماتی را روشن کند. روشن کردن تنظیمات نیز برای هر بار بوت الزامی خواهد بود. به‌هرحال کاربر می‌تواند بین نسخه‌های مختلف بوت کند و داده‌های شخصی نیز هیچ مشکلی نخواهند داشت.

پارتیشن‌بندی نسخه‌های جدید اندروید قابلیت تغییر ابعاد خواهد داشت

درنتیجه نیازی به آنلاک کردن بوت‌لودر هم نخواهد بود؟

مالکو: Dynamic System Update قابلیت پیش‌فرض یا الزامی دستگاه‌ها نخواهد بود، اما اگر فعال باشد، نیاز به آنلاک بودن دستگاه را از بین می‌برد. درواقع نکته‌ی اصلی قابلیت جدید نیز همین است.

پس هدف نهایی این است که کاربر بتواند نسخه‌ای جدید از اندروید، مثلا حالت بتا را حتی در گوشی‌های قفل نیز آزمایش کند.

مالکو: بله، این قابلیت اکنون در گوشی‌های پیکسل ما هم وجود دارد که در دموی اندروید Q مشاهده کردید.

برک: این قابلیت یکی دیگر از مواردی است که به‌لطف Treble ایجاد شد. درواقع رابط کاربری تمیز سمت سخت‌افزار به شما امکان می‌دهد که چنین مواردی را به سیستم‌عامل اضافه کنید. اگر سه یا چهار سال پیش چنین قابلیت‌هایی را تصور می‌کردیم، به نظر نشدنی می‌آمدند.

مالکو: اگر قابلیت کنونی را چند سال پیش ارائه می‌کردیم، هیچ دستگاه یکپارچه و بدون اشکالی برای اجرای آن وجود نداشت. درنتیجه نمی‌توانستیم مکانیزم را به‌راحتی اجرا کنیم. اکنون پشتیبانی از این وضعیت آسان‌تر به نظر می‌رسد و ما تمایل داریم همکاران آن را فعال کنند. به‌هرحال اکنون با برخی از آن‌ها برای فعال شدن قابلیت‌های جدید صحبت می‌کنیم.

قابلیت‌های دیگر اندروید Q

در بخش دیگری از مصاحبه به تغییرات اندروید Q نسبت به نسخه‌های قبلی و همچنین تغییر قابلیت‌ها در نسخه‌های بتا پرداخته شد. یکی از موارد، قابلیت Snooze برای اعلان‌ها بود که ابتدا با اندروید ۸ ارائه شد. سپس تا نسخه‌‌ی سوم بتا اندروید Q نیز قابلیت Snooze وجود داشت و حذف شد. اکنون در Android Q Beta 4 مجددا شاهد این قابلیت هستیم.

چرا Snooze از پنل اعلان‌ها حذف شد؟ آیا قابلیت بود یا باگ؟

برک: در آینده شاید شاهد این قابلیت باشیم و شاید هم آن را حذف کنیم. ما تنظیماتی به‌صورت حالت‌های Gentle و Priority برای اعلان‌ها ارائه کردیم. درواقع تلاش می‌کنیم تا همه‌ی بخش‌ها ساده‌سازی شوند. مشکل کنونی اعلان‌ها، پیچیده شدن آن‌ها است. اکنون حالت‌های متعددی همچون channel یا snooze وجود دارد و ما می‌خواستیم آن‌ها را ساده‌سازی کنیم.

درحال‌حاضر بخشی از تیم ما اعتقاد دارد که حالت snooze باید حذف شود تا تجربه‌ی کاری برای کاربران به سمت آسان‌‌تر شدن پیش برود. البته قطعا برخی از ما نگران کاربران علاقه‌مند به این قابلیت هستیم، اما به‌هرحال باید اکثریت کاربران را در نظر بگیریم. آیا ساده‌تر شدن برای آن‌ها بهتر خواهد بود؟ همین سؤال‌ها باعث می‌شود تا حالت‌های گوناگون را برای بخش اعلان در نظر بگیریم. در برخی از نسخه‌های بتا قابلیت snooze را داشتیم و در برخی دیگر آن را حذف کردیم. به‌هرحال تصور می‌کنم که به خاطر استفاده‌‌ی پایین، آن را حذف خواهیم کرد. این وضعیت از نقاط مثبت و البته منفی عرضه‌ی نسخه‌ی بتا محسوب می‌شود که علاوه بر بررسی قابلیت‌های متنوع، ما را به بحث‌های طولانی هم می‌کشاند.

اندروید q

از قابلیت‌های دیگر آزمایشی در نسخه‌های بتا اندروید Q می‌توان به Adaptive Sleep اشاره کرد که البته عملکرد مناسبی هم نداشت. درحال‌حاضر برخی دستگاه‌ها همچون گوشی‌های گلکسی سامسونگ، چنین قابلیتی را با بهره‌گیری از دوربین جلو به کاربر ارائه می‌کنند. گوشی با تشخیص چهره‌ی کاربر روشن می‌شود و تا زمانی‌که صورتی در مقابل آن باشد، روشن می‌ماند.

درباره‌ی قابلیت Adaptive Sleep توضیح دهید. آیا برای همه ارائه شد؟

برک: این قابلیت به‌نوعی آزمایشی بود و هنوز آماده نیست. تصور می‌کنم در اجرای آن تاحدودی با باگ روبه‌رو بودیم. برخی کاربران از ما انتظار داشتند که این قابلیت را ارائه کنیم. قابلیتی که گوشی هوشمند را در زمان نگاه کردن کاربر روشن نگه می‌داشت. درحال‌حاضر می‌‌توان آن را اسکلتی از قابلیت نهایی دانست که هرگونه تغییری در آن محتمل خواهد بود. به‌هرحال تصور نمی‌کنم که در AOSP هم ارائه شده باشد. درواقع اکنون تنها چگونگی پیاده‌سازی قابلیت را شرح داده‌ایم و تصمیم نهایی بر عهده‌ی تولیدکننده خواهد بود. به احتمال زیاد در نسخه‌ی نهایی اندروید Q شاهد آن نخواهیم بود و من هم به‌همین خاطر از حضور Adaptive Sleep در نسخه‌های بتا تعجب کردم.

روند بالا به دفعات از سوی گوگل دیده شده است. تولیدکننده‌ها عموما به شرکت مراجعه می‌کنند و ایده‌ی قابلیتی را می‌دهند که در اندروید وجود ندارد. آن‌ها اغلب خودشان قابلیت را اجرا می‌کنند یا درنهایت API ارائه می‌شود که دیگر تولیدکننده‌ها هم توانایی پیاده‌سازی آن را داشته باشند. به‌عنوان مثال پشتیبانی تقسیم نمایشگر ابتدا توسط تولیدکننده‌ها عرضه شد و کوگل در اندروید ۷ نوقا استانداردهای ارائه‌ی نهایی را برای کل اکوسیستم ارائه کرد. به‌هرحال در قابلیت Adaptive Sleep اکنون سامسونگ جلوتر از سایر حرکت می‌کند و شاید در آینده شاهد حضور قابلیت حتی در گوشی‌های پیکسل هم باشیم.

اندروید q

ویژگی مورد سؤال بعدی، حالت دسکتاپ اندروید Q است. با این قابلیت (که توضیحات کاملی از آن در XDA Developers وجود دارد)، می‌توان یک رابط کاربری کاملا دسکتاپ به اندروید داد. رابط دسکتاپ شباهت زیادی به سیستم‌عامل کروم دارد. پنجره‌های قابل جابه‌جایی مانند سیستم‌عامل‌های دسکتاپ دیگر، دکمه‌ی فهرست اپلیکیشن‌ها مانند استارت و موارد مشابه، از ویژگی‌های رابط کاربری دسکتاپ هستند. چرا گوگل باید چنین قابلیتی را در اندروید ایجاد کند؟ آیا آن‌ها قصد جایگزینی سیستم‌عامل کروم را دارند؟ آیا اندروید به‌دنبال تصاحب جایگاه ویندوز است؟ آیا در آینده شاهد کامپیوترهای برند پیکسل با کیبورد و ماوس خواهیم بود؟

چرا قابلیت دسکتاپ در نسخه‌ی جدید وجود دارد؟ با اجرای چند دستور ADB می‌تواند قابلیت دسکتاپ با پنجره‌های شناور و موارد دیگر را اجرا کرد.

گولوم: این بخش جزئی از همکاری ما با تیم Foldable (احتمالا تیمی مخصوص توسعه‌ی اندروید برای گوشی‌های تاشدنی) و تیم‌هایی از تولیدکننده‌های متعدد است. ما پشتیبانی از حالت‌های چند پنجره و چند نمایشگر را در سیستم توسعه می‌دهیم. برخی از ویژگی‌های جالب وجود دارند که ما به‌صورت رسمی در پیکسل عرضه نمی‌کنیم، اما شرکت‌های دیگر آن را ارائه می‌کنند. به‌عنوان مثال می‌توان به قابلیت DEX گوشی‌های سامسونگ یا حالت دسکتاپ گوشی‌‌های دیگر اشاره کرد. درنهایت تیم تلاش کرد تا نوعی دمو و تجربه‌ی اولیه ایجاد کند که پیش از تولید محصولات فیزیکی مرتبط، آزمایش شود.

بحث جذاب لینوکس

مالکو بعلاوه بر مسئولیت‌های اصلی مدیریتی، برخی اوقات به‌عنوان نماینده‌ی گوگل در کنفرانس‌های لینوکس هم شرکت می‌کند. به‌عنوان مثال او در رویداد Linaro Connect 2017 از سخنرانانی بود که خبر سه‌برابر شدن پشتیبانی از کرنل‌های طولانی‌مدت لینوکس (LTS) را رسانه‌ای کرد (از دو سال به ۶ سال). البته فهرست کنونی Kernel.org تنها دو نسخه را در پشتیبانی ۶ ساله نشان می‌دهد و نسخه‌های جدیدتر به همان پشتیبانی دوساله بازگردانده شده‌اند. برای شفاف‌سازی بهتر موضوع، در ادامه‌ی مصاحبه با مالکو درباره‌ی آن صحبت شد.

شما به پشتیبانی ۶ ساله‌ی کرنل‌ها اشاره کردید، اما به نظر می‌رسد همه‌ی آن‌ها چنین پشتیبانی را ندارند.

مالکو: کرنل‌های LTS با پشتیبانی ۶ ساله وجود دارند و ما باز همچنین کرنل‌هایی معرفی می‌کنیم. البته همه‌ی کرنل‌های دو ساله به ۶ ساله تغییر نخواهند کرد، چون همه‌ی کرنل‌ها به دستگاه‌های اندرویدی منتقل نمی‌شوند.

در نتیجه کوالکام مسئول چنین مواردی است؟

مالکو: بله، درواقع هر کرنلی که کوالکام، مدیاتک یا هر تولیدکننده‌ی دیگر پردازنده استفاده کند، از طرف ما به‌عنوان کرنل ۶ ساله معرفی خواهد شد. به‌عنوان مثال برای نسخه‌ی پای باید از یکی از این کرنل‌ها استفاده شود. ما حداقل نسخه‌ی قابل پشتیبانی را برای هریک از کرنل‌ها معرفی می‌کنیم. اکنون نسخه‌های ۴.۴ و ۴.۹ در میان نسخه‌های ۶ ساله قرار دارند. به‌هرحال برای انتخاب نسخه‌ی قطعی پشتیبانی ۶ ساله و اعلام آن، مراحل هماهنگی بین ما و تولیدکننده‌‌ها نیاز خواهد بود.

اندروید q

مالکو در بخش‌های از صحبت‌های خود می‌گوید که پیش‌نیاز اندروید پای برای کرنل‌های ۴.۴ و ۴.۱۴ لینوکس تنها برای دستگاه‌های جدید مجهز به این نسخه مطرح می‌شود. شایان ذکر است دستگاه‌های اندرویدی همیشه به کرنل‌های جدید و بزرگ به‌روزرسانی نمی‌شوند. به‌علاوه از آن‌جایی که گوگل تمایل دارد پشتیبانی از اندروید ۹ پای در دستگاه‌های قدیمی هم ارائه شود، این نسخه باید کرنل‌های قدیمی‌تر از ۴.۴ را هم پشتیبانی کند. درواقع پشتیبانی پای از کرنل‌ها به نسخه‌ی ۳.۱۸ می‌رسد که در سال ۲۰۱۴ ارائه شد. درنهایت نتیجه می‌گیریم که پشتیبانی از کرنل‌های با حدود ۶ سال عمر در اندروید امری بدیهی محسوب می‌شود.

پشتیبانی از نسخه‌های قدیمی کرنل می‌تواند تولیدکننده‌ها را به به‌روزرسانی نسخه‌های جدید اندروید تشویق کند. با ماژولار کردن اندروید در پروژه‌ی Treble و جدا کردن سیستم‌عامل از سخت‌افزار، کرنل در بخش سخت‌افزاری می‌ماند. در وضعیت کنونی و در نسخه‌های اصلی، پیاده‌سازی اندروید به‌معنای وارد کردن لینوکس در گوشی و رها کردن آن برای همیشه خواهد بود. رویکردی که درحال‌حاضر مناسب به نظر نمی‌رسد.

پشتیبانی از کرنل‌های قدیمی لینوکس، قدم مهمی برای به‌روزرسانی گوشی‌های قدیمی است

ساندیپ پاتیل از مهندسان ارشد تیم اندروید سال گذشته درLinux Plumber Conference یک سخنرانی ارائه کرد و آینده‌ی احتمالی همکاری لینوکس در کنار اندروید را ترسیم کرد. و در صحبت‌های خود با اشاره به GSI، از برنامه‌ی توسعه‌ی مفهوم جدیدی به‌نام GKI یا Generic Kernel Image رونمایی کرد. مفهوم مورد نظر او کرنلی خواهد بود که روی هر دستگاه با پشتیبانی از Treble پشتیبانی می‌شود.

پاتیل در ادامه‌ی صحبت‌های خود گفت که Treble امکان اجرای پروژه‌ی GKI را فراهم کرد و طرح اولیه برای رابط‌های کاربری مورد نیاز را به گوگل داد. علاوه بر رابط‌های کاربری، همکاری‌های بین اکوسیستمی و تست‌های مهم الزامی در پروژه‌ها هم نیاز خواهند بود که با اجرای Treble، درکی کلی از آن‌ها در گوگل ایجاد شد.

درباره‌ی Generic Kernel Image توضیح دهید. آیا شما کرنلی با GSI عرضه خواهید کرد؟ آیا مطلبی برای به‌روزرسانی اخبار در این مورد دارید؟

مالکو: ما می‌خواهیم همه‌ی بخش‌ها را به‌گونه‌ای کاربردی متحد کنیم. به‌علاوه مانند همیشه قصد داریم امکان شخصی‌سازی را به تولیدکننده‌ها ارائه کنیم و مفهوم متن‌باز همیشه ادامه داشته باشد. هدف نهایی، در کنار هم بودن و نه شبیه بودن خواهد بود. ما از مدت‌ها پیش منابع کرنل را در سطح همان منابع به سمت یکپارچگی برده‌ایم. در بحث GKI ما منابع اولیه را برای توسعه و آزمایش دستگاه‌ها با کرنل‌های جدید ارائه می‌کنیم. همین رویکرد در روح GSI هم وجود دارد. البته این مفاهیم هنوز وجود ندارند و تنها در سطح مفهومی جذاب به نظر می‌رسند. به‌هرحال ما باید فعالیت‌های زیادی انجام دهیم تا از مناسب بودن نتیجه‌ی نهایی در اکوسیستم مطمئن شویم.

اندروید کیو / Android Q

آیا هدف نهایی ایجاد یک کرنل مین‌لاین لینوکس برای گوشی است؟

مالکو: تقریبا همین برنامه را در نظر داریم. البته فعالیت‌های دشوار و گسترده‌ای نیاز خواهد بود. درواقع مسئله‌ای به گستردگی اکوسیستم داریم. در نتیجه مراحل را قدم به قدم پیش می‌بریم. ما منابع را یکپارچه کرده و به‌مرور سایر را به به‌روزرسانی کرنل‌ها به آخرین LTS تشویق می‌کنیم. درحال‌حاضر چنین رویکردی داریم و به‌نوعی مسیر را برای ادامه‌ی راه هموار می‌کنیم.

شما کرنل را در یک گوشی به‌روزرسانی نمی‌کنید. درست است؟

مالکو: بله کاملا روشن است که وقتی یک دستگاه به بازار عرضه شود، مثلا کرنل آن از ۴.۱۵ به ۵.۱ به‌روزرسانی نخواهد شد. درنتیجه نسخه‌های کرنل تغییر نمی‌کنند، اما با استفاده از LTS می‌توان تولیدکننده‌ها را به دریافت به‌روزرسانی‌های LTS تشویق کرد. ما برای چنین به‌روزرسانی‌هایی بسیار تلاش می‌کنیم.

با توجه به صحبت‌های مالکو، به‌نظر می‌رسد به‌روزرسانی‌های LTS جزئی در برخی گوشی‌ها انجام می‌شود. به‌عنوان مثال Pixel 3 XL با کرنل ۴.۹.۹۶ عرضه شد و اکنون در اندروید Q بتا نسخه‌ی ۴.۹.۱۶۵ دارد.

مصاحبه‌‌ی بالا بررسی تقریبا تخصصی بود که با مهندسان ارشد اندروید در گوگل انجام شد تا جزئیاتی هرچه بیشتر از تغییرات مهم این اکوسیستم روشن شود. قطعا مفاهیم تخصصی موجود در این مصاحبه برای کاربران عادی جذاب نخواهد بود.





تاريخ : شنبه 22 تير 1398برچسب:, | | نویسنده : مقدم |