Skip to content

Commit

Permalink
Use makefile instead of ninja on arm64 linux
Browse files Browse the repository at this point in the history
  • Loading branch information
1yefuwang1 committed Sep 26, 2024
1 parent 11d1e44 commit 3114a5e
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 11 deletions.
1 change: 0 additions & 1 deletion .github/workflows/arm64.yml
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,6 @@ jobs:
- name: Bootstrap vcpkg
run: |
git submodule update --init --recursive
python bootstrap_vcpkg.py
- name: Build wheels
run: python -m cibuildwheel --output-dir wheelhouse
Expand Down
11 changes: 11 additions & 0 deletions CMakePresets.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,17 @@
"CMAKE_BUILD_TYPE": "Release",
"CMAKE_EXPORT_COMPILE_COMMANDS": "1"
}
},
{
"name": "linux_arm64_release",
"toolchainFile": "vcpkg/scripts/buildsystems/vcpkg.cmake",
"binaryDir": "${sourceDir}/build/release",
"generator": "Unix Makefiles",
"cacheVariables": {
"CMAKE_BUILD_TYPE": "Release",
"CMAKE_EXPORT_COMPILE_COMMANDS": "1",
"VCPKG_TARGET_TRIPLET": "arm64-linux-release"
}
}
]
}
12 changes: 3 additions & 9 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,6 @@ environment = {MACOSX_DEPLOYMENT_TARGET = "10.15"} # 10.15 is the minimum versio
before-build = "yum install -y ninja-build"

[[tool.cibuildwheel.overrides]]
select = "*aarch64*"
environment = {VCPKG_FORCE_SYSTEM_BINARIES="1"}
before-build = [
"yum update",
"yum install -y curl zip unzip tar",
"git clone https://github.com/ninja-build/ninja.git",
"cd ninja && python3 configure.py --bootstrap",
"mv ninja /usr/bin/ && cd .. && rm -rf ninja"
]
select = "*manylinux_aarch64*"
# ninja-build is not installable via yum on aarch64
before-build = "yum install -y curl zip unzip tar; python bootstrap_vcpkg.py"
7 changes: 6 additions & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,12 @@ def build_extension(self, ext: CMakeExtension) -> None:
extra_args = []
# if system.lower() == 'windows':
# extra_args = ['-DCMAKE_CXX_COMPILER=cl', '-DCMAKE_C_COMPILER=cl']
configure = subprocess.run([cmake_path, '--preset', 'release', *extra_args])
preset = 'release'
if system.lower() == 'linux' and machine.lower() == 'aarch64':
preset = 'linux_arm64_release'
configure = subprocess.run([cmake_path, '--preset', preset, *extra_args])
with open('/project/build/release/vcpkg-manifest-install.log', 'r') as f:
print(f'!!!vcpkg-manifest-install.log: {f.read()}')
configure.check_returncode()

subprocess.run([cmake_path, '--build', os.path.join('build', 'release'), '-j8'], check=True)
Expand Down

0 comments on commit 3114a5e

Please sign in to comment.