פרוטוקול Thread ו-IPv6

Matter משתמש ב-IPv6 לתקשורת התפעולית שלו, ומתבסס על כתובות IPv6 Unicast ו-Multicast כדי לגשת לצמתים ולקבוצות שלו, בהתאמה.

צריכת חשמל נמוכה

חלק מהצמתים Matter מחוברים באמצעות חוטים ויש להם תקציבי אנרגיה שמאפשרים להם להשאיר את הרדיו פעיל באופן רציף. סוגים אחרים של צמתים, כמו חיישנים, צריכים לפעול במשך שנים על סוללה, ולהפעיל את הרדיו שלהם ברשתות עם צריכת חשמל נמוכה כמו Thread. ארכיטקטורת ה-proxy, יחד עם Thread מכשירי קצה במצב שינה, מאפשרת לצמתים עם אספקת חשמל מלאה לספק פונקציונליות ברמת הרשת וברמת האפליקציה, שמבודדת את צמתי הצאצא שלהם מעסקאות שדורשות הרבה אנרגיה.

היבט בסיסי של Matter הוא שהוא פועל גם במדיומים של רשתות עם קצב העברה גבוה כמו Wi-Fi ו-Ethernet, וגם ברשתות עם חביון נמוך ורוחב פס נמוך כמו Thread. אם כל חבילות הנתונים של Wi-Fi היו מגשרות ל-Thread, היינו מעמיסים על הרשת יותר מדי, ואולי גם גורמים להצפה.Multicast המטרה של Thread היא להפעיל IPv6 ברשתות Mesh עם צריכת חשמל נמוכה וזמן אחזור קצר, ולא להעביר נתונים ברוחב פס גבוה. בדרך כלל, פינגים של ICMPv6 ב-Thread ברשת מקומית הם מתחת לכמה עשרות אלפיות השנייה של זמן הלוך ושוב (RTT), אבל רוחב הפס הכולל מוגבל ל-250kbps ב-IEEE 802.15.4 PHY. עם שידור חוזר של חבילות ועם תקורה, רוחב הפס המקסימלי האופייני הוא בערך 125kbps. במילים אחרות, סדרי גודל פחותים מאלה של Wi-Fi.

פריימים ב-IEEE 802.15.4 PHY הם בגודל 127 בייט, אבל יחידת השידור המקסימלית (MTU) הגדולה ביותר (והטיפוסית) של חבילות IPv6 ב-Thread היא בגודל 1,280 בייט. לכן, לעיתים קרובות צריך לפצל חבילות IPv6 למספר פריימים של PHY. התהליך הזה מוגדר על ידי RFC4944.

מידע נוסף זמין במאמר IPv6 Addressing ב-Thread Primer ב-openthread.io.

נתבי גבולות

אז איך יכולים צמתים להתקיים בשני אמצעי התקשורת האלה באותה רשת? למרות שבשתי הרשתות יש אישורים ברמת האפליקציה Matter משותפים, הן לא משתמשות באותה טכנולוגיית קישור. בתרחיש הזה, כדי לאפשר קישוריות, הרשת צריכה נתב גבול (BR) של Thread. נתבי BR הם נתבי Stub IPv6.

נתבים מסוג Stub מאפשרים קישוריות בין רשתות מסוג Stub לבין רשתות רגילות. רשת Stub היא רשת 'המייל האחרון' שמספקת קישוריות חיצונית לחברים שלה, אבל לא משמשת כנתיב רשת מעבר בין רשתות אחרות. בדרך כלל, רשתות Stub מבוססות על Thread.Matter מידע נוסף על רשתות stub מופיע בטיוטת RFC.

לכן, ל-BR יש אחריות להיות הקישור בין רשת Stub לבין רשת התשתית הסמוכה, שהיא רשת ה-Wi-Fi או האתרנט המקומית. הם מעבירים רק את החבילות שרלוונטיות לרשת Thread.

התהליך הזה מתבצע על ידי הקצאת קידומות שונות של IPv6 ל-Thread ולרשתות תשתית סמוכות. לכן, ה-BR מעביר רק שידורים חד-פעמיים אל או מקידומת ה-IPv6‏ Thread.

נתבי גבולות אחראים גם ל:

  • הגדרת קידומות וניתוב IPv6 באופן אוטומטי גם עבור Thread וגם עבור רשתות תשתית סמוכות, כך שמארחים משני הצדדים של נתב הגבולות של Thread יוכלו לתקשר.
  • פרסום חבילות גילוי של DNS-SD ב-mDNS בשם צמתים, כדי שאפשר יהיה לגלות אותם ברשת התשתית הסמוכה.Thread

מידע נוסף זמין במדריך בנושא נתב גבולות באתר openthread.io.

IPv6 Multicast

הודעות Group חשובות גם הן, כי הן מאפשרות שליטה בו-זמנית בכמה צמתים (Matter Nodes) דרך Multicast. כדי לנתב את התנועה הזו לרשת Thread, גם Matter וגם Thread מטמיעים את Unicast Prefix-based IPv6 Multicast Addressing Scheme שמוגדר ב-RFC 3306.

השיטה הזו מאפשרת לבחור את צמתי היעד של מנות Multicast על סמך הקידומת המשותפת שלהם ב-IPv6 Unicast.

לדוגמה, כתובת Matter Multicast יכולה להיראות כך:

FF35:0040:FD<Fabric ID>00:<Group ID>

בטבלה 1 מפורט האופן שבו הכתובת הזו בנויה:

טבלה 1: Unicast כתובות IPv6 שמבוססות על קידומת
ביטים תיאור
‫12 ביט 0xFF3
‫4 ביטים 0x05

היקף: מקומי לאתר

‫8 ביט 0x00

שמור

‫8 ביט 0x40

מציין תחילית ארוכה של 64 ביט

‫8 ביט ‫0xFD

מציין קידומת של ULA

‫56 ביטים מזהה בד
‫8 ביטים 0x00
‫16 ביט מזהה קבוצה

מידע נוסף מופיע בקטע Multicast במבוא ל-Thread וב-RFC עצמו.

כשנוצרות כתובות IPv6 Multicast, הן כוללות גם את 56 הביטים העליונים של מזהה הרשת. המשמעות החשובה היא שההיקף של Multicast הוא בתוך Fabric, בעוד שכתובות Unicast משותפות בין Fabrics. בצמתים עם הרבה רשתות Fabric יכולות להיות כמה כתובות Multicast שמגדירות קבוצות צמתים חופפות שמוגדרות לכל רשת Fabric.

היציאות

Matter משתמשת ביציאה 5540 לשידורים שלה.