Skip to content

Commit

Permalink
fixup! python312Packages.triton*: repair package
Browse files Browse the repository at this point in the history
  • Loading branch information
SomeoneSerge committed Oct 14, 2024
1 parent 9c3b397 commit b5d765a
Showing 1 changed file with 157 additions and 124 deletions.
281 changes: 157 additions & 124 deletions pkgs/by-name/tr/triton-llvm/package.nix
Original file line number Diff line number Diff line change
@@ -1,60 +1,72 @@
{ lib
, stdenv
, fetchFromGitHub
, pkgsBuildBuild
, pkg-config
, cmake
, ninja
, git
, libxml2
, libxcrypt
, libedit
, libffi
, libpfm
, lit
, mpfr
, zlib
, ncurses
, doxygen
, sphinx
, which
, sysctl
, python3Packages
, buildDocs ? true
, buildMan ? true
, buildTests ? true
, llvmTargetsToBuild ? [ "NATIVE" ] # "NATIVE" resolves into x86 or aarch64 depending on stdenv
, llvmProjectsToBuild ? [ "llvm" "mlir" ]
{
lib,
stdenv,
fetchFromGitHub,
pkgsBuildBuild,
pkg-config,
cmake,
ninja,
git,
libxml2,
libxcrypt,
libedit,
libffi,
libpfm,
lit,
mpfr,
zlib,
ncurses,
doxygen,
sphinx,
which,
sysctl,
python3Packages,
buildDocs ? true,
buildMan ? true,
buildTests ? true,
llvmTargetsToBuild ? [ "NATIVE" ], # "NATIVE" resolves into x86 or aarch64 depending on stdenv
llvmProjectsToBuild ? [
"llvm"
"mlir"
],
}:

let
llvmNativeTarget =
if stdenv.hostPlatform.isx86_64 then "X86"
else if stdenv.hostPlatform.isAarch64 then "AArch64"
else throw "Currently unsupported LLVM platform '${stdenv.hostPlatform.config}'";
if stdenv.hostPlatform.isx86_64 then
"X86"
else if stdenv.hostPlatform.isAarch64 then
"AArch64"
else
throw "Currently unsupported LLVM platform '${stdenv.hostPlatform.config}'";

inferNativeTarget = t: if t == "NATIVE" then llvmNativeTarget else t;
llvmTargetsToBuild' = [ "AMDGPU" "NVPTX" ] ++ builtins.map inferNativeTarget llvmTargetsToBuild;
llvmTargetsToBuild' = [
"AMDGPU"
"NVPTX"
] ++ builtins.map inferNativeTarget llvmTargetsToBuild;

# This LLVM version can't seem to find pygments/pyyaml,
# but a later update will likely fix this (triton-2.1.0)
python =
if buildTests
then python3Packages.python.withPackages (p: with p; [ psutil pygments pyyaml ])
else python3Packages.python;
if buildTests then
python3Packages.python.withPackages (
p: with p; [
psutil
pygments
pyyaml
]
)
else
python3Packages.python;

