Threefish

מתוך ויקיפדיה, האנציקלופדיה החופשית
Threefish
תיאור ארבעה סבבים מתוך 72 הסבבים של Threefish-512 הכוללים שילוב של הפונקציה MIX, התמורה '"`UNIQ--postMath-00000001-QINU`"' ושילוב מפתח ההצפנה אחת לארבעה סבבים
תיאור ארבעה סבבים מתוך 72 הסבבים של Threefish-512 הכוללים שילוב של הפונקציה MIX, התמורה ושילוב מפתח ההצפנה אחת לארבעה סבבים
מידע כללי
תכנון Bruce Schneier, Niels Ferguson, Stefan Lucks, Doug Whiting, Mihir Bellare, Tadayoshi Kohno, Jon Callas, Jesse Walker
פרסום 2008
מבוסס על Blowfish, Twofish
מבנה הצופן
אורך מפתח 256/512/1024 סיביות
אורך בלוק זהה לאורך המפתח
מבנה ARX
מספר סבבים 72 (במפתח 1024 יש 80 סבבים)

Threefish[1] הוא צופן בלוקים בר התאמה (tweakable block cipher) שפותח ב-2008 כחלק מפונקציית הגיבוב Skein[2] שהוצעה לתחרות הגיבוב של NIST. הצופן מגיע בשלוש גרסאות לפי גודל בלוק; 256, 512 או 1024 סיביות ואורכו של מפתח ההצפנה כאורך הבלוק. הוא כולל tweak שהוא מעין וקטור אתחול בגודל 128 סיביות.

ליבת צופן Threefish הנקראת MIX, בנויה בסגנון ARX המורכבת משלוש פעולות בסיסיות, חיבור מודולו , XOR והזזה מעגלית בהיסטים קבועים. הקונספט הוא פעולות פשוטות עם יותר סבבים, בניגוד לצפנים אחרים בהם הפעולות מורכבות יותר אך עם פחות סבבים. כל הפעולות הן על מילים בגודל 64 סיביות. כאשר בצופן Threefish-256 ו-Threefish-512 הליבה מופעלת 72 פעמים בתשעה סבבים (שמונה פעמים לסבב) ואילו ב-Threefhish-1024 הליבה מופעלת 80 פעם בעשרה סבבים. בכל סבב מופעלת הפונקציה MIX שמונה פעמים, בנוסף מבוצעת תמורה של כל מילות הזיכרון הפנימי על ידי הזזה מעגלית לפי היסטים קבועים להשגת אפקט פיזור גבוה וכן אחת לארבעה סבבים מוסיפים חלק מהמפתח. בשל פשטותו הרבה הצופן מהיר מאוד ויכול להגיע לקצב של 6.5 cpb (על מחשב 64 ביט).

Threefish פותח על ידי Mihir Bellare, Jesse Walker, Jon Callas, Doug Whiting, Stefan Lucks, Niels Ferguson, Bruce Schneier, Tadayoshi Kohno והוא אינו רשום כפטנט, קוד המקור אינו מוגן בזכויות יוצרים והוא חופשי לשימוש לכל מטרה.

תיאור הצופן[עריכת קוד מקור | עריכה]

הפונקציה MIX

כל פעולות הצופן הן על מילים בגודל 64 סיביות המייצגות מספרים שלמים חיוביים (לא מסומנים) בטווח . אם הקלט הוא מערך בתים יש להמירו למילים בגודל 64 סיביות בשיטת סדר בתים קטן (להלן). דהיינו הבית הפחות משמעותי מאוחסן בכתובת הראשונה בזיכרון.

פונקציית ההצפנה מקבלת את הארגומנטים הבאים:

  • K. מפתח הצפנה סודי המסופק על ידי המשתמש שהוא מחרוזת באורך מילים כאשר .
  • T. ערך ייחודי שנקרא Tweak באורך 16 בתים.
  • P. טקסט גלוי באורך זהה למפתח.

את מפתח ההצפנה הסודי וה-tweak מאריכים תחילה במילה נוספת שנקראת זוגיות (parity) שהיא תוצאת XOR של כל מילות המפתח וה-tweak בהתאמה ומחלקים לתת-מפתחות עבור כל הסבבים. כל תת-מפתח הוא שילוב של כל מילות המפתח המורחב למעט אחת, שתים מתוך שלוש מילות tweak ומספר סידורי של תת-המפתח (כמתואר בתרשים הכנת המפתח). כל תהליך הכנת המפתח ניתן לביצוע במספר מחזורי שעון מועט. עובדה קריטית אם הצופן אמור להיות חלק מפונקציית גיבוב. כאשר מגבבים כמות גדולה של בלוקים, כל בלוק צריך להיות מוצפן בנפרד (עם מפתח שונה), על כן תהליך הכנה ארוך עבור כל הצפנה אינו יעיל.

המפתח מיוצג כמערך מילים: באורך ומילה נוספת לזוגיות, ה-tweak מוצג כשתי מילים: ומילה נוספת לזוגיות וטקסט המקור הוא מערך המילים . מספר הסבבים הוא פונקציה של גודל הבלוק כמוצג בטבלה.

גודל בלוק/מפתח מספר המילים מספר פעמים שהפונקציה MIX מופעלת מספר סבבים
256 4 72 8
512 8 72 8
1024 16 80 10

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

תחילה טוענים את הבתים של המסר כך:

לאחר מכן מבוצעים סבבים כשבכל אחד מהם מוסיפים תת-מפתח רק אם (אחת לארבעה סבבים) לסיכום:

את הערבוב MIX והתמורה (בטבלה הבאה) מבצעים לסירוגין כדלהלן:

והטקסט המוצפן מתקבל על ידי:

