افشای جزئیاتی جدید از معماری تراشه M1 اپل در پی اجرای لینوکس روی مک های جدید

یک‌شنبه ۱۹ بهمن ۱۳۹۹ - ۲۲:۰۰
مطالعه 3 دقیقه
اجرای سیستم‌عامل لینوکس روی رایانه‌ی مک M1 باعث شد جزئیات بیشتری از معماری پیچیده‌ی این پردازنده‌‌ی اپل فاش شود که برپایه‌ی معماری آرم ساخته شده است.
تبلیغات

Corellium شرکتی نرم‌افزاری است که در زمینه‌ی طراحی راهکارهای مجازی‌سازی (Virtualization) تخصص دارد و به‌تازگی موفق شده است سیستم‌عامل لینوکس را به یکی از رایانه‌های مک مبتنی‌بر پردازنده‌ی M1 پورت کند و سپس با موفقیت، تقریبا تمامی اجزای سیستم را به‌کار بیندازد. طبق گزارش خبرگزاری تامز هاردور، شرکت Corellium در فرایند پورت‌کردن لینوکس به مک M1، جزئیات جالبی درباره‌ی پردازنده‌ی M1 اپل و معماری آن کشف کرد.

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

Corellium بهبودهای بیشتری روی سیستم اِعمال کرد و درنهایت، موفق شد اکثر قابلیت‌ها (شامل وای‌فای) را راه‌اندازی کند و این یعنی اکنون عملا امکان استفاده از لینوکس روی جدیدترین مک‌ها وجود دارد. بااین‌حال، کل پروژه‌ی اجرای سیستم‌عاملی به‌غیر از سیستم‌عامل پیش‌فرض اپل روی مک‌ها اثر جانبی جالبی داشت و نشان داد که سیستم-روی-چیپ جدید اپل از چه جوانبی با دیگر پردازنده‌های ساخته‌شده برپایه‌ی معماری آرم متفاوت است.

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

تقریبا در تمامی سیستم‌های ۶۴ بیتی مبتنی‌بر آرم، سیستم وقتی روشن می‌شود، با بهره‌گیری از رابطی به نام PSCI فرم‌ور را فرامی‌خوانند. بااین‌حال در پردازنده‌ی M1 اپل، هسته‌های پردازنده‌ی مرکزی (CPU) آدرسی را اجرا می‌کنند که رجیستر MMIO مشخص کرده و سپس سراغ اجرای کرنل می‌روند. به‌علاوه،‌ سیستم‌های اپل از کنترلری اختصاصی با عنوان Apple Interrupt Controller (موسوم به AIC) استفاده می‌کنند که با استانداردهای آرم سازگار نیست.

در همین حین، وقفه‌های تایمر (Timer Interrupts) به FIQ متصل هستند. FIQ قابلیتی مبهم در معماری سیستم اپل است که به‌طور‌عمده روی سیستم‌های ۳۲ بیتی آرم استفاده می‌شود؛ سیستم‌هایی که با لینوکس سازگار نیستند. سیستم‌عامل برای اینکه بتواند کاری کند پردازنده‌های متنوع درون رایانه‌ی مجهز به M1 با‌هم تعامل برقرار کنند، باید مجموعه‌ای از وقفه‌های میان‌پردازنده‌ای (IPI) را ارائه دهد. IPIها پیش‌تر همچون IRQهای سنتی مدیریت می‌شدند؛ اما در پردازنده‌ی M1، اپل از رجیسترهای هسته‌ی پردازنده به‌منظور ارسال و شناساسایی IPIها استفاده می‌کند؛ زیرا IPIها متکی‌بر FIQ هستند.

اقدامات عجیب اپل در اینجا به‌پایان نمی‌رسند و M1 مشخصه‌های بحث‌برانگیز دیگری را شامل می‌شود. برای مثال، کنترلر وای‌فای و بلوتوث اپل با استفاده از پروتکلی غیراستاندارد برپایه‌ی PCIe به سیستم-روی-چیپ متصل می‌شود که خوشبختانه نرم‌افزار مجازی‌سازی Corellium از آن پشتیبانی می‌کند.

برای پیچیده‌ترشدن شرایط، PCIe اپل و کنترلر یکپارچه‌ی Synopsys DWC3 USB سراغ استفاده از سیستم اختصاصی اپل در زمینه‌ی مدیریت داده‌های ورودی‌خروجی حافظه (IOMMU) می‌روند که با نام DART شناخته می‌شود. افزون‌بر‌این‌، I2C اپل فرم‌وری سفارشی دارد که برپایه‌ی پروتکلی اختصاصی ساخته شده است. این پروتکل استفاده از درگاه USB Type-A را غیرممکن می‌کند.

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

مدتی پیش، توسعه‌دهنده‌ای توانست با بهره‌گیری از ابزار مجازی‌سازی QEMU سیستم‌عامل موردانتظار ویندوز 10X مایکروسافت را روی یکی از مک های مجهز به پردازنده‌ی M1 اجرا کند؛ بااین‌حال، این سیستم‌عامل هنوز کامل نشده است و نمی‌دانیم ویندوز ۱۰ ایکس چقدر به ثبات رسیده است. ویندوز ۱۰ ایکس مایکروسافت اپلیکیشن‌های Win32 را اجرا نمی‌کند و همین موضوع باعث می‌شود سیستم‌عاملی ارزشمند برای برخی از کاربران محسوب نشود. 

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

تبلیغات
داغ‌ترین مطالب روز

نظرات

تبلیغات