Cara Membuat Ernie: 11 Langkah
Cara Membuat Ernie: 11 Langkah
Anonim
Cara Membuat Ernie
Cara Membuat Ernie

Ini adalah tutorial tentang cara membuat Ernie, robot penerus suara otonom Anda, menggunakan Zybo Board. Ini akan mencakup cara: membuat proyek di Vivado, membuat driver motor servo seperti PWM di FPGA, antarmuka dengan dua sensor suara, membuat perbedaan waktu kedatangan IP, menggunakan freeRTOS, dan menjalankan zybo dari baterai. Ini adalah tugas akhir kami untuk kelas Sistem Operasi Waktu Nyata (CPE 439) di Cal Poly SLO.

Daftar perlengkapan:

  • 1 - Papan Pengembangan ZYBO Zynq 7000
  • 2 - Servo Rotasi Berkelanjutan Paralaks
  • 2 - Sensor Suara (Detektor Suara SparkFun)
  • Paket baterai USB Lithium Ion 1 - 5v (untuk papan)
  • 4 - baterai AA (untuk servos)
  • 1 - baterai AA (dengan 4 slot baterai)
  • 1 - Kabel USB mikro
  • 1 - Papan tempat memotong roti
  • banyak - Kabel Pria ke Pria
  • 1 - Sasis servo

Persyaratan perangkat lunak:

  • Xilinx Vivado Design Suite 2016.2
  • Rajin Mahir 2.16.1

Langkah 1: Menyiapkan Proyek di Vivado untuk Ernie

Menyiapkan Proyek di Vivado untuk Ernie
Menyiapkan Proyek di Vivado untuk Ernie
Menyiapkan Proyek di Vivado untuk Ernie
Menyiapkan Proyek di Vivado untuk Ernie
Menyiapkan Proyek di Vivado untuk Ernie
Menyiapkan Proyek di Vivado untuk Ernie
  1. Seorang penyihir akan muncul
  2. Klik Berikutnya
  3. Selanjutnya beri nama proyek

    1. Jangan pernah menggunakan nama proyek atau jalur direktori yang memiliki spasi di dalamnya!!!!!
    2. Ini akan menjadi proyek RTL.
  4. Kami tidak ingin menentukan sumber
  5. Mengklik Berikutnya, kita sampai ke halaman Bagian. Kami menggunakan ZYNQ XC7Z010-1CLG400C.

    1. Vivado tidak mencantumkan Zybo sebagai salah satu papan yang telah ditentukan sebelumnya. Pilih: "bagian" lalu cari xc7z010clg400-1.
    2. Jika Anda memilih bagian yang salah secara tidak sengaja, Anda dapat dengan mudah mengganti chip: Alat -> Pengaturan Proyek -> Umum dan klik titik di sebelah kanan "Perangkat Proyek"
  6. Klik Buat Desain Blok.

    Beri nama design_1 untuk saat ini

  7. Anda akan melihat bilah hijau yang mengatakan Tambahkan IP, klik itu.
  8. Cari Zynq.

    1. Klik dua kali Sistem Pemrosesan ZYNQ7,
    2. Blok ini akan muncul dalam desain blok kami.
  9. Anda akan melihat bilah hijau yang bertuliskan Run Block Automation, klik itu.
  10. Unduh zybo_zynq_def.xml di bawah ini.
  11. Di Vivado, klik "Impor Pengaturan XPS" dan pilih "zybo_zynq_def.xml"

    Pra ini mengisi konfigurasi blok Vivado dengan semua periferal bawaan Zybo dan penetapan pin

  12. Klik dua kali pada blok ZYNQ.

    1. Konfigurasi MIO

      1. Aktifkan Timer 0 (di bawah Unit Prosesor Aplikasi - img 1)
      2. Aktifkan Watchdog (di bawah Unit Prosesor Aplikasi- img 1)
      3. Aktifkan GPIO->GPIO MIO (di bawah Unit Prosesor Aplikasi - img 2)
      4. Aktifkan GPIO->ENET Reset (di bawah I/O Peripherals- img 2)
    2. Konfigurasi Jam

      Nonaktifkan FCLK0 (di bawah PL Fabric Clocks - img 3)

  13. Klik Oke.
  14. "Jalankan Otomatisasi Blok" sekarang.

    Akan ada beberapa pertanyaan tentang sinyal, katakan OK

  15. Klik "Hasilkan Pembungkus HDL".

    Kami ingin menyalin pembungkus yang dihasilkan untuk memungkinkan pengeditan pengguna

  16. Klik Oke.

Langkah 2: Membuat PWM Ernie di Vivado

