Ini adalah catatan uji coba pertama dari Launchpad produksi Texas Instruments yaitu MSP-EXP432P401R. Ini papan ketiga yang saya miliki dari TI yang sekalipun terdapat beberapa kesamaan dengan dua papan sistem sebelumnya tetapi juga memiliki perbedaan yang sekilas akan membingungkan saat perkenalan untuk pertama kali. Papan MSP-EXP432P401R ini berasal dari rumpun keluarga MSP432, jadi berdasarkan “silsilah” keluarga, papan ini lebih dekat pada papan MSP-EXP430G2 yang berasal dari keluarga MSP430. Tetapi berbeda dengan MSP430 yang merupakan keluarga mikrokontroler 16-bit, MSP432 adalah keluarga mikrokontroler 32-bit. Selain itu jika MSP430 dibangun berdasarkan pada arsitektur asli rancangan TI sendiri, MSP432 dibangun berdasarkan arsitektur ARM.
Papan Launchpad MSP-EXP432P401R berintikan mirkokontroler MSP432P401R. Menurut TI prosesor inti dari mikrokontroler ini berdasar pada arsitektur ARM;
Jadi perihal prosesor inti, papan launchpad ini sebenarnya lebih dekat kepada Tiva C, yaitu papan EK-TM4C123GXL . Mikrokontroler pada kedua papan itu berbasis pada arsitektur ARM Cortex-M4F. Tambahan huruf F menandakan adanya fasilitas Floating-Point unit. Situs letsmakerobots.com memuat artikel tentang perbandingan antara dua mikrokontroler ini:
Berbeda dengan catatan sebelumnya saat uji coba led blinking untuk sistem MSP430 dan Tiva C, pada catatan ini pengungkapan akan mendekati urutan kronologis.
Catatan sistem GNU/Linux:
$ uname -a
Linux xxx 3.16.0-38-generic #52~14.04.1-Ubuntu SMP Fri May 8 09:43:57 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux
Sebagian dari $ lsusb
Bus 003 Device 027: ID 0451:bef3 Texas Instruments, Inc.
Sebagian dari $ dmesg
[37080.370024] usb 3-1: new full-speed USB device number 27 using xhci_hcd
[37080.499458] usb 3-1: New USB device found, idVendor=0451, idProduct=bef3
[37080.499466] usb 3-1: New USB device strings: Mfr=1, Product=2, SerialNumber=3
[37080.499470] usb 3-1: Product: XDS110 (02.03.00.00) with CMSIS-DAP
[37080.499474] usb 3-1: Manufacturer: Texas Instruments
[37080.499477] usb 3-1: SerialNumber: 00000000
[37080.500199] cdc_acm 3-1:1.0: This device cannot do calls on its own. It is not a modem.
[37080.500230] cdc_acm 3-1:1.0: ttyACM0: USB ACM device
[37080.500924] cdc_acm 3-1:1.3: This device cannot do calls on its own. It is not a modem.
[37080.500955] cdc_acm 3-1:1.3: ttyACM1: USB ACM device
[37080.502418] hid-generic 0003:0451:BEF3.0014: hiddev0,hidraw1: USB HID v1.11 Device [Texas Instruments XDS110 (02.03.00.00) with CMSIS-DAP] on usb-0000:00:14.0-1/input5
Potensi masalah (tantangan):
Pertama kali saya mencoba untuk menguji papan sistem ini dengan menggunakan Energia 0101E0017, tetapi gagal dan mendapatkan pesan kesalahan sebagai berikut:
[intense_emphasis tag=”span”]
Connecting…
fatal: CS_DAP_0: Error connecting to the target: (Error -260 @ 0x0) An attempt to connect to the XDS110 failed. The cause may be one or more of: invalid firmware update, invalid XDS110 serial number, or faulty USB connection. The firmware and serial number may be updated using the xdsdfu utility found in the …/ccs_base/common/uscif/xds110 directory of your installation. View the ReadMe.txt file there for instructions. (Emulation package 6.0.14.5)
Failed: Operation was aborted
Kemudian saya mencoba peruntungan dengan mempergunakan CCS Cloud dari Texas Instruments. Selain dengan menggunakan Energia, pengguna (programmer) dapat melakukan pemrograman dengan CCS (Code Composer Studio). TI (Texas Instruments) menyediakan dua pilihan penggunaan CCS; CCS berbasis web (CCS Cloud) dan CCS pada desktop.
image credit: ti.com
Sayangnya sekalipun saya berhasil melakukan instalasi plug-in untuk browser Firefox, saya mengalami masalah saat perlu melakukan instalasi TI Cloud Agent. Aplikasi tersebut memerlukan libusb-1.0.so. Seperti pada panduan, permasalah seperti ini bisa dicoba diselesaikan dengan melakukan instalasi:
[intense_emphasis tag=”span”]sudo apt-get install lib32stdc++6 libc6-i386 libusb-1.0-0-dev:i386
[/intense_emphasis]Jika saat instalasi terjadi pesan kesalahan berikut:
Reading package lists… Error!
E: Encountered a section with no Package: header
maka dapat diperbaiki dengan perintah:
sudo rm /var/lib/apt/lists/* -vf
sudo apt-get update
Cara lain untuk mendapatkan file libusb-1.0.so adalah dengan mencari file tersebut di dalam sistem. Karena mungkin saja file tersebut sebenarnya sudah ada di dalam sistem. Misalnya untuk sistem saya:
[intense_emphasis tag=”span”]$ locate libusb-1.0.so
/home/sunuXx/.arduino15/packages/arduino/tools/openocd/0.9.0-arduino/lib/libusb-1.0.so
/home/sunuXx/.arduino15/packages/arduino/tools/openocd/0.9.0-arduino/lib/libusb-1.0.so.0
/home/sunuXx/.arduino15/packages/arduino/tools/openocd/0.9.0-arduino/lib/libusb-1.0.so.0.1.0
/home/sunuXx/AC6SyWbSTM32/plugins/fr.ac6.mcu.externaltools.openocd.linux64_1.10.0.201607251855/tools/openocd/lib/libusb-1.0.so
/home/sunuXx/AC6SyWbSTM32/plugins/fr.ac6.mcu.externaltools.openocd.linux64_1.10.0.201607251855/tools/openocd/lib/libusb-1.0.so.0
/home/sunuXx/AC6SyWbSTM32/plugins/fr.ac6.mcu.externaltools.openocd.linux64_1.10.0.201607251855/tools/openocd/lib/libusb-1.0.so.0.1.0
/home/sunuXx/AC6SyWbSTM32/plugins/fr.ac6.mcu.externaltools.openocd.linux64_1.8.0.201603291120/tools/openocd/lib/libusb-1.0.so
/home/sunuXx/AC6SyWbSTM32/plugins/fr.ac6.mcu.externaltools.openocd.linux64_1.8.0.201603291120/tools/openocd/lib/libusb-1.0.so.0
/home/sunuXx/AC6SyWbSTM32/plugins/fr.ac6.mcu.externaltools.openocd.linux64_1.8.0.201603291120/tools/openocd/lib/libusb-1.0.so.0.1.0
/home/sunuXx/eclipseArduino/arduinoPlugin/tools/arduino/avrdude/6.0.1-arduino5/lib/libusb-1.0.so
/home/sunuXx/eclipseArduino/arduinoPlugin/tools/arduino/avrdude/6.0.1-arduino5/lib/libusb-1.0.so.0
/home/sunuXx/eclipseArduino/arduinoPlugin/tools/arduino/avrdude/6.0.1-arduino5/lib/libusb-1.0.so.0.1.0
/lib/i386-linux-gnu/libusb-1.0.so.0
/lib/i386-linux-gnu/libusb-1.0.so.0.1.0
/lib/x86_64-linux-gnu/libusb-1.0.so.0
/lib/x86_64-linux-gnu/libusb-1.0.so.0.1.0
/usr/lib/x86_64-linux-gnu/libusb-1.0.so
[/intense_emphasis]
Jika file tersedia maka bisa diberikan perintah berikut untuk soft link;
[intense_emphasis tag=”span”]
$ cd /usr/lib
/usr/lib $ sudo ln /home/sunuXx/.arduino15/packages/arduino/tools/openocd/0.9.0-arduino/lib/libusb-1.0.so libusb-1.0.so
[/intense_emphasis]
Kembali ke permasalahan dengan Energia, tampaknya saya sedang beruntung. Energia telah merilis Energia 18 aka Energia 1.6.10E18 yang merupakan pembaharuan yang membawa perbedaan yang cukup signifikan dari versi terdahulu. Versi terbaru ini telah mendekati versi IDE yang baru dari Arduino. Misalnya sudah terdapat fasilitas line numbers dan code folding. Pengaturan pustaka dan pengaturan papan (board management) juga berubah. Sayangnya saya mendapatkan pesan adanya invalid library pada versi ini. Sebagai solusinya untuk sementara maka pustaka SPI dan WIRE saya hapus dari .energia15/packages/energia/hardware/msp432/1.0.15/libraries/. Keduanya masih saya biarkan di folder Energia 17.
Kemudian setelah membaca beberapa pengalaman orang lain sepertinya masalah yang pertama kali saya temui sebagaimana yang telah saya ungkapkan di awal catatan ini adalah masalah yang berkaitan dengan DSlite. Pengalaman para pendahulu dapat dibaca dan dipelajari di sumber-sumber berikut:
Upaya penyelesaian masalah yang saya tempuh adalah dengan melakukan copy DSlite dari Energia 18 ke Energia 17.
~/energia18 $ reset;find . -iname “*DSl*”
./hardware/tools/DSLite
./hardware/tools/DSLite/DebugServer/bin/DSLite
./hardware/tools/DSLite/DebugServer/scripts/readAtBp.dsls
./hardware/tools/DSLite/DebugServer/scripts/load.dsls
./hardware/tools/DSLite/DebugServer/scripts/flash.dsls
./hardware/tools/DSLite/DebugServer/scripts/help.dsls
./hardware/tools/DSLite/DebugServer/scripts/runWithCIO.dsls
./hardware/tools/DSLite/common/uscif/libxdslocal.so
Sedangkan pada Energia 17
~/energia0101E0017 $ reset;find . -iname “*DSlite*”
./tools/common/DSLite
./tools/common/DSLite/DebugServer/bin/DSLite
Pada Energia 18, file DSlite akan memberikan keterangan sebagai berikut:
~/energia18 $ ./hardware/tools/DSLite/DebugServer/bin/DSLite help
DSLite version 6.2.1.1595
DSLite [operation] [Args…]
load
Loads the specified file and exits, leaving the
target running
runWithCIO
Loads the specified file and runs the target,
printing stdout to the console. Exits when the
application returns from main
flash
Performs multiple flash-based operations as
specified on the command line including
erasing, loading, verifying, and device-
specific flash operations
readAtBp
Loads the specified file and runs the target to
a specified location. Variables can be written
before the run, and others echoed to the
console after
help
Prints this message
Gambar 1. Uji pemgrograman dengan menggunakan Energia
Gambar 2. Uji pemrograman online dengan CCS Cloud di Firefox
Gambar 3. Uji online debuging (stepping) menggunakan CCS Cloud
Gambar 4. Uji pengaturan (penggantian) warna LED secara online
Demikianlah catatan tinkering kali ini. Di lain kesempatan saya upayakan catatan untuk compiler, juga IDE lain. Juga uji coba pada sistem Microsoft Windows.