Skip to content

Commit e177440

Browse files
committedMay 18, 2017
displaylink: 1.1.62 -> 1.3.52
1 parent 8e7c7af commit e177440

File tree

3 files changed

+42
-52
lines changed

3 files changed

+42
-52
lines changed
 

‎nixos/modules/hardware/video/displaylink.nix

+16-11
Original file line numberDiff line numberDiff line change
@@ -1,28 +1,28 @@
1-
{ config, lib, ... }:
1+
{ config, lib, pkgs, ... }:
22

33
with lib;
44

55
let
66

77
enabled = elem "displaylink" config.services.xserver.videoDrivers;
88

9-
displaylink = config.boot.kernelPackages.displaylink;
9+
evdi = config.boot.kernelPackages.evdi;
10+
11+
displaylink = pkgs.displaylink.override {
12+
inherit evdi;
13+
};
1014

1115
in
1216

1317
{
1418

1519
config = mkIf enabled {
1620

17-
boot.extraModulePackages = [ displaylink ];
18-
19-
boot.kernelModules = [ "evdi" ];
21+
boot.extraModulePackages = [ evdi ];
2022

2123
# Those are taken from displaylink-installer.sh and from Arch Linux AUR package.
2224

23-
services.udev.extraRules = ''
24-
ACTION=="add", SUBSYSTEM=="usb", ATTR{idVendor}=="17e9", ATTR{bNumInterfaces}=="*5", TAG+="uaccess"
25-
'';
25+
services.udev.packages = [ displaylink ];
2626

2727
powerManagement.powerDownCommands = ''
2828
#flush any bytes in pipe
@@ -32,18 +32,22 @@ in
3232
echo "S" > /tmp/PmMessagesPort_in
3333
3434
#wait until suspend of DisplayLinkManager finish
35-
read -n 1 -t 10 SUSPEND_RESULT < /tmp/PmMessagesPort_out
35+
if [ -f /tmp/PmMessagesPort_out ]; then
36+
#wait until suspend of DisplayLinkManager finish
37+
read -n 1 -t 10 SUSPEND_RESULT < /tmp/PmMessagesPort_out
38+
fi
3639
'';
3740

3841
powerManagement.resumeCommands = ''
3942
#resume DisplayLinkManager
4043
echo "R" > /tmp/PmMessagesPort_in
4144
'';
4245

43-
systemd.services.displaylink = {
46+
systemd.services.dlm = {
4447
description = "DisplayLink Manager Service";
4548
after = [ "display-manager.service" ];
46-
wantedBy = [ "graphical.target" ];
49+
conflicts = [ "getty@tty7.service" ];
50+
path = [ pkgs.kmod ];
4751

4852
serviceConfig = {
4953
ExecStart = "${displaylink}/bin/DisplayLinkManager";
@@ -53,6 +57,7 @@ in
5357

5458
preStart = ''
5559
mkdir -p /var/log/displaylink
60+
modprobe evdi
5661
'';
5762
};
5863

‎pkgs/os-specific/linux/displaylink/default.nix

+22-39
Original file line numberDiff line numberDiff line change
@@ -1,64 +1,47 @@
1-
{ stdenv, lib, fetchurl, fetchFromGitHub, unzip, kernel, utillinux, libdrm, libusb1, makeWrapper }:
1+
{ stdenv, lib, fetchurl, unzip, utillinux, libusb1, evdi, systemd, makeWrapper }:
22

33
let
44
arch =
55
if stdenv.system == "x86_64-linux" then "x64"
66
else if stdenv.system == "i686-linux" then "x86"
77
else throw "Unsupported architecture";
8-
libPath = lib.makeLibraryPath [ stdenv.cc.cc utillinux libusb1 ];
8+
bins = "${arch}-ubuntu-1604";
9+
libPath = lib.makeLibraryPath [ stdenv.cc.cc utillinux libusb1 evdi ];
910

1011
in stdenv.mkDerivation rec {
1112
name = "displaylink-${version}";
12-
version = "1.1.62";
13+
version = "1.3.52";
1314

14-
src = fetchFromGitHub {
15-
owner = "DisplayLink";
16-
repo = "evdi";
17-
rev = "fe779940ff9fc7b512019619e24a5b22e4070f6a";
18-
sha256 = "02hw83f6lscms8hssjzf30hl9zly3b28qcxwmxvnqwfhx1q491z9";
19-
};
20-
21-
daemon = fetchurl {
15+
src = fetchurl {
2216
name = "displaylink.zip";
23-
url = "http://www.displaylink.com/downloads/file?id=607";
24-
sha256 = "0jky3xk4dfzbzg386qya9l9952i4m8zhf55fdl06pi9r82k2iijx";
17+
url = "http://www.displaylink.com/downloads/file?id=744";
18+
sha256 = "0ridpsxcf761vym0nlpq702qa46ynddzci17bjmyax2pph7khr0k";
2519
};
2620

2721
nativeBuildInputs = [ unzip makeWrapper ];
2822

29-
buildInputs = [ kernel libdrm ];
30-
3123
buildCommand = ''
32-
unpackPhase
33-
cd $sourceRoot
34-
unzip $daemon
24+
unzip $src
3525
chmod +x displaylink-driver-${version}.run
36-
./displaylink-driver-${version}.run --target daemon --noexec
26+
./displaylink-driver-${version}.run --target . --noexec
3727
38-
( cd module
39-
export makeFlags="$makeFlags KVER=${kernel.modDirVersion} KDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
40-
export hardeningDisable="pic format"
41-
buildPhase
42-
install -Dm755 evdi.ko $out/lib/modules/${kernel.modDirVersion}/kernel/drivers/gpu/drm/evdi/evdi.ko
28+
sed -i "s,/opt/displaylink/udev.sh,$out/lib/udev/displaylink.sh,g" udev-installer.sh
29+
( source udev-installer.sh
30+
mkdir -p $out/lib/udev/rules.d
31+
main systemd "$out/lib/udev/rules.d/99-displaylink.rules" "$out/lib/udev/displaylink.sh"
4332
)
33+
sed -i '2iPATH=${systemd}/bin:$PATH' $out/lib/udev/displaylink.sh
4434
45-
( cd library
46-
buildPhase
47-
install -Dm755 libevdi.so $out/lib/libevdi.so
48-
)
35+
install -Dt $out/lib/displaylink *.spkg
36+
install -Dm755 ${bins}/DisplayLinkManager $out/bin/DisplayLinkManager
37+
patchelf \
38+
--set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) \
39+
--set-rpath ${libPath} \
40+
$out/bin/DisplayLinkManager
41+
wrapProgram $out/bin/DisplayLinkManager \
42+
--run "cd $out/lib/displaylink"
4943
5044
fixupPhase
51-
52-
( cd daemon
53-
install -Dt $out/lib/displaylink *.spkg
54-
install -Dm755 ${arch}/DisplayLinkManager $out/bin/DisplayLinkManager
55-
patchelf \
56-
--set-interpreter $(cat ${stdenv.cc}/nix-support/dynamic-linker) \
57-
--set-rpath $out/lib:${libPath} \
58-
$out/bin/DisplayLinkManager
59-
wrapProgram $out/bin/DisplayLinkManager \
60-
--run "cd $out/lib/displaylink"
61-
)
6245
'';
6346

6447
meta = with stdenv.lib; {

‎pkgs/top-level/all-packages.nix

+4-2
Original file line numberDiff line numberDiff line change
@@ -11516,6 +11516,10 @@ with pkgs;
1151611516

1151711517
disk_indicator = callPackage ../os-specific/linux/disk-indicator { };
1151811518

11519+
displaylink = callPackage ../os-specific/linux/displaylink {
11520+
inherit (linuxPackages) evdi;
11521+
};
11522+
1151911523
dmidecode = callPackage ../os-specific/linux/dmidecode { };
1152011524

1152111525
dmtcp = callPackage ../os-specific/linux/dmtcp { };
@@ -11878,8 +11882,6 @@ with pkgs;
1187811882

1187911883
cpupower = callPackage ../os-specific/linux/cpupower { };
1188011884

11881-
displaylink = callPackage ../os-specific/linux/displaylink { };
11882-
1188311885
dpdk = callPackage ../os-specific/linux/dpdk { };
1188411886

1188511887
exfat-nofuse = callPackage ../os-specific/linux/exfat { };

0 commit comments

Comments
 (0)
Please sign in to comment.