Skip to end of banner
Go to start of banner

How to setup Windows on Arm for llvm development

Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 3 Next »

This describes how to setup a Windows on Arm laptop to build llvm.

Adding to the PATH

For all the steps below you’ll need to put things on the PATH, if an installer doesn’t do it for you. To do that open the start menu, type “environment” and open the link to “System Properties”. There click “Environment Variables” to see a GUI for editing them.

If you’re setting this up for a buildbot you may want to add to the system “Path” instead of the tcwg user’s path. So that the service used to run buildbot can find the tools. (though I haven’t confirmed that)

Note: just like in Unix, adding to the path doesn’t refresh active terminals. You’ll need to open a fresh one/google the “source ~/.bashrc” equivalent for Windows.

Install Visual Studio Build Tools

This is the command line portion of visual studio, download it from https://visualstudio.microsoft.com/downloads/ . (“Tools for Visual Studio 2019” → “Build Tools for Visual Studio 2019”)

The Visual Studio installer has many options but generally you want all the things to do with C++ desktop development for ARM64. (there are some ARM components, these are Arm 32 bit, we don’t need those)

If you have build issues later, come back to the installer and add anything that seems relevant. Here’s the list of what I installed, check this against “Individual Components” in your “Installation Details” panel:

  • C++/CLI support for v142 build tools (latest)

  • C++ Universal Windows Platform runtime for v142 build tools

  • MSVC v142 - VS 2019 C++ ARM64 build tools (latest)

  • C++ Universal Windows Platform support for v142 build tools (ARM64)

  • C++ ATL for latest v142 build tools (ARM64)

Note: there’s probably a choice in the installer for where to install to. If you do that modify any instructions as needed. The default that I got was “C:\Program Files (x86)\Microsoft Visual Studio\2019\BuildTools\Common7\Tools\”.

(worst case, you can always search C:\ for a file, it isn’t as slow as you’d expect)

Install llvm 12 for Windows on Arm

Go to https://github.com/llvm/llvm-project/releases/tag/llvmorg-12.0.0 and download the Windows on Arm (“woa64”) installer. Run it and if it asks to add llvm to the path say yes. If it doesn’t or you forget that you can always

Install CMake

Build tools comes with some version of cmake but the one it puts on the path is presumably a 64 bit x86 build. I instead installed the i386 build from https://cmake.org/download/ and added that to my PATH.

Install Python

If you run “python” it takes you to the Windows Store which allegedly will give you a (native?) copy of Python3. As per usual with the Windows Store, it didn’t do anything when I clicked install.

So instead, you can go to Python.org and get a 32 bit build of the latest Python3. Remember to get a debug build/tell the installer to install debug libs, if you want to build a debug lldb. (everything else is fine with a release Python afaict)

Build Ninja

Again build tools can/does come with a ninja but the default one doesn’t run on WoA. I built ninja from source (https://github.com/ninja-build/ninja ) using the cmake build method.

Testing the Install

First, open a plain terminal “Command Prompt”. Ignore the cross prompts shortcuts you might find in the start menu.

Then run VsDevCmd.bat to setup the environment.

"C:\Program Files (x86)\Microsoft Visual Studio\2019\BuildTools\Common7\Tools\VsDevCmd.bat" -host_arch=x86 -arch=arm64
<...>
"C:\Program Files (x86)\Microsoft Visual Studio\2019\BuildTools\Common7\Tools\VsDevCmd.bat" -test
<...>

If the second test command fails, your build probably won’t work. If figuring out why it failed is tricky, just go ahead and do a build and the compiler’s errors will probably be more informative.

Note: We setup the Visual Studio env first because it adds some copies of cmake and ninja that we don’t want. By doing it first, then checking cmake and ninja, we know if our preferred versions are being used.

Now check that cmake and ninja can run at all.

ninja --version
cmake --version

Doing a Build

(in the same command prompt from above)
Set your compiler(s) to be the clang-cl.exe we installed earlier.

set "CC=clang-cl.exe"
set "CXX=clang-cl.exe"

Then make a folder next to your llvm checkout and from that folder:

cmake ..\llvm-project\llvm -DCMAKE_BUILD_TYPE=Release -DLLVM_ENABLE_PROJECTS="clang;lldb;lld;llvm" -DLLVM_ENABLE_ASSERTIONS=ON -DCMAKE_C_FLAGS="-fms-compatibility-version=19.14" -DCMAKE_CXX_FLAGS="-fms-compatibility-version=19.14" -G Ninja

Note: https://reviews.llvm.org/D92515 bumped llvm’s required MSVC version, ironically meaning that clang-cl version 12 can’t build it. That’s why we need the “ms-compatibility-version" flag to have clang-cl pretend to be a newer MSVC.

Then build as usual with ninja.

Here is where you might get errors about includes and linker directories and so on. Best way to solve this is to go back to the Visual Studio Installer and add anything that looks related.

You will find things online about adding certain dirs to your path but be careful because you could just be adding x86 libs. Installing ARM64 specific variants is almost always what you want.

If you’re doing a debug build and you see linker errors about missing libs, see if the file names end with “d”. E.g. “foo.lib” would be “food.lib” for a debug build. When I had this issue I think I did actually add those libs to Path, but I’m not sure that’s the way you’re supposed to do it.

  • No labels