-
Notifications
You must be signed in to change notification settings - Fork 34
Ubuntu linux on Dell XPS 15 (9560)
DISCLAIMER: These are my personal notes for experiments with my own laptop. These instructions could cause data loss, damage to your system, or result in your system becoming unusable. Use at your own risk.
These are my notes to get Ubuntu working on a Dell XPS 15 (9560, early 2017).
I originally started with Ubuntu 16.04 LTS. Then I upgraded to Ubuntu 16.10, and recently to Ubuntu 17.04.
Warning: I recently upgraded Ubuntu to 17.10 (artful). Chrome will quite often freeze the whole machine, requiring a hard reset. Windows will no longer boot as a VirtualBox raw disk from linux. Python under conda got broken (2.7 and 3.6), and needed full removal of ~/.conda
and /opt/miniconda*
, as well as reinstalling from scratch. Package plymouth
seems to give random errors. If you want Ubuntu 17.10, I'd suggest you make a copy of your ~
directory and any programs on an external drive. Then, don't upgrade Ubuntu, but use a Live USB to reinstall Ubuntu from scratch, and copy back your ~
. My laptop took a lot of work to get back to work due to the upgrade.
With Ubuntu 16.04 to 17.04 I got:
- Ubuntu running
- encrypted home directory in Ubuntu
- encrypted Windows partition
- dual boot with Windows 10 Pro (it works fine)
- Suspend/resume work fine with the nVidia 381 driver
- I can also run the Windows 10 Pro (guest) from Ubuntu (host) as a virtual machine, at full resolution.
- That is, I can choose whether I want to boot Windows natively, or as a virtual machine from Ubuntu.
- I also have a shared folder so that Windows (as virtual machine) can access my linux encrypted home directory. This way, all the data and documents can live on the Ubuntu partition and I don't need to allocate extra space for data in the Windows partition.
However, there are a couple of small outstanding problems:
- trying to run Office alternatively natively and on the virtual machine (you have to commit to either one)
- drag'n'drop from Windows to Ubuntu
- Sometimes, bluetooth dies after suspend/resume (possible fix below)
- Sometimes the dual boot disappears and the laptop will boot Windows directly (but see below for easy fix).
- Laptop specs
- Installation steps
- Outstanding problems
- References
Created by gh-md-toc
- 15.6-inch (3840 x 2160) 4K 282ppi IPS InfinityEdge LCD glossy
- 2.8GHz Intel Core i7-7700HQ (3.8GHz boost) 4 cores, 8 threads
- Windows 10 Home 64-bit
- Nvidia GeForce GTX 1050 GPU Mobile with 4GB GDDR5 RAM
- 16GB 2400MHz DDR4 RAM (Up to 32GB)
- 512GB PCIe SSD Lite-On CX2-8B512-Q11 NV (Up to 1TB SSD)
- WiFi Qualcomm Atheros 802.11ac single-band 2x2 MIMO
- Bluetooth 4.1:
-
lsusb
reports: Qualcomm Atheros - Invoice reports: Killer 1535
- 1x USB-C 3.1
- 2x USB 3.0
- HDMI
- Kensington security slot
- SDXC card slot
- Stereo speakers
- HD webcam
- Single mic
- 3.5mm headset jack
- UK tiled keyboard
- Two-button trackpad
- 97 WHr, 6-cell lithium-ion battery, removable (design capacity 8509 mAh)
- 357mm x 235mm x 17mm
- 2kg
-
Plug the power cord into the laptop
-
Start laptop and go through the Windows 10 set up process
-
Create a Windows recovery USB stick so that we can reset the laptop to factory settings if things go wrong.
-
Go to the XPS 15 9560 drivers webpage and update the BIOS (version 1.1.3 at the time of this writing)
-
Other driver updates
- Graphics card: nVidia n17P-G0
-
Change SATA Operation so that Ubuntu can see the SSD
-
Login into Windows 10, and set up Safe Mode: "Change advanced Startup Options" -> "Restart Now" -> "Troubleshoot" > "Advanced options" > "Startup Settings" > "Restart"
-
Boot laptop and press F12 -> BIOS Setup
-
System Configuration -> SATA Operation
-
Change SATA Operation from "RAID On" to "AHCI"
-
Apply and Exit. This will reboot the laptop, and provide several boot options
-
Choose "4. Safe Mode"
-
"Start" -> "Windows System" -> "Control Panel" -> "Device Manager". Check that the "IDE ATA/ATAPI controller" is "Intel(R) 100 Series/C230 Chipset Family SATA AHCI Controller"
-
Reboot normally. This should boot into the regular Window 10
-
If you reboot and go into the BIOS, SATA Operation should still be AHCI
-
-
Create a bootable USB stick with Ubuntu Live. Either 16.04 LTS, 16.10 or 17.04 seem safe (although for complex resizing of partitions, gparted from the 17.04 Live USB hangs up, whereas gparted from 16.10 works fine). 17.10 used to corrupt the BIOS of Lenovo laptops, and I had serious issues when upgrading to it on my laptop, but it worked fine for a clean reinstall on my workstation. Presumably, a clean reinstall should also work on my laptop.
-
Boot the laptop with the USB stick (you need to press F12 while booting, and then select the USB stick from the BIOS menu)
-
Launch Ubuntu Live with "Try Ubuntu without installing"
-
Note: Ubuntu Live freezes on the Dell XPS 15 in several versions. As pointed out by Milan P. Antonovic, you can solve this by adding
nouveau.modeset=0
to the boot options.
-
Click on "Install Ubuntu 16.04.1 LTS" or similar to start installation
-
Select language (e.g. English)
-
Select whether you want to connect to Wifi (in my case I couldn't, because it doesn't give you the option to enter the Wifi username, and our Wifi requires that)
-
Select "Install third-party software for graphic and Wi-Fi hardware, Flash, MP3 and other media"
-
Check "Turn off Secure Boot" and enter a password that you'll need later
-
In "Installation Type", it should have detected the existing Windows installation, and offer to install Ubuntu alongside (dual boot).
-
Now you'll see the partitions in your drive. Select the main one, that contains Windows, and reduce it to make space for Ubuntu. For example, I reduced the Windows space to 50 GB, and left the rest for Ubuntu.
-
The rest of the steps (time zone, keyboard layout, login name and password) is straightforward, just complete them.m
-
After the system installs, you will have dual boot. Boot into Ubuntu, login and there you go.
-
If you want to upgrade the system to a later version, you can run
sudo do-release-upgrade
Both 16.10 and 17.04 seem safe, but 17.10 is a dangerous bloody mess that shouldn't have been released.
By default, Ubuntu uses the noveau driver. You can switch to the nVidia driver by launching "Additional drivers" from the dash, waiting for GUI to search for proprietary drivers, and then clicking on the nVidia driver, or using the command line. For example, to install v384 of the nVidia driver,
sudo apt-get install nvidia-384
This will ask you for permission to deactivate Safe Booting, as it's a third-party driver. You'll have to provide a password, the system will reboot, boot up into a configuration mode that will ask whether you want to deactivate Safe Booting, and ask for said password.
To avoid corruption of the window manager after resuming from suspend, you need version 381 of the driver or later. This is not in the regular repository of Ubuntu 17.04 at the time of this writing. To install the latest versions of the nVidia drivers, first you have to add the graphics team repositories
sudo add-apt-repository ppa:graphics-drivers/ppa
sudo apt-get update
Now launching "Additional drivers" from the dash will provide more options, in particular v381.09. Select and click "Apply changes".
The nVidia driver seems to work fine, and provides GPU acceleration. It also solves the window manager corruption after resuming from suspend caused by previous versions of the driver.
Moving your hand near the touchpad can cause the mouse pointer jump to the bottom left corner of the desktop and open the Trash. Sometimes, it also makes your cursor jump back so that you type in the middle of the sentence. To fix this problem, Juan Hernández suggests replacing xserver-xorg-input-synaptics
with xserver-xorg-input-libinput
sudo apt-get install xserver-xorg-input-libinput
sudo apt-get remove --purge xserver-xorg-input-synaptics
sudo reboot
After updating Windows, or installing a program, you may lose the dual boot (i.e. Windows boots without giving you the option to choose between Ubuntu or Windows). This is very easy to fix.
-
Reboot the machine.
-
Press F12 when the Dell logo appears. Apart from the BIOS options, at the top you'll be given the option to boot in Windows or Ubuntu. Select Ubuntu.
-
Log in, and run in a terminal
sudo grub-install
This will recover the dual boot. Alternatively, you can boot into the BIOS, and select the boot order as Ubuntu first, Windows second.
DISCLAIMER: The instructions in this section are particularly dangerous, and can corrupt or destroy your system. If you use these instructions, it's really at your own risk.
Usually, in VirtualBox you create a virtual disk where you install your guest operating system (e.g. Windows 10 Pro). Thus, Windows, all its programs and data are all inside a large file somewhere within your linux install. For example, ~/VirtualBox_VMs/win10pro.vdi
.
However, here we want to do something different. Instead of creating a virtual disk, we want to run the already installed native Windows 10 Pro from Ubuntu.
Basically, we are going to install VirtualBox in Ubuntu and follow GreenAsh's Running a real Windows install in VirtualBox on Linux instructions, slightly modified and with a couple of extra steps at the end.
First, we want to install VirtualBox and some related packages.
-
If you have version 5.1.18 or later in your Ubuntu repository, directly install that
sudo apt install virtualbox virtualbox-dkms virtualbox-ext-pack
-
If you have VirtualBox 5.1.6, the Guest Additions silently fail to work with the default Ubuntu 16.10 version, thus preventing us from resizing the Windows virtual machine to full resolution and full screen. In that case, you may want to install from the VirtualBox repository:
-
From the Ubuntu dash, "Software & Updates" -> "Other software" -> "Add". Following the VirtualBox linux downloads instructions, we add the deb source
deb [arch=amd64] http://download.virtualbox.org/virtualbox/debian yakkety contrib
-
Download and register the keys for the repository
wget -q https://www.virtualbox.org/download/oracle_vbox_2016.asc -O- | sudo apt-key add - wget -q https://www.virtualbox.org/download/oracle_vbox.asc -O- | sudo apt-key add -
-
Refresh the list of packages, and install the latest version of VirtualBox and the Oracle VM VirtualBox Extension Pack so that we can mount USB 2.0 and 3.0 devices, and other extended functionality.
sudo apt-get update sudo apt-get install virtualbox-5.1 virtualbox-ext-pack
-
Troubleshooting: If you had
virtualbox
installed, and have replaced it byvirtualbox-5.1
, when you try to start an existing virtual machine, you are going to get an error message saying that the VirtualBox kernel modules don't match the VirtualBox version. All you have to do is remove the old modules and rebuild themsudo rmmod vboxnetadp vboxnetflt vboxpci vboxdrv sudo /sbin/rcvboxdrv setup
-
Because
virtualbox-ext-pack
is the extension pack of the older 5.1.6 VirtualBox, when you launch VirtualBox, you may be asked whether you want to upgrade the Extension pack to 5.1.18. If so, accept and follow the upgrade process.
-
Either way, now you have to configure your system to work with VirtualBox
-
Add yourself as a VirtualBox user and to the
disk
group by running on a terminalsudo adduser $USER vboxusers sudo adduser $USER disk
-
Log out of Ubuntu and log in again for the changes to take effect.
-
Reboot, and press F12 during the Dell logo to enter the BIOS configuration.
-
Check that you have Secure Boot -> Secure Boot Enable -> Disabled.
-
Save and exit, and boot into Ubuntu.
-
Launch VirtualBox (you shouldn't have any virtual machines here), and go to File -> Preferences. Rename the default machine folder from
/home/$USER/VirtualBox VMs
to/home/$USER/VirtualBox_VMs
. Rename the/home/$USER/VirtualBox VMs
folder on your filesystem too, if it already exists. The reason for this is that whitespaces cause problems if you forget quotes, etc.
Now we are getting serious. This is the bit where we basically follow GreenAsh's Running a real Windows install in VirtualBox on Linux instructions
-
Install gparted
sudo apt-get install gparted
-
Run gparted and write down the partitions used by Windows. In my case, it was partitions
/dev/nvme0n1p1
(/boot/efi
),/dev/nvme0n1p2
(Microsoft reserved partition),/dev/nvme0n1p3
(OS / "Windows C drive"),/dev/nvme0n1p4
(WINRETOOLS),/dev/nvme0n1p5
(Image) and/dev/nvme0n1p6
(DELLSUPPORT). -
Create the "raw disk", which is a file with a pointer to the actual Windows partitions. In the example above, Windows is using partitions 1-6.
sudo VBoxManage internalcommands createrawvmdk \ -filename "$HOME/VirtualBox_VMs/win10pro.vmdk" \ -rawdisk /dev/nvme0n1 \ -partitions 1,2,3,4,5,6
-
Note: If this causes the machine to not boot and instead go to the
grub2
shell, you may need to allow access to the whole drive. This is very dangerous, because it will allow you to boot your Ubuntu host as a guest too, with both systems trying to access the same drive. If you do this, you need to make sure every time you boot your virtual machine, that you choose Windows.sudo VBoxManage internalcommands createrawvmdk \ -filename "$HOME/VirtualBox_VMs/win10pro.vmdk" \ -rawdisk /dev/nvme0n1
-
-
Change the owner and group of the pointer files, so that you can use them as a user and not superuser (otherwise, VirtualBox won't be able to use these files)
sudo chown $USER:$USER VirtualBox_VMs/win10pro*
After creating that pointer to the actual Windows partitions, we create a virtual machine for Windows 10 Pro in VirtualBox.
-
In VirtualBox, click on "New"
-
Set Name = "Windows_10_Pro", Type = "Microsoft Windows", Version = "Windows 10 (64-bit)".
-
Set Memory Size, e.g. 4096 B = 4 GB.
-
In "Hard drive", select "Use an existing virtual hard disk file", and select
/home/$USER/VirtualBox_VMs/win10pro.vmdk
. -
Click "Create".
-
In the "Oracle VM VirtualBox Manager" you will see your new "Windows 10 Pro" virtual machine. This virtual machine is "Powered Off".
If you try to boot now, you'll get a "FATAL! No bootable medium found" error. So we need a couple of final tweaks.
-
In VirtualBox, select the new Windows 10 Pro virtual machine, Settings -> Storage. Select
win10pro.vmdk
underController: SATA
and check "Solid-state drive", as the Dell XPS 15 comes with an SSD. -
Now select "System", and check "Enable EFI (special OSes only)".
We are going to enable graphics acceleration and provide enough video memory for full resolution.
-
In VirtualBox, select the Windows 10 Pro virtual machine, "Settings" -> "Display", and check "Enable 3D acceleration" and "Enable 2D video acceleration".
-
Increase video memory to 256 MB.
At this point, if you click "Start", the virtual machine will launch and boot your Windows 10 installation. But Windows 10 runs in a small size. To be able to increase the resolution, we need the Guest Additions.
-
Start the Windows 10 virtual machine.
-
On the virtual machine menu bar, "Devices" -> "Insert Guest Additions CD Image".
-
A dialogue will tell you that no CD is present and whether you wish to download from the internet. Click "Download", and then "Insert". This doesn't install the guest additions, only mounts the ISO as a CD.
-
Log into Windows. Open the File Explorer, "This PC" -> "CD Drive (D:)". Double-click on
VBoxWindowsAdditions.exe
. Follow the installation process, that at the end will ask to reboot Windows. -
Shut down the virtual machine and close VirtualBox. From a terminal create a custom video mode (1920x1080 is the screen resolution, and 24 is the colour-depth in bits)
VBoxManage setextradata "Windows_10_Pro" "CustomVideoMode1" "1920x1080x24"
Now we can use the laptop's screen at full specs for the Windows 10 virtual machine. This only needs to be done once, as afterwards every time we start the virtual machine, it'll remember the settings.
-
Launch VirtualBox and start the Windows 10 virtual machine.
-
In the menu, select "View" -> "Virtual Screen 1" -> "Resize to 1920x1080".
-
"View" -> "Full screen mode".
With this settings, the whole screen will display a Windows 10 Pro session, indistinguishable from running Windows natively, except for a thin gray line at the bottom that corresponds to a VirtualBox pull-up menu.
-
Launch VirtualBox with the virtual machine shut down.
-
Go to "Settings" -> "General" -> "Advanced".
-
Select "Bidirectional" for "Shared Clipboard". This enables copying something in Ubuntu and pasting to Windows, or vice versa.
-
Select "Bidirectional" for "Drag'n'Drop". This enables dragging a file from the Ubuntu file manager, and drop it in Windows, making a copy. For me, this works from Ubuntu to Windows, but not the other way around.
-
With the virtual machine shut down, open "Settings" -> "Shared folders".
-
Click on "Add new shared folders", and point it to your linux home directory. "Folder path" =
/home/$USER
, "Folder name" =linux_$USER
, where$USER
is your linux username, , "Read-only" = No, "Auto-mount" = Yes. -
When trying to start the virtual machine, I got the error
Kernel driver not installed (rc=-1908) The VirtualBox Linux kernel driver (vboxdrv) is either not loaded or there is a permission problem with /dev/vboxdrv. Please reinstall the kernel module by executing '/sbin/vboxconfig' as root. where: suplibOsInit what: 3 VERR_VM_DRIVER_NOT_INSTALLED (-1908) - The support driver is not installed. On linux, open returned ENOENT.
-
Running the suggested command fixed the error
sudo /sbin/vboxconfig
-
Start the Windows 10 Pro virtual machine. In File Explorer now you have a
linux_$USER
folder assigned to unitE:\
. This way, Windows can access the Ubuntu partition, so that you can store your data and documents there.
-
Launch Windows from VirtualBox in Ubuntu.
-
Search for "BitLocker" in the Start menu, and click in "Turn on BitLocker". You'll get the error
This device can’t use a Trusted Platform Module. Your administrator must set the ‘Allow BitLocker without a compatible TPM’ option in the ‘Require additional authentication at startup’ policy for OS volumes.
-
Enable BitLocker encryption without a TPM chip
- Go to the search box on the taskbar and type “group ” or “group policy ”. Then, open the “Edit group policy" search result.
- Go to Computer Configuration -> Administrative Templates -> Windows Components -> BitLocker Drive Encryption -> Operating System Drives.
- Open "Require additional authentication at startup".
- Change the value of the policy to "Enabled", and check "Allow BitLocker without a compatible TPM".
- Click OK, and close the policy editor.
-
Go back to BitLocker, and now you should be allowed to "Turn on BitLocker".
-
Click through several dialogues.
- Check that partition "C:" is going to be encrypted. You don't want to encrypt something else by mistake.
- Create the private key and save it somewhere safe (whether you want to upload it to Microsoft is up to you). If you lose it, you won't be able to recover anything in "C:" if something goes wrong.
- Choose whether you want the fast or complete encryption.
- Click OK. Windows will need to restart to encrypt the partition.
Booting Windows alternatively as native or as virtual machine makes Office 2013 detect a hardware change and ask for re-activation (you only have a couple of online activations before you have to go through a slow phone process, so you probably want to stick to running Office either natively or on the virtual machine).
Possible source of information (I have only skimmed it): https://mazimi.wordpress.com/2007/07/11/getting-around-windows-activation-when-virtualizing/
At this moment, when I try to drag a file from the Windows guest to the Ubuntu host, I get an error
Drag and drop operation from guest to host failed.
Drag and drop error from guest (VERR_FILE_NOT_FOUND).
Result Code:
VBOX_E_IPRT_ERROR (0x80BB0005)
Component:
GuestWrap
Interface:
IGuest {13a11514-402e-022e-6180-c3944de3f9c8}
These problems happen with latest linux-firmware package (v1.164).
I'm currently using the Microsoft Sculpt Comfort Mouse that connects via bluetooth to the laptop.
However, suspending/resuming the laptop crashes the bluetooth, and it cannot be brought back to life without rebooting.
Manual bluetooth blocking/unblocking works, so user rpress suggested blocking the bluetooth before suspend, and unblocking afterwards, and also killing and reloading module btusb
. Create the script with the right permissions and open it in an editor
cd /etc/pm/sleep.d
sudo touch 10_bluetooth
sudo chmod 0755 10_bluetooth
sudo emacs 10_bluetooth
Then add the code
#!/bin/bash
#Code from http://ubuntuforums.org/showthread.php?t=1387211
. /usr/lib/pm-utils/functions
case "$1" in
hibernate|suspend)
rfkill block bluetooth
;;
thaw|resume)
rfkill unblock bluetooth
rmmod btusb
modprobe btusb
;;
*)
;;
esac
exit
This works for one suspend/resume, but with two in a row, bluetooth dies after some use of the mouse, and I haven't found a way to get it back without rebooting the laptop.