Membuat PWM Ernie di Vivado
Membuat PWM Ernie di Vivado
Membuat PWM Ernie di Vivado
Membuat PWM Ernie di Vivado

Langkah ini akan menghasilkan IP PWM dengan input yang dikirim melalui library AXI.

  1. Buat blok AXI GPIO dengan cara klik kanan pada background, lalu klik "add IP"

    ketik "AXI_GPIO" ke dalam bilah pencarian, dan pilih paket ini

  2. Sesuaikan ulang IP dengan mengklik dua kali blok axi_gpio_0 baru

    1. di bawah GPIO, atur lebar GPIO ke 2. Bit ini akan menjadi sinyal PWM_ON untuk menggerakkan setiap instance modul PWM.
    2. klik "aktifkan saluran ganda"
    3. di bawah GPIO 2, atur lebar GPIO ke 2. Bit ini akan menjadi sinyal PWM_FW untuk mengatur arah setiap instance modul PWM.
  3. Klik kanan pada port output axi_gpio_0 berlabel GPIO, dan pilih "Make External"

    1. Klik pada output baru berlabel GPIO, dan arahkan ke tab "properties" di bilah alat kiri, dan ubah namanya menjadi PWM_ON
    2. Klik pada output baru berlabel GPIO2, dan arahkan ke tab "properties" di bilah alat kiri, dan ubah namanya menjadi PWM_FW
  4. Pilih Jalankan Otomatisasi Koneksi di spanduk hijau di atas diagram blok.

    Jika Anda menghubungkan port secara manual, alamat AXI mungkin tidak dikonfigurasi, yang menyebabkan masalah komunikasi di kemudian hari

  5. Di Flow Navigator Pane, pilih project manager -> Add Sources untuk membuat blok IP kustom baru

    1. pilih "tambah atau buat sumber desain", dan tekan berikutnya
    2. klik "buat file", ubah jenis file menjadi "SystemVerilog", dan ketik "pwm" ke dalam bidang nama file, lalu klik OK
    3. klik Selesai
    4. abaikan jendela Define Module dengan menekan OK (kami akan menimpanya nanti)

      jika ditanya apakah Anda yakin, klik Ya

  6. Di tab sources, klik dua kali pwm.sv (terletak di "Sumber Desain/design_1_wrapper")

    Salin/tempelkan seluruh kode SystemVerilog dari file pwm.txt terlampir di bawah ini

Langkah 3: Membuat TDOA Ernie di Vivado

Membuat TDOA Ernie di Vivado
Membuat TDOA Ernie di Vivado
Membuat TDOA Ernie di Vivado
Membuat TDOA Ernie di Vivado

Langkah ini akan menghasilkan IP TDOA yang outputnya dapat dibaca melalui library AXI

  1. Buat blok AXI GPIO dengan cara klik kanan pada background, lalu klik "add IP"

    ketik "AXI_GPIO" ke dalam bilah pencarian, dan pilih paket ini

  2. Sesuaikan ulang IP dengan mengklik dua kali blok axi_gpio_1 baru

    1. di bawah GPIO, centang kotak "All Inputs", dan atur lebar GPIO ke 32. Bus ini akan menjadi perbedaan waktu kedatangan antara kedua sensor.
    2. di dalam blok axi_gpio_1, klik + di sebelah port GPIO untuk membuka gpio_io_i[31:0].
  3. Klik kanan pada port output axi_gpio_1 berlabel gpio_io_i[31:0], dan pilih "Make External"

    Klik pada input baru berlabel gpio_io_i[31:0], dan navigasikan ke tab "properties" di bilah alat kiri, dan ubah namanya menjadi TDOA_val

  4. Pilih Jalankan Otomatisasi Koneksi di spanduk hijau di atas diagram blok.

    Jika Anda menghubungkan port secara manual, alamat AXI mungkin tidak dikonfigurasi, yang menyebabkan masalah komunikasi di kemudian hari

  5. Di Flow Navigator Pane, pilih project manager -> Add Sources untuk membuat blok IP kustom baru

    1. pilih "tambah atau buat sumber desain", dan tekan berikutnya
    2. klik "buat file", ubah jenis file menjadi "SystemVerilog", dan ketik "tdoa" di kolom nama file, lalu klik OK
    3. klik Selesai
    4. abaikan jendela Define Module dengan menekan OK (kami akan menimpanya nanti)

      jika ditanya apakah Anda yakin, klik Ya

  6. Di tab sources, klik dua kali tdoa.sv (terletak di "Sumber Desain/design_1_wrapper")

    Salin/tempelkan seluruh kode SystemVerilog dari file tdoa.txt terlampir di bawah

