طرح های Co-Processor توسط OpenThread پشتیبانی می شوند. هنگام ساختن نمونههای OpenThread، یک تصویر میانافزار برای هر طراحی همپردازنده بهطور خودکار ایجاد میشود. برای اطلاعات بیشتر به Binaries مراجعه کنید.
پردازنده مشترک رادیویی (RCP)
در طراحی RCP، هسته OpenThread روی پردازنده میزبان زندگی می کند و تنها با حداقل یک لایه MAC "کنترل کننده" روی دستگاه دارای رادیو Thread زندگی می کند. پردازنده میزبان معمولاً در این طراحی نمیخوابد، تا حدی برای اطمینان از قابلیت اطمینان شبکه Thread.
ارتباط بین RCP و پردازنده میزبان توسط OpenThread Daemon از طریق یک رابط SPI روی پروتکل Spinel مدیریت می شود.
مزیت اینجا این است که OpenThread می تواند از منابع پردازنده قدرتمندتر استفاده کند.
این طراحی برای دستگاه هایی که حساسیت کمتری به محدودیت های برق دارند مفید است. به عنوان مثال، پردازنده میزبان در یک دوربین فیلمبرداری همیشه برای پردازش ویدیو روشن است.
روتر مرزی OpenThread از طراحی RCP پشتیبانی می کند. برای اطلاعات بیشتر، به OpenThread Border Router مراجعه کنید.
برای ساخت RCP، به Codelabs زیر مراجعه کنید:
یک شبکه Thread با nRF52840 Thread Border Router بسازید
پردازشگر مشترک شبکه (NCP)
طراحی استاندارد NCP دارای ویژگیهای Thread در SoC است و لایه برنامه را روی یک پردازنده میزبان اجرا میکند، که معمولاً نسبت به دستگاه OpenThread توانایی بیشتری دارد (اما نیاز به انرژی بیشتری دارد).
ارتباط بین NCP و پردازنده میزبان توسط wpantund
از طریق یک رابط سریال، معمولاً با استفاده از SPI یا UART، روی پروتکل اسپینل مدیریت می شود.
مزیت این طراحی این است که هاست با توان بالاتر می تواند بخوابد در حالی که دستگاه OpenThread کم مصرف برای حفظ جایگاه خود در شبکه Thread فعال باقی می ماند. و از آنجایی که SoC به لایه برنامه متصل نیست، توسعه و آزمایش برنامه ها مستقل از ساخت OpenThread است.
این طراحی برای دستگاههای دروازه یا دستگاههایی که نیازهای پردازش دیگری مانند دوربینهای IP و بلندگو دارند، مفید است.
پروتکل اسپینل
اسپینل یک پروتکل مدیریت کلی است که به یک دستگاه میزبان امکان برقراری ارتباط و مدیریت یک پردازنده کمکی را می دهد. Spinel که در ابتدا برای پشتیبانی از NCPهای مبتنی بر Thread طراحی شده بود، با رویکرد لایهای طراحی شده است که به آن اجازه میدهد به راحتی با سایر فناوریهای شبکه در آینده سازگار شود. با هر دو طرح RCP و NCP استفاده می شود.
این پروتکل با OpenThread در /src/lib/spinel
گنجانده شده است. یک ابزار CLI پایتون به نام Pyspinel برای اهداف آزمایشی در دسترس است.
برای اطلاعات بیشتر، به پیشنویس اینترنت برای پروتکل کنترلکننده میزبان Spinel مراجعه کنید.