WSL
WSL : Windows Subsystem for Linux (WSL)
let's developers run a GNU/Linux environment. -- including most command-line tools, utilities, and applications -- directly on Windows, unmodified, without the overhead of a traditional virtual machine or dual-boot setup.
To try the most recent features or updates to WSL, join the Windows Insiders Program. Once you have joined Windows Insiders, you can choose the channel you would like to receive preview builds from inside the Windows settings menu. You can choose from:
Dev channel: Most recent updates, but low stability. Beta channel: Ideal for early adopters, more reliable builds than the Dev channel. Release Preview channel: Preview fixes and key features on the next version of Windows just before its available to the general public.
Install WSL
Install Linux on Windows with WSL Article 01/11/2023 8 contributors In this article Prerequisites Install WSL command Change the default Linux distribution installed Set up your Linux user info Show 6 more Developers can access the power of both Windows and Linux at the same time on a Windows machine. The Windows Subsystem for Linux (WSL) lets developers install a Linux distribution (such as Ubuntu, OpenSUSE, Kali, Debian, Arch Linux, etc) and use Linux applications, utilities, and Bash command-line tools directly on Windows, unmodified, without the overhead of a traditional virtual machine or dualboot setup.
==== Prerequisites ====
You must be running Windows 10 version 2004 and higher (Build 19041 and higher) or Windows 11 to use the commands below. If you are on earlier versions please see the manual install page.
==== Install WSL command ====
You can now install everything you need to run WSL with a single command. Open PowerShell or Windows Command Prompt in administrator mode by right-clicking and selecting "Run as administrator", enter the wsl --install command, then restart your machine.
PowerShell
Copy wsl --install This command will enable the features necessary to run WSL and install the Ubuntu distribution of Linux. (This default distribution can be changed).
If you're running an older build, or just prefer not to use the install command and would like step-by-step directions, see WSL manual installation steps for older versions.
The first time you launch a newly installed Linux distribution, a console window will open and you'll be asked to wait for files to de-compress and be stored on your machine. All future launches should take less than a second.
Note
The above command only works if WSL is not installed at all, if you run wsl --install and see the WSL help text, please try running wsl --list --online to see a list of available distros and run wsl --install -d <DistroName> to install a distro. To uninstall WSL, see Uninstall legacy version of WSL or unregister or uninstall a Linux distribution.
==== Change the default Linux distribution installed ====
By default, the installed Linux distribution will be Ubuntu. This can be changed using the -d flag.
To change the distribution installed, enter: wsl --install -d <Distribution Name>. Replace <Distribution Name> with the name of the distribution you would like to install. To see a list of available Linux distributions available for download through the online store, enter: wsl --list --online or wsl -l -o. To install additional Linux distributions after the initial install, you may also use the command: wsl --install -d <Distribution Name>.
Tip
If you want to install additional distributions from inside a Linux/Bash command line (rather than from PowerShell or Command Prompt), you must use .exe in the command: wsl.exe --install -d <Distribution Name> or to list available distributions: wsl.exe -l -o.
If you run into an issue during the install process, check the installation section of the troubleshooting guide.
To install a Linux distribution that is not listed as available, you can import any Linux distribution using a TAR file. Or in some cases, as with Arch Linux, you can install using an .appx file. You can also create your own custom Linux distribution to use with WSL.
==== Set up your Linux user info ====
Once you have installed WSL, you will need to create a user account and password for your newly installed Linux distribution. See the Best practices for setting up a WSL development environment guide to learn more.
==== Set up and best practices ====
We recommend following our Best practices for setting up a WSL development environment guide for a step-by-step walk-through of how to set up a user name and password for your installed Linux distribution(s), using basic WSL commands, installing and customizing Windows Terminal, set up for Git version control, code editing and debugging using the VS Code remote server, good practices for file storage, setting up a database, mounting an external drive, setting up GPU acceleration, and more.
==== Check which version of WSL you are running ====
You can list your installed Linux distributions and check the version of WSL each is set to by entering the command: wsl -l -v in PowerShell or Windows Command Prompt.
To set the default version to WSL 1 or WSL 2 when a new Linux distribution is installed, use the command: wsl --set-default-version <Version#>, replacing <Version#> with either 1 or 2.
To set the default Linux distribution used with the wsl command, enter: wsl -s <DistributionName> or wsl --setdefault <DistributionName>, replacing <DistributionName> with the name of the Linux distribution you would like to use. For example, from PowerShell/CMD, enter: wsl -s Debian to set the default distribution to Debian. Now running wsl npm init from Powershell will run the npm init command in Debian.
To run a specific wsl distribution from within PowerShell or Windows Command Prompt without changing your default distribution, use the command: wsl -d <DistributionName>, replacing <DistributionName> with the name of the distribution you want to use.
Learn more in the guide to Basic commands for WSL.
==== Upgrade version from WSL 1 to WSL 2 ====
New Linux installations, installed using the wsl --install command, will be set to WSL 2 by default.
The wsl --set-version command can be used to downgrade from WSL 2 to WSL 1 or to update previously installed Linux distributions from WSL 1 to WSL 2.
To see whether your Linux distribution is set to WSL 1 or WSL 2, use the command: wsl -l -v.
To change versions, use the command: wsl --set-version <distro name> 2 replacing <distro name> with the name of the Linux distribution that you want to update. For example, wsl --set-version Ubuntu-20.04 2 will set your Ubuntu 20.04 distribution to use WSL 2.
If you manually installed WSL prior to the wsl --install command being available, you may also need to enable the virtual machine optional component used by WSL 2 and install the kernel package if you haven't already done so.
To learn more, see the Command reference for WSL for a list of WSL commands, Comparing WSL 1 and WSL 2 for guidance on which to use for your work scenario, or Best practices for setting up a WSL development environment for general guidance on setting up a good development workflow with WSL.
==== Ways to run multiple Linux distributions with WSL ====
WSL supports running as many different Linux distributions as you would like to install. This can include choosing distributions from the Microsoft Store, importing a custom distribution, or building your own custom distribution.
There are several ways to run your Linux distributions once installed:
Install Windows Terminal (Recommended) Using Windows Terminal supports as many command lines as you would like to install and enables you to open them in multiple tabs or window panes and quickly switch between multiple Linux distributions or other command lines (PowerShell, Command Prompt, PowerShell, Azure CLI, etc). You can fully customize your terminal with unique color schemes, font styles, sizes, background images, and custom keyboard shortcuts. Learn more. You can directly open your Linux distribution by visiting the Windows Start menu and typing the name of your installed distributions. For example: "Ubuntu". This will open Ubuntu in it's own console window. From Windows Command Prompt or PowerShell, you can enter the name of your installed distribution. For example: ubuntu From Windows Command Prompt or PowerShell, you can open your default Linux distribution inside your current command line, by entering: wsl.exe. From Windows Command Prompt or PowerShell, you can use your default Linux distribution inside your current command line, without entering a new one, by entering:wsl [command]. Replacing [command] with a WSL command, such as: wsl -l -v to list installed distributions or wsl pwd to see where the current directory path is mounted in wsl. From PowerShell, the command get-date will provide the date from the Windows file system and wsl date will provide the date from the Linux file system. The method you select should depend on what you're doing. If you've opened a WSL command line within a Windows Prompt or PowerShell window and want to exit, enter the command: exit.
==== Want to try the latest WSL preview features? ====
Try the most recent features or updates to WSL by joining the Windows Insiders Program. Once you have joined Windows Insiders, you can choose the channel you would like to receive preview builds from inside the Windows settings menu to automatically receive any WSL updates or preview features associated with that build. You can choose from:
Dev channel: Most recent updates, but low stability. Beta channel: Ideal for early adopters, more reliable builds than the Dev channel. Release Preview channel: Preview fixes and key features on the next version of Windows just before its available to the general public.
Ubuntu in WSL
3) Updating Your Ubuntu System Now that you can access internet, you can update your Ubuntu.
Follow "Update and upgrade packages" in Set up a WSL development environment | Microsoft Docs.
4) Setup VS Code and everything else Now it's time to setup your VS code and terminals so that you can access your files on the VM to do this follow
Set up a WSL development environment | Microsoft Docs sections:
Set up Windows Terminal
File storage
Use Visual Studio Code
5) Install what we need for building the desktop app Run the following command to get your environment ready, these comments should be ran in WSL Ubuntu.
5.1) cmake sudo apt install cmake
5.2) Clang as compiler: sudo apt install clang-10 --install-suggests
After running this command a symbolic (type of file in Linux that points to another file or a folder) is created, when you use clang-10 and clang++-10, clang 10 C and C++ compilers are targeted respectively.
You can read more about this to understand it better by reading the answer by karel at How to set Clang 9 as the default C++ compiler on Ubuntu 19.10? - Ask Ubuntu (do not follow this as instruction but read to understand what is going on, you can check your symbolic to understand it better)
6) Update CMakeList.txt (if we did not push changes by the time you use this document) Add the following lines to CMakeList.txt (at /firmware/Desktop) before the line containing "project(XXXXXX)", this would set the compilers for project, if you set them after this line it will not work correctly.
set(CMAKE_C_COMPILER "clang-10") set(CMAKE_CXX_COMPILER "clang++-10")
7) Build the Project (to be updated) cd firmware/Breathing
rm -rf build
cmake -B build .
cd build
make
7.1) Troubleshooting 7.1.1) If CMake Does Not Apply Your Changes
rm -f CMakeCache.txt
Then redo build
8) Run the Tests cd /OS-firmware/
source run_small_window.sh
You may need to change the access to the run_small_window.sh by "sudo chmod 777 run_small_window.sh" (on WSL this is not needed)