-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Getting started with Johnny Five and the Intel Galileo gen2
In this tutorial we will learn how to set up an Intel Galileo development board and get it to run a blinking LED loop in johnny-five.
NOTE: You will need a 16 or 32GB micro SD card for your Galileo to complete this tutorial
Before we get started we want to make sure that we have the latest firmware installed on our Galileo. This process can be different depending on the Operating System you are using on your development machine. Therefore Intel provides detailed instructions for this process for each supported OS.
NOTE: If you get the error message
Target Firmware Version Query Failed
it usually means that the Galileo is not available on the selected serial (USB) port in the IDE. Sometimes it may happen if there is a sketch running on the board. Try rebooting the board and your computer, then connect the USB cable and re-select the correct serial port in the IDE.
Before we can get johnny-five to run on the board, we first need to download the Yocto Linux image for the Galileo and install it on our micro SD card; you can download the latest image here
Once the image is downloaded we will need to extract it and install it on our micro SD card. This process once again can be different depending on your OS.
Note: If you are on Windows , you can use PuTTY to make ssh connections.
Now that we have Yocto Linux Installed on the micro SD card and have booted our board with it, it's time to get access to it.
There are a few options when it comes to getting terminal access to the Galileo. But by far the easiest way is just to plug in an ethernet cable and access it via SSH.
To do this we first need to obtain the IP address of the Galileo. This can be found using applications like fing or Bonjour Browser.
Now that we have our IP, all we need to do is type
We should now have a root terminal session on the Galileo
Tip: To exit the ssh session and get back to your local terminal type
exit
It's always a good idea to be sure that the OS on the board has it's date set correctly, especially when using npm. You can very easily get the date from another system on your network by typing:
date -u `ssh [email protected] date -u '+%m%d%H%M%Y.%S'`
where x.x.x.x is a system with the correct date
NOTE: If you don't have access to such a machine , you can also follow this guide on setting the date for the Galileo.
The Yocto Linux image already has node installed so all that's left to do is write some Johnny-Five code, push it to the board and then run it.
We will do this in a folder on our local machine and then copy it to the Galileo to run. You can either set up the Galileo with an LED on pin 13 or you can just watch the built in LED labeled L
right next to the USB port on the board. This example is the same as the standard Johnny-Five blink example, except it specifies the use of the galileo-io
IO-Plugin so it will run directly on the board.
Let's create an index.js with the following code:
var five = require("johnny-five");
var Galileo = require("galileo-io");
var board = new five.Board({
io: new Galileo()
});
board.on("ready", function() {
var led = new five.Led(13);
led.blink(500);
});
And now we can copy index.js over to the board using scp:
scp index.js [email protected]:~
Now ssh back into the board and let's run our code.
First we we install our dependencies:
npm install johnny-five galileo-io
Then we run our program with node index.js
.
We should now have a blinking light on pin 13!