תוכן עניינים:
- שלב 1: הקמת פרויקט ב- Vivado עבור ארני
- שלב 2: יצירת ה- PWM של ארני ב- Vivado
- שלב 3: יצירת ה- TDOA של Ernie ב- Vivado
- שלב 4: עטיפה ויצוא של ארני
- שלב 5: בניית ארני
- שלב 6: ה- BSP הראשון של ארני
- שלב 7: FreeRTOS'ing Ernie
- שלב 8: ייבוא קוד C של ארני
- שלב 9: איתור באגים לארי
- שלב 10: הפיכת ארני לאוטונומית
- שלב 11: להפוך את ארני לחמוד
2025 מְחַבֵּר: John Day | [email protected]. שונה לאחרונה: 2025-01-23 14:46
זהו הדרכה כיצד לבנות את ארני, הצליל האוטונומי שלך בעקבות הרובוט, באמצעות לוח זיבו. הוא יסקור כיצד: ליצור פרויקט ב- Vivado, ליצור מנהלי מנוע סרוו דמויי PWM ב- FPGA, ממשק עם שני חיישני קול, ליצור הפרש זמן של IP הגעה, להשתמש ב- freeRTOS ולהפעיל את ה- zybo מארז סוללות. זה היה פרויקט הגמר שלנו עבור שיעור מערכות הפעלה בזמן אמת (CPE 439) ב- Cal Poly SLO.
רשימת ציוד:
- 1 - מועצת הפיתוח של ZYBO Zynq 7000
- 2 - סרוו סיבוב רציף של Parallax
- 2 - חיישן קול (גלאי קול SparkFun)
- 1 - סוללת ליתיום יון USB של 5V (ללוח)
- 4 - סוללות AA (עבור סרוווס)
- 1 - מארז סוללות AA (עם 4 חריצי סוללה)
- 1 - כבל מיקרו USB
- 1 - לוח לחם
- רבים - חוטי זכר לזכר
- 1 - מארז סרוו
דרישות תוכנה:
- סוויטת עיצוב Xilinx Vivado 2016.2
- Digilent Adept 2.16.1
שלב 1: הקמת פרויקט ב- Vivado עבור ארני
- אשף יופיע
- הקש "הבא
-
שם הבא לפרויקט
- לעולם אל תשתמש בשם הפרויקט או בנתיב ספרייה שיש בו רווחים !!!!!
- זה יהיה פרויקט RTL.
- איננו רוצים לפרט מקורות
-
לחיצה על הבא, נגיע לדף החלק. אנו משתמשים ב- ZYNQ XC7Z010-1CLG400C.
- ל- Vivado אין את ה- Zybo רשום כאחד הלוחות שהוגדרו מראש. בחר: "חלקים" ואז חפש xc7z010clg400-1.
- אם תבחר את החלק הלא נכון בטעות תוכל להחליף שבבים בקלות: כלים -> הגדרות פרויקט -> כללי ולחץ על הנקודות מימין ל"התקן הפרויקט"
-
לחץ על צור עיצוב בלוק.
תן לזה עיצוב_1 לעת עתה
- תראה סרגל ירוק שאומר הוסף IP, לחץ עליו.
-
חפש את Zynq.
- לחץ פעמיים על מערכת עיבוד ZYNQ7,
- בלוק זה יופיע בעיצוב הבלוק שלנו.
- תראה סרגל ירוק שאומר Run Block Automation, לחץ עליו.
- הורד להלן zybo_zynq_def.xml.
-
ב- Vivado, לחץ על "ייבא הגדרות XPS" ובחר "zybo_zynq_def.xml"
זה מאכלס מראש את תצורת בלוק Vivado עם כל הציוד ההיקפי המובנה של לוח Zybo והקצאות סיכות
-
לחץ פעמיים על בלוק ZYNQ.
-
תצורת MIO
- אפשר טיימר 0 (תחת יחידת מעבד היישומים - תמונה 1)
- אפשר כלב שמירה (תחת יחידת מעבד יישומים- תמונה 1)
- אפשר GPIO-> GPIO MIO (תחת יחידת מעבד יישומים - תמונה 2)
- הפעל איפוס GPIO-> ENET (תחת ציוד היקפי לקלט/פלט- img 2)
-
תצורת שעון
השבת FCLK0 (תחת שעוני בד PL - img 3)
-
- לחץ על אישור.
-
"הפעל אוטומציה של בלוק" כעת.
יהיו כמה שאלות בנוגע לאותות, אמור אישור
-
לחץ על "צור עטיפת HDL".
נרצה להעתיק את העטיפה שנוצרה כדי לאפשר עריכות משתמשים
- לחץ על אישור.
שלב 2: יצירת ה- PWM של ארני ב- Vivado
שלב זה ייצר IP PWM עם תשומות שנשלחות דרך ספריית AXI.
-
צור בלוק AXI GPIO על ידי לחיצה ימנית על הרקע ולחיצה על "הוסף IP"
הקלד "AXI_GPIO" בשורת החיפוש ובחר חבילה זו
-
התאם מחדש את ה- IP על ידי לחיצה כפולה על הבלוק axi_gpio_0 החדש
- תחת GPIO, הגדר את רוחב GPIO ל- 2. סיביות אלה יהיו האות PWM_ON להנעת כל מופע מודול PWM.
- לחץ על "הפעל ערוץ כפול"
- תחת GPIO 2, הגדר את רוחב GPIO ל- 2. סיביות אלה יהיו האות PWM_FW לקביעת הכיוון של כל מופע מודול PWM.
-
לחץ באמצעות לחצן העכבר הימני על יציאת הפלט axi_gpio_0 שכותרתה GPIO ובחר "צור חיצוני"
- לחץ על הפלט החדש שכותרתו GPIO, ועבור לכרטיסייה "מאפיינים" בסרגל הכלים השמאלי, ושנה את השם ל- PWM_ON
- לחץ על הפלט החדש שכותרתו GPIO2, ועבר לכרטיסייה "מאפיינים" בסרגל הכלים השמאלי, ושנה את השם ל- PWM_FW
-
בחר הפעל אוטומציה של חיבור בבאנר הירוק שמעל תרשים החסימה.
אם תחבר את היציאות באופן ידני, ייתכן שלא תוגדר כתובות AXI, מה שיוביל לבעיות תקשורת בהמשך
-
בחלונית ניווט Flow, בחר מנהל פרויקטים -> הוסף מקורות ליצירת בלוק IP מותאם אישית חדש
- בחר "הוסף או צור מקורות עיצוב" ולחץ על הבא
- לחץ על "צור קובץ", שנה את סוג הקובץ ל- "SystemVerilog" והקלד "pwm" בשדה שם הקובץ ולאחר מכן לחץ על אישור
- לחץ על סיום
-
התעלם מחלון הגדרת המודול על ידי לחיצה על אישור (אנו נחליף אותם מאוחר יותר)
אם הוא שואל אם אתה בטוח, לחץ על כן
-
בכרטיסיה מקורות, לחץ פעמיים על pwm.sv (הממוקם ב"מקורות עיצוב/design_1_wrapper ")
העתק/הדבק את כל קוד SystemVerilog מהקובץ pwm.txt המצורף למטה
שלב 3: יצירת ה- TDOA של Ernie ב- Vivado
שלב זה ייצר IP TDOA שניתן לקרוא את הפלט שלו באמצעות ספריית AXI
-
צור בלוק AXI GPIO על ידי לחיצה ימנית על הרקע ולחיצה על "הוסף IP"
הקלד "AXI_GPIO" בשורת החיפוש ובחר חבילה זו
-
התאם מחדש את ה- IP על ידי לחיצה כפולה על הבלוק axi_gpio_1 החדש
- תחת GPIO, סמן את התיבה "כל הכניסות" והגדר את רוחב GPIO ל- 32. אוטובוס זה יהיה הפרש זמן ההגעה בין שני החיישנים.
- בתוך הבלוק axi_gpio_1, לחץ על ה + לצד יציאת GPIO כדי לחשוף gpio_io_i [31: 0].
-
לחץ לחיצה ימנית על יציאת הפלט axi_gpio_1 שכותרתה gpio_io_i [31: 0] ובחר "צור חיצוני"
לחץ על הקלט החדש שכותרתו gpio_io_i [31: 0], ועבור לכרטיסייה "מאפיינים" בסרגל הכלים השמאלי, ושנה את השם ל- TDOA_val
-
בחר הפעל אוטומציה של חיבור בבאנר הירוק שמעל תרשים החסימה.
אם תחבר את היציאות באופן ידני, ייתכן שלא תוגדר כתובות AXI, מה שיוביל לבעיות תקשורת בהמשך
-
בחלונית ניווט Flow, בחר מנהל פרויקטים -> הוסף מקורות ליצירת בלוק IP מותאם אישית חדש
- בחר "הוסף או צור מקורות עיצוב" ולחץ על הבא
- לחץ על "צור קובץ", שנה את סוג הקובץ ל- "SystemVerilog" והקלד "tdoa" בשדה שם הקובץ ולאחר מכן לחץ על אישור
- לחץ על סיום
-
התעלם מחלון הגדרת המודול על ידי לחיצה על אישור (אנו נחליף אותם מאוחר יותר)
אם הוא שואל אם אתה בטוח, לחץ על כן
-
בכרטיסיה מקורות, לחץ פעמיים על tdoa.sv (נמצא ב "מקורות עיצוב/design_1_wrapper")
העתק/הדבק את כל קוד SystemVerilog מהקובץ tdoa.txt המצורף למטה
שלב 4: עטיפה ויצוא של ארני
- ודא שתרשים החסימה נראה כמו צילום המסך המצורף
-
בכרטיסיה מקורות, לחץ באמצעות לחצן העכבר הימני על design_1.bd ובחר "צור עטיפת HDL …"
- בחר "העתק פלט שנוצר כדי לאפשר עריכות משתמשים" ולאחר מכן לחץ על "אישור"
- העתק את הקוד מתוך design_1_wrapper.txt המצורף למטה והדבק אותו במקום קוד design_1_wrapper.v שנוצר
- שמור design_1_wrapper.v
-
בכרטיסיה מקורות, לחץ פעמיים על הקובץ ZYBO_Master.xdc תחת אילוצים/הגבלות 1
- העתק את הקוד מתוך ZYBO_Master.txt המצורף למטה והדבק אותו במקום הקוד ZYBO_Master.xdc הקיים
-
שימו לב לסיכות הקלט/פלט הבאות:
- L15: אות PWM עבור המנוע השמאלי (Pmod JA2 ב- Zybo)
- L14: אות PWM עבור המנוע הימני (Pmod JA8 ב- Zybo)
- V12: כניסת שער מחיישן קול 1 (Pmod JE1 ב- Zybo)
- K16: כניסת שער מחיישן הקול 2 (Pmod JE2 ב- Zybo)
-
בחלונית ניווט Flow, לחץ על "צור Bitstream" תחת תוכנית וניפוי באגים
אם אתה חושב שזה נעשה מייד, זה כנראה לא. ברצינות, להכין תה
-
לחץ על קובץ-> ייצוא-> צור חומרה
סמן את "כלול Bitstream" ולחץ על אישור
- לחץ על קובץ-> הפעל SDK
שלב 5: בניית ארני
- הרכבו את הסרוויים לשלדת הסרוו.
-
עקוב אחר גליון הנתונים של סרוווס, בצע את הפעולות הבאות:
- חבר את קרקע הסרוווס לסיכות הארקה ב- JA Pmod של ה- Zybo (ראה תמונת pinout המצורפת)
- חבר את פין ההפעלה של סרוווס לסוללת AA
גילינו שכאשר הסרוו מחוברים ל- Vdd של ה- Zybo, הלוח שואב יותר מדי זרם וגורם ללוח להתאפס ללא הרף
- חבר את סיכות אות הכניסה לסיכות הפלט המתאימות של ה- Zybo (משמאל: JA2, מימין: JA8)
- הרכיבו את חיישני הקול בחזית המארז, כשהם פונים קדימה, שמרו אותם קרוב ככל האפשר
-
השתמש במדריך החיבור של חיישן הקול כדי לשלב את חיישני הקול
- חברו את סיכות הקרקע וה- Vdd של כל חיישן קול לקרקע וסיכות Vdd על ה- JE Pmod של ה- Zybo (ראו תמונת pinout המצורפת)
- חבר את סיכת השער של חיישן הקול השמאלי ל- JE1
- לחבר את סיכת השער הנכונה של חיישן הקול ל- JE2
שלב 6: ה- BSP הראשון של ארני
-
צור BSP כדי לסכם את הפלטפורמה שיצרנו זה עתה.
אתה יכול להשיג זאת באמצעות קובץ -> חדש -> חבילת תמיכה בלוח
-
אשף יצוץ שיעזור לך ליצור את ה- BSP.
- אנחנו רוצים לקשור את ה- BSP הזה עם הפלטפורמה שלנו שיצרנו זה עתה
- פלטפורמת החומרה צריכה להתיישר עם זו שיצרנו זה עתה (ראה תמונה 1)
- המעבד שלנו יהיה המעבד _0.
- לחץ על סיום
- הקפד לסמן את lwip141 להכללה עם ה- bsp שלך בחלון שיופיע (ראה תמונה 2)
שלב 7: FreeRTOS'ing Ernie
-
הורד את המהדורה האחרונה של FreeRTOS מ- Sourceforge.
אם ההורדה ניתנת להפעלה, הפעל אותה כדי לחלץ את קבצי FreeRTOS לספריית הפרויקטים שלך
- שמור את ה- SDK פתוח ולחץ על קובץ -> ייבוא.
- אנו רוצים ללחוץ על כללי-> מסביבת עבודה קיימת, ולאחר מכן נרצה לנווט לאן שהורדנו את FreeRTOS.
-
ההדגמה שלנו תמוקם ב- FreeRTOS/Demo/CORTEX_A9_Zynq_ZC702. בבחירת התיקיה הזו, אנו אמורים לראות שלושה פרויקטים צצים (הקוד שלנו (OS), זה BSP ופלטפורמת HW).
ייבא רק RTOSDemo לסביבת העבודה הנוכחית שלך
-
בכל פרויקטי התיקיות "הכחולים" משנים את ה- BSP שהוזכר
- לחץ באמצעות לחצן העכבר הימני ובחר "שנה BSP שהוזכר".
- בחר את ה- BSP שיצרת זה עתה עבור ה- Zybo שלך
- עריכת קוד בתיקיות ה- SDK Blue של Xilinx הן פרויקטי הקוד בפועל.
שלב 8: ייבוא קוד C של ארני
- בספריית RTOSDemo/src, החלף את main.c הקיים עם קובץ main.c המצורף כאן.
- העתק את הגירסה main_sound.c לספריית RTOSDemo/src.
שלב 9: איתור באגים לארי
- בחר הפעלה -> תצורות באגים
- בחלונית השמאלית צור הפעלה חדשה של Debugger System
-
בכרטיסייה הגדרת יעד,
בחר "אפס את כל המערכת" כך שגם זה וגם ps7_init ייבחרו
-
כעת בחר בכרטיסייה יישום.
- בחר "הורד יישום"
- הגדר את ליבת cortexa9_0 ל"עצור בכניסת התוכנית"
- לחץ על Apply and Debug.
- ודא כי אין שגיאות בתהליך איתור באגים
- תוך שמירה מקרוב על הרובוט, לחץ על לחצן המשך עד שהתוכנית פועלת מבלי לפגוע בנקודות שבירה
- כעת הרובוט צריך להסתובב ולהתקדם לכיוון רעשים חזקים. יש!
שלב 10: הפיכת ארני לאוטונומית
- ברגע שהפרויקט שלך מוכן לצאת לדרך (אתה יכול לרוץ ללא בעיות דרך הבאגים) אתה מוכן לטעון אותו לזיכרון הבזק בלוח שלך.
-
צור מה שנקרא "פרויקט האתחול השלב הראשון" (FSBL) ומכיל את כל ההוראות הדרוש ללוח שלך על מנת לטעון את קבצי הפרויקט שלך (זרם הסיביות ומערכת ההפעלה) בעת ההפעלה.
- בחר: קובץ-> חדש-> פרויקט יישומים והחלון הבא אמור להופיע.
- תן לזה מה שאתה רוצה (כלומר "FSBL")
- וודא שפלטפורמת החומרה היא זו שאתה עובד איתה
- הקש על הבא (אל תלחץ על סיום)
- בחר את תבנית Zynq FSBL
- לחץ על סיום.
- לאחר השלמת תהליך היצירה תדע אם הכל עבד אם תראה את שתי התיקיות החדשות הבאות בחלון סייר הפרויקט.
-
צור תמונת אתחול כעת יהיה עליך ליצור את תמונת האתחול.
- קליק ימני על תיקיית הפרויקט שלך (במקרה זה שלי נקרא "RTOSDemo")
- לחץ על "צור תמונת אתחול" מהתפריט הנפתח
-
אם הכל מקושר כהלכה, הפרויקט יידע אילו קבצים הוא צריך והחלון הבא ייראה כפי שאתה רואה להלן (המפתח הוא שיש לך 3 מחיצות תחת סעיף תמונת אתחול, מטען האתחול, קובץ הסיביות שלך וקובץ הפרויקטים שלך.elf.).
אם זה לא המקרה, ייתכן שמשהו לא בסדר בקישור הפרויקט שלך. ודא שתיקיות הפרויקט מקושרות ל- BSP שלהם
- לחץ על כפתור "צור תמונה"
-
השלב האחרון לביצוע בתוכנה הוא להבהב כעת את התמונה שנוצרה בעבר לזיכרון הלוח
- בחר מסרגל הכלים הראשי של SDK בחר בכלי Xilinx-> תכנת זיכרון פלאש
- וודא שנבחרה פלטפורמת החומרה הנכונה וכי נתיב קובץ התמונה מצביע כראוי לקובץ. BIN שנוצר בשלב הקודם.
- בחר "qspi single" מסוג Flash
- סמן את האפשרות "אמת לאחר הבזק" כדי להבטיח את התקינות אך אין בכך צורך
- הגדר את הלוח שלך לבסוף עליך לוודא שמגשר מצב התכנות של לוחות (JP5) מוגדר כראוי לבחור לאתחול מה- qspi (המכיל את מה שהבזקת זה עתה) כאשר BootROM מופעל.
- כעת פשוט הפעל את המכשיר והפעל כי "נורית ה- Logic Configuration Done" (נורית 10) מוארת בירוק.
שלב 11: להפוך את ארני לחמוד
- פרווה
- הרבה פרווה
- עיניים גדולות!
- … כובע עליון
מוּמלָץ:
איך להכין טלפון פח אלחוטי! (מכשיר קשר ארדואינו): 7 שלבים (עם תמונות)
איך להכין טלפון פח אלחוטי! (ארקינו ווקי טוקי): ממש לפני כמה ימים, הייתי באמצע שיחת טלפון חשובה מאוד כשטלפון הבננות שלי הפסיק לעבוד! הייתי כל כך מתוסכל. זו הפעם האחרונה שאני מפספסת שיחה בגלל הטלפון המטופש הזה! (בדיעבד, אולי קצת יותר מדי כעסתי על
איך להכין מכס במיינקראפט: 8 שלבים
איך עושים מכס במיינקראפט: שלום לכולם !! שמי מתיו ווייט ובמהלך ההדרכה הזו אראה לך תהליך שלב אחר שלב כיצד להכין מכס עץ במהדורת ג'אווה Minecraft
איך להכין מטוס סילון RC פשוט משלך?: 10 שלבים
כיצד להכין מטוס RC Jet פשוט משלך?: כיצד להכין מטוס RC (שלט רחוק) באמצעות קצף או פקק פוליפום, שאני נוהג להשתמש בו, הוא די פשוט וקל אם אתה מכיר את הנוסחה הכללית. למה נוסחת הענן? כי אם תסביר בפירוט ותשתמש ב- sin cos tan וחבריו, של
איך להכין מטוס RC בבית מתחת ל -60 $: 4 שלבים
כיצד להכין מטוס RC בבית מתחת ל -60 $: היום אראה לך כיצד לבנות מטוס RC מתחת ל -60 $. אתה יכול לצפות בסרטון שלי ביוטיוב להבנה. בסרטון סיפרתי מחיר ברופי הודי מכיוון שאני רוצה למקד לקהל הודי. אם אתה אוהב את הסרטון שלי, הירשם כמנוי לערוץ שלי בעתיד
איך להכין מכונת משקל לתינוק באמצעות Arduino Nano, HX-711 Load Cell ו- OLED 128X64 -- כיול HX-711: 5 שלבים
כיצד להכין מכונת משקל לתינוק באמצעות Arduino Nano, HX-711 Load Cell ו- OLED 128X64 || כיול HX-711: שלום הוראות, לפני כמה ימים הפכתי לאבא לתינוק חמוד?. כשהייתי בבית חולים גיליתי שמשקל התינוק כה קריטי כדי לעקוב אחר התפתחות התינוק. אז יש לי רעיון? להכין מכונה במשקל תינוק מעצמי. במדריך זה אני