2014-11-29 07:34:42 +08:00
# Edison
2014-09-19 03:45:54 +08:00
2014-11-29 07:34:42 +08:00
The Intel Edison is a wifi and Bluetooth® enabled devolopment platform for the Internet of Things. It packs a robust set of features into its small size and supports a broad spectrum of I/O and software support.
2014-09-19 03:45:54 +08:00
2014-11-29 07:34:42 +08:00
For more info about the Edison platform click [here ](http://www.intel.com/content/www/us/en/do-it-yourself/edison.html ).
2014-09-19 03:45:54 +08:00
2015-07-11 03:48:02 +08:00
## How to Install (using Go 1.5+)
2014-09-19 03:45:54 +08:00
2015-07-11 03:48:02 +08:00
Install Go from source or use an [official distribution ](https://golang.org/dl/ ).
2014-09-19 03:45:54 +08:00
2015-07-11 03:48:02 +08:00
Then you must install the appropriate Go packages
2014-09-19 03:45:54 +08:00
2015-07-11 03:48:02 +08:00
## Setting up your Intel Edison
2014-09-19 03:45:54 +08:00
2016-08-26 00:20:07 +08:00
Everything you need to get started with the Edison is in the Intel Getting Started Guide:
https://software.intel.com/en-us/iot/library/edison-getting-started
2015-11-05 02:32:34 +08:00
Don't forget to configure your Edison's wifi connection and flash your Edison with the latest firmware image!
2014-09-19 03:45:54 +08:00
2016-08-26 00:20:07 +08:00
The recommended way to connect to your device is via wifi, for that follow the directions here:
2014-09-19 03:45:54 +08:00
2016-08-26 00:20:07 +08:00
https://software.intel.com/en-us/connecting-your-intel-edison-board-using-wifi
2014-09-19 03:45:54 +08:00
2016-08-26 00:20:07 +08:00
If you don't have a wifi network available, the Intel documentation explains how to use another connection type, but note that this guide assumes you are using wifi connection.
2015-07-11 03:48:02 +08:00
2016-08-26 00:20:07 +08:00
You can obtain the IP address of your Edison, by running the floowing command:
2014-11-29 07:34:42 +08:00
2015-07-11 03:48:02 +08:00
```
2016-08-26 00:20:07 +08:00
ip addr show | grep inet
2014-09-19 03:45:54 +08:00
```
2016-08-26 00:20:07 +08:00
Don't forget to setup the a password for the device otherwise you won't be able to connect using SSH. From within the screen session, run the following command:
2014-11-29 07:34:42 +08:00
2015-07-11 03:48:02 +08:00
```
configure_edison --password
2014-09-19 03:45:54 +08:00
```
2015-07-11 03:48:02 +08:00
Note that you MUST setup a password otherwise SSH won't be enabled. If
later on you aren't able to scp to the device, try to reset the
password. This password will obviously be needed next time you connect to
your device.
2014-11-29 07:34:42 +08:00
2014-09-19 03:45:54 +08:00
2015-07-11 03:48:02 +08:00
## Example program
Save the following code into a file called `main.go` .
2014-09-19 03:45:54 +08:00
```go
package main
import (
"time"
"github.com/hybridgroup/gobot"
"github.com/hybridgroup/gobot/platforms/gpio"
"github.com/hybridgroup/gobot/platforms/intel-iot/edison"
)
func main() {
gbot := gobot.NewGobot()
e := edison.NewEdisonAdaptor("edison")
led := gpio.NewLedDriver(e, "led", "13")
work := func() {
gobot.Every(1*time.Second, func() {
led.Toggle()
})
}
robot := gobot.NewRobot("blinkBot",
[]gobot.Connection{e},
[]gobot.Device{led},
work,
)
gbot.AddRobot(robot)
gbot.Start()
}
```
2014-11-29 07:34:42 +08:00
2015-07-11 03:48:02 +08:00
You can read the [full API documentation online ](http://godoc.org/github.com/hybridgroup/gobot ).
#### Cross compiling for the Intel Edison
Compile your Gobot program run the following command using the command
line from the directory where you have your `main.go` file:
```bash
$ GOARCH=386 GOOS=linux go build .
```
Then you can simply upload your program over the network from your host computer to the Edison
```bash
$ scp main root@< IP of your device > :/home/root/blink
```
and execute it on your Edison (use screen to connect, see the Intel
setup steps if you don't recall how to connect)
```bash
$ ./blink
```
2016-08-26 00:20:07 +08:00
At this point you should see the onboard LED blinking. Press control + c
2015-07-11 03:48:02 +08:00
to exit.
To update the program after you made a change, you will need to scp it
over once again and start it from the command line (via screen).
2016-08-26 00:20:07 +08:00
## License
Copyright (c) 2014-2016 The Hybrid Group. Licensed under the Apache 2.0 license.