2015-11-28 15:15:34 +01:00
# RIOT VM
## About
This repository includes a [Vagrantfile ](https://github.com/RIOT-OS/RIOT/blob/master/Vagrantfile )
2016-10-13 15:03:06 +02:00
to download and control a pre-configured Linux virtual machine (VM) based on an Ubuntu 16.04 (64-bit) image that contains all necessary toolchains and dependencies to build and flash compatible devices with RIOT.
2016-09-19 12:09:46 +02:00
The advantage of using this VM is to have a reproducible, portable and even disposable environment
2016-09-06 14:53:40 +02:00
that can be used to develop for RIOT with decreased setup times and without the requirement of
2015-11-28 15:15:34 +01:00
making changes to the underlying host system.
## Requirements
Make sure your system satisfies the latest version of all following dependencies:
* [VirtualBox ](https://www.virtualbox.org/wiki/Downloads )
2016-09-06 16:49:22 +02:00
* [VirtualBox Extension Pack ](https://www.virtualbox.org/wiki/Downloads )
2015-11-28 15:15:34 +01:00
* [Vagrant ](https://www.vagrantup.com/downloads.html )
2016-10-13 15:03:06 +02:00
## Selecting a non-default VM (optional)
In case a non-default VM should be used, one can easily adapt the source for the vagrant box. This is done by the following command.
```
vagrant box add RIOT-VM < path to box >
```
## General usage
2016-09-06 14:53:40 +02:00
The following commands must be run from the RIOT root directory on the host system.
2015-11-28 15:15:34 +01:00
```
vagrant up
```
This will start up the virtual machine and download the Ubuntu image as well as all necessary toolchains.
```
vagrant ssh
```
This will logs you in to the VM as the vagrant user.
```
vagrant halt
```
This will shut down the VM gracefully.
```
vagrant destroy
```
2016-10-13 14:34:36 +02:00
This will reset your VM to the default state.
2015-11-28 15:15:34 +01:00
## Inside the VM
2016-09-06 14:53:40 +02:00
Once logged in to the VM via `vagrant ssh` you can find the RIOT root directory in your
working directory. This is a shared directory and stays synchronized with your RIOT directory
2015-11-28 15:15:34 +01:00
on the host system. All changes made will be mirrored from the host system to the guest system
and vice versa.
2016-09-06 14:53:40 +02:00
This feature allows you to conveniently develop code for RIOT with your preferred IDE on
your host system and use the VM for compiling, flashing devices and running the native port of RIOT.
2015-11-28 15:15:34 +01:00
## Additional Information
2017-03-28 20:21:42 +02:00
1. VirtualBox: For new boards it is necessary to add a usb filter (open VirtualBox, click on USB and add the new filter for your board).
* For Linux Guest Systems: For new boards it is necessary to add new udev rules in the Vagrant config (in `dist/tools/vagrant/udev_rules` ) so that Vagrant can capture the device.
2016-09-06 16:49:22 +02:00
The needed `vendor id` and `product id` can be obtained by running `vboxmanage list usbhost` .
* For Linux Host Systems: Additionally, in order to allow USB access from within the guest system, the host system user
must be a member of the `vboxusers` group (see [here ](https://www.virtualbox.org/manual/ch02.html#idm1051 )).
2016-09-20 13:31:06 +02:00
2. You can forward ports on the virtual machine with the following command:
```
config.vm.network "forwarded_port", guest: < port_1 > , host: < port_2 >
```