nixpkgs/pkgs/tools/audio/openai-whisper-cpp/default.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

126 lines
3.4 KiB
Nix
Raw Normal View History

2022-12-07 15:26:15 +00:00
{ lib
, stdenv
, fetchFromGitHub
, SDL2
, makeWrapper
, wget
2024-01-24 22:55:58 +00:00
, which
2022-12-07 15:26:15 +00:00
, Accelerate
, CoreGraphics
, CoreML
2022-12-07 15:26:15 +00:00
, CoreVideo
, MetalKit
2024-01-18 16:39:31 +00:00
, config
, autoAddDriverRunpath
2024-01-18 16:39:31 +00:00
, cudaSupport ? config.cudaSupport
, cudaPackages ? {}
2022-12-07 15:26:15 +00:00
}:
2024-01-18 16:39:31 +00:00
let
# It's necessary to consistently use backendStdenv when building with CUDA support,
# otherwise we get libstdc++ errors downstream.
# cuda imposes an upper bound on the gcc version, e.g. the latest gcc compatible with cudaPackages_11 is gcc11
effectiveStdenv = if cudaSupport then cudaPackages.backendStdenv else stdenv;
in
effectiveStdenv.mkDerivation (finalAttrs: {
2022-12-07 15:26:15 +00:00
pname = "whisper-cpp";
2024-01-09 21:34:26 +00:00
version = "1.5.4";
2022-12-07 15:26:15 +00:00
src = fetchFromGitHub {
owner = "ggerganov";
repo = "whisper.cpp";
2024-01-18 16:39:31 +00:00
rev = "refs/tags/v${finalAttrs.version}" ;
2024-01-09 21:34:26 +00:00
hash = "sha256-9H2Mlua5zx2WNXbz2C5foxIteuBgeCNALdq5bWyhQCk=";
2022-12-07 15:26:15 +00:00
};
# The upstream download script tries to download the models to the
# directory of the script, which is not writable due to being
# inside the nix store. This patch changes the script to download
# the models to the current directory of where it is being run from.
patches = [ ./download-models.patch ];
2024-01-18 16:39:31 +00:00
nativeBuildInputs = [
2024-01-24 22:55:58 +00:00
which
2024-01-18 16:39:31 +00:00
makeWrapper
] ++ lib.optionals cudaSupport [
cudaPackages.cuda_nvcc
autoAddDriverRunpath
];
2024-01-18 16:39:31 +00:00
buildInputs = [
SDL2
] ++ lib.optionals stdenv.isDarwin [
Accelerate
CoreGraphics
CoreML
CoreVideo
MetalKit
] ++ lib.optionals cudaSupport ( with cudaPackages; [
2022-12-07 15:26:15 +00:00
2024-01-18 16:39:31 +00:00
# A temporary hack for reducing the closure size, remove once cudaPackages
# have stopped using lndir: https://github.com/NixOS/nixpkgs/issues/271792
2024-01-24 22:55:58 +00:00
cuda_cccl.dev # provides nv/target
2024-01-18 16:39:31 +00:00
cuda_cudart.dev
cuda_cudart.lib
cuda_cudart.static
libcublas.dev
libcublas.lib
libcublas.static
]);
postPatch = let
cudaOldStr = "-lcuda ";
cudaNewStr = "-lcuda -L${cudaPackages.cuda_cudart.lib}/lib/stubs ";
in lib.optionalString cudaSupport ''
substituteInPlace Makefile \
--replace '${cudaOldStr}' '${cudaNewStr}'
'';
2022-12-07 15:26:15 +00:00
2023-06-26 13:42:44 +00:00
env = lib.optionalAttrs stdenv.isDarwin {
WHISPER_COREML = "1";
WHISPER_COREML_ALLOW_FALLBACK = "1";
2024-01-18 16:39:31 +00:00
} // lib.optionalAttrs cudaSupport {
WHISPER_CUBLAS = "1";
2023-06-26 13:42:44 +00:00
};
2023-12-22 08:12:42 +00:00
makeFlags = [ "main" "stream" "command" ];
2022-12-07 15:26:15 +00:00
installPhase = ''
runHook preInstall
mkdir -p $out/bin
cp ./main $out/bin/whisper-cpp
cp ./stream $out/bin/whisper-cpp-stream
2023-12-22 08:12:42 +00:00
cp ./command $out/bin/whisper-cpp-command
2022-12-07 15:26:15 +00:00
cp models/download-ggml-model.sh $out/bin/whisper-cpp-download-ggml-model
wrapProgram $out/bin/whisper-cpp-download-ggml-model \
--prefix PATH : ${lib.makeBinPath [wget]}
${lib.optionalString stdenv.isDarwin ''
install -Dt $out/share/whisper-cpp ggml-metal.metal
for bin in whisper-cpp whisper-cpp-stream whisper-cpp-command; do
wrapProgram $out/bin/$bin \
--set-default GGML_METAL_PATH_RESOURCES $out/share/whisper-cpp
done
''}
2022-12-07 15:26:15 +00:00
runHook postInstall
'';
meta = with lib; {
description = "Port of OpenAI's Whisper model in C/C++";
longDescription = ''
To download the models as described in the project's readme, you may
use the `whisper-cpp-download-ggml-model` binary from this package.
'';
homepage = "https://github.com/ggerganov/whisper.cpp";
license = licenses.mit;
platforms = platforms.all;
maintainers = with maintainers; [ dit7ya hughobrien ];
2022-12-07 15:26:15 +00:00
};
2024-01-18 16:39:31 +00:00
})