Kubos FAQs and Troubleshooting Tips

FAQs

How do I contact y’all?

Our community Slack: slack.kubos.co

Our email: info@kubos.co

How do I check if I’m using the latest version of the Kubos Vagrant image?

From your host machine, issue the vagrant box outdated command.

How do I get the latest version of the Kubos Vagrant image?

From your host machine, issue the vagrant box update command.

Warning

This will overwrite all files in your existing image

How do I see the debug output of my board?

MSP430

minicom msp430

STM32F407

Connect an FTDI cable to your board’s debug UART port. By default:

  • Yellow wire (TX) –> pin PC6.
  • Orange wire (RX) –> pin PC7.

Then use minicom kubos to start a serial connection session.

ISIS-OBC

minicom kubos

How do I check what version of KubOS Linux I’m running?

Issue the uname -r command on the target board to display the kernel information. The KubOS Linux version will be the n.n.n number after “KubOS”.

uname -r
4.4.23-KubOS-1.0.0

Troubleshooting

Kubos SDK

I’ve tried other steps here, but my Kubos Vagrant image is still behaving weirdly.

Try logging out and restarting the VM using the vagrant reload command.

I got some weird errors while running a kubos command (kubos build, kubos target, etc)

Run kubos update -a to ensure that you’re using the latest version of the Kubos SDK

“error: could not install target {target} at * for {target}”

error: could not install target {target} at * for {target}
error: The targets registry does not provide a version of "{target}"

Run kubos link -a to re-establish the required module links for your project

“error: No module.json file.”

error: No module.json file.
error: The current directory does not contain a valid module.

You are not currently in a valid Kubos project directory. Alternatively, your project’s module.json file has somehow gotten deleted.

“ERROR: the gcc program “arm-linux-gcc” could not be found”

The iOBC toolchain is not currently in your path. Run this command to add it:

$ export PATH=$PATH:/usr/bin/iobc_toolchain/usr/bin

I can’t build my project. I keep getting “Permission denied” errors

If you copied your project from another location, it’s possible that the files are set up with root permissions only. Change the project file permissions to allow the local vagrant user to have access.

sudo chown vagrant:vagrant . -R

KubOS RT

My kubos flash command is failing and saying that it can’t find my board.

  • Make sure the board is connected to your computer
  • Make sure the board is powered
  • Verify that no other instances of Kubos Vagrant are running using the vagrant global-status command from your host machine

My kubos flash command failed or appeared to be hung for no obvious reason

The MSP430 is fickle. Retry the flash command. If it continues to fail more than a few times, there might be another problem.

I flashed my program, but I’m not seeing any output

Make sure that you are supposed to be seeing something. A loop that prints a message once a second can be helpful for this purpose.

Use kubos debug to start a GDB session and debug your problem.

MSP430

It’s possible that MSP430 has run out of RAM. Try removing some threads from your program.

STM32F4

Make sure that you are connected to the defined debug UART port.

Run the kubos config command to see which port is currently configured. The hardware.console settings define this connection.

KubOS Linux

I transferred a script, but it won’t run

kubos flash preserves the file permissions of everything you transfer. Check that your file has the appropriate execute permissions turned on.

Flash Troubleshooting

Flashing a file to the board can fail for various reasons. Sometimes simply reattempting the command can correct the problem.

If retrying doesn’t work, here is a list of some of the errors you might see after running the kubos flash command and the recovery actions you can take:

“No compatible FTDI device found”
  • Check that the iOBC is turned on and connected to your computer
  • Check that no other vagrant images are running. Only one VM can have control of the USB, so it may be that another instance currently has control of the device. You can shutdown a vagrant image with the command vagrant halt
  • Verify that the USB is showing up within the vagrant environment with the lsusb command. You should see an FTDI device
  • Verify that the USB has been mapped to a linux device. Issue the command ls /dev. You should see a /dev/ttyUSB* device. If you don’t, try rebooting your vagrant image (vagrant halt, vagrant up)
“Transfer Failed: Connection Failed”

The SDK was unable to connect to the iOBC

  • Verify that the USB has been mapped to a linux device. Issue the command ls /dev. You should see a /dev/ttyUSB* device. If you don’t, try rebooting your vagrant image (vagrant halt, vagrant up)
  • If this error occurs after the transfer process has started, then the SDK likely lost connection to the iOBC. Verify that the board is still correctly connected and powered and try the flash command again.
“Transfer Failed: Invalid Password”

The SDK was unable to log into the iOBC. Verify that the password is correctly defined in your config.json file by issuing the kubos config command.

System appears to have hung
  • If for some reason file transfer fails, it can take a couple minutes for the connection to time out and return control.
  • If you’ve waited a couple minutes and the system still appears hung, please let us know so that we can open a bug report.
My flash failed for some other reason

It’s possible that the transfer timed out. Check the build/{target}/flash.log file in your project for more information about why the flash failed.

If you were trying to flash an upgrade file, simply re-enter the kubos flash command to resume the transfer.