Langkah 4: Membungkus dan Mengekspor Ernie

Membungkus dan Mengekspor Ernie
Membungkus dan Mengekspor Ernie
  1. Verifikasi bahwa diagram blok terlihat seperti tangkapan layar terlampir
  2. Di tab sources, klik kanan design_1.bd dan pilih "Create HDL Wrapper…"

    1. Pilih "Salin keluaran yang dihasilkan untuk memungkinkan pengeditan pengguna", lalu tekan "OK"
    2. Salin kode dari design_1_wrapper.txt terlampir di bawah ini, dan tempel di tempat kode design_1_wrapper.v yang dihasilkan
    3. simpan design_1_wrapper.v
  3. Di tab sources, klik dua kali file ZYBO_Master.xdc di bawah Constraints/constrs1

    1. Salin kode dari ZYBO_Master.txt terlampir di bawah, dan tempel di tempat kode ZYBO_Master.xdc yang ada
    2. Perhatikan pin input/output berikut:

      1. L15: Sinyal PWM untuk motor kiri (Pmod JA2 di Zybo)
      2. L14: Sinyal PWM untuk motor kanan (Pmod JA8 pada Zybo)
      3. V12: input gerbang dari sensor suara 1 (Pmod JE1 pada Zybo)
      4. K16: input gerbang dari sensor suara 2 (Pmod JE2 pada Zybo)
  4. Di Panel Navigator Aliran, Klik "Hasilkan Bitstream" di bawah Program dan Debug

    jika Anda pikir itu dilakukan segera, itu mungkin tidak. serius, buat teh

  5. Klik File->Ekspor->Hasilkan Perangkat Keras

    Centang "Sertakan Bitstream" dan tekan OK

  6. Klik File-> Luncurkan SDK

Langkah 5: Membangun Ernie

Membangun Ernie
Membangun Ernie
Membangun Ernie
Membangun Ernie
  1. Pasang servos ke sasis servo.
  2. Mengikuti lembar data untuk servos, lakukan hal berikut:

    1. sambungkan ground servo ke pin ground pada JA Pmod Zybo (lihat gambar pinout terlampir)
    2. sambungkan pin daya servos ke paket baterai AA

      Kami menemukan bahwa ketika servos terhubung ke Vdd Zybo, papan menarik terlalu banyak arus, menyebabkan papan terus-menerus mengatur ulang

    3. sambungkan pin sinyal input ke pin output Zybo yang sesuai (kiri: JA2, kanan: JA8)
  3. pasang sensor suara ke bagian depan sasis, menghadap ke depan, jaga agar tetap sedekat mungkin
  4. gunakan panduan hookup sensor suara untuk mengintegrasikan sensor suara
    1. sambungkan pin ground dan Vdd dari setiap sensor suara ke ground dan pin Vdd pada JE Pmod Zybo (lihat gambar pinout terlampir)
    2. sambungkan pin Gerbang sensor suara kiri ke JE1
    3. sambungkan pin Gerbang sensor suara kanan ke JE2

Langkah 6: BSP Pertama Ernie

BSP Pertama Ernie
BSP Pertama Ernie
BSP Pertama Ernie
BSP Pertama Ernie
  1. Buat BSP untuk menyelesaikan platform yang baru saja kita buat.

    Anda bisa mendapatkannya melalui File -> New -> Board Support Package

  2. Wizard akan muncul untuk membantu Anda membuat BSP.

    1. Kami ingin mengikat BSP ini dengan Platform kami yang baru saja kami buat, jadi
    2. Platform Perangkat Keras harus sejajar dengan yang baru saja kita buat (lihat img 1)
    3. CPU kami akan menjadi _0 CPU.
    4. Klik Selesai
    5. Pastikan untuk mencentang lwip141 untuk penyertaan dengan bsp Anda di jendela yang muncul (lihat img 2)

Langkah 7: Ernie GratisRTOS

  1. Unduh rilis FreeRTOS terbaru dari Sourceforge.

    Jika unduhan dapat dieksekusi, jalankan untuk mengekstrak file FreeRTOS ke direktori proyek Anda

  2. Biarkan SDK itu tetap terbuka, dan klik File -> Impor.
  3. Kami ingin mengklik Umum->Dari Ruang Kerja yang Ada, dan kemudian kami ingin menavigasi ke tempat kami mengunduh FreeRTOS.
  4. Demo kami akan berlokasi di FreeRTOS/Demo/CORTEX_A9_Zynq_ZC702. Setelah memilih folder ini, kita akan melihat tiga proyek muncul (kode kita (OS), itu BSP, dan Platform HW).

    HANYA Impor RTOSDemo ke ruang kerja Anda saat ini

  5. Pada semua proyek folder "biru" ubah BSP yang direferensikan

    1. Klik kanan dan pilih "Ubah BSP yang Direferensikan."
    2. Pilih BSP yang baru saja Anda buat untuk Zybo Anda
    3. Pengeditan Kode di folder SDK Blue Xilinx adalah proyek kode yang sebenarnya.

