diff --git a/.github/workflows/windows-arm.yml b/.github/workflows/windows-arm.yml
new file mode 100644
index 0000000..4218261
--- /dev/null
+++ b/.github/workflows/windows-arm.yml
@@ -0,0 +1,182 @@
+# This file is a part of the UMSKT Project
+#
+# Copyleft (C) 2019-2023 UMSKT Contributors (et.al.)
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+#
+# @FileCreated by TheTank20 on 07/08/2025
+# @Maintainer Neo
+
+name: C/C++ CI (Windows ARM)
+
+on:
+ push:
+ branches: [ "*" ]
+ paths-ignore: [ '**.md', 'doc/**', '.idea/**']
+ workflow_dispatch:
+
+jobs:
+ build:
+ runs-on: windows-latest
+ strategy:
+ fail-fast: false
+ matrix:
+ include:
+ - arch: arm
+ arch_compilename: amd64_arm
+ vcpkg_arch: arm-windows-static
+ cmake_arch: ARM
+ sdk_version: '10.0.19041.0'
+ - arch: arm64
+ arch_compilename: arm64
+ vcpkg_arch: arm64-windows-static
+ cmake_arch: ARM64
+ sdk_version: '10.0.22621.0'
+ steps:
+ - name: Setup MSVC for ${{ matrix.arch }}
+ uses: ilammy/msvc-dev-cmd@v1
+ with:
+ arch: ${{ matrix.arch_compilename }}
+ sdk: ${{ matrix.sdk_version }}
+
+ - name: Checkout Source Tree
+ uses: actions/checkout@v4
+
+ - name: Setup vcpkg
+ if: matrix.arch == 'arm64'
+ shell: pwsh
+ run: |
+ git clone https://github.com/Microsoft/vcpkg.git
+ cd vcpkg
+ .\bootstrap-vcpkg.bat
+ echo "VCPKG_ROOT=$env:GITHUB_WORKSPACE/vcpkg" | Out-File -FilePath $env:GITHUB_ENV -Append
+ echo "VCPKG_DEFAULT_BINARY_CACHE=$env:GITHUB_WORKSPACE/vcpkg/bincache" | Out-File -FilePath $env:GITHUB_ENV -Append
+ echo "VCPKG_BINARY_SOURCES=clear;default,readwrite" | Out-File -FilePath $env:GITHUB_ENV -Append
+
+ - name: Cache vcpkg packages
+ if: matrix.arch == 'arm64'
+ uses: actions/cache@v4
+ with:
+ path: |
+ ${{ github.workspace }}/vcpkg/bincache
+ ${{ github.workspace }}/vcpkg/installed
+ ${{ github.workspace }}/vcpkg/packages
+ key: vcpkg-${{ matrix.arch }}-${{ hashFiles('**/CMakeLists.txt') }}-${{ hashFiles('**/*.cmake') }}
+ restore-keys: |
+ vcpkg-${{ matrix.arch }}-${{ hashFiles('**/CMakeLists.txt') }}-
+ vcpkg-${{ matrix.arch }}-
+
+ - name: Cache OpenSSL Binaries
+ if: matrix.arch == 'arm'
+ uses: actions/cache@v4
+ with:
+ path: |
+ ${{ github.workspace }}/openssl-install
+ key: openssl-${{ matrix.arch }}-${{ hashFiles('**/CMakeLists.txt') }}
+ restore-keys: |
+
+ - name: Install OpenSSL
+ shell: pwsh
+ run: |
+ if ("${{ matrix.arch }}" -eq "arm") {
+ # For ARM32, build OpenSSL from source
+ $opensslVersion = "1.1.1w"
+ $opensslDir = "openssl-src"
+
+ # Download OpenSSL source
+ Invoke-WebRequest -Uri "https://www.openssl.org/source/openssl-$opensslVersion.tar.gz" -OutFile "openssl.tar.gz"
+ tar -xf openssl.tar.gz
+ Rename-Item -Path "openssl-$opensslVersion" -NewName $opensslDir
+ cd $opensslDir
+
+ # Install Perl if needed
+ choco install strawberryperl -y
+
+ # Configure and build OpenSSL for ARM32
+ $env:PATH = "C:\Strawberry\perl\bin;$env:PATH"
+
+ # First set up Visual Studio environment
+ $vsPath = & "${env:ProgramFiles(x86)}\Microsoft Visual Studio\Installer\vswhere.exe" -latest -property installationPath
+ $vcvarsall = Join-Path $vsPath "VC\Auxiliary\Build\vcvarsall.bat"
+
+ # Configure OpenSSL
+ perl Configure VC-WIN32-ARM no-shared no-asm no-engine --prefix="$env:GITHUB_WORKSPACE/openssl-install"
+
+ # Build using MSVC ARM32 tools
+ cmd /c "call `"$vcvarsall`" amd64_arm && nmake && nmake install_sw"
+ cd ..
+ } else {
+ # For ARM64, use vcpkg as before
+ New-Item -ItemType Directory -Force -Path $env:VCPKG_DEFAULT_BINARY_CACHE
+ & "$env:VCPKG_ROOT\vcpkg.exe" install openssl:${{ matrix.vcpkg_arch }} --clean-after-build
+ echo "OPENSSL_ROOT_DIR=$env:VCPKG_ROOT/installed/${{ matrix.vcpkg_arch }}" | Out-File -FilePath $env:GITHUB_ENV -Append
+ }
+
+ - name: Save OpenSSL Binaries
+ if: matrix.arch == 'arm'
+ uses: actions/cache/save@v4
+ with:
+ path: |
+ ${{ github.workspace }}/openssl-install
+ key: openssl-${{ matrix.arch }}-${{ hashFiles('**/CMakeLists.txt') }}
+
+ - name: Set OpenSSL Environment
+ if: matrix.arch == 'arm'
+ shell: pwsh
+ run: |
+ echo "OPENSSL_ROOT=$env:GITHUB_WORKSPACE/openssl-install" | Out-File -FilePath $env:GITHUB_ENV -Append
+ echo "OPENSSL_LIBDIR=lib" | Out-File -FilePath $env:GITHUB_ENV -Append
+
+ - name: Configure UMSKT
+ shell: pwsh
+ run: |
+ cmake -G "Visual Studio 17 2022" `
+ -A ${{ matrix.cmake_arch }} `
+ -DWINDOWS_ARM=ON `
+ -DCMAKE_TOOLCHAIN_FILE="$env:VCPKG_ROOT/scripts/buildsystems/vcpkg.cmake" `
+ -DVCPKG_TARGET_TRIPLET=${{ matrix.vcpkg_arch }} `
+ .
+
+ - name: Build UMSKT
+ shell: pwsh
+ run: |
+ cmake --build . --config Release
+
+ - name: Upload build artifact
+ uses: actions/upload-artifact@v4.6.2
+ with:
+ name: UMSKT-WinNT-${{ matrix.arch }}
+ path: Release/umskt.exe
+
+ test-arm64:
+ needs: build
+ if: success()
+ runs-on: windows-11-arm
+ strategy:
+ matrix:
+ arch: [arm64]
+ steps:
+ - name: Download ARM64 artifact
+ uses: actions/download-artifact@v4
+ with:
+ name: UMSKT-WinNT-${{ matrix.arch }}
+ path: .
+
+ - name: Run tests
+ shell: pwsh
+ run: |
+ Write-Host Test 1 - generating key
+ .\umskt.exe -b 2C -c 365 -s 069420 -v
+ Write-Host Test 2 - generatng confid
+ .\umskt.exe -i 253286028742154311079061239762245184619981623171292574
\ No newline at end of file
diff --git a/.github/workflows/windows.yml b/.github/workflows/windows-x86-x64.yml
similarity index 70%
rename from .github/workflows/windows.yml
rename to .github/workflows/windows-x86-x64.yml
index 423e3e9..b9833fe 100644
--- a/.github/workflows/windows.yml
+++ b/.github/workflows/windows-x86-x64.yml
@@ -15,10 +15,10 @@
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see .
#
-# @FileCreated by TheTank20 on 06/13/2023
+# @FileCreated by TheTank20 on 07/08/2025
# @Maintainer Neo
-name: C/C++ CI (Windows)
+name: C/C++ CI (Windows x86+64)
on:
push:
@@ -32,10 +32,9 @@ jobs:
strategy:
fail-fast: false
matrix:
- arch: [x64, x86, arm64]
+ arch: [x64, x86]
steps:
- name: Setup TDM-GCC
- if: matrix.arch != 'arm64'
run: |
Write-Host Downloading TDM-GCC v10.3.0...
Invoke-WebRequest -Uri 'https://github.com/jmeubank/tdm-gcc/releases/download/v10.3.0-tdm64-2/tdm64-gcc-10.3.0-2.exe' -OutFile 'C:\Windows\temp\TDM-GCC-64.exe'
@@ -51,12 +50,6 @@ jobs:
$env:PATH = 'C:\TDM-GCC-64\bin;' + $env:PATH
[Environment]::SetEnvironmentVariable('PATH', $env:PATH, [EnvironmentVariableTarget]::Machine)
- - name: Setup MSVC for ARM64
- if: matrix.arch == 'arm64'
- uses: ilammy/msvc-dev-cmd@v1
- with:
- arch: arm64
-
- name: Checkout Source Tree
uses: actions/checkout@v4
@@ -79,7 +72,7 @@ jobs:
key: openssl-3.1.2-x64-${{ hashFiles('**/CMakeLists.txt') }}
- name: Setup MSYS2
- if: matrix.arch != 'arm64' && steps.cache-openssl-32.outputs.cache-hit != 'true' && steps.cache-openssl-64.outputs.cache-hit != 'true'
+ if: steps.cache-openssl-32.outputs.cache-hit != 'true' && steps.cache-openssl-64.outputs.cache-hit != 'true'
uses: msys2/setup-msys2@v2
with:
msystem: ${{ matrix.arch == 'x86' && 'MINGW32' || 'MINGW64' }}
@@ -92,7 +85,7 @@ jobs:
git
- name: Checkout and Compile OpenSSL 3.1.2
- if: matrix.arch != 'arm64' && steps.cache-openssl-32.outputs.cache-hit != 'true' && steps.cache-openssl-64.outputs.cache-hit != 'true'
+ if: steps.cache-openssl-32.outputs.cache-hit != 'true' && steps.cache-openssl-64.outputs.cache-hit != 'true'
shell: msys2 {0}
run: |
# Clone UMSKT's OpenSSL fork
@@ -167,39 +160,7 @@ jobs:
echo "OPENSSL_LIBDIR=lib" | Out-File -FilePath $env:GITHUB_ENV -Append
echo "CMAKE_FLAGS=-m64" | Out-File -FilePath $env:GITHUB_ENV -Append
- - name: Setup vcpkg for ARM64
- if: matrix.arch == 'arm64'
- shell: pwsh
- run: |
- git clone https://github.com/Microsoft/vcpkg.git
- cd vcpkg
- .\bootstrap-vcpkg.bat
- echo "VCPKG_ROOT=$env:GITHUB_WORKSPACE/vcpkg" | Out-File -FilePath $env:GITHUB_ENV -Append
- echo "VCPKG_DEFAULT_BINARY_CACHE=$env:GITHUB_WORKSPACE/vcpkg/bincache" | Out-File -FilePath $env:GITHUB_ENV -Append
- echo "VCPKG_BINARY_SOURCES=clear;default,readwrite" | Out-File -FilePath $env:GITHUB_ENV -Append
-
- - name: Cache vcpkg packages
- if: matrix.arch == 'arm64'
- uses: actions/cache@v4
- with:
- path: |
- ${{ github.workspace }}/vcpkg/bincache
- ${{ github.workspace }}/vcpkg/installed
- ${{ github.workspace }}/vcpkg/packages
- key: vcpkg-arm64-${{ hashFiles('**/CMakeLists.txt') }}-${{ hashFiles('**/*.cmake') }}
- restore-keys: |
- vcpkg-arm64-${{ hashFiles('**/CMakeLists.txt') }}-
- vcpkg-arm64-
-
- - name: Install OpenSSL for ARM64
- if: matrix.arch == 'arm64'
- shell: pwsh
- run: |
- New-Item -ItemType Directory -Force -Path $env:VCPKG_DEFAULT_BINARY_CACHE
- & "$env:VCPKG_ROOT\vcpkg.exe" install openssl:arm64-windows-static --clean-after-build
-
- - name: Configure UMSKT (TDM-GCC ${{ matrix.arch }})
- if: matrix.arch != 'arm64'
+ - name: Configure UMSKT
shell: pwsh
run: |
$env:PATH = 'C:\TDM-GCC-64\bin;' + $env:PATH
@@ -217,32 +178,13 @@ jobs:
-DCMAKE_CXX_FLAGS="$env:CMAKE_FLAGS" `
.
- - name: Configure UMSKT (MSVC ARM64)
- if: matrix.arch == 'arm64'
- shell: pwsh
- run: |
- cmake -G "Visual Studio 17 2022" `
- -A ARM64 `
- -DWINDOWS_ARM=ON `
- -DCMAKE_TOOLCHAIN_FILE="$env:VCPKG_ROOT/scripts/buildsystems/vcpkg.cmake" `
- -DVCPKG_TARGET_TRIPLET=arm64-windows-static `
- .
-
- - name: Build UMSKT (TDM-GCC ${{ matrix.arch }})
- if: matrix.arch != 'arm64'
+ - name: Build UMSKT
shell: pwsh
run: |
$env:PATH = 'C:\TDM-GCC-64\bin;' + $env:PATH
mingw32-make
- - name: Build UMSKT (MSVC ARM64)
- if: matrix.arch == 'arm64'
- shell: pwsh
- run: |
- cmake --build . --config Release
-
- - name: Run tests (x86/x64)
- if: matrix.arch != 'arm64'
+ - name: Run tests
shell: pwsh
run: |
Write-Host Test 1 - generating key
@@ -254,23 +196,4 @@ jobs:
uses: actions/upload-artifact@v4.6.2
with:
name: UMSKT-WinNT-${{ matrix.arch }}
- path: ${{ matrix.arch == 'arm64' && 'Release/umskt.exe' || 'umskt.exe' }}
-
- test-arm64:
- needs: build
- if: success()
- runs-on: windows-11-arm
- steps:
- - name: Download ARM64 artifact
- uses: actions/download-artifact@v4
- with:
- name: UMSKT-WinNT-arm64
- path: .
-
- - name: Run tests (ARM64)
- shell: pwsh
- run: |
- Write-Host Test 1 - generating key
- .\umskt.exe -b 2C -c 365 -s 069420 -v
- Write-Host Test 2 - generatng confid
- .\umskt.exe -i 253286028742154311079061239762245184619981623171292574
+ path: umskt.exe
\ No newline at end of file
diff --git a/README.md b/README.md
index be2debe..6f72ff7 100644
--- a/README.md
+++ b/README.md
@@ -50,11 +50,18 @@ In light of the recent exponential interest in this project I've decided to put
* MS-DOS 6.22 or later
* Any DOS-based version of Windows
* Windows NT 4.0 or later (via NTVDM)
-#### Windows
+#### Windows (x86/x64)
* i686 processor or better
* Windows XP or later
-*Note: Processors barely meeting the minimum system requirements for XP may not work. Use the MS-DOS version via NTVDM in that case.*
+> [!WARNING]
+> Processors barely meeting the minimum system requirements for XP may not work. Use the MS-DOS version via NTVDM in that case.
+
+#### Windows (ARM32/64)
+* Windows 11 21H2 or later
+
+> [!NOTE]
+> This is just all we can test. Try to get it to run on Windows RT, make an issue if it doesn't run and we'll try to fix it.
#### macOS
* Apple Silicon or x86_64 processor
* Latest version of macOS
@@ -74,15 +81,14 @@ In light of the recent exponential interest in this project I've decided to put
* *(GitHub account \*not\* required)*
* Download the latest release for your operating system and architecture from [the releases page](../../releases)
-* **Note:** Before continuing, please ensure you have the `umskt` executable extracted and on UNIX-like systems, have execution permissions (`chmod +x umskt`).
+> [!IMPORTANT]
+> Before continuing, please ensure you have the `umskt` executable extracted and on UNIX-like systems, have execution permissions (`chmod +x umskt`).
-#### 2. Install OpenSSL.
-For Windows, click [here](https://slproweb.com/products/Win32OpenSSL.html) and choose the right version. For other operating systems, consult your package manager.
-*Note: This only applies if the build you download has OpenSSL embedded (static library) or not. You can usually tell if the download size is measured in KB or MB. If it's MB, you don't need this.*
+#### 2. Run `umskt` to generate a key, or add `--help` or `-h` to see more options.
+> [!IMPORTANT]
+> On macOS, like all unsigned executables, you'll need to hold Ctrl while right clicking and selecting Open to actually open it.
-#### 3. Run `umskt` to generate a key, or add `--help` or `-h` to see more options.
-*Note: on macOS, like all unsigned executables, you'll need to hold Ctrl while right clicking and selecting Open to actually open it.*
-#### 4. *(Activation step for `Retail` and `OEM` only)*
+#### 3. *(Activation step for `Retail` and `OEM` only)*
* After installation, you will be prompted to activate Windows.
diff --git a/src/libumskt/confid/confid.cpp b/src/libumskt/confid/confid.cpp
index 3949e0c..92582cc 100644
--- a/src/libumskt/confid/confid.cpp
+++ b/src/libumskt/confid/confid.cpp
@@ -85,7 +85,7 @@ inline QWORD ConfirmationID::__umul128(QWORD a, QWORD b, QWORD* hi)
*hi = __umulh(a, b);
return a * b;
}
-#elif defined(__i386__) || defined(_M_IX86) || defined(__arm__) || defined(__EMSCRIPTEN__)
+#elif defined(__i386__) || defined(_M_IX86) || defined(__arm__) || defined(__EMSCRIPTEN__) || defined(_M_ARM)
inline QWORD ConfirmationID::__umul128(QWORD multiplier, QWORD multiplicand, QWORD *product_hi) {
// multiplier = ab = a * 2^32 + b
// multiplicand = cd = c * 2^32 + d