This is intended to be a quick guide to creating a new KubOS RT project on top of the Kubos framework.
Prerequisites
Create an instance of the Kubos Vagrant box
$ vagrant init kubostech/kubos-dev
This will create a Vagrantfile in your current directory. This Vagrantfile contains information about the configuration of your kubos-dev Vagrant box.
It is strongly recommended that you create your kubos projects in a directory that is shared with your box from your host, rather than a directory that is only available inside your box. If the directory is located on your host your projects will be protected in the event your box is ever damaged or destroyed.
To mount a specific directory from your host, open the Vagrantfile that was in the kubos-vagrant directory you clone in the above step and look for the following lines:
# Share an additional folder to the guest VM. The first argument is # the path on the host to the actual folder. The second argument is # the path on the guest to mount the folder. And the optional third # argument is a set of non-required options. # config.vm.synced_folder "../data", "/vagrant_data"
Uncomment the last line in this block and change the paths to match your host directory and a desired mount point in the box.
Note - The path in the box must be an absolute path. In the kubos-dev vagrant box the home directory is /home/vagrant
After a volume is mounted into the box all of the data from the host path will be available at the path specified for the box. In the above example the host path (../data
) would be exposed at /vagrant_data
inside of the box. This allows you to use the text editor of your choosing to edit the project files from your host machine at the host directory path.
Following the example if you create a kubos project in the box at /vagrant_data/kubos_project
it would be accessible on your host at the relative path ../data/kubos_project
from your Vagrantfile
For more information on mounting volumes see the following guide
Start the box
$ vagrant up
SSH into your box
$ vagrant ssh
At this point you will have a new terminal prompt inside your kubos-dev box.
Creating your project
The simplest way to create a new KubOS RT project is by using the Kubos CLI. The kubos init
command takes a project name and creates the project files & folder.
Note: Inside of the build system there are several reserved words, a project cannot be named any of these words. The most common of these are test
, source
and include
.
$ kubos init myproject
The init
command creates a new directory with the kubos-rt-example included so you can get started right away.
We have also created several different example Kubos projects which can be used as starting points.
- Example showing basic freertos tasks and csp
- Example showing the i2c HAL and sensors
- Example showing the spi HAL and sensors
- Example showing the sensor interface
- Example showing csp over uart
- Example KubOS Linux project
If you would prefer to use one of our other examples as a starting point all you need to do is run:
$ git clone https://github.com/kubostech/kubos-spi-example myproject
It is unnecessary to run the kubos init
command in this case.
If you created your project from a clone there's some additional setup needed to satisfy all of the projects dependencies for Kubos source modules.
Running the following commands will clone a project and link all of the Kubos modules needed to build it:
$ git clone <url of the project you want> $ cd <project name> $ kubos link --all
Choosing a target
Once you have created a project you will need to select a target. The target defines which hardware your project will run on and how the peripherals are configured.
You can see a list of available projects by running the following command:
$ kubos target --list
For this example we will set the msp430f5529 target:
$ kubos target msp430f5529-gcc
Building and flashing
Now that the target is set you can begin building. This command will build the current project:
$ kubos build
You should see the Build Succeeded
message! You are now ready to load your software on some hardware. Connect your hardware to your computer and run the following flash command:
$ kubos flash
Note - You may need to run this command with sudo
if you run into a permissions error.
$ sudo kubos flash
Congratulations! You have just created a basic Kubos project, built it and (hopefully) flashed it onto some hardware.