isNative = stdenv.hostPlatform == stdenv.buildPlatform;
in stdenv.mkDerivation (finalAttrs: {
in
stdenv.mkDerivation (finalAttrs: {
pname = "triton-llvm";
version = "llvmorg-19-init";

outputs = [
"out"
] ++ lib.optionals buildDocs [
"doc"
] ++ lib.optionals buildMan [
"man"
];
outputs = [ "out" ] ++ lib.optionals buildDocs [ "doc" ] ++ lib.optionals buildMan [ "man" ];

# See https://github.com/triton-lang/triton/blob/main/python/setup.py
# and https://github.com/ptillet/triton-llvm-releases/releases
Expand All @@ -65,18 +77,20 @@ in stdenv.mkDerivation (finalAttrs: {
hash = "sha256-9DPvcFmhzw6MipQeCQnr35LktW0uxtEL8axMMPXIfWw=";
};

nativeBuildInputs = [
pkg-config
cmake
ninja
git
python
] ++ lib.optionals (buildDocs || buildMan) [
doxygen
sphinx
python3Packages.recommonmark
python3Packages.myst-parser
];
nativeBuildInputs =
[
pkg-config
cmake
ninja
git
python
]
++ lib.optionals (buildDocs || buildMan) [
doxygen
sphinx
python3Packages.recommonmark
python3Packages.myst-parser
];

buildInputs = [
libxml2
Expand All @@ -94,78 +108,94 @@ in stdenv.mkDerivation (finalAttrs: {

sourceRoot = "${finalAttrs.src.name}/llvm";

cmakeFlags = [
(lib.cmakeFeature "LLVM_TARGETS_TO_BUILD" (lib.concatStringsSep ";" llvmTargetsToBuild'))
(lib.cmakeFeature "LLVM_ENABLE_PROJECTS" (lib.concatStringsSep ";" llvmProjectsToBuild))
(lib.cmakeFeature "LLVM_HOST_TRIPLE" stdenv.hostPlatform.config)
(lib.cmakeFeature "LLVM_DEFAULT_TARGET_TRIPLE" stdenv.hostPlatform.config)
(lib.cmakeBool "LLVM_INSTALL_UTILS" true)
(lib.cmakeBool "LLVM_INCLUDE_DOCS" (buildDocs || buildMan))
(lib.cmakeBool "MLIR_INCLUDE_DOCS" (buildDocs || buildMan))
(lib.cmakeBool "LLVM_BUILD_DOCS" (buildDocs || buildMan))
# Way too slow, only uses one core
# (lib.cmakeBool "LLVM_ENABLE_DOXYGEN" (buildDocs || buildMan))
(lib.cmakeBool "LLVM_ENABLE_SPHINX" (buildDocs || buildMan))
(lib.cmakeBool "SPHINX_OUTPUT_HTML" buildDocs)
(lib.cmakeBool "SPHINX_OUTPUT_MAN" buildMan)
(lib.cmakeBool "SPHINX_WARNINGS_AS_ERRORS" false)
(lib.cmakeBool "LLVM_INCLUDE_TESTS" buildTests)
(lib.cmakeBool "MLIR_INCLUDE_TESTS" buildTests)
(lib.cmakeBool "LLVM_BUILD_TESTS" buildTests)
# Cross compilation code taken/modified from LLVM 16 derivation
] ++ lib.optionals (!isNative) (let
nativeToolchainFlags = let
nativeCC = pkgsBuildBuild.targetPackages.stdenv.cc;
nativeBintools = nativeCC.bintools.bintools;
in [
(lib.cmakeFeature "CMAKE_C_COMPILER" "${nativeCC}/bin/${nativeCC.targetPrefix}cc")
(lib.cmakeFeature "CMAKE_CXX_COMPILER" "${nativeCC}/bin/${nativeCC.targetPrefix}c++")
(lib.cmakeFeature "CMAKE_AR" "${nativeBintools}/bin/${nativeBintools.targetPrefix}ar")
(lib.cmakeFeature "CMAKE_STRIP" "${nativeBintools}/bin/${nativeBintools.targetPrefix}strip")
(lib.cmakeFeature "CMAKE_RANLIB" "${nativeBintools}/bin/${nativeBintools.targetPrefix}ranlib")
];

# We need to repass the custom GNUInstallDirs values, otherwise CMake
# will choose them for us, leading to wrong results in llvm-config-native
nativeInstallFlags = [
(lib.cmakeFeature "CMAKE_INSTALL_PREFIX" (placeholder "out"))
(lib.cmakeFeature "CMAKE_INSTALL_BINDIR" "${placeholder "out"}/bin")
(lib.cmakeFeature "CMAKE_INSTALL_INCLUDEDIR" "${placeholder "out"}/include")
(lib.cmakeFeature "CMAKE_INSTALL_LIBDIR" "${placeholder "out"}/lib")
(lib.cmakeFeature "CMAKE_INSTALL_LIBEXECDIR" "${placeholder "out"}/libexec")
];
in [
(lib.cmakeBool "CMAKE_CROSSCOMPILING" true)
(lib.cmakeFeature "CROSS_TOOLCHAIN_FLAGS_NATIVE" (lib.concatStringsSep ";"
(lib.concatLists [ nativeToolchainFlags nativeInstallFlags ])))
]);

postPatch = ''
# `CMake Error: cannot write to file "/build/source/llvm/build/lib/cmake/mlir/MLIRTargets.cmake": Permission denied`
chmod +w -R ../mlir
patchShebangs ../mlir/test/mlir-reduce
# FileSystem permissions tests fail with various special bits
rm test/tools/llvm-objcopy/ELF/mirror-permissions-unix.test
rm unittests/Support/Path.cpp
substituteInPlace unittests/Support/CMakeLists.txt \
--replace "Path.cpp" ""
'' + lib.optionalString stdenv.hostPlatform.isAarch64 ''
# Not sure why this fails
rm test/tools/llvm-exegesis/AArch64/latency-by-opcode-name.s
'';

postInstall = ''
cp ${lib.getExe lit} $out/bin/llvm-lit
'' + (lib.optionalString (!isNative) ''
cp -a NATIVE/bin/llvm-config $out/bin/llvm-config-native
'');
cmakeFlags =
[
(lib.cmakeFeature "LLVM_TARGETS_TO_BUILD" (lib.concatStringsSep ";" llvmTargetsToBuild'))
(lib.cmakeFeature "LLVM_ENABLE_PROJECTS" (lib.concatStringsSep ";" llvmProjectsToBuild))
(lib.cmakeFeature "LLVM_HOST_TRIPLE" stdenv.hostPlatform.config)
(lib.cmakeFeature "LLVM_DEFAULT_TARGET_TRIPLE" stdenv.hostPlatform.config)
(lib.cmakeBool "LLVM_INSTALL_UTILS" true)
(lib.cmakeBool "LLVM_INCLUDE_DOCS" (buildDocs || buildMan))
(lib.cmakeBool "MLIR_INCLUDE_DOCS" (buildDocs || buildMan))
(lib.cmakeBool "LLVM_BUILD_DOCS" (buildDocs || buildMan))
# Way too slow, only uses one core
# (lib.cmakeBool "LLVM_ENABLE_DOXYGEN" (buildDocs || buildMan))
(lib.cmakeBool "LLVM_ENABLE_SPHINX" (buildDocs || buildMan))
(lib.cmakeBool "SPHINX_OUTPUT_HTML" buildDocs)
(lib.cmakeBool "SPHINX_OUTPUT_MAN" buildMan)
(lib.cmakeBool "SPHINX_WARNINGS_AS_ERRORS" false)
(lib.cmakeBool "LLVM_INCLUDE_TESTS" buildTests)
(lib.cmakeBool "MLIR_INCLUDE_TESTS" buildTests)
(lib.cmakeBool "LLVM_BUILD_TESTS" buildTests)
# Cross compilation code taken/modified from LLVM 16 derivation
]
++ lib.optionals (!isNative) (
let
nativeToolchainFlags =
let
nativeCC = pkgsBuildBuild.targetPackages.stdenv.cc;
nativeBintools = nativeCC.bintools.bintools;
in
[
(lib.cmakeFeature "CMAKE_C_COMPILER" "${nativeCC}/bin/${nativeCC.targetPrefix}cc")
(lib.cmakeFeature "CMAKE_CXX_COMPILER" "${nativeCC}/bin/${nativeCC.targetPrefix}c++")
(lib.cmakeFeature "CMAKE_AR" "${nativeBintools}/bin/${nativeBintools.targetPrefix}ar")
(lib.cmakeFeature "CMAKE_STRIP" "${nativeBintools}/bin/${nativeBintools.targetPrefix}strip")
(lib.cmakeFeature "CMAKE_RANLIB" "${nativeBintools}/bin/${nativeBintools.targetPrefix}ranlib")
];

# We need to repass the custom GNUInstallDirs values, otherwise CMake
# will choose them for us, leading to wrong results in llvm-config-native
nativeInstallFlags = [
(lib.cmakeFeature "CMAKE_INSTALL_PREFIX" (placeholder "out"))
(lib.cmakeFeature "CMAKE_INSTALL_BINDIR" "${placeholder "out"}/bin")
(lib.cmakeFeature "CMAKE_INSTALL_INCLUDEDIR" "${placeholder "out"}/include")
(lib.cmakeFeature "CMAKE_INSTALL_LIBDIR" "${placeholder "out"}/lib")
(lib.cmakeFeature "CMAKE_INSTALL_LIBEXECDIR" "${placeholder "out"}/libexec")
];
in
[
(lib.cmakeBool "CMAKE_CROSSCOMPILING" true)
(lib.cmakeFeature "CROSS_TOOLCHAIN_FLAGS_NATIVE" (
lib.concatStringsSep ";" (
lib.concatLists [
nativeToolchainFlags
nativeInstallFlags
]
)
))
]
);

postPatch =
''
# `CMake Error: cannot write to file "/build/source/llvm/build/lib/cmake/mlir/MLIRTargets.cmake": Permission denied`
chmod +w -R ../mlir
patchShebangs ../mlir/test/mlir-reduce
# FileSystem permissions tests fail with various special bits
rm test/tools/llvm-objcopy/ELF/mirror-permissions-unix.test
rm unittests/Support/Path.cpp
substituteInPlace unittests/Support/CMakeLists.txt \
--replace "Path.cpp" ""
''
+ lib.optionalString stdenv.hostPlatform.isAarch64 ''
# Not sure why this fails
rm test/tools/llvm-exegesis/AArch64/latency-by-opcode-name.s
'';

postInstall =
''
cp ${lib.getExe lit} $out/bin/llvm-lit
''
+ (lib.optionalString (!isNative) ''
cp -a NATIVE/bin/llvm-config $out/bin/llvm-config-native
'');

doCheck = buildTests;

nativeCheckInputs = [ which ]
++ lib.optionals stdenv.hostPlatform.isDarwin [ sysctl ];
nativeCheckInputs = [ which ] ++ lib.optionals stdenv.hostPlatform.isDarwin [ sysctl ];

checkTarget = "check-all";
requiredSystemFeatures = [ "big-parallel" ];
Expand All @@ -174,7 +204,10 @@ in stdenv.mkDerivation (finalAttrs: {
description = "Collection of modular and reusable compiler and toolchain technologies";
homepage = "https://github.com/llvm/llvm-project";
license = with licenses; [ ncsa ];
maintainers = with maintainers; [ SomeoneSerge Madouura ];
maintainers = with maintainers; [
SomeoneSerge
Madouura
];
platforms = with platforms; aarch64 ++ x86;
};
})

0 comments on commit b5d765a

Please sign in to comment.