Difference between revisions of "Laptop Dell XPS 15"
(Created page with " Notes about installing a Debian Stretch on a Dell XPS 15 ==Hardware== Dell XPS 15 model 9550 (variant with touchscreen & PCIe m.2 ssd) From the [http://www.dell.com/support/...") |
m |
||
(114 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
Notes about installing a Debian Stretch on a Dell XPS 15 |
Notes about installing a Debian Stretch on a Dell XPS 15 |
||
+ | |||
==Hardware== |
==Hardware== |
||
Dell XPS 15 model 9550 (variant with touchscreen & PCIe m.2 ssd) |
Dell XPS 15 model 9550 (variant with touchscreen & PCIe m.2 ssd) |
||
Line 20: | Line 21: | ||
* nVIDIA Geforce GTX 960M Graphics |
* nVIDIA Geforce GTX 960M Graphics |
||
From dmesg (incomplete): |
From dmesg (incomplete): |
||
− | * |
+ | * BCM20703A1 Bluetooth 4.1 (firmware brcm/BCM-0a5c-6410.hcd) |
− | From lspci: |
+ | From lspci -nn: |
<pre> |
<pre> |
||
− | 00:00.0 Host bridge: Intel Corporation Sky Lake Host Bridge/DRAM Registers (rev 07) |
+ | 00:00.0 Host bridge [0600]: Intel Corporation Sky Lake Host Bridge/DRAM Registers [8086:1910] (rev 07) |
− | 00:01.0 PCI bridge: Intel Corporation Sky Lake PCIe Controller (x16) (rev 07) |
+ | 00:01.0 PCI bridge [0604]: Intel Corporation Sky Lake PCIe Controller (x16) [8086:1901] (rev 07) |
− | 00:02.0 VGA compatible controller: Intel Corporation Device 191b (rev 06) |
+ | 00:02.0 VGA compatible controller [0300]: Intel Corporation Device [8086:191b] (rev 06) |
− | 00:04.0 Signal processing controller: Intel Corporation Device 1903 (rev 07) |
+ | 00:04.0 Signal processing controller [1180]: Intel Corporation Device [8086:1903] (rev 07) |
− | 00:14.0 USB controller: Intel Corporation Sunrise Point-H USB 3.0 xHCI Controller (rev 31) |
+ | 00:14.0 USB controller [0c03]: Intel Corporation Sunrise Point-H USB 3.0 xHCI Controller [8086:a12f] (rev 31) |
− | 00:14.2 Signal processing controller: Intel Corporation Sunrise Point-H Thermal subsystem (rev 31) |
+ | 00:14.2 Signal processing controller [1180]: Intel Corporation Sunrise Point-H Thermal subsystem [8086:a131] (rev 31) |
− | 00:15.0 Signal processing controller: Intel Corporation Sunrise Point-H LPSS I2C Controller #0 (rev 31) |
+ | 00:15.0 Signal processing controller [1180]: Intel Corporation Sunrise Point-H LPSS I2C Controller #0 [8086:a160] (rev 31) |
− | 00:15.1 Signal processing controller: Intel Corporation Sunrise Point-H LPSS I2C Controller #1 (rev 31) |
+ | 00:15.1 Signal processing controller [1180]: Intel Corporation Sunrise Point-H LPSS I2C Controller #1 [8086:a161] (rev 31) |
− | 00:16.0 Communication controller: Intel Corporation Sunrise Point-H CSME HECI #1 (rev 31) |
+ | 00:16.0 Communication controller [0780]: Intel Corporation Sunrise Point-H CSME HECI #1 [8086:a13a] (rev 31) |
− | 00:17.0 SATA controller: Intel Corporation Sunrise Point-H SATA Controller [AHCI mode] (rev 31) |
+ | 00:17.0 SATA controller [0106]: Intel Corporation Sunrise Point-H SATA Controller [AHCI mode] [8086:a103] (rev 31) |
− | 00:1c.0 PCI bridge: Intel Corporation Sunrise Point-H PCI Express Root Port #1 (rev f1) |
+ | 00:1c.0 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #1 [8086:a110] (rev f1) |
− | 00:1c.1 PCI bridge: Intel Corporation Sunrise Point-H PCI Express Root Port #2 (rev f1) |
+ | 00:1c.1 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #2 [8086:a111] (rev f1) |
− | 00:1d.0 PCI bridge: Intel Corporation Sunrise Point-H PCI Express Root Port #9 (rev f1) |
+ | 00:1d.0 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #9 [8086:a118] (rev f1) |
− | 00:1d.4 PCI bridge: Intel Corporation Sunrise Point-H PCI Express Root Port #13 (rev f1) |
+ | 00:1d.4 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #13 [8086:a11c] (rev f1) |
− | 00:1d.6 PCI bridge: Intel Corporation Sunrise Point-H PCI Express Root Port #15 (rev f1) |
+ | 00:1d.6 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #15 [8086:a11e] (rev f1) |
− | 00:1f.0 ISA bridge: Intel Corporation Sunrise Point-H LPC Controller (rev 31) |
+ | 00:1f.0 ISA bridge [0601]: Intel Corporation Sunrise Point-H LPC Controller [8086:a14e] (rev 31) |
− | 00:1f.2 Memory controller: Intel Corporation Sunrise Point-H PMC (rev 31) |
+ | 00:1f.2 Memory controller [0580]: Intel Corporation Sunrise Point-H PMC [8086:a121] (rev 31) |
− | 00:1f.3 Audio device: Intel Corporation Sunrise Point-H HD Audio (rev 31) |
+ | 00:1f.3 Audio device [0403]: Intel Corporation Sunrise Point-H HD Audio [8086:a170] (rev 31) |
− | 00:1f.4 SMBus: Intel Corporation Sunrise Point-H SMBus (rev 31) |
+ | 00:1f.4 SMBus [0c05]: Intel Corporation Sunrise Point-H SMBus [8086:a123] (rev 31) |
− | 01:00.0 3D controller: NVIDIA Corporation GM107M [GeForce GTX 960M] (rev |
+ | 01:00.0 3D controller [0302]: NVIDIA Corporation GM107M [GeForce GTX 960M] [10de:139b] (rev ff) |
− | 02:00.0 Network controller: Broadcom Corporation BCM43602 802.11ac Wireless LAN SoC (rev 01) |
+ | 02:00.0 Network controller [0280]: Broadcom Corporation BCM43602 802.11ac Wireless LAN SoC [14e4:43ba] (rev 01) |
− | 03:00.0 Unassigned class [ff00]: Realtek Semiconductor Co., Ltd. Device 525a (rev 01) |
+ | 03:00.0 Unassigned class [ff00]: Realtek Semiconductor Co., Ltd. Device [10ec:525a] (rev 01) |
− | 04:00.0 Non-Volatile memory controller: Samsung Electronics Co Ltd Device a802 (rev 01) |
+ | 04:00.0 Non-Volatile memory controller [0108]: Samsung Electronics Co Ltd Device [144d:a802] (rev 01) |
</pre> |
</pre> |
||
From lsusb: |
From lsusb: |
||
Line 55: | Line 56: | ||
Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub |
Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub |
||
</pre> |
</pre> |
||
+ | |||
+ | From lscpu: |
||
+ | <pre> |
||
+ | Architecture: x86_64 |
||
+ | CPU op-mode(s): 32-bit, 64-bit |
||
+ | Byte Order: Little Endian |
||
+ | CPU(s): 8 |
||
+ | On-line CPU(s) list: 0-7 |
||
+ | Thread(s) per core: 2 |
||
+ | Core(s) per socket: 4 |
||
+ | Socket(s): 1 |
||
+ | NUMA node(s): 1 |
||
+ | Vendor ID: GenuineIntel |
||
+ | CPU family: 6 |
||
+ | Model: 94 |
||
+ | Model name: Intel(R) Core(TM) i7-6700HQ CPU @ 2.60GHz |
||
+ | Stepping: 3 |
||
+ | CPU MHz: 2847.812 |
||
+ | CPU max MHz: 3500.0000 |
||
+ | CPU min MHz: 800.0000 |
||
+ | BogoMIPS: 5183.88 |
||
+ | Virtualization: VT-x |
||
+ | L1d cache: 32K |
||
+ | L1i cache: 32K |
||
+ | L2 cache: 256K |
||
+ | L3 cache: 6144K |
||
+ | NUMA node0 CPU(s): 0-7 |
||
+ | Flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush |
||
+ | dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts |
||
+ | rep_good nopl xtopology nonstop_tsc aperfmperf eagerfpu pni pclmulqdq dtes64 monitor ds_cpl vmx est tm2 |
||
+ | ssse3 sdbg fma cx16 xtpr pdcm pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx |
||
+ | f16c rdrand lahf_lm abm 3dnowprefetch ida arat epb pln pts dtherm hwp hwp_notify hwp_act_window hwp_epp |
||
+ | intel_pt tpr_shadow vnmi flexpriority ept vpid fsgsbase tsc_adjust bmi1 hle avx2 smep bmi2 erms invpcid |
||
+ | rtm mpx rdseed adx smap clflushopt xsaveopt xsavec xgetbv1 |
||
+ | </pre> |
||
+ | |||
+ | Dell Wireless 1830 = BCM43602 + BCM20703A1 (DW1830 Bluetooth 4.1 LE) |
||
+ | |||
+ | BCM43602 PCI ID: 14e4:43ba |
||
+ | |||
+ | <pre> |
||
+ | # smartctl -d scsi -i /dev/nvme0n1 |
||
+ | smartctl 6.4 2015-06-04 r4109 [x86_64-linux-4.3.0-1-amd64] (local build) |
||
+ | Copyright (C) 2002-15, Bruce Allen, Christian Franke, www.smartmontools.org |
||
+ | |||
+ | === START OF INFORMATION SECTION === |
||
+ | Vendor: NVMe |
||
+ | Product: PM951 NVMe SAMSU |
||
+ | Revision: 7D0Q |
||
+ | Compliance: SPC-4 |
||
+ | User Capacity: 1,024,209,543,168 bytes [1.02 TB] |
||
+ | Logical block size: 512 bytes |
||
+ | Rotation Rate: Solid State Device |
||
+ | Logical Unit id: 0x0025384cf1b0fd29 |
||
+ | Serial number: S2FZNXAGC03824 |
||
+ | Device type: disk |
||
+ | Local Time is: Sun Feb 14 22:02:03 2016 CET |
||
+ | SMART support is: Unavailable - device lacks SMART capability. |
||
+ | </pre> |
||
+ | |||
==Resources== |
==Resources== |
||
+ | * http://topics-cdn.dell.com/pdf/xps-15-9550-laptop_Service%20Manual_en-us.pdf |
||
* https://wiki.archlinux.org/index.php/Dell_XPS_15 |
* https://wiki.archlinux.org/index.php/Dell_XPS_15 |
||
* https://bbs.archlinux.org/viewtopic.php?id=204739 |
* https://bbs.archlinux.org/viewtopic.php?id=204739 |
||
Line 61: | Line 123: | ||
* http://forthescience.org/blog/2015/03/20/installing_ubuntu_14_04_on_the_new_dell_xps_13/ |
* http://forthescience.org/blog/2015/03/20/installing_ubuntu_14_04_on_the_new_dell_xps_13/ |
||
* https://wiki.debian.org/InstallingDebianOn/Dell/Dell%20XPS%2013 |
* https://wiki.debian.org/InstallingDebianOn/Dell/Dell%20XPS%2013 |
||
+ | * http://bartongeorge.net/2015/02/23/update-2-dell-xps-13-laptop-developer-edition-sputnik-gen-4/ |
||
+ | |||
==General== |
==General== |
||
I first tried to keep a dual-boot just in case, but once we disable Raid and put SATA in AHCI mode, Windows can't boot anymore. (later I read it could be possible to fix it by rebooting several times Windows till safe mode is kicked in, but it was too late for me.) |
I first tried to keep a dual-boot just in case, but once we disable Raid and put SATA in AHCI mode, Windows can't boot anymore. (later I read it could be possible to fix it by rebooting several times Windows till safe mode is kicked in, but it was too late for me.) |
||
Line 66: | Line 130: | ||
Just in case again, one can boot Windows and create a USB recovery. |
Just in case again, one can boot Windows and create a USB recovery. |
||
==Bios== |
==Bios== |
||
− | * Secure Boot: disable |
+ | * '''Secure Boot: disable''' |
− | * SATA: switch from Raid to AHCI |
+ | * '''SATA: switch from Raid to AHCI''' |
+ | * '''Advances Boot Options:/ NOT Enable Legacy Option ROMs''' |
||
* Boot: not sure it's needed but I disabled Windows boot manager entry and kept the hdd UEFI entry: UEFI: PM951 NVMe SAMSUNG 1024GB, Partition 1 |
* Boot: not sure it's needed but I disabled Windows boot manager entry and kept the hdd UEFI entry: UEFI: PM951 NVMe SAMSUNG 1024GB, Partition 1 |
||
+ | ** See below (first boot) how to create a new entry |
||
− | * POST/Fastboot/Thorough |
||
+ | * POST/Fastboot/Auto |
||
* auto os recovery threshold off |
* auto os recovery threshold off |
||
+ | * Fn Lock Options |
||
+ | ** NOT Fn Lock |
||
+ | ** Lock Mode Enable/Secondary |
||
+ | * UEFI Capsule Firmware Updates / Enable |
||
+ | ** This allows using ``fwupdmgr update`` e.g. to update the TPM firmware |
||
+ | |||
+ | To update the BIOS: |
||
+ | * put it on a USB stick |
||
+ | * reboot |
||
+ | * select BIOS flash update on the boot screen (F12). |
||
+ | No need to put it on a bootable DOS, just give the exe to the BIOS update built-in util. |
||
+ | <br>You can even drop the update on /boot/efi as it's also a FAT partition, no need for a USB memory stick. |
||
+ | |||
+ | Versions: |
||
+ | * 1.2.0 aka A6 [https://downloads.dell.com/FOLDER03659467M/1/XPS_9550_1.2.0.exe XPS_9550_1.2.0.exe] [http://www.dell.com/support/home/us/en/04/Drivers/DriversDetails?driverId=KTR76 fixes] |
||
+ | * 1.2.10 aka A10 [https://downloads.dell.com/FOLDER03800340M/1/XPS_9550_1.2.10.exe XPS_9550_1.2.10.exe] [http://www.dell.com/support/home/us/en/04/Drivers/DriversDetails?driverId=96T2K fixes] |
||
+ | * 1.2.14 aka A13 [https://downloads.dell.com/FOLDER03906323M/1/XPS_9550_1.2.14.exe XPS_9550_1.2.14.exe] [http://www.dell.com/support/home/us/en/04/Drivers/DriversDetails?driverId=VNMDK fixes] |
||
+ | * 1.2.16 [https://downloads.dell.com/FOLDER04030973M/1/XPS_9550_1.2.16.exe XPS_9550_1.2.16.exe] [http://www.dell.com/support/home/us/en/04/Drivers/DriversDetails?driverId=J8GY6 fixes] |
||
+ | * 1.2.18 aka A16 [https://downloads.dell.com/FOLDER04078627M/1/XPS_9550_1.2.18.exe XPS_9550_1.2.18.exe] [http://www.dell.com/support/home/us/en/4/Drivers/DriversDetails?driverId=KD0C7 fixes] |
||
+ | * 1.2.21 [https://downloads.dell.com/FOLDER04190863M/1/XPS_9550_1.2.21.exe XPS_9550_1.2.21.exe] [http://www.dell.com/support/home/us/en/04/Drivers/DriversDetails?driverId=6RV34 fixes] |
||
+ | * 1.2.25 [https://downloads.dell.com/FOLDER04319442M/1/XPS_9550_1.2.25.exe XPS_9550_1.2.25.exe] [http://www.dell.com/support/home/us/en/04/Drivers/DriversDetails?driverId=3W30W fixes] |
||
+ | * 1.2.29 [https://downloads.dell.com/FOLDER04449988M/1/XPS_9550_1.2.29.exe XPS_9550_1.2.29.exe] [http://www.dell.com/support/Home/us/en/19/Drivers/DriversDetails?driverId=F7M6G fixes] |
||
+ | * 1.3.0 [https://downloads.dell.com/FOLDER04481870M/1/XPS_9550_1.3.0.exe XPS_9550_1.3.0.exe] [http://www.dell.com/support/Home/us/en/19/Drivers/DriversDetails?driverId=NXVMP fixes] |
||
+ | * 1.4.0 [https://downloads.dell.com/FOLDER04499656M/1/XPS_9550_1.4.0.exe XPS_9550_1.4.0.exe] [http://www.dell.com/support/Home/us/en/19/Drivers/DriversDetails?driverId=DR9N6 fixes] |
||
+ | * 1.5.1 [https://downloads.dell.com/FOLDER04604618M/1/XPS_9550_1.5.1.exe XPS_9550_1.5.1.exe] [http://www.dell.com/support/Home/en/us/bebsdt1/Drivers/DriversDetails?driverId=TWKFC fixes] |
||
+ | * 1.6.1 [https://downloads.dell.com/FOLDER04717493M/1/XPS_9550_1.6.1.exe XPS_9550_1.6.1.exe] [http://www.dell.com/support/Home/en/us/bebsdt1/Drivers/DriversDetails?driverId=PFJ08 fixes] |
||
+ | * 1.7.0 [https://downloads.dell.com/FOLDER04839266M/1/XPS_9550_1.7.0.exe XPS_9550_1.7.0.exe] [http://www.dell.com/support/home/us/en/04/drivers/driversdetails?driverId=RYY62 fixes] |
||
+ | * 1.8.0 [https://downloads.dell.com/FOLDER05099834M/1/XPS_9550_1.8.0.exe XPS_9550_1.8.0.exe] [http://www.dell.com/support/home/us/en/04/drivers/driversdetails?driverId=4GDY8 fixes] |
||
+ | * 1.9.0 [https://downloads.dell.com/FOLDER05256907M/1/XPS_9550_1.9.0.exe XPS_9550_1.9.0.exe] [http://www.dell.com/support/home/us/en/04/drivers/driversdetails?driverId=xv1gp fixes] |
||
+ | * 1.10.0 [https://downloads.dell.com/FOLDER05476993M/1/XPS_9550_1.10.0.exe XPS_9550_1.10.0.exe] [http://www.dell.com/support/home/us/en/04/drivers/driversdetails?driverId=3N7TY fixes] |
||
+ | * 1.11.2 [https://downloads.dell.com/FOLDER05770328M/1/XPS_9550_1.11.2.exe XPS_9550_1.11.2.exe] [https://www.dell.com/support/home/us/en/04/drivers/driversdetails?driverid=gtm85 fixes] |
||
+ | * 1.12.0 [https://downloads.dell.com/FOLDER05865451M/1/XPS_9550_1.12.0.exe XPS_9550_1.12.0.exe] [https://www.dell.com/support/home/us/en/04/drivers/driversdetails?driverid=7HTW2 fixes] |
||
+ | * 1.13.1 [https://dl.dell.com/FOLDER06021536M/1/XPS_9550_1.13.1.exe XPS_9550_1.13.1.exe] [https://www.dell.com/support/home/us/en/04/drivers/driversdetails?driverid=3hr07 fixes] |
||
+ | * 1.14.0 [https://dl.dell.com/FOLDER06130362M/1/XPS_9550_1.14.0.exe XPS_9550_1.14.0.exe] [https://www.dell.com/support/home/us/en/04/drivers/driversdetails?driverid=90khw fixes] |
||
+ | |||
+ | Attention: with versions 1.2.10 through 1.2.16 and older Linux kernels, there is a serious bug that let the screen black after suspend/wake up. The workaround is to set the lightness to the maximum but it breaks further lightness tuning. |
||
+ | |||
+ | Linux kernels 4.8 and below tend to work best with A6 BIOS (1.2.0), although there is a workaround that allows it to work with later versions. This workaround uses the intel_reg utility to reset the "pwm_granuality" setting of the onboard graphics. Solution discussed here: [http://en.community.dell.com/techcenter/os-applications/f/4613/t/19985320]. This issue is reportedly fixed in Linux 4.9, and also in recent Ubuntu 16.10 kernel updates. See the patch here [https://patchwork.freedesktop.org/patch/109407/]. |
||
+ | |||
+ | Even with the intel_reg workaround above, the screen brightness cannot be set to the lowest level without turning the screen off. This is fixed in 1.2.18. |
||
− | I upgraded the BIOS afterwards, no idea if it would have helped if done before the installation... |
||
− | <br>Grab it [http://www.dell.com/support/home/fr/fr/frdhs1/Drivers/DriversDetails?driverId=HTCD4&fileId=3514387044&osCode=WT64A&productCode=xps-15-9550-laptop&languageCode=FR,EN&categoryId=BI&DCP=DNDTAG here], put it on a USB stick, reboot and select BIOS update on the boot screen (F12). |
||
− | <br>No need to put it on a bootable DOS, just give the exe to the BIOS update built-in util. |
||
==Debian== |
==Debian== |
||
I kept UEFI so we need a Debian netinstall because liveCD doesn't have UEFI support yet. |
I kept UEFI so we need a Debian netinstall because liveCD doesn't have UEFI support yet. |
||
Line 94: | Line 197: | ||
sgdisk --backup=/some/safe/location/nvme0n1.gpt /dev/nvme0n1 |
sgdisk --backup=/some/safe/location/nvme0n1.gpt /dev/nvme0n1 |
||
I installed Cinnamon. I don't know for the others but Cinnamon has a nice auto setting to double features on HiDPI screens. |
I installed Cinnamon. I don't know for the others but Cinnamon has a nice auto setting to double features on HiDPI screens. |
||
+ | |||
+ | ===Gnome=== |
||
+ | Update: now using Gnome3. |
||
+ | Needs to replace lightdm by gdm3 to get newer lock screen (gnome-screensaver is deprecated) |
||
+ | <pre> |
||
+ | sudo dpkg-reconfigure gdm3 |
||
+ | (choose gdm3) |
||
+ | # delay before blanking, in seconds: |
||
+ | gsettings set org.gnome.desktop.session idle-delay 300 |
||
+ | # delay after blanking before locking, in seconds: |
||
+ | gsettings set org.gnome.desktop.screensaver lock-delay 10 |
||
+ | (reboot) |
||
+ | </pre> |
||
+ | Sometimes after a crash, gnome extensions (https://extensions.gnome.org/local/) are disabled. To reenable them: |
||
+ | <pre> |
||
+ | dconf write /org/gnome/shell/disable-user-extensions false |
||
+ | </pre> |
||
+ | ===Wayland=== |
||
+ | Got quite some troubles with Wayland, so I reverted it back to X11: |
||
+ | |||
+ | Edit /etc/gdm3/daemon.conf and uncomment line: |
||
+ | WaylandEnable=false |
||
+ | |||
==First boot== |
==First boot== |
||
Once installed, the Debian didn't boot up. |
Once installed, the Debian didn't boot up. |
||
Line 115: | Line 241: | ||
* [http://www.rodsbooks.com/refind/getting.html Refind] couldn't boot at all. Strange as the netinstall could boot... |
* [http://www.rodsbooks.com/refind/getting.html Refind] couldn't boot at all. Strange as the netinstall could boot... |
||
* tweaks with efibootmgr, update-grub etc |
* tweaks with efibootmgr, update-grub etc |
||
+ | |||
+ | '''UPDATE''': It might be possible to fix the issue from the BIOS itself, see http://www.dell.com/support/article/us/en/04/SLN297060/en |
||
+ | * Boot Sequence / Add Boot Option |
||
+ | ** Boot Option Name : Debian |
||
+ | ** File System List : PciRoot(0x0)/Pic(0x1D,0x0)/Pci(0x0,0x0)/?/HD(1,GPT,<UUID>) |
||
+ | ** File Name : FS0 - EFI - debian - grubx64.efi |
||
+ | * Advances Boot Options / NOT Enable Legacy Option ROMs |
||
==Status== |
==Status== |
||
Line 125: | Line 258: | ||
* HDMI |
* HDMI |
||
* SD-Card reader |
* SD-Card reader |
||
− | * Speakers |
+ | * Speakers, mic |
* Webcam |
* Webcam |
||
+ | |||
===Working after manual steps=== |
===Working after manual steps=== |
||
====i915==== |
====i915==== |
||
Line 133: | Line 267: | ||
So I installed that firmware, not sure what it's changed |
So I installed that firmware, not sure what it's changed |
||
sudo apt-get install firmware-misc-nonfree |
sudo apt-get install firmware-misc-nonfree |
||
− | ====Optimus==== |
+ | ====Optimus & CUDA==== |
Resources: |
Resources: |
||
* https://wiki.archlinux.org/index.php/Optimus |
* https://wiki.archlinux.org/index.php/Optimus |
||
* https://wiki.archlinux.org/index.php/Bumblebee |
* https://wiki.archlinux.org/index.php/Bumblebee |
||
− | apt-get install bumblebee-nvidia |
+ | apt-get install bumblebee-nvidia nvidia-cuda-toolkit mesa-utils |
reboot |
reboot |
||
+ | Examples: |
||
− | Example: |
||
− | apt-get install nvidia-settings |
||
optirun -b none nvidia-settings -c :8 |
optirun -b none nvidia-settings -c :8 |
||
+ | optirun -vv glxgears |
||
− | This also works for CUDA: |
||
+ | optirun -vv clinfo |
||
− | optirun -b none ./cudaHashcat64.bin -m 500 example500.hash example.dict |
||
+ | optirun -b none ./hashcat64.bin -I |
||
+ | optirun --no-xorg ./hashcat64.bin -I |
||
+ | optirun -b none ./hashcat.bin -m 500 example500.hash example.dict |
||
+ | GPU load: |
||
+ | optirun --no-xorg nvidia-smi |
||
+ | |||
+ | As bridge, primus or virtualgl can be used. Primus is available in the Debian repos while VirtualGL is [https://sourceforge.net/projects/virtualgl/?source=typ_redirect here]. Using primus currently. |
||
+ | |||
====Touchpad==== |
====Touchpad==== |
||
Nothing wrong with the touchpad but its default config is a bit painful especially because it's large and my right palm touches it often, even with the option to diable it when typing and because it's "soft" buttons. |
Nothing wrong with the touchpad but its default config is a bit painful especially because it's large and my right palm touches it often, even with the option to diable it when typing and because it's "soft" buttons. |
||
Line 160: | Line 301: | ||
synclient CircularScrolling=1 |
synclient CircularScrolling=1 |
||
Some doc [https://wiki.archlinux.org/index.php/Touchpad_Synaptics#Buttonless_touchpads_.28aka_ClickPads.29 here] and the official one [http://www.x.org/archive/X11R7.5/doc/man/man4/synaptics.4.html here] |
Some doc [https://wiki.archlinux.org/index.php/Touchpad_Synaptics#Buttonless_touchpads_.28aka_ClickPads.29 here] and the official one [http://www.x.org/archive/X11R7.5/doc/man/man4/synaptics.4.html here] |
||
+ | |||
+ | If with some kernels you get troubles using Synaptics options, check dmesg, maybe Touchpad is detected by another driver too: |
||
+ | DLL06E4:01 06CB:7A13 Touchpad as /devices/pci0000:00/0000:00:15.1/i2c_designware.1/i2c-7/i2c-DLL06E4:01/0018:06CB:7A13.0003/input/input14 |
||
+ | hid-multitouch 0018:06CB:7A13.0003: input,hidraw2: I2C HID v1.00 Mouse [DLL06E4:01 06CB:7A13] on i2c-DLL06E4:01 |
||
+ | If this is so, add /etc/modprobe.d/synaptics.conf with this line, cf Kernel section below: |
||
+ | blacklist i2c-designware-platform |
||
+ | |||
+ | On recent kernels, i2c-designware-platform is directly in the kernel, not as module anymore. |
||
+ | To manage to blacklist it, see https://unix.stackexchange.com/questions/423797/how-do-i-disable-i2c-designware-support-when-its-not-built-as-a-module#446913 |
||
+ | Edit /etc/default/grub and append the following blacklist invocation to the command line, then update-grub. |
||
+ | GRUB_CMDLINE_LINUX_DEFAULT="… initcall_blacklist=dw_i2c_init_driver" |
||
+ | |||
+ | ====Touchscreen==== |
||
+ | Touchscreen works well but when an external screen is connected, it spans over both screens so e.g. touching the middle of the laptop screen moves the mouse to some middle point of the virtual screen combining both screens. |
||
+ | <br>To fix it, see https://wiki.archlinux.org/index.php/Calibrating_Touchscreen |
||
+ | <br>This example is for an external screen mapped to the right of the laptop screen: |
||
+ | # c0 = width of laptop screen / total width |
||
+ | c0=$(bc -l <<< "scale=2; $(xrandr|grep -A1 eDP1|sed '1d;s/x.*//')/$(xrandr|grep '^Screen 0'|sed 's/.*current //;s/ x.*//')") |
||
+ | xinput set-prop "ELAN Touchscreen" --type=float "Coordinate Transformation Matrix" \ |
||
+ | c0 0 0 \ |
||
+ | 0 1 0 \ |
||
+ | 0 0 1 |
||
+ | |||
====Bluetooth==== |
====Bluetooth==== |
||
Kernel complains about a missing file. |
Kernel complains about a missing file. |
||
Line 174: | Line 338: | ||
* https://wiki.archlinux.org/index.php/bluetooth |
* https://wiki.archlinux.org/index.php/bluetooth |
||
There is also a possibility to pair directly from bluetoothctl, see https://wiki.archlinux.org/index.php/bluetooth#Bluetoothctl |
There is also a possibility to pair directly from bluetoothctl, see https://wiki.archlinux.org/index.php/bluetooth#Bluetoothctl |
||
+ | |||
− | ====Small console font==== |
||
+ | I finally changed the Wi-Fi+BT card for an Intel one, see [[#Hardware_changes]] |
||
− | I don't care but if that's an issue for you, from [https://github.com/mpalourdio/xps13/blob/master/HiDPI/tty.md here]: |
||
+ | |||
+ | ====HiDPI==== |
||
+ | Cinnamon handles it nicely but some applications don't such as Gimp and you end up with a microscopic tools ribbon. |
||
+ | <br>See https://wiki.archlinux.org/index.php/HiDPI for some useful tips |
||
+ | |||
+ | Cinnamon / System Settings / Desktop Scaling has the same effect as `gsettings set org.cinnamon.desktop.interface scaling-factor 2` |
||
+ | |||
+ | xdpyinfo | grep -B2 resolution |
||
+ | screen #0: |
||
+ | dimensions: 3840x2160 pixels (1016x572 millimeters) |
||
+ | resolution: 96x96 dots per inch |
||
+ | I've no ruler at hand but if it's 15.6'' in diagonal and pixels are square, this gives 293.4 dpi for screen dimensions of 332x187mm. |
||
+ | <br>So closest hit with common DPI is 96*3=288dpi |
||
+ | xrandr --dpi 288 |
||
+ | xdpyinfo | grep -B2 resolution |
||
+ | screen #0: |
||
+ | dimensions: 3840x2160 pixels (338x190 millimeters) |
||
+ | resolution: 289x289 dots per inch |
||
+ | Let's document those fictive dimensions for next boots by creating /etc/X11/xorg.conf.d/90-monitor.conf with |
||
+ | Section "Monitor" |
||
+ | Identifier "<default monitor>" |
||
+ | DisplaySize 338 190 # In millimeters |
||
+ | EndSection |
||
+ | |||
+ | '''QT5 and GTK+ 3''' |
||
+ | <br>To enable better scaling of QT5 and GTK+ 3, add to .bashrc (not to .xsessionrc otherwise Cinnamon taskbar is messed up!): |
||
+ | QT_DEVICE_PIXEL_RATIO=3 |
||
+ | GDK_SCALE=3 |
||
+ | GDK_DPI_SCALE=0.4 |
||
+ | |||
+ | '''QT4''' |
||
+ | <br>E.g. Skype |
||
+ | sudo apt-get install qt4-qtconfig |
||
+ | qtconfig-qt4 |
||
+ | => one can change font size |
||
+ | |||
+ | '''Gimp 2.8''' |
||
+ | <br>E.g. copy /usr/share/gimp/2.0/themes/Default as ~/.gimp-2.8/themes/HiDPI and change a few options: |
||
+ | <source lang=diff> |
||
+ | --- gtkrc |
||
+ | +++ gtkrc |
||
+ | - GimpToolPalette::tool-icon-size = button |
||
+ | + GimpToolPalette::tool-icon-size = dialog |
||
+ | - GimpEditor::button-icon-size = menu |
||
+ | + GimpEditor::button-icon-size = button |
||
+ | </source> |
||
+ | |||
+ | '''Wine''' |
||
+ | winecfg |
||
+ | Change "dpi" in "Graphics" tab |
||
+ | '''Virtualbox''': |
||
+ | <br>View/Scale Factor is helpful... |
||
+ | |||
+ | '''Chromium''' |
||
+ | <br>Chrome works fine but ''Chromium'' broke at some point, so I've to launch it with: |
||
+ | |||
+ | GDK_SCALE=2 exec chromium |
||
+ | |||
+ | '''Small console font''': |
||
+ | <br>I don't care but if that's an issue for you, from [https://github.com/mpalourdio/xps13/blob/master/HiDPI/tty.md here]: |
||
sudo dpkg-reconfigure console-setup |
sudo dpkg-reconfigure console-setup |
||
* Choose UTF-8 |
* Choose UTF-8 |
||
Line 183: | Line 407: | ||
* OK |
* OK |
||
To apply immediately, open a TTY and run setupcon, else just reboot |
To apply immediately, open a TTY and run setupcon, else just reboot |
||
+ | |||
+ | '''Multiple displays''' |
||
+ | <br>Combining HiDPI screen with external non-HiDPI? See https://wiki.archlinux.org/index.php/HiDPI#Multiple_displays |
||
+ | |||
+ | '''xpra''' |
||
+ | <br>cf https://xpra.org/trac/ticket/2492 |
||
+ | |||
====Sensors==== |
====Sensors==== |
||
apt-get install lm-sensors |
apt-get install lm-sensors |
||
Line 189: | Line 420: | ||
coretemp |
coretemp |
||
+ | |||
− | ===Issues=== |
||
+ | ====External microphone==== |
||
+ | The sole jack is a TRRS, combining output and mic. |
||
+ | <br>Soundcard is a Realtek ALC3266 |
||
+ | grep -r Realtek /proc/asound/card* |
||
+ | /proc/asound/card0/codec#0:Codec: Realtek ALC3266 |
||
+ | <br>With Debian+Cinnamon, the system detects the mic, we can see it in the sound properties and select it, but still the internal mic is used. |
||
+ | <br>When using pavucontrol, selecting the "headset microphone" works fine (it still needs some level boosting). |
||
+ | |||
+ | ====DA200==== |
||
+ | [http://accessories.euro.dell.com/sna/products/Station_daccueil/productdetail.aspx?c=fr&l=fr&s=dhs&cs=frdhs1&sku=470-ABRY DA200] used to be recognized only if it was plugged at boot. |
||
+ | <br>With kernel 4.6 the device is properly detected dynamically. |
||
+ | <br>The adapter is actually using DisplayPort. |
||
+ | <br>VGA output works. |
||
+ | |||
+ | HDMI output is limited to some modes (max 1920x1080, cf [http://www.dell.com/support/article/us/en/19/SLN303466 Dell support]) and by default xrandr will try an unsupported mode. |
||
+ | <br>Even "xrandr --output DP-1 --mode 1920x1080" fails by default. |
||
+ | |||
+ | Some supported modes: 800x600, 1024x768, 1280x720, 1920x1080i |
||
+ | <br>1920x1080i is interlaced and awful to look at. |
||
+ | <br>Reducing the rate allows a non-interlaced 1920x1080 mode, you can test it with: |
||
+ | xrandr --output DP-1 --mode 1920x1080 -r 30 |
||
+ | If this works for you, you can create a new mode, using cvt to find the proper parameters: |
||
+ | cvt 1920 1080 30 |
||
+ | # 1920x1080 29.95 Hz (CVT) hsync: 33.01 kHz; pclk: 79.75 MHz |
||
+ | Modeline "1920x1080_30.00" 79.75 1920 1976 2168 2416 1080 1083 1088 1102 -hsync +vsync |
||
+ | Creating and adding the new mode: |
||
+ | xrandr --newmode "1920x1080_30.00" 79.75 1920 1976 2168 2416 1080 1083 1088 1102 -hsync +vsync |
||
+ | xrandr --addmode DP-1 "1920x1080_30.00" |
||
+ | Now you can choose this new mode: |
||
+ | xrandr --output DP-1 --mode "1920x1080_30.00" |
||
+ | |||
+ | When plugged the following hardware gets detected: |
||
+ | |||
+ | lsusb: |
||
+ | <pre> |
||
+ | Bus 004 Device 003: ID 0bda:8153 Realtek Semiconductor Corp.. <= Ethernet |
||
+ | Bus 004 Device 002: ID 05e3:0617 Genesys Logic, Inc.. |
||
+ | Bus 004 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub |
||
+ | Bus 003 Device 003: ID 0835:2a01 Action Star Enterprise Co., Ltd. <= Billboard |
||
+ | Bus 003 Device 002: ID 05e3:0610 Genesys Logic, Inc. 4-port hub |
||
+ | Bus 003 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub |
||
+ | </pre> |
||
+ | ''The USB Billboard Device Class definition describes the methods used to communicate the Alternate Modes supported by a device container to a host system. More details on Billboard Devices are available in the USB Billboard Device Class specification at the following link: http://www.usb.org/developers/docs/devclass_docs/.'' |
||
+ | |||
+ | lspci: |
||
+ | <pre> |
||
+ | 06:00.0 PCI bridge: Intel Corporation Device 1576 (prog-if 00 [Normal decode]) |
||
+ | 07:00.0 PCI bridge: Intel Corporation Device 1576 (prog-if 00 [Normal decode]) |
||
+ | 07:01.0 PCI bridge: Intel Corporation Device 1576 (prog-if 00 [Normal decode]) |
||
+ | 07:02.0 PCI bridge: Intel Corporation Device 1576 (prog-if 00 [Normal decode]) |
||
+ | 0a:00.0 USB controller: Intel Corporation Device 15b5 (prog-if 30 [XHCI]) |
||
+ | </pre> |
||
+ | |||
+ | lsmod: |
||
+ | <pre> |
||
+ | r8152 49152 0 |
||
+ | cdc_ether 16384 0 |
||
+ | usbnet 40960 1 cdc_ether |
||
+ | mii 16384 2 r8152,usbnet |
||
+ | </pre> |
||
+ | |||
+ | ===Solved issues=== |
||
+ | ====i915 and blank screen==== |
||
+ | There were numerous issues with the video card. Now with latest kernels (>=4.8) most issues are gone, still some occasional blank screen or freeze when plugging an external HDMI. |
||
====Bluetooth==== |
====Bluetooth==== |
||
− | WM615 mouse |
+ | WM615 mouse used to act erratically, the cursor stopping now and then. Now with latest kernels and an Intel Wi-Fi+BT card it's fine. |
− | <br>I paired it with an Android phone and there it runs very smoothly so the issue is somewhere on the Dell... |
||
====Wi-Fi==== |
====Wi-Fi==== |
||
Wi-Fi tends to disassociate under heavy load, switching to other SSIDs or frequencies (5Ghz<>2.4GHz) and coming back seems to help. |
Wi-Fi tends to disassociate under heavy load, switching to other SSIDs or frequencies (5Ghz<>2.4GHz) and coming back seems to help. |
||
− | <br>Maybe a proper firmware settings .txt would help? |
||
− | ====Screen blank==== |
||
− | When waking from screen off, the screen very often turns on but is entrely black. |
||
− | <br>And dmesg reports sth like this: |
||
− | [drm:intel_dp_start_link_train [i915]] *ERROR* failed to enable link training |
||
− | [drm:intel_dp_complete_link_train [i915]] *ERROR* failed to start channel equalization |
||
− | See issue [http://en.community.dell.com/techcenter/os-applications/f/4613/t/19640927 here] |
||
− | <br>It might be solved in kernel 4.4, I 'll wait for it to be in Sid. |
||
+ | I finally changed the Wi-Fi+BT card for an Intel one, see #Hardware_changes |
||
− | Workaround1: |
||
− | * if there is a remote connection possible, this solves the issue: |
||
− | DISPLAY=:0.0 xset dpms force off |
||
− | sleep 1 |
||
− | DISPLAY=:0.0 xset dpms force on |
||
− | or |
||
− | DISPLAY=:0.0 xrandr --output eDP1 --off |
||
− | sleep 1 |
||
− | DISPLAY=:0.0 xrandr --output eDP1 --auto |
||
− | Some associated those commands to a shortcut, but this still requires to login properly with a blank screen... |
||
+ | ===Issues=== |
||
− | Workaround2: |
||
− | * Close LID (and the machine goes to sleep) and open it again |
||
====rfkill button==== |
====rfkill button==== |
||
Rfkill button of the keyboard (Fn+PrtScr) doesn't seem to work, no big deal. |
Rfkill button of the keyboard (Fn+PrtScr) doesn't seem to work, no big deal. |
||
− | ====Mic==== |
||
− | Mic works but sound is terrible, need to look at it... |
||
− | ====HiDPI==== |
||
− | Cinnamon handles it nicely but some applications don't such as Gimp and you end up with a microscopic tools ribbon. |
||
− | ====DA200==== |
||
− | DA200 is recognized only if it was plugged at boot. |
||
+ | ==Kernels== |
||
− | VGA and HDMI outputs don't work, they're recognized by xrandr as 'DP1'... |
||
+ | initramfs complains about lvmetad and I'm not sure it's that useful on SSD, so just disabling it: |
||
+ | <br>Edit /etc/lvm/lvm.conf |
||
+ | use_lvmetad=0 |
||
+ | Then stop it |
||
+ | systemctl stop lvm2-lvmetad |
||
+ | ===Debian=== |
||
+ | Debian kernel 4.8 works quite well |
||
+ | ===Compilation notes=== |
||
+ | '''Warning''', to compile >=4.4, one needs at least initramfs-tools v0.122 to get the nvme.ko properly loaded and therefore the SSD properly seen. |
||
+ | |||
+ | To compile a vanilla kernel, cf http://www.cyberciti.biz/faq/debian-ubuntu-building-installing-a-custom-linux-kernel/ |
||
+ | sudo apt-get install git fakeroot build-essential ncurses-dev xz-utils libssl-dev bc |
||
+ | sudo apt-get install kernel-package |
||
+ | wget https://cdn.kernel.org/pub/linux/kernel/v4.x/linux-4.4.tar.xz |
||
+ | tar xf linux-4.4.tar.xz |
||
+ | cd linux-4.4 |
||
+ | cp /boot/config-$(uname -r) .config |
||
+ | make menuconfig |
||
+ | make-kpkg clean |
||
+ | make-kpkg --rootcmd fakeroot --initrd --append_to_version=9-doegox kernel_image kernel_headers -j 7 |
||
+ | |||
+ | ==Hardware changes== |
||
+ | Replacing Broadcom Wi-Fi+BT by an [https://wikidevi.com/wiki/Intel Intel one]: |
||
+ | * Intel 7265 Dual Band Wireless-AC 7265NGW Card 802.11ac 867Mbps WIFI BT4.0 UK |
||
+ | ** http://www.befr.ebay.be/itm/262049756966?_trksid=p2060353.m2749.l2649&ssPageName=STRK%3AMEBIDX%3AIT |
||
+ | ** https://downloadcenter.intel.com/download/17045 |
||
+ | ** This requires installing package firmware-iwlwifi |
||
+ | ** Seems to have less Wi-Fi issues, but still the same BT problems pairing the Dell mouse |
||
+ | |||
+ | iwlwifi 0000:02:00.0: firmware: direct-loading firmware iwlwifi-7265-17.ucode |
||
+ | iwlwifi 0000:02:00.0: Detected Intel(R) Dual Band Wireless AC 7265, REV=0x184 |
||
+ | |||
+ | Alternatives to DA200: |
||
+ | * HDMI Male To VGA Female Converter |
||
+ | ** http://www.aliexpress.com/item/1pc-HDMI-Male-To-VGA-Female-Converter-Box-Adapter-With-Audio-Cable-For-PC-HDTVHot-New/32448171552.html |
||
+ | * USB 3.0 10/100/1000Mbps Gigabit Ethernet RJ45 |
||
+ | ** http://www.aliexpress.com/item/Hot-selling-New-USB-3-0-10-100-1000Mbps-Gigabit-Ethernet-RJ45-External-Network-Card-LAN/32546613204.html |
||
+ | * 4-Port Ultra-Slim USB 3.0 Hub |
||
+ | ** https://www.anker.com/products/A7516011 |
||
+ | ** http://www.amazon.de/Anker-Datenhub-Ultrabooks-weiteren-kompatiblen/dp/B00Y211AFM/ |
||
+ | |||
+ | ==Misc hardware== |
||
+ | Smartcard reader |
||
+ | * ACS ACR38U PocketMate Smart Card Reader |
||
+ | ** http://www.acs.com.hk/en/products/160/acr38u-pocketmate-smart-card-reader/ |
||
+ | ** http://www.befr.ebay.be/itm/EU-SHIPPING-Smart-Card-USB-ACS-ACR38U-National-ID-Tachograph-Reader-Writer-/121899037557 |
Latest revision as of 23:16, 14 June 2023
Notes about installing a Debian Stretch on a Dell XPS 15
Hardware
Dell XPS 15 model 9550 (variant with touchscreen & PCIe m.2 ssd)
From the configuration list:
- 6th Generation Intel(R) Core (TM) i7-6700HQ Quad Core (6M Cache, up to 3.5 GHz)
- 16Go (2x8Go) DDR4 2133MHz
- 15.6" 4K Ultra HD (3840 x 2160) InfinityEdge touch, Sliver
- 1To PCIe Solid State
- DW1830 3x3 802.11ac 2.4/5GHz + Bluetooth 4.1
- Dell 84 WHr 6-Cell Lithium-Ion Battery
- Internal US/International Qwerty Backlit Keyboard
From the drivers list:
- Realtek High Definition Audio ALC3266
- Realtek RTS5242 PCIe Gen2 CardReader
- Realtek USB GBE Ethernet Controller
- ST Microlectronics LNG3DMTR Motion Sensor
- Intel HD Graphics 530/P530
- nVIDIA Geforce GTX 960M Graphics
From dmesg (incomplete):
- BCM20703A1 Bluetooth 4.1 (firmware brcm/BCM-0a5c-6410.hcd)
From lspci -nn:
00:00.0 Host bridge [0600]: Intel Corporation Sky Lake Host Bridge/DRAM Registers [8086:1910] (rev 07) 00:01.0 PCI bridge [0604]: Intel Corporation Sky Lake PCIe Controller (x16) [8086:1901] (rev 07) 00:02.0 VGA compatible controller [0300]: Intel Corporation Device [8086:191b] (rev 06) 00:04.0 Signal processing controller [1180]: Intel Corporation Device [8086:1903] (rev 07) 00:14.0 USB controller [0c03]: Intel Corporation Sunrise Point-H USB 3.0 xHCI Controller [8086:a12f] (rev 31) 00:14.2 Signal processing controller [1180]: Intel Corporation Sunrise Point-H Thermal subsystem [8086:a131] (rev 31) 00:15.0 Signal processing controller [1180]: Intel Corporation Sunrise Point-H LPSS I2C Controller #0 [8086:a160] (rev 31) 00:15.1 Signal processing controller [1180]: Intel Corporation Sunrise Point-H LPSS I2C Controller #1 [8086:a161] (rev 31) 00:16.0 Communication controller [0780]: Intel Corporation Sunrise Point-H CSME HECI #1 [8086:a13a] (rev 31) 00:17.0 SATA controller [0106]: Intel Corporation Sunrise Point-H SATA Controller [AHCI mode] [8086:a103] (rev 31) 00:1c.0 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #1 [8086:a110] (rev f1) 00:1c.1 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #2 [8086:a111] (rev f1) 00:1d.0 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #9 [8086:a118] (rev f1) 00:1d.4 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #13 [8086:a11c] (rev f1) 00:1d.6 PCI bridge [0604]: Intel Corporation Sunrise Point-H PCI Express Root Port #15 [8086:a11e] (rev f1) 00:1f.0 ISA bridge [0601]: Intel Corporation Sunrise Point-H LPC Controller [8086:a14e] (rev 31) 00:1f.2 Memory controller [0580]: Intel Corporation Sunrise Point-H PMC [8086:a121] (rev 31) 00:1f.3 Audio device [0403]: Intel Corporation Sunrise Point-H HD Audio [8086:a170] (rev 31) 00:1f.4 SMBus [0c05]: Intel Corporation Sunrise Point-H SMBus [8086:a123] (rev 31) 01:00.0 3D controller [0302]: NVIDIA Corporation GM107M [GeForce GTX 960M] [10de:139b] (rev ff) 02:00.0 Network controller [0280]: Broadcom Corporation BCM43602 802.11ac Wireless LAN SoC [14e4:43ba] (rev 01) 03:00.0 Unassigned class [ff00]: Realtek Semiconductor Co., Ltd. Device [10ec:525a] (rev 01) 04:00.0 Non-Volatile memory controller [0108]: Samsung Electronics Co Ltd Device [144d:a802] (rev 01)
From lsusb:
Bus 002 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub Bus 001 Device 003: ID 04f3:21d5 Elan Microelectronics Corp. <= touchscreen Bus 001 Device 002: ID 0a5c:6410 Broadcom Corp. <= bluetooth Bus 001 Device 004: ID 0c45:6713 Microdia <= webcam Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
From lscpu:
Architecture: x86_64 CPU op-mode(s): 32-bit, 64-bit Byte Order: Little Endian CPU(s): 8 On-line CPU(s) list: 0-7 Thread(s) per core: 2 Core(s) per socket: 4 Socket(s): 1 NUMA node(s): 1 Vendor ID: GenuineIntel CPU family: 6 Model: 94 Model name: Intel(R) Core(TM) i7-6700HQ CPU @ 2.60GHz Stepping: 3 CPU MHz: 2847.812 CPU max MHz: 3500.0000 CPU min MHz: 800.0000 BogoMIPS: 5183.88 Virtualization: VT-x L1d cache: 32K L1i cache: 32K L2 cache: 256K L3 cache: 6144K NUMA node0 CPU(s): 0-7 Flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc aperfmperf eagerfpu pni pclmulqdq dtes64 monitor ds_cpl vmx est tm2 ssse3 sdbg fma cx16 xtpr pdcm pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand lahf_lm abm 3dnowprefetch ida arat epb pln pts dtherm hwp hwp_notify hwp_act_window hwp_epp intel_pt tpr_shadow vnmi flexpriority ept vpid fsgsbase tsc_adjust bmi1 hle avx2 smep bmi2 erms invpcid rtm mpx rdseed adx smap clflushopt xsaveopt xsavec xgetbv1
Dell Wireless 1830 = BCM43602 + BCM20703A1 (DW1830 Bluetooth 4.1 LE)
BCM43602 PCI ID: 14e4:43ba
# smartctl -d scsi -i /dev/nvme0n1 smartctl 6.4 2015-06-04 r4109 [x86_64-linux-4.3.0-1-amd64] (local build) Copyright (C) 2002-15, Bruce Allen, Christian Franke, www.smartmontools.org === START OF INFORMATION SECTION === Vendor: NVMe Product: PM951 NVMe SAMSU Revision: 7D0Q Compliance: SPC-4 User Capacity: 1,024,209,543,168 bytes [1.02 TB] Logical block size: 512 bytes Rotation Rate: Solid State Device Logical Unit id: 0x0025384cf1b0fd29 Serial number: S2FZNXAGC03824 Device type: disk Local Time is: Sun Feb 14 22:02:03 2016 CET SMART support is: Unavailable - device lacks SMART capability.
Resources
- http://topics-cdn.dell.com/pdf/xps-15-9550-laptop_Service%20Manual_en-us.pdf
- https://wiki.archlinux.org/index.php/Dell_XPS_15
- https://bbs.archlinux.org/viewtopic.php?id=204739
- http://ubuntuforums.org/showthread.php?t=2301071
- http://forthescience.org/blog/2015/03/20/installing_ubuntu_14_04_on_the_new_dell_xps_13/
- https://wiki.debian.org/InstallingDebianOn/Dell/Dell%20XPS%2013
- http://bartongeorge.net/2015/02/23/update-2-dell-xps-13-laptop-developer-edition-sputnik-gen-4/
General
I first tried to keep a dual-boot just in case, but once we disable Raid and put SATA in AHCI mode, Windows can't boot anymore. (later I read it could be possible to fix it by rebooting several times Windows till safe mode is kicked in, but it was too late for me.)
Just in case again, one can boot Windows and create a USB recovery.
Bios
- Secure Boot: disable
- SATA: switch from Raid to AHCI
- Advances Boot Options:/ NOT Enable Legacy Option ROMs
- Boot: not sure it's needed but I disabled Windows boot manager entry and kept the hdd UEFI entry: UEFI: PM951 NVMe SAMSUNG 1024GB, Partition 1
- See below (first boot) how to create a new entry
- POST/Fastboot/Auto
- auto os recovery threshold off
- Fn Lock Options
- NOT Fn Lock
- Lock Mode Enable/Secondary
- UEFI Capsule Firmware Updates / Enable
- This allows using ``fwupdmgr update`` e.g. to update the TPM firmware
To update the BIOS:
- put it on a USB stick
- reboot
- select BIOS flash update on the boot screen (F12).
No need to put it on a bootable DOS, just give the exe to the BIOS update built-in util.
You can even drop the update on /boot/efi as it's also a FAT partition, no need for a USB memory stick.
Versions:
- 1.2.0 aka A6 XPS_9550_1.2.0.exe fixes
- 1.2.10 aka A10 XPS_9550_1.2.10.exe fixes
- 1.2.14 aka A13 XPS_9550_1.2.14.exe fixes
- 1.2.16 XPS_9550_1.2.16.exe fixes
- 1.2.18 aka A16 XPS_9550_1.2.18.exe fixes
- 1.2.21 XPS_9550_1.2.21.exe fixes
- 1.2.25 XPS_9550_1.2.25.exe fixes
- 1.2.29 XPS_9550_1.2.29.exe fixes
- 1.3.0 XPS_9550_1.3.0.exe fixes
- 1.4.0 XPS_9550_1.4.0.exe fixes
- 1.5.1 XPS_9550_1.5.1.exe fixes
- 1.6.1 XPS_9550_1.6.1.exe fixes
- 1.7.0 XPS_9550_1.7.0.exe fixes
- 1.8.0 XPS_9550_1.8.0.exe fixes
- 1.9.0 XPS_9550_1.9.0.exe fixes
- 1.10.0 XPS_9550_1.10.0.exe fixes
- 1.11.2 XPS_9550_1.11.2.exe fixes
- 1.12.0 XPS_9550_1.12.0.exe fixes
- 1.13.1 XPS_9550_1.13.1.exe fixes
- 1.14.0 XPS_9550_1.14.0.exe fixes
Attention: with versions 1.2.10 through 1.2.16 and older Linux kernels, there is a serious bug that let the screen black after suspend/wake up. The workaround is to set the lightness to the maximum but it breaks further lightness tuning.
Linux kernels 4.8 and below tend to work best with A6 BIOS (1.2.0), although there is a workaround that allows it to work with later versions. This workaround uses the intel_reg utility to reset the "pwm_granuality" setting of the onboard graphics. Solution discussed here: [1]. This issue is reportedly fixed in Linux 4.9, and also in recent Ubuntu 16.10 kernel updates. See the patch here [2].
Even with the intel_reg workaround above, the screen brightness cannot be set to the lowest level without turning the screen off. This is fixed in 1.2.18.
Debian
I kept UEFI so we need a Debian netinstall because liveCD doesn't have UEFI support yet.
But Wi-Fi requires a proprietary firmware:
https://github.com/OpenELEC/wlan-firmware/blob/master/firmware/brcm/brcmfmac43602-pcie.bin
so the easiest is to take a Debian netinstall with proprietary firmwares included.
At time of writing Stretch is testing and last release is alpha5:
http://cdimage.debian.org/cdimage/unofficial/non-free/cd-including-firmware/stretch_di_alpha5/amd64/iso-cd/
dd the image on a USB stick and boot it.
It will also complain for a missing brcmfmac43602-pcie.txt but we can safely ignore it. (well I think so, but Wi-Fi has troubles now and then under heavy load, see below)
I chose a guided partitionning of the entire disk, with encrypted LVM containing /, /home and swap. But proposed / was a bit too small IMHO (10G) so I deleted and recreated / (50G) and /home.
Initially I tried to add the "discard" option for the partitions which should help on SSD but the kernel reported that "discard" wasn't supported by the disk.
If you want to backup partition table and partitions before destroying everything, it's the right time!
parted /dev/nvme0n1 print sgdisk --backup=/some/safe/location/nvme0n1.gpt /dev/nvme0n1
I installed Cinnamon. I don't know for the others but Cinnamon has a nice auto setting to double features on HiDPI screens.
Gnome
Update: now using Gnome3. Needs to replace lightdm by gdm3 to get newer lock screen (gnome-screensaver is deprecated)
sudo dpkg-reconfigure gdm3 (choose gdm3) # delay before blanking, in seconds: gsettings set org.gnome.desktop.session idle-delay 300 # delay after blanking before locking, in seconds: gsettings set org.gnome.desktop.screensaver lock-delay 10 (reboot)
Sometimes after a crash, gnome extensions (https://extensions.gnome.org/local/) are disabled. To reenable them:
dconf write /org/gnome/shell/disable-user-extensions false
Wayland
Got quite some troubles with Wayland, so I reverted it back to X11:
Edit /etc/gdm3/daemon.conf and uncomment line:
WaylandEnable=false
First boot
Once installed, the Debian didn't boot up.
I tried many things but at the end the only thing that worked was to copy Debian EFI to the default one:
Starting the netinstall again, in rescue mode, get a chroot shell, then
mount /dev/nvme0n1p1 /boot/efi cd /boot/efi/EFI mkdir boot cp debian/grubx64.efi boot/bootx64.efi
I also deleted the Windows files in EFI.
Resource:
- https://wiki.debian.org/GrubEFIReinstall
- https://wiki.archlinux.org/index.php/GRUB#Create_an_ESP
- https://help.ubuntu.com/community/UEFI
- https://wiki.debian.org/UEFI
- https://isalo.org/wiki.debian-fr/Debian_%26_UEFI
FTR things that failed included:
- Refind couldn't boot at all. Strange as the netinstall could boot...
- tweaks with efibootmgr, update-grub etc
UPDATE: It might be possible to fix the issue from the BIOS itself, see http://www.dell.com/support/article/us/en/04/SLN297060/en
- Boot Sequence / Add Boot Option
- Boot Option Name : Debian
- File System List : PciRoot(0x0)/Pic(0x1D,0x0)/Pci(0x0,0x0)/?/HD(1,GPT,<UUID>)
- File Name : FS0 - EFI - debian - grubx64.efi
- Advances Boot Options / NOT Enable Legacy Option ROMs
Status
Working
- Screen
- Touchscreen
- Touchpad
- Keyboard backlight and media buttons (volume, luminosity, backlight)
- Wi-Fi (with the proprietary driver, cf installation above)
- HDMI
- SD-Card reader
- Speakers, mic
- Webcam
Working after manual steps
i915
Screen was working but dmesg was complaining:
i915 0000:00:02.0: firmware: failed to load i915/skl_dmc_ver1.bin
So I installed that firmware, not sure what it's changed
sudo apt-get install firmware-misc-nonfree
Optimus & CUDA
Resources:
apt-get install bumblebee-nvidia nvidia-cuda-toolkit mesa-utils reboot
Examples:
optirun -b none nvidia-settings -c :8 optirun -vv glxgears optirun -vv clinfo optirun -b none ./hashcat64.bin -I optirun --no-xorg ./hashcat64.bin -I optirun -b none ./hashcat.bin -m 500 example500.hash example.dict
GPU load:
optirun --no-xorg nvidia-smi
As bridge, primus or virtualgl can be used. Primus is available in the Debian repos while VirtualGL is here. Using primus currently.
Touchpad
Nothing wrong with the touchpad but its default config is a bit painful especially because it's large and my right palm touches it often, even with the option to diable it when typing and because it's "soft" buttons.
I disabled the button area to limit somehow the problem but still you've to get used to first touch and hold before pressing a button to do a drag and drop and not the opposite.
synclient AreaBottomEdge=4026
To add a middle button:
synclient RightButtonAreaLeft=3914 synclient RightButtonAreaRight=0 synclient RightButtonAreaTop=4026 synclient RightButtonAreaBottom=0 synclient MiddleButtonAreaLeft=3100 synclient MiddleButtonAreaRight=3873 synclient MiddleButtonAreaTop=4026 synclient MiddleButtonAreaBottom=0
And because I love it:
synclient CircularScrolling=1
Some doc here and the official one here
If with some kernels you get troubles using Synaptics options, check dmesg, maybe Touchpad is detected by another driver too:
DLL06E4:01 06CB:7A13 Touchpad as /devices/pci0000:00/0000:00:15.1/i2c_designware.1/i2c-7/i2c-DLL06E4:01/0018:06CB:7A13.0003/input/input14 hid-multitouch 0018:06CB:7A13.0003: input,hidraw2: I2C HID v1.00 Mouse [DLL06E4:01 06CB:7A13] on i2c-DLL06E4:01
If this is so, add /etc/modprobe.d/synaptics.conf with this line, cf Kernel section below:
blacklist i2c-designware-platform
On recent kernels, i2c-designware-platform is directly in the kernel, not as module anymore. To manage to blacklist it, see https://unix.stackexchange.com/questions/423797/how-do-i-disable-i2c-designware-support-when-its-not-built-as-a-module#446913 Edit /etc/default/grub and append the following blacklist invocation to the command line, then update-grub.
GRUB_CMDLINE_LINUX_DEFAULT="… initcall_blacklist=dw_i2c_init_driver"
Touchscreen
Touchscreen works well but when an external screen is connected, it spans over both screens so e.g. touching the middle of the laptop screen moves the mouse to some middle point of the virtual screen combining both screens.
To fix it, see https://wiki.archlinux.org/index.php/Calibrating_Touchscreen
This example is for an external screen mapped to the right of the laptop screen:
# c0 = width of laptop screen / total width c0=$(bc -l <<< "scale=2; $(xrandr|grep -A1 eDP1|sed '1d;s/x.*//')/$(xrandr|grep '^Screen 0'|sed 's/.*current //;s/ x.*//')") xinput set-prop "ELAN Touchscreen" --type=float "Coordinate Transformation Matrix" \ c0 0 0 \ 0 1 0 \ 0 0 1
Bluetooth
Kernel complains about a missing file.
Apparently we can get it from Windows drivers but I don't know where to find them, so I took this one and copied it into /lib/firmware/brcm
Then Bluetooth was recognized but I couldn't pair my WM615 mouse.
After restarting the Bt adaptor, I could finally pair:
bluetoothctl power off power on
References:
There is also a possibility to pair directly from bluetoothctl, see https://wiki.archlinux.org/index.php/bluetooth#Bluetoothctl
I finally changed the Wi-Fi+BT card for an Intel one, see #Hardware_changes
HiDPI
Cinnamon handles it nicely but some applications don't such as Gimp and you end up with a microscopic tools ribbon.
See https://wiki.archlinux.org/index.php/HiDPI for some useful tips
Cinnamon / System Settings / Desktop Scaling has the same effect as `gsettings set org.cinnamon.desktop.interface scaling-factor 2`
xdpyinfo | grep -B2 resolution screen #0: dimensions: 3840x2160 pixels (1016x572 millimeters) resolution: 96x96 dots per inch
I've no ruler at hand but if it's 15.6 in diagonal and pixels are square, this gives 293.4 dpi for screen dimensions of 332x187mm.
So closest hit with common DPI is 96*3=288dpi
xrandr --dpi 288 xdpyinfo | grep -B2 resolution screen #0: dimensions: 3840x2160 pixels (338x190 millimeters) resolution: 289x289 dots per inch
Let's document those fictive dimensions for next boots by creating /etc/X11/xorg.conf.d/90-monitor.conf with
Section "Monitor" Identifier "<default monitor>" DisplaySize 338 190 # In millimeters EndSection
QT5 and GTK+ 3
To enable better scaling of QT5 and GTK+ 3, add to .bashrc (not to .xsessionrc otherwise Cinnamon taskbar is messed up!):
QT_DEVICE_PIXEL_RATIO=3 GDK_SCALE=3 GDK_DPI_SCALE=0.4
QT4
E.g. Skype
sudo apt-get install qt4-qtconfig qtconfig-qt4
=> one can change font size
Gimp 2.8
E.g. copy /usr/share/gimp/2.0/themes/Default as ~/.gimp-2.8/themes/HiDPI and change a few options:
--- gtkrc
+++ gtkrc
- GimpToolPalette::tool-icon-size = button
+ GimpToolPalette::tool-icon-size = dialog
- GimpEditor::button-icon-size = menu
+ GimpEditor::button-icon-size = button
Wine
winecfg
Change "dpi" in "Graphics" tab
Virtualbox:
View/Scale Factor is helpful...
Chromium
Chrome works fine but Chromium broke at some point, so I've to launch it with:
GDK_SCALE=2 exec chromium
Small console font:
I don't care but if that's an issue for you, from here:
sudo dpkg-reconfigure console-setup
- Choose UTF-8
- Choose the default Combined - Latin, ... option ("Latin" includes the English alphabet)
- Select the terminus font
- Select 16x32
- OK
To apply immediately, open a TTY and run setupcon, else just reboot
Multiple displays
Combining HiDPI screen with external non-HiDPI? See https://wiki.archlinux.org/index.php/HiDPI#Multiple_displays
xpra
cf https://xpra.org/trac/ticket/2492
Sensors
apt-get install lm-sensors sensors-detect
Sensors-detect found coretemp which is now loaded via /etc/modules:
coretemp
External microphone
The sole jack is a TRRS, combining output and mic.
Soundcard is a Realtek ALC3266
grep -r Realtek /proc/asound/card* /proc/asound/card0/codec#0:Codec: Realtek ALC3266
With Debian+Cinnamon, the system detects the mic, we can see it in the sound properties and select it, but still the internal mic is used.
When using pavucontrol, selecting the "headset microphone" works fine (it still needs some level boosting).
DA200
DA200 used to be recognized only if it was plugged at boot.
With kernel 4.6 the device is properly detected dynamically.
The adapter is actually using DisplayPort.
VGA output works.
HDMI output is limited to some modes (max 1920x1080, cf Dell support) and by default xrandr will try an unsupported mode.
Even "xrandr --output DP-1 --mode 1920x1080" fails by default.
Some supported modes: 800x600, 1024x768, 1280x720, 1920x1080i
1920x1080i is interlaced and awful to look at.
Reducing the rate allows a non-interlaced 1920x1080 mode, you can test it with:
xrandr --output DP-1 --mode 1920x1080 -r 30
If this works for you, you can create a new mode, using cvt to find the proper parameters:
cvt 1920 1080 30 # 1920x1080 29.95 Hz (CVT) hsync: 33.01 kHz; pclk: 79.75 MHz Modeline "1920x1080_30.00" 79.75 1920 1976 2168 2416 1080 1083 1088 1102 -hsync +vsync
Creating and adding the new mode:
xrandr --newmode "1920x1080_30.00" 79.75 1920 1976 2168 2416 1080 1083 1088 1102 -hsync +vsync xrandr --addmode DP-1 "1920x1080_30.00"
Now you can choose this new mode:
xrandr --output DP-1 --mode "1920x1080_30.00"
When plugged the following hardware gets detected:
lsusb:
Bus 004 Device 003: ID 0bda:8153 Realtek Semiconductor Corp.. <= Ethernet Bus 004 Device 002: ID 05e3:0617 Genesys Logic, Inc.. Bus 004 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub Bus 003 Device 003: ID 0835:2a01 Action Star Enterprise Co., Ltd. <= Billboard Bus 003 Device 002: ID 05e3:0610 Genesys Logic, Inc. 4-port hub Bus 003 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
The USB Billboard Device Class definition describes the methods used to communicate the Alternate Modes supported by a device container to a host system. More details on Billboard Devices are available in the USB Billboard Device Class specification at the following link: http://www.usb.org/developers/docs/devclass_docs/.
lspci:
06:00.0 PCI bridge: Intel Corporation Device 1576 (prog-if 00 [Normal decode]) 07:00.0 PCI bridge: Intel Corporation Device 1576 (prog-if 00 [Normal decode]) 07:01.0 PCI bridge: Intel Corporation Device 1576 (prog-if 00 [Normal decode]) 07:02.0 PCI bridge: Intel Corporation Device 1576 (prog-if 00 [Normal decode]) 0a:00.0 USB controller: Intel Corporation Device 15b5 (prog-if 30 [XHCI])
lsmod:
r8152 49152 0 cdc_ether 16384 0 usbnet 40960 1 cdc_ether mii 16384 2 r8152,usbnet
Solved issues
i915 and blank screen
There were numerous issues with the video card. Now with latest kernels (>=4.8) most issues are gone, still some occasional blank screen or freeze when plugging an external HDMI.
Bluetooth
WM615 mouse used to act erratically, the cursor stopping now and then. Now with latest kernels and an Intel Wi-Fi+BT card it's fine.
Wi-Fi
Wi-Fi tends to disassociate under heavy load, switching to other SSIDs or frequencies (5Ghz<>2.4GHz) and coming back seems to help.
I finally changed the Wi-Fi+BT card for an Intel one, see #Hardware_changes
Issues
rfkill button
Rfkill button of the keyboard (Fn+PrtScr) doesn't seem to work, no big deal.
Kernels
initramfs complains about lvmetad and I'm not sure it's that useful on SSD, so just disabling it:
Edit /etc/lvm/lvm.conf
use_lvmetad=0
Then stop it
systemctl stop lvm2-lvmetad
Debian
Debian kernel 4.8 works quite well
Compilation notes
Warning, to compile >=4.4, one needs at least initramfs-tools v0.122 to get the nvme.ko properly loaded and therefore the SSD properly seen.
To compile a vanilla kernel, cf http://www.cyberciti.biz/faq/debian-ubuntu-building-installing-a-custom-linux-kernel/
sudo apt-get install git fakeroot build-essential ncurses-dev xz-utils libssl-dev bc sudo apt-get install kernel-package wget https://cdn.kernel.org/pub/linux/kernel/v4.x/linux-4.4.tar.xz tar xf linux-4.4.tar.xz cd linux-4.4 cp /boot/config-$(uname -r) .config make menuconfig make-kpkg clean make-kpkg --rootcmd fakeroot --initrd --append_to_version=9-doegox kernel_image kernel_headers -j 7
Hardware changes
Replacing Broadcom Wi-Fi+BT by an Intel one:
- Intel 7265 Dual Band Wireless-AC 7265NGW Card 802.11ac 867Mbps WIFI BT4.0 UK
- http://www.befr.ebay.be/itm/262049756966?_trksid=p2060353.m2749.l2649&ssPageName=STRK%3AMEBIDX%3AIT
- https://downloadcenter.intel.com/download/17045
- This requires installing package firmware-iwlwifi
- Seems to have less Wi-Fi issues, but still the same BT problems pairing the Dell mouse
iwlwifi 0000:02:00.0: firmware: direct-loading firmware iwlwifi-7265-17.ucode iwlwifi 0000:02:00.0: Detected Intel(R) Dual Band Wireless AC 7265, REV=0x184
Alternatives to DA200:
- HDMI Male To VGA Female Converter
- USB 3.0 10/100/1000Mbps Gigabit Ethernet RJ45
- 4-Port Ultra-Slim USB 3.0 Hub
Misc hardware
Smartcard reader