Unverified Commit 93e8ab64 authored by Masum Reza's avatar Masum Reza Committed by GitHub
Browse files

linuxPackages.drbd: 9.2.8 -> 9.2.12 (#360238)

parents fdcd79a3 9fd3fbeb
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -286,6 +286,7 @@ in {
  drawterm = discoverTests (import ./drawterm.nix);
  drbd = handleTest ./drbd.nix {};
  druid = handleTestOn [ "x86_64-linux" ] ./druid {};
  drbd-driver = handleTest ./drbd-driver.nix {};
  dublin-traceroute = handleTest ./dublin-traceroute.nix {};
  earlyoom = handleTestOn ["x86_64-linux"] ./earlyoom.nix {};
  early-mount-options = handleTest ./early-mount-options.nix {};
+24 −0
Original line number Diff line number Diff line
import ./make-test-python.nix (
  { lib, pkgs, ... }:
  {
    name = "drbd-driver";
    meta.maintainers = with pkgs.lib.maintainers; [ birkb ];

    nodes = {
      machine =
        { config, pkgs, ... }:
        {
          boot = {
            kernelModules = [ "drbd" ];
            extraModulePackages = with config.boot.kernelPackages; [ drbd ];
            kernelPackages = pkgs.linuxPackages;
          };
        };
    };

    testScript = ''
      machine.start();
      machine.succeed("modinfo drbd | grep --extended-regexp '^version:\s+${pkgs.linuxPackages.drbd.version}$'")
    '';
  }
)
+27 −35
Original line number Diff line number Diff line
{ stdenv, lib, fetchurl, kernel, flex, coccinelle, python3 }:

stdenv.mkDerivation rec {
  name = "drbd-${version}-${kernel.version}";
  version = "9.2.8";
{
  stdenv,
  lib,
  fetchurl,
  kernel,
  nixosTests,
  flex,
  coccinelle,
  python3,
}:

stdenv.mkDerivation (finalAttrs: {
  pname = "drbd";
  version = "9.2.12";

  src = fetchurl {
    url = "https://pkg.linbit.com//downloads/drbd/9/drbd-${version}.tar.gz";
    hash = "sha256-LqK1lPucab7wKvcB4VKGdvBIq+K9XtuO2m0DP5XtK3M=";
    url = "https://pkg.linbit.com//downloads/drbd/9/drbd-${finalAttrs.version}.tar.gz";
    hash = "sha256-amdcyPTynGTaaZh558Q3KnGuGyyLJKnsY+NBCO26Jq0=";
  };

  hardeningDisable = [ "pic" ];
@@ -18,40 +27,24 @@ stdenv.mkDerivation rec {
    python3
  ];

  makeFlags = [
  enableParallelBuilding = true;

  makeFlags = kernel.makeFlags ++ [
    "KDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
    "KVER=${kernel.version}"
    "INSTALL_MOD_PATH=${placeholder "out"}"
    "M=$(sourceRoot)"
    "SPAAS=false"
  ];

  # 6.4 and newer provide a in-tree version of the handshake module https://www.kernel.org/doc/html/v6.4/networking/tls-handshake.html
  installPhase = ''
    runHook preInstall
    install -D drbd/drbd.ko -t $out/lib/modules/${kernel.modDirVersion}/kernel/drivers/block/drbd9
    install -D drbd/drbd_transport_tcp.ko -t $out/lib/modules/${kernel.modDirVersion}/kernel/drivers/block/drbd9
    install -D drbd/drbd_transport_lb-tcp.ko -t $out/lib/modules/${kernel.modDirVersion}/kernel/drivers/block/drbd9
    install -D drbd/drbd_transport_rdma.ko -t $out/lib/modules/${kernel.modDirVersion}/kernel/drivers/block/drbd9
    ${lib.optionalString (lib.versionOlder kernel.version "6.4") ''
      install -D drbd/drbd-kernel-compat/handshake/handshake.ko -t $out/lib/modules/${kernel.modDirVersion}/kernel/drivers/block/drbd9
    ''}
    runHook postInstall
  '';
  installFlags = [ "INSTALL_MOD_PATH=${placeholder "out"}" ];

  postPatch = ''
    patchShebangs .
    substituteInPlace Makefile --replace 'SHELL=/bin/bash' 'SHELL=${builtins.getEnv "SHELL"}'
  '';

  # builder.pl had complained about the same file (drbd.ko.xz) provided by two different packages
  # builder.pl also had complained about different permissions between the files from the two packages
  # The compression is required because the kernel has the CONFIG_MODULE_COMPRESS_XZ option enabled
  postFixup = ''
    for ko in $out/lib/modules/${kernel.modDirVersion}/kernel/drivers/block/drbd9/*.ko; do
      xz --compress -6 --threads=0 $ko
      chmod 0444 $ko.xz
    done
  '';

  enableParallelBuilding = true;
  passthru.tests.drbd-driver = nixosTests.drbd-driver;

  meta = with lib; {
    homepage = "https://github.com/LINBIT/drbd";
@@ -63,6 +56,5 @@ stdenv.mkDerivation rec {
      DRBD is a software-based, shared-nothing, replicated storage solution
      mirroring the content of block devices (hard disks, partitions, logical volumes, and so on) between hosts.
    '';
    broken = lib.versionAtLeast kernel.version "6.8"; # wait until next DRBD release for 6.8 support https://github.com/LINBIT/drbd/issues/87#issuecomment-2059323084
  };
}
})