טבלת תמורות [עריכת קוד מקור | עריכה]

להלן טבלת התמורות המייצגת את הסידור מחדש של מילות הקלט לפי גודל הצופן. לדוגמה במקרה של Threefish-256 ישנן ארבע מילים ולכן התמורות הן לפי השורה הראשונה, לכן פירושו שהמילה הראשונה מהסבב הרביעי תהיה שלישית בסבב החמישי.

טבלת תמורות
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
0 3 2 1
2 1 4 7 6 5 0 3
0 9 2 13 6 11 4 15 10 7 12 3 14 5 8 1

הפונקציה MIX[עריכת קוד מקור | עריכה]

הפונקציה מקבלת שתי מילות קלט ומייצרת שתי מילות פלט לפי הנוסחה הבאה:

הסימן מייצג אופרטור הזזה מעגלית לשמאל. הקבועים הם לפי טבלת ההיסטים הבאה. חלק מהקבועים שונו בגרסה 2 של הצופן.

טבלת ההיסטים
4 8 16
j 0 1 0 1 2 3 0 1 2 3 4 5 6 7
0 14 16 46 36 19 37 24 13 8 47 8 17 22 37
1 52 57 33 27 14 42 38 19 10 55 49 18 23 52
2 23 40 17 49 36 39 33 4 51 13 34 41 59 17
d=3 5 37 44 9 54 56 5 20 48 41 47 28 16 25
4 25 33 39 30 34 24 41 9 37 31 12 47 44 30
5 46 12 13 50 10 17 16 34 56 51 4 53 42 41
6 58 22 25 29 39 43 31 44 47 46 19 42 44 25
7 32 32 8 35 56 22 9 48 35 52 23 31 37 20

פרוצדורת הרחבת מפתח[עריכת קוד מקור | עריכה]

פרוצדורת הכנת תת-מפתחות של Threefish

תחילה מוסיפים שתי מילים.

וכן .

כלומר מילת מפתח נוספת שהיא XOR של כל מילות המפתח וכן מילה נוספת שהיא XOR של שתי המילים של ה-tweak. הקבוע מבטיח שהמפתח המורחב לא יהיה כולו או כמעט כולו אפס. הקבוע הזה נוצר על ידי הצפנה של המספר "240" עם צופן AES כאשר המפתח כולו אפס. הוספת ה-tweak היא כדלהלן:

כל פעולות החיבור הן מודולו .

פענוח[עריכת קוד מקור | עריכה]

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

פסאודו-קוד[עריכת קוד מקור | עריכה]

הקוד הבא מתאר הצפנה ופענוח עם Threefish-512. פונקציית הכנת המפתח מקבלת מערך באורך 9 מילים ו-tweak באורך 3 מילים ומוסיפה את מילות הזוגיות (parity). תחילה מציבים את המפתח הסודי של המשתמש ב-8 הכניסות הראשונות של המערך ואת שתי מילות ה-tweak בשתי הכניסות הראשונות של ומבצעים כדלהלן.

הכנת מפתח[עריכת קוד מקור | עריכה]

הצפנה[עריכת קוד מקור | עריכה]

פונקציית ההצפנה מקבלת מערך באורך 8 מילים, tweak המסומן ב- באורך 3 מילים ומפתח סודי באורך 9 מילים ומחזירה מערך באורך 8 מילים. הקוד הבא לקוח מקוד היישום שהומלץ לתקן על ידי המפתחים ממנו הוסרו קטעי קוד לא חשובים למען הפשטות. הקוד מתוכנן בשיטת פרישת לולאות (loop unrolling) חלקית, פרישת לולאות מקובלת בכתיבת קודים ממוטבים למעבדי 32 ו-64 סיביות. כאן מספר הלולאות צומצם ל-9 וכן בדוגמה זו ההנחה היא שההמרות הן לפי סדר בתים קטן, כלומר מחרוזת הבתים המייצגת את הטקסט המקורי מומרת לפי הנוסחה להלן ל- שהוא מערך של 8 מספרים שלמים בגודל 64 סיביות מהקטן לגדול (המספר הראשון מאוחסן בכתובת וכן הלאה). באותה שיטה ממירים את הפרמטרים האחרים.

פונקציות עזר[עריכת קוד מקור | עריכה]

כל פעולות החיבור הן כאמור מודולו כלומר נוטלים את 64 הסיביות הראשונות של התוצאה ומהיתר מתעלמים. התקן במעבדים רבים הוא שחיבור שלמים מתבצע באופן עקיף מודולו גבולות המילה, כלומר כל תוצאה שחורגת מהגודל שנכנס באוגר נחתכת ממילא, כך שאין צורך לנקוט בפעולה כלשהי. הפונקציה היא הזזה מעגלית לימין והפונקציה היא הזזה מעגלית לשמאל. אפשר ליישמן עם האופרטורים הרגילים; הזזה לשמאל "", הזזה לימין "" ואופרטור וגם "", למשל ב-64 סיביות זה ייראה כך:

המרת מערכי בתים למילים וההפך מתבצעת לפי סדר בתים קטן כך:

פונקציית פענוח[עריכת קוד מקור | עריכה]

פונקציית הפענוח מבצעת את כל הפעולות למעט XOR שהיא הופכית של עצמה, בסדר הפוך; חיסור מודולו במקום חיבור, הזזה מעגלית לימין במקום לשמאל והוספת מפתח מהסוף להתחלה. הפונקציה מקבלת את המערך באורך 8 מילים, וקטור אתחול באורך 3 מילים ומפתח סודי באורך 9 מילים ומחזירה את באורך 8 מילים.

ראו גם[עריכת קוד מקור | עריכה]

הערות שוליים[עריכת קוד מקור | עריכה]