Linux
This page has information on how to install and use TinyGo on Ubuntu, as well as other Linux distributions.
If you want to use TinyGo to compile your own or sample code, you can install the release version directly on your machine by following the “Quick Install” instructions below.
If you wish to build TinyGo from source, for example if you intend to contribute to the project, please take a look here.
Quick Install
Ubuntu/Debian
You must have Go already installed on your machine in order to install TinyGo. We recommend Go v1.18 or above.
If you are using Ubuntu or another Debian based Linux on an Intel processor, download the DEB file from Github and install it using the following commands:
wget https://github.com/tinygo-org/tinygo/releases/download/v0.27.0/tinygo_0.27.0_amd64.deb
sudo dpkg -i tinygo_0.27.0_amd64.deb
If you are on a Raspberry Pi or other ARM-based Linux computer, you should use this command instead:
wget https://github.com/tinygo-org/tinygo/releases/download/v0.27.0/tinygo_0.27.0_armhf.deb
sudo dpkg -i tinygo_0.27.0_armhf.deb
You will need to ensure that the path to the tinygo
executable file is in your PATH
variable.
export PATH=$PATH:/usr/local/bin
You can test that the installation is working properly by running this code which should display the version number:
$ tinygo version
tinygo version 0.27.0 linux/amd64 (using go version go1.20 and LLVM version 15.0.0)
If you are on a 64 bit ARM OS, and running tinygo fails with “no such file or directory”, you may need to install the 32 bit C++ runtime library, e.g.:
sudo apt install libstdc++6:armhf
If you are only interested in compiling TinyGo code for WebAssembly then you are now done with the installation.
Otherwise, please continue with the installation of the additional requirements for your desired microcontroller.
Additional Requirements for Microcontrollers on Ubuntu/Debian
Some boards require a special flashing tool for that particular chip, like openocd
or nrfjprog
. See the documentation page for your board as listed here to see which flashing tool is required for your target board.
If you are only interested in compiling TinyGo code for ARM microcontrollers then you are now done with the installation.
AVR (e.g. Arduino Uno)
To flash TinyGo programs for AVR based processors such as the original Arduino Uno you must install avrdude
:
sudo apt-get install avrdude
This should allow you to flash TinyGo programs on an Arduino Uno or other supported AVR-based board.
You are now done with the TinyGo “Quick Install” for Ubuntu/Debian
Fedora Linux
There is an Fedora 30 package available for the latest TinyGo release. To install it:
sudo dnf install tinygo
If you are only interested in compiling TinyGo code for WebAssembly then you are now done with the installation.
Otherwise, please continue with the installation of the additional requirements for your desired microcontroller
Additional Requirements for Microcontrollers on Fedora Linux
There are some additional requirements to compile TinyGo programs that can run on microcontrollers.
AVR (e.g. Arduino Uno)
To compile and flash TinyGo programs for AVR based processors such as the original Arduino Uno you must install avrdude:
sudo dnf install avrdude
This should allow you to flash TinyGo programs on an Arduino or other supported AVR-based board.
You are now done with the TinyGo “Quick Install” for Fedora Linux
Arch Linux
There is an Arch package available for the latest TinyGo release.
If you are only interested in compiling TinyGo code for WebAssembly then you are now done with the installation.
Otherwise, please continue with the installation of the additional requirements for your desired microcontroller
Additional Requirements for Microcontrollers on Arch Linux
There are some additional requirements to compile TinyGo programs that can run on microcontrollers.
AVR (e.g. Arduino Uno)
To compile and flash TinyGo programs for AVR based processors such as the original Arduino Uno you must install avrdude:
This should allow you to flash TinyGo programs on an Arduino or other supported AVR-based board.