diff options
Diffstat (limited to 'nixpkgs/pkgs/os-specific/linux/wireguard/default.nix')
-rw-r--r-- | nixpkgs/pkgs/os-specific/linux/wireguard/default.nix | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/os-specific/linux/wireguard/default.nix b/nixpkgs/pkgs/os-specific/linux/wireguard/default.nix new file mode 100644 index 000000000000..e103de3e1b71 --- /dev/null +++ b/nixpkgs/pkgs/os-specific/linux/wireguard/default.nix @@ -0,0 +1,31 @@ +{ stdenv, kernel, wireguard-tools, perl }: + +# module requires Linux >= 3.10 https://www.wireguard.io/install/#kernel-requirements +assert stdenv.lib.versionAtLeast kernel.version "3.10"; + +stdenv.mkDerivation rec { + name = "wireguard-${version}"; + inherit (wireguard-tools) src version; + + preConfigure = '' + cd src + sed -i '/depmod/,+1d' Makefile + ''; + + hardeningDisable = [ "pic" ]; + + KERNELDIR = "${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"; + INSTALL_MOD_PATH = "\${out}"; + + NIX_CFLAGS = ["-Wno-error=cpp"]; + + nativeBuildInputs = [ perl ] ++ kernel.moduleBuildDependencies; + + buildPhase = "make module"; + + meta = with stdenv.lib; { + inherit (wireguard-tools.meta) homepage license maintainers; + description = "Kernel module for the WireGuard secure network tunnel"; + platforms = platforms.linux; + }; +} |