about summary refs log tree commit diff
path: root/nixpkgs/pkgs/os-specific/linux/wireguard/default.nix
diff options
context:
space:
mode:
Diffstat (limited to 'nixpkgs/pkgs/os-specific/linux/wireguard/default.nix')
-rw-r--r--nixpkgs/pkgs/os-specific/linux/wireguard/default.nix31
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;
+  };
+}