Skip to content
Tutorial emka
Menu
  • Home
  • Debian Linux
  • Ubuntu Linux
  • Red Hat Linux
Menu

Cara Membuat OTA Update (Over The Air Update) di Raspberry Pi W

Posted on March 13, 2024

Pada tutorial kali ini kita akan mengimplementasikan bootloader untuk Raspberry Pi Pico W yang memungkinkan pengunggahan kode program melalui WiFi (“Over The Air”). Cara paling mudah untuk menggunakannya adalah dengan menyertakan repositori ini sebagai submodule dalam aplikasi yang ingin kita dapatkan pembaruan melalui WiFi.

Contoh proyek menggunakan picowota dapat ditemukan di https://github.com/usedbytes/picowota_blink

Cara termudah untuk membangun picowota itu sendiri adalah:

mkdir build

cd build

export PICOWOTA_WIFI_SSID=picowota

export PICOWOTA_WIFI_PASS=password

export PICOWOTA_WIFI_AP=1

cmake -DPICO_BOARD=pico_w -DPICO_SDK_PATH=/path/ke/pico-sdk ../

make

Uji coba library PicoWOTA

Pertama, tambahkan picowota sebagai submodule ke proyek kita:

git submodule add https://github.com/usedbytes/picowota

git submodule update –init picowota

git commit -m “Tambahkan submodule picowota”

Kemudian, modifikasi CMakeLists.txt proyek kita untuk menyertakan direktori picowota:

add_subdirectory(picowota)

picowota dapat terhubung ke jaringan WiFi yang ada (secara default) atau membuat satu, dalam kedua kasus dengan SSID dan kata sandi yang diberikan.

kita dapat menyediakan informasi berikut sebagai variabel lingkungan atau mengaturnya sebagai variabel CMake:

PICOWOTA_WIFI_SSID # SSID jaringan WiFi

PICOWOTA_WIFI_PASS # Kata sandi jaringan WiFi

PICOWOTA_WIFI_AP # Opsional; 0 = terhubung ke jaringan, 1 = membuatnya sendiri

Selanjutnya, kita dapat membangun binary aplikasi mandiri (cocok untuk pembaruan melalui picowota ketika sudah ada di Pico) atau binary gabungan yang berisi bootloader dan aplikasi (cocok untuk flashing pertama kali):

picowota_build_stkitalone(nama_executable_kita)

picowota_build_combined(nama_executable_kita)

Mengunggah Kode Melalui picowota

Setelah picowota bootloader terinstal di Pico kita, kita dapat menggunakan alat https://github.com/usedbytes/serial-flash untuk mengunggah kode ke dalamnya.

Selama Pico berada dalam bootloader picowota (yaitu karena tidak ada kode aplikasi yang valid terunggah, atau aplikasi kita memanggil picowota_reboot(true);), kita dapat mengunggah file .elf aplikasi yang dibangun oleh picowota_build_stkitalone():

serial-flash tcp:192.168.1.123:4242 nama_executable_kita.elf

Setelah mengunggah kode, jika berhasil, Pico akan melompat ke aplikasi yang baru diunggah.

Cara Kerjanya

Ini berasal dari bootloader Pico non-W saya, https://github.com/usedbytes/rp2040-serial-bootloader, yang saya tulis dalam sebuah blog post: https://blog.usedbytes.com/2021/12/pico-serial-bootloader/

Kode bootloader berusaha menghindari “brick” dengan menyimpan CRC dari kode aplikasi yang diunggah. Jika CRC tidak cocok, maka aplikasi tidak akan dijalankan dan Pico akan tetap berada dalam mode bootloader picowota. Ini seharusnya membuatnya cukup kuat terhadap kesalahan dalam transfer, dll.

Recent Posts

  • How to Disable AI Features in Firefox 148
  • Git 2.53: What’s New?
  • Linux From Scratch Ditches Old System V init
  • How to Maintained the SSD with TRIM
  • What is CVE-2024-21009? Microsoft Office Security Serious Bug
  • Windows 11 Shutdown Problems: Why Your PC Won’t Turn Off (and What Microsoft’s Doing)
  • What is the Steam Overlay Error?
  • Why Your Computer Thinks Winaero Tweaker is Bad (and Why It’s Probably Wrong!)
  • What is Origami Linux? A Super-Safe, Unchangeable Computer System!
  • Why Does OneNote Freeze? Easy Fixes for Typing & Drawing Problems!
  • What is Protected File System (PFS) in Windows 11?
  • Linux News Roundup February 2026
  • How to Install JellyFin Media Server on Samsung TV with TizenOS
  • Why OneNote Clears Your Notes
  • AMD NPU Monitoring on Linux: A Beginner’s Guide to AI Chip Tracking!
  • How to Fix AMD Adrenalin’s Game Detection Issues on Windows
  • Greg Kroah-Hartman Wins Multiple Award at European Open Source Awards!
  • What are Microsoft Copilot Reminders?
  • What’s New in Plasma 6.7? Quick Notification History Clear-Up!
  • Awesome Alternatives to Microsoft Defender Application Guard (MDAG)
  • How tto Enable DLSS 4 & 5 for Your GPU
  • Backlinks: Why They’re Super Important for Your Website!
  • Gnome’s Smart Windows: Tiling Shell 17.3 Makes Organizing Your Screen Easier!
  • How to Replace Notepad with Microsoft Edit
  • What’s New in Shotcut 26.1?
  • Kenapa No Token Gagal Terus? Begini Cara Memasukkan!
  • Kode Bank Terbaru 2026: Kenali Arti dan Fungsinya! Jangan Sampai Salah Transfer
  • Bahayanya ‘Kumpulan Grup Asupan Malam Hijab Lokal Bocil Indo’, Waspada Phising!
  • Kenapa Voucher Axis Gagal Terus? Ini Dia Penyebab & Cara Mengatasinya!
  • Kenapa Meta AI Nggak Muncul di WhatsApp Padahal Udah Update?
  • Cara Membuat Podcast dari PDF dengan NotebookLlama dan Groq
  • Tutorial Membuat Sistem Automatic Content Recognition (ACR) untuk Deteksi Logo
  • Apa itu Google Code Wiki?
  • Cara Membuat Agen AI Otomatis untuk Laporan ESG dengan Python dan LangChain
  • Cara Membuat Pipeline RAG dengan Framework AutoRAG
  • Apa itu Spear-Phishing via npm? Ini Pengertian dan Cara Kerjanya yang Makin Licin
  • Apa Itu Predator Spyware? Ini Pengertian dan Kontroversi Penghapusan Sanksinya
  • Mengenal Apa itu TONESHELL: Backdoor Berbahaya dari Kelompok Mustang Panda
  • Siapa itu Kelompok Hacker Silver Fox?
  • Apa itu CVE-2025-52691 SmarterMail? Celah Keamanan Paling Berbahaya Tahun 2025
©2026 Tutorial emka | Design: Newspaperly WordPress Theme