Langkah 8: Mengimpor Kode C Ernie

  1. Di direktori RTOSDemo/src, timpa main.c yang ada dengan file main.c terlampir di sini.
  2. Salin file main_sound.c ke dalam direktori RTOSDemo/src.

Langkah 9: Men-debug Ernie

  1. Pilih Jalankan -> Konfigurasi Debug
  2. Di panel kiri buat jalankan System Debugger baru
  3. Di tab Pengaturan Target,

    pilih "Reset Seluruh Sistem" sehingga keduanya dan ps7_init dipilih

  4. Sekarang pilih tab Aplikasi.

    1. Pilih “unduh aplikasi”
    2. Setel inti cortexa9_0 ke "berhenti di entri program"
    3. Klik Terapkan dan Debug.
  5. Verifikasi bahwa tidak ada kesalahan dalam proses debugging
  6. Mencermati robot, tekan tombol Lanjutkan hingga program berjalan tanpa mencapai titik henti apa pun
  7. Robot sekarang harus berbalik dan bergerak ke arah suara keras. Ya!

Langkah 10: Membuat Ernie Otonom

  1. Setelah proyek Anda siap dijalankan (Anda dapat menjalankannya tanpa masalah melalui debugger), Anda siap untuk memuatnya ke memori flash di papan Anda.
  2. Buat apa yang disebut proyek "boot loader tahap pertama" (FSBL) dan berisi semua instruksi yang diperlukan papan Anda untuk memuat file proyek Anda (aliran bit dan OS) saat startup.

    1. Pilih: File->New->Application Project dan jendela berikut akan muncul.
    2. Beri nama apa yang Anda inginkan (yaitu "FSBL")
    3. Pastikan platform perangkat keras adalah platform yang Anda gunakan
    4. Tekan berikutnya (Jangan tekan Selesai)
    5. Pilih template Zynq FSBL
    6. Klik selesai.
  3. Setelah proses pembuatan selesai, Anda akan tahu apakah semuanya berfungsi jika Anda melihat dua folder baru berikut di jendela Project Explorer.
  4. Buat Gambar Boot Sekarang Anda perlu membuat gambar Boot.

    1. Klik kanan pada folder proyek Anda (dalam hal ini milik saya disebut "RTOSDemo")
    2. Klik "Buat gambar Boot" dari tarik-turun
    3. Jika semuanya terhubung dengan benar, proyek akan mengetahui file apa yang dibutuhkan dan jendela berikut akan terlihat seperti yang Anda lihat di bawah (kuncinya adalah Anda memiliki 3 partisi di bawah bagian Boot image, bootloader, file bit Anda, dan file.elf proyek Anda).

      Jika tidak demikian, mungkin ada yang salah dengan penautan proyek Anda. Pastikan folder proyek ditautkan ke BSP masing-masing

    4. Klik tombol "Buat Gambar"
  5. Langkah terakhir yang harus dilakukan dalam perangkat lunak adalah sekarang mem-flash gambar yang Anda buat sebelumnya ke memori papan

    1. Pilih dari bilah alat utama SDK pilih Xilinx Tools->Program Flash Memory
    2. Pastikan bahwa platform perangkat keras yang benar dipilih dan jalur file gambar dengan benar menunjuk ke file. BIN yang dibuat pada langkah sebelumnya.
    3. Pilih "qspi single" dari jenis Flash
    4. Centang "Verifikasi setelah flash" untuk memastikan integritas tetapi tidak diperlukan
  6. Konfigurasi Papan Anda Terakhir, Anda perlu memastikan bahwa jumper mode pemrograman papan (JP5) diatur dengan benar untuk memilih boot dari qspi (yang berisi apa yang baru saja Anda flash) ketika BootROM dijalankan.
  7. Sekarang cukup hidupkan perangkat dan pastikan "Logic Configuration Done LED" (LED 10) menyala hijau.

Langkah 11: Membuat Ernie Lucu

  1. Bulu
  2. Banyak Bulu
  3. Mata yang besar!
  4. … pucuk topi

Direkomendasikan: