From 5861397b7df921307fce1db43b8731ea997c7211 Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Sun, 26 May 2019 19:32:45 -0500 Subject: [PATCH 001/136] Reorganize files to account for new "External" section QubesOS/qubes-issues#4693 --- building/building-archlinux-template.md | 491 ++++++++++++++ building/building-non-fedora-template.md | 151 +++++ building/building-whonix-template.md | 94 +++ configuration-guides/change-time-zone.md | 36 + configuration-guides/disk-trim.md | 112 ++++ configuration-guides/external-audio.md | 55 ++ configuration-guides/fetchmail.md | 93 +++ configuration-guides/gui-configuration.md | 37 ++ configuration-guides/multiboot.md | 214 ++++++ configuration-guides/multimedia.md | 240 +++++++ configuration-guides/mutt.md | 222 +++++++ .../network-bridge-support.md | 146 +++++ configuration-guides/network-printer.md | 55 ++ configuration-guides/postfix.md | 155 +++++ configuration-guides/resize-disk-image.md | 76 +++ configuration-guides/rxvt.md | 152 +++++ configuration-guides/tips-and-tricks.md | 62 ++ configuration-guides/vpn.md | 324 +++++++++ configuration-guides/w3m.md | 40 ++ configuration-guides/zfs.md | 197 ++++++ customization-guides/awesome.md | 187 ++++++ customization-guides/dark-theme.md | 187 ++++++ .../fedora-minimal-template-customization.md | 294 +++++++++ customization-guides/i3.md | 90 +++ customization-guides/kde.md | 88 +++ customization-guides/language-localization.md | 46 ++ .../removing-templatevm-packages.md | 93 +++ .../windows-template-customization.md | 168 +++++ managing-os/archlinux.md | 434 ++++++++++++ managing-os/linux-hvm-tips.md | 96 +++ managing-os/netbsd.md | 23 + managing-os/pentesting.md | 30 + managing-os/pentesting/blackarch.md | 96 +++ managing-os/pentesting/kali.md | 616 ++++++++++++++++++ managing-os/pentesting/ptf.md | 121 ++++ managing-os/ubuntu.md | 41 ++ managing-os/windows/windows-tools.md | 158 +++++ managing-os/windows/windows-vm.md | 188 ++++++ .../anonymizing-your-mac-address.md | 69 ++ privacy-guides/martus.md | 49 ++ privacy-guides/signal.md | 65 ++ privacy-guides/tails.md | 86 +++ privacy-guides/torvm.md | 281 ++++++++ privacy-guides/whonix.md | 58 ++ security-guides/device-handling-security.md | 72 ++ security-guides/multifactor-authentication.md | 186 ++++++ security-guides/security-guidelines.md | 166 +++++ security-guides/split-bitcoin.md | 52 ++ security-guides/vm-sudo.md | 160 +++++ security-guides/yubi-key.md | 177 +++++ troubleshooting/install-nvidia-driver.md | 172 +++++ troubleshooting/intel-igfx-troubleshooting.md | 65 ++ troubleshooting/macbook-troubleshooting.md | 328 ++++++++++ .../newer-hardware-troubleshooting.md | 25 + troubleshooting/nvidia-troubleshooting.md | 159 +++++ troubleshooting/out-of-memory.md | 47 ++ troubleshooting/remove-vm-manually.md | 36 + troubleshooting/sony-vaio-tinkering.md | 58 ++ troubleshooting/thinkpad-troubleshooting.md | 94 +++ troubleshooting/uefi-troubleshooting.md | 237 +++++++ troubleshooting/updating-debian-and-whonix.md | 138 ++++ troubleshooting/wireless-troubleshooting.md | 121 ++++ 62 files changed, 8809 insertions(+) create mode 100644 building/building-archlinux-template.md create mode 100644 building/building-non-fedora-template.md create mode 100644 building/building-whonix-template.md create mode 100644 configuration-guides/change-time-zone.md create mode 100644 configuration-guides/disk-trim.md create mode 100644 configuration-guides/external-audio.md create mode 100644 configuration-guides/fetchmail.md create mode 100644 configuration-guides/gui-configuration.md create mode 100644 configuration-guides/multiboot.md create mode 100644 configuration-guides/multimedia.md create mode 100644 configuration-guides/mutt.md create mode 100644 configuration-guides/network-bridge-support.md create mode 100644 configuration-guides/network-printer.md create mode 100644 configuration-guides/postfix.md create mode 100644 configuration-guides/resize-disk-image.md create mode 100644 configuration-guides/rxvt.md create mode 100644 configuration-guides/tips-and-tricks.md create mode 100644 configuration-guides/vpn.md create mode 100644 configuration-guides/w3m.md create mode 100644 configuration-guides/zfs.md create mode 100644 customization-guides/awesome.md create mode 100644 customization-guides/dark-theme.md create mode 100644 customization-guides/fedora-minimal-template-customization.md create mode 100644 customization-guides/i3.md create mode 100644 customization-guides/kde.md create mode 100644 customization-guides/language-localization.md create mode 100644 customization-guides/removing-templatevm-packages.md create mode 100644 customization-guides/windows-template-customization.md create mode 100644 managing-os/archlinux.md create mode 100644 managing-os/linux-hvm-tips.md create mode 100644 managing-os/netbsd.md create mode 100644 managing-os/pentesting.md create mode 100644 managing-os/pentesting/blackarch.md create mode 100644 managing-os/pentesting/kali.md create mode 100644 managing-os/pentesting/ptf.md create mode 100644 managing-os/ubuntu.md create mode 100644 managing-os/windows/windows-tools.md create mode 100644 managing-os/windows/windows-vm.md create mode 100644 privacy-guides/anonymizing-your-mac-address.md create mode 100644 privacy-guides/martus.md create mode 100644 privacy-guides/signal.md create mode 100644 privacy-guides/tails.md create mode 100644 privacy-guides/torvm.md create mode 100644 privacy-guides/whonix.md create mode 100644 security-guides/device-handling-security.md create mode 100644 security-guides/multifactor-authentication.md create mode 100644 security-guides/security-guidelines.md create mode 100644 security-guides/split-bitcoin.md create mode 100644 security-guides/vm-sudo.md create mode 100644 security-guides/yubi-key.md create mode 100644 troubleshooting/install-nvidia-driver.md create mode 100644 troubleshooting/intel-igfx-troubleshooting.md create mode 100644 troubleshooting/macbook-troubleshooting.md create mode 100644 troubleshooting/newer-hardware-troubleshooting.md create mode 100644 troubleshooting/nvidia-troubleshooting.md create mode 100644 troubleshooting/out-of-memory.md create mode 100644 troubleshooting/remove-vm-manually.md create mode 100644 troubleshooting/sony-vaio-tinkering.md create mode 100644 troubleshooting/thinkpad-troubleshooting.md create mode 100644 troubleshooting/uefi-troubleshooting.md create mode 100644 troubleshooting/updating-debian-and-whonix.md create mode 100644 troubleshooting/wireless-troubleshooting.md diff --git a/building/building-archlinux-template.md b/building/building-archlinux-template.md new file mode 100644 index 0000000..88f3caf --- /dev/null +++ b/building/building-archlinux-template.md @@ -0,0 +1,491 @@ +--- +layout: doc +title: Building Archlinux Template +permalink: /doc/building-archlinux-template/ +redirect_from: +- /en/doc/building-archlinux-template/ +- /doc/BuildingArchlinuxTemplate/ +- /wiki/BuildingArchlinuxTemplate/ +--- + +# Archlinux template building instructions + +**These are the instructions for Qubes 3.2. They will take you step by step through the entire process start to finish** + +*Note: These instructions have not been tested for Qubes 3.1. However they could be working.* + +*Note: No binary package for the archlinux template exists for Qubes 3.1.* + +## 1: Create and configure VM to use for template building + +* The VM should be based on a Fedora template. It's best to use a standalone VM. I created a standalone VM based on + the Fedora 23 template. I named the VM “**development**”. These instructions assume a standalone VM based on a Fedora template is being used. +
+
+![arch-template-01](/attachment/wiki/ArchlinuxTemplate/arch-template-01.png) +
+
+* Ensure there is at least 25GB preferably 30GB of free space in the private storage. I made the private storage 30GB to be safe. +
+
+![arch-template-02](/attachment/wiki/ArchlinuxTemplate/arch-template-02.png) +
+
+ +*Note: Unless otherwise noted, all commands are from within the “development” VM or whatever you named your standalone VM used for building the template.* + +## 2: Create GitHub Account (optional) + +* It can be helpful. Creating only a basic account is all that is needed. This will allow you to help, going forward, with the Qubes project. You could be help edit errors in documentation. It can also be of use building other templates. + +* Create user account here https://github.com +
+
+![arch-template-03](/attachment/wiki/ArchlinuxTemplate/arch-template-03.png) +
+
+ +## 3: Install necessary packages to 'development' VM for "Qubes Automated Build System" + +* Necessary packages to install: + + * git + + * createrepo + + * rpm-build + + * make + + * rpmdevtools + + * python2-sh + + * dialog + + * rpm-sign + + * gnupg + + +* The tools can usually be installed all together with the following terminal command string: + + * **$ sudo dnf install git createrepo rpm-build make wget rpmdevtools python2-sh dialog rpm-sign gnupg** +
+
+![arch-template-04](/attachment/wiki/ArchlinuxTemplate/arch-template-04.png) +
+
+ +## 4: Downloading and verifying the integrity of the "Qubes Automated Build System" + +* Import the Qubes master key + + gpg --keyserver pgp.mit.edu --recv-keys 0xDDFA1A3E36879494 + +* Verify its fingerprint, set as 'trusted'. [This is described here](/doc/VerifyingSignatures). + +* Download the Qubes developers' keys. + + wget https://keys.qubes-os.org/keys/qubes-developers-keys.asc + gpg --import qubes-developers-keys.asc + +* Download the latest stable qubes-builder repository: + + git clone git://github.com/QubesOS/qubes-builder.git qubes-builder + + ![arch-template-05](/attachment/wiki/ArchlinuxTemplate/arch-template-05.png) + +* Copy your gpg keyrings to your local copy of the repository. (Otherwise you will be asked to download the keys again.) + + # Execute the following commands in your home directory. + # It is assumed that the path to the repository is '~/qubes-builder'. + mkdir -p qubes-builder/keyrings/git + cp -t qubes-builder/keyrings/git/ .gnupg/pubring.gpg .gnupg/trustdb.gpg + +* Verify the integrity of the downloaded repository. The last line should read `gpg: Good signature from`... + + cd qubes-builder + git tag -v `git describe` + + +## 5: Configuring setup script to create builder.conf file + +* You will be creating the builder.conf file which tells where and what to use. The most automated, and in this case the easiest, way to create this is to use the script that is provided in Qubes Builder. Its named '**setup**'. Before running the script you need to edit one file it uses. + + *In the future this should not be needed once a change is made to the 'setup' script.* + + * Edit the '**qubes-os-r3.2.conf**' which is found in **/home/user/qubes-builder/example-configs** Use the text editor of your choice. + + * **$ cd /home/user/qubes-builder/example-configs/** + + * **$ nano -W qubes-os-r3.2.conf** or **$ gedit qubes-os-r3.2.conf** or etc…. +
+
+![arch-template-06](/attachment/wiki/ArchlinuxTemplate/arch-template-06.png) +
+
+ * Go to the first line containing '**DISTS_VM ?= fc23**' it will be preceeded by line '**DIST_DOM0 ?= fc20**'. Remove '**fc23**' or whatever is listed there leaving only '**DISTS_VM ?=**'. Then save the file and close the text editor. +
+
+![arch-template-07](/attachment/wiki/ArchlinuxTemplate/arch-template-07.png) +
+
+
+ +## 6: Run the 'setup' script to build the builder.conf file + +* Run the 'setup' script located in '**/home/user/qubes-builder/**' Make sure you are in directory '**qubes-builder**' + + * **$ cd /home/user/qubes-builder/** + + * **$ ./setup** +
+
+![arch-template-08](/attachment/wiki/ArchlinuxTemplate/arch-template-08.png) +
+
+ * First screen will ask you to import 'Qubes-Master-Signing-key.asc'. The 'setup' script not only downloads but confirms the key to that of the key on Qubes-OS website. + + * Select '**YES**' + * Select '**OK**' Press '**Enter**' +
+
+![arch-template-09](/attachment/wiki/ArchlinuxTemplate/arch-template-09.png) +
+
+ + * Next screen will ask you to import Marek Marczykowski-Goracki (Qubes OS signing key). Again 'setup' will confirm this key to the fingerprint. + + * Select '**YES**' + * Select '**OK**' Press '**Enter**' +
+
+![arch-template-10](/attachment/wiki/ArchlinuxTemplate/arch-template-10.png) +
+
+ + * This screen will give you the choice of which Qubes Release to build the template for. + + * Select '**Qubes Release 3.2**' + * Select '**OK**' Press '**Enter**' +
+
+![arch-template-11](/attachment/wiki/ArchlinuxTemplate/arch-template-11.png) +
+
+ + * Screen "**Choose Repos To Use To Build Packages**" + + * Select 'QubesOS/qubes- Stable - Default Repo' + * Select '**OK**' Press '**Enter**' +
+
+![arch-template-12](/attachment/wiki/ArchlinuxTemplate/arch-template-12.png) +
+
+ + * Screen "**Build Template Only?**" + + * Select '**Yes**' Press '**Enter**' +
+
+![arch-template-12](/attachment/wiki/ArchlinuxTemplate/arch-template-12a.png) +
+
+ + * Screen '**Builder Plugin Selection**' will give choices of builder plugins to use for the build. + + * Deselect '**Fedora**' + + * Deselect '**mgmt_salt**' + + * Select '**builder-archlinux**' + + * Select '**OK**' Press **Enter** +
+
+![arch-template-13](/attachment/wiki/ArchlinuxTemplate/arch-template-13.png) +
+
+ + * Screen '**Get sources**' wants to download additional packages needed for the choosen plugin/s. + + * Select '**Yes**' Press '**Enter**' +
+
+![arch-template-14](/attachment/wiki/ArchlinuxTemplate/arch-template-14.png) +
+
+ + * Then wait for download to finish and press '**OK**' +
+
+![arch-template-14](/attachment/wiki/ArchlinuxTemplate/arch-template-15.png) +
+
+ + * Screen '**Template Distribution Selection**' allows you to choose the actual template/s you wish to build. + + * Scroll Down to the very bottom (it is off the screen at first) + + * Select '**archlinux**' + + * Select '**OK**' Press '**Enter**' +
+
+![arch-template-16](/attachment/wiki/ArchlinuxTemplate/arch-template-16.png) +
+
+ + *Note: 'Setup' will close and will output the text of the created build.conf file as well as the needed **make** commands to build the template* +
+
+![arch-template-17](/attachment/wiki/ArchlinuxTemplate/arch-template-17.png) +
+
+ +## 7: Install all the dependencies + +*Note: make sure you are in the “qubes-builder” directory to run the following cmds* + +* **$ make install-deps** +
+
+![arch-template-18](/attachment/wiki/ArchlinuxTemplate/arch-template-18.png) +
+
+ +## 8: Get all the require sources for the build: (Note: this may take some time) + +* **$ make get-sources** +
+
+![arch-template-19](/attachment/wiki/ArchlinuxTemplate/arch-template-19.png) +
+
+
+ +## 9: Make all the require Qubes Components + +* **Note:** You can run a single command to build all the Qubes components or you can run them each individually. + Both ways below: + + * Single command to build all Qubes components together: (this command can take a long time to process depending of your pc proccessing power) + + * **$ make qubes-vm** +
+
+![arch-template-20](/attachment/wiki/ArchlinuxTemplate/arch-template-20.png) +
+
+ + + * These are the indivual component 'make' commands: + + * **$ make vmm-xen-vm** + + * **$ make core-vchan-xen-vm** + + * **$ make core-qubesdb-vm** + + * **$ make linux-utils-vm** + + * **$ make core-agent-linux-vm** + + * **$ make gui-common-vm** + + * **$ make gui-agent-linux-vm** +
+
+ + +## 10: Make the actual Archlinux template + +* **$ make template** +
+
+![arch-template-21](/attachment/wiki/ArchlinuxTemplate/arch-template-21.png) +
+
+ +## 11: Transfer Template into Dom0 + +* You need to ensure these two files are in the '**noarch**' directory + + * **$ cd /home/user/qubes-builder/qubes-src/linux-template-builder/rpm/** + + * **$ ls** *(confirm the below two files are there)* + + * **install-templates.sh** (script to install template in dom0) + + * **$ cd noarch** + + * **$ ls** + + * **qubes-template-archlinux-X.X.X-XXXXXXXXXXXX.noarch.rpm** (this is the template package 'X' replaces version and build digits) +
+
+![arch-template-22](/attachment/wiki/ArchlinuxTemplate/arch-template-22.png) +
+
+ +* **Transfer the install-templates.sh script file into Dom0** + *Note: as there is not a typical file transfer method for Dom0, for security reasons, this less than simple transfer function has to be used* + + * Switch to Domo and open a terminal window. + + **Note:** Take care when entering these cmd strings. They are very long and have a number of characters that are easy to mix '**-**' vs '**.**' '**Templates** (correct) vs **templates** (wrong) or **Template_**'(also wrong) This script will also take care of transfering the actual template.rpm to Dom0 as well. + + * **$ qvm-run --pass-io development 'cat /home/user/qubes-builder/qubes-src/linux-template-builder/rpm/install-templates.sh' > install-templates.sh** + + * **$ chmod +x install-templates.sh** + + * **$ ./install-templates.sh** + +
+
+![arch-template-23](/attachment/wiki/ArchlinuxTemplate/arch-template-23.png) +
+
+![arch-template-24](/attachment/wiki/ArchlinuxTemplate/arch-template-24.png) +
+
+ +* If everything went correct there should be a Archlinux template listed in your Qubes VM Manager * + + +# Known problems in building with Qubes R3.X + +## Build fails when fetching qubes-mgmt-salt + +The `qubes-mgmt-salt` repo is not currently forked under the marmarek user on +GitHub, to whom the above instructions set the `GIT_PREFIX`. As Archlinux is +not yet supported by mgmt-salt, simply leave it out of the build (when building +the Archlinux template on its own) by appending the following to your `override.conf` file: + +`BUILDER_PLUGINS := $(filter-out mgmt-salt,$(BUILDER_PLUGINS))` + +## The nm-applet (network manager icon) fails to start when archlinux is defined as a template-vm + +In fact /etc/dbus-1/system.d/org.freedesktop.NetworkManager.conf does not allow a standard user to run network manager clients. To allow this, one need to change inside \: + +`` + +to + +`` + +## DispVM, Yum proxy and most Qubes addons (thunderbird ...) have not been tested at all + +## Error when building the gui-agent-linux with pulsecore error + +``` +module-vchan-sink.c:62:34: fatal error: pulsecore/core-error.h: No such file or directory + #include +``` + +This error is because Archlinux update package too quickly. Probably, a new version of pulseaudio has been released, but the qubes team has not imported the new development headers yet. + +You can create fake new headers just by copying the old headers: +``` +cd qubes-builder/qubes-src/gui-agent-linux/pulse +ls +cp -r pulsecore-#lastversion pulsecore-#archlinuxversion +``` + +You can check the current archlinux pulseaudio version like this: + +`sudo chroot chroot-archlinux/ pacman -Qi pulseaudio` + +## chroot-archlinux/dev/pts has not been unmounted + +This is a known problem when there are errors during building. Check what is mounted using the command mount (with no parameters). Just unmount what you can (or reboot your vm if you are too lazy :) ) + +# Known problems in building with Qubes R2-B2 + +## xen-vmm-vm fail to build with a PARSETUPLE related error (FIXED) + +Commenting out "\#define HAVE\_ATTRIBUTE\_FORMAT\_PARSETUPLE" from chroot\_archlinux/usr/include/python2.7/pyconfig.h fixes the problem, but it isn't the right solution [1]... + +A better fix is planned for the next python release (the bug is considered release blocking), and will be updated in archlinux chroot as soon as available. + +[1] [https://bugs.python.org/issue17547](https://bugs.python.org/issue17547) + +## The boot process fails without visible errors in the logs, but spawn a recovery shell + +The problem is new conflict between systemd and the old sysvinit style. To fix this, you can change the master xen template in dom0 to remove sysvinit remains: Edit **INSIDE DOM0** /usr/share/qubes/vm-template.conf, and change the variable 'extra' that contains the kernel variables: from: + +`extra="ro nomodeset 3 console=hvc0 rd_NO_PLYMOUTH {kernelopts}"` + +to: + +`extra="ro nomodeset console=hvc0 rd_NO_PLYMOUTH {kernelopts}"` + +## Qubes-OS is now using different xenstore variable names, which makes to archlinux VM failing to boot + +Apply the following fix in the template to revert the variable name to the old Qubes version. + +You can edit the template the following way: + +``` +sudo mkdir /mnt/vm +sudo mount /var/lib/qubes/vm-templates/archlinux-x64/root.img /mnt/vm +sudo chroot /mnt/vm +``` + +Then apply the fix: + +``` +sudo sed 's:qubes-keyboard:qubes_keyboard:g' -i /etc/X11/xinit/xinitrc.d/qubes-keymap.sh + +sudo sed 's:qubes-netvm-domid:qubes_netvm_domid:g' -i /etc/NetworkManager/dispatcher.d/30-qubes-external-ip +sudo sed 's:qubes-netvm-external-ip:qubes_netvm_external_ip:g' -i /etc/NetworkManager/dispatcher.d/30-qubes-external-ip + +sudo sed 's:qubes-netvm-network:qubes_netvm_network:g' -i /usr/lib/qubes/init/network-proxy-setup.sh +sudo sed 's:qubes-netvm-gateway:qubes_netvm_gateway:g' -i /usr/lib/qubes/init/network-proxy-setup.sh +sudo sed 's:qubes-netvm-netmask:qubes_netvm_netmask:g' -i /usr/lib/qubes/init/network-proxy-setup.sh +sudo sed 's:qubes-netvm-secondary-dns:qubes_netvm_secondary_dns:g' -i /usr/lib/qubes/init/network-proxy-setup.sh + +sudo sed 's:qubes-vm-type:qubes_vm_type:g' -i /usr/lib/qubes/init/qubes-sysinit.sh + +sudo sed 's:qubes-ip:qubes_ip:g' -i /usr/lib/qubes/setup-ip +sudo sed 's:qubes-netmask:qubes_netmask:g' -i /usr/lib/qubes/setup-ip +sudo sed 's:qubes-gateway:qubes_gateway:g' -i /usr/lib/qubes/setup-ip +sudo sed 's:qubes-secondary-dns:qubes_secondary_dns:g' -i /usr/lib/qubes/setup-ip +sudo sed 's:qubes-netvm-network:qubes_netvm_network:g' -i /usr/lib/qubes/setup-ip +sudo sed 's:qubes-netvm-gateway:qubes_netvm_gateway:g' -i /usr/lib/qubes/setup-ip +sudo sed 's:qubes-netvm-netmask:qubes_netvm_netmask:g' -i /usr/lib/qubes/setup-ip +sudo sed 's:qubes-netvm-secondary-dns:qubes_netvm_secondary_dns:g' -i /usr/lib/qubes/setup-ip + +sudo sed 's:qubes-iptables-domainrules:qubes_iptables_domainrules:g' -i /usr/bin/qubes-firewall +sudo sed 's:qubes-iptables-header:qubes_iptables_header:g' -i /usr/bin/qubes-firewall +sudo sed 's:qubes-iptables-error:qubes_iptables_error:g' -i /usr/bin/qubes-firewall +sudo sed 's:qubes-iptables:qubes_iptables:g' -i /usr/bin/qubes-firewall + +sudo sed 's:qubes-netvm-domid:qubes_netvm_domid:g' -i /usr/bin/qubes-netwatcher +sudo sed 's:qubes-netvm-external-ip:qubes_netvm_external_ip:g' -i /usr/bin/qubes-netwatcher +sudo sed 's:qubes-vm-updateable:qubes_vm_updateable:g' -i /usr/lib/qubes/qubes_trigger_sync_appmenus.sh + +sudo sed 's:qubes-vm-type:qubes_vm_type:g' -i /usr/bin/qubes-session +sudo sed 's:qubes-vm-updateable:qubes_vm_updateable:g' -i /usr/bin/qubes-session +``` + +Do not forgot to unmount the VM: + +`umount /mnt/vm` + +## Installing the template in dom0 fails because of a missing dependency (qubes-core-dom0-linux) + +Again you built a template based on a recent Qubes API which has not been released yet. So skip the dependency for now + +`sudo rpm -U --nodeps yourpackage.rpm` + + +# Qubes Mailing List Threads on the Archlinux build process + +* [Qubes-Devel](https://groups.google.com/forum/#!forum/qubes-devel): [Qubes Builder failed Archlinux repository is missing](https://groups.google.com/forum/#!topic/qubes-devel/tIFkS-rPVx8) + +* [Qubes-Users](https://groups.google.com/forum/#!forum/qubes-users): [Trying to compile archlinux template](https://groups.google.com/forum/#!topic/qubes-users/7wuwr3LgkQQ) + +
diff --git a/building/building-non-fedora-template.md b/building/building-non-fedora-template.md new file mode 100644 index 0000000..182634a --- /dev/null +++ b/building/building-non-fedora-template.md @@ -0,0 +1,151 @@ +--- +layout: doc +title: Building Non-Fedora Template +permalink: /doc/building-non-fedora-template/ +redirect_from: +- /en/doc/building-non-fedora-template/ +- /doc/BuildingNonFedoraTemplate/ +- /wiki/BuildingNonFedoraTemplate/ +--- + +Building a TemplateVM for ArchLinux (or another non Fedora OS) +============================================================== + +If you don't like using Fedora because of specific administration, package management or other building needs, you could build a TemplateVM for your distribution of choice. + +This article shows how to build a template for a different OS, taking ArchLinux as an example. + +Qubes builder scripts +===================== + +You can start creating Qubes builder scripts for your new OS. Just note that it will probably make your testing process harder than trying to build the package directly in an HVM on which you already installed this new OS. + +chroot initialization +--------------------- + +You need to customize some scripts that will be used to build all the Qubes tools. + +The scripts you will be interested in will be inside the `qubes-src/linux-template-builder` folder: + +~~~ +scripts_fedora +scripts_archlinux +scripts_yourOSname +~~~ + +### 00\_prepare.sh + +The goal of the first script `00_prepare.sh` is to download and verify the signature of the installation CD and tools. You can use the `$CACHEDIR` directory variable to store files that could be reused (such as downloaded scripts or iso files). + +### 01\_install\_core.sh + +The goal of this script is to install a base environment of your target OS inside the `$INSTALLDIR` directory variable. Generally you need to bootstrap/install your package manager inside the `$INSTALLDIR` directory and install the base packages. + +### Testing the installation process + +Edit the file `builder.conf` to change the variable `$DISTS_VM` to your OS name (`DISTS_VM=your_os_name`). The try to create (make) the template to check that at least these first two scripts are working correctly: + +~~~ +make linux-template-builder +~~~ + +Qubes builder Makefiles +----------------------- + +Now you need to create Makefiles specific to your OS. You will find the required scripts directly inside the `qubes-builder` folder: + +~~~ +prepare-chroot-yourOSname +Makefile.yourOSname +~~~ + +### prepare-chroot-yourOSname + +The goal of this file is to prepare a development environment of your target OS inside a chroot. You will reuse the `00_prepare.sh` and `01_install_core.sh` scripts. Additionally, the following things will be necessary to put in this Makefile: + +- the `$1` variable will contain the installation directory (`$INSTALLDIR` should contain the same value as `$1` when you run `00_prepare.sh` or `01_install_core.sh`) +- after your base system is installed, you should install development tools and libraries (gcc, make, ...) +- create a user called 'user' inside your chroot, and give him enough rights to run the command sudo without any password +- register all the repositories that are be necessary and synchronize the package database +- register a custom repository that will be used to store Qubes packages + +### Makefile.yourOSname + +This file will be used to define the action required when installing a custom package. The most important one are: + +- `dist-prepare-chroot`: that's where you will call `prepare-chroot-yourOSname` if the chroot has not been initialized. +- `dist-package`: that's where you will chroot the development environment and run the command used to build a package. +- `dist-build-dep`: that's where you will create the custom repository for your target OS based on already compiled packages. + +These additional target need to exist once you created your first packages: + +- `dist-copy-out`: that's where you will retrieve the package you just built and put it with all the other packages you prepared. +- `update-repo`: that's where you will retrieve the package that have been built and add it to the custom repository. + +### Testing the development chroot + +You will be able to test these scripts when making the first Qubes packages. Don't forget that the first things that run when running `make somcomponent-vm` will be these two scripts, and that you will need to debug it at this point. + +Qubes packages +-------------- + +* [vmm-xen](https://github.com/QubesOS/qubes-vmm-xen) +* [core-vchan-xen](https://github.com/QubesOS/qubes-core-vchan-xen) +* [linux-utils](https://github.com/QubesOS/qubes-linux-utils) +* [core-agent-linux](https://github.com/QubesOS/qubes-core-agent-linux) +* [gui-common](https://github.com/QubesOS/qubes-gui-common) +* [gui-agent-linux](https://github.com/QubesOS/qubes-gui-agent-linux) + +Additional Installation scripts +------------------------------- + +Again you need to work on scripts inside the `qubes-src/linux-template-builder` folder: + +~~~ +scripts_fedora +scripts_archlinux +scripts_yourOSname +~~~ + +### 02\_install\_groups.sh + +The goal of this script is to install all the packages that you want to use in your template (eg: firefox, thunderbird, a file manager, Xorg...). + +### 04\_install\_qubes.sh + +The goal of this script is to install in your template all the packages you built previously. Also you need to edit the fstab file of your template to mount Qubes virtual hard drives. + +### 09\_cleanup.sh + +This script is use to finalize and to remove unnecessary things from your template, such as cached packages, unused development packages ... + +Starting with an HVM +==================== + +If no Qubes packages are available for your selected OS. You could start to install an HVM with your OS. Your goals will be: + +- to identify how to install the OS using command lines +- to create required Qubes packages +- to identify potential issue making all Qubes agents and scripts working correctly. + +As soon as you manage to make `qrexec` and `qubes-gui-agent` working, it should be sufficient to start preparing a template VM. + +### Xen libraries + +Several Xen libraries are required for Qubes to work correctly. In fact, you need to make `xenstore` commands working before anything else. For this, Qubes git can be used as several patches have been selected by Qubes developers that could impact the activity inside a VM. Start be retrieving a recent git and identify how you can build a package from it: `git clone https://github.com/QubesOS/qubes-vmm-xen.git`. + +Find the .spec file in the git repository (this is the file being used to build rpm packages), and try to adapt it to your OS in order to build a package similar to the target 'vmm-xen'. For example, a PKGBUILD has been created for [ArchLinux](/doc/templates/archlinux/) and can be found in the vmm-xen repository. + +Don't be afraid with the complexity of the PKGBUILD, most of the code is almost a copy/paste of required sources and patches found in the .spec file provided in the git repository. + +Note once the package has been successfully compiled and installed, you need to setup XEN filesystem. Add the following line to your fstab (you can create this line in your package install script): `xen /proc/xen xenfs defaults 0 0`. + +Now install the package you built and mount `/proc/xen`. Verify that xenstore-read works by running: `xenstore-read name`. That should give you the current name. + +### ArchLinux example PKGBUILDs + +Qubes OS core agent (qrexec...) - [https://aur.archlinux.org/packages/qu/qubes-vm-core/PKGBUILD](https://aur.archlinux.org/packages/qu/qubes-vm-core/PKGBUILD) + +Qubes OS kernel modules - [https://aur.archlinux.org/packages/qu/qubes-vm-kernel-modules/PKGBUILD](https://aur.archlinux.org/packages/qu/qubes-vm-kernel-modules/PKGBUILD) + +Qubes OS GUI agent - [https://aur.archlinux.org/packages/qu/qubes-vm-gui/PKGBUILD](https://aur.archlinux.org/packages/qu/qubes-vm-gui/PKGBUILD) diff --git a/building/building-whonix-template.md b/building/building-whonix-template.md new file mode 100644 index 0000000..423487b --- /dev/null +++ b/building/building-whonix-template.md @@ -0,0 +1,94 @@ +--- +layout: doc +title: Building Whonix Templates +permalink: /doc/building-whonix-template/ +redirect_from: +- /en/doc/building-whonix-template/ +--- + +## Building Whonix Templates + +The Whonix templates are easily downloaded and installed by following the [procedure here](https://www.whonix.org/wiki/Qubes/Install). +However, they are integrated into `qubes-builder` so they are straight-forward to build yourself if you prefer. + +Many other Qubes templates can also be built by following this procedure. +Simply choose the appropriate builder(s) and template(s) you wish to build in the `./setup` procedure below. +Always include the `mgmt-salt` builder. + +First, set up the [Build Environment](/doc/qubes-iso-building/#build-environment) (follow the build environment section only). + +Next, configure the builder: + +~~~ +cd ~/qubes-builder +./setup +# Select Yes to add Qubes Master Signing Key +# Select Yes to add Qubes OS Signing Key +# Select 4.0 for version +# Stable +# Select Current (if you want the option to use pre-built packages) +# Yes (we want to build only templates) +# Select fc29 and stretch (for the currently shipping templates) +# Select builder-rpm, builder-debian, template-whonix, mgmt-salt +# Yes (to download) +~~~ + +Once it completes downloading, re-run `setup` to add the Whonix templates: + +~~~ +./setup +# Choose the same options as above, except at templates select: +# whonix-gateway-14, whonix-workstation-14 +# If prompted, choose Yes to add adrelanos's third party key +~~~ +Continue the build process with: + +~~~ +make install-deps +make get-sources +~~~ + +You will often need to edit/update `qubes-src/template-whonix/builder.conf` at this stage to specify the currently shipping Tor Browser version. +Open it in your favorite editor, then look for "Extra Whonix Build Options" and add/edit the `WHONIX_TBB_VERSION` variable to specify the current version. +For example: + +``` +################################################################################ +# Extra Whonix Build Options +################################################################################ + +# Whonix repository. +WHONIX_APT_REPOSITORY_OPTS ?= stable +#WHONIX_APT_REPOSITORY_OPTS = off + +# Use turbo mode to build template +BUILDER_TURBO_MODE ?= 1 + +# Enable Tor by default (0: disable; 1: enable) +WHONIX_ENABLE_TOR ?= 0 + +WHONIX_TBB_VERSION ?= 7.5.2 +``` + +You can add/edit the `WHONIX_TBB_VERSION` variable in `~/qubes-builder/builder.conf` instead of this file if preferred. + +Finally, use: + +~~~ +make qubes-vm +make template +~~~ + +Once the build is complete, the install packages for your newly built templates will be located in `~/qubes-builder/qubes-src/linux-template-builder/rpm/noarch`. +Copy them from there to dom0 and install: + +~~~ +qvm-run --pass-io 'cat ~/qubes-builder/qubes-src/linux-template-builder/rpm/noarch/qubes-template-whonix-gw-4.0.0-201802250036.noarch.rpm' > ~/qubes-template-whonix-gw-4.0.0-201802250036.noarch.rpm +qvm-run --pass-io 'cat ~/qubes-builder/qubes-src/linux-template-builder/rpm/noarch/qubes-template-whonix-ws-4.0.0-201802250145.noarch.rpm' > ~/qubes-template-whonix-ws-4.0.0-201802250145.noarch.rpm +sudo dnf install qubes-template-whonix-gw-4.0.0-201802250036.noarch.rpm +sudo dnf install qubes-template-whonix-ws-4.0.0-201802250145.noarch.rpm +~~~ + +And you are done! + + diff --git a/configuration-guides/change-time-zone.md b/configuration-guides/change-time-zone.md new file mode 100644 index 0000000..4846317 --- /dev/null +++ b/configuration-guides/change-time-zone.md @@ -0,0 +1,36 @@ +--- +layout: doc +title: Changing your Time Zone +permalink: /doc/change-time-zone/ +--- + +# Changing your Time Zone # + +## Qubes 4.0 ## + +### Command line ### + +If you use the i3 window manager or would prefer to change the system's time +zone in terminal you can issue the `timedatectl` command with the option +`set-timezone`. + +For example, to set the system's time zone to Berlin, Germany type in a dom0 +terminal: + + $ sudo timedatectl set-timezone 'Europe/Berlin' + +You can list the available time zones with the option `list-timezones` and show +the current settings of the system clock and time zone with option `status`. + +Example output status of `timedatectl` on a system with time zone set to +Europe/Berlin: + + [user@dom0 ~]$ timedatectl status + Local time: Sun 2018-10-14 06:20:00 CEST + Universal time: Sun 2018-10-14 04:20:00 UTC + RTC time: Sun 2018-10-14 04:20:00 + Time zone: Europe/Berlin (CEST, +0200) + Network time on: no + NTP synchronized: no + RTC in local TZ: no + diff --git a/configuration-guides/disk-trim.md b/configuration-guides/disk-trim.md new file mode 100644 index 0000000..e1fe258 --- /dev/null +++ b/configuration-guides/disk-trim.md @@ -0,0 +1,112 @@ +--- +layout: doc +title: Disk TRIM +permalink: /doc/disk-trim/ +redirect_from: +- /en/doc/disk-trim/ +- /doc/DiskTRIM/ +- /wiki/DiskTRIM/ +--- + +Disk Trim +========= + +Disk trimming is the procedure by which the operating system informs the underlying storage device of which storage blocks are no longer in use. +It does this by issuing an `ATA_TRIM` command for the block. This is also known as a `discard`. +In this way, the storage device can perform garbage collection of the unused blocks and internally prepare them for reuse. SSDs in general benefit from this, while HDDs do not. + +In a Linux system running on bare metal, this is relatively straight-forward. +When instructed by the operating system, discards are issued by the file-system driver directly to the storage driver and then to the SSD. + +In Qubes, this gets more complex due to virtualization, LUKS, and LVM (and thin pools on R4.0 and up). +If you run `fstrim --all` inside a TemplateVM, in a worst case the `discard` can follow a path like: + + OS -> File-system Driver -> Virtual Storage Driver -> Backend Storage Driver -> LVM Storage Driver -> LUKS Driver -> Physical Storage Driver -> Physical Storage Device + +If discards are not supported at any one of those layers, it will not make it to the underlying physical device. + +There are some security implications to permitting TRIM (read for example [this article](https://asalor.blogspot.com/2011/08/trim-dm-crypt-problems.html)), but in most cases not exploitable. +Conversely, TRIM can improve security against local forensics when using SSDs, because with TRIM enabled deleting data (usually) results in the actual data being erased quickly, rather than remaining in unallocated space indefinitely. +However deletion is not guaranteed, and can fail to happen without warning for a variety of reasons. + + +Configuration +---------- + +In all versions of Qubes, you may want to set up a periodic job in `dom0` to trim the disk. +This can be done with either systemd (weekly only) or cron (daily or weekly). + + * **Systemd** + + From a terminal as a regular user: + + ``` + systemctl enable fstrim.timer + systemctl start fstrim.timer + ``` + + * **Cron** + + This can be done from a terminal as root, by creating a `trim` file in `/etc/cron.daily` (or `/etc/cron.weekly`). + Add the following contents: + + ``` + #!/bin/bash + /sbin/fstrim --all + ``` + And mark it as executable with `chmod 755 /etc/cron.daily/trim`. + +**Note** Although discards can be issued on every delete inside `dom0` by adding the `discard` mount option to `/etc/fstab`, this option can hurt performance so the above procedure is recommended instead. +However, inside App and Template qubes, the `discard` mount option is on by default to notify the LVM thin pool driver that the space is no longer needed and can be zeroed and re-used. + +If you are using Qubes with LVM, you may also want to set `issue_discards = 1` in `/etc/lvm/lvm.conf`. +Setting this option will permit LVM to issue discards to the SSD when logical volumes are shrunk or deleted. +In R4.x, LVM Logical volumes are frequently deleted (every time a disposable VM is shut down, for example) so you may want to set `issue_discards = 1` if using an SSD, but see the article linked in the first section of this page. +However, this is relatively rare in R3.x. + + +LUKS +---------- + +If you have enabled LUKS in dom0, discards will not get passed down to the storage device. + +To enable TRIM support in dom0 with LUKS you need to: + +1. Get your LUKS device UUID: + + ~~~ + ls /dev/mapper/luks-* + ~~~ + +2. Add entry to `/etc/crypttab` (replace luks-\ with the device name and the \ with UUID alone): + + ~~~ + luks- UUID= none discard + ~~~ + +3. Add `rd.luks.options=discard` to kernel cmdline (follow either GRUB2 or EFI, not both): + * GRUB2: `/etc/default/grub`, `GRUB_CMDLINE_LINUX` line and + Rebuild grub config (`grub2-mkconfig -o /boot/grub2/grub.cfg`), then + Rebuild initrd (`dracut -f`) + * EFI: `/boot/efi/EFI/qubes/xen.cfg`, `kernel=` line(s), then + Rebuild initrd (`dracut -f /boot/efi/EFI/qubes/initramfs-$(uname -r).img $(uname -r)`) + +4. Reboot the system. + +5. To verify if discards are enabled you may use `dmsetup table` (confirm the line for your device mentions "discards") or just run `fstrim -av` (you should see a `/` followed by the number of bytes trimmed). + + +Swap Space +---------- + +By default TRIM is not enabled for swap. +To enable it add the `discard` flag to the options for the swap entry in `/etc/fstab`. +This may or may not actually improve performance. +If you only want the security against local forensics benefit of TRIM, you can use the `discard=once` option instead to only perform the TRIM operation once during at boot. + +To verify that TRIM is enabled, check `dmesg` for what flags were enabled when the swap space was activated. +You should see something like the following: + + Adding 32391164k swap on /dev/mapper/qubes_dom0-swap. Priority:-2 extents:1 across:32391164k SSDscFS + +The `s` indicates that the entire swap device will be trimmed at boot, and `c` indicates that individual pages are trimmed after they are no longer being used. diff --git a/configuration-guides/external-audio.md b/configuration-guides/external-audio.md new file mode 100644 index 0000000..b50c6a7 --- /dev/null +++ b/configuration-guides/external-audio.md @@ -0,0 +1,55 @@ +--- +layout: doc +title: External Audio +permalink: /doc/external-audio/ +redirect_from: +- /en/doc/external-audio/ +- /doc/ExternalAudio/ +- /wiki/ExternalAudio/ +--- + +Using External Audio Devices +============================ + +Why you want to use external audio devices +------------------------------------------ + +Qubes audio virtualization protocol does not implement latency reporting for security reasons, keeping the protocol as simple as possible. +Also, in a compromise between low latency and low CPU usage, latency may be around 200 ms. +So applications demanding higher audio quality (even Skype) need a better environment. +But Qubes flexibility fully allows that using external audio devices. +These are mostly USB audio cards, but firewire devices also might be used. + +Implementing external audio devices +----------------------------------- + +First you need to identify an user VM dedicated to audio and [assign a device](/doc/AssigningDevices) to it. +In the most common case the assigned device is the USB controller to which your USB audio card will be connected. + +### Fedora VMs + +In a terminal of the template from which you user VM depends, install pavucontrol with: + +~~~ +sudo dnf install pavucontrol +~~~ + +Close the template and start or restart your user VM, insert your external audio device, open a terminal and prepare pulseaudio to use it with: + +~~~ +sudo chmod a+rw /dev/snd/* +pactl load-module module-udev-detect +~~~ + +Start the audio application that is going to use the external audio device. + +Launch pavucontrol, for example using "run command in VM" of Qubes Manager and select your external audio card in pavucontrol. +You need to do that only the first time you use a new external audio device, then pulse audio will remember your selection. + +If you detach your external audio device, then want to insert it again (or want to change it with another one), you need to repeat the previous commands in terminal adding another line at the beginning: + +~~~ +pactl unload-module module-udev-detect +sudo chmod a+rw /dev/snd/* +pactl load-module module-udev-detect +~~~ diff --git a/configuration-guides/fetchmail.md b/configuration-guides/fetchmail.md new file mode 100644 index 0000000..25bd4ab --- /dev/null +++ b/configuration-guides/fetchmail.md @@ -0,0 +1,93 @@ +--- +layout: doc +title: Fetchmail +permalink: /doc/fetchmail/ +redirect_from: +- /en/doc/fetchmail/ +- /doc/Fetchmail/ +- /wiki/Fetchmail/ +--- + +Fetchmail +========= + +Fetchmail is standalone MRA (Mail Retrieval Agent) aka "IMAP/POP3 client". Its sole purpose is to fetch your messages and store it locally or feed to local MTA (Message Transfer Agent). It cannot "read" messages — for that, use a MUA like Thunderbird or [Mutt](/doc/mutt/). + +Installation +------------ + +`dnf install fetchmail` + +Configuration +------------- + +Assuming you have more than one account (safe assumption these days), you need to spawn multiple fetchmail instances, one for each IMAP/POP3 server (though one instance can watch over several accounts on one server). The easiest way is to create template systemd unit and start it several times. Fedora does not supply any, so we have to write one anyway. + +**NOTE:** this assumes you use [Postfix](/doc/postfix/) or Exim4 as your local MTA. + +In TemplateVM create `/etc/systemd/system/fetchmail@.service`: + +~~~ +[Unit] +Description=Mail Retrieval Agent +After=network.target +Requires=postfix.service + +[Service] +User=user +ExecStart=/bin/fetchmail -f /usr/local/etc/fetchmail/%I.rc -d 60 -i /usr/local/etc/fetchmail/.%I.fetchids --pidfile /usr/local/etc/fetchmail/.%I.pid +RestartSec=1 +~~~ + +Alternatively, in Debian with Exim4: + +~~~ +[Unit] +Description=Mail Retrieval Agent +After=network.target +Requires=exim4.service + +[Service] +User=user +ExecStart=/usr/bin/fetchmail -f /usr/local/etc/fetchmail/%I.rc -d 60 -i /usr/local/etc/fetchmail/.%I.fetchids --pidfile /usr/local/etc/fetchmail/.%I.pid +RestartSec=1 +~~~ + +Then shutdown TemplateVM, start AppVM and create directory `/usr/local/etc/fetchmail`. In it, create one `.rc` file for each instance of fetchmail, ie. `personal1.rc` and `personal2.rc`. Sample configuration file: + +~~~ +set syslog +set no bouncemail +#set daemon 600 + +poll mailserver1.com proto imap + no dns + uidl + tracepolls +user woju pass supersecret + ssl + sslproto "TLS1" + sslcertfile "/etc/pki/ca-trust/extracted/openssl/ca-bundle.trust.crt" + sslcertck + mda "/usr/sbin/sendmail -i -f %F -- user" + fetchall + idle + +# vim: ft=fetchmail +~~~ + +Then `chown -R user:user /usr/local/etc/fetchmail` and `chmod 600 /usr/local/etc/fetchmail/*.rc`. **This is important**, fetchmail will refuse to run with wrong permissions on its rc-file. + +Next, add this to `/rw/config/rc.local`: + +~~~ +#!/bin/sh + +for rc in /usr/local/etc/fetchmail/*.rc; do + instance=${rc%.*} + instance=${instance##*/} + systemctl --no-block start fetchmail@${instance} +done +~~~ + +Now reboot your AppVM and you are done. diff --git a/configuration-guides/gui-configuration.md b/configuration-guides/gui-configuration.md new file mode 100644 index 0000000..ee64552 --- /dev/null +++ b/configuration-guides/gui-configuration.md @@ -0,0 +1,37 @@ +--- +layout: doc +title: GUI Configuration and Troubleshooting +permalink: /doc/gui-configuration/ +--- + +GUI Configuration and Troubleshooting +===================================== + +Video RAM adjustment for high-resolution displays +------------------------------------------------- + +**Problem:** You have a 4K external display, and when you connect it, you can't click on anything but a small area in the upper-right corner. + +When a qube starts, a fixed amount of RAM is allocated to the graphics buffer called video RAM. +This buffer needs to be at least as big as the whole desktop, accounting for all displays that are or will be connected to the machine. +By default, it is as much as needed for the current display and an additional full HD (FHD) display (1920×1080 8 bit/channel RGBA). +This logic fails when the machine has primary display in FHD resolution and, after starting some qubes, a 4K display is connected. +The buffer is too small, and internal desktop resize fails. + +**Solution:** Increase the minimum size of the video RAM buffer. + +```sh +qvm-features dom0 gui-videoram-min $(($WIDTH * $HEIGHT * 4 / 1024)) +qvm-features dom0 gui-videoram-overhead 0 +``` + +Where `$WIDTH`×`$HEIGHT` is the maximum desktop size that you anticipate needing. +For example, if you expect to use a 1080p display and a 4k display side-by-side, that is `(1920 + 3840) × 2160 × 4 / 1024 = 48600`, or slightly more than 48 MiB per qube. +After making these adjustments, the qubes need to be restarted. + +The amount of memory allocated per qube is the maximum of: +- `gui-videoram-min` +- current display + `gui-videoram-overhead` + +Default overhead is about 8 MiB, which is enough for a 1080p display (see above). +So, the `gui-videoram-overhead` zeroing is not strictly necessary; it only avoids allocating memory that will not be used. diff --git a/configuration-guides/multiboot.md b/configuration-guides/multiboot.md new file mode 100644 index 0000000..d33152a --- /dev/null +++ b/configuration-guides/multiboot.md @@ -0,0 +1,214 @@ +--- +layout: doc +title: Multibooting +permalink: /doc/multiboot/ +--- + +Multibooting Qubes +======================================== + +Introduction +--------------------- + +You should think carefully before dual booting Qubes on your box. +Read the [guidelines](/doc/security-guidelines) carefully. + +One problem is that when you dual or multiboot, even if you are using +encryption on your Qubes installation, /boot is still unprotected and +could be maliciously modified by the other OS, possibly leading to Qubes +itself being maliciously modified. + +The other problem is firmware security - for example the other system +could infect BIOS firmware, which might enable compromise or spying on +the Qubes system. + +You can use [Anti Evil Maid](/doc/anti-evil-maid/), which would inform +you if /boot had been modified, but it cannot prevent or fix the problem. + +If you have considered these issues, tried out the live system and want to +install Qubes alongside your existing OS, these notes should help. + +They assume that you are installing Qubes on a PC where you already have +another OS installed. + +The first thing to do is STOP. +Before you do anything else back up all your data. +If possible do a full system backup. +Back up the MBR. +Back up /boot. +If you are really paranoid clone your disc. + +Make sure you have install discs to hand for the existing operating system. + +Qubes by default does not include other systems in the generated grub menu, +because handling of other systems has been disabled. This means +that you will have to manually add grub entries for any other OS. + +The general approach is: + +* Enable legacy boot mode +* Ensure current OS boots in legacy mode. +* Install Qubes +* Manually add boot stanzas to /etc/grub.d/40_custom +* Update grub + + + +Windows +---------------------- + +If you change boot mode to legacy boot almost certainly the Windows +installation will not boot. +You will either have to format the disk and reinitialise it, and then reinstall +Windows in legacy boot mode, or use a utility like Easy Recovery Essentials +which will change the existing installation to be bootable in both +UEFI/GPT and BIOS/MBR mode in-place, without losing any data. + +At this stage you can install Qubes. + +As noted above the default configuration will not add an entry for Windows to +the grub menu, so you will need to add one. + +1. Boot into Qubes. + +2. Identify the Windows system partition that has /bootmgr + + In blkid output, the system partition is the one with LABEL='SYSTEM + RESERVED' or LABEL='SYSTEM' and is only about 100 to 200 MB in size + +3. Add this stanza to /etc/grub.d/40_custom, + +~~~ +menuentry "Windows" { + insmod part_msdos + insmod ntldr + insmod ntfs + ntldr (hd1,X)/bootmgr +} +~~~ + +(Change `X` to reflect the relevant system partition.) + +Then update the grub config: + +~~~ +sudo grub2-mkconfig -o /boot/grub2/grub.cfg +~~~ + +There is no need to reinstall grub itself. + +If the above stanza does not work, you may try this one (at your own risk!) +instead: + +~~~ +menuentry "Windows" { + insmod part_msdos + insmod ntfs + set root='(hd0,msdosX)' + chainloader +1 +} +~~~ + +(Change `X` to reflect the relevant system partition.) + + +Linux +---------------------- + +If you have had to change to legacy boot mode then you may have to reinstall grub in +the existing OS. (Make sure that you use grub rather than a grub-efi version). + +Micah Lee +[suggests](https://micahflee.com/2014/04/dual-booting-qubes-and-ubuntu-with-encrypted-disks/) +installing grub to a partition, and then installing Qubes with grub +installed in MBR. + +If you take this approach then you need to add to /etc/grub.d/40_custom in Qubes +dom0: + +~~~ +menuentry "Other Linux" { +set root=(hd1,X) +chainloader +1 +} +(Change X to reflect the relevant partition where grub is installed.) +~~~ + +Then update the grub config: + +~~~ +sudo grub2-mkconfig -o /boot/grub2/grub.cfg +~~~ + +There is no need to reinstall grub itself. + + +Existing /boot partition, grub installed in MBR +---------------------- + +Most distros will have already installed grub to the MBR. + +It is possible to use the *same* /boot for both OS. +To do this, do **NOT** choose the automatic configuration option when installing +Qubes. +Select 'custom' layout, and assign the existing /boot partition as /boot. +Deselect the 'Format' option. +Then continue with the installation. +This will install the qubes boot files in /boot *alongside* the existing files, +but overwrite the grub.cfg file in /boot/grub2. + +If the other distro uses legacy grub you can simply copy the relevant sections +from /boot/grub/grub.cfg into /etc/grub.d/40_custom. + +If the other distro uses grub2 then copy the relevant sections +from the backup you made into /etc/grub.d/40_custom. + +Then update the grub config: + +~~~ +sudo grub2-mkconfig -o /boot/grub2/grub.cfg +~~~ + + + +Troubleshooting +---------------------- + +If you install Qubes without making any backups beforehand, don't worry. +If you didn't overwrite the original partitions, then it is usually +possible to recover your old systems relatively easily, as described above. + +If you decided to use a shared /boot and *don't* have backups of your previous +grub config, it is quite easy to fix this. +This example may help. + +* Boot into Qubes. +* Back up (at a minimum) /boot/grub2 +* Identify the partition containing the other OS. +* Then mount the other OS and chroot in to it. + +~~~ +sudo mount /dev/sdX /mnt +sudo mount --bind /dev/sdY /mnt/boot +sudo mount --bind /dev /mnt/dev +sudo mount --bind /dev/pts /mnt/dev/pts +sudo mount --bind /proc /mnt/proc +sudo mount --bind /sys /mnt/sys + +sudo chroot /mnt +~~~ + +* Update the grub config: + +~~~ +sudo grub2-mkconfig -o /boot/grub2/grub.cfg.new +~~~ + +* Exit out the chroot, and reverse the mounts. +* Copy the relevant sections from /boot/grub2/grub.cfg.new in to +/etc/grub.d/40_custom. +* Update the grub config: + +~~~ +sudo grub2-mkconfig -o /boot/grub2/grub.cfg +~~~ diff --git a/configuration-guides/multimedia.md b/configuration-guides/multimedia.md new file mode 100644 index 0000000..e4c3cf1 --- /dev/null +++ b/configuration-guides/multimedia.md @@ -0,0 +1,240 @@ +--- +layout: doc +title: How to Make a Multimedia TemplateVM +permalink: /doc/multimedia/ +redirect_from: +- /en/doc/multimedia/ +- /doc/Multimedia/ +- /wiki/Multimedia/ +--- + +How to Make a Multimedia TemplateVM +=================================== + +Note: This Howto has been written and was tested under Qubes 4rc4 + +You can consolidate most of your media streaming tasks into one "multimedia" App-VM. This howto explains how to create a multimedia template which can be used to play multimedia content. +This includes: + +- Spotify +- Amazon Prime +- Netflix +- DVDs + +Installation +------------ + +Start by cloning the default debian template in dom0. +Hint: +t-multimedia is just the template VM where we will install all packages. +In the last step we will create an AppVM from this template. + +`qvm-clone debian-9 t-multimedia` + +Launch a Terminal in the new template VM: + +`qvm-run --auto t-multimedia gnome-terminal` + +Important: +Enter all the following commands in the terminal of the template VM +Become the root user to run all following command without the need to use sudo in the multimedia template VM + +`sudo -i` + +This howto assumes that you have xclip available in the AppVM where you download the Repository Signing keys. +xclip will be used to paste the content of the clipboard to a file. +You can install xclip via: + +`apt-get install xclip` on Debian +`dnf install xclip` on Fedora + +You can of course install xclip just into the AppVM where you download the signing keys to have it available for this howto and it will be deleted if you reboot the AppVM. To have xclip available also after a reboot you need to install it in the Template VM on which your Internet AppVM is based (make sure to reboot the AppVM after you've installed any package in its template) + +Installation of Spotify +----------------------- + +Import GPG-Key for spotify +As the template VM can't connect to internet you need to get the public key file from another AppVM and copy it to the template VM. The easiest way is to use the Qubes Clipboard to copy the keys from the AppVM where you get the key to the Template VM. + +In an AppVM which has Internet access: +- Open +- Copy content of page to the Clipboard (Ctrl+A and Ctrl+C) +- open a Terminal in this AppVM and copy the content of the clipboard to a file + `xclip -o > spotify.pubkey` + +Copy the public signing key over to the multimedia template VM +- copy the file via `qvm-copy-to-vm t-multimedia spotify.pubkey` +- or create a new file on the Template VM and copy the content of the clipboard (the public key) + Copy content of page to the Qubes Clipboard (Ctrl+C and then Shift+Ctrl+C) + Switch to the gnome terminal in the Multimedia Template VM + `nano spotify.pubkey` + Paste the content from the Qubes Clipboard into nano (Shift+Ctrl+V and then Paste) + Save the file (Ctrl+O Ctrl+X) + +Check the signature of the signing key (in the multimedia Template VM). +Hint: depending on your installed version of GnuPG the command to show a public might slightly be different. +See [this StackExchange question](https://unix.stackexchange.com/questions/391344/gnupg-command-to-show-key-info-from-file) for more information. +If this command doesn't show a fingerprint choose one of the other commands mentioned in the above link. + +`gpg --with-fingerprint spotify.pubkey` + +This should look like: + + [user@t-multimedia ~]$ `gpg --with-fingerprint spotify.pubkey` + + pub 4096R/48BF1C90 2018-05-23 Spotify Public Repository Signing Key + + Key fingerprint = 931F F8E7 9F08 7613 4EDD BDCC A87F F9DF 48BF 1C90 + +You can (and should) lookup the fingerprint on at least one (or more) keyservers as the above information might be outdated. + + + +Add the public key to the repository keyring +`apt-key add spotify.pubkey` + +Add the Spotify repository to your list of package sources: + +`echo deb http://repository.spotify.com stable non-free > /etc/apt/sources.list.d/spotify.list` + +Update the list of all known packages + +`apt-get update` + +Install Spotify +`apt-get install -y spotify-client` + +Create a spotify desktop-entry + +`cp -p /usr/share/spotify/spotify.desktop /usr/share/applications/` + +`cp /usr/share/spotify/icons/spotify-linux-16.png /usr/share/icons/hicolor/16x16/apps/spotify.png` + + +Installation of VLC +------------------- + +To play DVDs you can install VLC with the needed Codecs + +Download the public key which signs the VLC package repositories +In an AppVM which has Internet access: +- Open +- Repeat all steps to save the public signing key on the AppVM (see above / Spotify example) + `xclip -o > videolan.pubkey` + +Copy the public signing key over to the multimedia template VM +- copy the file via `qvm-copy-to-vm t-multimedia videolan.pubkey` +- or create a new file on the Template VM and copy the content of the clipboard (the public key) + Copy content of page to the Qubes Clipboard (Ctrl+C and then Shift+Ctrl+C) + Switch to the gnome terminal in the Multimedia Template VM + `nano videolan.pubkey` + Paste the content from the Qubes Clipboard into nano (Shift+Ctrl+V and then Paste) + Save the file (Ctrl+O Ctrl+X) + +Check the signature of the signing key + +`gpg --with-fingerprint videolan.pubkey` + +This should look like: + + [user@t-multimedia ~]$ `gpg --with-fingerprint videolan.pubkey` + + pub 2048R/B84288D9 2013-08-27 VideoLAN APT Signing Key + + Key fingerprint = 8F08 45FE 77B1 6294 429A 7934 6BCA 5E4D B842 88D9 + + sub 2048R/288D4A2C 2013-08-27 + +You can (and should) lookup the fingerprint on at least one (or more) keyservers as the above information might be outdated. + + + +Add the public key to the repository keyring +`apt-key add videolan.pubkey` + +Add the new VLC package repositories to your list of sources + +`echo "deb http://download.videolan.org/pub/debian/stable/ /" > /etc/apt/sources.list.d/vlc.list` + +`echo "deb-src http://download.videolan.org/pub/debian/stable/ /" >> /etc/apt/sources.list.d/vlc.list` + +Update package repositories + +`apt-get update` + +Install libdvdcss and VLC + +`apt-get install -y libdvdcss2 vlc` + + +Installation Google Chrome +-------------------------- + +To play Videos with Netflix, Amazon Prime & Co using Chrome is a good option as it has all needed codecs included. +Hint: Using Chromium will not work for some reasons. + +Download the public key which signs the Google package repositories +In an AppVM which has Internet access: +- Open +- Repeat all steps to save the public signing key on the AppVM (see above / Spotify example) + `xclip -o > google.pubkey` + +Copy the public signing key over to the multimedia template VM +- copy the file via `qvm-copy-to-vm t-multimedia google.pubkey` +- or create a new file on the Template VM and copy the content of the clipboard (the public key) + Copy content of page to the Qubes Clipboard (Ctrl+C and then Shift+Ctrl+C) + Switch to the gnome terminal in the Multimedia Template VM + `nano google.pubkey` + Paste the content from the Qubes Clipboard into nano (Shift+Ctrl+V and then Paste) + Save the file (Ctrl+O Ctrl+X) + +Check the signature of the signing key (still in the AppVM where you downloaded the key) + +`gpg --with-fingerprint google.pubkey` + +This should look like: + + [user@t-multimedia ~]$ `gpg --with-fingerprint google.pubkey` + + pub 4096R/D38B4796 2016-04-12 Google Inc. (Linux Packages Signing Authority) + + + + Key fingerprint = EB4C 1BFD 4F04 2F6D DDCC EC91 7721 F63B D38B 4796 + + sub 4096R/640DB551 2016-04-12 [expires: 2019-04-12] + + sub 4096R/997C215E 2017-01-24 [expires: 2020-01-24] + +You can (and should) lookup the fingerprint on at least one (or more) keyservers as the above information might be outdated. + + + +or + + + +Add the public key to the repository keyring + +`apt-key add google.pubkey` + +Add the Google package repositories to your list of sources + +`echo "deb http://dl.google.com/linux/chrome/deb/ stable main"> /etc/apt/sources.list.d/google.list` + +Update package repositories + +`apt-get update` + +Install Chrome + +`apt-get install google-chrome-stable` + + +Create a Multimedia AppVM +------------------------- + +The last step is to create a multimedia AppVM (named "my-multimedia" here) based on the new multimedia template. + +`qvm-create --template t-multimedia --label orange my-multimedia` + diff --git a/configuration-guides/mutt.md b/configuration-guides/mutt.md new file mode 100644 index 0000000..0ae3f94 --- /dev/null +++ b/configuration-guides/mutt.md @@ -0,0 +1,222 @@ +--- +layout: doc +title: Mutt +permalink: /doc/mutt/ +redirect_from: +- /en/doc/mutt/ +- /doc/Mutt/ +- /wiki/Mutt/ +--- + +Mutt +==== + +Mutt is a fast, standards-compliant, efficient MUA (Mail User Agent). In some areas it works better than Thunderbird+Enigmail, and is certainly faster and more responsive. + +Mutt lacks true MTA (Message Transfer Agent aka "SMTP client") and MRA (Mail +Retrieval Agent aka "IMAP/POP3 client"), thus there are some provisions +built-in. In principle it is only mail reader and composer. You may install +true MTA such as [Postfix](/doc/postfix/) or Exim and MRA such as +[Fetchmail](/doc/fetchmail/). Alternatively you can synchronize your mailbox +using [OfflineIMAP](https://github.com/OfflineIMAP/offlineimap) and just stick +to integrated SMTP support. You can even use integrated IMAP client, but it is +not very convenient. + +Installation +------------ + +`dnf install mutt cyrus-sasl-plain` + +`cyrus-sasl-plain` package is necessary for SMTP authentication to work. + +Configuration +------------- + +Mutt generally works out of the box. This configuration guide discusses only Qubes-specific setup. In this example we will have one TemplateVM and several AppVMs. It also takes advantage of [SplitGPG](/doc/split-gpg/), which is assumed to be already working. + +**NOTE:** this requires `qubes-gpg-split >= 2.0.9`. 2.0.8 and earlier contains bug which causes this setup to hang in specific situations and does not allow to list keys. + +First, paste this to `/etc/Muttrc.local` in TemplateVM: + +~~~ +# specify your key or override in ~/.mutt/muttrc in AppVM +set pgp_sign_as="0xDEADBEEF" + +set pgp_use_gpg_agent = no + +# this needs qubes-gpg-split >= 2.0.8; 2.0.7 end earlier has had a deadlock on this +set pgp_decode_command="qubes-gpg-client-wrapper --status-fd=2 --batch %f" +#set pgp_decode_command="gpg --status-fd=2 %?p?--passphrase-fd=0? --no-verbose --quiet --batch --output - %f" + +set pgp_decrypt_command="$pgp_decode_command" + +set pgp_verify_command="qubes-gpg-client-wrapper --status-fd=2 --no-verbose --quiet --batch --output - --verify %s %f" + +set pgp_sign_command="qubes-gpg-client-wrapper --batch --armor --detach-sign --textmode %?a?-u %a? %f" +set pgp_clearsign_command="qubes-gpg-client-wrapper --batch --armor --textmode --clearsign %?a?-u %a? %f" + +# I found no option to add Charset armor header when it is UTF-8, since this is +# default (as specified in RFC4880). This is needed to workaround bug in +# Enigmail, which ignores RFC and without this header Thunderbird interprets +# plaintext as us-ascii. See https://sourceforge.net/p/enigmail/bugs/38/. + +### also note you must specify absolute path of pgpewrap when using debian +### e.g. /usr/lib/mutt/pgpewrap + +set pgp_encrypt_only_command="pgpewrap qubes-gpg-client-wrapper --batch --textmode --armor --always-trust %?a?--encrypt-to %a? --encrypt -- -r %r -- %f | sed -e '2iCharset: UTF-8'" +set pgp_encrypt_sign_command="pgpewrap qubes-gpg-client-wrapper --batch --textmode --armor --always-trust %?a?--encrypt-to %a? --encrypt --sign %?a?-u %a? -- -r %r -- %f | sed -e '2iCharset: UTF-8'" + +# we need to import both into vault and locally wrt $pgp_verify_command +set pgp_import_command="qubes-gpg-import-key %f; gpg --no-verbose --import %f" + +# those are unsupported by split-gpg +set pgp_export_command="gpg --no-verbose --export --armor %r" +set pgp_verify_key_command="gpg --no-verbose --batch --fingerprint --check-sigs %r" + +# read in the public key ring +set pgp_list_pubring_command="qubes-gpg-client-wrapper --no-verbose --batch --quiet --with-colons --list-keys %r" + +# read in the secret key ring +set pgp_list_secring_command="qubes-gpg-client-wrapper --no-verbose --batch --quiet --with-colons --list-secret-keys %r" + +# this set the number of seconds to keep in memory the passpharse used to encrypt/sign +# the more the less secure it will be +set pgp_timeout=600 + +# it's a regexp used against the GPG output: if it matches some line of the output +# then mutt considers the message a good signed one (ignoring the GPG exit code) +#set pgp_good_sign="^gpg: Good signature from" +set pgp_good_sign="^\\[GNUPG:\\] GOODSIG" + +# mutt uses by default PGP/GPG to sign/encrypt messages +# if you want to use S-mime instead set the smime_is_default variable to yes + +# automatically sign all outcoming messages +set crypt_autosign=yes +# sign only replies to signed messages +#set crypt_replysign + +# automatically encrypt outcoming messages +#set crypt_autoencrypt=yes +# encrypt only replies to signed messages +set crypt_replyencrypt=yes +# encrypt and sign replies to encrypted messages +set crypt_replysignencrypted=yes + +# automatically verify the sign of a message when opened +set crypt_verify_sig=yes + +send-hook "~A" set pgp_autoinline=no crypt_autoencrypt=no +send-hook "~t @invisiblethingslab\.com" set crypt_autoencrypt=yes + +# vim:ft=muttrc +~~~ + +Then shutdown your TemplateVM. Next open your AppVM, create file `/home/user/.mutt/muttrc` and adjust for your needs: + +~~~ +# +# accounts +# +set from = "Wojciech Zygmunt Porczyk " +alternates '^woju@invisiblethingslab\.com$' +alternates '^wojciech@porczyk\.eu$' + +# +# crypto +# +set pgp_sign_as = "0xDEADBEEF" +send-hook "~t @my\.family\.com" set crypt_autoencrypt=no + +# +# lists +# + +# google groups +lists .*@googlegroups\.com + +subscribe (qubes-(users|devel)|othergroup)@googlegroups\.com +fcc-save-hook qubes-users@googlegroups\.com =list/qubes-users/ +fcc-save-hook qubes-devel@googlegroups\.com =list/qubes-devel/ +fcc-save-hook othergroup@googlegroups\.com =list/othergroup/ +~~~ + +You may also create `/home/user/.signature`: + +~~~ +regards, +Wojciech Porczyk +~~~ + +Some additional useful settings +------------------------------- + +In `muttrc`: + + ###qubes integration stuff + + #open links in a dispvm using urlview + #see below for sample .urlview + macro pager \cb 'urlview' 'Follow links with urlview' + + #override default mailcap MIME settings with qvm-open-in-dvm calls + #see sample .mailcap below + set mailcap_path=~/.mailcap + + bind attach view-mailcap + +Debian-specific options: + + #use debian mutt-patched package for mailbox sidebar hack + set sidebar_width = 30 + set sidebar_visible = no + set sidebar_delim='|' + + #show/hide sidebar + macro index S 'toggle sidebar_visible' + macro pager S 'toggle sidebar_visible' + + #navigate the sidebar folders + bind index CP sidebar-prev + bind index CN sidebar-next + bind index CO sidebar-open + bind pager CP sidebar-prev + bind pager CN sidebar-next + + +In `.urlview`: + + ### TODO: this doesn't work with encrypted emails -- + ### urlview can't find the links + ### + COMMAND qvm-open-in-dvm %s + + +In `.mailcap`: + + ### TODO: override most/all default mailcap settings to prevent + ### opening in muttvm + ### is there a way to do this polymorphically? i.e. not + ### listing every damn mimetype by hand + ### + ### also would be convenient to use mailcap's TEST feature to + ### show some html in mutt pager (e.g. with w3m, links or html2text), + ### else open others in dispvm + + # MS Word documents + application/msword; qvm-open-in-dvm %s + + application/vnd.oasis.opendocument.spreadsheet; qvm-open-in-dvm %s + application/vnd.oasis.opendocument.text; qvm-open-in-dvm %s + + # Images + image/jpg; qvm-open-in-dvm %s + image/jpeg; qvm-open-in-dvm %s + image/png; qvm-open-in-dvm %s + image/gif; qvm-open-in-dvm %s + + # PDFs + application/pdf; qvm-open-in-dvm %s + + # HTML + text/html; qvm-open-in-dvm %s diff --git a/configuration-guides/network-bridge-support.md b/configuration-guides/network-bridge-support.md new file mode 100644 index 0000000..822d991 --- /dev/null +++ b/configuration-guides/network-bridge-support.md @@ -0,0 +1,146 @@ +--- +layout: doc +title: Network Bridge Support +permalink: /doc/network-bridge-support/ +redirect_from: +- /en/doc/network-bridge-support/ +- /doc/NetworkBridgeSupport/ +- /wiki/NetworkBridgeSupport/ +--- + +Network Bridge Support (EXPERIMENTAL and UNSUPPORTED) +===================================================== + +The Qubes development team does not support bridging the network interfaces found in NetVM and don't plan to support it at all. Several reasons for that: + +- Using a bridged VM is almost only necessary for developers testing or working on OSI layer 2 or layer 3 tools (MAC or routing protocols). If not for testing, such tools are almost only used directly on routers ...). +- Most of these tools can be anyway used directly inside the NetVM, which has direct access to the network card. +- It is also possible to use a secondary network card plugged into a specific development VM. +- Such a setup could break security features of Qubes such as AppVM firewalling. + +Now if you really want to work with OSI layer2 / layer 3 tools, that you don't have a secondary network card, or that you want to completely expose services of a given AppVM (at your own risk), a bridged setup may help you. + +Qubes manager patch (Qubes R2B2) +-------------------------------- + +The following patches can be applied to the Qubes Manager GUI in order to add an option to easily bridge a VM. Use it at your own risk. If the patch breaks the Qubes Manager, you can try to restore the Qubes packages: + +~~~ +# qubes-dom-update qubes-core-dom0 qubes-manager +# yum reinstall qubes-core-dom0 +# yum reinstall qubes-manager +~~~ + +First, retrieve the attachment of this Wifi article in dom0. Then apply the three patches the following way after installing the patch tool : + +~~~ +# qubes-dom0-update patch +# patch /usr/lib64/python2.7/site-package/qubes/qubes.py < qubes.py-bridge.diff +# patch /usr/lib64/python2.7/site-package/qubesmanager/settings.py < settings.py-bridge.diff +# patch /usr/lib64/python2.7/site-package/qubesmanager/ui_settingsdlg.py < ui_settingsdlg.py-bridge.diff +~~~ + +Finally restart the qubes manager GUI. + +An option is available in the AppVM Settings to enable setting the NetVM in bridge mode. For a bridged AppVM, you should then select a NetVM instead of a FirewallVM/ ProxyVM, enable the Bridge option, and restart your AppVM. + +NetVM patch (Qubes R2B2) +------------------------ + +You need to modify manually the NetVM iptable script inside the NetVM. The reason is that by default the NetVM only accepts traffic coming from network interfaces called vif\* (in our case, we will use an additional interface called bridge0. The second reason is that all traffic is NATed by default. In our case, we want to forward traffic from the bridge interface without modifying it, while NATing traffic coming from vif\* interfaces. + +Modify manually the Template you use for your NetVM (not the NetVM itself). This is by default fedora-x86\_64. Edit the file /etc/sysconfig/iptables. You need to modify two parts of the file. + +- Starting from the line -A POSTROUTING -j MASQUERADE that you need to comment : + + ~~~ + # Bridge support + # Comment the following line + #-A POSTROUTING -j MASQUERADE + # Ensure packets coming from firewallVMs or AppVMs use NAT + -A POSTROUTING -m iprange --src-range 10.137.1.0-10.137.2.255 -j MASQUERADE + # Allow redirection of bridge packets (optional as POSTROUTING default is ACCEPT) + #-A POSTROUTING -o bridge+ -j ACCEPT + # End Bridge support + ~~~ + +- Starting from the line -A FORWARD -i vif+ -j ACCEPT: + + ~~~ + -A FORWARD -i vif+ -o vif+ -j DROP + -A FORWARD -i vif+ -j ACCEPT + # Bridge Support + -A FORWARD -i bridge+ -j ACCEPT + # End Bridge Support + -A FORWARD -j DROP + ~~~ + +Ensure that the IP addresses used by default in Qubes are in the form 10.137.1.\* or 10.137.2.\* by running ifconfig. Of course, this setup won't work with IPv6. + +Now you need to restart the NetVM and FirewallVM or only iptables in both VMs if you prefer: + +~~~ +# systemctl restart iptables +~~~ + +Create a Bridge inside the NetVM +-------------------------------- + +A bridge can be created inside the standard network manager (the network icon in the taskbar). + +This requires: + +- creating a bridge that will be your main IP (ex: setup the bridge with DHCP) +- attach eth0 to your bridge + +Note: A wireless interface cannot be bridged. + +The bridge edition GUI is somewhat buggy as it does not remember all the parameters you set up. You can fix it by editing manually the files in /etc/NetworkManager/system-connections/. Here is one example for these files: + +- Bridge-DHCP + + ~~~ + [connection] + id=Bridge-DHCP + uuid=fd68198b-313a-47cb-9155-52e95cdc67f3 + type=bridge + autoconnect=false + timestamp=1363938302 + + [ipv6] + method=auto + + [ipv4] + method=auto + + [bridge] + interface-name=bridge0 + stp=false + ~~~ + +Note: Do not forget to put stp=false if you bridge only eth0 because sending BPDUs could make your admins angry :) + +- bridge0-eth0 + + ~~~ + [802-3-ethernet] + duplex=full + mac-address=88:AE:1D:AE:30:31 + + [connection] + id=bridge0-eth0 + uuid=38320e5b-226c-409e-9fd6-0fbf4d0460a0 + type=802-3-ethernet + autoconnect=false + timestamp=1363601650 + master=fd68198b-313a-47cb-9155-52e95cdc67f3 + slave-type=bridge + ~~~ + +If you do not manage to start your bridge, you can start it manually from a NetVM terminal: + +~~~ +$ nmcli con up id bridge0-eth0 +~~~ + +Now that the bridge is ready, the bridged AppVM can be started... diff --git a/configuration-guides/network-printer.md b/configuration-guides/network-printer.md new file mode 100644 index 0000000..f5d7ef9 --- /dev/null +++ b/configuration-guides/network-printer.md @@ -0,0 +1,55 @@ +--- +layout: doc +title: Network Printer +permalink: /doc/network-printer/ +redirect_from: +- /en/doc/network-printer/ +- /doc/NetworkPrinter/ +- /wiki/NetworkPrinter/ +--- + +Configuring a network printer for Qubes AppVMs +============================================== + +Where to configure printers and install drivers? +------------------------------------------------ + +One would normally want to configure a printer in a template VM, rather than in particular AppVMs. +This is because all the global settings made to AppVMs (those stored in its /etc, as well as binaries installed in /usr) would be discarded upon AppVM shutdown. +When printer is added and configured in a template VM, then all the AppVMs based on this template should automatically be able to use it (without the need for the template VM to be running, of course). + +Alternatively one can add a printer in a standalone VM, but this would limit the printer usage to this particular VM. + +Security considerations for network printers and drivers +-------------------------------------------------------- + +Some printers require third-party drivers, typically downloadable from the vendor's website. +Such drivers are typically distributed in a form of ready to install RPM packages. +However, they are often unsigned, and additionally the downloads are available via HTTP connections only. +As a result, installation of such third-party RPMs in a default template VM exposes a risk of compromise of this template VM, which, in turn, leads automatically to compromise of all the AppVMs based on the template. +(Again, it's not buggy or malicious drivers that we fear here, but rather malicious installation scripts for those drivers). + +In order to mitigate this risk, one might consider creating a custom template (i.e. clone the original template) and then install the third-party, unverified drivers there. +Such template might then be made a DVM template for [DisposableVM creation](/doc/disposablevm/), which should allow one to print any document by right-clicking on it, choosing "Open in DisposableVM" and print from there. +This would allow to print documents from more trusted AppVMs (based on a trusted default template that is not poisoned by third-party printer drivers). + +However, one should be aware that most (all?) network printing protocols are insecure, unencrypted protocols. +This means, that an attacker who is able to sniff the local network, or who is controlling the (normally untrusted) Qubes NetVM, will likely to be able to see the documents being printed. +This is a limitation of today's printers and printing protocols, something that cannot be solved by Qubes or any other OS. + +Additionally, the printer drivers as well as CUPS application itself, might be buggy and might get exploited when talking to a compromised printer (or by an attacker who controls the local network, or the default NetVM). +Consider not using printing from your more trusted AppVMs for this reason. + +Steps to configure a network printer in a template VM +---------------------------------------------------------- + +1. Start the "Printer Settings" App in a template VM (either via Qubes "Start Menu", or by launching the `system-config-printer` in the template). +2. Add/Configure the printer in the same way as one would do on any normal Linux. + You may need to allow network access from the template VM to your printer to complete configuration, as normally the template VM is not allowed any network access except to the Qubes proxy for software installation. + One can use Qubes Manager to modify firewall rules for particular VMs. +3. Optional: Test the printer by printing a test page. If it works, shut down the template VM. +4. Open an AppVM (make sure it's based on the template where you just installed the printer, normally all AppVMs are based on the default template), and test if printing works. + If it doesn't then probably the AppVM doesn't have networking access to the printer -- in that case adjust the firewall settings for that AppVM in Qubes Manager. + Also, make sure that the AppVM gets restarted after the template was shutdown. +5. Alternatively if you do not want to modify the firewall rules of the template VM (that have security scope) you can simply shut down the template VM without trying to print the test page (which will not work), start or restart an AppVM based on the template and test printing there. + diff --git a/configuration-guides/postfix.md b/configuration-guides/postfix.md new file mode 100644 index 0000000..7a142f3 --- /dev/null +++ b/configuration-guides/postfix.md @@ -0,0 +1,155 @@ +--- +layout: doc +title: Postfix +permalink: /doc/postfix/ +redirect_from: +- /en/doc/postfix/ +- /doc/Postfix/ +- /wiki/Postfix/ +--- + +Postfix +======= + +Postfix is full featured MTA (Message Transfer Agent). Here we will configure it in smarthost mode as part of common [Mutt](/doc/mutt/)+Postfix+[Fetchmail](/doc/fetchmail/) stack. + +Installation +------------ + +`dnf install postfix procmail make cyrus-sasl cyrus-sasl-plain` + +Cyrus-sasl is installed to authenticate to remote servers. Procmail is not strictly necessary, but is useful to sort your incoming mail, for example to put each mailing list in its own directory. Make is also not necessary, but is used to keep Postfix lookup tables. + +You should also check `alternatives` command, to see if it is the default `mta`. It probably is not. You may need to `dnf remove ssmtp` or something + +Configuration +------------- + +In TemplateVM open `/etc/aliases` and add line: + +~~~ +root: user +~~~ + +and run `newaliases`. + +This is the only thing to do in TemplateVM, as MTA configuration is AppVM specific, so we will keep it in `/usr/local` (ie. `/rw/usrlocal`) in each AppVM. + +Now shutdown TemplateVM, start AppVM. Create directory `/usr/local/etc/postfix` and copy `/etc/postfix/master.cf` and `/etc/postfix/postfix-files` there. + +### Makefile + +Postfix keeps its lookup tables in bdb hash databases. They need to be compiled from source files. Postfix admins like to keep track of them by means of `/usr/local/etc/postfix/Makefile`: + +~~~ +all: $(addsuffix .db,$(shell sed -n -e '/^[^#].*hash:\/etc\/postfix/s:.*/::p' main.cf)) + newaliases +clean: + $(RM) *.db +.PHONY: all clean + +%.db: % + /usr/sbin/postmap hash:$< +~~~ + +### Postfix main configuration + +`/usr/local/etc/postfix/main.cf` (`/etc/postfix` is intentional, don't correct it): + +~~~ +mydestination = $myhostname, $myhostname.$mydomain, $myhostname.localdomain, localhost, localhost.$mydomain, localhost.localdomain, $mydomain, localdomain +mynetworks_style = host + +inet_protocols = ipv4 + +smtp_generic_maps = hash:/etc/postfix/generic +local_header_rewrite_clients = + +smtp_sender_dependent_authentication = yes +sender_dependent_relayhost_maps = hash:/etc/postfix/sender_relay +smtp_sasl_auth_enable = yes +smtp_sasl_password_maps = hash:/etc/postfix/saslpass +smtp_sasl_security_options = +smtp_tls_security_level = encrypt +smtp_sasl_mechanism_filter = plain, login +smtpd_relay_restrictions = permit_mynetworks,permit_sasl_authenticated,defer_unauth_destination +smtpd_sender_restrictions = check_sender_access hash:/etc/postfix/sender_access + +home_mailbox = .maildir/ +setgid_group = postdrop +mail_owner = postfix + +html_directory = no +manpage_directory = /usr/share/man +queue_directory = /var/spool/postfix +readme_directory = no + +mailbox_command = /usr/bin/procmail +sendmail_path = /usr/sbin/sendmail +newaliases_path = /usr/bin/newaliases +mailq_path = /usr/bin/mailq +alias_maps = hash:/etc/aliases +~~~ + +### Lookup tables + +`/usr/local/etc/postfix/generic` (put there your primary address): + +~~~ +@localhost your.mail@example.com +~~~ + +`/usr/local/etc/postfix/sender_relay`. This is an important file. Put all your SMTP servers there. Pay attention to port (smtp/submission). Square brackets have their special meaning, they are almost certainly needed. For more info consult Postfix manual. + +~~~ +your.mail@exmaple.com [mail.example.com]:submission +your.other@mail.com [smtp.mail.com]:smtp +~~~ + +`/usr/local/etc/postfix/saslpass`. Here you put passwords to above mentioned servers. It depends on your provider if you need to put whole email as username or just the part before `@`. + +~~~ +[mail.example.com]:submission your.mail:y0urP4ssw0rd +[smtp.mail.com]:smtp your.other@mail.com:supers3cret +~~~ + +`/usr/local/etc/postfix/sender_access`. I use it to nullroute known spam domains. If you do not need it, comment respective line in `main.cf`. + +~~~ +spamdomain1.com DISCARD +spamdomain2.com DISCARD +~~~ + +Now run `make` in `/usr/local/etc/postfix`. It will hopefully compile four above mentioned lookup tables (`generic.db`, `sender_relay.db`, `saslpass.db` and `sender_access`). + +### procmail + +Don't start postfix or fetchmail yet, first create `/home/user/.procmailrc`: + +~~~ +MAILDIR = "${HOME}/.maildir" +ORGMAIL = "${MAILDIR}/" +DEFAULT = "${MAILDIR}/" + +:0 +* ^List-Id:.*qubes-users\.googlegroups\.com +list/qubes-users/ + +:0 +* ^List-Id:.*qubes-devel\.googlegroups\.com +list/qubes-devel/ +~~~ + +Run +--- + +Open `/rw/config/rc.local` and add those two lines (before fetchmail lines, if you have them): + +~~~ +#!/bin/sh + +mount --bind /usr/local/etc/postfix /etc/postfix +systemctl --no-block start postfix +~~~ + +Make sure `/rw/config/rc.local` is executable (i.e., `chmod a+x /rw/config/rc.local`). Reboot your AppVM and you are done. diff --git a/configuration-guides/resize-disk-image.md b/configuration-guides/resize-disk-image.md new file mode 100644 index 0000000..3c6223c --- /dev/null +++ b/configuration-guides/resize-disk-image.md @@ -0,0 +1,76 @@ +--- +layout: doc +title: Resize Disk Image +permalink: /doc/resize-disk-image/ +redirect_from: +- /en/doc/resize-disk-image/ +- /en/doc/resize-root-disk-image/ +- /doc/ResizeDiskImage/ +- /doc/ResizeRootDiskImage/ +- /wiki/ResizeDiskImage/ +- /wiki/ResizeRootDiskImage/ +--- + +Resize Disk Image +----------------- + +There are several disk images which can be easily extended, but pay attention to the overall consumed space of your sparse/thin disk images. +In most cases, the GUI tool Qube Settings (available for every qube from the Start menu, and also in the Qube Manager) will allow you to easily increase maximum disk image size. + +![vm-settings-disk-image.png](/attachment/wiki/DiskSize/vm-settings-disk-image.png) + +In case of standalone qubes and templates, just change the Disk Storage settings above. +In case of template-based qubes, the private storage (the /home directory and user files) can be changed in the qube's own settings, but the system root image is [inherited from the template](/getting-started/#appvms-qubes-and-templatevms), and so it must be changed in the template settings. +If you are increasing the disk image size for Linux-based qubes installed from Qubes OS repositories in Qubes 4.0 or later, changing the settings above is all you need to do - in other cases, you may need to do more, according to instructions below. +See also the OS-specific follow-up instructions below. + +### Resize disk image + +Use either GUI tool Qube Settings (`qubes-vm-settings`) or the CLI tool `qvm-volume`. +Maximum size which can be assigned through Qube Settings is 1048576 MiB - if you need more, use `qvm-volume`: + +~~~ +qvm-volume extend :root +~~~ +OR +~~~ +qvm-volume extend :private +~~~ + +Note: Size is the target size (i.e. 4096MB or 16GB, ...), not the size to add to the existing disk. + +If you have run out of space for software in your Template, you need to increase *root image* of the Template (not private storage!). +**Make sure changes in the Template between reboots don't exceed 10G.** +It is recommended to restart (or start and then shutdown, if it is not running) the template after resizing the root image. + +If you are **not** using Linux in the qube, you will also need to: + +1. Start the template. +2. Resize the filesystem using OS appropriate tools. +3. Verify available space in the template using `df -h` or OS specific tools. +4. Shutdown the template. + +#### Windows 7 + +1. Click Start +2. type "diskmgmt.msc" - this takes you to Disk Management +3. Right-click on your existing volume, select "Extend Volume..." +4. Click through the wizard. + +No reboot required. + +#### FreeBSD + +~~~ +gpart recover ada0 +sysctl kern.geom.debugflags=0x10 +gpart resize -i index ada0 +zpool online -e poolname ada0 +~~~ + +#### Linux + +Qubes will automatically grow the filesystem for you on all AppVMs with Qubes packages installed (which are all AppVMs installed from templates, cloned from templates etc. - if you have not created an empty HVM and installed a Linux distribution in it, without using Qubes repositories, you are almost certainly safe). +Otherwise, you will see that there is unallocated free space at the end of your primary disk. +You can use standard linux tools like `fdisk` and `resize2fs` to make this space available. + diff --git a/configuration-guides/rxvt.md b/configuration-guides/rxvt.md new file mode 100644 index 0000000..aa0c0bb --- /dev/null +++ b/configuration-guides/rxvt.md @@ -0,0 +1,152 @@ +--- +layout: doc +title: Rxvt +permalink: /doc/rxvt/ +redirect_from: +- /en/doc/rxvt/ +- /doc/Rxvt/ +- /wiki/Rxvt/ +--- + +Rxvt +==== + +`rxvt-unicode` is an advanced and efficient vt102 emulator. Here is a quick guide to configuration in both dom0 and guest VM. + +Installation +------------ + +`dnf install rxvt-unicode-256color-ml` will bring both base `rxvt-unicode` and extension. +Let me also recommend excellent Terminus font: `dnf install terminus-fonts`. + +Xresources +---------- + +In TemplateVM create file `/etc/X11/Xresources.urxvt` and paste config below. +`!`-lines are comments and may be left out. +`#`-lines are directives to CPP (C preprocessor) and are necessary. +This shouldn't go to `/etc/X11/Xresources`, because that file is not preprocessed by default. + +~~~ +! CGA colour palette + +!*color0: #000000 +!*color1: #AA0000 +!*color2: #00AA00 +!*color3: #AA5500 +!*color4: #0000AA +!*color5: #AA00AA +!*color6: #00AAAA +!*color7: #AAAAAA +!*color8: #555555 +!*color9: #FF5555 +!*color10: #55FF55 +!*color11: #FFFF55 +!*color12: #5555FF +!*color13: #FF55FF +!*color14: #55FFFF +!*color15: #FFFFFF + +! Qubes' favourite tango palette (improved with cyan) + +#define TANGO_Butter1 #c4a000 +#define TANGO_Butter2 #edd400 +#define TANGO_Butter3 #fce94f +#define TANGO_Orange1 #ce5c00 +#define TANGO_Orange2 #f57900 +#define TANGO_Orange3 #fcaf3e +#define TANGO_Chocolate1 #8f5902 +#define TANGO_Chocolate2 #c17d11 +#define TANGO_Chocolate3 #e9b96e +#define TANGO_Chameleon1 #4e9a06 +#define TANGO_Chameleon2 #73d216 +#define TANGO_Chameleon3 #8ae234 +#define TANGO_SkyBlue1 #204a87 +#define TANGO_SkyBlue2 #3465a4 +#define TANGO_SkyBlue3 #729fcf +#define TANGO_Plum1 #5c3566 +#define TANGO_Plum2 #75507b +#define TANGO_Plum3 #ad7fa8 +#define TANGO_ScarletRed1 #a40000 +#define TANGO_ScarletRed2 #cc0000 +#define TANGO_ScarletRed3 #ef2929 +#define TANGO_Aluminium1 #2e3436 +#define TANGO_Aluminium2 #555753 +#define TANGO_Aluminium3 #888a85 +#define TANGO_Aluminium4 #babdb6 +#define TANGO_Aluminium5 #d3d7cf +#define TANGO_Aluminium6 #eeeeec + +*color0: TANGO_Aluminium1 +*color1: TANGO_ScarletRed2 +*color2: TANGO_Chameleon1 +*color3: TANGO_Chocolate2 +*color4: TANGO_SkyBlue1 +*color5: TANGO_Plum2 +*color6: #06989a +*color7: TANGO_Aluminium4 + +*color8: TANGO_Aluminium3 +*color9: TANGO_ScarletRed3 +*color10: TANGO_Chameleon3 +*color11: TANGO_Butter3 +*color12: TANGO_SkyBlue3 +*color13: TANGO_Plum3 +*color14: #34e2e2 +*color15: TANGO_Aluminium6 + +URxvt.foreground: #E0E0E0 +!URxvt.background: black +!URxvt.cursorColor: rgb:ffff/0000/0000 + +URxvt.cursorColor: TANGO_ScarletRed3 + +!URxvt.font: -*-terminus-*-*-*-*-14-*-*-*-*-*-iso8859-2 +!URxvt.boldFont: -*-terminus-*-*-*-*-14-*-*-*-*-*-iso8859-2 +URxvt.font: xft:Terminus:pixelsize=14:style=Bold +URxvt.boldFont: xft:Terminus:pixelsize=14:style=Bold +URxvt.italicFont: xft:Terminus:pixelsize=14:style=Regular +URxvt.boldItalicFont: xft:Terminus:pixelsize=14:style=Regular +URxvt.scrollBar: False +URxvt.visualBell: False + +! Qubes X11 passthrough does not support those, but in dom0 they are nice. +URxvt.background: rgba:0000/0000/0000/afff +URxvt.depth: 32 +URxvt.urgentOnBell: True + +! TODO: write qubes-rpc to handle printing +URxvt.print-pipe: cat > $(TMPDIR=$HOME mktemp urxvt.XXXXXX) + +! selection-to-clipboard violates +! http://standards.freedesktop.org/clipboards-spec/clipboards-latest.txt [1], +! but it does for greater good: urxvt has no other means to move PRIMARY to +! CLIPBOARD, so Qubes' clipboard won't work without it. Also the rationale given +! in [1] has little relevance to advanced terminal emulator, specifically there +! is no need for w32-style intuition and virtually no need to "paste over". +URxvt.perl-ext-common: default,selection-to-clipboard + +! Prevent rxvt from entering Keyboard symbols entry mode whenever you press +! ctrl+shift, e.g. to copy or paste something to/from Qubes' clipboard. +URxvt.iso14755_52: false + +URxvt.insecure: False + +! some termcap-aware software sometimes throw '$TERM too long' +!URxvt.termName: rxvt-256color +~~~ + +Then create script to automatically merge those to xrdb. +File `/etc/X11/xinit/xinitrc.d/urxvt.sh`: + +~~~ +#!/bin/sh + +[ -r /etc/X11/Xresources.urxvt ] && xrdb -merge /etc/X11/Xresources.urxvt +~~~ + +Shortcuts +--------- + +For each AppVM, go to *Qubes Manager \> VM Settings \> Applications*. +Find `rxvt-unicode` (or `rxvt-unicode (256-color) multi-language`) and add. diff --git a/configuration-guides/tips-and-tricks.md b/configuration-guides/tips-and-tricks.md new file mode 100644 index 0000000..f341998 --- /dev/null +++ b/configuration-guides/tips-and-tricks.md @@ -0,0 +1,62 @@ +--- +layout: doc +title: Tips and Tricks +permalink: /doc/tips-and-tricks/ +--- + +Tips and Tricks +=============== +This section provides user suggested tips that aim to increase Qubes OS usability, security or that allow users to discover new ways to use your computer that are unique to Qubes OS. + +Opening links in your preferred AppVM +------------------------------------- +To increase both security and usability you can set an AppVM so that it automatically opens any link in an different AppVM of your choice. You can do this for example in the email AppVM, in this way you avoid to make mistakes like opening links in it. To learn more you can check [security guidelines](/doc/security-guidelines/) and [security goals](/security/goals/). + +The command `qvm-open-in-vm` lets you open a document or a URL in another VM. It takes two parameters: vmname and filename. + +For example, if you launch this command from your email AppVM: + +`qvm-open-in-vm untrusted https://duckduckgo.com` + +it will open duckduckgo.com in the `untrusted` AppVM (after you confirmed the request). + +If you want this to happen automatically you can create a .desktop file that advertises itself as a handler for http/https links, and then set this as your default browser. + +Open a text editor and copy and paste this into it: + + [Desktop Entry] + Encoding=UTF-8 + Name=BrowserVM + Exec=qvm-open-in-vm APPVMNAME %u + Terminal=false + X-MultipleArgs=false + Type=Application + Categories=Network;WebBrowser; + MimeType=x-scheme-handler/unknown;x-scheme-handler/about;text/html;text/xml;application/xhtml+xml;application/xml;application/vnd.mozilla.xul+xml;application/rss+xml;application/rdf+xml;image/gif;image/jpeg;image/png;x-scheme-handler/http;x-scheme-handler/https; + +Replace `APPVMNAME` with the AppVM name you want to open links in. Now save, in the AppVM that you want to modify, this file to `~/.local/share/applications/browser_vm.desktop` + +Finally, set it as your default browser: + +`xdg-settings set default-web-browser browser_vm.desktop` + +Credit: [Micah Lee](https://micahflee.com/2016/06/qubes-tip-opening-links-in-your-preferred-appvm/) + +Preventing data leaks +--------------------- +First make sure to read [Understanding and Preventing Data Leaks](/doc/data-leaks/) section to understand the limits of this tip. + +Suppose that you have within a not so trusted environment - for example, a Windows VM - an application that tracks and reports its usage, or you simply want to protect your data. + +Start the Windows TemplateVM (which has no user data), install/upgrade apps; then start Windows AppVM (with data) in offline mode. So, if you worry (hypothetically) that your Windows or app updater might want to send your data away, this Qubes OS trick will prevent this. +This applies also to any TemplateBasedVM relative to its parent TemplateVM, but the privacy risk is especially high in the case of Windows. + +Credit: [Joanna Rutkovska](https://twitter.com/rootkovska/status/832571372085850112) + + +Trim for standalone AppVMs +--------------------- +The `qvm-trim-template` command is not available for a standalone AppVM. + +It is still possible to trim the AppVM disks by using the `fstrim --all` command from the appvm. +You can also add the `discard` option to the mount line in `/etc/fstab` inside the standalone AppVM if you want trimming to be performed automatically, but there may be a performance impact on writes and deletes. diff --git a/configuration-guides/vpn.md b/configuration-guides/vpn.md new file mode 100644 index 0000000..7d2d63e --- /dev/null +++ b/configuration-guides/vpn.md @@ -0,0 +1,324 @@ +--- +layout: doc +title: VPN +permalink: /doc/vpn/ +redirect_from: +- /doc/privacy/vpn/ +- /en/doc/vpn/ +- /doc/VPN/ +- /wiki/VPN/ +--- + +How To make a VPN Gateway in Qubes +================================== + +Although setting up a VPN connection is not by itself Qubes specific, Qubes includes a number of tools that can make the client-side setup of your VPN more versatile and secure. This document is a Qubes-specific outline for choosing the type of VM to use, and shows how to prepare a ProxyVM for either NetworkManager or a set of fail-safe VPN scripts. + +Please refer to your guest OS and VPN service documentation when considering the specific steps and parameters for your connection(s); The relevant documentation for the Qubes default guest OS (Fedora) is [Establishing a VPN Connection.](https://docs.fedoraproject.org/en-US/Fedora/23/html/Networking_Guide/sec-Establishing_a_VPN_Connection.html) + +### NetVM + +The simplest case is to set up a VPN connection using the NetworkManager service inside your NetVM. Because the NetworkManager service is already started, you are ready to set up your VPN connection. However this has some disadvantages: + +- You have to place (and probably save) your VPN credentials inside the NetVM, which is directly connected to the outside world +- All your AppVMs which are connected to the NetVM will be connected to the VPN (by default) + +### AppVM + +While the NetworkManager service is not started here (for a good reason), you can configure any kind of VPN client in your AppVM as well. However this is only suggested if your VPN client has special requirements. + +### ProxyVM + +One of the best unique features of Qubes OS is its special type of VM called a ProxyVM. The special thing is that your AppVMs see this as a NetVM (or uplink), and your NetVMs see it as a downstream AppVM. Because of this, you can place a ProxyVM between your AppVMs and your NetVM. This is how the default sys-firewall VM functions. + +Using a ProxyVM to set up a VPN client gives you the ability to: + +- Separate your VPN credentials from your NetVM. +- Separate your VPN credentials from your AppVM data. +- Easily control which of your AppVMs are connected to your VPN by simply setting it as a NetVM of the desired AppVM. + +Set up a ProxyVM as a VPN gateway using NetworkManager +------------------------------------------------------ + +1. Create a new VM, name it, click the ProxyVM radio button, and choose a color and template. + + ![Create\_New\_VM.png](/attachment/wiki/VPN/Create_New_VM.png) + +2. Add the `network-manager` service to this new VM. + + ![Settings-services.png](/attachment/wiki/VPN/Settings-services.png) + +3. Set up your VPN as described in the NetworkManager documentation linked above. + +4. (Optional) Make your VPN start automatically. + + Edit `/rw/config/rc.local` and add these lines: + + ```bash + # Automatically connect to the VPN once Internet is up + while ! ping -c 1 -W 1 1.1.1.1; do + sleep 1 + done + PWDFILE="/rw/config/NM-system-connections/secrets/passwd-file.txt" + nmcli connection up file-vpn-conn passwd-file $PWDFILE + ``` + You can find the actual "file-vpn-conn" in `/rw/config/NM-system-connections/`. + + Create directory `/rw/config/NM-system-connections/secrets/` (You can put your `*.crt` and `*.pem` files here too). + Create a new file `/rw/config/NM-system-connections/secrets/passwd-file.txt`: + ``` + vpn.secrets.password:XXXXXXXXXXXXXX + ``` + And substitute "XXXXXXXXXXXXXX" for the actual password. + The contents of `passwd-file.txt` may differ depending on your VPN settings. See the [documentation for `nmcli up`](https://www.mankier.com/1/nmcli#up). + +5. (Optional) Make the network fail-close for the AppVMs if the connection to the VPN breaks. + + Edit `/rw/config/qubes-firewall-user-script` and add these lines: + ```bash + # Block forwarding of connections through upstream network device + # (in case the vpn tunnel breaks) + iptables -I FORWARD -o eth0 -j DROP + iptables -I FORWARD -i eth0 -j DROP + ip6tables -I FORWARD -o eth0 -j DROP + ip6tables -I FORWARD -i eth0 -j DROP + ``` + +6. Configure your AppVMs to use the new VM as a NetVM. + + ![Settings-NetVM.png](/attachment/wiki/VPN/Settings-NetVM.png) + +7. Optionally, you can install some [custom icons](https://github.com/Zrubi/qubes-artwork-proxy-vpn) for your VPN + + +Set up a ProxyVM as a VPN gateway using iptables and CLI scripts +---------------------------------------------------------------- + +This method is more involved than the one above, but has anti-leak features that also make the connection _fail closed_ should it be interrupted. +It has been tested with Fedora 23 and Debian 8 templates. + +1. Create a new VM, name it, click the ProxyVM radio button, and choose a color and template. + + ![Create\_New\_VM.png](/attachment/wiki/VPN/Create_New_VM.png) + + Note: Do not enable NetworkManager in the ProxyVM, as it can interfere with the scripts' DNS features. + If you enabled NetworkManager or used other methods in a previous attempt, do not re-use the old ProxyVM... + Create a new one according to this step. + + If your choice of TemplateVM doesn't already have the VPN client software, you'll need to install the software in the template before proceeding. + Disable any auto-starting service that comes with the software package. + For example for OpenVPN. + + sudo systemctl disable openvpn.service + + You may also wish to install `nano` or another simple text editor for entering the scripts below. + +2. Set up and test the VPN client. + Make sure the VPN VM and its TemplateVM is not running. + Run a terminal (CLI) in the VPN VM -- this will start the VM. + Then create a new `/rw/config/vpn` folder with. + + sudo mkdir /rw/config/vpn + + Copy your VPN config files to `/rw/config/vpn`. + Your VPN config file should be named `openvpn-client.ovpn`) so you can use the scripts below as is without modification. + Otherwise you would have to replace the file name. + `openvpn-client.ovpn` contents: + + * Files accompanying the main config such as `*.crt` and `*.pem` should also go to `/rw/config/vpn` folder. + * Files referenced in `openvpn-client.ovpn` should not use absolute paths such as `/etc/...`. + + The VPN scripts here are intended to work with commonly used `tun` interfaces, whereas `tap` mode is untested. + Also, the config should route all traffic through your VPN's interface after a connection is created; For OpenVPN the directive for this is `redirect-gateway def1`. + + sudo nano /rw/config/vpn/openvpn-client.ovpn + + Make sure it already includes or add: + + redirect-gateway def1 + + The VPN client may not be able to prompt you for credentials when connecting to the server. + Create a file in the `/rw/config/vpn` folder with your credentials and using a directive. + For example for OpenVPN, add: + + auth-user-pass pass.txt + + Save file `/rw/config/vpn/openvpn-client.ovpn`. + Make sure a `/rw/config/vpn/pass.txt` file actually exists. + + sudo nano /rw/config/vpn/pass.txt + + Add: + + username + password + + Replace `username` and `password` with your actual username and password. + + **Test your client configuration:** + Run the client from a CLI prompt in the 'vpn' folder, preferably as root. + For example: + + sudo openvpn --cd /rw/config/vpn --config openvpn-client.ovpn + + Watch for status messages that indicate whether the connection is successful and test from another VPN VM terminal window with `ping`. + + ping 8.8.8.8 + + `ping` can be aborted by pressing the two keys `ctrl` + `c` at the same time. + DNS may be tested at this point by replacing addresses in `/etc/resolv.conf` with ones appropriate for your VPN (although this file will not be used when setup is complete). + Diagnose any connection problems using resources such as client documentation and help from your VPN service provider. + Proceed to the next step when you're sure the basic VPN connection is working. + +3. Create the DNS-handling script. + + sudo nano /rw/config/vpn/qubes-vpn-handler.sh + + Edit and add: + + ~~~ + #!/bin/bash + set -e + export PATH="$PATH:/usr/sbin:/sbin" + + case "$1" in + + up) + # To override DHCP DNS, assign DNS addresses to 'vpn_dns' env variable before calling this script; + # Format is 'X.X.X.X Y.Y.Y.Y [...]' + if [[ -z "$vpn_dns" ]] ; then + # Parses DHCP foreign_option_* vars to automatically set DNS address translation: + for optionname in ${!foreign_option_*} ; do + option="${!optionname}" + unset fops; fops=($option) + if [ ${fops[1]} == "DNS" ] ; then vpn_dns="$vpn_dns ${fops[2]}" ; fi + done + fi + + iptables -t nat -F PR-QBS + if [[ -n "$vpn_dns" ]] ; then + # Set DNS address translation in firewall: + for addr in $vpn_dns; do + iptables -t nat -A PR-QBS -i vif+ -p udp --dport 53 -j DNAT --to $addr + iptables -t nat -A PR-QBS -i vif+ -p tcp --dport 53 -j DNAT --to $addr + done + su - -c 'notify-send "$(hostname): LINK IS UP." --icon=network-idle' user + else + su - -c 'notify-send "$(hostname): LINK UP, NO DNS!" --icon=dialog-error' user + fi + + ;; + down) + su - -c 'notify-send "$(hostname): LINK IS DOWN !" --icon=dialog-error' user + ;; + esac + ~~~ + + Save the script. + Make it executable. + + sudo chmod +x /rw/config/vpn/qubes-vpn-handler.sh + +4. Configure client to use the DNS handling script. Using openvpn as an example, edit the config. + + sudo nano /rw/config/vpn/openvpn-client.ovpn + + Add the following. + + script-security 2 + up 'qubes-vpn-handler.sh up' + down 'qubes-vpn-handler.sh down' + + Remove other instances of lines starting with `script-security`, `up` or `down` should there be any others. + Save the script. + **Restart the client and test the connection again** ...this time from an AppVM! + +5. Set up iptables anti-leak rules. + Edit the firewall script. + + sudo nano /rw/config/qubes-firewall-user-script + + Clear out the existing lines and add: + + ~~~ + #!/bin/bash + # Block forwarding of connections through upstream network device + # (in case the vpn tunnel breaks): + iptables -I FORWARD -o eth0 -j DROP + iptables -I FORWARD -i eth0 -j DROP + ip6tables -I FORWARD -o eth0 -j DROP + ip6tables -I FORWARD -i eth0 -j DROP + + # Block all outgoing traffic + iptables -P OUTPUT DROP + iptables -F OUTPUT + iptables -I OUTPUT -o lo -j ACCEPT + + # Add the `qvpn` group to system, if it doesn't already exist + if ! grep -q "^qvpn:" /etc/group ; then + groupadd -rf qvpn + sync + fi + sleep 2s + + # Allow traffic from the `qvpn` group to the uplink interface (eth0); + # Our VPN client will run with group `qvpn`. + iptables -I OUTPUT -p all -o eth0 -m owner --gid-owner qvpn -j ACCEPT + ~~~ + + Save the script. + Make it executable. + + sudo chmod +x /rw/config/qubes-firewall-user-script + +5. Set up the VPN's autostart. + + sudo nano /rw/config/rc.local + + Clear out the existing lines and add: + + ~~~ + #!/bin/bash + VPN_CLIENT='openvpn' + VPN_OPTIONS='--cd /rw/config/vpn/ --config openvpn-client.ovpn --daemon' + + su - -c 'notify-send "$(hostname): Starting $VPN_CLIENT..." --icon=network-idle' user + groupadd -rf qvpn ; sleep 2s + sg qvpn -c "$VPN_CLIENT $VPN_OPTIONS" + ~~~ + + If you are using anything other than OpenVPN, change the `VPN_CLIENT` and `VPN_OPTIONS` variables to match your VPN software. + Save the script. + Make it executable. + + sudo chmod +x /rw/config/rc.local + +6. Restart the new VM! + The link should then be established automatically with a popup notification to that effect. + + +Usage +----- + +Configure your AppVMs to use the VPN VM as a NetVM... + +![Settings-NetVM.png](/attachment/wiki/VPN/Settings-NetVM.png) + +If you want to be able to use the [Qubes firewall](/doc/firewall), create a new FirewallVM (as a ProxyVM) and set it to use the VPN VM as its NetVM. +Then, configure AppVMs to use your new FirewallVM as their NetVM. + +If you want to update your TemplateVMs through the VPN, enable the `qubes-updates-proxy` service in your new FirewallVM. +You can do this in the Services tab in Qubes VM Manager or on the command-line: + + qvm-service -e qubes-updates-proxy + +Then, configure your templates to use your new FirewallVM as their NetVM. + + +Troubleshooting +--------------- + +* Always test your basic VPN connection before adding scripts. +* Test DNS: Ping a familiar domain name from an appVM. It should print the IP address for the domain. +* For scripting: Ping external IP addresses from inside the VPN VM using `sudo sg qvpn -c 'ping ...'`, then from an appVM using just `ping ...`. Once the firewall rules are in place, you will have to use `sudo sg` to run any IP network commands in the VPN VM. +* Use `iptables -L -v` and `iptables -L -v -t nat` to check firewall rules. The latter shows the critical PR-QBS chain that enables DNS forwarding. diff --git a/configuration-guides/w3m.md b/configuration-guides/w3m.md new file mode 100644 index 0000000..5511adb --- /dev/null +++ b/configuration-guides/w3m.md @@ -0,0 +1,40 @@ +--- +layout: doc +title: Reducing the fingerprint of the text-based web browser w3m +permalink: /doc/w3m/ +redirect_from: +- /en/doc/mutt/ +- /doc/W3m/ +- /wiki/W3m/ +--- + +Reducing the fingerprint of the text-based web browser w3m +==== + +TL;DR: You can reduce the amount of information w3m gives about itself and the environment it is running in (and, by extension, you). **It will not make you anonymous; your fingerprint will still be unique.** But it may improve your privacy. + +[w3m](http://w3m.sourceforge.net/) 'is a text-based web browser as well as a pager like `more` or `less`. With w3m you can browse web pages through a terminal emulator window (xterm, rxvt or something like that). Moreover, w3m can be used as a text formatting tool which typesets HTML into plain text.' + +You can reduce the [browser fingerprint](https://panopticlick.eff.org/about#browser-fingerprinting) by applying the following changes to `~/.w3m/config` in any AppVM you want to use w3m in. (If you have not run w3m yet, you might need to copy the config file from elsewhere.) You can also apply the same changes to `/etc/w3m/config` in the relevant TemplateVM(s) to have them apply to multiple AppVMs; but make sure they are not reversed by the contents of `~/.w3m/config` in any of the AppVMs. (w3m reads `~/.w3m/config` after `/etc/w3m/config`). + +* Set `user_agent` to `user_agent Mozilla/5.0 (Windows NT 6.1; rv:45.0) Gecko/20100101 Firefox/45.0`. + + By default w3m identifies itself as `w3m/` + version number. The user agent `Mozilla/5.0 (Windows NT 6.1; rv:45.0) Gecko/20100101 Firefox/45.0` is the most common and the one used by the Tor Browser Bundle (TBB). One in fourteen browsers fingerprinted by Panopticlick has this value. + +* Make w3m use the same HTTP_ACCEPT headers the TBB by adding the following lines at the end of the file: + + accept_language en-US,en;q=0.5 + accept_encoding gzip, deflate + accept_media text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 + + These changes will hide your computer's locale and some other information that may or may not be unique to the VM in which it is running. With the modifications above w3m will have the same headers as about one in fifteen browsers fingerprinted by Panopticlick. + +Testing these settings on returns a fingerprint that is distinguishable from that of the TBB (with JavaScript disabled) only by 'Screen Size (CSS)' and 'Browser supports HSTS?'.\* ( does not work with w3m.) Due to the low number of w3m users it is highly likely that you will have an unique browser fingerprint among the visitors of a website using somewhat sophisticated browser fingerprinting technology. But at least your browser fingerprint will not reveal your computer's locale settings or other specifics about it in the HTTP_ACCEPT headers. And while it may be inferred from your fingerprint that you use w3m, it is not be explicitly stated in the User-Agent header. + +**Reminder: Do not rely on these settings for anonymity. Using w3m is all but guaranteed to make you stand out in the crowd.** + +PS: You still need to delete cookies manually (`~/.w3m/cookie`) if you are not running w3m in a DispVM anyway. If you set w3m to not accept cookies, its fingerprint will change. (You can configure w3m to not use store cookies or accept new ones (or both), but the setting `use_cookie` seems to really mean `accept_cookie` and vice-versa, so maybe it is best to delete them manually for now.) + +* * * + +\* Does someone know how to fix this? diff --git a/configuration-guides/zfs.md b/configuration-guides/zfs.md new file mode 100644 index 0000000..931d459 --- /dev/null +++ b/configuration-guides/zfs.md @@ -0,0 +1,197 @@ +--- +layout: doc +title: ZFS +permalink: /doc/zfs/ +redirect_from: +- /en/doc/zfs/ +- /doc/ZFS/ +- /wiki/ZFS/ +--- + +ZFS in Qubes +============ + +**Use at your own risk**! + +Beware: Dragons might eat your precious data! + +Install ZFS in Dom0 +=================== + +Install DKMS style packages for Fedora (defunct in 0.6.2 due to spl/issues/284) +---------------------------------------------------------------------------------------------------- + +Fetch and install repository for DKMS style packages for your Dom0 Fedora version [http://zfsonlinux.org/fedora.html](http://zfsonlinux.org/fedora.html): + +~~~ +disp1# wget http://archive.zfsonlinux.org/fedora/zfs-release-1-1$(rpm -E %dist).noarch.rpm +dom0# qvm-run --pass-io disp1 'cat /home/user/zfs-release-1-1.fc18.noarch.rpm' > /home/user/zfs-release-1-1.fc18.noarch.rpm +dom0# sudo yum localinstall /home/user/zfs-release-1-1.fc18.noarch.rpm +dom0# sudo sed -i 's/$releasever/18/g' /etc/yum.repo.d/zfs.repo +dom0# sudo qubes-dom0-update @development-tools +dom0# sudo qubes-dom0-update zfs +~~~ + +Install DKMS style packages from git-repository +----------------------------------------------- + +Build and install your DKMS or KMOD packages as described in [http://zfsonlinux.org/generic-rpm.html](http://zfsonlinux.org/generic-rpm.html). + +### Prerequisites steps in AppVM (i.e. disp1) + +Checkout repositories for SPL and ZFS: + +~~~ +mkdir ~/repositories && cd ~/repositories +git clone https://github.com/zfsonlinux/spl.git +git clone https://github.com/zfsonlinux/zfs.git +~~~ + +Revert changes in SPL repository due to this bug: [https://github.com/zfsonlinux/spl/issues/284](https://github.com/zfsonlinux/spl/issues/284) + +~~~ +cd ~/repositories/spl +git config --global user.email "user@example.com" +git config --global user.name "user" +git revert e3c4d44886a8564e84aa697477b0e37211d634cd +~~~ + +### Installation steps in Dom0 + +Copy repositories over to Dom0: + +~~~ +mkdir ~/repositories +qvm-run --pass-io disp1 'tar -cf - -C ~/repositories/ {spl,zfs}' | tar -xpf - -C ~/repositories/ +~~~ + +Installing build requirements for SPL and ZFS DKMS modules: + +~~~ +sudo qubes-dom0-update dkms kernel-devel zlib-devel libuuid-devel libblkid-devel lsscsi bc autoconf automake binutils bison flex gcc gcc-c++ gdb gettext libtool make pkgconfig redhat-rpm-config rpm-build strace +~~~ + +Configure and build SPL DKMS packages: + +~~~ +cd ~/repositories/spl +./autogen.sh +./configure --with-config=user +make rpm-utils rpm-dkms +~~~ + +Configure and build ZFS DKMS packages: + +~~~ +cd ~/repositories/zfs +./autogen.sh +./configure --with-config=user +make rpm-utils rpm-dkms +~~~ + +Install SPL and ZFS packages (i.e. version 0.6.2): + +~~~ +sudo yum localinstall \ + ~/repositories/spl/spl-0.6.2-1.qbs2.x86_64.rpm \ + ~/repositories/spl/spl-dkms-0.6.2-1.qbs2.noarch.rpm \ + ~/repositories/zfs/zfs-0.6.2-1.qbs2.x86_64.rpm \ + ~/repositories/zfs/zfs-dkms-0.6.2-1.qbs2.noarch.rpm \ + ~/repositories/zfs/zfs-dracut-0.6.2-1.qbs2.x86_64.rpm \ + ~/repositories/zfs/zfs-test-0.6.2-1.qbs2.x86_64.rpm +~~~ + +Configure ZFS +============= + +Automatically load modules +-------------------------- + +/etc/sysconfig/modules/zfs.modules + +~~~ +#!/bin/sh + +for module in spl zfs; do + modprobe ${module} >/dev/null 2>&1 +done +~~~ + +Make this file executable. + +Tuning +------ + +Tame the memory-eating dragon (i.e. 512 Mb zfs\_arc\_max): + +/etc/modprobe.d/zfs.conf + +~~~ +options zfs zfs_arc_max=536870912 +~~~ + +Setup a zpool with ZFS datasets +------------------------------- + +You can create a ZFS dataset for each AppVM, ServiceVM, HVM or TemplateVM or just use a pool as your backup location. + +Move your existing directory to a temporary location, or the ZFS mount will overlay your directory. + +Beware: VMs on a ZFS dataset aren't working, if your ZFS installation deserts you. + +So keep netvm, firewallvm and your templates on your root file-system (preferably on a SSD). + +~~~ +zpool create -m none -o ashift=12 -O atime=off -O compression=lz4 qubes mirror /dev/mapper/ /dev/mapper/ +zfs create -p qubes/appvms +zfs create -m /var/lib/qubes/backup-zfs qubes/backup +zfs create -m /var/lib/qubes/appvms/banking qubes/appvms/banking +zfs create -m /var/lib/qubes/appvms/personal qubes/appvms/personal +zfs create -m /var/lib/qubes/appvms/untrusted qubes/appvms/untrusted +zfs create -m /var/lib/qubes/appvms/work qubes/appvms/work +~~~ + +Have fun with zpool and zfs. + +Tips and Hints +============== + +Backup your data +---------------- + +You're depending on an huge amount of code for this file system, keep this in mind and backup your precious data. + +Encrypt underlying devices +-------------------------- + +~~~ +dom0# cryptsetup -c aes-xts-plain64 luksFormat +dom0# cryptsetup luksOpen +~~~ + +With the use of cryptsetup a keyfile can be specified to decrypt devices. + +~~~ +dom0# head -c 256 /dev/random > /root/keyfile1 +dom0# chmod 0400 /root/keyfile1 +dom0# cryptsetup luksAddKey /root/keyfile1 +~~~ + +Decrypt devices on boot +----------------------- + +Add your devices to /etc/crypttab. + +~~~ + + none +~~~ + +Specifying a keyfile is especially useful, if ZFS should be ready during boot. + +Further Reading +--------------- + +- [http://www.open-zfs.org](http://www.open-zfs.org) +- [http://zfsonlinux.org](http://zfsonlinux.org) + diff --git a/customization-guides/awesome.md b/customization-guides/awesome.md new file mode 100644 index 0000000..4f95505 --- /dev/null +++ b/customization-guides/awesome.md @@ -0,0 +1,187 @@ +--- +layout: doc +title: awesome +permalink: /doc/awesome/ +redirect_from: +- /en/doc/awesome/ +- /doc/awesome/ +--- + +# Using awesome in dom0 + +## Qubes-specific features + +* support for the Qubes OS window colors +* rudimentary support for the Qubes application menu entries following the freedesktop standard +* support for custom filters and menu entries + +## Installation + +awesome can be installed with the standard dom0 installation mechanisms. + + $ sudo qubes-dom0-update awesome + +That's it. After logging out, you can select awesome in the login manager. + +## Development + +To [contribute code](/doc/contributing/) you may clone the awesome repository as follows: + + $ git clone https://github.com/QubesOS/qubes-desktop-linux-awesome + +For build instructions please check the repository _README_. + +The repository attempts to follow the upstream Fedora repository. + +## Common customizations + +This section focuses on Qubes-specific customizations. For generic awesome customizations you might want to have a look at the [awesome website](https://awesomewm.org). + +Customizations for awesome are usually done at `~/.config/awesome/rc.lua`. The default file can be found at `/etc/xdg/awesome/rc.lua`. + +### Application menu + +Starting from Qubes 4.0 application menu entries specific to awesome can be put into `~/.config/awesome/xdg-menu/` following the freedesktop standard. The folder might have to be created. + +### Focus steal hardening + +The default Qubes OS awesome installation comes with the defaults set by the awesome developers for focus changes. Some users may want more tight control over window focus changes - especially since focus changes can have security implications when sensitive data is provided to an incorrect application or even qube. + +#### Definition + +For the below example we'll define _wanted focus changes_ as one of the below: + +* mouse move & click afterwards +* workspace/tag change +* pre-defined key combinations for focus changes (e.g. Mod-j & Mod-k) +* tag assignments and unassignments + +Everything else is considered an unwanted _focus steal_. + +In particular the following events are not meant to cause a focus change: + +* new window created +* a window was closed +* application request +* mouse move without click (sloppy focus) + +For the below example other requests from applications to the window manager are meant to be ignored in general as well, e.g.: +* windows shouldn't be able to maximize themselves without the user giving a respective command to the WM (simple test: Firefox F11 next to another window) +* windows shouldn't be able to change their size themselves +* windows shouldn't be able to modify their borders in any way + +Users may want to adjust their definitions and respective implementations according to their needs. + +#### Implementation + +The implementation may be specific to the awesome version you're running. This guide refers to awesome version 3.5.9 which is available to Qubes 4.0 users. + +Please keep in mind that this guide may not be conclusive. Your mileage may vary. + +##### Change the autofocus implementation + +The line `require("awful.autofocus")` in your _rc.lua_ implements various focus-related features for your awesome instance. + +In order to customise these, you can copy the file `/usr/share/awesome/lib/awful/autofocus.lua` to e.g. `~/.config/awesome/autofocus_custom.lua` and replace the line above with `require("autofocus_custom")`. + +Then you can customise the focus behavior. According to our above definitions it would look as follows: + +```lua +---autofocus_custom.lua +local client = client +local screen = screen +local aclient = require("awful.client") +local atag = require("awful.tag") + +--- When loaded, this module makes sure that there's always a client that will have focus +-- on events such as tag switching, client unmanaging, etc. +-- awful.autofocus + +-- Give focus when clients appear/disappear and no one else has focus. +-- @param obj An object that should have a .screen property. +function check_focus(obj) + -- When no visible client has the focus... + if not client.focus or not client.focus:isvisible() then + local c = aclient.focus.history.get(obj.screen, 0) + if c then client.focus = c end + end +end + +-- Give focus on tag selection change. +-- @param tag A tag object +function check_focus_tag(t) + local s = atag.getscreen(t) + if not s then return end + check_focus({ screen = s }) + if client.focus and client.focus.screen ~= s then + local c = aclient.focus.history.get(s, 0) + if c then client.focus = c end + end +end + +--made above functions global & removed some focus switches below (user interaction required instead) + +--clear any focus +function clear_focus() + --unfortunately this doesn't work at the moment + --cf. https://github.com/awesomeWM/awesome/issues/164 + --(Qubes uses an older awesome version that doesn't have the fix yet) + --client.focus = nil +end + +atag.attached_connect_signal(nil, "property::selected", check_focus_tag) +client.connect_signal("unmanage", clear_focus) +client.connect_signal("tagged", check_focus) +client.connect_signal("untagged", check_focus) +client.connect_signal("property::hidden", clear_focus) +client.connect_signal("property::minimized", clear_focus) +``` + +##### Remove unwanted focus changing key bindings + +The mouse bindings + +```lua +awful.button({ }, 4, awful.tag.viewnext), +awful.button({ }, 5, awful.tag.viewprev) +``` + +in the default _rc.lua_ may cause tag and thus focus changes without keyboard interaction and tend to happen accidentally. This doesn't suit our definition from above and should therefore be removed or commented out. + +##### Adjust client rules + +The default client rule allows certain focus changes via `focus = awful.client.focus.filter`. These changes can be prevented entirely by setting `focus = false`. + +Alternatively users may provide their own focus filter functions. + +##### Disable sloppy focus + +In your _rc.lua_ you'll find a section such as + +```lua + -- Enable sloppy focus + c:connect_signal("mouse::enter", function(c) + if awful.layout.get(c.screen) ~= awful.layout.suit.magnifier + and awful.client.focus.filter(c) then + client.focus = c + end + end) +``` + +These enable _sloppy focus_ aka focus changes on mouse movements (without clicking) and should be removed or commented out to disable that behaviour. + +##### Ignore requests from applications to the window manager + +Handling of such requests is currently mostly implemented by awesome in the file `/usr/share/awesome/lib/awful/ewmh.lua`. You can either comment out the respective `client.connect_singal()` lines in that file (it will change back after each awesome update though) or disconnect the signals in your _rc.lua_. + +As of awesome 3.5.9 this however is apparently only possible for signals connected to global functions, i.e. currently only the below signals can be disconnected in the _rc.lua_: + +```lua +local ewmh = require("awful.ewmh") + +client.disconnect_signal("request::activate", ewmh.activate) +client.disconnect_signal("request::tag", ewmh.tag) +``` + +The signal names may change across awesome versions. + diff --git a/customization-guides/dark-theme.md b/customization-guides/dark-theme.md new file mode 100644 index 0000000..4cdf0c7 --- /dev/null +++ b/customization-guides/dark-theme.md @@ -0,0 +1,187 @@ +--- +layout: doc +title: Dark Theme in Dom0 and DomU +permalink: /doc/dark-theme/ +--- + +Dark Theme in Dom0 +================== + +Dark KDE in Dom0 +---------------- + +The following text describes how to change the default light theme to a dark theme. This is just an example, feel free to adjust the appearance to your taste. + +The image below shows the default light theme after installation. +![begin light theme](/attachment/wiki/Dark-Theme/kde-fresh-installed-standard.png) + +This is the result after applying the steps described here. +![end result dark theme](/attachment/wiki/Dark-Theme/kde-end-result.png) + +1. Change `Workspace Appearance` + + 1. Open the `Workspace Appearance` window + + Qubes Menu -> System Tools -> System Settings -> Workspace Appearance + + ![Workspace Appearance](/attachment/wiki/Dark-Theme/kde-app-appearance-menu-style.png) + + 2. Go to `Desktop Theme` + + ![Desktop Menu](/attachment/wiki/Dark-Theme/kde-appearance-settings-desktop-theme-oxygen.png) + + 3. Select `Oxygen` and `Apply` the change + +2. (Optional) Remove blue glowing task items + + ![blue glowing task bar items](/attachment/wiki/Dark-Theme/kde-taskbar-blue-glowing-border.png) + + 1. Adjust Oxygen `Details` + + Qubes Menu -> System Tools -> System Settings -> Workspace Appearance -> Desktop Theme -> Details (Tab) + + 2. Select `Oxygen` + + 3. Change `Theme Item -> Task Items` from `Oxygen Task Items` to `Air Task Items` + + ![Change Task items look](/attachment/wiki/Dark-Theme/kde-desktop-theme-details.png) + + 4. Apply changes + + ![task bar items blue glowing removed](/attachment/wiki/Dark-Theme/kde-taskbar-blue-glowing-removed.png) + +3. Change `Application Appearance` + + 1. Open the `Application Appearance` window + + Qubes Menu -> System Tools -> System Settings -> Application Appearance + + 2. Go to `Colors` + + ![colors tab](/attachment/wiki/Dark-Theme/kde-app-appearance-menu-colors.png) + + 3. Select `Obsidian Coast` + + ![set to Obsidian Coast](/attachment/wiki/Dark-Theme/kde-app-appearance-menu-colors-set.png) + + 4. Apply Changes + + Qubes VM Manager should now look like the image below. + + ![result black Qubes Manager](/attachment/wiki/Dark-Theme/kde-black-qubes-manager.png) + +**Note:** Changing the `Window Decorations` from `Plastik for Qubes` will remove the border color and the VM name. The problem with `Plastik for Qubes` is, that it does not overwrite the background and text color for Minimize, Maximize and Close buttons. The three button are therefore hard to read. + +Dark XCFE in Dom0 +----------------- + +The following text describes how to change the default light theme to a dark theme. This is just an example, feel free to adjust the appearance to your taste. + +The image below shows the default light theme after installation. +![begin light theme](/attachment/wiki/Dark-Theme/xfce-fresh-installed.png) + +This is the result after applying the steps described here. +![end result dark theme](/attachment/wiki/Dark-Theme/xfce-end-result.png) + +1. Change Appearance + + 1. Open the `Appearance` dialog + + Qubes Menu -> System Tools -> Appearance + + ![appearance dialog](/attachment/wiki/Dark-Theme/xfce-appearance-dialog.png) + + 2. Change Style to `Albatross` + + **Note:** The black appearance theme `Xfce-dusk` makes the VM names in the `Qubes OS Manager` unreadable. + +2. *(Optional)* Change Window Manager Style + + 1. Open the `Window Manager` dialog + + Qubes Menu -> System Tools -> Appearance + + ![window manager dialog](/attachment/wiki/Dark-Theme/xfce-window-manager-theme.png) + + 2. Change the Theme in the `Style` Tab (e. g. Defcon-IV). All available themes work. + + +Dark App VM, Template VM, Standalone VM, HVM (Linux Gnome) +========================================================== + +Almost all Qubes VMs use default applications based on the GTK toolkit. Therefore the description below is focused on tools from the Gnome Desktop Environment. + +Using "Gnome-Tweak-Tool" +------------------------ + +The advantage of creating a dark themed Template VM is, that each AppVM which is derived from the Template VM will be dark themed by default. + +**Note:** Gnome-Tweak-Tool crashes under Archlinux. A workaround is to assign the AppVM to another TemplateVM (Debian, Fedora) which has Gnome-Tweak-Tool installed. Start the AppVM and configure the settings. Shutdown the machine and switch the template VM back to Archlinux. + +1. Start VM + + **Note:** Remember that if you want to make the change persistent, the change needs to be made in the TemplateVM, not the AppVM. + +2. Install `Gnome-Tweak-Tool` + + - Fedora + + sudo dnf install gnome-tweak-tool + + - Debian + + sudo apt-get install gnome-tweak-tool + +3. *(Only AppVM)* Stop template and start AppVM + +4. Add `Gnome-Tweak-Tool` to the Application Menu + + 1. `Right-click` on VM entry in `Qubes VM Manager` select `Add/remove app shortcuts` + + 2. Select `Tweak Tool` and press the `>` button to add it + + ![Application Dialog](/attachment/wiki/Dark-Theme/dialog-add-gnome-tweak-tool.png) + +5. Enable `Global Dark Theme` + + 1. *Debian only* + + cd ~/.config/ + mkdir gtk-3.0 + cd gtk-3.0/ + touch settings.ini + + 2. Start `Tweak Tool` from the VM application menu and set the `Global Dark Theme` switch to `on` + + ![Global Dark Theme enabled](/attachment/wiki/Dark-Theme/gnome-tweak-tool.png) + +6. *(Optional)* Modify Firefox + + **Note:** Firefox uses GTK style settings by default. This can create side effects such as unusable forms or search fields. One way to avoid this is to add the following line to `/rw/config/rc.local`: + + sed -i.bak "s/Exec=firefox %u/Exec=bash -c 'GTK_THEME=Adwaita:light firefox %u'/g" /usr/share/applications/firefox.desktop + +7. Restart VM or all application + +Manually +-------- + +Manually works for Debian, Fedora and Archlinux. + +1. Start VM + + **Note:** Remember that if you want to make the change persistent, the change needs to be made in the TemplateVM, not the AppVM. + +2. Enable `Global Dark Theme` + + cd ~/.config/ + mkdir gtk-3.0 + cd gtk-3.0/ + touch settings.ini + + add the following lines to `settings.ini` + + [Settings] + gtk-application-prefer-dark-theme=1 + +3. follow step 6 and 7 in: Using `Gnome-Tweak-Tool` diff --git a/customization-guides/fedora-minimal-template-customization.md b/customization-guides/fedora-minimal-template-customization.md new file mode 100644 index 0000000..d4280f2 --- /dev/null +++ b/customization-guides/fedora-minimal-template-customization.md @@ -0,0 +1,294 @@ +--- +layout: doc +title: Fedora Minimal Template Customization +permalink: /doc/fedora-minimal-template-customization/ +redirect_from: /en/doc/fedora-minimal-template-customization/ +--- + +FEDORA Packages Recommendations +====================== + +(starting from a minimal template) + +Template installation +------------------------------ + +> [dom0]#qubes-dom0-update qubes-template-fedora-26-minimal + + +*Note*: If you have doubts about a set of tools or package you want to install, start installing and testing it in an AppVM. +You can then reproduce it later in your TemplateVM if you are satisfied. +That is the template philosophy in QubesOS. + +For more information on the uses of a minimal template read [this page][Minimal]. + +Standard tools installation +================ + +Administration (documented) +--------------------------------------------- + +> sudo pciutils vim-minimal less tcpdump telnet psmisc nmap nmap-ncat usbutils + +*Notes*: nmap can be used to discover hosts on a network (nmap -sP [network]), especially if you are inside a Microsoft network, because your AppVM will be protected/NATted behind the Qubes firewall. +(Microsoft / home networks make heavy use of autodiscovery technologies which require clients to be in the same local network (no firewall/no NAT), eg: your printer.) + +Some recommendations here: check your current network using the Network manager applet (eg: 192.168.1.65). +Then run nmap in your current AppVM/TemplateVM to search for the selected printer/equipment: + nmap -sP 192.168.1.-. +Don't forget to temporarily allow traffic via the Qubes Firewall if you are doing this in a TemplateVM. + +Administration (undocumented) +------------------------------------------------- + +> openssh keepassx openssl gnome-keyring man + +Dependency note: keepassx rely on qt which takes ~30MB + +Network VM (documented) +---------------------------------------- + +> NetworkManager NetworkManager-wifi network-manager-applet wireless-tools dbus-x11 tar tinyproxy iptables + +Network VM (undocumented) +-------------------------------------------- + +> which dconf dconf-editor + +*Notes*: which is required for autostart scripts + +*Notes*: dconf is required to remember the VM settings that are changed (the gsetting backend will be in memory only if gconf is not installed). + +Network VM (manual operations - documented) +------------------------------------------------------------------------ + +Search for wireless firmware matching your wireless card (to be launched in network VM) + +> lspci; dnf search firmware + +ProxyVM/NetworkVM for 3G Modems +-------------------------------------------- + +> ModemManager NetworkManager-wwan usb_modeswitch modem-manager-gui + +Dependency note: modem-manager-gui relies on webkit-gtk and is optional (NetworkManager can handle the modem alone) + +Source: [3GMODEM] + +ProxyVM for VPNs +-------------------------------------------- + +Search for a VPN package for your particular vpn solution then [configure][VPNNM] NetworkManager + +> dnf search NetworkManager [openvpn\|openconnect\|openswat\|...] + +OR + +Refer to [this guide][VPN] which includes instructions for failsafe anti-leak VPN configuration using CLI scripts. (An early discussion about OpenVPN configuration can be viewed [here][OPENVPNSETUP].) Required packages will be `iptables` in addition to VPN software such as `openvpn`. + + +Printer Setup +-------------------------------------------- + +> system-config-printer system-config-printer-applet cups + +Dependency Note: depends on python3 + python3 additional libraries which takes more than 40 M once installed. + +Dependency Note: cups depends on ghostscript and require installing additional printing fonts (not documented here), so it can takes several dozen of MB + +Manual operations +--------------------------- + +- Don't forget to restart your TemplateVM or only the cups service when you installed cups (systemctl start cups) + +- First you need to search for your printer. If you don't know its name or IP, search for it using nmap: check your current network using the Network manager applet (eg: 192.168.1.65). Then run nmap in your current AppVM/TemplateVM to search for the selected printer/equipement: nmap -sP 192.168.1.-. Don't forget to temporarily allow traffic via the Qubes Firewall if you are inside a TemplateVM. + +- Once you identified your printer, run system-config-printer GUI to install your printer + +- You may need to cancel the operation to install more adapted printer drivers (eg: if the driver cannot be found automatically). Use dnf search printername to find potential drivers (eg dnf search photosmart) + +GUI recommendations +====================== + +Lightweight packages recommendations +--------------------------------------------------------------- + +> lxterminal dejavu-sans-mono-fonts dejavu-sans-fonts gnome-settings-daemon + +*Note*: You need to install sans-mono fonts for the terminal or it will be unreadable (overlapping characters....), while the sans fonts are just to get nicer GUI menus. + +*Scite* is a nice notepad that can also highlight scripts with very light dependencies +> scite + +*Meld* allows easy comparison of two text files/ two configuration files. + +> meld + +*Thunar* is a light file manager usually used by xfce + +> thunar thunar-volman ntfs-3g + +Dependency Note: xfce4 dependencies (but still quite light ~1.4M downloads) + +Miscellaneous packages +-------------------------- + +*pycairo* package is needed for file's contextual menu "Send to VM" to function (to actually popup dialog box and enter VM's name where the file will be sent to). + +*pinentry-gtk* package is responsible for pop-up dialog window where you enter password for your password protected gpg key. +Install this package in the qube holding your password protected gpg keys. +If you do not use password protected gpg keys, there is no need to install this package. + +GUI themes +----------------- + +Managing GUI theme / appearance is often complex because when you do not want to depend on a specific desktop system. + +For this reason, we need to customize themes for each GUI framework that our application depends on. + +This often includes GTK2, GTK3 (which us a different configuration/themes than GTK2), Qt. + +The appearance of Windows can only be changed in dom0, however, the appearance of all buttons, menus, icons, widgets are specific to each AppVM. + +### Packages + +Choose theme packages for each framework. I recommend the following documentation [THEMEPACKAGES] + +> clearlooks-phenix-gtk2-theme clearlooks-phenix-gtk3-theme + +You can search for other themes using `dnf search theme gtk`. + +You can check your currently installed theme packages (to eventually remove them) using `rpm -qa | grep theme`. + +### Tweaking theme and appearance + +First you can get an insight of installed Gtk theme and see how it will appear using lxappearance. + +I recommend not applying settings using lxappearance (do not click on apply) because it will create multiple configuration files. + +To remove these files, follow cleanup notes. + +#### Cleanup notes + +~~~ +rm ~/.gtkrc-2.0 +rm ~/.icons/default/index.theme +rm ~/.config/gtk-3.0/settings.ini +rm ~/.config/Trolltech.conf +~~~ + +Cleaning the whole dconf settings is also possible by removing the following file. Please note that it will remove all preferences set for gnome application (not only the themes) + +~~~ +rm ~/.config/dconf/user +~~~ + +*Note*: lxappearance only has an effect on gtk3 themes so it won't work to change gtk2 themes (used by Firefox, Thunderbird ...). + However, it is very lightweight and can be used to identify the name and look of themes you are interested in. + Once you have the name, you can apply it using gsetting command line or gconf-editor. + +*Note*: if you really want a GUI theme editor, you can install gnome-tweak-tools, but this tool has a lot + of gnome dependencies (~150MB of dependencies). You can install it and uninstall it as soon as you change your theme. + +#### Testing notes + +The following programs can be used to see if theme has been correctly applied: + +* GTK2 program: scite, thunderbird, firefox +* GTK3 program: lxterminal +* Qt program: keepassx + +*Note*: testing in a TemplateVM will not work as expected because gnome-settings-daemon is not started in TemplateVM. + so test your themes in an AppVM and then update the TemplateVM accordingly. + +### Forcing theme change for all AppVM depending on a TemplateVM + +This can be done for gtk themes by creating dconf global settings. I recommend reading these articles: + +[DCONF1] + +[DCONF2] + +#### Creating global file + + * Setup global config file: + + > mkdir /etc/dconf/db/qubes.d + + Edit/Create the following file: /etc/dconf/db/qubes.d/10-global-theme-settings: + + ~~~ + [org/gnome/desktop/interface] + cursor-theme="Adwaita" + gtk-theme="Clearlooks-Phenix" + icon-theme="Adwaita" + font-name="Cantarell 11" + monospace-font-name="Monospace 11" + ~~~ + + * Generate global config database + + > dconf update + + * Configure default user profile + + Edit/Create the following file: /etc/dconf/profile/user: + + ~~~ + user-db:user + system-db:qubes + ~~~ + +#### Locking configuration + +It should be noted that the user dconf settings stored in ~/.config/dconf/user always takes precedence over the global dconf settings. + +User dconf settings can be browsed using dconf-editor GUI. + +If you want to force specific settings to be applied for all user (so in our case for all AppVMs depending on the template), you need to create locks: + +> mkdir /etc/dconf/db/qubes.d/locks + +Edit/Create the following file: /etc/dconf/db/qubes.d/locks/theme.lock: + +~~~ +/org/gnome/desktop/interface/gtk-theme +~~~ + +Finally, regenerate the dconf database +> dconf update + +### Uniform look for Qt & GTK + +Getting an uniform look for Qt & GTK is not achieved yet. A good source is on the following link [UNIFORMTHEME] + +Two case: + +1. You installed packages of the theme you selected both for Qt, GTK2 and GTK3. + (eg: Adwaita which is the default theme. I have not found another cross framework theme on fedora default packages). + +2. You want to use the GTK theme you selected for Qt but there is no qt package. + In this case QGtkStyle will take precedence and convert the style automatically. + You can verify if it is enabled by searching for "style=GTK+" in /etc/xdg/Trolltech.conf. + If style is changed to another name, it will be used instead of your GTK theme. + +*Note*: check that ~/.config/Trolltech.conf in your AppVMs is not defining another "style=" because it will take precedence over your global Qt theme. + + +[3GMODEM]: https://www.codeenigma.com/community/blog/installing-3g-usb-modems-linux + +[OPENVPNSETUP]: https://groups.google.com/forum/#!searchin/qubes-users/openvpn$20setup/qubes-users/UbY4-apKScE/lhB_ouTnAwAJ + +[THEMEPACKAGES]: https://groups.google.com/forum/#!search/appvm$20theme/qubes-users/RyVeDiEZ6D0/YR4ITjgdYX0J + +[DCONF1]: http://www.mattfischer.com/blog/?p=431 + +[DCONF2]: https://wiki.gnome.org/Projects/dconf/SystemAdministrators + +[UNIFORMTHEME]: https://wiki.archlinux.org/index.php/Uniform_look_for_Qt_and_GTK_applications + +[Minimal]: ../templates/fedora-minimal/ + +[VPNNM]: ../vpn/#set-up-a-proxyvm-as-a-vpn-gateway-using-networkmanager + +[VPN]: ../vpn/#set-up-a-proxyvm-as-a-vpn-gateway-using-iptables-and-cli-scripts diff --git a/customization-guides/i3.md b/customization-guides/i3.md new file mode 100644 index 0000000..a8de3b6 --- /dev/null +++ b/customization-guides/i3.md @@ -0,0 +1,90 @@ +--- +layout: doc +title: i3 +permalink: /doc/i3/ +redirect_from: +- /en/doc/i3/ +- /doc/i3/ +- "/doc/UserDoc/i3/" +- "/wiki/UserDoc/i3/" +--- + +# i3 installation in dom0 + +i3 is part of the stable repository (as of Qubes R3.1) and can be installed by +using the [dom0 update mechanism](/doc/software-update-dom0/). To install the i3 +window manager and the its Qubes specific configuration: + + $ sudo qubes-dom0-update i3 i3-settings-qubes + +The Qubes-specific configuration (package `i3-settings-qubes`) can be installed +optionally in case you would prefer writing your own configuration (see +[customization](#customization) section for scripts and configuration). + +That's it. After logging out, you can select i3 in the login manager. + +### Customization + +* [xdg_autostart_script](https://gist.github.com/SietsevanderMolen/7b4cc32ce7b4884513b0a639540e454f) +* [i3bar_script](https://gist.github.com/SietsevanderMolen/e7f594f209dfaa3596907e427b657e30) +* [terminal_start_script](https://gist.github.com/SietsevanderMolen/7c6f2b5773dbc0c08e1509e49abd1e96) +* [i3 config with dmenu-i3-window-jumper](https://github.com/anadahz/qubes-i3-config/blob/master/config) + +## Compilation and installation from source + +Note that the compilation from source is done in a Fedora based domU (could +be dispvm). The end result is always an `.rpm` that is copied to dom0 and then +installed through the package manager. + +### Getting the code + +Clone the i3-qubes repository here: + + $ git clone https://github.com/QubesOS/qubes-desktop-linux-i3 + +In this case, the most interesting file is probably +`i3/0001-Show-qubes-domain-in-non-optional-colored-borders.patch` It's the patch +with changes that are necessary to make i3 work nicely with Qubes OS. The code +should not need much explanation, it just gets the vmname and label from Qubes +OS and changes some defaults so the user can't override decisions. + +If you want to make any changes to the package, this is the time and place to do +it. + +### Building + +You'll need to install the build dependencies, which are listed in +build-deps.list. You can verify them and then install them with: + + $ sudo dnf install -y $(cat build-deps.list) + +This used to be more complicated, but I finally redid this and use the same +buildsystem that's used by Qubes OS for XFCE. It's just a Makefile that helps +you get the sources and start off the build: + + $ make rpms + +### Installing + +**Warning**: Manually installing software in dom0 is inherently risky, and the method described here circumvents the usual security mechanisms of qubes-dom0-update. + +You should now have your i3 rpm in `./rpm/x86_64/i3-4.8-3.fc20.x86_64.rpm`. +Protip: copying this file to `~/i3.rpm` now will save you some typing in the +next step. + +Now in dom0, copy in the rpm: + + $ qvm-run --pass-io 'cat ' > i3.rpm + +Now that the rpm is in dom0 we can proceed with installing it. i3 has some +dependencies that we can easily install with: + + $ sudo qubes-dom0-update perl-AnyEvent-I3 xorg-x11-apps \\ + rxvt-unicode xcb-util-wm perl-JSON-XS xcb-util-cursor \\ + dzen2 dmenu xorg-x11-fonts-misc libev + +After that you can just install the generated rpm like any other local package: + + $ sudo yum localinstall i3.rpm + +Log out, select i3, then log in again. diff --git a/customization-guides/kde.md b/customization-guides/kde.md new file mode 100644 index 0000000..bdc5492 --- /dev/null +++ b/customization-guides/kde.md @@ -0,0 +1,88 @@ +--- +layout: doc +title: KDE +permalink: /doc/kde/ +redirect_from: /en/doc/kde/ +--- + +Using KDE in dom0 +================= + +Installation +------------ + +Prior to R3.2, KDE was the default desktop environment in Qubes. Beginning with +R3.2, however, [XFCE is the new default desktop environment](/doc/releases/3.2/release-notes/). Nonetheless, it is +still possible to install KDE by issuing this command in dom0: + + $ sudo qubes-dom0-update @kde-desktop-qubes + +You can also change your default login manager (lightdm) to the new KDE default: sddm + + * first you need to edit the `/etc/sddm.conf` to make sure if the custom X parameter is set according to Qubes needs: + +~~~ + [XDisplay] + ServerArguments=-nolisten tcp -background none +~~~ + + * disable the lightdm service: + +~~~ + $ sudo systemctl disable lightdm +~~~ + + * enable the sddm service: + +~~~ + $ sudo systemctl enable sddm +~~~ + + * reboot + +If you encounter performance issues with KDE, try switching back to LightDM. + +Window Management +----------------- + +You can set each window's position and size like this: + +~~~ +Right click title bar --> More actions --> Special window settings... + + Window matching tab + Window class (application): Exact Match: + Window title: Substring Match: + + Size & Position tab + [x] Position: Apply Initially: x,y + [x] Size: Apply Initially: x,y +~~~ + +You can also use `kstart` to control virtual desktop placement like this: + +~~~ + kstart --desktop 3 --windowclass -q --tray -a '' +~~~ + +(Replace "3" with whichever virtual desktop you want the window to be +on.) + +This can be useful for creating a simple shell script which will set up your +workspace the way you like. + +Removal +------------ + +If you decide to remove KDE do **not** use `dnf remove @kde-desktop-qubes`. You will almost certainly break your system. + +The safest way to remove (most of) KDE is: +~~~ +sudo dnf remove kdelibs,plasma-workspace +~~~ + + +Mailing List Threads +-------------------- + + * [Nalu's KDE customization thread](https://groups.google.com/d/topic/qubes-users/KhfzF19NG1s/discussion) diff --git a/customization-guides/language-localization.md b/customization-guides/language-localization.md new file mode 100644 index 0000000..79c2255 --- /dev/null +++ b/customization-guides/language-localization.md @@ -0,0 +1,46 @@ +--- +layout: doc +title: Language Localization +permalink: /doc/language-localization/ +redirect_from: +- /en/doc/language-localization/ +- /doc/LanguageLocalization/ +- /wiki/LanguageLocalization/ +--- + +Language Localization +===================== + +How to set up pinyin input in Qubes +----------------------------------- + +The pinyin input method will be installed in a TemplateVM to make it available after restarts and across multiple AppVMs. + +1. In a TemplateVM, install `ibus-pinyin` via the package manager or terminal. + If the template is Fedora-based, run `sudo dnf install ibus-pinyin`. + If the template is Debian-based, run `sudo apt install ibus-pinyin` + +2. Shut down the TemplateVM. + +3. Start or restart an AppVM based on the template in which you installed `ibus-pinyin` and open a terminal. + +4. Run `ibus-setup`. + +5. You will likely get an error message telling you to paste the following into your bashrc: + + export GTK_IM_MODULE=ibus + export XMODIFIERS=@im=ibus + export QT_IM_MODULE=ibus + + Copy the text into your `~/.bashrc` file with your favorite text editor. + You will need to do this for any AppVM in which you wish to use pinyin input. + +6. Set up ibus input as you like using the graphical menu (add pinyin or intelligent pinyin to selections). + You can bring the menu back by issuing `ibus-setup` from a terminal. + +7. Set up your shortcut for switching between inputs. + By default it is super-space. + +If `ibus-pinyin` is not enabled when you restart one of these AppVMs, open a terminal and run `ibus-setup` to activate ibus again. + +For further discussion, see [this qubes-users thread](https://groups.google.com/forum/#!searchin/qubes-users/languge/qubes-users/VcNPlhdgVQM/iF9PqSzayacJ). diff --git a/customization-guides/removing-templatevm-packages.md b/customization-guides/removing-templatevm-packages.md new file mode 100644 index 0000000..ddb61f3 --- /dev/null +++ b/customization-guides/removing-templatevm-packages.md @@ -0,0 +1,93 @@ +--- +layout: doc +title: Removing TemplateVM Packages +permalink: /doc/removing-templatevm-packages/ +--- + +# Removing TemplateVM Packages +When removing any packages from a default TemplateVM, be sure to check what's being removed by `apt autoremove` or `dnf`. +When removing certain packages, for instance Thunderbird, `apt` and `dnf` will attempt to remove many packages required by qubes for the template to function correctly under qubes. + +As an example from a terminal in a TemplateVM: +```shell_session +$ sudo apt remove thunderbird +Reading package lists... Done +Building dependency tree +Reading state information... Done +The following packages were automatically installed and are no longer required: + debugedit libjs-sphinxdoc libjs-underscore librpm3 librpmbuild3 librpmio3 + librpmsign3 libsqlite0 linux-headers-4.9.0-6-amd64 + linux-headers-4.9.0-6-common linux-image-4.9.0-6-amd64 python-backports-abc + python-cffi-backend python-concurrent.futures python-croniter + python-cryptography python-dateutil python-enum34 python-idna + python-iniparse python-ipaddress python-jinja2 python-libxml2 python-lzma + python-markupsafe python-msgpack python-openssl python-pyasn1 python-pycurl + python-requests python-rpm python-singledispatch python-six python-sqlite + python-sqlitecachec python-tornado python-tz python-urlgrabber + python-urllib3 python-xpyb python-yaml qubes-core-agent-dom0-updates + qubes-core-agent-passwordless-root qubes-gpg-split qubes-img-converter + qubes-input-proxy-sender qubes-mgmt-salt-vm-connector qubes-pdf-converter + qubes-usb-proxy rpm rpm-common rpm2cpio salt-common salt-ssh usbutils yum + yum-utils +Use 'sudo apt autoremove' to remove them. +The following packages will be REMOVED: + icedove lightning qubes-thunderbird qubes-vm-recommended thunderbird +0 upgraded, 0 newly installed, 5 to remove and 0 not upgraded. +After this operation, 151 MB disk space will be freed. +Do you want to continue? [Y/n] +``` + +Note all of the qubes packages are tracked as dependencies that will no longer be required. `apt remove` will only remove the packages listed, which is ok. +If, however you also run `apt autoremove` the other qubes packages necessary for TemplateVMs will be removed. + +If you'd still like to remove one of these applications without breaking your TemplateVM you have a couple different options. + +## Removing Only Packages Not Needed for a Qubes TemplateVM + +### Debian + 1. In your TemplateVM terminal run: + ```shell_session $ apt remove package-name``` + Note the packages "no longer required" + 2. If the list of "no longer required" packages includes anything beginning with `qubes-` or `salt-` make a note to yourself to **never** run `$ sudo apt autoremove` on this TemplateVM + +**Recommended but optional:** Use `apt-mark` to make `apt autoremove` safe again. +```shell_session +$ sudo apt mark-manual package-name package-name +``` + +Replace package-names with actual `qubes-*` and `salt-*` packages you'd like to retain. + +For example, still in your TemplateVM terminal: +```shell_session +$ sudo apt-mark manual qubes-core-agent-dom0-updates qubes-core-agent-passwordless-root qubes-gpg-split qubes-img-converter qubes-input-proxy-sender qubes-mgmt-salt-vm-connector qubes-pdf-converter salt-common salt-ssh qubes-usb-proxy +``` + +`$ apt autoremove` should now be safe to use. + +### Fedora +In your TemplateVM terminal, run: +```shell_session +$ dnf remove --noautoremove package-name +``` + + +## Recovering A TemplateVM which you've already removed needed qubes-* packages +If you've already removed packages, run `apt autoremove` and restarted your VM you've lost passwordless sudo access. +You can login as root, open a terminal in dom0 and run: +```shell_session +$ qvm-run -u root vmname xterm +``` +This will open an xterm terminal in the TemplateVM named `vmname` + +Once you're logged in as root, reinstall these packages & their dependencies: + +### Debian +```shell_session +$ sudo apt install qubes-core-agent-dom0-updates qubes-core-agent-passwordless-root qubes-gpg-split qubes-img-converter qubes-input-proxy-sender qubes-mgmt-salt-vm-connector qubes-pdf-converter salt-common salt-ssh +``` + +### Fedora +Similar to Debian for example (package names may vary): +```shell_session +$ sudo dnf install qubes-core-agent-dom0-updates qubes-core-agent-passwordless-root qubes-gpg-split qubes-img-converter qubes-input-proxy-sender qubes-mgmt-salt-vm-connector qubes-pdf-converter salt-common salt-ssh +``` diff --git a/customization-guides/windows-template-customization.md b/customization-guides/windows-template-customization.md new file mode 100644 index 0000000..ecaffa2 --- /dev/null +++ b/customization-guides/windows-template-customization.md @@ -0,0 +1,168 @@ +--- +layout: doc +title: Windows Template Customization +permalink: /doc/windows-template-customization/ +redirect_from: /en/doc/windows-template-customization/ +--- + +Disable/Uninstall unnecessary features/services +============================= + +Windows features +---------------------------- + +Uninstall windows features from Control Panel > Turn windows features On/Off. + +Generally, it will be required to reboot after features are uninstalled. + +If you do not manage to uninstall some features, it is sometimes necessary to uninstall them one by one or two by two. + +Only keep: + + * Print and Document Service => Internet Printing Client + * Print and Document Service => Windows Fax and Scan (apparently it cannot be uninstalled) + * Windows search + +*Note*: Windows search is recommended because it is a nightmare to find something in menus if it is not enabled (it removes the search bar from the start menu, from the explorer, and from the control panel). + +*Note*: Unselecting windows media, .Net and Internet Explorer will uninstall these components. On a new install they are generally old versions anyway and it will be quicker to install directly the new versions later. + +Windows services +--------------------------- + +Disable the following services that are not required or have no sense in a VM context: + + * Base Filtering Engine (only required if you want to use Microsoft IPSEC) + * DHCP Client + * Function Discovery Provider Host + + this will not work anyway because SSDP discovery uses multicast - need to be on the same network which is not the case because of Qubes firewall + * Peer Name Resolution Protocol + * Peer Netwoking Grouping + * Peer Networking Identity Manager + * SSDP Discovery + * Security Center (is it only notifications ?) + * TCP/IP Netbios Help (is Netbios still really used by Windows ? Maybe for discovery only ?) + * Themes (if you don't care about theme) + * Volume Shadow Copy (see next note in the performance section) + * Windows defender + * Windows Firewall + +*Notes*: IP Helper is required as it is used by Qubes Agent to configure the IP address. + +Windows update +-------------------------- + +I recommend disabling windows update (Never Check for Update) because checking for updates will start every time you start an AppVM if you haven't started your template in a while. + +Running windows update is also apparently IO hungry. + +Of course I recommend starting the template regularly and checking manually for updates. + +System properties +--------------------------- + +Right click on computer and go to Properties > Advanced > Performance: + + * If you don't care about visual effect, in Visual Effect select "Adjust for best performance" + * I personally tweak the page file size to gain some space on my root. + + In Advanced>Performances>Advanced tab, change Virtual memory: + + 1. unselect automatically manage paging file size for all drive + 2. click on drive C: + 3. select no paging file + 4. click on set + 5. click on drive d: + 6. select customer size + 7. use an initial size of 500 and a max size of 1000. If the page file is too small, you will notice a low memory pop up when working on windows. In this case, it often means that you should extend your AppVM RAM. + + * System Protection + + Here you can disable Shadow Folder because it has little sense in the case of Qubes because + + * we do regular backups of AppVMs/TemplateVMs; + * we can revert at least one template change if we break something. + + Select drives where system protection is enabled and click Configure. "Turn off system protection" "Delete all restore points" + + * Remote + + Unselect Allow Remote Assistance connections to this computer. + +Task scheduler +----------------------- + +Open the task scheduler and *disable* the following tasks. + +If you remove these tasks they may be recreated automatically by various windows management tools (such as defragmentation) + + * Autochk: All + * Application Experience: All + * Customer Experience Improvement Program: All + * Defrag: All + * DiskDiagnosis: All (the disk is virtual anyway so S.M.A.R.T. has no sense) + * Maintenance: All + * SystemRestore: All + * WindowsBackup: All + +Power options +------------- + +First, enable the "Power" Windows service. Then, set all of the following: + + * Put the computer to sleep: `Never` + * Turn the display off: `Never` + * Turn off hard disk after: Setting (Minutes): `0` + +Turn off hibernation. Open a command prompt (`cmd.exe`) as an administrator, +then execute: + + powercfg -h off + +The hibernation file (`C:\hyberfil.sys`) should now be deleted. + +Manual tasks that can/should be started in the template +------------------------------------------------------- + + * Disk defragmentation + + * Windows Update + + * Windows file cleaning + 1. Run windows drive cleaner as Administrator. + 2. Enable all the task and run the cleaner + + * CCleaner file cleaning + 1. Install CCleaner free + 2. Copy the attached ccleaner configuration file in CCleaner program file folder + 3. Run ccleaner with all option set except "wipe free space" (it will also remove user history and preferences) + 4. Run ccleaner only with the option "wipe free space". + + It will write zeros in all unused space. This will allow you to strip the root.img file later + + * TemplateVM stripping + + Ensure that you know what you are doing in this section as you may destroy by error your template root.img file. + + * If you ran ccleaner with "wipe free space", follow the following procedure + + 1. from dom0, go to /var/lib/templates-vm/yourtemplate + + 2. copy root.img using the following command + + > cp --sparse=always root.img root.img.clean + + 3. if the copy worked, you can move the new root file by running this command + + > mv root.img.clean root.img + + * If it doesn't manage to fill the free space with zeros, you can follow the following *unsafe* undocumented procedure + + 1. from dom0, go to /var/lib/templates-vm/yourtemplate + 2. check the partitioning to identify the filesystem offset of root.img + 3. mount the filesystem + 4. create a file with zeros inside the filesystem until the mounted filesystem is full + 5. remove the file + 6. unmount the partition + 7. make a copy of root.img in sparse mode. diff --git a/managing-os/archlinux.md b/managing-os/archlinux.md new file mode 100644 index 0000000..7cbcfb4 --- /dev/null +++ b/managing-os/archlinux.md @@ -0,0 +1,434 @@ +--- +layout: doc +title: Archlinux Template +permalink: /doc/templates/archlinux/ +redirect_from: +- /doc/archlinux/ +- /en/doc/templates/archlinux/ +- /doc/Templates/Archlinux/ +- /wiki/Templates/Archlinux/ +--- + +# Archlinux Template + +Archlinux template is one of the templates made by Qubes community. It should +be considered experimental as Qubes developers team use mainly Fedora-based VMs +to test new features/updates. + +Main maintainer of this template is [Olivier Médoc](mailto:o_medoc@yahoo.fr). + +Updates for this template are provided by [Olivier Médoc](mailto:o_medoc@yahoo.fr) and are signed by the following key: + + + pub 2048R/2043E7ACC1833B9C 2014-03-27 [expires: 2018-03-29] + Key fingerprint = D85E E12F 9678 51CC F433 515A 2043 E7AC C183 3B9C + uid Olivier MEDOC (Qubes-OS signing key) + +## Installation + +A prebuilt template is available only for Qubes 3.2. Before Qubes 3.2, it should be compiled from source as described in [building-archlinux-template](/doc/building-archlinux-template/). + + [user@dom0 ~]$ sudo qubes-dom0-update --enablerepo=qubes-templates-community qubes-template-archlinux + +## Binary packages activation + +The Qubes update repository is disabled by default in the Archlinux template. You can however choose to trust it by registering it into pacman. + +Since November 2017, an activation package is present in the template. The update repository can thus be activated by running the following command inside the template: + + # pacman -sU /etc/pacman.d/qubes-vm-keyring*.pkg.tar.xz + +It should be noted to this command will create a trust for packages provided by [Olivier Médoc](mailto:o_medoc@yahoo.fr) and signed by the PGP key above. + +If the qubes-vm-keyring package is not present in `/etc/pacman.d/`, please refer to the section #Activating binary packages manually. + +## Optional Qubes packages + +Several Qubes packages are not necessarily installed by default in the Archlinux Template. These packages can be installed to add additional functionnalities to the template: +* `qubes-vm-networking`: Contains Qubes tools and dependencies required to use the template as a NetVM/ProxyVM +* `qubes-vm-pulseaudio`: Contains `Pulseaudio` agent enabling sound support in the template + +## Default template packages + +In order to keep the template as small and simple as possible, default installed package have been arbitrarily selected based on multiple subjective criterias that however essentially include libraries dependencies. This packages are: +* Some font packages to keep good user experience +* leafpad: a note pad +* xfce4-terminal: a terminal +* thunar: a file browser that supports mounting usb keys +* firefox: web browser +* thunderbird: a mail browser +* evince: a document viewer + +Note that Archlinux does not install GUI packages by default as this decision is left to users. These packages have only been selected to have a usable template. + +## Activating binary packages manually + +Enable the repository by running the following command: + + # rm /etc/pacman.d/99-qubes-repository-3.2.conf + # ln -s /etc/pacman.d/99-qubes-repository-3.2.disabled /etc/pacman.d/99-qubes-repository-3.2.conf + +Then you need to install and sign the public GPG key of the package maintainer (note that accessing to GPG servers requires to temporarily disable the firewall in your template): + + # pacman-key --recv-key 2043E7ACC1833B9C + # pacman-key --finger 2043E7ACC1833B9C + +If the fingerprint is correct, you can then sign the key: + + # pacman-key --lsign-key 2043E7ACC1833B9C + +## Updating a Qubes-3.2 Archlinux Template + +Because of changes in the Qubes-4.0 partition layout, and usage of XEN HVMs instead of pv-guests. It is not straightforward to update a Qubes-3.2 template to Qubes-4.0. + +For this reason, it is recommended to start from a new template in Qubes-4.0. + +## Updating a Qubes-3.1 Archlinux Template + +If you decide to use binary packages but that you were using a Qubes-3.1 Template, you can follow these instructions to enable Qubes 3.2 agents. + +You can use a template that you built for Qubes 3.1 in Qubes 3.2. The qrexec and gui agent functionalities should still be working so that you can at least open a terminal. + +In order to enable binary packages for Qubes 3.2, add the following lines to the end of /etc/pacman.conf + +``` +[qubes-r3.2] +Server = http://olivier.medoc.free.fr/archlinux/current/ +``` + +You should then follow the instruction related to pacman-key in order to sign the binary packages PGP key. With the key enabled, a pacman update will update qubes agents: +` # pacman -Suy ` + +The two lines that have just been added to /etc/pacman.conf should then be removed as they have been included in the qubes-vm-core update in the file `/etc/pacmand.d/99-qubes-repository-3.2.conf` + +## Known Issues + +### Package cannot be updated because of errors related to xorg-server or pulseaudio versions + +The Qubes GUI agent must be rebuilt whenever xorg-server or pulseaudio make major changes. +If an update of one of these packages causes your template to break, simply [revert it](https://www.qubes-os.org/doc/software-update-vm/#reverting-changes-to-a-templatevm) and wait for corresponding Qubes package updates to be available (or attempt to build them yourself, if you're so inclined). +This should not happen frequently. + +### qubes-vm is apparently starting properly (green dot) however graphical applications do not appear to work + +They are multiple potential reasons. Some of them are described in the following issue: +* https://github.com/QubesOS/qubes-issues/issues/2612 + +In issue 2612, check that the option `noauto` is present for all lines in /etc/fstab related to /rw or /home. This bug can appear if you come from an old Archlinux Template (pre February 2017). + +## Debugging a broken VM + +In order to identify the issue, you should start by getting a console access to the VM: + +* Either by running in dom0 `qvm-run --pass-io --nogui yourbrokenvm 'your command here'` + +* Or by running in dom0 `sudo xl console yourbrokenvm` + +Start by trying to run a GUI application such as xfce4-terminal in order to identify any error message. + +Then you can check potential broken systemd service by running the following command inside the broken vm: `systemctl | grep fail`. + +If you identified a broken service check `journalctl -la -u yourbrokenservice`. If not check `journalctl -b` for errors. + +Finally, errors related to the GUI agent can be found inside the VM in `/home/user/.xsession-errors` + +## Packages manager wrapper + +Powerpill is a full Pacman wrapper that not only gives easy proxy configuration but further offers numerous other advantages. + +Please check out: + +[Archlinux Powerpill](https://wiki.archlinux.org/index.php/powerpill) + +[XYNE's (dev) Powerpill](http://xyne.archlinux.ca/projects/powerpill/) + + +**Important Note:** As you are working in a template vm, by default, you will have to open network access to the template to download files manually, except for managed packages which should be handled by the Qubes proxy. You can use the "allow full access for" a given time period in the FW settings of the template in the VMM or open up the various services through the same window. Remember to change it back if you choose the later route. Actions needing network access will be noted with (needs network access) + +
+
+ +##### **1: Editing Pacman's configuration file (pacman.conf)** ##### + +* Open archlinux terminal app + +* edit /etc/pacman.conf + +* **$ sudo nano -w /etc/pacman.conf** + +* Below is the output of a correct pacman.conf file Make the changes so your file matches this one or rename the original and create a new one and copy and paste this text into it. Text should be justified left in the file. The changes from your default are to make gpg signing mandatory for packages but not required for DBs for the archlinux repos. Also to add the repo (at the end) for the Powerpill package. + + +
+
+ + + # /etc/pacman.conf + # + # See the pacman.conf(5) manpage for option and repository directives + + # + # GENERAL OPTIONS + # + [options] + # The following paths are commented out with their default values listed. + # If you wish to use different paths, uncomment and update the paths. + # RootDir = / + # DBPath = /var/lib/pacman/ + # CacheDir = /var/cache/pacman/pkg/ + # LogFile = /var/log/pacman.log + GPGDir = /etc/pacman.d/gnupg/ + HoldPkg = pacman glibc + # XferCommand = /usr/bin/curl -C - -f %u > %o + # XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u + # CleanMethod = KeepInstalled + # UseDelta = 0.7 + Architecture = auto + + + # Pacman won't upgrade packages listed in IgnorePkg and members of IgnoreGroup + # IgnorePkg = + # IgnoreGroup = + # NoUpgrade = + NoUpgrade = /etc/X11/xinit/xinitrc.d/pulseaudio + NoUpgrade = /etc/X11/xinit/xinitrc.d/pulseaudio + NoUpgrade = /etc/X11/xinit/xinitrc.d/pulseaudio + # NoExtract = + + # Misc options + # UseSyslog + # Color + # TotalDownload + CheckSpace + # VerbosePkgLists + + # By default, pacman accepts packages signed by keys that its local keyring + # trusts (see pacman-key and its man page), as well as unsigned packages. + +**Edited Line:** `# SigLevel = Required DatabaseOptional` + + LocalFileSigLevel = Optional + # RemoteFileSigLevel = Required + + # NOTE: You must run `pacman-key --init` before first using pacman; the local + # keyring can then be populated with the keys of all official Arch Linux + # packagers with `pacman-key --populate archlinux`. + + # + # REPOSITORIES + # - can be defined here or included from another file + # - pacman will search repositories in the order defined here + # - local/custom mirrors can be added here or in separate files + # - repositories listed first will take precedence when packages + # have identical names, regardless of version number + # - URLs will have $repo replaced by the name of the current repo + # - URLs will have $arch replaced by the name of the architecture + # + # Repository entries are of the format: + # [repo-name] + # Server = ServerName + # Include = IncludePath + # + # The header [repo-name] is crucial - it must be present and + # uncommented to enable the repo. + # + + # The testing repositories are disabled by default. To enable, uncomment the + # repo name header and Include lines. You can add preferred servers immediately + # after the header, and they will be used before the default mirrors. + + # [testing] + # SigLevel = PackageRequired + # Include = /etc/pacman.d/mirrorlist + + [core] + +**Edited Line:** `SigLevel = PackageRequired` + + Include = /etc/pacman.d/mirrorlist + + [extra] + +**Edited Line:** `SigLevel = PackageRequired` + + Include = /etc/pacman.d/mirrorlist + + # [community-testing] + # SigLevel = PackageRequired + # Include = /etc/pacman.d/mirrorlist + + [community] + +**Edited Line:** `SigLevel = PackageRequired` + + Include = /etc/pacman.d/mirrorlist + + # If you want to run 32 bit applications on your x86_64 system, + # enable the multilib repositories as required here. + + # [multilib-testing] + # Include = /etc/pacman.d/mirrorlist + + # [multilib] + # Include = /etc/pacman.d/mirrorlist + + # An example of a custom package repository. See the pacman manpage for + # tips on creating your own repositories. + # [custom] + # SigLevel = Optional TrustAll + # Server = file:///home/custompkgs + + [multilib] + +**Edited Line:** `SigLevel = PackageRequired` + + Include = /etc/pacman.d/mirrorlist + +**Edited Line:** `# [qubes]` + +**Edited Line:** `# Server = http://olivier.medoc.free.fr/archlinux/pkgs/` + +**Add Section Below:** + + [xyne-x86_64] + # A repo for Xyne's own projects: http://xyne.archlinux.ca/projects/ + # Packages for the "x86_64" architecture. + # Added for PowerPill app + # Note that this includes all packages in [xyne-any]. + SigLevel = Required + Server = http://xyne.archlinux.ca/repos/xyne + +---------- + +
+ +##### **2: Setting Up GPG** (needs network access) ##### + +* Initialize GPG Keyring + + * **$ sudo pacman-key --init** + +* Populate the keyring with Archlinux master keys + + * **$ sudo pacman-key --populate archlinux** + + * Confirm keys with those at [Archlinux Master Keys](https://www.archlinux.org/master-keys/) + + * For more information on Pacman key signing: [Pacman Package Key Signing](https://wiki.archlinux.org/index.php/Pacman/Package_signing) + +
+
+ +##### **3: Install Powerpill (Pacman wrapper)** ##### + +* **$ sudo pacman -S powerpill** + +
+
+ +##### **4: Install Reflector** ##### + +*Note: It scripts mirror updating. Grabbing the most up to date gen mirror list. It ranks them by most recently sync'd. Then ranks them on fastest speed. Also can be used by Powerpill config to allow a once stop conf file for all if so wanted.* + +* **$ sudo pacman -S reflector** + + +Note: You can combine package downloads: **$ sudo pacman -S powerpill reflector** + +
+
+ +##### **5: Backup mirrorlist prior to first running Reflector.** ##### + +Note: For info on Reflector and its configs: [Reflector](https://wiki.archlinux.org/index.php/Reflector) + +* **$ sudo cp /etc/pacman.d/mirrorlist /etc/pacman.d/mirrorlist.bkup** + +
+
+ +##### **6: Setup mirrolist with Reflector** (needs network access)** ##### + +*Note: Look at the Reflector page to decide what filter and argument string you wish to run. Below is a default string that will work for most all to setup a working basic mirrorlist. + +*Look to Reflector pages or --help for more info on args and filters.* + +* **$ sudo reflector --verbose -l 5 --sort rate --save /etc/pacman.d/mirrorlist** + + * The above ranks all the most up to date and sorts for the 5 fastest + + * You can confirm the new list by opening the newly created mirrorlist. + +
+
+ + +##### **7: Configure Powerpill configuration file to use Qubes Proxy Service** ##### + +* Qubes Proxy Address: **10.137.255.254:8082** + +* Edit **powerpill.json** (powerpill config file) + + * **$ sudo nano -w /etc/powerpill/powerpill.json** + + * Add line '**--all-proxy=10.137.255.254:8082**' at the bottom of the list under the **"aria2"** section under the **"args"** line. Example below: + +
+ + { + "aria2": { + "args": [ + "--allow-overwrite=true", + "--always-resume=false", + "--auto-file-renaming=false", + "--check-integrity=true", + "--conditional-get=true", + "--continue=true", + "--file-allocation=none", + "--log-level=error", + "--max-concurrent-downloads=100", + "--max-connection-per-server=5", + "--min-split-size=5M", + "--remote-time=true", + "--show-console-readout=true", + "--all-proxy=10.137.255.254:8082" + ], + "path": "/usr/bin/aria2c" + }, + +
+
+ +##### **8: Test Powerpill Configuration** ##### + +*Note: Powerpill uses and passes the same syntax as pacman* + +* Configure Archlinux Template to only use the Qubes Proxy Update Service + * In the Qubes VM Manager under Archlinux FW tab make sure only the access check box for update proxy is on. All others should be set to deny. + +* **$ sudo powerpill -Syu** + + * You should get a similar output as below: + +
+
+![arch-template-26](/attachment/wiki/ArchlinuxTemplate/arch-template-26.png) +
+
+ + +**Remember you must open up network access anytime you wish to run the Reflector script to update the mirrorlist. This page will be updated when/if this situation changes.** + + +### **If the above checks out, you can start using your new Archlinux Template** ### + +
+
+ +## Want to contribute? + +* [How can I contribute to the Qubes Project?](/doc/contributing/) + +* [Guidelines for Documentation Contributors](/doc/doc-guidelines/) + +
diff --git a/managing-os/linux-hvm-tips.md b/managing-os/linux-hvm-tips.md new file mode 100644 index 0000000..c1c99fa --- /dev/null +++ b/managing-os/linux-hvm-tips.md @@ -0,0 +1,96 @@ +--- +layout: doc +title: Linux HVM Tips +permalink: /doc/linux-hvm-tips/ +redirect_from: +- /en/doc/linux-hvm-tips/ +- /doc/LinuxHVMTips/ +- /wiki/LinuxHVMTips/ +--- + +Tips for Linux in HVM domain +============================ + +How to fix bootup kernel error +------------------------------- + +The HVM may pause on boot, showing a fixed cursor. +After a while a series of warnings may be shown similar to this: + + BUG: soft lockup - CPU#0 stuck for 23s! [systemd-udevd:244] + +To fix this: + +1. Kill the HVM. +1. Start the HVM +1. Press "e" at the grub screen to edit the boot parameters +1. Find the /vmlinuz line, and edit it to replace "rhgb" with "modprobe.blacklist=bochs_drm" +1. Press "Ctrl-x" to start the HVM + +If this solves the problem then you will want to make the change permanent: + +1. Edit the file `/etc/default/grub`. +1. Find the line which starts: + ~~~ + GRUB_CMDLINE_LINUX= + ~~~ +1. Remove this text from that line: + ~~~ + rhgb + ~~~ +1. Add this text to that line: + ~~~ + modprobe.blacklist=bochs_drm + ~~~ +1. Run this command: + ~~~ + grub2-mkconfig --output=/boot/grub2/grub.cfg + ~~~ + +The HVM should now start normally. + + +Screen resolution +----------------- + +Some kernel/Xorg combinations use only 640x480 in HVM, which is quite small. +To enable maximum resolution, some changes in the Xorg configuration are needed: +1. Force "vesa" video driver +2. Provide wide horizontal synchronization range + +To achieve it (all commands to be run as root): + +1. Generate XOrg configuration (if you don't have it): + ~~~ + X -configure :1 && mv ~/xorg.conf.new /etc/X11/xorg.conf + ~~~ + +1. Add HorizSync line to Monitor section, it should look something like: + ~~~ + Section "Monitor" + Identifier "Monitor0" + VendorName "Monitor Vendor" + ModelName "Monitor Model" + HorizSync 30.0 - 60.0 + EndSection + ~~~ + +1. Change driver to "vesa" in Device section: + ~~~ + Section "Device" + # (...) + Identifier "Card0" + Driver "vesa" + VendorName "Technical Corp." + BoardName "Unknown Board" + BusID "PCI:0:2:0" + EndSection + ~~~ + +Now you should get resolution of at least 1280x1024 and should be able to choose other modes. + +Qubes agents +------------ + +Linux Qubes agents are written primarily for PV qubes, but it is possible to run them also in a HVM qube. +However some work may be required to achieve this. Check [this thread](https://groups.google.com/group/qubes-devel/browse_thread/thread/081df4a43e49e7a5). diff --git a/managing-os/netbsd.md b/managing-os/netbsd.md new file mode 100644 index 0000000..8b655ec --- /dev/null +++ b/managing-os/netbsd.md @@ -0,0 +1,23 @@ +--- +layout: doc +title: How to Create a NetBSD VM +permalink: /doc/netbsd/ +--- + +How to Create a NetBSD VM +========================= + +1. Create a StandaloneVM with the default template. +2. Replace `vmlinuz` with the `netbsd-INSTALL_XEN3_DOMU` kernel. +3. During setup, choose to install on the `xbd1` hard disk. +4. Attach the CD to the VM. +5. Configure the networking. +6. Optionally enable SSHD during the post-install configuration. +7. Replace the kernel with `netbsd-XEN3_DOMU`. +8. The VM may fail to boot automatically, in which case you must explicitly + specify `xbd1a` as the root device when prompted. + +For further discussion, please see this [thread] and this [guide]. + +[thread]: https://groups.google.com/group/qubes-devel/msg/4015c8900a813985 +[guide]: https://wiki.xen.org/wiki/How_to_install_a_NetBSD_PV_domU_on_a_Debian_Squeeze_host_%28Xen_4.0.1%29 diff --git a/managing-os/pentesting.md b/managing-os/pentesting.md new file mode 100644 index 0000000..56d7926 --- /dev/null +++ b/managing-os/pentesting.md @@ -0,0 +1,30 @@ +--- +layout: doc +title: Penetration Testing +permalink: /doc/pentesting/ +--- + +**Legal notice:** + +The usage of penetration testing tools outside your own laboratory environment requires the permission of the organization you attack. Penetration testing without permission can have legal consequences. + +To avoid such legal conflicts please refer to the [EC-Council: Code of Ethics](https://www.eccouncil.org/Support/code-of-ethics). + +Penetration Testing +=================== + +"A penetration test, colloquially known as a pen test, is an authorised simulated attack on a computer system that looks for security weaknesses, potentially gaining access to the system's features and data." (Source: [Wikipedia](https://en.wikipedia.org/wiki/Penetration_test)). + +Penetration Testing Distributions +--------------------------------- + +The following instructions explain how to install a penetration testing distribution within Qubes OS. + +- [BlackArch](/doc/pentesting/blackarch/) +- [Kali](/doc/pentesting/kali/) +- [PenTester Framework (PTF)](/doc/pentesting/ptf/) + +Using Qubes OS to host a "hacking" laboratory +--------------------------------------------- + +Qubes OS is a hypervisor based operating system. Qubes OS can host various operating systems such as Linux, Unix or Windows and run them in parallel. Qubes OS can therefore be used to host your own "hacking" laboratory. diff --git a/managing-os/pentesting/blackarch.md b/managing-os/pentesting/blackarch.md new file mode 100644 index 0000000..03fac39 --- /dev/null +++ b/managing-os/pentesting/blackarch.md @@ -0,0 +1,96 @@ +--- +layout: doc +title: How to Create a BlackArch VM +permalink: /doc/pentesting/blackarch/ +redirect_from: +- /doc/blackarch/ +--- + +**General reminder:** + +- The installation scripts and provided tools may have bugs, be vulnerable to Man in the Middle (MitM) attacks or other vulnerabilities. + +- Adding additional repositories or tools for installing software extends your trust to those tool providers. + +Please keep in mind that using such a VM or VMs based on the template for security and privacy critical tasks is not recommended. + +How to Create a BlackArch VM +============================ + +[BlackArch](https://www.blackarch.org) Linux is an [Arch Linux](https://www.archlinux.org)-based distribution for penetration testers and security researchers. The repository contains [1434](https://www.blackarch.org/tools.html) tools. + +- List of [tools](https://www.blackarch.org/tools.html) +- [Installation Instructions](https://www.blackarch.org/downloads.html) + +Create ArchLinux Based BlackArch Template +----------------------------------------- + +1. Create ArchlLinux Template + + - Follow the [Archlinux Template instructions](/doc/templates/archlinux/) + + +2. Update Template + + sudo pacman -Syyu + +3. Clone template + + 1. Via Qubes VM Manager + + 2. Via command line + + qvm-clone archlinux blackarch + +4. Install BlackArch repository + + $ curl -O https://blackarch.org/strap.sh + + # The SHA1 sum should match: 34b1a3698a4c971807fb1fe41463b9d25e1a4a09 + $ sha1sum strap.sh + + # Set execute bit + $ chmod +x strap.sh + + # Run strap.sh + $ sudo ./strap.sh + +5. Install tools + + - install all tools + + sudo pacman -S blackarch + + - or by category: + + # list available categories + pacman -Sg | grep blackarch + + # install category + sudo pacman -S blackarch- + + # example + sudo pacman -S blackarch-forensic + + - or specific tool + + # Search for tool + pacman -Ss + + # Install tool + sudo pacman -S + + # Example + pacman -Ss burpsuite + sudo pacman -S burpsuite + +6. Create a AppVMs based on the `blackarch` template + + - (Optional) Attach necessary devices + +Alternative Options to BlackArch +-------------------------------- + +- [Kali](/doc/pentesting/kali/) +- [PenTester Framework (PTF)](/doc/pentesting/ptf/) +- [Pentesting](/doc/pentesting/) diff --git a/managing-os/pentesting/kali.md b/managing-os/pentesting/kali.md new file mode 100644 index 0000000..08e0336 --- /dev/null +++ b/managing-os/pentesting/kali.md @@ -0,0 +1,616 @@ +--- +layout: doc +title: How to create a Kali Linux VM +permalink: /doc/pentesting/kali/ +redirect_from: +- /doc/kali/ +--- + +# How to create a Kali Linux VM + +## Warnings + +- The installation scripts and provided tools may have bugs, be vulnerable to Man in the Middle (MitM) attacks or other vulnerabilities. + +- Adding additional repositories or tools for installing software extends your trust to those tool providers. + +- Please keep in mind that using such a VM or VM's based on the template for security and privacy critical tasks is not recommended. + +- Kali Linux distribution is a rolling distribution based constantly on Debian testing release, so it always will have newer software base than available in Qubes OS debian template. Keep in mind that it may result in problems (especially in regard to package dependency) not covered by this tutorial. + + +## Qubes 3.2 + +### How to Create a Kali Linux VM + +This guide is being created to give guidance on ways in which you could create a [Kali Linux][kali] penetration testing VM (qube) in Qubes OS. + +Kali Linux is the most widely used penetration testing Linux distribution. + +There are multiple ways to create a Kali Linux VM: + + 1. Create a HVM and use the official ISO to install the system or convert a [Virtual Image][kali-vbox]. Explained [here](#hvm3_2). + 2. Clone the Qubes OS latest Debian template image and turn it into a Kali Linux distribution: + - using [katoolin]. Explained [here](#katoolin3_2). + - manually. Explained [here](#templatevm-from-debian3_2). + +### Kali Linux HVM + +1. Download the Kali installation DVD + +2. Create a new HVM + +3. Start the HVM with attached CD/DVD + + [user@dom0 ~]$ qvm-start --cdrom :/home/user/Downloads/.iso + +### Debian based Kali Template with Katoolin + +**Note:** The prompt on each line indicates where each command should be entered (`@dom0`, `@debian-` or `@kali`). + +1. (Optional) Check for latest Debian stable template and install it (if not already done) + + [user@dom0 ~]$ sudo qubes-dom0-update --action="search all" qubes-template-debian + [user@dom0 ~]$ sudo qubes-dom0-update + +2. Start, update and close your latest Debian template + + [user@dom0 ~]$ qvm-start debian- + [user@dom0 ~]$ qvm-run -a debian- gnome-terminal + [user@debian- ~]$ sudo apt-get update + [user@debian- ~]$ sudo apt-get upgrade + [user@dom0 ~]$ qvm-shutdown debian- + +3. Clone `debian-` template (two options) + + 1. Via Qubes VM Manager + + ![Clone Debian Template](/attachment/wiki/Kali/clone-kali.png) + + 2. Via command line + + [user@dom0 ~]$ qvm-clone debian- kali + +4. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly + + [user@kali ~]$ sudo sed -i 's///g' /etc/apt/sources.list + [user@kali ~]$ sudo sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list + + e.g. in this example we update `stretch` stable repository to `buster` testing repository + + [user@kali ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list + [user@kali ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list.d/qubes-r.list + +5. Upgrade `kali` template to latest Debian testing release + + [user@kali ~]$ sudo apt-get update + [user@kali ~]$ sudo apt-get dist-upgrade + [user@kali ~]$ sudo apt-get autoremove + + **Note:** During execution of a `dist-upgrade` command read carefully list of packages to be removed. + If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. + +6. Install Katoolin and add Kali Linux repositories + + 1. Install Katoolin + + [user@kali ~]$ sudo apt-get install git + [user@kali ~]$ git clone https://github.com/LionSec/katoolin.git + [user@kali ~]$ sudo cp katoolin/katoolin.py /usr/bin/katoolin + [user@kali ~]$ sudo chmod +x /usr/bin/katoolin + [user@kali ~]$ rm -rf katoolin + + 2. Add Kali Linux repositories + + - start katoolin + + [user@kali ~]$ sudo katoolin + + - select 'Add Kali repositories & Update' + + 1) Add Kali repositories & Update + 2) View Categories + 3) Install classicmenu indicator + 4) Install Kali menu + 5) Help + + kat > 1 + + ![Add Kali repositories and Update menu](/attachment/wiki/Kali/katoolin-add-update-repo-menu.png) + + - select 'Add kali linux repositories' + + 1) Add kali linux repositories + 2) Update + 3) Remove all kali linux repositories + 4) View the contents of sources.list file + + What do you want to do ?> 1 + + ![Add Kali repositories](/attachment/wiki/Kali/katoolin-add-repos-menu.png) + + - update Kali repositories + + + 1) Add kali linux repositories + 2) Update + 3) Remove all kali linux repositories + 4) View the contents of sources.list file + + What do you want to do ?> 2 + + - quit katoolin by pressing `CRTL` + `c` keys + + What do you want to do ?> ^CShutdown requested...Goodbye... + +7. Clean up and update `kali` template + + [user@kali ~]$ sudo apt-get dist-upgrade + [user@kali ~]$ sudo apt-get autoremove + +8. Shutdown and trim `kali` template + + - Shutdown `kali` template + + [user@kali ~]$ sudo shutdown -h now + + - In `dom0` console: + + [user@dom0 ~]$ qvm-trim-template kali + +9. Start image + + [user@dom0 ~]$ qvm-start kali + +10. Install tools + + **Note** [Resize the template disk image][qubes-resize-disk-image] to at least 20GB if you plan on installing all packages from Kali distribution. + + 1. View Categories + + - start katoolin + + [user@kali ~]$ sudo katoolin + + - select `2) View Categories` + + 2. Select the categories/tools you want to install + + - For more information on how to use Katoolin see [How to Auto Install All Kali Linux Tools Using “Katoolin” on Debian/Ubuntu][katoolin-howto]. + + - **Note:** The `all` option does not work for `Information Gathering`, `Web Apps`, `Forensic Tools`, `Reverse Engineering` and `Extra`. + +11. Create a AppVMs based on the `kali` template + + - (Optional) Attach necessary devices + +### Kali Linux TemplateVM from a Debian template + +This section will explain how to create your own [Kali] Linux TemplateVM based +on a current stable Debian TemplateVM. The basic idea is to personalize the +template with all the tools needed, and then spin up isolated AppVMs based on +the template. + +The steps can be summarised as: + +1. Install Qubes stable Debian template +2. Upgrade the template to Debian testing release +3. Install Kali Linux through the ``kali-linux-full`` package +4. Use the template to build AppVM so that you can maintain isolation between + e.g. pentesting jobs + +#### Get Kali Linux GPG key + +**CAUTION:** Before proceeding, please carefully read [On Digital Signatures and Key Verification][qubes-verifying-signatures]. +This website cannot guarantee that any PGP key you download from the Internet is authentic. +Always obtain a trusted key fingerprint via other channels, and always check any key you download against your trusted copy of the fingerprint. + +This step is required since by (security) default a TemplateVM do not have a +direct Internet connectivity. Users understanding the risks of enabling such +access can change this configuration in firewall settings for the TemplateVM. + +**Note:** The prompt on each line indicates where each command should be entered +(`@dom0`, `@kali-rolling`, `@xxxx-dvm` or `@debian-`). + +1. Retrive the Kali Linux GPG key using a DispVM. + + [user@xxxx-dvm ~]$ gpg --keyserver hkp://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 + [user@xxxx-dvm ~]$ gpg --list-keys --with-fingerprint 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 + [user@xxxx-dvm ~]$ gpg --export --armor 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 > kali-key.asc + +2. **DO NOT TURN OFF** the DispVM, the `kali-key.asc` file will be copied to + the Kali Linux template in a further step. + +3. Make sure the key is the authentic Kali key. + See the [Kali website] for further advice and instructions on verification. + +#### Create a Kali Linux (rolling) template + +These instructions will show you how to upgrade a Debian TemplateVM to Kali Linux. + +1. (Optional) Check for latest Debian stable template and install it (if not already done) + + [user@dom0 ~]$ sudo qubes-dom0-update --action="search all" qubes-template-debian + [user@dom0 ~]$ sudo qubes-dom0-update + +2. Start, update and close your latest Debian template + + [user@dom0 ~]$ qvm-start debian- + [user@dom0 ~]$ qvm-run -a debian- gnome-terminal + [user@debian- ~]$ sudo apt-get update + [user@debian- ~]$ sudo apt-get upgrade + [user@dom0 ~]$ qvm-shutdown debian- + +3. Clone `debian-X` template + + [user@dom0 ~]$ qvm-clone debian- kali-rolling + +4. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly + + [user@kali-rolling ~]$ sudo sed -i 's///g' /etc/apt/sources.list + [user@kali-rolling ~]$ sudo sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list + + e.g. in this example we update `stretch` stable repository to `buster` testing repository + + [user@kali-rolling ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list + [user@kali-rolling ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list.d/qubes-r.list + +5. Upgrade `kali-rolling` template to latest Debian testing release + + [user@kali-rolling ~]$ sudo apt-get update + [user@kali-rolling ~]$ sudo apt-get dist-upgrade + [user@kali-rolling ~]$ sudo apt-get autoremove + +**Note:** During execution of a `dist-upgrade` command read carefully list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. + +6. Copy the Kali GPG key from the DispVM to the new template: + + [user@xxxx-dvm ~]$ qvm-copy-to-vm kali-rolling kali-key.asc + + The DispVM can now be turned off. + +7. Add the Kali GPG key to the list of keys trusted to authenticate packages: + + [user@kali-rolling ~]$ cat /home/user/QubesIncoming/dispXXX/kali-key.asc | sudo apt-key add - + + This command should return `OK` on a line by itself. + +8. Attempt the upgrade process in the new template. + + [user@kali-rolling ~]$ sudo cat < /etc/apt/sources.list.d/kali.list + # Kali Linux repository + deb http://http.kali.org/kali kali-rolling main non-free contrib + EOF + [user@kali-rolling ~]$ sudo apt-get update + [user@kali-rolling ~]$ sudo apt-get dist-upgrade + [user@kali-rolling ~]$ sudo apt-get autoremove + +9. Shut down and trim the new template. + + [user@dom0 ~]$ qvm-shutdown kali-rolling + [user@dom0 ~]$ qvm-trim-template kali-rolling + +10. Ensure a terminal can be opened in the new template. + + [user@dom0 ~]$ qvm-run -a kali-rolling gnome-terminal + +#### Install the Kali tools + +At this point you should have a working template and you can install the tools you need. + +1. [Resize the template disk image][qubes-resize-disk-image] if you plan on installing the full Kali distribution. For example to install `kali-linux-full` you must **grow** the size of the VM system from 10GB to at least 20GB. + +2. Install Kali Linux tools: + + [user@kali-rolling ~]$ sudo apt-get install kali-linux-full + +3. (Optional) Customise the template's home directory (e.g. install your licensed copy of Burp Suite Professional) + +#### Use the template + +The template is ready to be used. You can now spin up AppVMs based on the `kali-rolling` template. + + +## Qubes 4.0 + +### How to Create a Kali Linux VM + +This guide is being created to give guidance on ways in which you could create a [Kali Linux][kali] penetration testing VM (qube) in Qubes OS. + +Kali Linux is the most widely used penetration testing Linux distribution. + +There are multiple ways to create a Kali Linux VM: + + 1. Create a HVM and use the official ISO to install the system or convert a [Virtual Image][kali-vbox]. Explained [here](#hvm4_0). + 2. Clone the Qubes OS latest Debian template image and turn it into a Kali Linux distribution: + - using [katoolin]. Explained [here](#katoolin4_0). + - manually. Explained [here](#templatevm-from-debian4_0). + +### Kali Linux HVM + +1. Download the Kali installation DVD + +2. Create a new HVM + +3. Start the HVM with attached CD/DVD + + [user@dom0 ~]$ qvm-start --cdrom :/home/user/Downloads/.iso + +### Debian based Kali Template with Katoolin + +**Note:** The prompt on each line indicates where each command should be entered (`@dom0`, `@debian-` or `@kali`). + +1. (Optional) Check for latest Debian stable template and install it (if not already done) + + [user@dom0 ~]$ sudo qubes-dom0-update --action="search all" qubes-template-debian + [user@dom0 ~]$ sudo qubes-dom0-update + +2. Start, update and close your latest Debian template + + [user@dom0 ~]$ qvm-start debian- + [user@dom0 ~]$ qvm-run -a debian- gnome-terminal + [user@debian- ~]$ sudo apt-get update + [user@debian- ~]$ sudo apt-get upgrade + [user@dom0 ~]$ qvm-shutdown debian- + +3. Clone `debian-` template (two options) + + 1. Via Qubes VM Manager + + ![Clone Debian Template](/attachment/wiki/Kali/clone-kali.png) + + 2. Via command line + + [user@dom0 ~]$ qvm-clone debian- kali + +4. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly. + + [user@kali ~]$ sudo sed -i 's///g' /etc/apt/sources.list + [user@kali ~]$ sudo sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list + + e.g. in this example we update `stretch` stable repository to `buster` testing repository + + [user@kali ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list + [user@kali ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list.d/qubes-r.list + +5. Upgrade `kali` template to latest Debian testing release + + [user@kali ~]$ sudo apt-get update + [user@kali ~]$ sudo apt-get dist-upgrade + [user@kali ~]$ sudo apt-get autoremove + + **Note:** During execution of a `dist-upgrade` command read carefully list of packages to be removed. + If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. + +6. Install Katoolin and add Kali Linux repositories + + 1. Install Katoolin + + [user@kali ~]$ sudo apt-get install git + [user@kali ~]$ git clone https://github.com/LionSec/katoolin.git + [user@kali ~]$ sudo cp katoolin/katoolin.py /usr/bin/katoolin + [user@kali ~]$ sudo chmod +x /usr/bin/katoolin + [user@kali ~]$ rm -rf katoolin + + 2. Add Kali Linux repositories + + - start katoolin + + [user@kali ~]$ sudo katoolin + + - select 'Add Kali repositories & Update' + + 1) Add Kali repositories & Update + 2) View Categories + 3) Install classicmenu indicator + 4) Install Kali menu + 5) Help + + kat > 1 + + ![Add Kali repositories and Update menu](/attachment/wiki/Kali/katoolin-add-update-repo-menu.png) + + - select 'Add kali linux repositories' + + 1) Add kali linux repositories + 2) Update + 3) Remove all kali linux repositories + 4) View the contents of sources.list file + + What do you want to do ?> 1 + + ![Add Kali repositories](/attachment/wiki/Kali/katoolin-add-repos-menu.png) + + - update Kali repositories + + + 1) Add kali linux repositories + 2) Update + 3) Remove all kali linux repositories + 4) View the contents of sources.list file + + What do you want to do ?> 2 + + - quit katoolin by pressing `CRTL` + `c` keys + + What do you want to do ?> ^CShutdown requested...Goodbye... + +7. Clean up and update `kali` template + + [user@kali ~]$ sudo apt-get dist-upgrade + [user@kali ~]$ sudo apt-get autoremove + +8. Install tools + + **Note** [Resize the template disk image][qubes-resize-disk-image] to at least 20GB if you plan on installing all packages from Kali distribution. + + 1. View Categories + + - start katoolin + + [user@kali ~]$ sudo katoolin + + - select `2) View Categories` + + 2. Select the categories/tools you want to install + + - For more information on how to use Katoolin see [How to Auto Install All Kali Linux Tools Using “Katoolin” on Debian/Ubuntu][katoolin-howto]. + + - **Note:** The `all` option does not work for `Information Gathering`, `Web Apps`, `Forensic Tools`, `Reverse Engineering` and `Extra`. + +9. Create a AppVMs based on the `kali` template + + - (Optional) Attach necessary devices + +### Kali Linux TemplateVM from a Debian template + +This section will explain how to create your own [Kali] Linux TemplateVM based +on a current stable Debian TemplateVM. The basic idea is to personalize the +template with all the tools needed, and then spin up isolated AppVMs based on +the template. + +The steps can be summarised as: + +1. Install Qubes stable Debian template +2. Upgrade the template to Debian testing release +3. Install Kali Linux through the ``kali-linux-full`` package +4. Use the template to build AppVM so that you can maintain isolation between + e.g. pentesting jobs + +#### Get Kali Linux GPG key + +**CAUTION:** Before proceeding, please carefully read [On Digital Signatures and Key Verification][qubes-verifying-signatures]. +This website cannot guarantee that any PGP key you download from the Internet is authentic. +Always obtain a trusted key fingerprint via other channels, and always check any key you download against your trusted copy of the fingerprint. + +This step is required since by (security) default a TemplateVM do not have a +direct Internet connectivity. Users understanding the risks of enabling such +access can change this configuration in firewall settings for the TemplateVM. + +**Note:** The prompt on each line indicates where each command should be entered +(`@dom0`, `@kali-rolling`, `@xxxx-dvm` or `@debian-`). + +1. Retrive the Kali Linux GPG key using a DispVM. + + [user@xxxx-dvm ~]$ gpg --keyserver hkp://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 + [user@xxxx-dvm ~]$ gpg --list-keys --with-fingerprint 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 + [user@xxxx-dvm ~]$ gpg --export --armor 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 > kali-key.asc + +2. **DO NOT TURN OFF** the DispVM, the `kali-key.asc` file will be copied to + the Kali Linux template in a further step. + +3. Make sure the key is the authentic Kali key. + See the [Kali website] for further advice and instructions on verification. + +#### Create a Kali Linux (rolling) template + +These instructions will show you how to upgrade a Debian TemplateVM to Kali Linux. + +1. (Optional) Check for latest Debian stable template and install it (if not already done) + + [user@dom0 ~]$ sudo qubes-dom0-update --action="search all" qubes-template-debian + [user@dom0 ~]$ sudo qubes-dom0-update + +2. Start, update and close your latest Debian template + + [user@dom0 ~]$ qvm-start debian- + [user@dom0 ~]$ qvm-run -a debian- gnome-terminal + [user@debian- ~]$ sudo apt-get update + [user@debian- ~]$ sudo apt-get upgrade + [user@dom0 ~]$ qvm-shutdown debian- + +3. Clone `debian-X` template + + [user@dom0 ~]$ qvm-clone debian- kali-rolling + +4. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly + + [user@kali-rolling ~]$ sudo sed -i 's///g' /etc/apt/sources.list + [user@kali-rolling ~]$ sudo sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list + + e.g. in this example we update `stretch` stable repository to `buster` testing repository + + [user@kali-rolling ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list + [user@kali-rolling ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list.d/qubes-r.list + +5. Upgrade `kali-rolling` template to latest Debian testing release + + [user@kali-rolling ~]$ sudo apt-get update + [user@kali-rolling ~]$ sudo apt-get dist-upgrade + [user@kali-rolling ~]$ sudo apt-get autoremove + +**Note:** During execution of a `dist-upgrade` command read carefully list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. + +6. Copy the Kali GPG key from the DispVM to the new template: + + [user@xxxx-dvm ~]$ qvm-copy kali-key.asc + + The DispVM can now be turned off. + +7. Add the Kali GPG key to the list of keys trusted to authenticate packages: + + [user@kali-rolling ~]$ cat /home/user/QubesIncoming/dispXXX/kali-key.asc | sudo apt-key add - + + This command should return `OK` on a line by itself. + +8. Attempt the upgrade process in the new template. + + [user@kali-rolling ~]$ sudo cat < /etc/apt/sources.list.d/kali.list + # Kali Linux repository + deb http://http.kali.org/kali kali-rolling main non-free contrib + EOF + [user@kali-rolling ~]$ sudo apt-get update + [user@kali-rolling ~]$ sudo apt-get dist-upgrade + [user@kali-rolling ~]$ sudo apt-get autoremove + +9. Ensure a terminal can be opened in the new template. + + [user@dom0 ~]$ qvm-run -a kali-rolling gnome-terminal + +#### Install the Kali tools + +At this point you should have a working template and you can install the tools you need. + +1. [Resize the template disk image][qubes-resize-disk-image] if you plan on installing the full Kali distribution. For example to install `kali-linux-full` you must **grow** the size of the VM system from 10GB to at least 20GB. + +2. Install Kali Linux tools: + + [user@kali-rolling ~]$ sudo apt-get install kali-linux-full + +3. (Optional) Customise the template's home directory (e.g. install your licensed copy of Burp Suite Professional) + +#### Use the template + +The template is ready to be used. You can now spin up AppVMs based on the `kali-rolling` template. + + +### Alternative Options to Kali Linux + + * [PenTester Framework][PTF], with [PTF Qubes OS guide][qubes-ptf] + * BlackArch Linux, with [BA Qubes OS guide][qubes-blackarch] + * [KATOOLIN][katoolin-howto] + * more on the [Penetration Testing page][qubes-pentesting] + + +## Notes + +Thanks to the people in [the discussion thread](https://github.com/QubesOS/qubes-issues/issues/1981). + +[qubes-verifying-signatures]: /security/verifying-signatures/ +[qubes-pentesting]: /doc/pentesting/ +[qubes-blackarch]: /doc/pentesting/blackarch/ +[qubes-ptf]: /doc/pentesting/ptf/ +[qubes-template-debian-install]: /doc/templates/debian/#install +[qubes-resize-disk-image]: /doc/resize-disk-image/ + +[kali]: https://www.kali.org/ +[kali-vbox]: https://www.offensive-security.com/kali-linux-vmware-virtualbox-image-download/ +[kali website]: https://docs.kali.org/introduction/download-official-kali-linux-images + +[PTF]: https://www.trustedsec.com/may-2015/new-tool-the-pentesters-framework-ptf-released/ + +[katoolin]: https://github.com/LionSec/katoolin +[katoolin-howto]: http://www.tecmint.com/install-kali-linux-tools-using-katoolin-on-ubuntu-debian/ + +[Debian-releases]: https://www.debian.org/releases/ + diff --git a/managing-os/pentesting/ptf.md b/managing-os/pentesting/ptf.md new file mode 100644 index 0000000..badc085 --- /dev/null +++ b/managing-os/pentesting/ptf.md @@ -0,0 +1,121 @@ +--- +layout: doc +title: How to create Penetration Testers Framework (PTF) VM +permalink: /doc/pentesting/ptf/ +redirect_from: +- /doc/ptf/ +--- + +**General reminder:** + +- The installation scripts and provided tools may have bugs, be vulnerable to Man in the Middle (MitM) attacks or other vulnerabilities. + +- Adding additional repositories or tools for installing software extends your trust to those tool providers. + +Please keep in mind that using such a VM or VM's based on the template for security and privacy critical tasks is not recommended. + +How to create Penetration Testers Framework (PTF) VM +==================================================== + +"The PenTesters Framework (PTF) is a Python script designed for Debian/Ubuntu/ArchLinux based distributions to create a similar and familiar distribution for Penetration Testing. + +PTF attempts to install all of your penetration testing tools (latest and greatest), compile them, build them, and make it so that you can install/update your distribution on any machine." (source [PTF Readme](https://github.com/trustedsec/ptf/blob/master/README.md)) + +**Note** PTF works on Debian testing as well as on Debian 8. PTF itself works with Debian 8, but the software tools will have missing dependencies. Metasploit for example requires a newer Ruby version than Debian 8 has in the repositories. Therefore the best way to install PTF is by upgrading a Debian 8 into Debian testing with additional Kali repositories. Instead of installing the tools from Kali, PTF will install and update the newest tools. + +Create Debian Based Penetration Testers Framework (PTF) Template +---------------------------------------------------------------- + +1. Create PTF template + + 1. Follow [Create Debian Based Kali Template](/doc/pentesting/kali/) till step 7. + + 2. (Optional) Rename the cloned template to `ptf` + +2. Download PTF + + sudo apt-get install git + cd /opt + sudo git clone https://github.com/trustedsec/ptf.git + + - (Optional) Configure PTF + + 1. Go to configuration directory + + cd /opt/ptf/config + + 2. Edit the configuration file + + for example by using vim: + + sudo vim ptf.config + + the configuration options are described in the `ptf.config` file + +3. Install PTF + + cd /opt/ptf + sudo ./ptf + + **Note:** the config file has to be in the same directory as the executable. It is not +possible to do sudo ptf/ptf + + PTF will put itself into `/usr/local/bin/ptf`. You can use `ptf` from now on. + +4. Install/Update modules (tools) + + 1. Start PTF + + sudo ptf + + ![PTF start banner](/attachment/wiki/PTF/ptf-banner.png) + + 2. Show available modules (tools) + + ptf> show modules + + 3. Install/Update modules (all/) + + - Install/Update all tools + + ptf> use modules/install_update_all + + - or by category Install/Update + + ptf> use modules/code-audit/install_update_all + + - or individually (example Metasploit) + + 1. Search for module + + ptf> search metasploit + [*] Search results below: + modules/exploitation/metasploit + + 2. Use module + + ptf> use modules/exploitation/metasploit + ptf:(modules/exploitation/metasploit)> + + 3. Install module + + ptf:(modules/exploitation/metasploit)>install + + 4. Run Metasploit + + ptf:(modules/exploitation/metasploit)>exit + ptf> quit + [*] Exiting PTF - the easy pentest platform creation framework. + sudo msfconsole + +5. Create an AppVM based on the `ptf` template + + - (Optional) Attach necessary devices + + +Alternative Options to PTF +-------------------------- + +- [BlackArch](/doc/pentesting/blackarch/) +- [Kali](/doc/pentesting/kali/) +- [Pentesting](/doc/pentesting/) diff --git a/managing-os/ubuntu.md b/managing-os/ubuntu.md new file mode 100644 index 0000000..91e9414 --- /dev/null +++ b/managing-os/ubuntu.md @@ -0,0 +1,41 @@ +--- +layout: doc +title: Ubuntu Template +permalink: /doc/templates/ubuntu/ +redirect_from: +- /doc/ubuntu/ +- /en/doc/templates/ubuntu/ +- /doc/Templates/Ubuntu/ +- /wiki/Templates/Ubuntu/ +--- + +Ubuntu template(s) +================== + +If you would like to use Ubuntu Linux distribution in your AppVMs, you can build and +install one of the available Ubuntu templates. These templates are currently not +available in ready to use binary packages, because Canonical does not allow +redistribution of a modified Ubuntu. The redistribution is not allowed by their +[Intellectual property rights policy](https://www.ubuntu.com/legal/terms-and-policies/intellectual-property-policy). + + +Install +------- + +It can be built using [Qubes Builder](/doc/qubes-builder/). You can also access its +documentation in the [source code +repository](https://github.com/QubesOS/qubes-builder/blob/master/README.md). + +To quickly prepare the builder configuration, you can use the `setup` script +available in the repository - it will interactively ask you which templates you +want to build. + +The build for Ubuntu 14.04 LTS (Trusty) should be straightforward. + +The build for Ubuntu 16.04 LTS (Xenial) is straightforward. Note that packages perl-Digest-MD5 and perl-Digest-SHA are required for the build to succeed. + + +---------- + +If you want to help in improving the template, feel free to +[contribute](/doc/contributing/). diff --git a/managing-os/windows/windows-tools.md b/managing-os/windows/windows-tools.md new file mode 100644 index 0000000..19aea38 --- /dev/null +++ b/managing-os/windows/windows-tools.md @@ -0,0 +1,158 @@ +--- +layout: doc +title: Qubes Windows Tools +permalink: /doc/windows-tools/ +redirect_from: +- /doc/windows-appvms/ +- /en/doc/windows-appvms/ +- /doc/WindowsAppVms/ +- /wiki/WindowsAppVms/ +--- + +Qubes Windows Tools +=================== + +Qubes Windows Tools are a set of programs and drivers that provide integration of Windows AppVMs with the rest of the Qubes system. Currently the following features are available for Windows VMs after installation of those tools: + +- Seamless GUI mode that integrates apps windows onto the common Qubes trusted desktop +- Support for [secure clipboard copy/paste](/doc/copy-paste/) between the Windows VM and other AppVMs +- Support for [secure file exchange](/doc/copying-files/) between the Windows VM and other AppVMs +- Support for qvm-run and generic qrexec for the Windows VM (e.g. ability to run custom service within/from the Windows VM) +- Xen PV drivers for Windows that increase performance compared to qemu emulated devices + +Qubes Windows Tools are open source and are distributed under a GPL license. + +NOTES: +- Qubes Windows Tools are currently unmaintained +- Currently only 64-bit versions of Windows 7 are supported by Qubes Windows Tools. Only emulated SVGA GPU is supported (although [there has been reports](https://groups.google.com/forum/#!topic/qubes-users/cmPRMOkxkdA) on working GPU passthrough). +- There is currently no audio support for Windows HVMs. +- There is currently no USB pass-through support for Windows HVMs. +- __This page documents the process of installing Qubes Windows Tools on versions up to R3.2.__. Installation on Qubes R4.0 is possible but is a work in progress and there are limitations/bugs (see [issue #3585](https://github.com/QubesOS/qubes-issues/issues/3585)). + + +Installing Windows OS in a Qubes VM +----------------------------------- + +Please refer to [this page](/doc/windows-vm/) for instructions on how to install Windows in a Qubes VM. + +NOTE: It is strongly suggested to enable autologon for any Windows HVMs that will have Qubes Tools installed. To do so, run `netplwiz` command from the `Win+R`/Start menu and uncheck the *Users must enter a user name and password to use this computer* option. + +Installing Qubes guest tools in Windows 7 VMs +--------------------------------------------- + +First, make sure that `qubes-windows-tools` is installed in your system: + +~~~ +sudo qubes-dom0-update qubes-windows-tools +~~~ + +(If the above command does not work, it could be that the Qubes Tools are not in the stable repo yet. Try installing from the testing repo instead.) + +You can also install the package from testing repositories, where we usually publish new versions first: + +~~~ +sudo qubes-dom0-update --enablerepo=qubes-dom0-current-testing qubes-windows-tools +~~~ + +This package brings the ISO with Qubes Windows Tools that is passed to the VM when `--install-windows-tools` is specified for the `qvm-start` command. Please note that none of this software ever runs in Dom0 or any other part of the system except for the Windows AppVM in which it is to be installed. + +Before proceeding with the installation we need to disable Windows mechanism that allows only signed drivers to be installed, because currently (beta releases) the drivers we provide as part of the Windows Tools are not digitally signed with a publicly recognizable certificate. To do that: + +- Start command prompt as Administrator, i.e. right click on the Command Prompt icon (All Programs -> Accessories) and choose "Run as administrator" +- In the command prompt type `bcdedit /set testsigning on` +- Reboot your Windows VM + +In the future this step will not be necessary anymore, because we will sign our drivers with a publicly verifiable certificate. However, it should be noted that even now, the fact that those drivers are not digitally signed, this doesn't affect security of the Windows VM in 'any' way. This is because the actual installation ISO (the `qubes-windows-tools-*.iso` file) is distributed as a signed RPM package and its signature is verified by the `qubes-dom0-update` utility once it's being installed in Dom0. The only downside of those drivers not being signed is the inconvenience to the user that he or she must disable the signature enforcement policy before installing the tools. + +To install the Qubes Windows Tools in a Windows VM one should start the VM passing the additional option `--install-windows-tools`: + +~~~ +qvm-start lab-win7 --install-windows-tools +~~~ + +Once the Windows VM boots, a CDROM should appear in the 'My Computer' menu (typically as `D:`) with a setup program in its main directory. + +After successful installation, the Windows VM must be shut down and started again, possibly a couple of times. + +Qubes will automatically detect the tools has been installed in the VM and will set appropriate properties for the VM, such as `qrexec_installed`, `guiagent_installed`, and `default_user`. This can be verified (but is not required) using qvm-prefs command: + +~~~ +qvm-prefs +~~~ + +NOTE: it is recommended to increase the default value of Windows VM's `qrexec_timeout` property from 60 (seconds) to, for example, 300. During one of the first reboots after Windows Tools installation Windows user profiles are moved onto the private VM's virtual disk (private.img) and this operation can take some time. Moving profiles is performed in an early boot phase when qrexec is not yet running, so timeout may occur with the default value. To change the property use this command in dom0: + +~~~ +qvm-prefs -s qrexec_timeout 300 +~~~ + +Using Windows AppVMs in seamless mode +------------------------------------- + +Once you start a Windows-based AppVM with Qubes Tools installed, you can easily start individual applications from the VM (note the `-a` switch used here, which will auto-start the VM if it is not running): + +~~~ +qvm-run -a my-win7-appvm explorer.exe +~~~ + +![windows-seamless-4.png](/attachment/wiki/WindowsAppVms/windows-seamless-4.png) ![windows-seamless-1.png](/attachment/wiki/WindowsAppVms/windows-seamless-1.png) + +Also, the inter-VM services work as usual -- e.g. to request opening a document or URL in the Windows AppVM from another VM: + +~~~ +[user@work ~]$ qvm-open-in-vm work-win7 roadmap.pptx +~~~ + +~~~ +[user@work ~]$ qvm-open-in-vm work-win7 https://invisiblethingslab.com +~~~ + +... just like in the case of Linux AppVMs. Of course all those operations are governed by central policy engine running in Dom0 -- if the policy doesn't contain explicit rules for the source and/or target AppVM, the user will be asked whether to allow or deny the operation. + +Inter-VM file copy and clipboard works for Windows AppVMs the same way as for Linux AppVM (except that we don't provide a command line wrapper, `qvm-copy-to-vm` in Windows VMs) -- to copy files from Windows AppVMs just right-click on the file in Explorer, and choose: Send To-\> Other AppVM. + +To simulate CTRL-ALT-DELETE in the HVM (SAS, Secure Attention Sequence), press Ctrl-Alt-Home while having any window of this VM in the foreground. + +![windows-seamless-7.png](/attachment/wiki/WindowsAppVms/windows-seamless-7.png) + +Changing between seamless and full desktop mode +----------------------------------------------- + +You can switch between seamless and "full desktop" mode for Windows HVMs in their settings in Qubes Manager. The latter is the default. + +Using template-based Windows AppVMs +----------------------------------- + +Qubes allows HVM VMs to share a common root filesystem from a select Template VM, just as for Linux AppVMs. This mode is not limited to Windows AppVMs, and can be used for any HVM (e.g. FreeBSD running in a HVM). + +In order to create a HVM TemplateVM one can use the following command, suitably adapted: + +~~~ +qvm-create --class TemplateVM win7-x64-template --property virt_mode=HVM --property kernel='' -l green +~~~ + +... , set memory as appropriate, and install Windows OS (or other OS) into this template the same way as you would install it into a normal HVM -- please see instructions on [this page](/doc/hvm-create/). + +If you use this Template as it is, then any HVMs that use it will effectively be DisposableVMs - the User directory will be wiped when the HVN is closed down. + +If you want to retain the User directory between reboots, then it would make sense to store the `C:\Users` directory on the 2nd disk which is automatically exposed by Qubes to all HVMs. +This 2nd disk is backed by the `private.img` file in the AppVMs' and is not reset upon AppVMs reboot, so the user's directories and profiles would survive the AppVMs reboot, unlike the "root" filesystem which will be reverted to the "golden image" from the Template VM automatically. +To facilitate such separation of user profiles, Qubes Windows Tools provide an option to automatically move `C:\Users` directory to the 2nd disk backed by `private.img`. +It's a selectable feature of the installer, enabled by default. +If that feature is selected during installation, completion of the process requires two reboots: + +- The private disk is initialized and formatted on the first reboot after tools installation. It can't be done **during** the installation because Xen mass storage drivers are not yet active. +- User profiles are moved to the private disk on the next reboot after the private disk is initialized. +Reboot is required because the "mover utility" runs very early in the boot process so OS can't yet lock any files in there. +This can take some time depending on the profiles' size and because the GUI agent is not yet active dom0/Qubes Manager may complain that the AppVM failed to boot. +That's a false alarm (you can increase AppVM's default boot timeout using `qvm-prefs`), the VM should appear "green" in Qubes Manager shortly after. + +It also makes sense to disable Automatic Updates for all the template-based AppVMs -- of course this should be done in the Template VM, not in individual AppVMs, because the system-wide settings are stored in the root filesystem (which holds the system-wide registry hives). +Then, periodically check for updates in the Template VM and the changes will be carried over to any child AppVMs. + +Once the template has been created and installed it is easy to create AppVMs based on it: + +~~~ +qvm-create --hvm --template --label - -1. Download the Kali installation DVD - -2. Create a new HVM - -3. Start the HVM with attached CD/DVD - - [user@dom0 ~]$ qvm-start --cdrom :/home/user/Downloads/.iso - -### Debian based Kali Template with Katoolin - -**Note:** The prompt on each line indicates where each command should be entered (`@dom0`, `@debian-` or `@kali`). - -1. (Optional) Check for latest Debian stable template and install it (if not already done) - - [user@dom0 ~]$ sudo qubes-dom0-update --action="search all" qubes-template-debian - [user@dom0 ~]$ sudo qubes-dom0-update - -2. Start, update and close your latest Debian template - - [user@dom0 ~]$ qvm-start debian- - [user@dom0 ~]$ qvm-run -a debian- gnome-terminal - [user@debian- ~]$ sudo apt-get update - [user@debian- ~]$ sudo apt-get upgrade - [user@dom0 ~]$ qvm-shutdown debian- - -3. Clone `debian-` template (two options) - - 1. Via Qubes VM Manager - - ![Clone Debian Template](/attachment/wiki/Kali/clone-kali.png) - - 2. Via command line - - [user@dom0 ~]$ qvm-clone debian- kali - -4. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly - - [user@kali ~]$ sudo sed -i 's///g' /etc/apt/sources.list - [user@kali ~]$ sudo sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list - - e.g. in this example we update `stretch` stable repository to `buster` testing repository - - [user@kali ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list - [user@kali ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list.d/qubes-r.list - -5. Upgrade `kali` template to latest Debian testing release - - [user@kali ~]$ sudo apt-get update - [user@kali ~]$ sudo apt-get dist-upgrade - [user@kali ~]$ sudo apt-get autoremove - - **Note:** During execution of a `dist-upgrade` command read carefully list of packages to be removed. - If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. - -6. Install Katoolin and add Kali Linux repositories - - 1. Install Katoolin - - [user@kali ~]$ sudo apt-get install git - [user@kali ~]$ git clone https://github.com/LionSec/katoolin.git - [user@kali ~]$ sudo cp katoolin/katoolin.py /usr/bin/katoolin - [user@kali ~]$ sudo chmod +x /usr/bin/katoolin - [user@kali ~]$ rm -rf katoolin - - 2. Add Kali Linux repositories - - - start katoolin - - [user@kali ~]$ sudo katoolin - - - select 'Add Kali repositories & Update' - - 1) Add Kali repositories & Update - 2) View Categories - 3) Install classicmenu indicator - 4) Install Kali menu - 5) Help - - kat > 1 - - ![Add Kali repositories and Update menu](/attachment/wiki/Kali/katoolin-add-update-repo-menu.png) - - - select 'Add kali linux repositories' - - 1) Add kali linux repositories - 2) Update - 3) Remove all kali linux repositories - 4) View the contents of sources.list file - - What do you want to do ?> 1 - - ![Add Kali repositories](/attachment/wiki/Kali/katoolin-add-repos-menu.png) - - - update Kali repositories - - - 1) Add kali linux repositories - 2) Update - 3) Remove all kali linux repositories - 4) View the contents of sources.list file - - What do you want to do ?> 2 - - - quit katoolin by pressing `CRTL` + `c` keys - - What do you want to do ?> ^CShutdown requested...Goodbye... - -7. Clean up and update `kali` template - - [user@kali ~]$ sudo apt-get dist-upgrade - [user@kali ~]$ sudo apt-get autoremove - -8. Shut down `kali` template - - [user@kali ~]$ sudo shutdown -h now - -9. Start image - - [user@dom0 ~]$ qvm-start kali - -10. Install tools - - **Note** [Resize the template disk image][qubes-resize-disk-image] to at least 20GB if you plan on installing all packages from Kali distribution. - - 1. View Categories - - - start katoolin - - [user@kali ~]$ sudo katoolin - - - select `2) View Categories` - - 2. Select the categories/tools you want to install - - - For more information on how to use Katoolin see [How to Auto Install All Kali Linux Tools Using “Katoolin” on Debian/Ubuntu][katoolin-howto]. - - - **Note:** The `all` option does not work for `Information Gathering`, `Web Apps`, `Forensic Tools`, `Reverse Engineering` and `Extra`. - -11. Create a AppVMs based on the `kali` template - - - (Optional) Attach necessary devices - -### Kali Linux TemplateVM from a Debian template - -This section will explain how to create your own [Kali] Linux TemplateVM based -on a current stable Debian TemplateVM. The basic idea is to personalize the -template with all the tools needed, and then spin up isolated AppVMs based on -the template. - -The steps can be summarised as: - -1. Install Qubes stable Debian template -2. Upgrade the template to Debian testing release -3. Install Kali Linux through the ``kali-linux-full`` package -4. Use the template to build AppVM so that you can maintain isolation between - e.g. pentesting jobs - -#### Get Kali Linux GPG key - -**CAUTION:** Before proceeding, please carefully read [On Digital Signatures and Key Verification][qubes-verifying-signatures]. -This website cannot guarantee that any PGP key you download from the Internet is authentic. -Always obtain a trusted key fingerprint via other channels, and always check any key you download against your trusted copy of the fingerprint. - -This step is required since by (security) default a TemplateVM do not have a -direct Internet connectivity. Users understanding the risks of enabling such -access can change this configuration in firewall settings for the TemplateVM. - -**Note:** The prompt on each line indicates where each command should be entered -(`@dom0`, `@kali-rolling`, `@xxxx-dvm` or `@debian-`). - -1. Retrive the Kali Linux GPG key using a DispVM. - - [user@xxxx-dvm ~]$ gpg --keyserver hkp://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 - [user@xxxx-dvm ~]$ gpg --list-keys --with-fingerprint 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 - [user@xxxx-dvm ~]$ gpg --export --armor 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 > kali-key.asc - -2. **DO NOT TURN OFF** the DispVM, the `kali-key.asc` file will be copied to - the Kali Linux template in a further step. - -3. Make sure the key is the authentic Kali key. - See the [Kali website] for further advice and instructions on verification. - -#### Create a Kali Linux (rolling) template - -These instructions will show you how to upgrade a Debian TemplateVM to Kali Linux. - -1. (Optional) Check for latest Debian stable template and install it (if not already done) - - [user@dom0 ~]$ sudo qubes-dom0-update --action="search all" qubes-template-debian - [user@dom0 ~]$ sudo qubes-dom0-update - -2. Start, update and close your latest Debian template - - [user@dom0 ~]$ qvm-start debian- - [user@dom0 ~]$ qvm-run -a debian- gnome-terminal - [user@debian- ~]$ sudo apt-get update - [user@debian- ~]$ sudo apt-get upgrade - [user@dom0 ~]$ qvm-shutdown debian- - -3. Clone `debian-X` template - - [user@dom0 ~]$ qvm-clone debian- kali-rolling - -4. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly - - [user@kali-rolling ~]$ sudo sed -i 's///g' /etc/apt/sources.list - [user@kali-rolling ~]$ sudo sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list - - e.g. in this example we update `stretch` stable repository to `buster` testing repository - - [user@kali-rolling ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list - [user@kali-rolling ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list.d/qubes-r.list - -5. Upgrade `kali-rolling` template to latest Debian testing release - - [user@kali-rolling ~]$ sudo apt-get update - [user@kali-rolling ~]$ sudo apt-get dist-upgrade - [user@kali-rolling ~]$ sudo apt-get autoremove - -**Note:** During execution of a `dist-upgrade` command read carefully list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. - -6. Copy the Kali GPG key from the DispVM to the new template: - - [user@xxxx-dvm ~]$ qvm-copy-to-vm kali-rolling kali-key.asc - - The DispVM can now be turned off. - -7. Add the Kali GPG key to the list of keys trusted to authenticate packages: - - [user@kali-rolling ~]$ cat /home/user/QubesIncoming/dispXXX/kali-key.asc | sudo apt-key add - - - This command should return `OK` on a line by itself. - -8. Attempt the upgrade process in the new template. - - [user@kali-rolling ~]$ sudo cat < /etc/apt/sources.list.d/kali.list - # Kali Linux repository - deb http://http.kali.org/kali kali-rolling main non-free contrib - EOF - [user@kali-rolling ~]$ sudo apt-get update - [user@kali-rolling ~]$ sudo apt-get dist-upgrade - [user@kali-rolling ~]$ sudo apt-get autoremove - -9. Shut down the new template. - - [user@dom0 ~]$ qvm-shutdown kali-rolling - -10. Ensure a terminal can be opened in the new template. - - [user@dom0 ~]$ qvm-run -a kali-rolling gnome-terminal - -#### Install the Kali tools - -At this point you should have a working template and you can install the tools you need. - -1. [Resize the template disk image][qubes-resize-disk-image] if you plan on installing the full Kali distribution. For example to install `kali-linux-full` you must **grow** the size of the VM system from 10GB to at least 20GB. - -2. Install Kali Linux tools: - - [user@kali-rolling ~]$ sudo apt-get install kali-linux-full - -3. (Optional) Customise the template's home directory (e.g. install your licensed copy of Burp Suite Professional) - -#### Use the template - -The template is ready to be used. You can now spin up AppVMs based on the `kali-rolling` template. - - ## Qubes 4.0 ### How to Create a Kali Linux VM @@ -327,137 +42,9 @@ There are multiple ways to create a Kali Linux VM: 3. Start the HVM with attached CD/DVD - [user@dom0 ~]$ qvm-start --cdrom :/home/user/Downloads/.iso - -### Debian based Kali Template with Katoolin - -**Note:** The prompt on each line indicates where each command should be entered (`@dom0`, `@debian-` or `@kali`). - -1. (Optional) Check for latest Debian stable template and install it (if not already done) - - [user@dom0 ~]$ sudo qubes-dom0-update --action="search all" qubes-template-debian - [user@dom0 ~]$ sudo qubes-dom0-update - -2. Start, update and close your latest Debian template - - [user@dom0 ~]$ qvm-start debian- - [user@dom0 ~]$ qvm-run -a debian- gnome-terminal - [user@debian- ~]$ sudo apt-get update - [user@debian- ~]$ sudo apt-get upgrade - [user@dom0 ~]$ qvm-shutdown debian- - -3. Clone `debian-` template (two options) - - 1. Via Qubes VM Manager - - ![Clone Debian Template](/attachment/wiki/Kali/clone-kali.png) - - 2. Via command line - - [user@dom0 ~]$ qvm-clone debian- kali - -4. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly. - - [user@kali ~]$ sudo sed -i 's///g' /etc/apt/sources.list - [user@kali ~]$ sudo sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list - - e.g. in this example we update `stretch` stable repository to `buster` testing repository - - [user@kali ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list - [user@kali ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list.d/qubes-r.list - -For installation based on Debian 10 stable, please note that the security repository of Debian testing has [recently been renamed][Debian-security-naming-convention] from `/update` to `-security`. To account for that change, execute the following command. - - [user@kali ~]$ sudo sed -i 's/bullseye\/updates/bullseye-security/g' /etc/apt/sources.list - -5. Upgrade `kali` template to latest Debian testing release - - [user@kali ~]$ sudo apt-get update - [user@kali ~]$ sudo apt-get dist-upgrade - [user@kali ~]$ sudo apt-get autoremove - - **Note:** During execution of a `dist-upgrade` command read carefully list of packages to be removed. - If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. - -6. Install Katoolin and add Kali Linux repositories - - 1. Install Katoolin - - [user@kali ~]$ sudo apt-get install git - [user@kali ~]$ git clone https://github.com/LionSec/katoolin.git - [user@kali ~]$ sudo cp katoolin/katoolin.py /usr/bin/katoolin - [user@kali ~]$ sudo chmod +x /usr/bin/katoolin - [user@kali ~]$ rm -rf katoolin - - 2. Add Kali Linux repositories - - - start katoolin - - [user@kali ~]$ sudo katoolin - - - select 'Add Kali repositories & Update' - - 1) Add Kali repositories & Update - 2) View Categories - 3) Install classicmenu indicator - 4) Install Kali menu - 5) Help - - kat > 1 - - ![Add Kali repositories and Update menu](/attachment/wiki/Kali/katoolin-add-update-repo-menu.png) - - - select 'Add kali linux repositories' - - 1) Add kali linux repositories - 2) Update - 3) Remove all kali linux repositories - 4) View the contents of sources.list file - - What do you want to do ?> 1 - - ![Add Kali repositories](/attachment/wiki/Kali/katoolin-add-repos-menu.png) - - - update Kali repositories - - - 1) Add kali linux repositories - 2) Update - 3) Remove all kali linux repositories - 4) View the contents of sources.list file - - What do you want to do ?> 2 - - - quit katoolin by pressing `CRTL` + `c` keys - - What do you want to do ?> ^CShutdown requested...Goodbye... - -7. Clean up and update `kali` template - - [user@kali ~]$ sudo apt-get dist-upgrade - [user@kali ~]$ sudo apt-get autoremove - -8. Install tools - - **Note** [Resize the template disk image][qubes-resize-disk-image] to at least 20GB if you plan on installing all packages from Kali distribution. - - 1. View Categories - - - start katoolin - - [user@kali ~]$ sudo katoolin - - - select `2) View Categories` - - 2. Select the categories/tools you want to install - - - For more information on how to use Katoolin see [How to Auto Install All Kali Linux Tools Using “Katoolin” on Debian/Ubuntu][katoolin-howto]. - - - **Note:** The `all` option does not work for `Information Gathering`, `Web Apps`, `Forensic Tools`, `Reverse Engineering` and `Extra`. - -9. Create a AppVMs based on the `kali` template - - - (Optional) Attach necessary devices +```shell_session +$ qvm-start --cdrom :/home/user/Downloads/.iso +``` ### Kali Linux TemplateVM from a Debian template @@ -470,9 +57,8 @@ The steps can be summarised as: 1. Install Qubes stable Debian template 2. Upgrade the template to Debian testing release -3. Install Kali Linux through the ``kali-linux-full`` package -4. Use the template to build AppVM so that you can maintain isolation between - e.g. pentesting jobs +3. Add the Kali repository +4. Update the template #### Get Kali Linux GPG key @@ -484,14 +70,13 @@ This step is required since by (security) default a TemplateVM do not have a direct Internet connectivity. Users understanding the risks of enabling such access can change this configuration in firewall settings for the TemplateVM. -**Note:** The prompt on each line indicates where each command should be entered -(`@dom0`, `@kali-rolling`, `@xxxx-dvm` or `@debian-`). - 1. Retrive the Kali Linux GPG key using a DispVM. - [user@xxxx-dvm ~]$ gpg --keyserver hkp://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 - [user@xxxx-dvm ~]$ gpg --list-keys --with-fingerprint 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 - [user@xxxx-dvm ~]$ gpg --export --armor 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 > kali-key.asc +```shell_session +$ gpg --keyserver hkp://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 +$ gpg --list-keys --with-fingerprint 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 +$ gpg --export --armor 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 > kali-key.asc +``` 2. **DO NOT TURN OFF** the DispVM, the `kali-key.asc` file will be copied to the Kali Linux template in a further step. @@ -505,85 +90,94 @@ These instructions will show you how to upgrade a Debian TemplateVM to Kali Linu 1. (Optional) Check for latest Debian stable template and install it (if not already done) - [user@dom0 ~]$ sudo qubes-dom0-update --action="search all" qubes-template-debian - [user@dom0 ~]$ sudo qubes-dom0-update +```shell_session +$ sudo qubes-dom0-update --action="search all" qubes-template-debian +$ sudo qubes-dom0-update +``` -2. Start, update and close your latest Debian template +2. Start your latest Debian template - [user@dom0 ~]$ qvm-start debian- - [user@dom0 ~]$ qvm-run -a debian- gnome-terminal - [user@debian- ~]$ sudo apt-get update - [user@debian- ~]$ sudo apt-get upgrade - [user@dom0 ~]$ qvm-shutdown debian- +```shell_session +$ qvm-start debian- +$ qvm-run -a debian- gnome-terminal +``` -3. Clone `debian-X` template +3. Update it - [user@dom0 ~]$ qvm-clone debian- kali-rolling +4. And then close it -4. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly +```shell_session +$ qvm-shutdown debian- +``` - [user@kali-rolling ~]$ sudo sed -i 's///g' /etc/apt/sources.list - [user@kali-rolling ~]$ sudo sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list - - e.g. in this example we update `stretch` stable repository to `buster` testing repository - - [user@kali-rolling ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list - [user@kali-rolling ~]$ sudo sed -i 's/stretch/buster/g' /etc/apt/sources.list.d/qubes-r.list +5. Clone `debian-X` template + +```shell_session +$ qvm-clone debian- kali-rolling +``` + +6. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly + +```shell_session +# sed -i 's///g' /etc/apt/sources.list +# sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list +``` + +e.g. in this example we update `buster` stable repository to `bullseye` testing repository + + +```shell_session +# sed -i 's/buster/bullseye/g' /etc/apt/sources.list +# sed -i 's/buster/bullseye/g' /etc/apt/sources.list.d/qubes-r.list +``` For installation based on Debian 10 stable, please note that the security repository of Debian testing has [recently been renamed][Debian-security-naming-convention] from `/update` to `-security`. To account for that change, execute the following command. - [user@kali ~]$ sudo sed -i 's/bullseye\/updates/bullseye-security/g' /etc/apt/sources.list +```shell_session +# sed -i 's/bullseye\/updates/bullseye-security/g' /etc/apt/sources.list +``` -5. Upgrade `kali-rolling` template to latest Debian testing release +5. Update the template - [user@kali-rolling ~]$ sudo apt-get update - [user@kali-rolling ~]$ sudo apt-get dist-upgrade - [user@kali-rolling ~]$ sudo apt-get autoremove - -**Note:** During execution of a `dist-upgrade` command read carefully list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. +**Note:** During execution of the update, read carefully list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. 6. Copy the Kali GPG key from the DispVM to the new template: - - [user@xxxx-dvm ~]$ qvm-copy kali-key.asc + +```shell_session +$ qvm-copy kali-key.asc +``` The DispVM can now be turned off. 7. Add the Kali GPG key to the list of keys trusted to authenticate packages: - [user@kali-rolling ~]$ cat /home/user/QubesIncoming/dispXXX/kali-key.asc | sudo apt-key add - +```shell_session +# cat /home/user/QubesIncoming/dispXXX/kali-key.asc | apt-key add - +``` This command should return `OK` on a line by itself. -8. Attempt the upgrade process in the new template. +8. Add the Kali repository - [user@kali-rolling ~]$ sudo cat < /etc/apt/sources.list.d/kali.list - # Kali Linux repository - deb http://http.kali.org/kali kali-rolling main non-free contrib - EOF - [user@kali-rolling ~]$ sudo apt-get update - [user@kali-rolling ~]$ sudo apt-get dist-upgrade - [user@kali-rolling ~]$ sudo apt-get autoremove +```shell_session +# cat < /etc/apt/sources.list.d/kali.list +# Kali Linux repository +deb https://http.kali.org/kali kali-rolling main non-free contrib +EOF +``` -9. Ensure a terminal can be opened in the new template. +9. Update the template - [user@dom0 ~]$ qvm-run -a kali-rolling gnome-terminal +10. Ensure a terminal can be opened in the new template. + +```shell_session +$ qvm-run -a kali-rolling gnome-terminal +``` #### Install the Kali tools At this point you should have a working template and you can install the tools you need. - -1. [Resize the template disk image][qubes-resize-disk-image] if you plan on installing the full Kali distribution. For example to install `kali-linux-full` you must **grow** the size of the VM system from 10GB to at least 20GB. - -2. Install Kali Linux tools: - - [user@kali-rolling ~]$ sudo apt-get install kali-linux-full - -3. (Optional) Customise the template's home directory (e.g. install your licensed copy of Burp Suite Professional) - -#### Use the template - -The template is ready to be used. You can now spin up AppVMs based on the `kali-rolling` template. - +Keep in mind that the tools you will install can easily take more than 10GB, [so you will need to **grow** the size of the VM1][qubes-resize-disk-image] ### Alternative Options to Kali Linux From a70c5bdb0a852a452f79e9a473f8921123b26223 Mon Sep 17 00:00:00 2001 From: Neowutran Date: Sun, 10 May 2020 10:09:53 +0200 Subject: [PATCH 061/136] [Kali] add positive and negative points for each methods --- os-guides/pentesting/kali.md | 90 ++++++++++++++---------------------- 1 file changed, 34 insertions(+), 56 deletions(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index cb182c5..940cf5d 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -6,52 +6,32 @@ redirect_from: - /doc/kali/ --- -# How to create a Kali Linux VM +How to create a Kali Linux VM +=============================== +Warnings +-------------- +* The installation scripts and provided tools may have bugs, be vulnerable to Man in the Middle (MitM) attacks or other vulnerabilities. +* Adding additional repositories or tools for installing software extends your trust to those tool providers. +* Please keep in mind that using such a VM or VM's based on the template for security and privacy critical tasks is not recommended. +* Kali Linux distribution is a rolling distribution based constantly on Debian testing release, so it always will have newer software base than available in Qubes OS debian template. Keep in mind that it may result in problems (especially in regard to package dependency) not covered by this tutorial. -## Warnings - -- The installation scripts and provided tools may have bugs, be vulnerable to Man in the Middle (MitM) attacks or other vulnerabilities. - -- Adding additional repositories or tools for installing software extends your trust to those tool providers. - -- Please keep in mind that using such a VM or VM's based on the template for security and privacy critical tasks is not recommended. - -- Kali Linux distribution is a rolling distribution based constantly on Debian testing release, so it always will have newer software base than available in Qubes OS debian template. Keep in mind that it may result in problems (especially in regard to package dependency) not covered by this tutorial. - - -## Qubes 4.0 - -### How to Create a Kali Linux VM - -This guide is being created to give guidance on ways in which you could create a [Kali Linux][kali] penetration testing VM (qube) in Qubes OS. - -Kali Linux is the most widely used penetration testing Linux distribution. - -There are multiple ways to create a Kali Linux VM: - - 1. Create a HVM and use the official ISO to install the system or convert a [Virtual Image][kali-vbox]. Explained [here](#hvm4_0). - 2. Clone the Qubes OS latest Debian template image and turn it into a Kali Linux distribution: - - using [katoolin]. Explained [here](#katoolin4_0). - - manually. Explained [here](#templatevm-from-debian4_0). - -### Kali Linux HVM +From the official ISO file +================================================== +Only use this method if you want to have the full Kali GUI (desktop, fancy menus, ...), it come at the cost of much greater resources consumption. 1. Download the Kali installation DVD - 2. Create a new HVM - 3. Start the HVM with attached CD/DVD - ```shell_session $ qvm-start --cdrom :/home/user/Downloads/.iso ``` -### Kali Linux TemplateVM from a Debian template +From a Debian template +================================================================ +This is the recommanded method. +Easier to maintain and less demanding on resources, but you won't have the full Kali GUI. -This section will explain how to create your own [Kali] Linux TemplateVM based -on a current stable Debian TemplateVM. The basic idea is to personalize the -template with all the tools needed, and then spin up isolated AppVMs based on -the template. +If you need to install custom kernel modules (wifi drivers, ...) you need use the kernel provided by Kali instead of the kernel provided by Qubes, see [Managing VM Kernel][managing-vm-kernel] The steps can be summarised as: @@ -60,8 +40,8 @@ The steps can be summarised as: 3. Add the Kali repository 4. Update the template -#### Get Kali Linux GPG key - +Get Kali Linux GPG key +----------------------- **CAUTION:** Before proceeding, please carefully read [On Digital Signatures and Key Verification][qubes-verifying-signatures]. This website cannot guarantee that any PGP key you download from the Internet is authentic. Always obtain a trusted key fingerprint via other channels, and always check any key you download against your trusted copy of the fingerprint. @@ -70,7 +50,7 @@ This step is required since by (security) default a TemplateVM do not have a direct Internet connectivity. Users understanding the risks of enabling such access can change this configuration in firewall settings for the TemplateVM. -1. Retrive the Kali Linux GPG key using a DispVM. +1. Retrive the Kali Linux GPG key using a DisposableVM. ```shell_session $ gpg --keyserver hkp://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 @@ -78,14 +58,14 @@ $ gpg --list-keys --with-fingerprint 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 $ gpg --export --armor 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 > kali-key.asc ``` -2. **DO NOT TURN OFF** the DispVM, the `kali-key.asc` file will be copied to +2. **DO NOT TURN OFF** the DisposableVM, the `kali-key.asc` file will be copied to the Kali Linux template in a further step. 3. Make sure the key is the authentic Kali key. See the [Kali website] for further advice and instructions on verification. -#### Create a Kali Linux (rolling) template - +Create a Kali Linux (rolling) template +---------------------------------------- These instructions will show you how to upgrade a Debian TemplateVM to Kali Linux. 1. (Optional) Check for latest Debian stable template and install it (if not already done) @@ -125,7 +105,6 @@ $ qvm-clone debian- kali-rolling e.g. in this example we update `buster` stable repository to `bullseye` testing repository - ```shell_session # sed -i 's/buster/bullseye/g' /etc/apt/sources.list # sed -i 's/buster/bullseye/g' /etc/apt/sources.list.d/qubes-r.list @@ -141,13 +120,13 @@ For installation based on Debian 10 stable, please note that the security reposi **Note:** During execution of the update, read carefully list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. -6. Copy the Kali GPG key from the DispVM to the new template: +6. Copy the Kali GPG key from the DisposableVM to the new template: ```shell_session $ qvm-copy kali-key.asc ``` - The DispVM can now be turned off. + The DisposableVM can now be turned off. 7. Add the Kali GPG key to the list of keys trusted to authenticate packages: @@ -174,21 +153,20 @@ EOF $ qvm-run -a kali-rolling gnome-terminal ``` -#### Install the Kali tools - +Install the Kali tools +------------------------------ At this point you should have a working template and you can install the tools you need. -Keep in mind that the tools you will install can easily take more than 10GB, [so you will need to **grow** the size of the VM1][qubes-resize-disk-image] +Keep in mind that the tools you will install can easily take more than 10GB, [so you will need to **grow** the size of the VM][qubes-resize-disk-image] -### Alternative Options to Kali Linux - - * [PenTester Framework][PTF], with [PTF Qubes OS guide][qubes-ptf] - * BlackArch Linux, with [BA Qubes OS guide][qubes-blackarch] - * [KATOOLIN][katoolin-howto] - * more on the [Penetration Testing page][qubes-pentesting] +Alternative Options to Kali Linux +=================================== +* [PenTester Framework][PTF], with [PTF Qubes OS guide][qubes-ptf] +* BlackArch Linux, with [BA Qubes OS guide][qubes-blackarch] +* more on the [Penetration Testing page][qubes-pentesting] -## Notes - +Notes +============= Thanks to the people in [the discussion thread](https://github.com/QubesOS/qubes-issues/issues/1981). [qubes-verifying-signatures]: /security/verifying-signatures/ From 5db1f5e92e17718aae4bda1f5dbf0d98f2b4837a Mon Sep 17 00:00:00 2001 From: Neowutran Date: Sun, 10 May 2020 10:14:13 +0200 Subject: [PATCH 062/136] [Kali] fix link --- os-guides/pentesting/kali.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index 940cf5d..dd86944 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -31,7 +31,7 @@ From a Debian template This is the recommanded method. Easier to maintain and less demanding on resources, but you won't have the full Kali GUI. -If you need to install custom kernel modules (wifi drivers, ...) you need use the kernel provided by Kali instead of the kernel provided by Qubes, see [Managing VM Kernel][managing-vm-kernel] +If you need to install custom kernel modules (wifi drivers, ...) you need use the kernel provided by Kali instead of the kernel provided by Qubes, see [Managing VM Kernel](/doc/managing-vm-kernel/) The steps can be summarised as: From aad19d12140c7cf966a3a0647cac577a511aa6a3 Mon Sep 17 00:00:00 2001 From: Neowutran Date: Sun, 10 May 2020 10:34:23 +0200 Subject: [PATCH 063/136] [Kali] fix typos --- os-guides/pentesting/kali.md | 39 ++++++++++++++++++------------------ 1 file changed, 20 insertions(+), 19 deletions(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index dd86944..3be86c8 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -12,14 +12,15 @@ Warnings -------------- * The installation scripts and provided tools may have bugs, be vulnerable to Man in the Middle (MitM) attacks or other vulnerabilities. * Adding additional repositories or tools for installing software extends your trust to those tool providers. -* Please keep in mind that using such a VM or VM's based on the template for security and privacy critical tasks is not recommended. -* Kali Linux distribution is a rolling distribution based constantly on Debian testing release, so it always will have newer software base than available in Qubes OS debian template. Keep in mind that it may result in problems (especially in regard to package dependency) not covered by this tutorial. +* Please keep in mind that using such template for security and privacy critical tasks is not recommended. +* Kali Linux distribution is a rolling distribution constantly based on Debian testing release, so it will always have a newer software base than available in Qubes OS Debian template. Keep in mind that it may result in problems (especially in regard to package dependency) not covered by this tutorial. From the official ISO file ================================================== -Only use this method if you want to have the full Kali GUI (desktop, fancy menus, ...), it come at the cost of much greater resources consumption. +Only use this method if you want the full Kali GUI (desktop, fancy menus, etc.). +It comes at the cost of much greater resources consumption. -1. Download the Kali installation DVD +1. Download the Kali ISO 2. Create a new HVM 3. Start the HVM with attached CD/DVD ```shell_session @@ -28,12 +29,12 @@ $ qvm-start --cdrom :/home/user/Downloads/.iso From a Debian template ================================================================ -This is the recommanded method. -Easier to maintain and less demanding on resources, but you won't have the full Kali GUI. +This is the recommended method. +Easier to maintain and less demanding on resources, but you won’t have the full Kali GUI. -If you need to install custom kernel modules (wifi drivers, ...) you need use the kernel provided by Kali instead of the kernel provided by Qubes, see [Managing VM Kernel](/doc/managing-vm-kernel/) +If you need to install custom kernel modules (wifi drivers, …) you need to use the kernel provided by Kali instead of the kernel provided by Qubes, see [Managing VM Kernel.](/doc/managing-vm-kernel/) -The steps can be summarised as: +The steps can be summarized as: 1. Install Qubes stable Debian template 2. Upgrade the template to Debian testing release @@ -43,14 +44,14 @@ The steps can be summarised as: Get Kali Linux GPG key ----------------------- **CAUTION:** Before proceeding, please carefully read [On Digital Signatures and Key Verification][qubes-verifying-signatures]. -This website cannot guarantee that any PGP key you download from the Internet is authentic. -Always obtain a trusted key fingerprint via other channels, and always check any key you download against your trusted copy of the fingerprint. +This website cannot guarantee that any GPG key you download from the Internet is authentic. +Always obtain a trusted key fingerprint via other channels, and always check key you download against your trusted copy of the fingerprint. -This step is required since by (security) default a TemplateVM do not have a +This step is required since by (security) default TemplateVM do not have a direct Internet connectivity. Users understanding the risks of enabling such access can change this configuration in firewall settings for the TemplateVM. -1. Retrive the Kali Linux GPG key using a DisposableVM. +1. Retrieve the Kali Linux GPG key using a DisposableVM. ```shell_session $ gpg --keyserver hkp://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 @@ -59,7 +60,7 @@ $ gpg --export --armor 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 > kali-key.asc ``` 2. **DO NOT TURN OFF** the DisposableVM, the `kali-key.asc` file will be copied to - the Kali Linux template in a further step. + the Kali Linux template for a further step. 3. Make sure the key is the authentic Kali key. See the [Kali website] for further advice and instructions on verification. @@ -68,11 +69,11 @@ Create a Kali Linux (rolling) template ---------------------------------------- These instructions will show you how to upgrade a Debian TemplateVM to Kali Linux. -1. (Optional) Check for latest Debian stable template and install it (if not already done) +1. (Optional) Check for latest Debian stable templates and install it (if not already done) ```shell_session -$ sudo qubes-dom0-update --action="search all" qubes-template-debian -$ sudo qubes-dom0-update +# qubes-dom0-update --action="search all" qubes-template-debian +# qubes-dom0-update ``` 2. Start your latest Debian template @@ -118,7 +119,7 @@ For installation based on Debian 10 stable, please note that the security reposi 5. Update the template -**Note:** During execution of the update, read carefully list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. +**Note:** During execution of the update, carefully read list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. 6. Copy the Kali GPG key from the DisposableVM to the new template: @@ -134,7 +135,7 @@ $ qvm-copy kali-key.asc # cat /home/user/QubesIncoming/dispXXX/kali-key.asc | apt-key add - ``` - This command should return `OK` on a line by itself. + This command should return: "`OK".` 8. Add the Kali repository @@ -156,7 +157,7 @@ $ qvm-run -a kali-rolling gnome-terminal Install the Kali tools ------------------------------ At this point you should have a working template and you can install the tools you need. -Keep in mind that the tools you will install can easily take more than 10GB, [so you will need to **grow** the size of the VM][qubes-resize-disk-image] +Keep in mind that the tools you will install can easily take more than 10 GB, [so you will need to **grow** the size of the VM.][qubes-resize-disk-image] Alternative Options to Kali Linux =================================== From c437bb245f67aecbc26bd18ced7204194c5cb1cb Mon Sep 17 00:00:00 2001 From: Neowutran Date: Sun, 10 May 2020 10:36:03 +0200 Subject: [PATCH 064/136] [Kali] fix typos --- os-guides/pentesting/kali.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index 3be86c8..0868321 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -135,7 +135,7 @@ $ qvm-copy kali-key.asc # cat /home/user/QubesIncoming/dispXXX/kali-key.asc | apt-key add - ``` - This command should return: "`OK".` + This command should return: `OK`. 8. Add the Kali repository From 0bd93308311e1b51b4f6aa1e5a78be219f966967 Mon Sep 17 00:00:00 2001 From: Neowutran Date: Tue, 19 May 2020 18:31:04 +0200 Subject: [PATCH 065/136] [Kali] minor fix --- os-guides/pentesting/kali.md | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index 0868321..d0ff945 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -12,8 +12,8 @@ Warnings -------------- * The installation scripts and provided tools may have bugs, be vulnerable to Man in the Middle (MitM) attacks or other vulnerabilities. * Adding additional repositories or tools for installing software extends your trust to those tool providers. -* Please keep in mind that using such template for security and privacy critical tasks is not recommended. -* Kali Linux distribution is a rolling distribution constantly based on Debian testing release, so it will always have a newer software base than available in Qubes OS Debian template. Keep in mind that it may result in problems (especially in regard to package dependency) not covered by this tutorial. +* Please keep in mind that using such a template for security and privacy critical tasks is not recommended. +* Kali Linux distribution is a rolling distribution based on Debian testing release, so it will always have a newer software base than available in the Qubes OS Debian template. Keep in mind that this may result in problems (especially in regard to package dependencies) not covered by this tutorial. From the official ISO file ================================================== @@ -41,17 +41,17 @@ The steps can be summarized as: 3. Add the Kali repository 4. Update the template -Get Kali Linux GPG key +Get Kali Linux PGP key ----------------------- **CAUTION:** Before proceeding, please carefully read [On Digital Signatures and Key Verification][qubes-verifying-signatures]. -This website cannot guarantee that any GPG key you download from the Internet is authentic. -Always obtain a trusted key fingerprint via other channels, and always check key you download against your trusted copy of the fingerprint. +This website cannot guarantee that any PGP key you download from the Internet is authentic. +Always obtain a trusted key fingerprint via other channels, and always check any key you download against your trusted copy of the fingerprint. This step is required since by (security) default TemplateVM do not have a direct Internet connectivity. Users understanding the risks of enabling such access can change this configuration in firewall settings for the TemplateVM. -1. Retrieve the Kali Linux GPG key using a DisposableVM. +1. Retrieve the Kali Linux PGP key using a DisposableVM. ```shell_session $ gpg --keyserver hkp://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 @@ -59,7 +59,7 @@ $ gpg --list-keys --with-fingerprint 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 $ gpg --export --armor 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 > kali-key.asc ``` -2. **DO NOT TURN OFF** the DisposableVM, the `kali-key.asc` file will be copied to +2. **DO NOT TURN OFF** the DisposableVM, the `kali-key.asc` file will be copied in the Kali Linux template for a further step. 3. Make sure the key is the authentic Kali key. @@ -69,14 +69,14 @@ Create a Kali Linux (rolling) template ---------------------------------------- These instructions will show you how to upgrade a Debian TemplateVM to Kali Linux. -1. (Optional) Check for latest Debian stable templates and install it (if not already done) +1. (Optional) Check for latest Debian stable template and install it (if not already done) ```shell_session # qubes-dom0-update --action="search all" qubes-template-debian # qubes-dom0-update ``` -2. Start your latest Debian template +2. Start your Debian template ```shell_session $ qvm-start debian- @@ -114,14 +114,14 @@ e.g. in this example we update `buster` stable repository to `bullseye` testing For installation based on Debian 10 stable, please note that the security repository of Debian testing has [recently been renamed][Debian-security-naming-convention] from `/update` to `-security`. To account for that change, execute the following command. ```shell_session -# sed -i 's/bullseye\/updates/bullseye-security/g' /etc/apt/sources.list +# sed -i 's%bullseye/updates%bullseye-security%g' /etc/apt/sources.list ``` 5. Update the template **Note:** During execution of the update, carefully read list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. -6. Copy the Kali GPG key from the DisposableVM to the new template: +6. Copy the Kali PGP key from the DisposableVM to the new template: ```shell_session $ qvm-copy kali-key.asc @@ -129,7 +129,7 @@ $ qvm-copy kali-key.asc The DisposableVM can now be turned off. -7. Add the Kali GPG key to the list of keys trusted to authenticate packages: +7. Add the Kali PGP key to the list of keys trusted to authenticate packages: ```shell_session # cat /home/user/QubesIncoming/dispXXX/kali-key.asc | apt-key add - @@ -157,7 +157,7 @@ $ qvm-run -a kali-rolling gnome-terminal Install the Kali tools ------------------------------ At this point you should have a working template and you can install the tools you need. -Keep in mind that the tools you will install can easily take more than 10 GB, [so you will need to **grow** the size of the VM.][qubes-resize-disk-image] +Keep in mind that the tools you will install can easily take more than 10 GB, [so you will need to **grow** the size of the VM system storage.][qubes-resize-disk-image] Alternative Options to Kali Linux =================================== From f6ab96ade4403a5699bc8c62552cc2bf17de1f40 Mon Sep 17 00:00:00 2001 From: Neowutran Date: Sat, 23 May 2020 19:29:04 +0200 Subject: [PATCH 066/136] [Kali] migitagion against dependency hell between Qubes repository and Kali repository --- os-guides/pentesting/kali.md | 56 +++++++++++------------------------- 1 file changed, 17 insertions(+), 39 deletions(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index d0ff945..b74af7b 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -37,7 +37,7 @@ If you need to install custom kernel modules (wifi drivers, …) you need to use The steps can be summarized as: 1. Install Qubes stable Debian template -2. Upgrade the template to Debian testing release +2. Add `testing` and `securitytesting` Qubes repositories 3. Add the Kali repository 4. Update the template @@ -45,7 +45,8 @@ Get Kali Linux PGP key ----------------------- **CAUTION:** Before proceeding, please carefully read [On Digital Signatures and Key Verification][qubes-verifying-signatures]. This website cannot guarantee that any PGP key you download from the Internet is authentic. -Always obtain a trusted key fingerprint via other channels, and always check any key you download against your trusted copy of the fingerprint. +In order to obtain a trusted fingerprint, check its value against multiple sources. +Then, check the keys you download against your trusted fingerprint. This step is required since by (security) default TemplateVM do not have a direct Internet connectivity. Users understanding the risks of enabling such @@ -54,7 +55,7 @@ access can change this configuration in firewall settings for the TemplateVM. 1. Retrieve the Kali Linux PGP key using a DisposableVM. ```shell_session -$ gpg --keyserver hkp://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 +$ gpg --keyserver hkps://keys.gnupg.net --recv-key 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 $ gpg --list-keys --with-fingerprint 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 $ gpg --export --armor 44C6513A8E4FB3D30875F758ED444FF07D8D0BF6 > kali-key.asc ``` @@ -76,52 +77,30 @@ These instructions will show you how to upgrade a Debian TemplateVM to Kali Linu # qubes-dom0-update ``` -2. Start your Debian template - -```shell_session -$ qvm-start debian- -$ qvm-run -a debian- gnome-terminal -``` - -3. Update it - -4. And then close it - -```shell_session -$ qvm-shutdown debian- -``` - -5. Clone `debian-X` template +2. Clone `debian-X` template ```shell_session $ qvm-clone debian- kali-rolling ``` -6. Check the name of currently used repository in `/etc/apt/sources.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly +3. Check the name of currently used repository in `/etc/apt/sources.list.d/qubes-r.list` and current testing [Debian release][Debian-releases]. Update repository list accordingly ```shell_session -# sed -i 's///g' /etc/apt/sources.list # sed -i 's///g' /etc/apt/sources.list.d/qubes-r.list ``` e.g. in this example we update `buster` stable repository to `bullseye` testing repository ```shell_session -# sed -i 's/buster/bullseye/g' /etc/apt/sources.list # sed -i 's/buster/bullseye/g' /etc/apt/sources.list.d/qubes-r.list ``` - -For installation based on Debian 10 stable, please note that the security repository of Debian testing has [recently been renamed][Debian-security-naming-convention] from `/update` to `-security`. To account for that change, execute the following command. -```shell_session -# sed -i 's%bullseye/updates%bullseye-security%g' /etc/apt/sources.list -``` +4. Enable the QubesOS `testing` and `securitytesting` repositories -5. Update the template +In `/etc/apt/sources.list.d/qubes-r.list`, enable the 'testing' and 'securitytesting' repository. +We do that to reduce the 'dependency hell' between Qubes repository and Kali repository. -**Note:** During execution of the update, carefully read list of packages to be removed. If it contains `qubes-*` packages, terminate operation and try to resolve `qubes-*` packages missing dependencies first. - -6. Copy the Kali PGP key from the DisposableVM to the new template: +5. Copy the Kali PGP key from the DisposableVM to the new template: ```shell_session $ qvm-copy kali-key.asc @@ -129,7 +108,7 @@ $ qvm-copy kali-key.asc The DisposableVM can now be turned off. -7. Add the Kali PGP key to the list of keys trusted to authenticate packages: +6. Add the Kali PGP key to the list of keys trusted to authenticate packages: ```shell_session # cat /home/user/QubesIncoming/dispXXX/kali-key.asc | apt-key add - @@ -137,18 +116,17 @@ $ qvm-copy kali-key.asc This command should return: `OK`. -8. Add the Kali repository +7. Replace Debian repositories with Kali repository ```shell_session -# cat < /etc/apt/sources.list.d/kali.list -# Kali Linux repository -deb https://http.kali.org/kali kali-rolling main non-free contrib -EOF +# echo 'deb https://http.kali.org/kali kali-rolling main non-free contrib' > /etc/apt/sources.list ``` -9. Update the template +8. Update the template -10. Ensure a terminal can be opened in the new template. +**Note:** During execution of the update, carefully read list of packages to be removed. If it contains `qubes-vm-dependencies` package, terminate operation and try to resolve missing dependencies first. For other `qubes-*` packages, it is up to you to decide if you need them. + +9. Ensure a terminal can be opened in the new template. ```shell_session $ qvm-run -a kali-rolling gnome-terminal From f261d281363dcd985e28f74eff12ce3b42327a6b Mon Sep 17 00:00:00 2001 From: Neowutran Date: Sat, 23 May 2020 20:34:07 +0200 Subject: [PATCH 067/136] [Kali] fix wrong tag for spellchecker --- os-guides/pentesting/kali.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index b74af7b..2bd0720 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -97,7 +97,7 @@ e.g. in this example we update `buster` stable repository to `bullseye` testing 4. Enable the QubesOS `testing` and `securitytesting` repositories -In `/etc/apt/sources.list.d/qubes-r.list`, enable the 'testing' and 'securitytesting' repository. +In `/etc/apt/sources.list.d/qubes-r.list`, enable the `testing` and `securitytesting` repository. We do that to reduce the 'dependency hell' between Qubes repository and Kali repository. 5. Copy the Kali PGP key from the DisposableVM to the new template: From b26f7b9d9af0f41c8c2d90b32627bc9aa1fcb0ef Mon Sep 17 00:00:00 2001 From: Sarvottam Kumar Date: Sat, 30 May 2020 23:05:55 +0530 Subject: [PATCH 068/136] Fix wrong numbering --- troubleshooting/out-of-memory.md | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/troubleshooting/out-of-memory.md b/troubleshooting/out-of-memory.md index 195e645..58f8fe7 100644 --- a/troubleshooting/out-of-memory.md +++ b/troubleshooting/out-of-memory.md @@ -19,17 +19,17 @@ qvm-console-dispvm If this does not work, check the size of /var/lib/qubes/qubes.xml. If it is zero, you'll need to use one of the file backup (stored in /var/lib/qubes/backup), hopefully you have the current data there. Find the most recent one and place in /var/lib/qubes/qubes.xml instead of the empty file. -In any case you'll need some disk space to start the VM. Check `df -h` output if you have some. If not, some hints how to free some disk space: +In any case you'll need some disk space to start the VM. Check `df -h` output if you have some. If not, here are some hints how to free some disk space: -1. Clean yum cache: +1. Clean yum cache ~~~ sudo yum clean all ~~~ -1. Delete .img files of a less important VM, that can be found in +2. Delete .img files of a less important VM, that can be found in /var/lib/qubes/appvms/ -/var/lib/qubes/appvms/. Then, when the system is working again, cleanup the rest with: +Then, when the system is working again, cleanup the rest with: ~~~ qvm-remove @@ -37,11 +37,11 @@ qvm-remove With this method you lose the data of one VM, but it'll work more reliably. -1. Decrease filesystem safety margin (5% by default): +3. Decrease filesystem safety margin (5% by default) ~~~ sudo tune2fs -m 4 /dev/mapper/vg_dom0-lv_root ~~~ -1. Remove some unneeded files in dom0 home (if you have any, most likely not). +4. Remove some unneeded files in dom0 home (if you have any, most likely not) From dc9b3e2ab76b18bafa54f8ae7293712646f73961 Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Thu, 4 Jun 2020 08:11:25 -0500 Subject: [PATCH 069/136] Minor text cleanup --- troubleshooting/out-of-memory.md | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/troubleshooting/out-of-memory.md b/troubleshooting/out-of-memory.md index 58f8fe7..6af4840 100644 --- a/troubleshooting/out-of-memory.md +++ b/troubleshooting/out-of-memory.md @@ -21,27 +21,26 @@ If this does not work, check the size of /var/lib/qubes/qubes.xml. If it is zero In any case you'll need some disk space to start the VM. Check `df -h` output if you have some. If not, here are some hints how to free some disk space: -1. Clean yum cache +1. Clean yum cache. ~~~ sudo yum clean all ~~~ -2. Delete .img files of a less important VM, that can be found in /var/lib/qubes/appvms/ - -Then, when the system is working again, cleanup the rest with: +2. Delete `.img` files of a less important VM, which can be found in `/var/lib/qubes/appvms/`. + Then, when the system is working again, clean up the rest. ~~~ qvm-remove ~~~ -With this method you lose the data of one VM, but it'll work more reliably. +With this method, you lose the data of one VM, but it'll work more reliably. -3. Decrease filesystem safety margin (5% by default) +3. Decrease the filesystem safety margin (5% by default). ~~~ sudo tune2fs -m 4 /dev/mapper/vg_dom0-lv_root ~~~ -4. Remove some unneeded files in dom0 home (if you have any, most likely not) +4. Remove some unneeded files in dom0 home (if you have any, most likely not). From 93216903dfed9caa6169ab5cb17090130930e656 Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Thu, 4 Jun 2020 08:12:55 -0500 Subject: [PATCH 070/136] Fix indentation --- troubleshooting/out-of-memory.md | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/troubleshooting/out-of-memory.md b/troubleshooting/out-of-memory.md index 6af4840..869da99 100644 --- a/troubleshooting/out-of-memory.md +++ b/troubleshooting/out-of-memory.md @@ -23,24 +23,24 @@ In any case you'll need some disk space to start the VM. Check `df -h` output if 1. Clean yum cache. -~~~ -sudo yum clean all -~~~ + ~~~ + sudo yum clean all + ~~~ 2. Delete `.img` files of a less important VM, which can be found in `/var/lib/qubes/appvms/`. Then, when the system is working again, clean up the rest. -~~~ -qvm-remove -~~~ + ~~~ + qvm-remove + ~~~ -With this method, you lose the data of one VM, but it'll work more reliably. + With this method, you lose the data of one VM, but it'll work more reliably. 3. Decrease the filesystem safety margin (5% by default). -~~~ -sudo tune2fs -m 4 /dev/mapper/vg_dom0-lv_root -~~~ + ~~~ + sudo tune2fs -m 4 /dev/mapper/vg_dom0-lv_root + ~~~ 4. Remove some unneeded files in dom0 home (if you have any, most likely not). From 9c638e293b1edeb6b48b75945d4a0ba27d80ddfe Mon Sep 17 00:00:00 2001 From: Lemlay Date: Fri, 5 Jun 2020 02:12:32 -0400 Subject: [PATCH 071/136] modified: signal.md --- privacy-guides/signal.md | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/privacy-guides/signal.md b/privacy-guides/signal.md index 5e205c8..de7b122 100644 --- a/privacy-guides/signal.md +++ b/privacy-guides/signal.md @@ -30,27 +30,27 @@ How to install Signal in Qubes This website cannot guarantee that any PGP key you download from the Internet is authentic. Always obtain a trusted key fingerprint via other channels, and always check any key you download against your trusted copy of the fingerprint. -1. (Optional)Create a TemplateVM (Debian 9) +1. (Optional)Create a TemplateVM (Debian, 9 is used as an examle but feel free to use any more updated by changing the 9 to a 10, etc.) [user@dom0 ~]$ sudo qubes-dom0-update qubes-template-debian-9 -2. Open a terminal in Debian 9 +2. Open a terminal in Debian 9 (Or your previously chosen template) [user@dom0 ~]$ qvm-run -a debian-9 gnome-terminal -3. Use these commands in your terminal +3. Use these commands in your terminal (If you chose a different distribution, such as buster, substitute that for xenial in the 3rd command) (Optional)[user@debian-8 ~]$ sudo apt-get install curl - [user@debian-8 ~]$ curl -s https://updates.signal.org/desktop/apt/keys.asc | sudo apt-key add - + [user@debian-8 ~]$ curl -s -x 127.0.0.1:8082 https://updates.signal.org/desktop/apt/keys.asc | sudo apt-key add - [user@debian-8 ~]$ echo "deb [arch=amd64] https://updates.signal.org/desktop/apt xenial main" | sudo tee -a /etc/apt/sources.list.d/signal-xenial.list [user@debian-8 ~]$ sudo apt update && sudo apt install signal-desktop -5. Shutdown the TemplateVM : +5. Shutdown the TemplateVM (substitute your template name if needed) : [user@dom0 ~]$ qvm-shutdown debian-9 6. Create an AppVM based on this TemplateVM -7. With your mouse select the `Q` menu -> `Domain: "AppVM Name"` -> `"AppVM Name": Add more shortcuts` +7. With your mouse select the `Q` menu -> `Create Qubes VM` -> `tick 'launch settings after creation' and set name` -> OK -> 'Applications' (or `"AppVM Name": VM Settings` -> `Applications`). Select `Signal` from the left `Available` column, move it to the right `Selected` column by clicking the `>` button and then `OK` to apply the changes and close the window. From a48e65cf365cc64ae11c3042be124650a7bfd384 Mon Sep 17 00:00:00 2001 From: Lemlay <66223105+Lemlay@users.noreply.github.com> Date: Fri, 5 Jun 2020 02:46:55 -0400 Subject: [PATCH 072/136] Update signal.md --- privacy-guides/signal.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/privacy-guides/signal.md b/privacy-guides/signal.md index de7b122..95f376e 100644 --- a/privacy-guides/signal.md +++ b/privacy-guides/signal.md @@ -30,7 +30,7 @@ How to install Signal in Qubes This website cannot guarantee that any PGP key you download from the Internet is authentic. Always obtain a trusted key fingerprint via other channels, and always check any key you download against your trusted copy of the fingerprint. -1. (Optional)Create a TemplateVM (Debian, 9 is used as an examle but feel free to use any more updated by changing the 9 to a 10, etc.) +1. (Optional)Create a TemplateVM (Debian, 9 is used as an example but feel free to use any more updated by changing the 9 to a 10, etc.) [user@dom0 ~]$ sudo qubes-dom0-update qubes-template-debian-9 From 82ae2d8ac425a3897c3e03881683fed5bff4311d Mon Sep 17 00:00:00 2001 From: Lemlay <66223105+Lemlay@users.noreply.github.com> Date: Fri, 5 Jun 2020 02:53:26 -0400 Subject: [PATCH 073/136] Update signal.md --- privacy-guides/signal.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/privacy-guides/signal.md b/privacy-guides/signal.md index 95f376e..9c51079 100644 --- a/privacy-guides/signal.md +++ b/privacy-guides/signal.md @@ -50,7 +50,7 @@ Always obtain a trusted key fingerprint via other channels, and always check any [user@dom0 ~]$ qvm-shutdown debian-9 6. Create an AppVM based on this TemplateVM -7. With your mouse select the `Q` menu -> `Create Qubes VM` -> `tick 'launch settings after creation' and set name` -> OK -> 'Applications' +7. With your mouse select the `Q` menu -> `Create Qubes VM` -> `Domain: "AppVM Name"` -> OK -> 'Applications' (or `"AppVM Name": VM Settings` -> `Applications`). Select `Signal` from the left `Available` column, move it to the right `Selected` column by clicking the `>` button and then `OK` to apply the changes and close the window. From f17d7f71d1a583d4feef040907fb0e70305a9600 Mon Sep 17 00:00:00 2001 From: Lemlay <66223105+Lemlay@users.noreply.github.com> Date: Fri, 5 Jun 2020 02:56:33 -0400 Subject: [PATCH 074/136] Update signal.md --- privacy-guides/signal.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/privacy-guides/signal.md b/privacy-guides/signal.md index 9c51079..b67dc1d 100644 --- a/privacy-guides/signal.md +++ b/privacy-guides/signal.md @@ -50,7 +50,7 @@ Always obtain a trusted key fingerprint via other channels, and always check any [user@dom0 ~]$ qvm-shutdown debian-9 6. Create an AppVM based on this TemplateVM -7. With your mouse select the `Q` menu -> `Create Qubes VM` -> `Domain: "AppVM Name"` -> OK -> 'Applications' +7. With your mouse select the `Q` menu -> `Domain: "AppVM Name"` -> 'Qube Settings' -> OK -> 'Applications' (or `"AppVM Name": VM Settings` -> `Applications`). Select `Signal` from the left `Available` column, move it to the right `Selected` column by clicking the `>` button and then `OK` to apply the changes and close the window. From 692c7dfdebb292cdbba311a06fd82042b7437b0e Mon Sep 17 00:00:00 2001 From: Lemlay <66223105+Lemlay@users.noreply.github.com> Date: Fri, 5 Jun 2020 03:05:57 -0400 Subject: [PATCH 075/136] Update signal.md --- privacy-guides/signal.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/privacy-guides/signal.md b/privacy-guides/signal.md index b67dc1d..b637885 100644 --- a/privacy-guides/signal.md +++ b/privacy-guides/signal.md @@ -50,7 +50,7 @@ Always obtain a trusted key fingerprint via other channels, and always check any [user@dom0 ~]$ qvm-shutdown debian-9 6. Create an AppVM based on this TemplateVM -7. With your mouse select the `Q` menu -> `Domain: "AppVM Name"` -> 'Qube Settings' -> OK -> 'Applications' +7. With your mouse select the `Q` menu -> `Domain: "AppVM Name"` -> 'AppVM name: Qube Settings' -> OK -> 'Applications' (or `"AppVM Name": VM Settings` -> `Applications`). Select `Signal` from the left `Available` column, move it to the right `Selected` column by clicking the `>` button and then `OK` to apply the changes and close the window. From 11c93b114166b2162b2fc2e88df0d16f96365149 Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Thu, 18 Jun 2020 14:29:27 -0500 Subject: [PATCH 076/136] Abstract version number --- os-guides/centos.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/os-guides/centos.md b/os-guides/centos.md index 3f4ab8e..5b1c9d6 100644 --- a/os-guides/centos.md +++ b/os-guides/centos.md @@ -13,9 +13,9 @@ For the minimal version, please see [Minimal TemplateVMs](/doc/templates/minimal ## Installation -CentOS-7 can be installed with the following command: +The standard CentOS TemplateVM can be installed with the following command in dom0, where `X` is the desired version number: - [user@dom0 ~]$ sudo qubes-dom0-update --enablerepo=qubes-templates-community qubes-template-centos-7 + [user@dom0 ~]$ sudo qubes-dom0-update --enablerepo=qubes-templates-community qubes-template-centos-X To switch, reinstall and uninstall a CentOS TemplateVM that is already installed in your system, see *How to [switch], [reinstall] and [uninstall]*. From a892e92ed4da72c336a1e5fcc978e8bbd9eb2d81 Mon Sep 17 00:00:00 2001 From: Daniel Moerner Date: Fri, 3 Jul 2020 12:32:49 -0400 Subject: [PATCH 077/136] Update thinkpad-troubleshooting.md Two changes: 1. Correct the file to be edited on the flash drive (s/xen.cfg/BOOTX64.cfg/), closing qubesos/qubes-issues#5851 2. Improve the list of affected Thinkpads, with citations when available. --- troubleshooting/thinkpad-troubleshooting.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/troubleshooting/thinkpad-troubleshooting.md b/troubleshooting/thinkpad-troubleshooting.md index c4e94a5..8615920 100644 --- a/troubleshooting/thinkpad-troubleshooting.md +++ b/troubleshooting/thinkpad-troubleshooting.md @@ -16,9 +16,9 @@ redirect_from: # Lenovo ThinkPad Troubleshooting # ## Instructions to create USB installation medium for newer (UEFI-only) ThinkPads ## -Newer ThinkPads (e.g. T470, T470p, ThinkPad 25) are likely to fail installation attempts made from a USB stick that was created with dd or Rufus, and even from a DVD burned using official ISO images - if the ThinkPad is configured for UEFI boot. If you don't want to use Legacy Mode as a workaround, the following instructions should help you create a Qubes Installation USB stick that works in UEFI-only mode. +Some newer ThinkPads (e.g. T470, T470p, [P51](https://www.svensemmler.org/blog/2017/12/17/qubes-on-thinkpad-p51.html), ThinkPad 25, but not the [P53](https://github.com/QubesOS/qubes-issues/issues/5851)) are likely to fail installation attempts made from a USB stick that was created with dd or Rufus, and even from a DVD burned using official ISO images - if the ThinkPad is configured for UEFI boot. If you don't want to use Legacy Mode as a workaround, the following instructions should help you create a Qubes Installation USB stick that works in UEFI-only mode. -In a nutshell, you need to use the Fedora livecd-tools to make a Qubes Installation USB Stick from the Qubes ISO image, then update the label on the partition of that USB stick to "BOOT", and then update the BOOT/EFI/xen.cfg file on the USB stick so that all labels point to BOOT. In more detail: +In a nutshell, you need to use the Fedora livecd-tools to make a Qubes Installation USB Stick from the Qubes ISO image, then update the label on the partition of that USB stick to "BOOT", and then update the BOOT/EFI/BOOTX64.cfg file on the USB stick so that all labels point to BOOT. In more detail: 1. On your ThinkPad, enter the UEFI setup (press F1 at startup) and make sure to set at least the following options: - *USB UEFI BIOS Support: Enabled* @@ -37,7 +37,7 @@ In a nutshell, you need to use the Fedora livecd-tools to make a Qubes Installat ``# mount /dev/sdd1 /mnt/qinst/`` -10. Use your favorite editor to edit the file */mnt/qinst/EFI/BOOT/xen.cfg*: Replace all instances of ``LABEL=Qubes-R4.0-rc3-x86_64`` with ``LABEL=BOOT``. There is typically no space in front of ``LABEL``, but there is a space at the end of the portion you replace. +10. Use your favorite editor to edit the file */mnt/qinst/EFI/BOOT/BOOTX64.cfg*: Replace all instances of ``LABEL=Qubes-R4.0-rc3-x86_64`` with ``LABEL=BOOT``. There is typically no space in front of ``LABEL``, but there is a space at the end of the portion you replace. 11. Unmount the Qubes Installation USB stick: ``# umount /dev/sdd*`` and disconnect it. That's it! You can now reboot the machine with the Qubes USB Installation stick attached, and press F12 to select it as the boot device at startup. Proceed to install Qubes OS normally. Enjoy! From ff168b99720503756a58689e3570c4ccbb6826e9 Mon Sep 17 00:00:00 2001 From: Michael Carbone Date: Tue, 7 Jul 2020 09:53:43 -0400 Subject: [PATCH 078/136] Update language-localization.md added mention and cross-link to utf8 in title bars --- customization-guides/language-localization.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/customization-guides/language-localization.md b/customization-guides/language-localization.md index 79c2255..50ab8cc 100644 --- a/customization-guides/language-localization.md +++ b/customization-guides/language-localization.md @@ -11,6 +11,11 @@ redirect_from: Language Localization ===================== +Enable UTF-8 in dom0 title bars +------------------------- + +You can enable UTF-8 characters in the title bar for all qubes or on a per-qube basis. Follow the instructions [here](https://www.qubes-os.org/doc/config-files/#gui-and-audio-configuration-in-dom0) for further information. + How to set up pinyin input in Qubes ----------------------------------- From 266be13ec630feb58ec5f9e6a4374d4f8c024372 Mon Sep 17 00:00:00 2001 From: Neowutran Date: Sat, 25 Jul 2020 09:50:44 +0200 Subject: [PATCH 079/136] [Kali] replace gcc8 --- os-guides/pentesting/kali.md | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index 2bd0720..5bc1258 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -122,11 +122,19 @@ $ qvm-copy kali-key.asc # echo 'deb https://http.kali.org/kali kali-rolling main non-free contrib' > /etc/apt/sources.list ``` -8. Update the template +8. Replace gcc8 + +```shell_session +# apt-get remove libgcc-8-dev && apt-get install libc6-dev +``` + +**Note:** This step is currently needed. But it will not always be the case. + +9. Update the template **Note:** During execution of the update, carefully read list of packages to be removed. If it contains `qubes-vm-dependencies` package, terminate operation and try to resolve missing dependencies first. For other `qubes-*` packages, it is up to you to decide if you need them. -9. Ensure a terminal can be opened in the new template. +10. Ensure a terminal can be opened in the new template. ```shell_session $ qvm-run -a kali-rolling gnome-terminal From 3f2e9f6b6eb50bc5903c276def3ff45465e5b8f0 Mon Sep 17 00:00:00 2001 From: Neowutran Date: Sat, 25 Jul 2020 10:38:54 +0200 Subject: [PATCH 080/136] [Kali] replace gcc8 - typo --- os-guides/pentesting/kali.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index 5bc1258..1e7d252 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -122,7 +122,7 @@ $ qvm-copy kali-key.asc # echo 'deb https://http.kali.org/kali kali-rolling main non-free contrib' > /etc/apt/sources.list ``` -8. Replace gcc8 +8. Replace `gcc8` ```shell_session # apt-get remove libgcc-8-dev && apt-get install libc6-dev From 7a27e84e5b01af907162c204b0189d3163f0fc8d Mon Sep 17 00:00:00 2001 From: Neowutran Date: Wed, 29 Jul 2020 10:19:58 +0200 Subject: [PATCH 081/136] [Kali] re-word the dependency issue workaround step --- os-guides/pentesting/kali.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index 1e7d252..81a2d58 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -122,13 +122,15 @@ $ qvm-copy kali-key.asc # echo 'deb https://http.kali.org/kali kali-rolling main non-free contrib' > /etc/apt/sources.list ``` -8. Replace `gcc8` +8. Replace `gcc8` to work around a dependency issue ```shell_session # apt-get remove libgcc-8-dev && apt-get install libc6-dev ``` -**Note:** This step is currently needed. But it will not always be the case. +**Note:** This kind of dependency issues will pop up and disappear without notice. +It depends on the differences of dependencies between the Kali repository, the testing Qubes repository and the dependency issues related to the upgrade from stable Debian to testing Debian/Kali. +So this step [step 8] is currently needed. But it will not always be the case. 9. Update the template From 302bd6bcc128291183ca74b5d9853cbbf03530aa Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Sat, 22 Aug 2020 23:18:08 -0500 Subject: [PATCH 082/136] Update qubes-users references to /support/ Now that we have a user forum in addition to qubes-users, it makes more sense to link to /support/ than to link directly to qubes-users (or to the forum, for that matter). This layer of redirection means allows us to update just one thing (namely, the /support/ page) instead of having to hunt through all the documentation every time support information changes. --- os-guides/windows/windows-tools.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index 50678ac..345c1fd 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -251,7 +251,7 @@ If a specific component is malfunctioning, you can increase its log verbosity as Updates ------- -When we publish new QWT version (which is announced on `qubes-users` Google Group) it's usually pushed to the `current-testing` or `unstable` repository first. To use versions from current-testing, run this in dom0: +When we publish new QWT version, it's usually pushed to the `current-testing` or `unstable` repository first. To use versions from current-testing, run this in dom0: `qubes-dom0-update --enablerepo=qubes-dom0-current-testing qubes-windows-tools` From effcbcd7865f102a3c2f8e923745ec2c6cf2fd81 Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Thu, 3 Sep 2020 18:13:22 -0500 Subject: [PATCH 083/136] Add note about Whonix and potential VPN risks --- configuration-guides/vpn.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/configuration-guides/vpn.md b/configuration-guides/vpn.md index 45227fd..1f84321 100644 --- a/configuration-guides/vpn.md +++ b/configuration-guides/vpn.md @@ -12,6 +12,12 @@ redirect_from: How To make a VPN Gateway in Qubes ================================== + + Although setting up a VPN connection is not by itself Qubes specific, Qubes includes a number of tools that can make the client-side setup of your VPN more versatile and secure. This document is a Qubes-specific outline for choosing the type of VM to use, and shows how to prepare a ProxyVM for either NetworkManager or a set of fail-safe VPN scripts. Please refer to your guest OS and VPN service documentation when considering the specific steps and parameters for your connection(s); The relevant documentation for the Qubes default guest OS (Fedora) is [Establishing a VPN Connection.](https://docs.fedoraproject.org/en-US/Fedora/23/html/Networking_Guide/sec-Establishing_a_VPN_Connection.html) From 8edc047a5e6e67979962424124f75d3cbc5b6ede Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Sun, 13 Sep 2020 07:14:57 -0500 Subject: [PATCH 084/136] Merge branch 'patch-6' of https://github.com/gasull/qubes-doc into gasull-patch-6 --- configuration-guides/mutt.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/configuration-guides/mutt.md b/configuration-guides/mutt.md index 6118a3d..c857258 100644 --- a/configuration-guides/mutt.md +++ b/configuration-guides/mutt.md @@ -206,21 +206,21 @@ In `.mailcap`: ### also would be convenient to use mailcap's TEST feature to ### show some html in mutt pager (e.g. with w3m, links or html2text), ### else open others in dispvm - + # MS Word documents application/msword; qvm-open-in-dvm %s - application/vnd.oasis.opendocument.spreadsheet; qvm-open-in-dvm %s application/vnd.oasis.opendocument.text; qvm-open-in-dvm %s - + # Images image/jpg; qvm-open-in-dvm %s image/jpeg; qvm-open-in-dvm %s image/png; qvm-open-in-dvm %s image/gif; qvm-open-in-dvm %s - + # PDFs application/pdf; qvm-open-in-dvm %s - + # HTML + text/html; w3m -T text/html '%s' | cat --squeeze-blank; nametemplate=%s.html; copiousoutput text/html; qvm-open-in-dvm %s From aa76d355f7548e364d481620cf40436a03f9a8ed Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Sun, 13 Sep 2020 08:19:29 -0500 Subject: [PATCH 085/136] Update links --- security-guides/security-guidelines.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/security-guides/security-guidelines.md b/security-guides/security-guidelines.md index 4a85d55..a9beaf2 100644 --- a/security-guides/security-guidelines.md +++ b/security-guides/security-guidelines.md @@ -141,7 +141,7 @@ See [here](/doc/usb/). Dom0 Precautions ---------------- -As explained [here](/getting-started/#appvms-qubes-and-templatevms), dom0 should not be used for any user operations. There are several reasons for this: +As explained [here](/getting-started/), dom0 should not be used for any user operations. There are several reasons for this: 1. Secure isolation among domUs (i.e., AppVMs, StandaloneVMs, HVMs, etc.) is the *raison d'être* of Qubes. This is the primary reason that we recommend the delegation of all user activities to some number of AppVMs. In the event that any given VM is compromised, only that particular VM is compromised. (TemplateVMs are the exception to this. If a TemplateVM were compromised, then every AppVM based on it might also be compromised. Even in this case, however, the entire system would not necessarily have been compromised, since StandaloneVM(s), HVM(s), and/or multiple TemplateVMs might be in use.) By contrast, if dom0 were ever compromised, the entire system would thereby be compromised. 2. Due to the absence of convenience mechanisms in dom0 such as the inter-VM clipboard and inter-VM file copying, it is significantly less convenient to attempt to use dom0 for user operations (e.g., password management) in conjunction with AppVMs than it is to use another dedicated AppVM (e.g., a "vault" VM). From 8e50e64cb4b04ef248728ee58b04c81c41476bf1 Mon Sep 17 00:00:00 2001 From: Neowutran Date: Sat, 19 Sep 2020 08:59:31 +0200 Subject: [PATCH 086/136] [kali] apply recommendations from pull request #989 --- os-guides/pentesting/kali.md | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index 81a2d58..8e3ea74 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -21,7 +21,7 @@ Only use this method if you want the full Kali GUI (desktop, fancy menus, etc.). It comes at the cost of much greater resources consumption. 1. Download the Kali ISO -2. Create a new HVM +2. [Create a new HVM][qubes-new-hvm] 3. Start the HVM with attached CD/DVD ```shell_session $ qvm-start --cdrom :/home/user/Downloads/.iso @@ -37,9 +37,10 @@ If you need to install custom kernel modules (wifi drivers, …) you need to use The steps can be summarized as: 1. Install Qubes stable Debian template -2. Add `testing` and `securitytesting` Qubes repositories -3. Add the Kali repository -4. Update the template +2. Upgrade from Debian `stable` to Debian `testing` for Qubes repositories +3. Add `testing` and `securitytesting` Qubes repositories +4. Replace the content of `/etc/apt/sources.list` file with the Kali repository +5. Update the template Get Kali Linux PGP key ----------------------- @@ -128,8 +129,10 @@ $ qvm-copy kali-key.asc # apt-get remove libgcc-8-dev && apt-get install libc6-dev ``` -**Note:** This kind of dependency issues will pop up and disappear without notice. -It depends on the differences of dependencies between the Kali repository, the testing Qubes repository and the dependency issues related to the upgrade from stable Debian to testing Debian/Kali. +**Note:** This kind of dependency issue will pop up and disappear without notice. +Such issues arise because of the differences of dependencies in packages from +the Kali repository, the Qubes testing repository and the Debian testing +repository. So this step [step 8] is currently needed. But it will not always be the case. 9. Update the template @@ -145,6 +148,7 @@ $ qvm-run -a kali-rolling gnome-terminal Install the Kali tools ------------------------------ At this point you should have a working template and you can install the tools you need. +You can find [a list of Kali Linux Metapackages here](https://tools.kali.org/kali-metapackages) Keep in mind that the tools you will install can easily take more than 10 GB, [so you will need to **grow** the size of the VM system storage.][qubes-resize-disk-image] Alternative Options to Kali Linux @@ -164,6 +168,7 @@ Thanks to the people in [the discussion thread](https://github.com/QubesOS/qubes [qubes-ptf]: /doc/pentesting/ptf/ [qubes-template-debian-install]: /doc/templates/debian/#install [qubes-resize-disk-image]: /doc/resize-disk-image/ +[qubes-new-hvm]: /doc/standalone-and-hvm/ [kali]: https://www.kali.org/ [kali-vbox]: https://www.offensive-security.com/kali-linux-vmware-virtualbox-image-download/ From dbc447da5be240f6b0845765adeefd612865ef45 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Mon, 21 Sep 2020 14:38:17 +0200 Subject: [PATCH 087/136] Update windows-vm.md Added instructions for installing QWT on Windows 10, using the Xen version 9.0.0 drivers and added instructions on creating Windows 7 and 10 as TemplateVMs and AppVMs instead of StandaloneVMs. --- os-guides/windows/windows-vm.md | 60 +++++++++++++++++++++++++++++++-- 1 file changed, 58 insertions(+), 2 deletions(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 74ea761..4c3c6af 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -117,8 +117,9 @@ To install Qubes Windows Tools, follow instructions [below](#xen-pv-drivers-and- MS Windows versions considerations: -- The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. +- The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x +- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in serverel instances, is described below. Create a VM named win7new in [HVM](/doc/hvm/) mode (Xen's current PVH limitations precludes from using PVH): @@ -210,6 +211,57 @@ qvm-prefs win7new qrexec_timeout 300 At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](#xen-pv-drivers-and-qubes-windows-tools) below). It is a good time to clone the VM again. +### Installing Qubes Windows Tools on Windows 10 + +If the Xen bus and storage drivers version 9.0.0 are installed in a Windows 10 system without Qubes Windows Tools, and QWT 4.0.1.3 are installed after the Xen installation has finished, the Qubes interface works correctly. Files can be exchanged with other VMs, and the common clipboard works in both directions. So to get a working Windows 10 system (Standalone or Template VM) under Qubes R4.0, the following steps should be performed: + +- Copy the installation kits of `xenvbd` and `xenbus` Version 9.0.0 from the Xen web site and Qubes Windows Tools 4.0.1.3 to the Windows system drive (normally `C:\`.) +- Extract `qubes-tools-4.0.1.3.exe` from the QWT installation media, and store it on the Windows system disk. +- Install `xenvbd` and `xenbus` version 9.0.0. +- After installation, reboot. without the installation disk. +- Install Qubes Windows Tools 4.0.1.3 by starting `qubes-tools-4.0.1.3.exe`, unselecting the Xen storage driver and the `Move of user data to Drive D` (which would probably lead to problems in Windows, anyhow). +- Shut down Windows. +- Set `qvm-features win10new gui 1` +- Reboot Windows. The VM starts, but does not show any window. +- Shutdown Windows from the Qube manager. +- Reboot Windows once more. Now the system is up, with QWT running correctly. + +For me, this sequence worked for Windows 10 as template VM, and a correspondig AppVM worked too. + +File copy operations to a Windows 10 VM are possible, if the Qubes OS `default_user` property is set to the user name used for access to that VM, which can be done via the command +~~~ +qvm-prefs default_user +~~~ +If this property is not set or set to a wrong value, files copied to this VM are stored in the folder +~~~ +C:\Windows\System32\config\systemprofile\Documents\QubesIncoming\ +~~~ +If the target VM is an AppVM, this has the consequence that the files are stored in the corresponding TemplateVM and so are lost on AppVM shutdown. + +Windows as TemplateVM +--------------------- + +Windows 7 and 10 can be installed as TemplateVM by selecting +~~~ +qvm-create --class TemplateVM --property virt_mode=HVM --property kernel='' --label black Windows-7 +qvm-create --class TemplateVM --property virt_mode=HVM --property kernel='' --label black Windows-10 +~~~ +when creating the VM. To have the user data stored in AppVMs depending on this template, Windows 7 and 10 have to be treated differently: + +- For Windows 7, the option to move the user directories from drive `C` to drive `D` works and causes any user data to be stored in the AppVMs based on this template, and not in the template itself. + +- After installation of Windows 10 as a TemplateVM, the Windows disk manager may be used to add the private volume as disk `D:`, and you may, using the doumented Windows operations, move the user directories `C:\users\\Documents` to this new disk, allowing depending AppVMs to have their own private volumes. Moving the hidden application directories `AppData`, however, is likely to invite trouble - the same trouble that occurs if, during QWT installation, the option `Move of user data to drive D` is selected. + +For Windows 10, configuration data like those stored in directories like `AppData` still remain in the TemplateVM, such that their changes are lost each time the AppVM shuts down. In order to make permanent changes to these configuration data, they have to be changed in the TemplateVM, meaning that applications have to be started there, which violates and perhaps even endangers the security of the TemplateVM. Such changes should be done only if absolutely necessary and with great care. It is a good idea to test them first in a cloned TemplateVM before applying them in the production VM. + +AppVMs based on these templates can be created the normal way by using the Qube Manager or by specifying +~~~ +qvm-create --class=AppVM --template= +~~~ + +On starting the AppVM, sometimes a message is displayed that the Xen PV Network Class needs to restart the system. This message can be safely ignored and closed by selecting "No". + +**Caution:** These AppVMs must not be started while the corresponding TemplateVM is running, because they share the TemplateVM's license data. Even if this could work sometimes, it would be a violation of the license terms. Windows update -------------- @@ -229,10 +281,14 @@ Installing Xen's PV drivers in the VM will lower its resources usage when using 2. installing Qubes Windows Tools (QWT), which bundles Xen's PV drivers. Notes about using Xen's VBD (storage) PV driver: -- Windows 7: installing the driver requires a fully updated VM or else you'll likely get a BSOD and a VM in a difficult to fix state. Updating Windows takes *hours* and for casual usage there isn't much of a performance between the disk PV driver and the default one; so there is likely no need to go through the lengthy Windows Update process if your VM doesn't have access to untrusted networks and if you don't use I/O intensive apps. If you plan to update your newly installed Windows VM it is recommended that you do so *before* installing Qubes Windows Tools (QWT). If QWT are installed, you should temporarily re-enable the standard VGA adapter in Windows and disable Qubes' (see the section above). +- **Windows 7:** installing the driver requires a fully updated VM or else you'll likely get a BSOD and a VM in a difficult to fix state. Updating Windows takes *hours* and for casual usage there isn't much of a performance between the disk PV driver and the default one; so there is likely no need to go through the lengthy Windows Update process if your VM doesn't have access to untrusted networks and if you don't use I/O intensive apps. If you plan to update your newly installed Windows VM it is recommended that you do so *before* installing Qubes Windows Tools (QWT). If QWT are installed, you should temporarily re-enable the standard VGA adapter in Windows and disable Qubes' (see the section above). - the option to install the storage PV driver is disabled by default in Qubes Windows Tools - in case you already had QWT installed without the storage PV driver and you then updated the VM, you may then install the driver from Xen's site (xenvbd.tar). +**Caution:** Installing the version 9.0.0 Xen drivers on Windows 7 (a system without QWT - QWT uninstalled) leads to an unbootable system. The drivers install without error, but after reboot, the system aborts the reboot saying ´Missing driver xenbus.sys´. + +- **Windows 10:** The version 9.0.0 Xen drivers have to be installed before installing Qubes Windows Tools. Installing them on a system with QWT installed is likely to produce a system which crashes or has the tools in a non-functional state. Even if the tools were installed and then removed before installing the Xen drivers, they probably will not work as expected. + Installing Qubes Windows Tools: - on R3.2: see [this page](/doc/windows-tools/) From 92b4cdd840861a3166d462f3638912926e90eaa2 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Mon, 21 Sep 2020 16:50:27 +0200 Subject: [PATCH 088/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 4c3c6af..5db5318 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -119,7 +119,7 @@ MS Windows versions considerations: - The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x -- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in serverel instances, is described below. +- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in serveral instances, is described below. Create a VM named win7new in [HVM](/doc/hvm/) mode (Xen's current PVH limitations precludes from using PVH): @@ -219,14 +219,14 @@ If the Xen bus and storage drivers version 9.0.0 are installed in a Windows 10 s - Extract `qubes-tools-4.0.1.3.exe` from the QWT installation media, and store it on the Windows system disk. - Install `xenvbd` and `xenbus` version 9.0.0. - After installation, reboot. without the installation disk. -- Install Qubes Windows Tools 4.0.1.3 by starting `qubes-tools-4.0.1.3.exe`, unselecting the Xen storage driver and the `Move of user data to Drive D` (which would probably lead to problems in Windows, anyhow). +- Install Qubes Windows Tools 4.0.1.3 by starting `qubes-tools-4.0.1.3.exe`, not selecting the Xen storage driver and the `Move of user data to Drive D` (which would probably lead to problems in Windows, anyhow). - Shut down Windows. - Set `qvm-features win10new gui 1` - Reboot Windows. The VM starts, but does not show any window. - Shutdown Windows from the Qube manager. - Reboot Windows once more. Now the system is up, with QWT running correctly. -For me, this sequence worked for Windows 10 as template VM, and a correspondig AppVM worked too. +For me, this sequence worked for Windows 10 as template VM, and a corresponding AppVM worked too. File copy operations to a Windows 10 VM are possible, if the Qubes OS `default_user` property is set to the user name used for access to that VM, which can be done via the command ~~~ @@ -250,7 +250,7 @@ when creating the VM. To have the user data stored in AppVMs depending on this t - For Windows 7, the option to move the user directories from drive `C` to drive `D` works and causes any user data to be stored in the AppVMs based on this template, and not in the template itself. -- After installation of Windows 10 as a TemplateVM, the Windows disk manager may be used to add the private volume as disk `D:`, and you may, using the doumented Windows operations, move the user directories `C:\users\\Documents` to this new disk, allowing depending AppVMs to have their own private volumes. Moving the hidden application directories `AppData`, however, is likely to invite trouble - the same trouble that occurs if, during QWT installation, the option `Move of user data to drive D` is selected. +- After installation of Windows 10 as a TemplateVM, the Windows disk manager may be used to add the private volume as disk `D:`, and you may, using the documented Windows operations, move the user directories `C:\users\\Documents` to this new disk, allowing depending AppVMs to have their own private volumes. Moving the hidden application directories `AppData`, however, is likely to invite trouble - the same trouble that occurs if, during QWT installation, the option `Move of user data to drive D` is selected. For Windows 10, configuration data like those stored in directories like `AppData` still remain in the TemplateVM, such that their changes are lost each time the AppVM shuts down. In order to make permanent changes to these configuration data, they have to be changed in the TemplateVM, meaning that applications have to be started there, which violates and perhaps even endangers the security of the TemplateVM. Such changes should be done only if absolutely necessary and with great care. It is a good idea to test them first in a cloned TemplateVM before applying them in the production VM. From a13ea731b3408bac40e8b6b08d016043997d7f17 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Mon, 21 Sep 2020 17:06:20 +0200 Subject: [PATCH 089/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 5db5318..15ffba1 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -119,7 +119,7 @@ MS Windows versions considerations: - The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x -- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in serveral instances, is described below. +- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described below. Create a VM named win7new in [HVM](/doc/hvm/) mode (Xen's current PVH limitations precludes from using PVH): From 61ab4ac2d1a768df221b0cfd4860f02f9bccf085 Mon Sep 17 00:00:00 2001 From: Neowutran Date: Tue, 22 Sep 2020 08:39:38 +0200 Subject: [PATCH 090/136] [kali] spellchecking --- os-guides/pentesting/kali.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/pentesting/kali.md b/os-guides/pentesting/kali.md index 8e3ea74..9f401ea 100644 --- a/os-guides/pentesting/kali.md +++ b/os-guides/pentesting/kali.md @@ -148,7 +148,7 @@ $ qvm-run -a kali-rolling gnome-terminal Install the Kali tools ------------------------------ At this point you should have a working template and you can install the tools you need. -You can find [a list of Kali Linux Metapackages here](https://tools.kali.org/kali-metapackages) +You can find [a list of Kali Linux `Metapackages` here](https://tools.kali.org/kali-metapackages) Keep in mind that the tools you will install can easily take more than 10 GB, [so you will need to **grow** the size of the VM system storage.][qubes-resize-disk-image] Alternative Options to Kali Linux From 834e3a98cd140d39de5c7e366f6ed82aa18b0cd3 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Tue, 22 Sep 2020 10:38:39 +0200 Subject: [PATCH 091/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 15ffba1..c5d265b 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -263,6 +263,12 @@ On starting the AppVM, sometimes a message is displayed that the Xen PV Network **Caution:** These AppVMs must not be started while the corresponding TemplateVM is running, because they share the TemplateVM's license data. Even if this could work sometimes, it would be a violation of the license terms. +### Windows 10 Usage According to GDPR + +If Windows 10 is used in the EU to process personal data, according to GDPR no automatic data transfer to countries outside the EU is allowed without explicit consent of the person(s) concerned, or other legal consent, as applicable. Since no reliable way is found to completely control the sending of telemetry from Windows 10, the system containing personal data must be completely shielded from the internet. + +This can be achieved by installing Windows 10 on a TemplateVM with the user data directory moved to a separate drive (usually `D:`). Personal data must not be stored within the TemplateVM, but only in AppVMs depending on this TemplateVM. Network access by these AppVMs must be restricted to the local network and perhaps additional selected servers within the EU. Any data exchange of the AppVMs must be restricted to file and clipboard operations to and from other VMs in the same Qubes system. + Windows update -------------- From 4b6c9dd9a94f86876d9d2cbec9e1404ec28fd4ab Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Thu, 24 Sep 2020 18:52:28 +0200 Subject: [PATCH 092/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index c5d265b..1c7314b 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -215,10 +215,12 @@ At that point you should have a functional and stable Windows VM, although witho If the Xen bus and storage drivers version 9.0.0 are installed in a Windows 10 system without Qubes Windows Tools, and QWT 4.0.1.3 are installed after the Xen installation has finished, the Qubes interface works correctly. Files can be exchanged with other VMs, and the common clipboard works in both directions. So to get a working Windows 10 system (Standalone or Template VM) under Qubes R4.0, the following steps should be performed: -- Copy the installation kits of `xenvbd` and `xenbus` Version 9.0.0 from the Xen web site and Qubes Windows Tools 4.0.1.3 to the Windows system drive (normally `C:\`.) -- Extract `qubes-tools-4.0.1.3.exe` from the QWT installation media, and store it on the Windows system disk. -- Install `xenvbd` and `xenbus` version 9.0.0. -- After installation, reboot. without the installation disk. +- Install Qubes Windows Tools in dom0: `sudo qubes-dom0-update qubes-windows-tools`. The iso will be the file `/usr/lib/qubes/qubes-windows-tools-4.0.1.3.iso`. +- Copy this file to some AppVM: `qvm-copy-to-vm VMname /usr/lib/qubes/qubes-windows-tools-4.0.1.3.iso`. +- In this VM, extract the file `qubes-tools-4.0.1.3.exe` from the iso, using the archive manager. +- Copy the installation kits of `xenvbd` and `xenbus` Version 9.0.0 (two Zip-files) from the Xen web site and the file `qubes-tools-4.0.1.3.exe` to the Windows system drive (normally `C:\`.) +- Install `xenvbd` and `xenbus` version 9.0.0 by starting the file `dpinst.exe` from the `x64` directories of the Zip-file. +- After installation, reboot. - Install Qubes Windows Tools 4.0.1.3 by starting `qubes-tools-4.0.1.3.exe`, not selecting the Xen storage driver and the `Move of user data to Drive D` (which would probably lead to problems in Windows, anyhow). - Shut down Windows. - Set `qvm-features win10new gui 1` From ce8e446dfc6b47329505f3f83f6a1cd51181cc90 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Fri, 25 Sep 2020 11:12:07 +0200 Subject: [PATCH 093/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 1c7314b..d05cad7 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -213,7 +213,11 @@ At that point you should have a functional and stable Windows VM, although witho ### Installing Qubes Windows Tools on Windows 10 -If the Xen bus and storage drivers version 9.0.0 are installed in a Windows 10 system without Qubes Windows Tools, and QWT 4.0.1.3 are installed after the Xen installation has finished, the Qubes interface works correctly. Files can be exchanged with other VMs, and the common clipboard works in both directions. So to get a working Windows 10 system (Standalone or Template VM) under Qubes R4.0, the following steps should be performed: +If the Xen bus and storage drivers version 9.0.0 are installed in a Windows 10 system without Qubes Windows Tools, and QWT 4.0.1.3 are installed after the Xen installation has finished, the Qubes interface works correctly. Files can be exchanged with other VMs, and the common clipboard works in both directions. + +The installation of Qubes Windows Tools should **not** be done by using the parameter `--install-windows-tools`or by directly specifying `--cdrom=...`when starting the Windows VM, as this is bound to crash the VM on booting, showing the error `INACCESSIBLE BOOT DEVICE`- which makes no sense, but does happen. + +So to get a working Windows 10 system (Standalone or Template VM) under Qubes R4.0, the following steps should be performed: - Install Qubes Windows Tools in dom0: `sudo qubes-dom0-update qubes-windows-tools`. The iso will be the file `/usr/lib/qubes/qubes-windows-tools-4.0.1.3.iso`. - Copy this file to some AppVM: `qvm-copy-to-vm VMname /usr/lib/qubes/qubes-windows-tools-4.0.1.3.iso`. From a9c17846e34eb4a88f4084f1006bc14713043eda Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sat, 26 Sep 2020 10:39:12 +0200 Subject: [PATCH 094/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index d05cad7..6a73b2c 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -219,10 +219,23 @@ The installation of Qubes Windows Tools should **not** be done by using the para So to get a working Windows 10 system (Standalone or Template VM) under Qubes R4.0, the following steps should be performed: +**to be replaced** - Install Qubes Windows Tools in dom0: `sudo qubes-dom0-update qubes-windows-tools`. The iso will be the file `/usr/lib/qubes/qubes-windows-tools-4.0.1.3.iso`. - Copy this file to some AppVM: `qvm-copy-to-vm VMname /usr/lib/qubes/qubes-windows-tools-4.0.1.3.iso`. - In this VM, extract the file `qubes-tools-4.0.1.3.exe` from the iso, using the archive manager. - Copy the installation kits of `xenvbd` and `xenbus` Version 9.0.0 (two Zip-files) from the Xen web site and the file `qubes-tools-4.0.1.3.exe` to the Windows system drive (normally `C:\`.) +**end of replaced text** + +**new text** +- In the Windows 10 VM, download the installation kits of `xenvbd` and `xenbus` Version 9.0.0 (two files`xenvbd.zip`and `xenbus.zip`) from the Xen web site and the file `qubes-tools-4.0.1.3.exe` from https://www.qubes-os.org/doc/windows-tools/ **enter the final url** and store them on the Windows system drive (normally `C:\`.) +**end of new text** + +- Check the integrity of the file `qubes-tools-4.0.1.3.exe`by comparing its hash checksum. This can be done using the Windows command `certutil` specifying an appropriate hash algorithm like: +~~~ +certutil --hashfile qubes-tools-4.0.1.3.exe SHA256 +~~~ +This utility supports the algorithms MD5, SHA1, SHA256 and SHA512 (to be entered in uppercase!). The correct hash values can be retrieved from the Qubes website: https://www.qubes-os.org/doc/windows-tools/ **enter the final url** + - Install `xenvbd` and `xenbus` version 9.0.0 by starting the file `dpinst.exe` from the `x64` directories of the Zip-file. - After installation, reboot. - Install Qubes Windows Tools 4.0.1.3 by starting `qubes-tools-4.0.1.3.exe`, not selecting the Xen storage driver and the `Move of user data to Drive D` (which would probably lead to problems in Windows, anyhow). From 6aeacff183e4c5e02f1658bbdf869d05dc6c56c5 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sat, 26 Sep 2020 13:02:41 +0200 Subject: [PATCH 095/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 6a73b2c..59de22f 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -117,7 +117,7 @@ To install Qubes Windows Tools, follow instructions [below](#xen-pv-drivers-and- MS Windows versions considerations: -- The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. +- The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x - For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described below. @@ -227,7 +227,7 @@ So to get a working Windows 10 system (Standalone or Template VM) under Qubes R4 **end of replaced text** **new text** -- In the Windows 10 VM, download the installation kits of `xenvbd` and `xenbus` Version 9.0.0 (two files`xenvbd.zip`and `xenbus.zip`) from the Xen web site and the file `qubes-tools-4.0.1.3.exe` from https://www.qubes-os.org/doc/windows-tools/ **enter the final url** and store them on the Windows system drive (normally `C:\`.) +- In the Windows 10 VM, download the installation kits of `xenvbd` and `xenbus` Version 9.0.0 (two files`xenvbd.tar`and `xenbus.tar`) from the Xen web site and the file `qubes-tools-4.0.1.3.exe` from https://www.qubes-os.org/doc/windows-tools/ **enter the final url** and store them on the Windows system drive (normally `C:\`.) In order to extract the contents from the tar-archives, you will need an external utility like 7zip. **end of new text** - Check the integrity of the file `qubes-tools-4.0.1.3.exe`by comparing its hash checksum. This can be done using the Windows command `certutil` specifying an appropriate hash algorithm like: @@ -236,9 +236,9 @@ certutil --hashfile qubes-tools-4.0.1.3.exe SHA256 ~~~ This utility supports the algorithms MD5, SHA1, SHA256 and SHA512 (to be entered in uppercase!). The correct hash values can be retrieved from the Qubes website: https://www.qubes-os.org/doc/windows-tools/ **enter the final url** -- Install `xenvbd` and `xenbus` version 9.0.0 by starting the file `dpinst.exe` from the `x64` directories of the Zip-file. +- Install `xenvbd` and `xenbus` version 9.0.0 by starting the file `dpinst.exe` from the `x64` directories of the extracted tar-files. If during installation, the Xen driver requests a reboot, select "No" and let the installation continue. - After installation, reboot. -- Install Qubes Windows Tools 4.0.1.3 by starting `qubes-tools-4.0.1.3.exe`, not selecting the Xen storage driver and the `Move of user data to Drive D` (which would probably lead to problems in Windows, anyhow). +- Install Qubes Windows Tools 4.0.1.3 by starting `qubes-tools-4.0.1.3.exe`, not selecting the `Xen PV disk drivers` and the `Move user profiles` (which would probably lead to problems in Windows, anyhow). If during installation, the Xen driver requests a reboot, select "No" and let the installation continue - the system will be rebooted later. - Shut down Windows. - Set `qvm-features win10new gui 1` - Reboot Windows. The VM starts, but does not show any window. @@ -269,7 +269,7 @@ when creating the VM. To have the user data stored in AppVMs depending on this t - For Windows 7, the option to move the user directories from drive `C` to drive `D` works and causes any user data to be stored in the AppVMs based on this template, and not in the template itself. -- After installation of Windows 10 as a TemplateVM, the Windows disk manager may be used to add the private volume as disk `D:`, and you may, using the documented Windows operations, move the user directories `C:\users\\Documents` to this new disk, allowing depending AppVMs to have their own private volumes. Moving the hidden application directories `AppData`, however, is likely to invite trouble - the same trouble that occurs if, during QWT installation, the option `Move of user data to drive D` is selected. +- After installation of Windows 10 as a TemplateVM, the Windows disk manager may be used to add the private volume as disk `D:`, and you may, using the documented Windows operations, move the user directories `C:\users\\Documents` to this new disk, allowing depending AppVMs to have their own private volumes. Moving the hidden application directories `AppData`, however, is likely to invite trouble - the same trouble that occurs if, during QWT installation, the option `Move user profiles` is selected. For Windows 10, configuration data like those stored in directories like `AppData` still remain in the TemplateVM, such that their changes are lost each time the AppVM shuts down. In order to make permanent changes to these configuration data, they have to be changed in the TemplateVM, meaning that applications have to be started there, which violates and perhaps even endangers the security of the TemplateVM. Such changes should be done only if absolutely necessary and with great care. It is a good idea to test them first in a cloned TemplateVM before applying them in the production VM. From c357d266a5d517af1faba58485bdf4942ea4df4d Mon Sep 17 00:00:00 2001 From: deeplow Date: Sat, 26 Sep 2020 15:47:17 -0400 Subject: [PATCH 096/136] move QWT instructions and make them step-by-step --- os-guides/windows/windows-tools.md | 75 ++++++++++++++++++++++++++---- os-guides/windows/windows-vm.md | 45 ------------------ 2 files changed, 67 insertions(+), 53 deletions(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index 345c1fd..d313175 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -19,22 +19,34 @@ Qubes Windows Tools Qubes Windows Tools are a set of programs and drivers that provide integration of Windows AppVMs with the rest of the Qubes system. Currently the following features are available for Windows VMs after installation of those tools: -- Seamless GUI mode that integrates apps windows onto the common Qubes trusted desktop -- Support for [secure clipboard copy/paste](/doc/copy-paste/) between the Windows VM and other AppVMs -- Support for [secure file exchange](/doc/copying-files/) between the Windows VM and other AppVMs -- Support for qvm-run and generic qrexec for the Windows VM (e.g. ability to run custom service within/from the Windows VM) -- Xen PV drivers for Windows that increase performance compared to qemu emulated devices +- **Qubes Video Driver** - provides for the Seamless GUI mode that integrates apps windows onto the common Qubes trusted desktop +- **File sender/receiver** - Support for [secure clipboard copy/paste](/doc/copy-paste/) between the Windows VM and other AppVMs +- ***File sender/receiver** - Support for [secure file exchange](/doc/copying-files/) between the Windows VM and other AppVMs +- **Copy/Edit in Dipostable VM** - Support for editing files in DisposableVMs as well as for qvm-run and generic qrexec for the Windows VM (e.g. ability to run custom service within/from the Windows VM) +- **Xen PV drivers** for Windows that increase performance compared to qemu emulated devices + +Bellow is a breakdown of the feature availablility depending on the windows version: + +| Feature | Windows 7 x64 | Windows 10 x64 | +| ------------------------------------ | :------------: | :------------: | +| Qubes Video Driver | + | - | +| Qubes Network Setup | + | + | +| Private Volume Setup (move profiles) | + | + | +| File sender/receiver | + | + | +| Clipboard Copy/Paste | + | + | +| Application shortcuts | + | + | +| Copy/Edit in Disposible VM | + | + | +| Block device | + | + | +| USB device | - | - | +| Audio | - | - | Qubes Windows Tools are open source and are distributed under a GPL license. NOTES: - Qubes Windows Tools are currently unmaintained - Currently only 64-bit versions of Windows 7 are supported by Qubes Windows Tools. Only emulated SVGA GPU is supported (although [there has been reports](https://groups.google.com/forum/#!topic/qubes-users/cmPRMOkxkdA) on working GPU passthrough). -- There is currently no audio support for Windows HVMs. -- There is currently no USB pass-through support for Windows HVMs. - __This page documents the process of installing Qubes Windows Tools on versions up to R3.2.__. Installation on Qubes R4.0 is possible but is a work in progress and there are limitations/bugs (see [issue #3585](https://github.com/QubesOS/qubes-issues/issues/3585)). - Installing Windows OS in a Qubes VM ----------------------------------- @@ -42,6 +54,51 @@ Please refer to [this page](/doc/windows-vm/) for instructions on how to install NOTE: It is strongly suggested to enable autologon for any Windows HVMs that will have Qubes Tools installed. To do so, run `netplwiz` command from the `Win+R`/Start menu and uncheck the *Users must enter a user name and password to use this computer* option. +Installing Qubes guest tools in Windows 10 VMs +---------------------------------------------- + +This will allow you to installs the Qubes Windows Tools on Windows 10 both as a StandaloneVM as well as a template VM and a corresponding AppVM. But some features are not available: + +TODO available features + + 1. In the Windows 10 VM, download from the [XEN website](https://xenproject.org/downloads/windows-pv-drivers/windows-pv-drivers-9-series/windows-pv-drivers-9-0-0/) the installation kits for Xen bus (`xenbus`) and storage drivers (`xenvbd`) Version 9.0.0 (two files`xenvbd.tar`and `xenbus.tar`). + + 2. Use an archive extractor like [7-zip](https://www.7-zip.org/) to extract the contents of the `.tar` files. + + 3. - Install `xenvbd` and `xenbus` by starting the file `dpinst.exe` from the `x64` directories of the extracted tar-files. If during installation, the Xen driver requests a reboot, select "No" and let the installation continue. + + 4. After installation, reboot. + + 5. Download the Qubes Windows Tools (`qubes-tools-4.0.1.3.exe`) from [the qubes FTP server](TODO add ftp link) and move it to `C:\`. + + 6. Check the integrity of the file `qubes-tools-4.0.1.3.exe`by comparing its hash checksum. This can be done using the Windows command `certutil` on the windows command prompt (`cmd.exe`) and specifying an appropriate hash algorithm like: + + certutil --hashfile C:\qubes-tools-4.0.1.3.exe SHA256 + + And compare it the value to `148A2A993F0C746B48FA6C5C9A5D1B504E09A7CFBA3FB931A4DCF86FDA4EC9B1` (**it has to exactly match for security reasons**). If it matches, feel free to continue the installation. If not, repeat the download to make sure it was not corrupted due to a network problem. If keeps on not matching it might be an attacker attempting to do something nasty to your system -- Ask for support. + + > **Note**: this is a workaround for installing the qubes windows tools on windows 10 since the standard way is broken. + + 7. Install Qubes Windows Tools 4.0.1.3 by starting `qubes-tools-4.0.1.3.exe`, not selecting the `Xen PV disk drivers` and the `Move user profiles` (which would probably lead to problems in Windows, anyhow). If during installation, the Xen driver requests a reboot, select "No" and let the installation continue - the system will be rebooted later. + + 8. Shut down Windows. + + 9. On a `dom0` terminal write: *(where `` is the name of your Windows 10 VM)* + + `qvm-features gui 1` + + 10. Reboot Windows. If the VM starts, but does not show any window then shutdown Windows from the Qube manager and reboot Windows once more. + + 11. Now the system should be up, with QWT running correctly. + + 12. Lastly to enable file copy operations to a Windows 10 VM the `default_user` property should be set the `` that you use to login to the Windows VM. This can be done via the following command on a `dom0` terminal: *(where `` is the name of your Windows 10 VM)* + + qvm-prefs win10 default_user + + > **Note:** If this property is not set or set to a wrong value, files copied to this VM are stored in the folder `C:\Windows\System32\config\systemprofile\Documents\QubesIncoming\`. + > If the target VM is an AppVM, this has the consequence that the files are stored in the corresponding TemplateVM and so are lost on AppVM shutdown. + + Installing Qubes guest tools in Windows 7 VMs --------------------------------------------- @@ -94,6 +151,8 @@ qvm-prefs -s qrexec_timeout 300 Using Windows AppVMs in seamless mode ------------------------------------- +> **Note:** This feature is only available for Windows 7 + Once you start a Windows-based AppVM with Qubes Tools installed, you can easily start individual applications from the VM (note the `-a` switch used here, which will auto-start the VM if it is not running): ~~~ diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 59de22f..59b6e28 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -211,51 +211,6 @@ qvm-prefs win7new qrexec_timeout 300 At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](#xen-pv-drivers-and-qubes-windows-tools) below). It is a good time to clone the VM again. -### Installing Qubes Windows Tools on Windows 10 - -If the Xen bus and storage drivers version 9.0.0 are installed in a Windows 10 system without Qubes Windows Tools, and QWT 4.0.1.3 are installed after the Xen installation has finished, the Qubes interface works correctly. Files can be exchanged with other VMs, and the common clipboard works in both directions. - -The installation of Qubes Windows Tools should **not** be done by using the parameter `--install-windows-tools`or by directly specifying `--cdrom=...`when starting the Windows VM, as this is bound to crash the VM on booting, showing the error `INACCESSIBLE BOOT DEVICE`- which makes no sense, but does happen. - -So to get a working Windows 10 system (Standalone or Template VM) under Qubes R4.0, the following steps should be performed: - -**to be replaced** -- Install Qubes Windows Tools in dom0: `sudo qubes-dom0-update qubes-windows-tools`. The iso will be the file `/usr/lib/qubes/qubes-windows-tools-4.0.1.3.iso`. -- Copy this file to some AppVM: `qvm-copy-to-vm VMname /usr/lib/qubes/qubes-windows-tools-4.0.1.3.iso`. -- In this VM, extract the file `qubes-tools-4.0.1.3.exe` from the iso, using the archive manager. -- Copy the installation kits of `xenvbd` and `xenbus` Version 9.0.0 (two Zip-files) from the Xen web site and the file `qubes-tools-4.0.1.3.exe` to the Windows system drive (normally `C:\`.) -**end of replaced text** - -**new text** -- In the Windows 10 VM, download the installation kits of `xenvbd` and `xenbus` Version 9.0.0 (two files`xenvbd.tar`and `xenbus.tar`) from the Xen web site and the file `qubes-tools-4.0.1.3.exe` from https://www.qubes-os.org/doc/windows-tools/ **enter the final url** and store them on the Windows system drive (normally `C:\`.) In order to extract the contents from the tar-archives, you will need an external utility like 7zip. -**end of new text** - -- Check the integrity of the file `qubes-tools-4.0.1.3.exe`by comparing its hash checksum. This can be done using the Windows command `certutil` specifying an appropriate hash algorithm like: -~~~ -certutil --hashfile qubes-tools-4.0.1.3.exe SHA256 -~~~ -This utility supports the algorithms MD5, SHA1, SHA256 and SHA512 (to be entered in uppercase!). The correct hash values can be retrieved from the Qubes website: https://www.qubes-os.org/doc/windows-tools/ **enter the final url** - -- Install `xenvbd` and `xenbus` version 9.0.0 by starting the file `dpinst.exe` from the `x64` directories of the extracted tar-files. If during installation, the Xen driver requests a reboot, select "No" and let the installation continue. -- After installation, reboot. -- Install Qubes Windows Tools 4.0.1.3 by starting `qubes-tools-4.0.1.3.exe`, not selecting the `Xen PV disk drivers` and the `Move user profiles` (which would probably lead to problems in Windows, anyhow). If during installation, the Xen driver requests a reboot, select "No" and let the installation continue - the system will be rebooted later. -- Shut down Windows. -- Set `qvm-features win10new gui 1` -- Reboot Windows. The VM starts, but does not show any window. -- Shutdown Windows from the Qube manager. -- Reboot Windows once more. Now the system is up, with QWT running correctly. - -For me, this sequence worked for Windows 10 as template VM, and a corresponding AppVM worked too. - -File copy operations to a Windows 10 VM are possible, if the Qubes OS `default_user` property is set to the user name used for access to that VM, which can be done via the command -~~~ -qvm-prefs default_user -~~~ -If this property is not set or set to a wrong value, files copied to this VM are stored in the folder -~~~ -C:\Windows\System32\config\systemprofile\Documents\QubesIncoming\ -~~~ -If the target VM is an AppVM, this has the consequence that the files are stored in the corresponding TemplateVM and so are lost on AppVM shutdown. Windows as TemplateVM --------------------- From 4fc518c3792d176d5d8c1d107a5acb5a21c45536 Mon Sep 17 00:00:00 2001 From: deeplow Date: Sat, 26 Sep 2020 15:54:46 -0400 Subject: [PATCH 097/136] moved xen drivers and QWT info to windows-tools.md --- os-guides/windows/windows-tools.md | 30 ++++++++++++++++++++++++++++++ os-guides/windows/windows-vm.md | 30 ------------------------------ 2 files changed, 30 insertions(+), 30 deletions(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index d313175..58cbba6 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -148,6 +148,36 @@ NOTE: it is recommended to increase the default value of Windows VM's `qrexec_ti qvm-prefs -s qrexec_timeout 300 ~~~ +Xen PV drivers and Qubes Windows Tools +-------------------------------------- + +Installing Xen's PV drivers in the VM will lower its resources usage when using network and/or I/O intensive applications, but *may* come at the price of system stability (although Xen's PV drivers on a Win7 VM are usually very stable). There are two ways of installing the drivers: + +1. installing the drivers independently, from Xen's [official site](https://www.xenproject.org/developers/teams/windows-pv-drivers.html) +2. installing Qubes Windows Tools (QWT), which bundles Xen's PV drivers. + +Notes about using Xen's VBD (storage) PV driver: +- **Windows 7:** installing the driver requires a fully updated VM or else you'll likely get a BSOD and a VM in a difficult to fix state. Updating Windows takes *hours* and for casual usage there isn't much of a performance between the disk PV driver and the default one; so there is likely no need to go through the lengthy Windows Update process if your VM doesn't have access to untrusted networks and if you don't use I/O intensive apps. If you plan to update your newly installed Windows VM it is recommended that you do so *before* installing Qubes Windows Tools (QWT). If QWT are installed, you should temporarily re-enable the standard VGA adapter in Windows and disable Qubes' (see the section above). +- the option to install the storage PV driver is disabled by default in Qubes Windows Tools +- in case you already had QWT installed without the storage PV driver and you then updated the VM, you may then install the driver from Xen's site (xenvbd.tar). + +**Caution:** Installing the version 9.0.0 Xen drivers on Windows 7 (a system without QWT - QWT uninstalled) leads to an unbootable system. The drivers install without error, but after reboot, the system aborts the reboot saying ´Missing driver xenbus.sys´. + +- **Windows 10:** The version 9.0.0 Xen drivers have to be installed before installing Qubes Windows Tools. Installing them on a system with QWT installed is likely to produce a system which crashes or has the tools in a non-functional state. Even if the tools were installed and then removed before installing the Xen drivers, they probably will not work as expected. + + +Installing Qubes Windows Tools: +- on R3.2: see [this page](/doc/windows-tools/) +- R4.0: you'll have to install QWT for Qubes R3.2. Be warned that QWT on R4.0 is a work in progress though (see [issue #3585](https://github.com/QubesOS/qubes-issues/issues/3585) for instructions and known issues). + + +With Qubes Windows Tools installed the early graphical console provided in debugging mode isn't needed anymore since Qubes' display driver will be used instead of the default VGA driver: + +~~~ +qvm-prefs -s win7new debug false +~~~ + + Using Windows AppVMs in seamless mode ------------------------------------- diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 59b6e28..1ac220b 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -252,36 +252,6 @@ Note: if you already have Qubes Windows Tools installed the video adapter in Win To avoid guessing the VM's state enable debugging (`qvm-prefs -s win7new debug true`) and in Windows' device manager (My computer -> Manage / Device manager / Display adapters) temporarily re-enable the standard VGA adapter and disable "Qubes video driver". You can disable debugging and revert to Qubes' display once the VM is updated. -Xen PV drivers and Qubes Windows Tools ------------------------------------- - -Installing Xen's PV drivers in the VM will lower its resources usage when using network and/or I/O intensive applications, but *may* come at the price of system stability (although Xen's PV drivers on a Win7 VM are usually very stable). There are two ways of installing the drivers: - -1. installing the drivers independently, from Xen's [official site](https://www.xenproject.org/developers/teams/windows-pv-drivers.html) -2. installing Qubes Windows Tools (QWT), which bundles Xen's PV drivers. - -Notes about using Xen's VBD (storage) PV driver: -- **Windows 7:** installing the driver requires a fully updated VM or else you'll likely get a BSOD and a VM in a difficult to fix state. Updating Windows takes *hours* and for casual usage there isn't much of a performance between the disk PV driver and the default one; so there is likely no need to go through the lengthy Windows Update process if your VM doesn't have access to untrusted networks and if you don't use I/O intensive apps. If you plan to update your newly installed Windows VM it is recommended that you do so *before* installing Qubes Windows Tools (QWT). If QWT are installed, you should temporarily re-enable the standard VGA adapter in Windows and disable Qubes' (see the section above). -- the option to install the storage PV driver is disabled by default in Qubes Windows Tools -- in case you already had QWT installed without the storage PV driver and you then updated the VM, you may then install the driver from Xen's site (xenvbd.tar). - -**Caution:** Installing the version 9.0.0 Xen drivers on Windows 7 (a system without QWT - QWT uninstalled) leads to an unbootable system. The drivers install without error, but after reboot, the system aborts the reboot saying ´Missing driver xenbus.sys´. - -- **Windows 10:** The version 9.0.0 Xen drivers have to be installed before installing Qubes Windows Tools. Installing them on a system with QWT installed is likely to produce a system which crashes or has the tools in a non-functional state. Even if the tools were installed and then removed before installing the Xen drivers, they probably will not work as expected. - - -Installing Qubes Windows Tools: -- on R3.2: see [this page](/doc/windows-tools/) -- R4.0: you'll have to install QWT for Qubes R3.2. Be warned that QWT on R4.0 is a work in progress though (see [issue #3585](https://github.com/QubesOS/qubes-issues/issues/3585) for instructions and known issues). - - -With Qubes Windows Tools installed the early graphical console provided in debugging mode isn't needed anymore since Qubes' display driver will be used instead of the default VGA driver: - -~~~ -qvm-prefs -s win7new debug false -~~~ - - Further customization --------------------- From dc2ed98225a1ecdeeabeba9f90fdbe76761a9217 Mon Sep 17 00:00:00 2001 From: deeplow Date: Sat, 26 Sep 2020 15:56:56 -0400 Subject: [PATCH 098/136] remove self-referencing note --- os-guides/windows/windows-tools.md | 5 ----- 1 file changed, 5 deletions(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index 58cbba6..86fff9c 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -166,11 +166,6 @@ Notes about using Xen's VBD (storage) PV driver: - **Windows 10:** The version 9.0.0 Xen drivers have to be installed before installing Qubes Windows Tools. Installing them on a system with QWT installed is likely to produce a system which crashes or has the tools in a non-functional state. Even if the tools were installed and then removed before installing the Xen drivers, they probably will not work as expected. -Installing Qubes Windows Tools: -- on R3.2: see [this page](/doc/windows-tools/) -- R4.0: you'll have to install QWT for Qubes R3.2. Be warned that QWT on R4.0 is a work in progress though (see [issue #3585](https://github.com/QubesOS/qubes-issues/issues/3585) for instructions and known issues). - - With Qubes Windows Tools installed the early graphical console provided in debugging mode isn't needed anymore since Qubes' display driver will be used instead of the default VGA driver: ~~~ From 4caf193d7f7e5f2c59328a6d2a3e41fd92c5b594 Mon Sep 17 00:00:00 2001 From: deeplow <47065258+deeplow@users.noreply.github.com> Date: Sat, 26 Sep 2020 21:09:18 +0000 Subject: [PATCH 099/136] formatting typo --- os-guides/windows/windows-tools.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index 86fff9c..47cbf11 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -65,7 +65,7 @@ TODO available features 2. Use an archive extractor like [7-zip](https://www.7-zip.org/) to extract the contents of the `.tar` files. - 3. - Install `xenvbd` and `xenbus` by starting the file `dpinst.exe` from the `x64` directories of the extracted tar-files. If during installation, the Xen driver requests a reboot, select "No" and let the installation continue. + 3. Install `xenvbd` and `xenbus` by starting the file `dpinst.exe` from the `x64` directories of the extracted tar-files. If during installation, the Xen driver requests a reboot, select "No" and let the installation continue. 4. After installation, reboot. From c9537f4ed41bf81303aa1adfd3380d019256300e Mon Sep 17 00:00:00 2001 From: deeplow <47065258+deeplow@users.noreply.github.com> Date: Sat, 26 Sep 2020 21:10:08 +0000 Subject: [PATCH 100/136] formatting typo --- os-guides/windows/windows-tools.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index 47cbf11..027270b 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -85,7 +85,7 @@ TODO available features 9. On a `dom0` terminal write: *(where `` is the name of your Windows 10 VM)* - `qvm-features gui 1` + qvm-features gui 1 10. Reboot Windows. If the VM starts, but does not show any window then shutdown Windows from the Qube manager and reboot Windows once more. From 9031f98a3964ee70ce032b86a08b87d85e34ce52 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sun, 27 Sep 2020 13:27:13 +0200 Subject: [PATCH 101/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 1ac220b..865676d 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -119,7 +119,7 @@ MS Windows versions considerations: - The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x -- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described below. +- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [https://www.qubes-os.org/doc/windows-tools/](https://www.qubes-os.org/doc/windows-tools/). Create a VM named win7new in [HVM](/doc/hvm/) mode (Xen's current PVH limitations precludes from using PVH): @@ -217,8 +217,7 @@ Windows as TemplateVM Windows 7 and 10 can be installed as TemplateVM by selecting ~~~ -qvm-create --class TemplateVM --property virt_mode=HVM --property kernel='' --label black Windows-7 -qvm-create --class TemplateVM --property virt_mode=HVM --property kernel='' --label black Windows-10 +qvm-create --class TemplateVM --property virt_mode=HVM --property kernel='' --label black Windows-template ~~~ when creating the VM. To have the user data stored in AppVMs depending on this template, Windows 7 and 10 have to be treated differently: From c84cc303f83e7d377af8362de061c4f1446d8cd6 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sun, 27 Sep 2020 13:27:38 +0200 Subject: [PATCH 102/136] Update windows-tools.md --- os-guides/windows/windows-tools.md | 25 +++++++++++++++---------- 1 file changed, 15 insertions(+), 10 deletions(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index 027270b..5d01c4e 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -44,7 +44,7 @@ Qubes Windows Tools are open source and are distributed under a GPL license. NOTES: - Qubes Windows Tools are currently unmaintained -- Currently only 64-bit versions of Windows 7 are supported by Qubes Windows Tools. Only emulated SVGA GPU is supported (although [there has been reports](https://groups.google.com/forum/#!topic/qubes-users/cmPRMOkxkdA) on working GPU passthrough). +- Currently only 64-bit versions of Windows 7 and Windows 10 are supported by Qubes Windows Tools. Only emulated SVGA GPU is supported (although [there has been reports](https://groups.google.com/forum/#!topic/qubes-users/cmPRMOkxkdA) on working GPU passthrough). - __This page documents the process of installing Qubes Windows Tools on versions up to R3.2.__. Installation on Qubes R4.0 is possible but is a work in progress and there are limitations/bugs (see [issue #3585](https://github.com/QubesOS/qubes-issues/issues/3585)). Installing Windows OS in a Qubes VM @@ -57,9 +57,9 @@ NOTE: It is strongly suggested to enable autologon for any Windows HVMs that wil Installing Qubes guest tools in Windows 10 VMs ---------------------------------------------- -This will allow you to installs the Qubes Windows Tools on Windows 10 both as a StandaloneVM as well as a template VM and a corresponding AppVM. But some features are not available: +This will allow you to install the Qubes Windows Tools on Windows 10 both as a StandaloneVM as well as a Template VM and a corresponding AppVM. But some features are not available: -TODO available features +TODO available features - **not available: seamless mode - others?** 1. In the Windows 10 VM, download from the [XEN website](https://xenproject.org/downloads/windows-pv-drivers/windows-pv-drivers-9-series/windows-pv-drivers-9-0-0/) the installation kits for Xen bus (`xenbus`) and storage drivers (`xenvbd`) Version 9.0.0 (two files`xenvbd.tar`and `xenbus.tar`). @@ -92,8 +92,8 @@ TODO available features 11. Now the system should be up, with QWT running correctly. 12. Lastly to enable file copy operations to a Windows 10 VM the `default_user` property should be set the `` that you use to login to the Windows VM. This can be done via the following command on a `dom0` terminal: *(where `` is the name of your Windows 10 VM)* - - qvm-prefs win10 default_user + + `qvm-prefs default_user ` > **Note:** If this property is not set or set to a wrong value, files copied to this VM are stored in the folder `C:\Windows\System32\config\systemprofile\Documents\QubesIncoming\`. > If the target VM is an AppVM, this has the consequence that the files are stored in the corresponding TemplateVM and so are lost on AppVM shutdown. @@ -161,7 +161,7 @@ Notes about using Xen's VBD (storage) PV driver: - the option to install the storage PV driver is disabled by default in Qubes Windows Tools - in case you already had QWT installed without the storage PV driver and you then updated the VM, you may then install the driver from Xen's site (xenvbd.tar). -**Caution:** Installing the version 9.0.0 Xen drivers on Windows 7 (a system without QWT - QWT uninstalled) leads to an unbootable system. The drivers install without error, but after reboot, the system aborts the reboot saying ´Missing driver xenbus.sys´. +**Caution:** Installing the version 9.0.0 Xen drivers on Windows 7 (a system without QWT - QWT uninstalled) leads to an unbootable system. The drivers install without error, but after reboot, the system aborts the reboot saying `Missing driver xenbus.sys`. - **Windows 10:** The version 9.0.0 Xen drivers have to be installed before installing Qubes Windows Tools. Installing them on a system with QWT installed is likely to produce a system which crashes or has the tools in a non-functional state. Even if the tools were installed and then removed before installing the Xen drivers, they probably will not work as expected. @@ -217,7 +217,7 @@ Qubes allows HVM VMs to share a common root filesystem from a select Template VM In order to create a HVM TemplateVM one can use the following command, suitably adapted: ~~~ -qvm-create --class TemplateVM win7-x64-template --property virt_mode=HVM --property kernel='' -l green +qvm-create --class TemplateVM win-template --property virt_mode=HVM --property kernel='' -l green ~~~ ... , set memory as appropriate, and install Windows OS (or other OS) into this template the same way as you would install it into a normal HVM -- please see instructions on [this page](/doc/hvm-create/). @@ -227,7 +227,7 @@ If you use this Template as it is, then any HVMs that use it will effectively be If you want to retain the User directory between reboots, then it would make sense to store the `C:\Users` directory on the 2nd disk which is automatically exposed by Qubes to all HVMs. This 2nd disk is backed by the `private.img` file in the AppVMs' and is not reset upon AppVMs reboot, so the user's directories and profiles would survive the AppVMs reboot, unlike the "root" filesystem which will be reverted to the "golden image" from the Template VM automatically. To facilitate such separation of user profiles, Qubes Windows Tools provide an option to automatically move `C:\Users` directory to the 2nd disk backed by `private.img`. -It's a selectable feature of the installer, enabled by default. +It's a selectable feature of the installer, enabled by default, but working only for Windows 7. If that feature is selected during installation, completion of the process requires two reboots: - The private disk is initialized and formatted on the first reboot after tools installation. It can't be done **during** the installation because Xen mass storage drivers are not yet active. @@ -236,8 +236,13 @@ Reboot is required because the "mover utility" runs very early in the boot proce This can take some time depending on the profiles' size and because the GUI agent is not yet active dom0/Qubes Manager may complain that the AppVM failed to boot. That's a false alarm (you can increase AppVM's default boot timeout using `qvm-prefs`), the VM should appear "green" in Qubes Manager shortly after. -It also makes sense to disable Automatic Updates for all the template-based AppVMs -- of course this should be done in the Template VM, not in individual AppVMs, because the system-wide settings are stored in the root filesystem (which holds the system-wide registry hives). -Then, periodically check for updates in the Template VM and the changes will be carried over to any child AppVMs. +For Windows 10, the user directories have to be moved manually, because the automatic transfer during QWT installation is bound to crash due to undocumented new features of NTFS, and a system having the directory `users`on another disk than `C:` will break on Windows update. So the following steps should be taken: + +- The Windows disk manager may be used to add the private volume as disk `D:`, and you may, using the documented Windows operations, move the user directories `C:\users\\Documents` to this new disk, allowing depending AppVMs to have their own private volumes. Moving the hidden application directories `AppData`, however, is likely to invite trouble - the same trouble that occurs if, during QWT installation, the option `Move user profiles` is selected. + +- Configuration data like those stored in directories like `AppData` still remain in the TemplateVM, such that their changes are lost each time the AppVM shuts down. In order to make permanent changes to these configuration data, they have to be changed in the TemplateVM, meaning that applications have to be started there, which violates and perhaps even endangers the security of the TemplateVM. Such changes should be done only if absolutely necessary and with great care. It is a good idea to test them first in a cloned TemplateVM before applying them in the production VM. + +It also makes sense to disable Automatic Updates for all the template-based AppVMs -- of course this should be done in the Template VM, not in individual AppVMs, because the system-wide settings are stored in the root filesystem (which holds the system-wide registry hives). Then, periodically check for updates in the Template VM and the changes will be carried over to any child AppVMs. Once the template has been created and installed it is easy to create AppVMs based on it: From b47bf5f325eb4adb7460639cae39459d530a7fc2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Pierret=20=28fepitre=29?= Date: Sun, 27 Sep 2020 14:19:02 +0200 Subject: [PATCH 103/136] Add Gentoo template related - Specific release note will follow later QubesOS/qubes-issues#4412 --- os-guides/gentoo.md | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 os-guides/gentoo.md diff --git a/os-guides/gentoo.md b/os-guides/gentoo.md new file mode 100644 index 0000000..18f0e46 --- /dev/null +++ b/os-guides/gentoo.md @@ -0,0 +1,36 @@ +--- +layout: doc +title: Gentoo Template +permalink: /doc/templates/gentoo/ +--- + +# Gentoo Template + +If you would like to use a stable, predictable, manageable and reproducible distribution in your AppVMs, you can install the Gentoo template, provided by Qubes in ready to use binary package. + +For the minimal version, please see [Minimal TemplateVMs](/doc/templates/minimal/) + + +## Installation + +The standard Gentoo TemplateVM can be installed with the following command in dom0: + + [user@dom0 ~]$ sudo qubes-dom0-update --enablerepo=qubes-templates-community qubes-template-gentoo + +To switch, reinstall and uninstall a Gentoo TemplateVM that is already installed in your system, see *How to [switch], [reinstall] and [uninstall]*. + +#### After Installing + +After a fresh install, we recommend to [Update the TemplateVM](/doc/software-update-vm/). + +## Want to contribute? + +* [How can I contribute to the Qubes Project?](/doc/contributing/) + +* [Guidelines for Documentation Contributors](/doc/doc-guidelines/) + +[switch]: /doc/templates/#switching +[reinstall]: /doc/reinstall-template/ +[uninstall]: /doc/templates/#uninstalling + + From 9bc676cfeb325dc7ec41554ea7b290a813776eb5 Mon Sep 17 00:00:00 2001 From: deeplow Date: Sun, 27 Sep 2020 15:26:45 -0400 Subject: [PATCH 104/136] remove TODO on feature availability --- os-guides/windows/windows-tools.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index 5d01c4e..72640ba 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -59,7 +59,7 @@ Installing Qubes guest tools in Windows 10 VMs This will allow you to install the Qubes Windows Tools on Windows 10 both as a StandaloneVM as well as a Template VM and a corresponding AppVM. But some features are not available: -TODO available features - **not available: seamless mode - others?** +> **Note:** seamless mode is currently not available for windows. Please check the top of this document for the full feature availability breakdown. 1. In the Windows 10 VM, download from the [XEN website](https://xenproject.org/downloads/windows-pv-drivers/windows-pv-drivers-9-series/windows-pv-drivers-9-0-0/) the installation kits for Xen bus (`xenbus`) and storage drivers (`xenvbd`) Version 9.0.0 (two files`xenvbd.tar`and `xenbus.tar`). From e8926c03faa4227241caf8bd8827209eaf0d35c6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Pierret=20=28fepitre=29?= Date: Mon, 28 Sep 2020 00:18:16 +0200 Subject: [PATCH 105/136] Update XFCE related templates --- os-guides/centos.md | 8 +++----- os-guides/gentoo.md | 8 +++----- 2 files changed, 6 insertions(+), 10 deletions(-) diff --git a/os-guides/centos.md b/os-guides/centos.md index 5b1c9d6..6159590 100644 --- a/os-guides/centos.md +++ b/os-guides/centos.md @@ -6,9 +6,7 @@ permalink: /doc/templates/centos/ # CentOS Template -If you would like to use a stable, predictable, manageable and reproducible distribution in your AppVMs, you can install the CentOS template, provided by Qubes in ready to use binary package. - -For the minimal version, please see [Minimal TemplateVMs](/doc/templates/minimal/) +If you would like to use a stable, predictable, manageable and reproducible distribution in your AppVMs, you can install the CentOS template, provided by Qubes in ready to use binary package. For the minimal and Xfce versions, please see the [Minimal TemplateVMs] and [Xfce TemplateVMs] pages. ## Installation @@ -32,5 +30,5 @@ After a fresh install, we recommend to [Update the TemplateVM](/doc/software-upd [switch]: /doc/templates/#switching [reinstall]: /doc/reinstall-template/ [uninstall]: /doc/templates/#uninstalling - - +[Minimal TemplateVMs]: /doc/templates/minimal/ +[Xfce TemplateVMs]: /doc/templates/xfce/ diff --git a/os-guides/gentoo.md b/os-guides/gentoo.md index 18f0e46..abed83c 100644 --- a/os-guides/gentoo.md +++ b/os-guides/gentoo.md @@ -6,9 +6,7 @@ permalink: /doc/templates/gentoo/ # Gentoo Template -If you would like to use a stable, predictable, manageable and reproducible distribution in your AppVMs, you can install the Gentoo template, provided by Qubes in ready to use binary package. - -For the minimal version, please see [Minimal TemplateVMs](/doc/templates/minimal/) +If you would like to use a stable, predictable, manageable and reproducible distribution in your AppVMs, you can install the Gentoo template, provided by Qubes in ready to use binary package. For the minimal and Xfce versions, please see the [Minimal TemplateVMs] and [Xfce TemplateVMs] pages. ## Installation @@ -32,5 +30,5 @@ After a fresh install, we recommend to [Update the TemplateVM](/doc/software-upd [switch]: /doc/templates/#switching [reinstall]: /doc/reinstall-template/ [uninstall]: /doc/templates/#uninstalling - - +[Minimal TemplateVMs]: /doc/templates/minimal/ +[Xfce TemplateVMs]: /doc/templates/xfce/ From ab0344af6e6d7a48dfe0db28355809576d533d02 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Mon, 28 Sep 2020 12:42:09 +0200 Subject: [PATCH 106/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 865676d..f488d78 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -119,7 +119,7 @@ MS Windows versions considerations: - The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x -- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [https://www.qubes-os.org/doc/windows-tools/](https://www.qubes-os.org/doc/windows-tools/). +- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [Qubes Wndows Tools](/doc/windows-tools/). Create a VM named win7new in [HVM](/doc/hvm/) mode (Xen's current PVH limitations precludes from using PVH): From e5c021063fce9723052e49acc945e6ce0fd77b68 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Mon, 28 Sep 2020 12:42:22 +0200 Subject: [PATCH 107/136] Update windows-tools.md --- os-guides/windows/windows-tools.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index 72640ba..9063269 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -25,7 +25,7 @@ Qubes Windows Tools are a set of programs and drivers that provide integration o - **Copy/Edit in Dipostable VM** - Support for editing files in DisposableVMs as well as for qvm-run and generic qrexec for the Windows VM (e.g. ability to run custom service within/from the Windows VM) - **Xen PV drivers** for Windows that increase performance compared to qemu emulated devices -Bellow is a breakdown of the feature availablility depending on the windows version: +Below is a breakdown of the feature availablility depending on the windows version: | Feature | Windows 7 x64 | Windows 10 x64 | | ------------------------------------ | :------------: | :------------: | @@ -69,7 +69,7 @@ This will allow you to install the Qubes Windows Tools on Windows 10 both as a S 4. After installation, reboot. - 5. Download the Qubes Windows Tools (`qubes-tools-4.0.1.3.exe`) from [the qubes FTP server](TODO add ftp link) and move it to `C:\`. + 5. Download the Qubes Windows Tools (`qubes-tools-4.0.1.3.exe`) from [the qubes FTP server](https://ftp.qubes-os.org/qubes-windows-tools/) and move it to `C:\`. 6. Check the integrity of the file `qubes-tools-4.0.1.3.exe`by comparing its hash checksum. This can be done using the Windows command `certutil` on the windows command prompt (`cmd.exe`) and specifying an appropriate hash algorithm like: From f10412956b85bdc315f02cbcdab66e7e842e49a5 Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Fri, 2 Oct 2020 04:06:07 +0100 Subject: [PATCH 108/136] Add Installation Troubleshooting, move files --- troubleshooting/install-nvidia-driver.md | 177 ---------- troubleshooting/intel-igfx-troubleshooting.md | 65 ---- troubleshooting/macbook-troubleshooting.md | 328 ------------------ troubleshooting/nvidia-troubleshooting.md | 159 --------- troubleshooting/out-of-memory.md | 46 --- troubleshooting/remove-vm-manually.md | 36 -- troubleshooting/sony-vaio-tinkering.md | 58 ---- troubleshooting/thinkpad-troubleshooting.md | 94 ----- troubleshooting/updating-debian-and-whonix.md | 138 -------- troubleshooting/wireless-troubleshooting.md | 121 ------- 10 files changed, 1222 deletions(-) delete mode 100644 troubleshooting/install-nvidia-driver.md delete mode 100644 troubleshooting/intel-igfx-troubleshooting.md delete mode 100644 troubleshooting/macbook-troubleshooting.md delete mode 100644 troubleshooting/nvidia-troubleshooting.md delete mode 100644 troubleshooting/out-of-memory.md delete mode 100644 troubleshooting/remove-vm-manually.md delete mode 100644 troubleshooting/sony-vaio-tinkering.md delete mode 100644 troubleshooting/thinkpad-troubleshooting.md delete mode 100644 troubleshooting/updating-debian-and-whonix.md delete mode 100644 troubleshooting/wireless-troubleshooting.md diff --git a/troubleshooting/install-nvidia-driver.md b/troubleshooting/install-nvidia-driver.md deleted file mode 100644 index 97b8826..0000000 --- a/troubleshooting/install-nvidia-driver.md +++ /dev/null @@ -1,177 +0,0 @@ ---- -layout: doc -title: How to Install an Nvidia Driver -permalink: /doc/install-nvidia-driver/ -redirect_from: -- /en/doc/install-nvidia-driver/ -- /doc/InstallNvidiaDriver/ -- /wiki/InstallNvidiaDriver/ ---- - -# Nvidia proprietary driver installation - -You can use rpm packages from rpmfusion, or you can build the driver yourself. - -## Word of Caution - -Proprietary (NVIDIA/AMD) drivers are known to be sometimes highly problematic, or completely unsupported. -Radeon driver support is prebaked in the Qubes kernel (v4.4.14-11) but only versions 4000-9000 give or take. -Support for newer cards is limited until AMDGPU support in the 4.5+ kernel, which isn't released yet for Qubes. - -Built in Intel graphics, Radeon graphics (between that 4000-9000 range), and perhaps some prebaked NVIDIA card support that I don't know about. Those are your best bet for great Qubes support. - -If you do happen to get proprietary drivers working on your Qubes system (via installing them), please take the time to go to the -[Hardware Compatibility List (HCL)](/doc/hcl/#generating-and-submitting-new-reports ) -Add your computer, graphics card, and installation steps you did to get everything working. - -Before continuing, you may wish to try the `kernel-latest` package from the `current` repository. This kernel may better support your card and if so, you would not have to rely on proprietary drivers. This can be installed from dom0 with: -~~~ -sudo qubes-dom0-update kernel-latest -~~~ - -## RpmFusion packages - -There are rpm packages with all necessary software on rpmfusion. The only package you have to compile is the kernel module (but there is a ready built src.rpm package). - -### Download packages - -You will need any Fedora 18 system to download and build packages. You can use Qubes AppVM for it, but it isn't necessary. To download packages from rpmfusion - add this repository to your yum configuration (instructions are on their website). Then download packages using yumdownloader: - -~~~ -yumdownloader --resolve xorg-x11-drv-nvidia -yumdownloader --source nvidia-kmod -~~~ - -### Build kernel package - -You will need at least kernel-devel (matching your Qubes dom0 kernel), rpmbuild tool and kmodtool, and then you can use it to build the package: - -~~~ -yum install kernel-devel rpm-build kmodtool -rpmbuild --nodeps -D "kernels `uname -r`" --rebuild nvidia-kmod-260.19.36-1.fc13.3.src.rpm -~~~ - -In the above command, replace `uname -r` with kernel version from your Qubes dom0. If everything went right, you have now complete packages with nvidia drivers for the Qubes system. Transfer them to dom0 (e.g. using a USB stick) and install (using standard "yum install /path/to/file"). - -Then you need to disable nouveau (normally it is done by install scripts from nvidia package, but unfortunately it isn't compatible with Qubes...): - -Edit /etc/default/grub: - -~~~ -GRUB_CMDLINE_LINUX="quiet rhgb nouveau.modeset=0 rd.driver.blacklist=nouveau video=vesa:off" -~~~ - -Regenerate grub configuration: - -~~~ -grub2-mkconfig -o /boot/grub2/grub.cfg -~~~ - -Reboot. - - - -## Manual installation - -This process is quite complicated: First - download the source from nvidia.com site. Here "NVIDIA-Linux-x86\_64-260.19.44.run" is used. Copy it to dom0. Every next step is done in dom0. - -See [this page](/doc/copy-to-dom0/) for instructions on how to transfer files to Dom0 (where there is normally no networking). - -**WARNING**: Nvidia doesn't sign their files. To make it worse, you are forced to download them over a plaintext connection. This means there are virtually dozens of possibilities for somebody to modify this file and provide you with a malicious/backdoored file. You should realize that installing untrusted files into your Dom0 is a bad idea. Perhaps it might be a better idea to just get a new laptop with integrated Intel GPU? You have been warned. - - - -### Userspace components - -Install libraries, Xorg driver, configuration utilities. This can by done by nvidia-installer: - -~~~ -./NVIDIA-Linux-x86_64-260.19.44.run --ui=none --no-x-check --keep --no-nouveau-check --no-kernel-module -~~~ - -### Kernel module - -You will need: - -- nvidia kernel module sources (left from previous step) -- kernel-devel package installed -- gcc, make, etc - -This installation must be done manually, because nvidia-installer refused to install it on Xen kernel. Firstly ensure that kernel-devel package installed all needed files. This should consist of: - -- */usr/src/kernels/2.6.34.1-12.xenlinux.qubes.x86\_64* -- */lib/modules/2.6.34.1-12.xenlinux.qubes.x86\_64/build* symlinked to the above directory -- */usr/src/kernels/2.6.34.1-12.xenlinux.qubes.x86\_64/arch/x64/include/mach-xen* should be present (if not - take it from kernel sources) - -If all the files are not there correct the errors manually. To build the kernel module, enter *NVIDIA-Linux-x86\_64-260.19.44/kernel* directory and execute: - -~~~ -make -IGNORE_XEN_PRESENCE=1 CC="gcc -DNV_VMAP_4_PRESENT -DNV_SIGNAL_STRUCT_RLIM" make -f Makefile.kbuild -mv /lib/modules/2.6.34.1-12.xenlinux.qubes.x86_64/kernel/drivers/video/nvidia.ko /lib/modules/2.6.34.1-12.xenlinux.qubes.x86_64/extra/ -~~~ - -Ignore any errors while inserting nvidia.ko (at the end of make phase). - -### Disable nouveau: - -~~~ -cat /etc/modprobe.d/nouveau-disable.conf -# blacklist isn't enough... -install nouveau /bin/true -~~~ - -Add *rdblacklist=nouveau* option to /boot/grub/menu.lst (at the end of line containing *vmlinuz*). - -### Configure Xorg - -Finally, you should configure Xorg to use nvidia driver. You can use *nvidia-xconfig* or do it manually: - -~~~ -X -configure -mv /root/xorg.conf.new /etc/X11/xorg.conf -# replace Driver in Device section by "nvidia" -~~~ - -Reboot to verify all this works. - -# Troubleshooting lack of video output during installation - -Specifically, the notes below are aimed to help when the GRUB menu shows up fine, the installation environment starts loading, and then the display(s) go into standby mode. This is, typically, related to some sort of an issue with the kernel's KMS/video card modules. - -## Initial setup. -*Note*: The steps below do *not* produce a fully-functional Qubes OS install. Rather, only a dom0 instance is functional, and there is no networking there. However, they can be used to gather data in order to troubleshoot video card issues and/or possible other basic kernel module issues. - -1. Append `nomodeset ip=dhcp inst.nokill inst.vnc` to the kernel command line. Remove `rhgb` and `quiet` to see the kernel messages scroll by, which may help in further diagnostics. - * If DHCP is not available on the installation network, the syntax becomes a bit more involved. The full list of variants is documented in the [Dracut Command-line parameters] (http://man7.org/linux/man-pages/man7/dracut.cmdline.7.html) -2. The VGA console should switch into the installer's multi-virtual-terminal display. VNC may take a number of minutes to start, please be patient. - * Using the anaconda installer interface, switch to the "shell" TTY (ALT-F2), and use `ip a` command to display the IP addresses. -3. Using the Connect to the IP (remember the :1) using a VNC viewer. -4. Follow the installation UI. - * Since this won't be a usable install, skipping LUKS encryption is an option which will simplify this troubleshooting process. - * Do *not* reboot at the end of the installation. -5. Once the installation completes, use the local VGA console switch to TTY2 via ALT-F2 - * Switch to the chroot of the newly-installed system via `chroot /mnt/sysinstall` - * Set the root password (this will also enable the root account login) - * Double-check that `/boot/grub2/grub.cfg` contains a `nomodeset` kernel parameter. - * Exit out of the chroot environment (`exit` or CTRL-D) -6. Reboot - -*Note* If the kernel parameters do *not* include `quiet` and `rhgb`, the kernel messages can easily obscure the LUKS passphrase prompt. Additionally, each character entered will cause the LUKS passphrase prompt to repeat onto next line. Both of these are cosmetic. The trade-off between kernel messages and the easy-to-spot LUKS passphrase prompt is left as an exercise to the user. - -## Gather initial `dmesg` output -If all is well, the newly-installed Qubes OS instance should allow for user root to log in. -Run `dmesg > dmesg.nomodeset.out` to gather an initial dmesg output. - -## Gather the 'video no worky' `dmesg` output -1. Reboot and interrupt the Grub2's process, modifying the kernel parameters to no longer contain `nomodeset`. - * If the LUKS passphrase was set, blindly enter it. -2. Wait for the system to finish booting (about 5 minutes, typically). -3. Blindly switch to a TTY via CTRL-ALT-F2. -4. Blindly log in as user root -5. Blindly run `dmesg > dmesg.out` -6. Blindly run `reboot` (this will also serve to confirm that logging in as root, and running commands blindly is possible rather than, say, the kernel having hung or some such). - * Should this step fail, perhaps by the time step #3 was undertaken, the OS hasn't finished coming up yet. Please retry, possibly with a different TTY (say, 3 or 4 - so CTRL-ALT-F3?) - -## Exfiltrate the dmesg outputs -Allow the system to boot normally, log in as user root, and sneakernet the files off the system for analysis, review, bug logging, et cetera. diff --git a/troubleshooting/intel-igfx-troubleshooting.md b/troubleshooting/intel-igfx-troubleshooting.md deleted file mode 100644 index 03014eb..0000000 --- a/troubleshooting/intel-igfx-troubleshooting.md +++ /dev/null @@ -1,65 +0,0 @@ ---- -layout: doc -title: Intel Integrated Graphics Troubleshooting -permalink: /doc/intel-igfx-troubleshooting/ ---- -# Intel Integrated Graphics Troubleshooting # - -## Software Rendering or Video Lags - -If you are experiencing this issue, you will see extremely slow graphics updates. -You will be able to watch the screen and elements paint slowly from top to bottom. -You can confirm this is the issue by looking for a line similar to the following in your `/var/log/Xorg.0.log` file: - - [ 131.769] (EE) AIGLX: reverting to software rendering - -Newer versions of the Linux kernel have renamed the `i915.preliminary_hw_support=1` option to `i915.alpha_support=1`, so if you needed this kernel option in the past you will have to rename it or add it to your configuration files (follow either GRUB2 or EFI, not both): - - * GRUB2: `/etc/default/grub`, `GRUB_CMDLINE_LINUX` line and - Rebuild grub config (`grub2-mkconfig -o /boot/grub2/grub.cfg`) - * EFI: `/boot/efi/EFI/qubes/xen.cfg`, `kernel=` line(s) - - -## IOMMU ## - -Dom0 Kernels currently included in Qubes have issues related to VT-d (IOMMU) and some versions of the integrated Intel Graphics Chip. -Depending on the specific hardware / software combination the issues are quite wide ranging, from apparently harmless log errors, to VM window refresh issues, to complete screen corruption and crashes rendering the machine unusable with Qubes. - -Such issues have been reported on at least the following machines: - -* HP Elitebook 2540p -* Lenovo x201 -* Lenovo x220 -* Thinkpad T410 -* Thinkpad T450s - -Log errors only on : -* Librem 13v1 -* Librem 15v2 - -The installer for Qubes 4.0 final has been updated to disable IOMMU for the integrated intel graphics by default. -However, users of 3.2 may experience issues on install or on kernel upgrades to versions higher than 3.18.x. - -Disabling IOMMU for the integrated graphics chip is not a security issue, as the device currently lives in dom0 and is not passed to a VM. -This behaviour is planned to be changed as of Qubes 4.1, when passthrough capabilities will be required for the GUI domain [1](#f1). - - -## Workaround for existing systems with VT-d enabled (grub / legacy mode) ## - -Edit the startup parameters for Xen: - -1. Open a terminal in dom0 -2. Edit `/etc/default/grub` (e.g. `sudo nano /etc/default/grub`) -3. Add to the line `GRUB_CMDLINE_XEN_DEFAULT` the setting `iommu=no-igfx`, save and quit -4. Commit the change with`sudo grub2-mkconfig --output /boot/grub2/grub.cfg` - -## Workaround for existing systems with VT-d enabled (UEFI) ## - -Edit the startup parameters for Xen: - -1. Open a terminal in dom0 -2. Edit `/boot/efi/EFI/qubes/xen.cfg` (e.g. `sudo nano /boot/efi/EFI/qubes/xen.cfg`) -3. Add to the line `options` the setting `iommu=no-igfx`, save and quit - -1 [↩](#a1-1) - diff --git a/troubleshooting/macbook-troubleshooting.md b/troubleshooting/macbook-troubleshooting.md deleted file mode 100644 index 5743a67..0000000 --- a/troubleshooting/macbook-troubleshooting.md +++ /dev/null @@ -1,328 +0,0 @@ ---- -layout: doc -title: Apple MacBook Troubleshooting -permalink: /doc/macbook-troubleshooting/ ---- - -Apple MacBook Troubleshooting -============================= - -MacBook Air 13" mid 2011 (MacBookAir 4,2) ------------------------------------------ - -In this section, I explain how to install Qubes on a MacBook Air 13" mid 2011 -(MacBookAir 4,2). - -This model has the following features: - -* Dual Intel i7-2677M 1.80 Ghz CPU (2 dual cores) -* Intel HD Graphics 3000 -* 4Gb RAM -* 256Gb SDD -* Broadcom BCM43224 802.11 a/b/g/n wifi and Bluetooth adapter -* Intel DSL2310 Thunderbolt controller -* It has 1 DVI/Thunderbolt display port, 2 USB2.0 ports, a Magsafe power - adapter, a standard 3.5mm audio jack and SD reader. - -I first tried to install Qubes using the UEFI boot, but it failed. Not wanting -to waste too much time, I quickly opted for the legacy BIOS install. - -### 1. Boot from Mac OS X (or Internet Recovery Image with `CMD`+`R` during bootup) - -Run in a terminal [[1]]: - -~~~ -# diskutil list -(find your usb device) -# bless –device /dev/diskX –legacy –setBoot –nextonly # bless the disk not the partition -# reboot -~~~ - -Insert your Qubes 3.2 USB flash drive. The ISOLINUX boot screen should come up. -Install Qubes normally. - -If you try to boot Qubes now, it will freeze while "setting up networking." You -need to put the Broadcom wireless device into PCI passtrough [[2],[3]]. Or, as -an alternative [remove it from your Mac][bluetooth-replacement] and Qubes will -boot up smoothly. If you choose to remove the card, jump to step 3. - -### 2. Boot from Mac OS X again - -Run in a terminal: - -~~~ -# diskutil list -(find your usb device) -# bless –device /dev/diskX –legacy –setBoot –nextonly # bless the disk not the partition -# reboot -~~~ - -Insert your Qubes 3.2 USB flash drive. The ISOLINUX boot screen should come up. -Select Troubleshooting and Boot the Rescue image. Enter your disk password when -prompted. Select continue and after mounting the HD filesystem and launching a -shell, `chroot` as instructed. - -Then find your Bluetooth card: - -~~~ -# lspci -.. -02:00.0 Network controller: Broadcom Corporation BCM43224 802.11a/b/g/n (rev 01) -… -# qvm-pci -a sys-net 02:00.0 # this assigns the device to sys-net VM -~~~ - -Then create `/etc/systemd/system/qubes-pre-netvm.service` with: - -~~~ -[Unit] -Description=Netvm fix for Broadcom -Before=qubes-netvm.service - -[Service] -ExecStart=/bin/sh -c 'echo 02:00.0 > /sys/bus/pci/drivers/pciback/permissive' -Type=oneshot -RemainAfterExit=yes - -[Install] -WantedBy=multi-user.target -~~~ - -Run: - -~~~ -systemctl enable qubes-pre-netvm.service -~~~ - -And that's it. - -### 3. After reboot, boot Mac OS X again - -Run in a terminal: - -~~~ -# diskutil list -(find the HD device where you installed Qubes) -# bless –device /dev/diskX –legacy –setBoot # bless the disk not the partition -# reboot -~~~ - -Results: - -* System booted and running smoothly -* Youtube video: OK (including full screen after configuration) -* Trackpad: OK -* Audio control: OK -* Brightness control: OK -* Keyboard light control:OK -* SD card access: OK (tested at dom0) -* Lid-close suspend: OK -* Wifi: +10%-20% ICMP packet loss when comparing with OSX (have similar rates - with Tails Linux, more tests are required) - -### References - -1. -2. -3. - - -MacBook Air 2012 (MacBookAir 5,1) ---------------------------------- - -Please see [this thread o the qubes-devel mailing list][macbook-air-2012-5-1]. - - -[1]: https://github.com/QubesOS/qubes-issues/issues/794 -[2]: https://github.com/QubesOS/qubes-issues/issues/1261 -[3]: /doc/assigning-devices/ -[bluetooth-replacement]: https://www.ifixit.com/Guide/MacBook+Air+13-Inch+Mid+2011+AirPort-Bluetooth+Card+Replacement/6360 -[macbook-air-2012-5-1]: https://groups.google.com/d/topic/qubes-devel/uLDYGdKk_Dk/discussion - - - -MacBook Pro Retina, 15 inch, Mid-2015 (MacBookPro 11,5) -------------------------------------------------------- - -In this section, I explain how I installed Qubes 3.2 on a MacBook Pro Retina 2015 (MacBookPro 11,5). -Good news: the relevant stuff works. -Bad news: still some minor issue to investigate. - -For the time being, my setup is just for testing purposes and help to bypass some blocking issues: do not use it in production or on machine where security is a concern! -I hope to improve it as soon as possible. - -During my nights trying to get Qubes OS working, I faced two main and blocking issues: -* no boot, due to empty xen.cfg file -* system freeze, due to Broadcom BCM43602 wifi card - -I am already using Qubes for my daily job on Intel NUC. For the time being, I installed Qubes on Macbook for test purposes. Later on I will review the security implications. - -This model has the following features: - -* 2,5 GHz Intel Core i7-4870HQ (2 quad cores) -* Dual Graphic Card - * Intel Iris Pro - * AMD Radeon R9 M370X -* 16Gb RAM -* 512Gb SDD -* Broadcom BCM43602 802.11ac wifi adapter - -### 1. Reclaim space to be able to multiboot OSX - -For security reasons, you should install Qubes using the whole disk. I preferred to keep OSX, so I shrunk OS partition: -* reboot in recovery mode -* run disk utility and shrink OSX partition, eg 150GB for OSX and the remaining space for Qubes OS -* reboot - - -### 2. Boot installer - -Download and prepare a USB with Qubes 3.2 - -You can install Qubes using BIOS or UEFI: -* BIOS/CSM/Legacy: I have not been able to install using legacy, but I did not spend a lot of time on it. -* UEFI plain: grub menu appears, but any gave me a quick flash and returned the main menu. I can boot it manually fixing the grub.cfg file, adding commands linuexefi and initrdefi, pointing proper files in /efi/boot. After boot, I end up with no root file system. -* UEFI, using rEFInd: I have been successful, despite some issues to be fixed manually, after installation completion - * download [rEFInd] refind-bin-0.10.4.zip: this file is not signed, so decide if you trust it or not. SHA1 sum is 3d69c23b7d338419e5559a93cd6ae3ec66323b1e - * unzip it and run installer, which installs rEFIind on the internal SSD - * if installation fails due to SIP, reboot in recovery mode, open a terminal and issue command - ~~~ - csrutil disable - ~~~ - * reboot and you will see some icons - * choose Boot EFI\BOOT\xen.efi from ANACONDA - * after a while the graphical installer is up (keyboard and touchpad working) - -### 3. Installation - -* As a general rule, keep the default values proposed during installation: you can change them later on -* Keep English, as language, locale -* My Macbook has a US keyboard, so I cannot say what happens if you change keyboard layout -* DO NOT CHANGE the timezone, because it will trigger the wifi card, leading to a system freeze -* Choose the "installation destination": do not change anything and press DONE button -* Insert your password for Full Disk Encryption -* If you do not already have free space on internal SSD disk, you will be prompted to reclaim some space: -* If you shrunk OSX partition, disk utility left an empty partition: delete useless partition (e.g.: if you shrunk OSX partition, diskutil created an empty partition) -* Press on "reclaim space" -* Press on "begin installation" -* create your user and password -* after a while, installation completes -* DO NOT press "Reboot button" - -Qubes OS is now installed, but you cannot boot it due to some issues, with bootloader configuration and wifi card. -You cannot Qubes boot using EFI/qubes/xen.efi because XEN bootloader configuration is broken. -You cannot even Qubes without XEN support, using GRUB2, because its configuration is broken too. - -Let's fix it manually, switch to console, pressing Fn+CTRL+ALT+F2 - -### 4. Fix GRUB configuration - -You can skip this section, but I found it very useful - during troubleshooting - to have a rescue system at hand. I could boot Qubes, without XEN support - -Grub configuration file is using some wrong commands, which are not compatible with grub2-efi -~~~ -chroot /mnt/sysimage -sed -i.bak -e "s/multiboot/chainloader/" -e "s/module.*--nounzip/initrdefi/" -e "s/module/linuxefi/" /etc/grub.d/20_linux_efi -exit -~~~ - -Now, despite XEN configuration is still broken, you have a rescue system booting vmlinux from rEFInd screen. -TBV1: chainloading XEN does not work, unless you specify the right disk prefix, eg: (hd1,gpt4) -TBV2: grub.cfg set the wrong disk in "set root" command -TBV3: in case you reach grub shell, you can -~~~ -ls -~~~ -and also reload config file and change it manualy before booting -~~~ -configfile /EFI/qubes/grub.cfg -~~~ -then press "e", edit grub cfg and boot pressing Fn+F10 - - -### 5. Fix bootloader - -* Fix grub2 configuration, which uses wrong command for EFI boot -* analyzing /mnt/sysimage/var/log/anaconda/program.log I found the faulty commands issues by Anaconda installer - -~~~ -chrooot /mnt/sysimage -~~~ -* edit /boot/efi/EFI/qubes/xen.cfg file putting the following content - -~~~ -[global] -default=4.4.14-11.pvops.qubes.x868_64 - -[4.4.14-11.pvops.qubes.x868_64] -options=loglvl=all dom0_mem=min:1024M dom0_mem=max:4096M -kernel=vmlinuz-4.4.14-11.pvops.qubes.x86_64 -ramdisk=initramfs-4.4.14-11.pvops.qubes.x86_64.img -~~~ - -* The main mistake is the efibootmgr, that needs the right commands. Just in case, re-apply all the commands, adapting to your own disk layout (-d /dev/sdxxx -p partition_number) - -~~~ -grep Running /mnt/sysimage/var/log/anaconda/program.log | tail -n 20 -efibootmgr -b 0000 -B -efibootmgr -c -w -L Qubes -d /dev/sda -p 4 -l \\EFI\\qubes\\xen-4.6.1.efi -/usr/libexec/mactel-boot-setup -kernel-install add 4.4.14-11.pvops.qubes.x86_64 /boot/vmlinuz-4.4.14-11.pvops.qubes.x86_64 -systemctl disable qubes-netvm -reboot -~~~ - -At rEFInd screen, choose Boot EFI/qubes/xen-4.6.1.efi -Everything should now be ok, Qubes OS boots using EFI and you will get the last setup screen -* select "Qubes OS", do not change anything and click on "Done" -* VMs are created, including NetVM - -### 6. Fix pulseaudio, which locks CPU freezing the system often for 20 seconds - -My Macbook has frequent freezes. Looking at journalctl output I saw that pulseaudio locks CPU for 20 seconds, very often. - -You can fix this issue, killing audio support with this quick workaround: -* open a dom0 terminal, as root and edit /etc/pulse/client.conf -* add "autospawn = no" -* Then, as normal user, issue command "pulseaudio --kill" - -### 7. Fix system freezes due to Broadcom BCM43602 - -* If you experience a system freeze, during VM setup, force a reboot and press OPTION key. - * You will reach grub shell - ~~~ - configfile /EFI/qubes/grub.cfg - ~~~ - press Fn+F10 to boot without XEN support - * Once booted, press Fn+CTRL+ALT+F4 to open a shell - * Log into system - ~~~ - sudo su - - systemctl disable qubes-netvm - ~~~ - Press Fn+F2 and complete setup -* reboot and you finally have your Qubes OS -* DO NOT launch sys-net machine -* Open its setting and remove wifi adapter from the Selected devices, using Qubes Manager or use the following command line. Get the BFD of the adapter and remove it. On my Macbook BFD is 04:00.0 and you will use it later on, also -~~~ -qvm-pci -l sys-net -qvm-pci -d sys-net 04:00.0 -~~~ - -Ok, setup is complete and we are almost done. -* Open a dom0 terminal -~~~ -sudo su - -xl pci-assignable-list -echo 04:00.0 > /sys/bus/pci/drivers/pciback/permissive -qvm-start sys-net -xl pci-attach sys-net 04:00.0 -~~~ - -These latest steps are required to launch sys-net with wifi access. They can be automated in a custom systemd service. - - - - - -[rEFInd]: http://www.rodsbooks.com/refind/getting.html diff --git a/troubleshooting/nvidia-troubleshooting.md b/troubleshooting/nvidia-troubleshooting.md deleted file mode 100644 index af54891..0000000 --- a/troubleshooting/nvidia-troubleshooting.md +++ /dev/null @@ -1,159 +0,0 @@ ---- -layout: doc -title: Nvidia Troubleshooting -permalink: /doc/nvidia-troubleshooting/ -redirect_from: -- /en/doc/nvidia-troubleshooting/ -- /doc/NvidiaTroubleshooting/ -- /wiki/NvidiaTroubleshooting/ ---- - -NVidia Troubleshooting Guide -============================ - -If you have an NVidia graphics card it will probably not work under Xen out of the box. If your system freezes during boot and you don't see the graphical login manager after you installed Xen, then this problem most likely affects you. The following steps should provide a work around so that you should be able to use your NVidia with X under Xen, however without any fancy "desktop effects". - -Boot in failsafe ---------------------- - -Boot your system using the "failsafe" boot menu, that should have been automatically added to your `grub.conf` when you installed the Dom0 kernel. - -If the X Window System doesn't start now, this is probably a non-Xen related issue and this guide will probably not help you. - - -Configure X with nouveau ---------------------- - -Assuming your X Window System works fine now when you booted from the "failsafe" configuration, do the next steps... - - 1. Do not log into X, but instead switch to a text console (press Ctrl-Alt-F2) - - 2. Log in as root - - 3. Switch to runlevel 3 (this should kill your X server): - - ~~~ - init 3 - ~~~ - - 4. Run X-autoconfiguration: - - ~~~ - Xorg -configure - ~~~ - - This should generate a file `xorg.conf.new` in the `/root` directory. - - In most cases you can ignore any warning or error messages displayed by the X server, assuming it generated the xorg.conf.new file. - - 5. Edit this newly generated `xorg.conf.new` file and introduce the following two modifications: - - First, uncomment the ShadowFB option, so that you should now have something like this: - - ~~~ - Option "ShadowFB" # [] - ~~~ - - Second, change the driver name to `nouveau` (you will probably have `nv` written there): - - ~~~ - Driver "nouveau" - ~~~ - - Save the modification, exit the editor. - - 6. Move the file to `/etc/X11` and rename it as `xorg.conf`: - - ~~~ - mv /root/xorg.conf.new /etc/X11/xorg.conf - ~~~ - - 7. Verify that X will work with those new settings: - - ~~~ - xinit - ~~~ - - If you see a terminal window in the top left corner, it means you most likely succeeded, even if your keyboard or mouse do not work now (don't worry about them). - - 8. Reboot and let the system boot from the normal boot configuration. You should be able to use X under Xen now. - - -Disabling Nouveau ---------------------- -If Qubes fails to properly boot after the GRUB Boot menu and you are stuck on a black screen that displays messages starting with `nouveau` then it means that the nouveau driver failed to launch properly. - -One way to get rid of this for now is to disable nouveau. - -Example error - -~~~ -nouveau E[ PGRAPH][0000:01:00.0] grctx template channel unload timeout -nouveau E[ PGRAPH][0000:01:00.0] failed to construct context -nouveau E[ PGRAPH][0000:01:00.0] init failed, -16 -~~~ - -Tip: In case you only have an external monitor it is advised to attach it directly to a connector of the motherboard if it is present, this should ensure that you're using the integrated graphics card instead of the nvidia graphics card. - -If you're seeing this error then that means another graphics card (most likely an integrated one) acted as failsafe. Disabling nouveau has the consequences of disabling nvidia support altogether. - - 1. Verify that that GRUB Boot Menu is displaying, you should be presented with two options and a progressbar/timer than goes rather fast. - - ~~~ - Qubes - Qubes with advanced Xen options - ~~~ - - 2. Quickly press the "E" key before the time is up. - - 3. An editor will open up that allows you to temporarily change the grub options for the next boot. - - 4. Press the down arrow key and move the cursor to the line after the line with the kernel options. The line with the kernel options will look like this: - - ~~~ - module /vmlinux-4.1.13-9.pvops.qubes.x86_64 placeholder root=/dev/mapper/qubes_dom0-root ro ... rhgb quiet - ~~~ - - It is not an exact copy as it may differ from system to system. - - Please note: choose the module that starts with `vmlinux`! - - 5. Press the left/right arrow keys to position the cursor at the end of kernel options line, after `rhgb quiet` in this case. - - 6. Add the following: - - ~~~ - nouveau.modeset=0 rd.driver.blacklist=nouveau video=vesa:off - ~~~ - - This will temporarily disable nouveau until next boot. - - 7. Press either the F10 key or Ctrl+X to start the boot process. - - Qubes should now boot properly, if that's the case then we should make this change permanent such that the GRUB config knows to not run nouveau. - -You'll have to do the following to make this change persistent, so that it will work properly on every boot : - - 1. Open a terminal (do this by clicking on Q > 'run command' > type 'terminal' and hit enter) - - 2. type following commands: - - ~~~ - cd /etc/default/ - sudo nano grub - ~~~ - - 3. Edit `GRUB_CMDLINE_LINUX`, add the following to it at the end: - - ~~~ - nouveau.modeset=0 rd.driver.blacklist=nouveau video=vesa:off - ~~~ - - 4. ctrl + X and then y to save the file. - - 5. The final step is to compile the configuration file to something the bootloader can read. - - ~~~ - sudo grub2-mkconfig -o /boot/grub2/grub.cfg - ~~~ - diff --git a/troubleshooting/out-of-memory.md b/troubleshooting/out-of-memory.md deleted file mode 100644 index 869da99..0000000 --- a/troubleshooting/out-of-memory.md +++ /dev/null @@ -1,46 +0,0 @@ ---- -layout: doc -title: Out of Memory -permalink: /doc/out-of-memory/ -redirect_from: -- /en/doc/out-of-memory/ -- /doc/OutOfmemory/ -- /wiki/OutOfmemory/ ---- - -VMs (especially templates) use pre-allocated space. The default private storage max size is 2 GB, but it's very easy to increase as needed. If the disk is completely full, you will get an `Out of disk space` error that may crash your system because Dom0 does not have enough disk space to work. So it's good practice to regularly check disk space usage with the command `df -h` in dom0 terminal. - -A system that's out of space should be able to boot, but may be unable to load a desktop manager. In this case it is possible to login to dom0 terminal with Alt + Ctrl + F2. To recover disk space it may be possible to delete files in a userVM by connecting to the userVM terminal: - -~~~ -qvm-start -qvm-console-dispvm -~~~ - -If this does not work, check the size of /var/lib/qubes/qubes.xml. If it is zero, you'll need to use one of the file backup (stored in /var/lib/qubes/backup), hopefully you have the current data there. Find the most recent one and place in /var/lib/qubes/qubes.xml instead of the empty file. - -In any case you'll need some disk space to start the VM. Check `df -h` output if you have some. If not, here are some hints how to free some disk space: - -1. Clean yum cache. - - ~~~ - sudo yum clean all - ~~~ - -2. Delete `.img` files of a less important VM, which can be found in `/var/lib/qubes/appvms/`. - Then, when the system is working again, clean up the rest. - - ~~~ - qvm-remove - ~~~ - - With this method, you lose the data of one VM, but it'll work more reliably. - -3. Decrease the filesystem safety margin (5% by default). - - ~~~ - sudo tune2fs -m 4 /dev/mapper/vg_dom0-lv_root - ~~~ - -4. Remove some unneeded files in dom0 home (if you have any, most likely not). - diff --git a/troubleshooting/remove-vm-manually.md b/troubleshooting/remove-vm-manually.md deleted file mode 100644 index fbc1c14..0000000 --- a/troubleshooting/remove-vm-manually.md +++ /dev/null @@ -1,36 +0,0 @@ ---- -layout: doc -title: How to Remove VMs Manually -permalink: /doc/remove-vm-manually/ ---- - -How to Remove VMs Manually -========================== - -How to Remove a TemplateVM Manually ------------------------------------ - -Try the [normal method] before resorting to this. -All of the following commands should be executed in a dom0 terminal. - -When a template is marked as 'installed by package manager', but cannot be uninstalled there, trying to uninstall manually will result in the error "ERROR: VM installed by package manager: template-vm-name". Do as follows to be able to uninstall the template: - -1. Check the state of `installed_by_rpm` - - $ qvm-prefs template-vm-name - -2. If `installed_by_rpm - True]`, mark the template as not installed by package manager - - $ qvm-prefs template-vm-name installed_by_rpm false - -3. Re-check the state of `installed_by_rpm` - -- If `installed_by_rpm - False`, remove the template like you would a regular qube: - - $ qvm-remove template-vm-name - -- If `installed_by_rpm` remains `True`, reboot your computer to bring qubes.xml in sync with qubesd, and try again to remove the template. - - -[normal method]: /doc/templates/#uninstalling - diff --git a/troubleshooting/sony-vaio-tinkering.md b/troubleshooting/sony-vaio-tinkering.md deleted file mode 100644 index 022e8bf..0000000 --- a/troubleshooting/sony-vaio-tinkering.md +++ /dev/null @@ -1,58 +0,0 @@ ---- -layout: doc -title: Sony Vaio Tinkering -permalink: /doc/sony-vaio-tinkering/ -redirect_from: -- /en/doc/sony-vaio-tinkering/ -- /doc/SonyVaioTinkering/ -- /wiki/SonyVaioTinkering/ ---- - -Instructions for getting your Sony Vaio Z laptop working with Qubes/Linux -========================================================================= - -Sony Vaio Z are great laptops -- they are very powerful, yet compact. The newer models, starting from Z12 are, however, not very well supported by Linux kernels (at least 2.6.34 that we currently use in Dom0) and thus some tinkering is needed to get Qubes working on those machines. - -Getting the graphics card working under Linux/Qubes OS ------------------------------------------------------- - -Newer models of Sony Vaio Z come with an "intelligent" GPU switch, that automatically chooses either Intel Integrated GPU (IGD) or the discrete NVIDIA GPU. This confuses the Linux graphics so much, that in most cases won't even be able to install a regular Linux on such a machine. Unfortunately, moving the switch into the "Stamina" position apparently doesn't work, and the automatic GPU switching is still active. - -One solution that actually worked for me was to reflash the BIOS (I know, I know, this is scary) and to enable the so called "Advanced Menu" in the BIOS. This Advanced Menu allows you to choose the desired behaviour of the GPU switch, which in our case would be to set it to "Static" and then move the mechanical switch to the "Stamina" position, that enabled the Intel IGD (which is much better supported on Linux). - -If you think you are ready to reflash you BIOS, here are the instructions that worked for me: - -[http://forum.notebookreview.com/sony/473226-insyde-hacking-new-vaio-z-advanced-menu-bios.html](http://forum.notebookreview.com/sony/473226-insyde-hacking-new-vaio-z-advanced-menu-bios.html) - -**WARNING**: We take absolutely no responsibility that the BIOS reflashing instructions given at the referenced forum are 1) valid, 2) non-malicious, and 3) work at all. Do this step at your own risk. Keep in mind that reflashing your BIOS might yield your system unusable. If you don't feel like taking this risk (which is a reasonable state of mind), look for a different notebook, or ask Sony Support to enable this option for you. - -In practice I have downloaded the BIOS-patching tools, run them in a VM on a BIOS image I extracted from my laptop, diffed the two versions, and concluded that it doesn't *seem* malicious, and then bravely applied tha patched image. If you don't know what are you doing, just get a different laptop, really! - -On a side note, we should note that allowing anybody to reflash the BIOS is really a bad idea from a security point of view (Hello Evil Maids!). Shame on you, Sony! - -Getting the touchpad working during installation ------------------------------------------------- - -In order to get the touchpad working during installation you should pass the **~~~i8042.nopnp=1~~~** option to the kernel before the installer starts. - -\ - -Applying other fixes --------------------- - -There are a few more fixes needed for Sony Vaio Z, and we have prepared a special package that you can install in Dom0 that applies them all. After the installation is complete, open console in Dom0 and do the following: - -~~~ -$ sudo bash -# qvm-dom0-networking up -# yum install qubes-core-dom0-vaio-fixes -# reboot -~~~ - -This script takes care about the following: - -- Setting i8042.nopnp for your installed system -- Adding special option for the sound module (so you can get sound) -- Adding pm-suspend scripts that take care about restoring your screen after resume - -... now, having done this all, you will surely feel unprecedented satisfaction and you will love your Vaio very much! ;) diff --git a/troubleshooting/thinkpad-troubleshooting.md b/troubleshooting/thinkpad-troubleshooting.md deleted file mode 100644 index 8615920..0000000 --- a/troubleshooting/thinkpad-troubleshooting.md +++ /dev/null @@ -1,94 +0,0 @@ ---- -layout: doc -title: Lenovo ThinkPad Troubleshooting -permalink: /doc/thinkpad-troubleshooting/ -redirect_from: -- /doc/thinkpad_x201/ -- /en/doc/thinkpad_x201/ -- /doc/Thinkpad_X201/ -- /wiki/Thinkpad_X201/ -- /doc/lenovo450-tinkering/ -- /en/doc/lenovo450-tinkering/ -- /doc/Lenovo450Tinkering/ -- /wiki/Lenovo450Tinkering/ ---- - -# Lenovo ThinkPad Troubleshooting # - -## Instructions to create USB installation medium for newer (UEFI-only) ThinkPads ## -Some newer ThinkPads (e.g. T470, T470p, [P51](https://www.svensemmler.org/blog/2017/12/17/qubes-on-thinkpad-p51.html), ThinkPad 25, but not the [P53](https://github.com/QubesOS/qubes-issues/issues/5851)) are likely to fail installation attempts made from a USB stick that was created with dd or Rufus, and even from a DVD burned using official ISO images - if the ThinkPad is configured for UEFI boot. If you don't want to use Legacy Mode as a workaround, the following instructions should help you create a Qubes Installation USB stick that works in UEFI-only mode. - -In a nutshell, you need to use the Fedora livecd-tools to make a Qubes Installation USB Stick from the Qubes ISO image, then update the label on the partition of that USB stick to "BOOT", and then update the BOOT/EFI/BOOTX64.cfg file on the USB stick so that all labels point to BOOT. In more detail: - -1. On your ThinkPad, enter the UEFI setup (press F1 at startup) and make sure to set at least the following options: - - *USB UEFI BIOS Support: Enabled* - - *UEFI/Legacy Boot: UEFI Only* - - *Secure Boot: Disabled* -2. On a different computer, create a "Fedora Live USB Stick": Download a current Fedora Live CD image, and put it onto a USB stick (e.g. using dd or Rufus). Start your ThinkPad from the Fedora Live USB Stick on your ThinkPad (Press F12 at startup to select boot device). Of course, you can alternatively start a different machine from the Fedora Live USB Stick, or use an existing Fedora installation. The next steps all occur within Fedora: -3. Install livecd-tools: `# dnf install livecd-tools` -4. Download the desired Qubes ISO image (or attach a storage device containing it), and verify the signatures as described in the Qubes installation guide. For these instructions, I assume the ISO image is at */run/media/liveuser/qsrc/Qubes-R4.0-rc3-x86_64.iso* (so whenever you see that path going forward in these instructions, replace it with whatever your own path is) -5. Within Fedora, attach the USB stick that you would like to turn into your Qubes Installation USB Stick. Use `dmesg` to figure out what the device name of that stick is. For these instructions, I assume it's */dev/sdd* (so whenever you see */dev/sdd* going forward in these instructions, replace it with whatever your actual device name is) -6. Make sure your target USB stick (presumed to be /dev/sdd) has no mounted partitions: ``# umount /dev/sdd*`` (the asterisk at the end makes sure to unmount all partitions if more than one exists). If none are mounted you'll get an error that you can ignore. -7. Use livecd-tools to copy the image: ``# livecd-iso-to-disk --format --efi /run/media/liveuser/qsrc/Qubes-R4.0-rc3-x86_64.iso /dev/sdd``. **This will erase everything on the drive. Make sure you specify the correct destination.** Then press ENTER when prompted to proceed. This process will take quite a while, be patient. -8. When imaging is complete, change the partition label to BOOT: ``# dosfslabel /dev/sdd1 BOOT`` -9. Now create a mount point and mount the partition: - - ``# mkdir /mnt/qinst`` - - ``# mount /dev/sdd1 /mnt/qinst/`` - -10. Use your favorite editor to edit the file */mnt/qinst/EFI/BOOT/BOOTX64.cfg*: Replace all instances of ``LABEL=Qubes-R4.0-rc3-x86_64`` with ``LABEL=BOOT``. There is typically no space in front of ``LABEL``, but there is a space at the end of the portion you replace. -11. Unmount the Qubes Installation USB stick: ``# umount /dev/sdd*`` and disconnect it. - -That's it! You can now reboot the machine with the Qubes USB Installation stick attached, and press F12 to select it as the boot device at startup. Proceed to install Qubes OS normally. Enjoy! - -## ThinkPads with Intel HD 3000 graphics ## - -Several ThinkPad models have Intel HD 3000 graphics, including the T420s and the -T520. Some users with these laptops have experienced random reboots, which were -solved by adding `i915.enable_rc6=0` as a kernel parameter to -`GRUB_CMDLINE_LINUX` in the file `/etc/default/grub` in dom0. - - -## Instructions for getting your Lenovo Thinkpad X201 & X200 laptop working with Qubes/Linux ## - -For being able to boot the installer from USB, you have to disable VT-d in the BIOS. -Enter the BIOS by hitting F1, go to Config - CPU and then disable VT-d there. - -After the installation, you have to set a startup-parameter for Xen, to be able to activate VT-d again: - -1. Open a terminal in dom0 -2. Edit `/etc/default/grub` -3. Add to the line `GRUB_CMDLINE_XEN_DEFAULT` the setting `iommu=no-igfx`, save and quit -4. sudo `grub2-mkconfig --output /boot/grub2/grub.cfg` - -Then reboot, enter BIOS and re-enable VT-d. - -### Getting scrolling with the Trackpoint and the Middle Button to work ### - -1. Create a script with the following content: - - ~~~ - #!/bin/sh - xinput set-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation" 1 - xinput set-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation Button" 2 - xinput set-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation Timeout" 200 - xinput set-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation Axes" 6 7 4 5 - ~~~ - -2. Add the script to the startup-items of your desktop environment. - - -## Instructions for getting your Lenovo 450 laptop working with Qubes/Linux ## - -Lenovo 450 uses UEFI, so some settings are needed to get Qubes (or Fedora) to boot, otherwise Qubes install USB stick will reboot right after boot selector screen and not continue install. - -### Setting UEFI options to get Qubes install to boot ### - -1. Enable Legacy USB mode -2. Disable all Secure Boot and UEFI options, but leave this enabled: Config / USB / USB UEFI BIOS SUPPORT -3. Save settings and reboot -5. Install Qubes - -... and now enjoy :) These settings may be needed also in other UEFI computers. - diff --git a/troubleshooting/updating-debian-and-whonix.md b/troubleshooting/updating-debian-and-whonix.md deleted file mode 100644 index 39091d1..0000000 --- a/troubleshooting/updating-debian-and-whonix.md +++ /dev/null @@ -1,138 +0,0 @@ ---- -layout: doc -title: Updating Debian and Whonix -permalink: /doc/troubleshooting/updating-debian-and-whonix/ ---- - -Updating Debian and Whonix -========================== - -Despite Qubes shipping with [Debian Templates](/doc/templates/debian/), most of Qubes core components run on Fedora and thus our documentation has better coverage for Fedora. However, Qubes has been working closely with the [Whonix](https://whonix.org) project which is based on Debian. - -This troubleshooting guide is collection of tips about updating Whonix that also pertain to updating the normal Debian package manager. If you plan to use Debian heavily, **we highly recommend you install the Whonix templates and use them to update your normal Debian TemplateVM.** - -*Note: some of the links on this page go to documentation on Whonix's website* - -### Updating Error Messages - -After running the commands to update Debian or Whonix, hopefully everything will complete perfectly. - -~~~ -sudo apt-get update && sudo apt-get dist-upgrade -~~~ - -However, if you see something like the following, then something went wrong. - -~~~ -W: Failed to fetch http://ftp.us.debian.org/debian/dist/jessie/contrib/binary-i386/Packages 404 Not Found - -W: Failed to fetch http://ftp.us.debian.org/debian/dist/jessie/non-free/binary-i386/Packages 404 Not Found - -E: Some index files failed to download. They have been ignored, or old ones used instead. - -Err http://ftp.us.debian.org jessie Release.gpg - Could not resolve 'ftp.us.debian.org' -Err http://deb.torproject.org jessie Release.gpg - Could not resolve 'deb.torproject.org' -Err http://security.debian.org jessie/updates Release.gpg - Could not resolve 'security.debian.org' -Reading package lists... Done -W: Failed to fetch http://security.debian.org/dists/jessie/updates/Release.gpg Could not resolve 'security.debian.org' - -W: Failed to fetch http://ftp.us.debian.org/debian/dists/jessie/Release.gpg Could not resolve 'ftp.us.debian.org' - -W: Failed to fetch http://deb.torproject.org/torproject.org/dists/jessie/Release.gpg Could not resolve 'deb.torproject.org' - -W: Some index files failed to download. They have been ignored, or old ones used instead. -~~~ - -This could be a temporary Tor exit relay or server failure that should fix itself. Here are some simple things to try: - -- Check if your network connection is functional -- Try to [change your Tor circuit](https://www.whonix.org/wiki/Arm), then try again -- Running [whonixcheck](https://www.whonix.org/wiki/Whonixcheck) might also help diagnose the problem - -Sometimes if you see a message such as: - -~~~ -Could not resolve 'security.debian.org' -~~~ - -It helps to run the following command: - -~~~ -nslookup security.debian.org -~~~ - -And then trying running the `update` and `upgrade` commands again. - -~~~ -sudo apt-get update && sudo apt-get dist-upgrade -~~~ - -*Please note: if you [disabled the Whonix APT Repository](https://www.whonix.org/wiki/Whonix-APT-Repository#Disable_Whonix_APT_Repository) you'll have to manually check for new Whonix releases and [manually install them from source code](https://www.whonix.org/wiki/Dev/Build_Documentation).* - -### Never Install Unsigned Packages - -If you see something like this: - -~~~ -WARNING: The following packages cannot be authenticated! - icedove -Install these packages without verification [y/N]? -~~~ - -Don't proceed! Press `N` and ``. Running `apt-get update` again should fix it. If not, something is broken or it's a [Man in the middle attack](https://www.whonix.org/wiki/Warning#Man-in-the-middle_attacks), which isn't that unlikely, since we are updating over Tor exit relays and some of them are malicious. Try to [change your Tor circuit](https://www.whonix.org/wiki/Arm#Arm). - - -### Signature Verification Warnings - -There should be none at the moment. If there was such a warning, it would look like this: - -~~~ -W: A error occurred during the signature verification. The repository is not updated and the previous index files will be used. GPG error: http://deb.torproject.org stable Release: The following signatures were invalid: KEYEXPIRED 1409325681 KEYEXPIRED 1409325681 KEYEXPIRED 1409325681 KEYEXPIRED 1409325681 -~~~ - -Even though, `apt-get` will automatically ignore repositories with expired keys or signatures, you will not receive upgrades from that repository. Unless the issue is already known/documented, it should be reported so it can be further investigated. - -There are two possible reasons why this could happen, either there is an issue with the repository that the maintainers have to fix, or you are victim of a [Man-in-the-middle_attacks](https://www.whonix.org/wiki/Warning#Man-in-the-middle_attacks). The latter would not be a big issue and might go away after a while automatically or try to [change your Tor circuit](https://www.whonix.org/wiki/Arm#Arm) - -In past various apt repositories were signed with expired key. If you want to see how the documentation looked at that point, please click on expand on the right. - -[The Tor Project's apt repository key was expired](https://trac.torproject.org/projects/tor/ticket/12994). You saw the following warning. - -~~~ -W: A error occurred during the signature verification. The repository is not updated and the previous index files will be used. GPG error: http://deb.torproject.org stable Release: The following signatures were invalid: KEYEXPIRED 1409325681 KEYEXPIRED 1409325681 KEYEXPIRED 1409325681 KEYEXPIRED 1409325681 - -W: Failed to fetch http://deb.torproject.org/torproject.org/dists/stable/Release -W: Some index files failed to download. They have been ignored, or old ones used instead. -~~~ - -It had already been [reported](https://trac.torproject.org/projects/tor/ticket/12994). There was no immediate danger. You could have just ignored it. Just make sure, you never install unsigned packages as explained above. - -If you were to see other signature verification errors, those should be reported, but it shouldn't happen at this time. - -### Changed Configuration Files - -If you see something like the following. - -~~~ -Setting up ifupdown ... -Configuration file /etc/network/interfaces - ==> Modified (by you or by a script) since installation. - ==> Package distributor has shipped an updated version. - What would you like to do about it ? Your options are: - Y or I : install the package maintainer's version - N or O : keep your currently-installed version - D : show the differences between the versions - Z : background this process to examine the situation - The default action is to keep your current version. -*** interfaces (Y/I/N/O/D/Z) [default=N] ? N -~~~ - -Be careful. If the updated file isn't coming from Whonix specific package (some are called `whonix-...`), then press `n`. Otherwise anonymity/privacy/security settings deployed with Whonix might get lost. If you are an advanced user and know better, you can of course manually check the difference and merge them. - -How could you find out if the file is coming from a Whonix specific package or not? - -* Whonix specific packages are sometimes called `whonix-...`. In the example above it's saying `Setting up ifupdown ...`, so the file isn't coming from a Whonix specific package. In this case, you should press `n` as advised in the paragraph above. -* If the package name does include `whonix-...`, it's a Whonix specific package. In that case, your safest bet should be pressing `y`, but then you would lose your customized settings. You can re-add them afterwards. Such conflicts will hopefully rarely happen, if you use [Whonix modular flexible .d style configuration folders](https://www.whonix.org/wiki/Whonix_Configuration_Files). diff --git a/troubleshooting/wireless-troubleshooting.md b/troubleshooting/wireless-troubleshooting.md deleted file mode 100644 index 9c8ea33..0000000 --- a/troubleshooting/wireless-troubleshooting.md +++ /dev/null @@ -1,121 +0,0 @@ ---- -layout: doc -title: Wireless Troubleshooting -permalink: /doc/wireless-troubleshooting/ -redirect_from: -- /en/doc/wireless-troubleshooting/ ---- - -Wireless Troubleshooting Guide -============================== - -These instructions may help with suspend/resume issues for more devices than just wireless cards, that is just the (unfortunately not uncommon) example used here. - -Resetting wireless cards by reloading drivers ---------------------------------------------- - -If your wireless card works, but after suspending and resuming your computer, the Network-Manager applet just says "Device not ready", then try un-loading and re-loading the driver. - -### Determining your wireless card driver ### - -First, determine which kernel module corresponds to your wireless card. There are several ways to do this. - -The easiest is via the output of `lspci -k` in your sys-net VM: - -~~~ -[user@sys-net ~]$ lspci -k -00:00.0 Network controller: Intel Corporation Wireless 8260 (rev 3a) - Subsystem: Intel Corporation Device 0130 - Kernel driver in use: iwlwifi - Kernel modules: iwlwifi -~~~ - -Here we see that the machine in question has an Intel wireless card, being used by the `iwlwifi` kernel module. - - -### Checking logs for relevant messages ### - -View the output of `dmesg` in sys-net, and check if you see a bunch of wireless related errors. Depending on your hardware, they may look like the following (or not): - -~~~ -iwlwifi 0000:00:00.0: loaded firmware version 16.242414.0 op_mode iwlmvm -iwlwifi 0000:00:00.0: Detected Intel(R) Dual Band Wireless AC 8260, REV=0x208 -... -IPv6: ADDRCONF(NETDEV_UP): wlp0s0: link is not ready -iwlwifi 0000:00:00.0: L1 Enabled - LTR Enabled -iwlwifi 0000:00:00.0: L1 Enabled - LTR Enabled -iwlwifi 0000:00:00.0: Failed to load firmware chunk! -iwlwifi 0000:00:00.0: Could not load the [0] uCode section -iwlwifi 0000:00:00.0: Failed to start INIT ucode: -110 -iwlwifi 0000:00:00.0: Failed to run INIT ucode: -110 -... -iwlwifi 0000:00:00.0: Direct firmware load for iwlwifi-8000C-18.ucode failed with error -2 -~~~ - -### Seeing what modules you have loaded ### - -You can check which drivers are currently loaded with `lsmod`, and view details about a module with `modinfo `. - -For example, we list what modules we have loaded: - -~~~ -[user@sys-net ~]$ lsmod -Module Size Used by -iwlmvm 315392 0 -iwlwifi 155648 1 iwlmvm -mac80211 708608 1 iwlmvm -cfg80211 557056 3 iwlwifi,mac80211,iwlmvm -... -~~~ - -and check one: - -~~~ -[user@sys-net ~]$ modinfo iwlmvm | grep -E '^(description|author|depends):' -author: Copyright(c) 2003- 2015 Intel Corporation -description: The new Intel(R) wireless AGN driver for Linux -depends: iwlwifi,mac80211,cfg80211 -~~~ - -Hey, it's our wireless driver! - -Now, check if reloading the module makes wireless work again: - -~~~ -[user@sys-net ~]$ sudo rmmod iwlmvm -[user@sys-net ~]$ sudo modprobe iwlmvm -~~~ - -and try reconnecting to a network that is known to work. - -If that is successful, see below about having Qubes automatically reload the driver for you. If not, try also reloading some dependent modules, in our example we must also reload iwlwifi: - -~~~ -[user@sys-net ~]$ modinfo iwlwifi | grep -E '^(description|author|depends):' -author: Copyright(c) 2003- 2015 Intel Corporation -description: Intel(R) Wireless WiFi driver for Linux -depends: cfg80211 -~~~ - -~~~ -[user@sys-net ~]$ sudo rmmod iwlmvm -[user@sys-net ~]$ sudo rmmod iwlwifi -[user@sys-net ~]$ sudo modprobe iwlwifi # note the reverse order of loading/unloading -[user@sys-net ~]$ sudo modprobe iwlmvm -~~~ - -Automatically reloading drivers on suspend/resume -------------------------------------------------- - -If reloading the driver (which resets the hardware into a known-state) resolves your issue when done manually, you can have Qubes automatically un/reload them on suspend & resume by listing the relevant modules in `/rw/config/suspend-module-blacklist`. - -In the above example, it would look like this: - -~~~ -[user@sys-net config]$ cat /rw/config/suspend-module-blacklist -# You can list here modules you want to be unloaded before going to sleep. This -# file is used only if the VM has any PCI device assigned. Modules will be -# automatically loaded after resume. -iwlmvm -iwlwifi -~~~ From 465d59cce86a31b0d56b9c7de0f70e60ad6d12d8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Pierret=20=28fepitre=29?= Date: Sun, 4 Oct 2020 11:36:59 +0200 Subject: [PATCH 109/136] gentoo: add notes about post-install --- os-guides/gentoo.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/os-guides/gentoo.md b/os-guides/gentoo.md index abed83c..219c205 100644 --- a/os-guides/gentoo.md +++ b/os-guides/gentoo.md @@ -19,7 +19,7 @@ To switch, reinstall and uninstall a Gentoo TemplateVM that is already installed #### After Installing -After a fresh install, we recommend to [Update the TemplateVM](/doc/software-update-vm/). +After a fresh install, we recommend to [Update the TemplateVM](/doc/software-update-vm/). We highlight that the template memory/CPU allocation certainly need to be adjusted in some cases. As Gentoo is a *linux source distribution*, the template needs resources to perform updates or installing any packages. By default, each TemplateVM has *2 VCPUs* for *4000 MB Max memory* allocated. If needed, double those values, *4 VCPUs* for *8000 MB Max memory*. For example, it has been observed failing updates or builds with *4 VCPUs* for *4000 MB Max memory* due to out of memory issue. For more general considerations, we refer to the official [Gentoo Handbook]. ## Want to contribute? @@ -32,3 +32,4 @@ After a fresh install, we recommend to [Update the TemplateVM](/doc/software-upd [uninstall]: /doc/templates/#uninstalling [Minimal TemplateVMs]: /doc/templates/minimal/ [Xfce TemplateVMs]: /doc/templates/xfce/ +[Gentoo Handbook]: https://wiki.gentoo.org/wiki/Handbook:AMD64 \ No newline at end of file From 859949cf05954ad2eaf7e5ecaa59ffe6cd134fa0 Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Sat, 10 Oct 2020 09:50:00 +0100 Subject: [PATCH 110/136] Replace wireless troubleshooting with resume/suspend troubleshooting --- troubleshooting/wireless-troubleshooting.md | 121 -------------------- 1 file changed, 121 deletions(-) delete mode 100644 troubleshooting/wireless-troubleshooting.md diff --git a/troubleshooting/wireless-troubleshooting.md b/troubleshooting/wireless-troubleshooting.md deleted file mode 100644 index 9c8ea33..0000000 --- a/troubleshooting/wireless-troubleshooting.md +++ /dev/null @@ -1,121 +0,0 @@ ---- -layout: doc -title: Wireless Troubleshooting -permalink: /doc/wireless-troubleshooting/ -redirect_from: -- /en/doc/wireless-troubleshooting/ ---- - -Wireless Troubleshooting Guide -============================== - -These instructions may help with suspend/resume issues for more devices than just wireless cards, that is just the (unfortunately not uncommon) example used here. - -Resetting wireless cards by reloading drivers ---------------------------------------------- - -If your wireless card works, but after suspending and resuming your computer, the Network-Manager applet just says "Device not ready", then try un-loading and re-loading the driver. - -### Determining your wireless card driver ### - -First, determine which kernel module corresponds to your wireless card. There are several ways to do this. - -The easiest is via the output of `lspci -k` in your sys-net VM: - -~~~ -[user@sys-net ~]$ lspci -k -00:00.0 Network controller: Intel Corporation Wireless 8260 (rev 3a) - Subsystem: Intel Corporation Device 0130 - Kernel driver in use: iwlwifi - Kernel modules: iwlwifi -~~~ - -Here we see that the machine in question has an Intel wireless card, being used by the `iwlwifi` kernel module. - - -### Checking logs for relevant messages ### - -View the output of `dmesg` in sys-net, and check if you see a bunch of wireless related errors. Depending on your hardware, they may look like the following (or not): - -~~~ -iwlwifi 0000:00:00.0: loaded firmware version 16.242414.0 op_mode iwlmvm -iwlwifi 0000:00:00.0: Detected Intel(R) Dual Band Wireless AC 8260, REV=0x208 -... -IPv6: ADDRCONF(NETDEV_UP): wlp0s0: link is not ready -iwlwifi 0000:00:00.0: L1 Enabled - LTR Enabled -iwlwifi 0000:00:00.0: L1 Enabled - LTR Enabled -iwlwifi 0000:00:00.0: Failed to load firmware chunk! -iwlwifi 0000:00:00.0: Could not load the [0] uCode section -iwlwifi 0000:00:00.0: Failed to start INIT ucode: -110 -iwlwifi 0000:00:00.0: Failed to run INIT ucode: -110 -... -iwlwifi 0000:00:00.0: Direct firmware load for iwlwifi-8000C-18.ucode failed with error -2 -~~~ - -### Seeing what modules you have loaded ### - -You can check which drivers are currently loaded with `lsmod`, and view details about a module with `modinfo `. - -For example, we list what modules we have loaded: - -~~~ -[user@sys-net ~]$ lsmod -Module Size Used by -iwlmvm 315392 0 -iwlwifi 155648 1 iwlmvm -mac80211 708608 1 iwlmvm -cfg80211 557056 3 iwlwifi,mac80211,iwlmvm -... -~~~ - -and check one: - -~~~ -[user@sys-net ~]$ modinfo iwlmvm | grep -E '^(description|author|depends):' -author: Copyright(c) 2003- 2015 Intel Corporation -description: The new Intel(R) wireless AGN driver for Linux -depends: iwlwifi,mac80211,cfg80211 -~~~ - -Hey, it's our wireless driver! - -Now, check if reloading the module makes wireless work again: - -~~~ -[user@sys-net ~]$ sudo rmmod iwlmvm -[user@sys-net ~]$ sudo modprobe iwlmvm -~~~ - -and try reconnecting to a network that is known to work. - -If that is successful, see below about having Qubes automatically reload the driver for you. If not, try also reloading some dependent modules, in our example we must also reload iwlwifi: - -~~~ -[user@sys-net ~]$ modinfo iwlwifi | grep -E '^(description|author|depends):' -author: Copyright(c) 2003- 2015 Intel Corporation -description: Intel(R) Wireless WiFi driver for Linux -depends: cfg80211 -~~~ - -~~~ -[user@sys-net ~]$ sudo rmmod iwlmvm -[user@sys-net ~]$ sudo rmmod iwlwifi -[user@sys-net ~]$ sudo modprobe iwlwifi # note the reverse order of loading/unloading -[user@sys-net ~]$ sudo modprobe iwlmvm -~~~ - -Automatically reloading drivers on suspend/resume -------------------------------------------------- - -If reloading the driver (which resets the hardware into a known-state) resolves your issue when done manually, you can have Qubes automatically un/reload them on suspend & resume by listing the relevant modules in `/rw/config/suspend-module-blacklist`. - -In the above example, it would look like this: - -~~~ -[user@sys-net config]$ cat /rw/config/suspend-module-blacklist -# You can list here modules you want to be unloaded before going to sleep. This -# file is used only if the VM has any PCI device assigned. Modules will be -# automatically loaded after resume. -iwlmvm -iwlwifi -~~~ From 6272d4b3aef0f46d960e4272cb43d5484dc515f7 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sat, 10 Oct 2020 11:50:11 +0200 Subject: [PATCH 111/136] Update windows-vm.md fixed typo --- os-guides/windows/windows-vm.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index f488d78..bcc023c 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -119,7 +119,7 @@ MS Windows versions considerations: - The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x -- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [Qubes Wndows Tools](/doc/windows-tools/). +- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [Qubes Windows Tools](/doc/windows-tools/). Create a VM named win7new in [HVM](/doc/hvm/) mode (Xen's current PVH limitations precludes from using PVH): From 1058f148637e774af5a71ce2daa3bc31282e17bc Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Sat, 10 Oct 2020 11:02:41 +0100 Subject: [PATCH 112/136] Add VM Troubleshooting --- troubleshooting/remove-vm-manually.md | 36 --------------------------- 1 file changed, 36 deletions(-) delete mode 100644 troubleshooting/remove-vm-manually.md diff --git a/troubleshooting/remove-vm-manually.md b/troubleshooting/remove-vm-manually.md deleted file mode 100644 index fbc1c14..0000000 --- a/troubleshooting/remove-vm-manually.md +++ /dev/null @@ -1,36 +0,0 @@ ---- -layout: doc -title: How to Remove VMs Manually -permalink: /doc/remove-vm-manually/ ---- - -How to Remove VMs Manually -========================== - -How to Remove a TemplateVM Manually ------------------------------------ - -Try the [normal method] before resorting to this. -All of the following commands should be executed in a dom0 terminal. - -When a template is marked as 'installed by package manager', but cannot be uninstalled there, trying to uninstall manually will result in the error "ERROR: VM installed by package manager: template-vm-name". Do as follows to be able to uninstall the template: - -1. Check the state of `installed_by_rpm` - - $ qvm-prefs template-vm-name - -2. If `installed_by_rpm - True]`, mark the template as not installed by package manager - - $ qvm-prefs template-vm-name installed_by_rpm false - -3. Re-check the state of `installed_by_rpm` - -- If `installed_by_rpm - False`, remove the template like you would a regular qube: - - $ qvm-remove template-vm-name - -- If `installed_by_rpm` remains `True`, reboot your computer to bring qubes.xml in sync with qubesd, and try again to remove the template. - - -[normal method]: /doc/templates/#uninstalling - From 975166d834f5a3b4e3cb6f35a3255278006dadd0 Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Sat, 10 Oct 2020 11:50:35 +0100 Subject: [PATCH 113/136] Add HVM Troubleshooting --- os-guides/linux-hvm-tips.md | 36 +----------------------------------- 1 file changed, 1 insertion(+), 35 deletions(-) diff --git a/os-guides/linux-hvm-tips.md b/os-guides/linux-hvm-tips.md index c1c99fa..4bf5dde 100644 --- a/os-guides/linux-hvm-tips.md +++ b/os-guides/linux-hvm-tips.md @@ -14,41 +14,7 @@ Tips for Linux in HVM domain How to fix bootup kernel error ------------------------------- -The HVM may pause on boot, showing a fixed cursor. -After a while a series of warnings may be shown similar to this: - - BUG: soft lockup - CPU#0 stuck for 23s! [systemd-udevd:244] - -To fix this: - -1. Kill the HVM. -1. Start the HVM -1. Press "e" at the grub screen to edit the boot parameters -1. Find the /vmlinuz line, and edit it to replace "rhgb" with "modprobe.blacklist=bochs_drm" -1. Press "Ctrl-x" to start the HVM - -If this solves the problem then you will want to make the change permanent: - -1. Edit the file `/etc/default/grub`. -1. Find the line which starts: - ~~~ - GRUB_CMDLINE_LINUX= - ~~~ -1. Remove this text from that line: - ~~~ - rhgb - ~~~ -1. Add this text to that line: - ~~~ - modprobe.blacklist=bochs_drm - ~~~ -1. Run this command: - ~~~ - grub2-mkconfig --output=/boot/grub2/grub.cfg - ~~~ - -The HVM should now start normally. - +If the HVM pauses on boot and shows a series of warnings, visit [HVM Troubleshooting](/doc/hvm-troubleshooting/#hvm-pauses-on-boot-followed-by-kernel-error) for a fix. Screen resolution ----------------- From c04f55183fd88c6329e17865a061b3c6ae363592 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sat, 10 Oct 2020 13:57:01 +0200 Subject: [PATCH 114/136] Update windows-tools.md --- os-guides/windows/windows-tools.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index 9063269..b65350b 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -22,10 +22,10 @@ Qubes Windows Tools are a set of programs and drivers that provide integration o - **Qubes Video Driver** - provides for the Seamless GUI mode that integrates apps windows onto the common Qubes trusted desktop - **File sender/receiver** - Support for [secure clipboard copy/paste](/doc/copy-paste/) between the Windows VM and other AppVMs - ***File sender/receiver** - Support for [secure file exchange](/doc/copying-files/) between the Windows VM and other AppVMs -- **Copy/Edit in Dipostable VM** - Support for editing files in DisposableVMs as well as for qvm-run and generic qrexec for the Windows VM (e.g. ability to run custom service within/from the Windows VM) +- **Copy/Edit in Diposable VM** - Support for editing files in DisposableVMs as well as for qvm-run and generic qrexec for the Windows VM (e.g. ability to run custom service within/from the Windows VM) - **Xen PV drivers** for Windows that increase performance compared to qemu emulated devices -Below is a breakdown of the feature availablility depending on the windows version: +Below is a breakdown of the feature availability depending on the windows version: | Feature | Windows 7 x64 | Windows 10 x64 | | ------------------------------------ | :------------: | :------------: | @@ -35,7 +35,7 @@ Below is a breakdown of the feature availablility depending on the windows versi | File sender/receiver | + | + | | Clipboard Copy/Paste | + | + | | Application shortcuts | + | + | -| Copy/Edit in Disposible VM | + | + | +| Copy/Edit in Disposable VM | + | + | | Block device | + | + | | USB device | - | - | | Audio | - | - | From ea0681188707cbe003e978046110c86928be5c11 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sat, 10 Oct 2020 14:23:29 +0200 Subject: [PATCH 115/136] Update windows-tools.md --- os-guides/windows/windows-tools.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-tools.md b/os-guides/windows/windows-tools.md index b65350b..4a5ff7d 100644 --- a/os-guides/windows/windows-tools.md +++ b/os-guides/windows/windows-tools.md @@ -22,7 +22,7 @@ Qubes Windows Tools are a set of programs and drivers that provide integration o - **Qubes Video Driver** - provides for the Seamless GUI mode that integrates apps windows onto the common Qubes trusted desktop - **File sender/receiver** - Support for [secure clipboard copy/paste](/doc/copy-paste/) between the Windows VM and other AppVMs - ***File sender/receiver** - Support for [secure file exchange](/doc/copying-files/) between the Windows VM and other AppVMs -- **Copy/Edit in Diposable VM** - Support for editing files in DisposableVMs as well as for qvm-run and generic qrexec for the Windows VM (e.g. ability to run custom service within/from the Windows VM) +- **Copy/Edit in Disposable VM** - Support for editing files in DisposableVMs as well as for qvm-run and generic qrexec for the Windows VM (e.g. ability to run custom service within/from the Windows VM) - **Xen PV drivers** for Windows that increase performance compared to qemu emulated devices Below is a breakdown of the feature availability depending on the windows version: From 118470eea2c282513e057f4045c659b88f4d267f Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sun, 11 Oct 2020 11:26:25 +0200 Subject: [PATCH 116/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index bcc023c..328a3f8 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -209,7 +209,7 @@ Finally, increase the VM's `qrexec_timeout`: in case you happen to get a BSOD or qvm-prefs win7new qrexec_timeout 300 ~~~ -At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](#xen-pv-drivers-and-qubes-windows-tools) below). It is a good time to clone the VM again. +At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](./windows-tools#xen-pv-drivers-and-qubes-windows-tools) below). It is a good time to clone the VM again. Windows as TemplateVM From c63494f1adb4ad39cf841929f1fb0135a16561e4 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sun, 11 Oct 2020 11:28:03 +0200 Subject: [PATCH 117/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 328a3f8..c7258d4 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -209,7 +209,7 @@ Finally, increase the VM's `qrexec_timeout`: in case you happen to get a BSOD or qvm-prefs win7new qrexec_timeout 300 ~~~ -At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](./windows-tools#xen-pv-drivers-and-qubes-windows-tools) below). It is a good time to clone the VM again. +At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](./windows-tools.md#xen-pv-drivers-and-qubes-windows-tools) below). It is a good time to clone the VM again. Windows as TemplateVM From 07e26ac2ee8ec3360aeb1ae902d36f6fac1aaf14 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sun, 11 Oct 2020 11:57:55 +0200 Subject: [PATCH 118/136] Correct links to ther file --- os-guides/windows/windows-vm.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index c7258d4..8a4611a 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -119,7 +119,7 @@ MS Windows versions considerations: - The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x -- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [Qubes Windows Tools](/doc/windows-tools/). +- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [Qubes Windows Tools](/external/os-guides/windows/windows-tools.md). Create a VM named win7new in [HVM](/doc/hvm/) mode (Xen's current PVH limitations precludes from using PVH): @@ -209,7 +209,7 @@ Finally, increase the VM's `qrexec_timeout`: in case you happen to get a BSOD or qvm-prefs win7new qrexec_timeout 300 ~~~ -At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](./windows-tools.md#xen-pv-drivers-and-qubes-windows-tools) below). It is a good time to clone the VM again. +At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](/external/os-guides/windows/windows-tools.md#xen-pv-drivers-and-qubes-windows-tools)). It is a good time to clone the VM again. Windows as TemplateVM From e0fafae68d64dd32a081b6ad0a489a0b0721f618 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sun, 11 Oct 2020 12:20:51 +0200 Subject: [PATCH 119/136] Correct links to other file --- os-guides/windows/windows-vm.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 8a4611a..ca79f84 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -119,7 +119,7 @@ MS Windows versions considerations: - The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x -- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [Qubes Windows Tools](/external/os-guides/windows/windows-tools.md). +- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [Qubes Windows Tools](./windows-tools.md). Create a VM named win7new in [HVM](/doc/hvm/) mode (Xen's current PVH limitations precludes from using PVH): @@ -209,7 +209,7 @@ Finally, increase the VM's `qrexec_timeout`: in case you happen to get a BSOD or qvm-prefs win7new qrexec_timeout 300 ~~~ -At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](/external/os-guides/windows/windows-tools.md#xen-pv-drivers-and-qubes-windows-tools)). It is a good time to clone the VM again. +At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](./windows-tools.md#xen-pv-drivers-and-qubes-windows-tools)). It is a good time to clone the VM again. Windows as TemplateVM From 3ac6d417b26e842b4ecd57cac8c3b25d6fc43dbd Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sun, 11 Oct 2020 12:52:06 +0200 Subject: [PATCH 120/136] Update windows-vm.md --- os-guides/windows/windows-vm.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index ca79f84..7ea153e 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -119,7 +119,7 @@ MS Windows versions considerations: - The instructions *may* work on other versions than Windows 7 x64 but haven't been tested. - Qubes Windows Tools (QWT) only supports Windows 7 x64. Note that there are [known issues](https://github.com/QubesOS/qubes-issues/issues/3585) with QWT on Qubes 4.x -- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [Qubes Windows Tools](./windows-tools.md). +- For Windows 10 under Qubes 4.0, a way to install QWT 4.0.1.3, which has worked in several instances, is described in [Qubes Windows Tools](/doc/windows-tools/). Create a VM named win7new in [HVM](/doc/hvm/) mode (Xen's current PVH limitations precludes from using PVH): @@ -209,7 +209,7 @@ Finally, increase the VM's `qrexec_timeout`: in case you happen to get a BSOD or qvm-prefs win7new qrexec_timeout 300 ~~~ -At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](./windows-tools.md#xen-pv-drivers-and-qubes-windows-tools)). It is a good time to clone the VM again. +At that point you should have a functional and stable Windows VM, although without updates, Xen's PV drivers nor Qubes integration (see sections [Windows Update](#windows-update) and [Xen PV drivers and Qubes Windows Tools](/doc/windows-tools/#xen-pv-drivers-and-qubes-windows-tools)). It is a good time to clone the VM again. Windows as TemplateVM From 82f36650f855912d8a49730fd3738155f4060253 Mon Sep 17 00:00:00 2001 From: "Dr. Gerhard Weck" Date: Sun, 11 Oct 2020 13:38:15 +0200 Subject: [PATCH 121/136] Hopefully last try to get the syntax right --- os-guides/windows/windows-vm.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/os-guides/windows/windows-vm.md b/os-guides/windows/windows-vm.md index 7ea153e..5eeb7f6 100644 --- a/os-guides/windows/windows-vm.md +++ b/os-guides/windows/windows-vm.md @@ -111,7 +111,7 @@ qvm-prefs win7new qrexec_timeout 300 qvm-prefs win7new debug false ~~~ -To install Qubes Windows Tools, follow instructions [below](#xen-pv-drivers-and-qubes-windows-tools). +To install Qubes Windows Tools, follow instructions in [Qubes Windows Tools](/doc/windows-tools/). ### Detailed instructions ### From 4c55837833e9fe024395fb55e67f3ab9d8d7fdc1 Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Sat, 10 Oct 2020 11:50:35 +0100 Subject: [PATCH 122/136] Add HVM Troubleshooting --- os-guides/linux-hvm-tips.md | 36 +----------------------------------- 1 file changed, 1 insertion(+), 35 deletions(-) diff --git a/os-guides/linux-hvm-tips.md b/os-guides/linux-hvm-tips.md index c1c99fa..4bf5dde 100644 --- a/os-guides/linux-hvm-tips.md +++ b/os-guides/linux-hvm-tips.md @@ -14,41 +14,7 @@ Tips for Linux in HVM domain How to fix bootup kernel error ------------------------------- -The HVM may pause on boot, showing a fixed cursor. -After a while a series of warnings may be shown similar to this: - - BUG: soft lockup - CPU#0 stuck for 23s! [systemd-udevd:244] - -To fix this: - -1. Kill the HVM. -1. Start the HVM -1. Press "e" at the grub screen to edit the boot parameters -1. Find the /vmlinuz line, and edit it to replace "rhgb" with "modprobe.blacklist=bochs_drm" -1. Press "Ctrl-x" to start the HVM - -If this solves the problem then you will want to make the change permanent: - -1. Edit the file `/etc/default/grub`. -1. Find the line which starts: - ~~~ - GRUB_CMDLINE_LINUX= - ~~~ -1. Remove this text from that line: - ~~~ - rhgb - ~~~ -1. Add this text to that line: - ~~~ - modprobe.blacklist=bochs_drm - ~~~ -1. Run this command: - ~~~ - grub2-mkconfig --output=/boot/grub2/grub.cfg - ~~~ - -The HVM should now start normally. - +If the HVM pauses on boot and shows a series of warnings, visit [HVM Troubleshooting](/doc/hvm-troubleshooting/#hvm-pauses-on-boot-followed-by-kernel-error) for a fix. Screen resolution ----------------- From 52ea037da0f2c2a7e9475a7e877ee309806393ba Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Fri, 30 Oct 2020 15:07:40 +0100 Subject: [PATCH 123/136] Add VPN Troubleshooting --- configuration-guides/vpn.md | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/configuration-guides/vpn.md b/configuration-guides/vpn.md index 1f84321..002a28f 100644 --- a/configuration-guides/vpn.md +++ b/configuration-guides/vpn.md @@ -318,6 +318,4 @@ If you want to update your TemplateVMs through the VPN, you can enable the `qube Troubleshooting --------------- -* Always test your basic VPN connection before adding scripts. -* Test DNS: Ping a familiar domain name from an appVM. It should print the IP address for the domain. -* Use `iptables -L -v` and `iptables -L -v -t nat` to check firewall rules. The latter shows the critical PR-QBS chain that enables DNS forwarding. +See the [VPN Troubleshooting](/doc/vpn-troubleshooting/) guide for tips on how to fix common VPN issues. From 19d8f9b74c1fbc857dd85a5bcdf7ac3c887b92bb Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Fri, 30 Oct 2020 16:26:50 +0100 Subject: [PATCH 124/136] Add Nvidia Troubleshooting --- configuration-guides/install-nvidia-driver.md | 141 +++++++++++ troubleshooting/nvidia-troubleshooting.md | 225 ++++++++++++++++++ 2 files changed, 366 insertions(+) create mode 100644 configuration-guides/install-nvidia-driver.md create mode 100644 troubleshooting/nvidia-troubleshooting.md diff --git a/configuration-guides/install-nvidia-driver.md b/configuration-guides/install-nvidia-driver.md new file mode 100644 index 0000000..d9b65ac --- /dev/null +++ b/configuration-guides/install-nvidia-driver.md @@ -0,0 +1,141 @@ +--- +layout: doc +title: How to Install an Nvidia Driver +permalink: /doc/install-nvidia-driver/ +redirect_from: +- /en/doc/install-nvidia-driver/ +- /doc/InstallNvidiaDriver/ +- /wiki/InstallNvidiaDriver/ +--- + +# Nvidia proprietary driver installation + +You can use rpm packages from rpmfusion, or you can build the driver yourself. + +## Word of Caution + +Proprietary (NVIDIA/AMD) drivers are known to be sometimes highly problematic, or completely unsupported. +Radeon driver support is prebaked in the Qubes kernel (v4.4.14-11) but only versions 4000-9000 give or take. +Support for newer cards is limited until AMDGPU support in the 4.5+ kernel, which isn't released yet for Qubes. + +Built in Intel graphics, Radeon graphics (between that 4000-9000 range), and perhaps some prebaked NVIDIA card support that I don't know about. Those are your best bet for great Qubes support. + +If you do happen to get proprietary drivers working on your Qubes system (via installing them), please take the time to go to the +[Hardware Compatibility List (HCL)](/doc/hcl/#generating-and-submitting-new-reports ) +Add your computer, graphics card, and installation steps you did to get everything working. + +Before continuing, you may wish to try the `kernel-latest` package from the `current` repository. This kernel may better support your card and if so, you would not have to rely on proprietary drivers. This can be installed from dom0 with: +~~~ +sudo qubes-dom0-update kernel-latest +~~~ + +## RpmFusion packages + +There are rpm packages with all necessary software on rpmfusion. The only package you have to compile is the kernel module (but there is a ready built src.rpm package). + +### Download packages + +You will need any Fedora 18 system to download and build packages. You can use Qubes AppVM for it, but it isn't necessary. To download packages from rpmfusion - add this repository to your yum configuration (instructions are on their website). Then download packages using yumdownloader: + +~~~ +yumdownloader --resolve xorg-x11-drv-nvidia +yumdownloader --source nvidia-kmod +~~~ + +### Build kernel package + +You will need at least kernel-devel (matching your Qubes dom0 kernel), rpmbuild tool and kmodtool, and then you can use it to build the package: + +~~~ +yum install kernel-devel rpm-build kmodtool +rpmbuild --nodeps -D "kernels `uname -r`" --rebuild nvidia-kmod-260.19.36-1.fc13.3.src.rpm +~~~ + +In the above command, replace `uname -r` with kernel version from your Qubes dom0. If everything went right, you have now complete packages with nvidia drivers for the Qubes system. Transfer them to dom0 (e.g. using a USB stick) and install (using standard "yum install /path/to/file"). + +Then you need to disable nouveau (normally it is done by install scripts from nvidia package, but unfortunately it isn't compatible with Qubes...): + +Edit /etc/default/grub: + +~~~ +GRUB_CMDLINE_LINUX="quiet rhgb nouveau.modeset=0 rd.driver.blacklist=nouveau video=vesa:off" +~~~ + +Regenerate grub configuration: + +~~~ +grub2-mkconfig -o /boot/grub2/grub.cfg +~~~ + +Reboot. + + + +## Manual installation + +This process is quite complicated: First - download the source from nvidia.com site. Here "NVIDIA-Linux-x86\_64-260.19.44.run" is used. Copy it to dom0. Every next step is done in dom0. + +See [this page](/doc/copy-to-dom0/) for instructions on how to transfer files to Dom0 (where there is normally no networking). + +**WARNING**: Nvidia doesn't sign their files. To make it worse, you are forced to download them over a plaintext connection. This means there are virtually dozens of possibilities for somebody to modify this file and provide you with a malicious/backdoored file. You should realize that installing untrusted files into your Dom0 is a bad idea. Perhaps it might be a better idea to just get a new laptop with integrated Intel GPU? You have been warned. + + + +### Userspace components + +Install libraries, Xorg driver, configuration utilities. This can by done by nvidia-installer: + +~~~ +./NVIDIA-Linux-x86_64-260.19.44.run --ui=none --no-x-check --keep --no-nouveau-check --no-kernel-module +~~~ + +### Kernel module + +You will need: + +- nvidia kernel module sources (left from previous step) +- kernel-devel package installed +- gcc, make, etc + +This installation must be done manually, because nvidia-installer refused to install it on Xen kernel. Firstly ensure that kernel-devel package installed all needed files. This should consist of: + +- */usr/src/kernels/2.6.34.1-12.xenlinux.qubes.x86\_64* +- */lib/modules/2.6.34.1-12.xenlinux.qubes.x86\_64/build* symlinked to the above directory +- */usr/src/kernels/2.6.34.1-12.xenlinux.qubes.x86\_64/arch/x64/include/mach-xen* should be present (if not - take it from kernel sources) + +If all the files are not there correct the errors manually. To build the kernel module, enter *NVIDIA-Linux-x86\_64-260.19.44/kernel* directory and execute: + +~~~ +make +IGNORE_XEN_PRESENCE=1 CC="gcc -DNV_VMAP_4_PRESENT -DNV_SIGNAL_STRUCT_RLIM" make -f Makefile.kbuild +mv /lib/modules/2.6.34.1-12.xenlinux.qubes.x86_64/kernel/drivers/video/nvidia.ko /lib/modules/2.6.34.1-12.xenlinux.qubes.x86_64/extra/ +~~~ + +Ignore any errors while inserting nvidia.ko (at the end of make phase). + +### Disable nouveau: + +~~~ +cat /etc/modprobe.d/nouveau-disable.conf +# blacklist isn't enough... +install nouveau /bin/true +~~~ + +Add *rdblacklist=nouveau* option to /boot/grub/menu.lst (at the end of line containing *vmlinuz*). + +### Configure Xorg + +Finally, you should configure Xorg to use nvidia driver. You can use *nvidia-xconfig* or do it manually: + +~~~ +X -configure +mv /root/xorg.conf.new /etc/X11/xorg.conf +# replace Driver in Device section by "nvidia" +~~~ + +Reboot to verify all this works. + +## Troubleshooting lack of video output during installation + +The GRUB menu may show up fine, the installation environment starts loading, and then the display(s) go into standby mode. This is, typically, related to some sort of an issue with the kernel's KMS/video card modules. See the [Nvidia Troubleshooting](/doc/nvidia-troubleshooting/#lack-of-video-output-during-nvidia-driver-installation) guide for troubleshooting steps. + diff --git a/troubleshooting/nvidia-troubleshooting.md b/troubleshooting/nvidia-troubleshooting.md new file mode 100644 index 0000000..70dce19 --- /dev/null +++ b/troubleshooting/nvidia-troubleshooting.md @@ -0,0 +1,225 @@ +--- +layout: doc +title: Nvidia Troubleshooting +permalink: /doc/nvidia-troubleshooting/ +redirect_from: +- /en/doc/nvidia-troubleshooting/ +- /doc/NvidiaTroubleshooting/ +- /wiki/NvidiaTroubleshooting/ +--- + +# Nvidia Troubleshooting Guide + +## System freezes during boot / Graphical login manager is not visible + +If you have an NVidia graphics card it will probably not work under Xen out of the box. If your system freezes during boot and you don't see the graphical login manager after you installed Xen, then this problem most likely affects you. The following steps should provide a workaround so that you should be able to use your NVidia with X under Xen, however without any fancy "desktop effects". + +### Boot in failsafe + +Boot your system using the "failsafe" boot menu, that should have been automatically added to your `grub.conf` when you installed the Dom0 kernel. + +If the X Window System doesn't start now, this is probably a non-Xen related issue and this guide will probably not help you. + + +### Configure X with nouveau + +Assuming your X Window System works fine now when you booted from the "failsafe" configuration, do the next steps... + + 1. Do not log into X, but instead switch to a text console (press Ctrl-Alt-F2) + + 2. Log in as root + + 3. Switch to runlevel 3 (this should kill your X server): + + ~~~ + init 3 + ~~~ + + 4. Run X-autoconfiguration: + + ~~~ + Xorg -configure + ~~~ + + This should generate a file `xorg.conf.new` in the `/root` directory. + + In most cases you can ignore any warning or error messages displayed by the X server, assuming it generated the xorg.conf.new file. + + 5. Edit this newly generated `xorg.conf.new` file and introduce the following two modifications: + + First, uncomment the ShadowFB option, so that you should now have something like this: + + ~~~ + Option "ShadowFB" # [] + ~~~ + + Second, change the driver name to `nouveau` (you will probably have `nv` written there): + + ~~~ + Driver "nouveau" + ~~~ + + Save the modification, exit the editor. + + 6. Move the file to `/etc/X11` and rename it as `xorg.conf`: + + ~~~ + mv /root/xorg.conf.new /etc/X11/xorg.conf + ~~~ + + 7. Verify that X will work with those new settings: + + ~~~ + xinit + ~~~ + + If you see a terminal window in the top left corner, it means you most likely succeeded, even if your keyboard or mouse do not work now (don't worry about them). + + 8. Reboot and let the system boot from the normal boot configuration. You should be able to use X under Xen now. + +## Boot failure after GRUB menu / System freezes followed by reboot + +If Qubes fails to properly boot after the GRUB Boot menu and you are stuck on a black screen that displays messages starting with `nouveau` then it means that the nouveau driver failed to launch properly. + +One way to get rid of this for now is to disable nouveau. + +### Disabling Nouveau + +Example error: + +~~~ +nouveau E[ PGRAPH][0000:01:00.0] grctx template channel unload timeout +nouveau E[ PGRAPH][0000:01:00.0] failed to construct context +nouveau E[ PGRAPH][0000:01:00.0] init failed, -16 +~~~ + +Tip: In case you only have an external monitor it is advised to attach it directly to a connector of the motherboard if it is present, this should ensure that you're using the integrated graphics card instead of the nvidia graphics card. + +If you're seeing this error then that means another graphics card (most likely an integrated one) acted as failsafe. Disabling nouveau has the consequences of disabling nvidia support altogether. + +#### EFI + + 1. Open a terminal in dom0. + + 2. To edit the `xen.cfg` file using the `nano` editor: + + ~~~ + sudo nano /boot/efi/EFI/qubes/xen.cfg + ~~~ + + 3. Locate the three `kernel=` lines. Press the left/right arrow keys to position the cursor at the end of the lines, after `rhgb quiet`. + + 4. Add the following: + + ~~~ + nouveau.modeset=0 rd.driver.blacklist=nouveau video=vesa:off + ~~~ + + This will temporarily disable nouveau until next boot. + + 5. Press either the `Ctrl+X` keys, then `y` to save changes. + + 6. Reboot + +#### GRUB + + 1. Verify that that GRUB Boot Menu is displaying, you should be presented with two options and a progressbar/timer than goes rather fast. + + ~~~ + Qubes + Qubes with advanced Xen options + ~~~ + + 2. Quickly press the "E" key before the time is up. + + 3. An editor will open up that allows you to temporarily change the grub options for the next boot. + + 4. Press the down arrow key and move the cursor to the line after the line with the kernel options. The line with the kernel options will look like this: + + ~~~ + module /vmlinux-4.1.13-9.pvops.qubes.x86_64 placeholder root=/dev/mapper/qubes_dom0-root ro ... rhgb quiet + ~~~ + + It is not an exact copy as it may differ from system to system. + + Please note: choose the module that starts with `vmlinux`! + + 5. Press the left/right arrow keys to position the cursor at the end of kernel options line, after `rhgb quiet` in this case. + + 6. Add the following: + + ~~~ + nouveau.modeset=0 rd.driver.blacklist=nouveau video=vesa:off + ~~~ + + This will temporarily disable nouveau until next boot. + + 7. Press either the F10 key or Ctrl+X to start the boot process. + + Qubes should now boot properly, if that's the case then we should make this change permanent such that the GRUB config knows to not run nouveau. + +You'll have to do the following to make this change persistent, so that it will work properly on every boot : + + 1. Open a terminal (do this by clicking on Q > 'run command' > type 'terminal' and hit enter) + + 2. type following commands: + + ~~~ + cd /etc/default/ + sudo nano grub + ~~~ + + 3. Edit `GRUB_CMDLINE_LINUX`, add the following to it at the end: + + ~~~ + nouveau.modeset=0 rd.driver.blacklist=nouveau video=vesa:off + ~~~ + + 4. ctrl + X and then y to save the file. + + 5. The final step is to compile the configuration file to something the bootloader can read. + + ~~~ + sudo grub2-mkconfig -o /boot/grub2/grub.cfg + ~~~ + +## Lack of video output during Nvidia driver installation + +Specifically, the notes below are aimed to help when during Nvidia driver installation, the GRUB menu shows up fine, the installation environment starts loading, and then the display(s) go into standby mode. This is, typically, related to some sort of an issue with the kernel's KMS/video card modules. + +### Initial setup. +*Note*: The steps below do *not* produce a fully-functional Qubes OS install. Rather, only a dom0 instance is functional, and there is no networking there. However, they can be used to gather data in order to troubleshoot video card issues and/or possible other basic kernel module issues. + +1. Append `nomodeset ip=dhcp inst.nokill inst.vnc` to the kernel command line. Remove `rhgb` and `quiet` to see the kernel messages scroll by, which may help in further diagnostics. + * If DHCP is not available on the installation network, the syntax becomes a bit more involved. The full list of variants is documented in the [Dracut Command-line parameters] (http://man7.org/linux/man-pages/man7/dracut.cmdline.7.html) +2. The VGA console should switch into the installer's multi-virtual-terminal display. VNC may take a number of minutes to start, please be patient. + * Using the anaconda installer interface, switch to the "shell" TTY (ALT-F2), and use `ip a` command to display the IP addresses. +3. Using the Connect to the IP (remember the :1) using a VNC viewer. +4. Follow the installation UI. + * Since this won't be a usable install, skipping LUKS encryption is an option which will simplify this troubleshooting process. + * Do *not* reboot at the end of the installation. +5. Once the installation completes, use the local VGA console switch to TTY2 via ALT-F2 + * Switch to the chroot of the newly-installed system via `chroot /mnt/sysinstall` + * Set the root password (this will also enable the root account login) + * Double-check that `/boot/grub2/grub.cfg` contains a `nomodeset` kernel parameter. + * Exit out of the chroot environment (`exit` or CTRL-D) +6. Reboot + +*Note* If the kernel parameters do *not* include `quiet` and `rhgb`, the kernel messages can easily obscure the LUKS passphrase prompt. Additionally, each character entered will cause the LUKS passphrase prompt to repeat onto next line. Both of these are cosmetic. The trade-off between kernel messages and the easy-to-spot LUKS passphrase prompt is left as an exercise to the user. + +### Gather initial `dmesg` output +If all is well, the newly-installed Qubes OS instance should allow for user root to log in. +Run `dmesg > dmesg.nomodeset.out` to gather an initial dmesg output. + +### Gather the 'video no worky' `dmesg` output +1. Reboot and interrupt the Grub2's process, modifying the kernel parameters to no longer contain `nomodeset`. + * If the LUKS passphrase was set, blindly enter it. +2. Wait for the system to finish booting (about 5 minutes, typically). +3. Blindly switch to a TTY via CTRL-ALT-F2. +4. Blindly log in as user root +5. Blindly run `dmesg > dmesg.out` +6. Blindly run `reboot` (this will also serve to confirm that logging in as root, and running commands blindly is possible rather than, say, the kernel having hung or some such). + * Should this step fail, perhaps by the time step #3 was undertaken, the OS hasn't finished coming up yet. Please retry, possibly with a different TTY (say, 3 or 4 - so CTRL-ALT-F3?) + +### Exfiltrate the dmesg outputs +Allow the system to boot normally, log in as user root, and sneakernet the files off the system for analysis, review, bug logging, et cetera. From 1bc1602cb1e983619d4d11c3fbed086ec22f40cd Mon Sep 17 00:00:00 2001 From: Enjeck Cleopatra <32180937+PROTechThor@users.noreply.github.com> Date: Sun, 1 Nov 2020 08:35:33 +0100 Subject: [PATCH 125/136] Update nvidia-troubleshooting.md --- troubleshooting/nvidia-troubleshooting.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/troubleshooting/nvidia-troubleshooting.md b/troubleshooting/nvidia-troubleshooting.md index 70dce19..ddd922f 100644 --- a/troubleshooting/nvidia-troubleshooting.md +++ b/troubleshooting/nvidia-troubleshooting.md @@ -115,9 +115,9 @@ If you're seeing this error then that means another graphics card (most likely a nouveau.modeset=0 rd.driver.blacklist=nouveau video=vesa:off ~~~ - This will temporarily disable nouveau until next boot. + This will disable nouveau until the option is manually edited back to its original state. - 5. Press either the `Ctrl+X` keys, then `y` to save changes. + 5. Press the `Ctrl+X` keys, then `y` to save changes. 6. Reboot From b8977f4c7bf900a36889941eff8f50a3c7e44394 Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Tue, 3 Nov 2020 18:08:12 +0100 Subject: [PATCH 126/136] Edit Thinkpad Troubleshooting --- troubleshooting/thinkpad-troubleshooting.md | 94 +++++++++++++++++++++ 1 file changed, 94 insertions(+) create mode 100644 troubleshooting/thinkpad-troubleshooting.md diff --git a/troubleshooting/thinkpad-troubleshooting.md b/troubleshooting/thinkpad-troubleshooting.md new file mode 100644 index 0000000..fe58324 --- /dev/null +++ b/troubleshooting/thinkpad-troubleshooting.md @@ -0,0 +1,94 @@ +--- +layout: doc +title: Lenovo ThinkPad Troubleshooting +permalink: /doc/thinkpad-troubleshooting/ +redirect_from: +- /doc/thinkpad_x201/ +- /en/doc/thinkpad_x201/ +- /doc/Thinkpad_X201/ +- /wiki/Thinkpad_X201/ +- /doc/lenovo450-tinkering/ +- /en/doc/lenovo450-tinkering/ +- /doc/Lenovo450Tinkering/ +- /wiki/Lenovo450Tinkering/ +--- + +# Lenovo ThinkPad Troubleshooting # + +## Installation from USB stick fails for newer (UEFI-only) ThinkPads ## +Some newer ThinkPads (e.g. T470, T470p, [P51](https://www.svensemmler.org/blog/2017/12/17/qubes-on-thinkpad-p51.html), ThinkPad 25, but not the [P53](https://github.com/QubesOS/qubes-issues/issues/5851)) are likely to fail installation attempts made from a USB stick that was created with dd or Rufus, and even from a DVD burned using official ISO images - if the ThinkPad is configured for UEFI boot. If you don't want to use Legacy Mode as a workaround, the following instructions should help you create a Qubes Installation USB stick that works in UEFI-only mode. + +In a nutshell, you need to use the Fedora livecd-tools to make a Qubes Installation USB Stick from the Qubes ISO image, then update the label on the partition of that USB stick to "BOOT", and then update the BOOT/EFI/BOOTX64.cfg file on the USB stick so that all labels point to BOOT. In more detail: + +1. On your ThinkPad, enter the UEFI setup (press F1 at startup) and make sure to set at least the following options: + - *USB UEFI BIOS Support: Enabled* + - *UEFI/Legacy Boot: UEFI Only* + - *Secure Boot: Disabled* +2. On a different computer, create a "Fedora Live USB Stick": Download a current Fedora Live CD image, and put it onto a USB stick (e.g. using dd or Rufus). Start your ThinkPad from the Fedora Live USB Stick on your ThinkPad (Press F12 at startup to select boot device). Of course, you can alternatively start a different machine from the Fedora Live USB Stick, or use an existing Fedora installation. The next steps all occur within Fedora: +3. Install livecd-tools: `# dnf install livecd-tools` +4. Download the desired Qubes ISO image (or attach a storage device containing it), and verify the signatures as described in the Qubes installation guide. For these instructions, I assume the ISO image is at */run/media/liveuser/qsrc/Qubes-R4.0-rc3-x86_64.iso* (so whenever you see that path going forward in these instructions, replace it with whatever your own path is) +5. Within Fedora, attach the USB stick that you would like to turn into your Qubes Installation USB Stick. Use `dmesg` to figure out what the device name of that stick is. For these instructions, I assume it's */dev/sdd* (so whenever you see */dev/sdd* going forward in these instructions, replace it with whatever your actual device name is) +6. Make sure your target USB stick (presumed to be /dev/sdd) has no mounted partitions: ``# umount /dev/sdd*`` (the asterisk at the end makes sure to unmount all partitions if more than one exists). If none are mounted you'll get an error that you can ignore. +7. Use livecd-tools to copy the image: ``# livecd-iso-to-disk --format --efi /run/media/liveuser/qsrc/Qubes-R4.0-rc3-x86_64.iso /dev/sdd``. **This will erase everything on the drive. Make sure you specify the correct destination.** Then press ENTER when prompted to proceed. This process will take quite a while, be patient. +8. When imaging is complete, change the partition label to BOOT: ``# dosfslabel /dev/sdd1 BOOT`` +9. Now create a mount point and mount the partition: + + ``# mkdir /mnt/qinst`` + + ``# mount /dev/sdd1 /mnt/qinst/`` + +10. Use your favorite editor to edit the file */mnt/qinst/EFI/BOOT/BOOTX64.cfg*: Replace all instances of ``LABEL=Qubes-R4.0-rc3-x86_64`` with ``LABEL=BOOT``. There is typically no space in front of ``LABEL``, but there is a space at the end of the portion you replace. +11. Unmount the Qubes Installation USB stick: ``# umount /dev/sdd*`` and disconnect it. + +That's it! You can now reboot the machine with the Qubes USB Installation stick attached, and press F12 to select it as the boot device at startup. Proceed to install Qubes OS normally. Enjoy! + +## Random reboots on ThinkPads with Intel HD 3000 graphics ## + +Several ThinkPad models have Intel HD 3000 graphics, including the T420s and the +T520. Some users with these laptops have experienced random reboots, which were +solved by adding `i915.enable_rc6=0` as a kernel parameter to +`GRUB_CMDLINE_LINUX` in the file `/etc/default/grub` in dom0. + + +## Can't boot the installer from a USB on Thinkpad X201 & X200 ## + +For being able to boot the installer from USB, you have to disable VT-d in the BIOS. +Enter the BIOS by hitting F1, go to Config - CPU and then disable VT-d there. + +After the installation, you have to set a startup-parameter for Xen, to be able to activate VT-d again: + +1. Open a terminal in dom0 +2. Edit `/etc/default/grub` +3. Add to the line `GRUB_CMDLINE_XEN_DEFAULT` the setting `iommu=no-igfx`, save and quit +4. sudo `grub2-mkconfig --output /boot/grub2/grub.cfg` + +Then reboot, enter BIOS and re-enable VT-d. + +### Getting scrolling with the Trackpoint and the Middle Button to work ### + +1. Create a script with the following content: + + ~~~ + #!/bin/sh + xinput set-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation" 1 + xinput set-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation Button" 2 + xinput set-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation Timeout" 200 + xinput set-prop "TPPS/2 IBM TrackPoint" "Evdev Wheel Emulation Axes" 6 7 4 5 + ~~~ + +2. Add the script to the startup-items of your desktop environment. + + +## Can’t boot from USB stick on Lenovo 450 ## + +Lenovo 450 uses UEFI, so some settings are needed to get Qubes (or Fedora) to boot, otherwise Qubes install USB stick will reboot right after boot selector screen and not continue install. + +### Setting UEFI options to get Qubes install to boot ### + +1. Enable Legacy USB mode +2. Disable all Secure Boot and UEFI options, but leave this enabled: Config / USB / USB UEFI BIOS SUPPORT +3. Save settings and reboot +5. Install Qubes + +... and now enjoy :) These settings may be needed also in other UEFI computers. + From c07fd43a5e880ec6f83b4f90e905860be52c533d Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Sat, 7 Nov 2020 09:24:54 +0100 Subject: [PATCH 127/136] Move to external, edit headings --- troubleshooting/intel-igfx-troubleshooting.md | 65 +++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 troubleshooting/intel-igfx-troubleshooting.md diff --git a/troubleshooting/intel-igfx-troubleshooting.md b/troubleshooting/intel-igfx-troubleshooting.md new file mode 100644 index 0000000..75be156 --- /dev/null +++ b/troubleshooting/intel-igfx-troubleshooting.md @@ -0,0 +1,65 @@ +--- +layout: doc +title: Intel Integrated Graphics Troubleshooting +permalink: /doc/intel-igfx-troubleshooting/ +--- +# Intel Integrated Graphics Troubleshooting # + +## Software Rendering or Video Lags + +If you are experiencing this issue, you will see extremely slow graphics updates. +You will be able to watch the screen and elements paint slowly from top to bottom. +You can confirm this is the issue by looking for a line similar to the following in your `/var/log/Xorg.0.log` file: + + [ 131.769] (EE) AIGLX: reverting to software rendering + +Newer versions of the Linux kernel have renamed the `i915.preliminary_hw_support=1` option to `i915.alpha_support=1`, so if you needed this kernel option in the past you will have to rename it or add it to your configuration files (follow either GRUB2 or EFI, not both): + + * GRUB2: `/etc/default/grub`, `GRUB_CMDLINE_LINUX` line and + Rebuild grub config (`grub2-mkconfig -o /boot/grub2/grub.cfg`) + * EFI: `/boot/efi/EFI/qubes/xen.cfg`, `kernel=` line(s) + + +## IOMMU-related issues ## + +Dom0 Kernels currently included in Qubes have issues related to VT-d (IOMMU) and some versions of the integrated Intel Graphics Chip. +Depending on the specific hardware / software combination the issues are quite wide ranging, from apparently harmless log errors, to VM window refresh issues, to complete screen corruption and crashes rendering the machine unusable with Qubes. + +Such issues have been reported on at least the following machines: + +* HP Elitebook 2540p +* Lenovo x201 +* Lenovo x220 +* Thinkpad T410 +* Thinkpad T450s + +Log errors only on : +* Librem 13v1 +* Librem 15v2 + +The installer for Qubes 4.0 final has been updated to disable IOMMU for the integrated intel graphics by default. +However, users of 3.2 may experience issues on install or on kernel upgrades to versions higher than 3.18.x. + +Disabling IOMMU for the integrated graphics chip is not a security issue, as the device currently lives in dom0 and is not passed to a VM. +This behaviour is planned to be changed as of Qubes 4.1, when passthrough capabilities will be required for the GUI domain [1](#f1). + + +## Workaround for existing systems with VT-d enabled (grub / legacy mode) ## + +Edit the startup parameters for Xen: + +1. Open a terminal in dom0 +2. Edit `/etc/default/grub` (e.g. `sudo nano /etc/default/grub`) +3. Add to the line `GRUB_CMDLINE_XEN_DEFAULT` the setting `iommu=no-igfx`, save and quit +4. Commit the change with`sudo grub2-mkconfig --output /boot/grub2/grub.cfg` + +## Workaround for existing systems with VT-d enabled (UEFI) ## + +Edit the startup parameters for Xen: + +1. Open a terminal in dom0 +2. Edit `/boot/efi/EFI/qubes/xen.cfg` (e.g. `sudo nano /boot/efi/EFI/qubes/xen.cfg`) +3. Add to the line `options` the setting `iommu=no-igfx`, save and quit + +1 [↩](#a1-1) + From 3823984df667a529779fff02cc18f15467f70b7e Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Fri, 13 Nov 2020 21:54:48 +0100 Subject: [PATCH 128/136] Edit Macbook Troubleshooting --- troubleshooting/macbook-troubleshooting.md | 211 +++++++++++++++++++++ 1 file changed, 211 insertions(+) create mode 100644 troubleshooting/macbook-troubleshooting.md diff --git a/troubleshooting/macbook-troubleshooting.md b/troubleshooting/macbook-troubleshooting.md new file mode 100644 index 0000000..bb74047 --- /dev/null +++ b/troubleshooting/macbook-troubleshooting.md @@ -0,0 +1,211 @@ +--- +layout: doc +title: Apple MacBook Troubleshooting +permalink: /doc/macbook-troubleshooting/ +--- + +# Apple MacBook Troubleshooting + +## Boot freezes at "Setting up networking" + +After installing Qubes 3.2 on a MacBook Air 13" mid-2011 (MacBookAir 4,2), it may freeze at "Setting up networking" during booting. This issue is caused by the Broadcom Wireless adapter, if you have one. + +To fix the problem, you need to [remove the Wi-Fi card from your Mac][bluetooth-replacement] or put the Wi-Fi adapter into PCI passthrough, as explained below: + +1. Run in a terminal: + ~~~ + # diskutil list + (find your usb device) + # bless –device /dev/diskX –legacy –setBoot –nextonly # bless the disk not the partition + # reboot + ~~~ + +2. Insert your Qubes 3.2 USB flash drive. The ISOLINUX boot screen should come up. +Select Troubleshooting and Boot the Rescue image. Enter your disk password when +prompted. Select continue and after mounting the HD filesystem and launching a +shell, `chroot` as instructed. + +3. Find your Wi-Fi card: + ~~~ + # lspci + ... + 02:00.0 Network controller: Broadcom Corporation BCM43224 802.11a/b/g/n (rev 01) + ~~~ +In the above example, the device has a BDF of `02:00.0`. +To assign this device to the sys-net VM: + ~~~ + # qvm-pci -a sys-net 02:00.0 + ~~~ + +4. Create `/etc/systemd/system/qubes-pre-netvm.service` with: + ~~~ + [Unit] + Description=Netvm fix for Broadcom + Before=qubes-netvm.service + + [Service] + ExecStart=/bin/sh -c 'echo 02:00.0 > /sys/bus/pci/drivers/pciback/permissive' + Type=oneshot + RemainAfterExit=yes + + [Install] + WantedBy=multi-user.target + ~~~ + +5. To enable the `qubes-pre-netvm` services, run: + + ~~~ + systemctl enable qubes-pre-netvm.service + ~~~ + +6. After reboot, boot Mac OS X again by running in a terminal: + + ~~~ + # diskutil list + (find the HD device where you installed Qubes) + # bless –device /dev/diskX –legacy –setBoot # bless the disk not the partition + # reboot + ~~~ + +## Can't boot the installer + +You can install Qubes 3.2 on a MacBook Pro Retina, 15 inch, Mid-2015 (MacBookPro 11,5) using BIOS or UEFI (If one method fails, try the other): +* BIOS/CSM/Legacy +* UEFI plain: Here, the grub menu appears, but any gives a quick flash and returns the main menu. Then, you can boot it manually and fix the `grub.cfg` file by adding the commands `linuexefi` and `initrdefi` and pointing to the proper files in `/efi/boot`. After boot, you may end up with no root file system. +* UEFI, using rEFInd: This method may prove successful, but there are some issues to be fixed manually after the installation is complete. + 1. Download [rEFInd] refind-bin-0.10.4.zip. Note that this file is not signed, so decide if you trust it or not. The SHA1 sum is 3d69c23b7d338419e5559a93cd6ae3ec66323b1e + 2. Unzip it and run the installer, which installs rEFInd on the internal SSD + 3. If installation fails due to SIP, reboot in recovery mode, open a terminal and run the command: + ~~~ + csrutil disable + ~~~ + 4. Reboot. You will see some icons. + 5. Choose Boot EFI\BOOT\xen.efi from ANACONDA. After a while, the graphical installer is up (keyboard and touchpad working) + +## Can't boot using GRUB2 + +After installing Qubes 3.2 on a MacBook Mid-2015, you may be unable to boot using `EFI/qubes/xen.efi` because the [XEN bootloader configuration is broken](/doc/macbook-troubleshooting/#cant-boot-using-xen-bootloader). +You can't also boot using GRUB2 without XEN support because the GRUB configuration is broken as well. + +To start fixing this issue manually, switch to the console by pressing Fn+CTRL+ALT+F2. + +It can be very useful – during troubleshooting – to have a rescue system at hand. It could help you boot Qubes, even without XEN support. This troubleshoot assumes you are performing a [UEFI boot, using rEFInd](/doc/macbook-troubleshooting/#cant-boot-the-installer). + +At this point, the GRUB configuration file is using some wrong commands, which are not compatible with grub2-efi + +~~~ +chroot /mnt/sysimage +sed -i.bak -e "s/multiboot/chainloader/" -e "s/module.*--nounzip/initrdefi/" -e "s/module/linuxefi/" /etc/grub.d/20_linux_efi +exit +~~~ + +Now, despite XEN configuration is still broken, you have a rescue system booting vmlinux from rEFInd screen. +TBV1: chainloading XEN does not work, unless you specify the right disk prefix, eg: (hd1,gpt4) +TBV2: grub.cfg set the wrong disk in "set root" command +TBV3: in case you reach grub shell, you can +~~~ +ls +~~~ +and also reload config file and change it manually before booting +~~~ +configfile /EFI/qubes/grub.cfg +~~~ +Then press "e", edit `grub.cfg` and boot by pressing Fn+F10. + + +## Can't boot using XEN bootloader + +You may be unable to boot Qubes 3.2 using `EFI/qubes/xen.efi` on a MacBook Mid-2015 because the XEN bootloader configuration is broken. This issue is accompanied by the GRUB2 configuration being broken as well. After [fixing the GRUB configuration](/doc/macbook-troubleshooting/#cant-boot-using-grub2), follow the following steps to fix the bootloader. This troubleshoot assumes you are performing a [UEFI boot, using rEFInd](/doc/macbook-troubleshooting/#cant-boot-the-installer). + +* Fix grub2 configuration, which uses wrong command for EFI boot +* Analyzing `/mnt/sysimage/var/log/anaconda/program.log`, you may find the faulty commands issued by the Anaconda installer. + ~~~ + chrooot /mnt/sysimage + ~~~ +* Edit the `/boot/efi/EFI/qubes/xen.cfg` file to add the following content: + ~~~ + [global] + default=4.4.14-11.pvops.qubes.x868_64 + + [4.4.14-11.pvops.qubes.x868_64] + options=loglvl=all dom0_mem=min:1024M dom0_mem=max:4096M + kernel=vmlinuz-4.4.14-11.pvops.qubes.x86_64 + ramdisk=initramfs-4.4.14-11.pvops.qubes.x86_64.img + ~~~ + +* The main mistake is that `efibootmgr` needs the right commands. Just in case, reapply all the commands, adapting them to your own disk layout (`-d /dev/sdxxx -p partition_number`) + +~~~ +grep Running /mnt/sysimage/var/log/anaconda/program.log | tail -n 20 +efibootmgr -b 0000 -B +efibootmgr -c -w -L Qubes -d /dev/sda -p 4 -l \\EFI\\qubes\\xen-4.6.1.efi +/usr/libexec/mactel-boot-setup +kernel-install add 4.4.14-11.pvops.qubes.x86_64 /boot/vmlinuz-4.4.14-11.pvops.qubes.x86_64 +systemctl disable qubes-netvm +reboot +~~~ + +At the rEFInd screen, choose Boot EFI/qubes/xen-4.6.1.efi. +Everything should now be ok, Qubes OS boots using EFI and you will get the last setup screen. +Select "Qubes OS", do not change anything and click on "Done". +VMs are created, including NetVM. + +## System freezes often for 20 seconds + +Using Qubes 3.2 on the MacBook Mid-2015 was reported to have frequent freezes, which lasts for 20 seconds. Upon looking at the `journalctl` output, you may see that pulseaudio locks the CPU for 20 seconds, very often. + +To fix this issue, kill audio support with this quick workaround: +1. Open a dom0 terminal as root +2. Edit `/etc/pulse/client.conf` and add `autospawn = no` +3. As normal user, kill pulseaudio with the command `pulseaudio --kill` + +## System freezes after attaching Broadcom BCM43602 Wi-Fi card + +You may experience system freezes or crashes after attaching a Broadcom Wi-Fi adapter to the sys-net VM. This issue has been reported to exist on both Qubes 3.2 and 4.0. For Qubes 4.0, you may have to replace the Wi-Fi card, as described in the [PCI Troubleshooting](/doc/pci-troubleshooting/#broadcom-bcm43602-wi-fi-card-causes-system-freeze) guide. + +The following troubleshoot is known to work on Qubes 3.2: + +1. During VM setup, force a reboot and press `OPTION` key. + +2. You will reach the grub shell + ~~~ + configfile /EFI/qubes/grub.cfg + ~~~ + +3. Press Fn+F10 to boot without XEN support. + +4. Once booted, press Fn+CTRL+ALT+F4 to open a shell. + +5. Log into the system + ~~~ + sudo su - + systemctl disable qubes-netvm + ~~~ + +6. Press Fn+F2 and complete the setup. +7. Reboot Qubes. +8. DO NOT launch the sys-net qube. +Rather, open its setting and remove the Wi-Fi adapter from the Selected devices using the Qubes Manager. +You can also remove it from the command line, if you know the BDF of the adapter. +You can see the list of devices attached to sys-net and their associated BDFs by running: + ~~~ + qvm-pci -l sys-net + ~~~ +For a device with a BDF of `04:00.0`, you can remove it with: + ~~~ + qvm-pci -d sys-net 04:00.0 + ~~~ +9. In a dom0 terminal, run: + ~~~ + sudo su - + xl pci-assignable-list + echo 04:00.0 > /sys/bus/pci/drivers/pciback/permissive + qvm-start sys-net + xl pci-attach sys-net DEVICE_BDF + ~~~ +Be sure to replace "DEVICE_BDF" with the actual BDF of the Wi-Fi adapter. + +After following the above steps, you should be able to launch sys-net with Wi-Fi access. These steps can be automated in a custom `systemd` service. + +[bluetooth-replacement]: https://www.ifixit.com/Guide/MacBook+Air+13-Inch+Mid+2011+AirPort-Bluetooth+Card+Replacement/6360 +[rEFInd]: http://www.rodsbooks.com/refind/getting.html From 9d0dcf0231b42c347a1d037b3055e6f65e162073 Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Fri, 13 Nov 2020 22:48:09 +0100 Subject: [PATCH 129/136] Add more information --- troubleshooting/macbook-troubleshooting.md | 124 +++++++++++++-------- 1 file changed, 77 insertions(+), 47 deletions(-) diff --git a/troubleshooting/macbook-troubleshooting.md b/troubleshooting/macbook-troubleshooting.md index bb74047..86854c1 100644 --- a/troubleshooting/macbook-troubleshooting.md +++ b/troubleshooting/macbook-troubleshooting.md @@ -6,6 +6,83 @@ permalink: /doc/macbook-troubleshooting/ # Apple MacBook Troubleshooting +## System freezes after attaching Broadcom BCM43602 Wi-Fi card + +You may experience system freezes or crashes after attaching a Broadcom Wi-Fi adapter to the sys-net VM. This issue has been reported to exist on both Qubes 3.2 and 4.0. + +### Qubes 3.2 + +To fix this issue on Qubes 3.2: + +1. During VM setup, force a reboot and press `OPTION` key. + +2. You will reach the grub shell + ~~~ + configfile /EFI/qubes/grub.cfg + ~~~ + +3. Press Fn+F10 to boot without XEN support. + +4. Once booted, press Fn+CTRL+ALT+F4 to open a shell. + +5. Log into the system + ~~~ + sudo su - + systemctl disable qubes-netvm + ~~~ + +6. Press Fn+F2 and complete the setup. +7. Reboot Qubes. +8. DO NOT launch the sys-net qube. +Rather, open its setting and remove the Wi-Fi adapter from the Selected devices using the Qubes Manager. +You can also remove it from the command line, if you know the BDF of the adapter. +You can see the list of devices attached to sys-net and their associated BDFs by running: + ~~~ + qvm-pci -l sys-net + ~~~ +For a device with a BDF of `04:00.0`, you can remove it with: + ~~~ + qvm-pci -d sys-net 04:00.0 + ~~~ +9. In a dom0 terminal, run: + ~~~ + sudo su - + xl pci-assignable-list + echo 04:00.0 > /sys/bus/pci/drivers/pciback/permissive + qvm-start sys-net + xl pci-attach sys-net DEVICE_BDF + ~~~ +Be sure to replace "DEVICE_BDF" with the actual BDF of the Wi-Fi adapter. + +After following the above steps, you should be able to launch sys-net with Wi-Fi access. These steps can be automated in a custom `systemd` service. + +### Qubes 4.0 + +For Qubes 4.0, you may have to remove the wireless card from sys-net or replace it, as described in the [PCI Troubleshooting](/doc/pci-troubleshooting/#broadcom-bcm43602-wi-fi-card-causes-system-freeze) guide. + +It is a bit tricky to execute, but you may be able to successfully attach a Broadcom BCM43602 to sys-net by executing the `attach` command immediately after starting sys-net. Follow these steps: + +1. Disable "Start qube automatically on boot" for sys-net and sys-firewall in the Qubes Manager. +2. Manually start sys-net using the `qvm-start sys-net` command. +3. Immediately (About 2 seconds later) after stating sys-net, attach the device to sys-net using permissive mode: +`sudo xl pci-attach sys-net 'DEVICE_BDF,permissive=1` +Replace `DEVICE_BDF,` with the BDF of your wireless card. If you can immediately attach the device to sys-net while it is still starting up, it could work. If it is attached too late, the VM doesn't seem to detect it. + +You can use the following script to do the above steps quickly after each boot: + +~~~ +#!/bin/bash +qvm-start sys-net & +sleep 3 +sudo xl pci-attach sys-net '03:00.0,permissive=1' +~~~ + +## Broadcom BCM4360 doesn't work in a Fedora-based qube + +Several people have been unable use the Broadcom BCM4360 Wireless card on a Fedora-based qube. This issue appears to be [related to Fedora](https://ask.fedoraproject.org/t/cant-connect-to-wifi-after-update-bcm4360-with-broadcom-wl-driver/482?page=2), not Qubes. + +To get internet access in sys-net, try shutting down all your VMs, then changing sys-net to use the Debian 10 template. Finally, install the [broadcom-sta-dkms](https://pkgs.org/download/broadcom-sta-dkms) package. + ## Boot freezes at "Setting up networking" After installing Qubes 3.2 on a MacBook Air 13" mid-2011 (MacBookAir 4,2), it may freeze at "Setting up networking" during booting. This issue is caused by the Broadcom Wireless adapter, if you have one. @@ -159,53 +236,6 @@ To fix this issue, kill audio support with this quick workaround: 2. Edit `/etc/pulse/client.conf` and add `autospawn = no` 3. As normal user, kill pulseaudio with the command `pulseaudio --kill` -## System freezes after attaching Broadcom BCM43602 Wi-Fi card - -You may experience system freezes or crashes after attaching a Broadcom Wi-Fi adapter to the sys-net VM. This issue has been reported to exist on both Qubes 3.2 and 4.0. For Qubes 4.0, you may have to replace the Wi-Fi card, as described in the [PCI Troubleshooting](/doc/pci-troubleshooting/#broadcom-bcm43602-wi-fi-card-causes-system-freeze) guide. - -The following troubleshoot is known to work on Qubes 3.2: - -1. During VM setup, force a reboot and press `OPTION` key. - -2. You will reach the grub shell - ~~~ - configfile /EFI/qubes/grub.cfg - ~~~ - -3. Press Fn+F10 to boot without XEN support. - -4. Once booted, press Fn+CTRL+ALT+F4 to open a shell. - -5. Log into the system - ~~~ - sudo su - - systemctl disable qubes-netvm - ~~~ - -6. Press Fn+F2 and complete the setup. -7. Reboot Qubes. -8. DO NOT launch the sys-net qube. -Rather, open its setting and remove the Wi-Fi adapter from the Selected devices using the Qubes Manager. -You can also remove it from the command line, if you know the BDF of the adapter. -You can see the list of devices attached to sys-net and their associated BDFs by running: - ~~~ - qvm-pci -l sys-net - ~~~ -For a device with a BDF of `04:00.0`, you can remove it with: - ~~~ - qvm-pci -d sys-net 04:00.0 - ~~~ -9. In a dom0 terminal, run: - ~~~ - sudo su - - xl pci-assignable-list - echo 04:00.0 > /sys/bus/pci/drivers/pciback/permissive - qvm-start sys-net - xl pci-attach sys-net DEVICE_BDF - ~~~ -Be sure to replace "DEVICE_BDF" with the actual BDF of the Wi-Fi adapter. - -After following the above steps, you should be able to launch sys-net with Wi-Fi access. These steps can be automated in a custom `systemd` service. [bluetooth-replacement]: https://www.ifixit.com/Guide/MacBook+Air+13-Inch+Mid+2011+AirPort-Bluetooth+Card+Replacement/6360 [rEFInd]: http://www.rodsbooks.com/refind/getting.html From 105eb3c29dcec6ae73d272ac2882617ae3def3f6 Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Sat, 14 Nov 2020 06:26:22 +0100 Subject: [PATCH 130/136] Edit Sony Vaio Tinkering --- troubleshooting/sony-vaio-tinkering.md | 58 ++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 troubleshooting/sony-vaio-tinkering.md diff --git a/troubleshooting/sony-vaio-tinkering.md b/troubleshooting/sony-vaio-tinkering.md new file mode 100644 index 0000000..64e3df2 --- /dev/null +++ b/troubleshooting/sony-vaio-tinkering.md @@ -0,0 +1,58 @@ +--- +layout: doc +title: Sony Vaio Tinkering +permalink: /doc/sony-vaio-tinkering/ +redirect_from: +- /en/doc/sony-vaio-tinkering/ +- /doc/SonyVaioTinkering/ +- /wiki/SonyVaioTinkering/ +--- + +Instructions for getting your Sony Vaio Z laptop working with Qubes/Linux +========================================================================= + +The following issues were reported on Qubes 3.2 and may not be prevalent on Qubes 4.0. + +Graphics card does not work +--------------------------- + +Newer models of Sony Vaio Z come with an "intelligent" GPU switch, that automatically chooses either Intel Integrated GPU (IGD) or the discrete NVIDIA GPU. This confuses the Linux graphics so much, that in most cases, it won't even be able to install a regular Linux on such a machine. Unfortunately, moving the switch into the "Stamina" position apparently doesn't work, and the automatic GPU switching is still active. + +One solution that actually worked for me was to reflash the BIOS (I know, I know, this is scary) and to enable the so called "Advanced Menu" in the BIOS. This Advanced Menu allows you to choose the desired behaviour of the GPU switch, which in our case would be to set it to "Static" and then move the mechanical switch to the "Stamina" position, that enabled the Intel IGD (which is much better supported on Linux). + +If you think you are ready to reflash you BIOS, you can follow [these instructions](http://forum.notebookreview.com/sony/473226-insyde-hacking-new-vaio-z-advanced-menu-bios.html). + +**WARNING**: We take absolutely no responsibility that the BIOS reflashing instructions given at the referenced forum are 1) valid, 2) non-malicious, and 3) work at all. Do this step at your own risk. Keep in mind that reflashing your BIOS might yield your system unusable. If you don't feel like taking this risk (which is a reasonable state of mind), look for a different notebook, or ask Sony Support to enable this option for you. + +In practice I have downloaded the BIOS-patching tools, run them in a VM on a BIOS image I extracted from my laptop, diffed the two versions, and concluded that it doesn't *seem* malicious, and then bravely applied that patched image. If you don't know what are you doing, just get a different laptop, really! + +On a side note, we should note that allowing anybody to reflash the BIOS is really a bad idea from a security point of view (Hello Evil Maids!). Shame on you, Sony! + +Touchpad does not work during installation +------------------------------------------ + +In order to get the touchpad working during installation you should pass the `i8042.nopnp=1` option to the kernel before the installer starts: + +~~~ +sudo nano /etc/default/grub +GRUB_CMDLINE_LINUX_DEFAULT="i8042.nopnp=1" +~~~ + +Applying other fixes +-------------------- + +There are a few more fixes needed for Sony Vaio Z, and we have prepared a special package that you can install in dom0 that applies them all. After the installation is complete, open a console in dom0 and do the following: + +~~~ +$ sudo bash +# qvm-dom0-networking up +# yum install qubes-core-dom0-vaio-fixes +# reboot +~~~ + +This script takes care about the following: + +- Setting i8042.nopnp for your installed system +- Adding special option for the sound module (so you can get sound) +- Adding pm-suspend scripts that take care about restoring your screen after resume + From 37b58f7388e9ec100d1cd55c355966e4fa98345a Mon Sep 17 00:00:00 2001 From: Enjeck Cleopatra <32180937+PROTechThor@users.noreply.github.com> Date: Sat, 14 Nov 2020 06:32:10 +0100 Subject: [PATCH 131/136] Change word --- troubleshooting/sony-vaio-tinkering.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/troubleshooting/sony-vaio-tinkering.md b/troubleshooting/sony-vaio-tinkering.md index 64e3df2..34e4552 100644 --- a/troubleshooting/sony-vaio-tinkering.md +++ b/troubleshooting/sony-vaio-tinkering.md @@ -24,7 +24,7 @@ If you think you are ready to reflash you BIOS, you can follow [these instructio **WARNING**: We take absolutely no responsibility that the BIOS reflashing instructions given at the referenced forum are 1) valid, 2) non-malicious, and 3) work at all. Do this step at your own risk. Keep in mind that reflashing your BIOS might yield your system unusable. If you don't feel like taking this risk (which is a reasonable state of mind), look for a different notebook, or ask Sony Support to enable this option for you. -In practice I have downloaded the BIOS-patching tools, run them in a VM on a BIOS image I extracted from my laptop, diffed the two versions, and concluded that it doesn't *seem* malicious, and then bravely applied that patched image. If you don't know what are you doing, just get a different laptop, really! +In practice I have downloaded the BIOS-patching tools, run them in a VM on a BIOS image I extracted from my laptop, diffed the two versions, and concluded that it doesn't *seem* malicious, and then bravely applied the patched image. If you don't know what are you doing, just get a different laptop, really! On a side note, we should note that allowing anybody to reflash the BIOS is really a bad idea from a security point of view (Hello Evil Maids!). Shame on you, Sony! From 50592853cb2f538dc2e16d391b7952b3e2ca4319 Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Sat, 21 Nov 2020 12:02:25 +0100 Subject: [PATCH 132/136] Add App Troubleshooting --- .../application-troubleshooting.md | 44 +++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 troubleshooting/application-troubleshooting.md diff --git a/troubleshooting/application-troubleshooting.md b/troubleshooting/application-troubleshooting.md new file mode 100644 index 0000000..434e511 --- /dev/null +++ b/troubleshooting/application-troubleshooting.md @@ -0,0 +1,44 @@ +--- +layout: doc +title: Application Troubleshooting +permalink: /doc/application-troubleshooting/ +--- + +# Troubleshooting default applications on Qubes # + +## Fullscreen Firefox is frozen ## + +Press F11 twice. + +## Firefox crashes ## + +If you are facing frequent crashes or lags when using Firefox browser (especially when watching videos), you may need to turn off Hardware Acceleration. You can do this by navigating to "Preferences", then "Performance". Untick the "Use recommended performance settings" checkbox, followed by "Use hardware acceleration when available". + +If this doesn't fix the issue, try turning off smooth scrolling by unticking "Use smoothing scrolling" under the "Browsing" section. + +## LibreOffice open as a tiny window ## + +Some programs like LibreOffice open as a tiny window -- small enough that the content of the file is not even visible. + +You can open LibreOffice as a larger window using this workaround: + +### Using the command line +1. In the VM where you want to open the LibreOffice, open the `registrymodifications.xcu` file in an editor: + ~~~ + sudo nano ~/.config/libreoffice/4/user/registrymodifications.xcu + ~~~ + +2. Find the lines containing `ooSetupFactoryWindowAttributes`. It will look like this: +~~~ +61,61,1807,982;5;38,56,1807,982; + +3. We are interested in the values between the `` tag. These window position values are specified as: `x-pos,y-pos,width,height ; window-state ; maximized-x-pos,maximized-y-pos,maximized-width,maximized-height`. Edit the third and fourth values to your desired width and height (for example, to 1800 and 900). +4. Do this once for every template and the program will always open at this size. + +### Using the GUI +1. Open any Libreoffice app. +2. Navigate to the "Tools" menu, select "Options", then "Advanced". Click the "Open Expert Configuration" button. +3. Search for "ooSetupFactoryWindowAttributes". +4. Scroll right to see the values set for each component as a string value. For example: `61,61,1807,982;5;38,56,1807,982;`. These window position values are specified as: `x-pos,y-pos,width,height ; window-state ; maximized-x-pos,maximized-y-pos,maximized-width,maximized-height`. Edit the third and fourth values to your desired width and height (for example, to 1800 and 900). +5. Do this once for every template and the program will always open at this size. + From 6b7e22c3fa18d2e4a91a490b836388cd8b570209 Mon Sep 17 00:00:00 2001 From: Enjeck Cleopatra <32180937+PROTechThor@users.noreply.github.com> Date: Sat, 21 Nov 2020 12:06:05 +0100 Subject: [PATCH 133/136] Add ~~~ and space --- troubleshooting/application-troubleshooting.md | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/troubleshooting/application-troubleshooting.md b/troubleshooting/application-troubleshooting.md index 434e511..b8aa8d7 100644 --- a/troubleshooting/application-troubleshooting.md +++ b/troubleshooting/application-troubleshooting.md @@ -29,8 +29,9 @@ You can open LibreOffice as a larger window using this workaround: ~~~ 2. Find the lines containing `ooSetupFactoryWindowAttributes`. It will look like this: -~~~ -61,61,1807,982;5;38,56,1807,982; + ~~~ + 61,61,1807,982;5;38,56,1807,982; + ~~~ 3. We are interested in the values between the `` tag. These window position values are specified as: `x-pos,y-pos,width,height ; window-state ; maximized-x-pos,maximized-y-pos,maximized-width,maximized-height`. Edit the third and fourth values to your desired width and height (for example, to 1800 and 900). 4. Do this once for every template and the program will always open at this size. From aec231de1379a3da5f927e7328f944a68279962c Mon Sep 17 00:00:00 2001 From: PROTechThor Date: Sat, 21 Nov 2020 12:26:46 +0100 Subject: [PATCH 134/136] Add Tails Troubleshooting --- privacy-guides/tails.md | 36 ++++-------------------- troubleshooting/tails-troubleshooting.md | 33 ++++++++++++++++++++++ 2 files changed, 39 insertions(+), 30 deletions(-) create mode 100644 troubleshooting/tails-troubleshooting.md diff --git a/privacy-guides/tails.md b/privacy-guides/tails.md index be20901..a159df4 100644 --- a/privacy-guides/tails.md +++ b/privacy-guides/tails.md @@ -47,36 +47,7 @@ To run Tails under Qubes: 7. Use Tails as normal. -## Usage Notes - -### Display issues: -**Black screen on start up.** - -This was reported with earlier versions of Tails: The problem should now be fixed. -If you do encounter this problem, you can try to constrain display settings by appending vga codes to the Tails boot parameters. -(If you do not know the codes, append `vga=999`, and a helpful prompt will appear.) - -N.B Tails 2.3 does not appear to honour the vga code. - -**Window extends beyond the bottom of the screen.** - -This seems to arise because Tails sizes to the height of the screen, but there is a title bar at the top of the window. -Either remove the title bar altogether, or move the window upwards using ALT+drag. - -### Persistent Volume -The persistence tools will not work because Tails has not been launched from USB. -The HVM disk(s) can be configured and mounted from within Tails to provide persistent storage. -If you want to use an existing USB persistent volume: - - Interrupt the Tails vm boot process with arrow-up when the grub boot menu appears. - - In dom0 attach the USB drive containing the persistent volume to the Tails vm. - - Continue booting Tails: Tails-greeter will detect the encrypted partition on the attached USB. - - Unlock the persistent volume in Tails-greeter and use it as normal. - -### Shutdown -The Tails qube will not shut down cleanly. -Kill it from the GUI Manager or ```qvm-kill Tails``` in Konsole. - -### Security +## Security You will probably want to implement [MAC spoofing](/doc/anonymizing-your-mac-address/). There are added security concerns for Tails users when running it in a virtual machine. @@ -84,3 +55,8 @@ If you intend to do this, you should read [the warnings](https://tails.boum.org/ While the Qubes security model mitigates most of the risks identified, traces of the Tails session may remain on the disk. Live booting Tails, though less convenient, is always more secure than using it inside virtualization software or Qubes, because you don't run the added risk of the virtualization software or Host OS being compromised. Depending on your threat model, this might induce too much risk. + +## Troubleshooting + +See the [Tails Troubleshooting guide](/doc/tails-troubleshooting/). + diff --git a/troubleshooting/tails-troubleshooting.md b/troubleshooting/tails-troubleshooting.md new file mode 100644 index 0000000..2d5d855 --- /dev/null +++ b/troubleshooting/tails-troubleshooting.md @@ -0,0 +1,33 @@ +--- +layout: doc +title: Tails Troubleshooting +permalink: /doc/tails-troubleshooting/ +--- + +# Tails Troubleshooting Guide # + +## Black screen during startup + +This was reported with earlier versions of Tails -- the problem should now be fixed. +If you do encounter a black screen during Tails startup, you can try to constrain display settings by appending vga codes to the Tails boot parameters. +If you do not know the codes, append `vga=999`, and a helpful prompt will appear. + +Note: Tails 2.3 does not appear to honour the vga code. + +## Window extends beyond the bottom of the screen + +This problem seems to arise because Tails sizes to the height of the screen, but there is a title bar at the top of the window. +Either remove the title bar altogether, or move the window upwards using ALT+drag. + +## Persistent tools do not work +The persistence tools, such as persistent volume, may not work because Tails has not been launched from USB. +The HVM disk(s) can be configured and mounted from within Tails to provide persistent storage. +If you want to use an existing USB persistent volume: +1. Interrupt the Tails vm boot process with arrow-up when the grub boot menu appears. +2. In dom0 attach the USB drive containing the persistent volume to the Tails VM. +3. Continue booting Tails. Tails-greeter will detect the encrypted partition on the attached USB. +4. Unlock the persistent volume in Tails-greeter and use it as normal. + +## Tails qube doesn't shut down cleanly +If the Tails qube will not shut down cleanly, you can kill it from the GUI Manager or enter ```qvm-kill Tails``` in the console. + From c7f785452a700e77dae530e9fd419626075b4f28 Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Mon, 7 Dec 2020 17:04:29 -0800 Subject: [PATCH 135/136] Convert absolute to relative links Absolute links break automatic onion redirection: https://groups.google.com/g/qubes-users/c/NJdzP27wvmM/ --- building-guides/building-archlinux-template.md | 2 +- configuration-guides/vpn.md | 2 +- customization-guides/language-localization.md | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/building-guides/building-archlinux-template.md b/building-guides/building-archlinux-template.md index 9fe8ac8..4ab4811 100644 --- a/building-guides/building-archlinux-template.md +++ b/building-guides/building-archlinux-template.md @@ -326,7 +326,7 @@ I tried to rebuild archlinux and got the same issue. The issue come from a systemd unit named "qubes-mount-dirs". We want to know more about that. We can't execute command into the qube, so let's shut it down. Then, we mount the archlinux root disk into a DisposableVM ( [mount_lvm_image.sh](https://github.com/Qubes-Community/Contents/blob/master/code/OS-administration/mount_lvm_image.sh) -& [mount-lvm-image](https://www.qubes-os.org/doc/mount-lvm-image/) ) +& [mount-lvm-image](/doc/mount-lvm-image/) ) ```shell_session $ ./mount_lvm_image.sh /dev/qubes_dom0/vm-archlinux-minimal-root fedora-dvm ``` diff --git a/configuration-guides/vpn.md b/configuration-guides/vpn.md index 002a28f..81b5aa1 100644 --- a/configuration-guides/vpn.md +++ b/configuration-guides/vpn.md @@ -312,7 +312,7 @@ Configure your AppVMs to use the VPN VM as a NetVM... ![Settings-NetVM.png](/attachment/wiki/VPN/Settings-NetVM.png) -If you want to update your TemplateVMs through the VPN, you can enable the `qubes-updates-proxy` service for your new VPN VM and configure the [qubes-rpc policy](https://www.qubes-os.org/doc/software-update-domu/#updates-proxy). +If you want to update your TemplateVMs through the VPN, you can enable the `qubes-updates-proxy` service for your new VPN VM and configure the [qubes-rpc policy](/doc/software-update-domu/#updates-proxy). Troubleshooting diff --git a/customization-guides/language-localization.md b/customization-guides/language-localization.md index 50ab8cc..ac4f5d1 100644 --- a/customization-guides/language-localization.md +++ b/customization-guides/language-localization.md @@ -14,7 +14,7 @@ Language Localization Enable UTF-8 in dom0 title bars ------------------------- -You can enable UTF-8 characters in the title bar for all qubes or on a per-qube basis. Follow the instructions [here](https://www.qubes-os.org/doc/config-files/#gui-and-audio-configuration-in-dom0) for further information. +You can enable UTF-8 characters in the title bar for all qubes or on a per-qube basis. Follow the instructions [here](/doc/config-files/#gui-and-audio-configuration-in-dom0) for further information. How to set up pinyin input in Qubes ----------------------------------- From 0c3f3bacfa66790effadecb12f465ba1eeafac65 Mon Sep 17 00:00:00 2001 From: Andrew David Wong Date: Mon, 7 Dec 2020 20:00:31 -0800 Subject: [PATCH 136/136] Rename directories to match target repo structure --- {building-guides => docs/building}/building-archlinux-template.md | 0 .../building}/building-non-fedora-template.md | 0 {building-guides => docs/building}/building-whonix-template.md | 0 {configuration-guides => docs/configuration}/change-time-zone.md | 0 {configuration-guides => docs/configuration}/disk-trim.md | 0 {configuration-guides => docs/configuration}/external-audio.md | 0 {configuration-guides => docs/configuration}/fetchmail.md | 0 .../configuration}/install-nvidia-driver.md | 0 {configuration-guides => docs/configuration}/multiboot.md | 0 {configuration-guides => docs/configuration}/multimedia.md | 0 {configuration-guides => docs/configuration}/mutt.md | 0 .../configuration}/network-bridge-support.md | 0 {configuration-guides => docs/configuration}/network-printer.md | 0 {configuration-guides => docs/configuration}/postfix.md | 0 {configuration-guides => docs/configuration}/rxvt.md | 0 {configuration-guides => docs/configuration}/tips-and-tricks.md | 0 {configuration-guides => docs/configuration}/vpn.md | 0 {configuration-guides => docs/configuration}/w3m.md | 0 {configuration-guides => docs/configuration}/zfs.md | 0 {customization-guides => docs/customization}/dark-theme.md | 0 .../customization}/fedora-minimal-template-customization.md | 0 .../customization}/language-localization.md | 0 .../customization}/removing-templatevm-packages.md | 0 .../customization}/windows-template-customization.md | 0 {os-guides => docs/os}/centos.md | 0 {os-guides => docs/os}/gentoo.md | 0 {os-guides => docs/os}/linux-hvm-tips.md | 0 {os-guides => docs/os}/netbsd.md | 0 {os-guides => docs/os}/pentesting.md | 0 {os-guides => docs/os}/pentesting/blackarch.md | 0 {os-guides => docs/os}/pentesting/kali.md | 0 {os-guides => docs/os}/pentesting/ptf.md | 0 {os-guides => docs/os}/ubuntu.md | 0 {os-guides => docs/os}/windows/windows-tools.md | 0 {os-guides => docs/os}/windows/windows-vm.md | 0 {privacy-guides => docs/privacy}/anonymizing-your-mac-address.md | 0 {privacy-guides => docs/privacy}/signal.md | 0 {privacy-guides => docs/privacy}/tails.md | 0 {privacy-guides => docs/privacy}/torvm.md | 0 {privacy-guides => docs/privacy}/whonix.md | 0 {security-guides => docs/security}/multifactor-authentication.md | 0 {security-guides => docs/security}/security-guidelines.md | 0 {security-guides => docs/security}/split-bitcoin.md | 0 .../troubleshooting}/application-troubleshooting.md | 0 .../troubleshooting}/intel-igfx-troubleshooting.md | 0 .../troubleshooting}/macbook-troubleshooting.md | 0 .../troubleshooting}/nvidia-troubleshooting.md | 0 {troubleshooting => docs/troubleshooting}/sony-vaio-tinkering.md | 0 .../troubleshooting}/tails-troubleshooting.md | 0 .../troubleshooting}/thinkpad-troubleshooting.md | 0 50 files changed, 0 insertions(+), 0 deletions(-) rename {building-guides => docs/building}/building-archlinux-template.md (100%) rename {building-guides => docs/building}/building-non-fedora-template.md (100%) rename {building-guides => docs/building}/building-whonix-template.md (100%) rename {configuration-guides => docs/configuration}/change-time-zone.md (100%) rename {configuration-guides => docs/configuration}/disk-trim.md (100%) rename {configuration-guides => docs/configuration}/external-audio.md (100%) rename {configuration-guides => docs/configuration}/fetchmail.md (100%) rename {configuration-guides => docs/configuration}/install-nvidia-driver.md (100%) rename {configuration-guides => docs/configuration}/multiboot.md (100%) rename {configuration-guides => docs/configuration}/multimedia.md (100%) rename {configuration-guides => docs/configuration}/mutt.md (100%) rename {configuration-guides => docs/configuration}/network-bridge-support.md (100%) rename {configuration-guides => docs/configuration}/network-printer.md (100%) rename {configuration-guides => docs/configuration}/postfix.md (100%) rename {configuration-guides => docs/configuration}/rxvt.md (100%) rename {configuration-guides => docs/configuration}/tips-and-tricks.md (100%) rename {configuration-guides => docs/configuration}/vpn.md (100%) rename {configuration-guides => docs/configuration}/w3m.md (100%) rename {configuration-guides => docs/configuration}/zfs.md (100%) rename {customization-guides => docs/customization}/dark-theme.md (100%) rename {customization-guides => docs/customization}/fedora-minimal-template-customization.md (100%) rename {customization-guides => docs/customization}/language-localization.md (100%) rename {customization-guides => docs/customization}/removing-templatevm-packages.md (100%) rename {customization-guides => docs/customization}/windows-template-customization.md (100%) rename {os-guides => docs/os}/centos.md (100%) rename {os-guides => docs/os}/gentoo.md (100%) rename {os-guides => docs/os}/linux-hvm-tips.md (100%) rename {os-guides => docs/os}/netbsd.md (100%) rename {os-guides => docs/os}/pentesting.md (100%) rename {os-guides => docs/os}/pentesting/blackarch.md (100%) rename {os-guides => docs/os}/pentesting/kali.md (100%) rename {os-guides => docs/os}/pentesting/ptf.md (100%) rename {os-guides => docs/os}/ubuntu.md (100%) rename {os-guides => docs/os}/windows/windows-tools.md (100%) rename {os-guides => docs/os}/windows/windows-vm.md (100%) rename {privacy-guides => docs/privacy}/anonymizing-your-mac-address.md (100%) rename {privacy-guides => docs/privacy}/signal.md (100%) rename {privacy-guides => docs/privacy}/tails.md (100%) rename {privacy-guides => docs/privacy}/torvm.md (100%) rename {privacy-guides => docs/privacy}/whonix.md (100%) rename {security-guides => docs/security}/multifactor-authentication.md (100%) rename {security-guides => docs/security}/security-guidelines.md (100%) rename {security-guides => docs/security}/split-bitcoin.md (100%) rename {troubleshooting => docs/troubleshooting}/application-troubleshooting.md (100%) rename {troubleshooting => docs/troubleshooting}/intel-igfx-troubleshooting.md (100%) rename {troubleshooting => docs/troubleshooting}/macbook-troubleshooting.md (100%) rename {troubleshooting => docs/troubleshooting}/nvidia-troubleshooting.md (100%) rename {troubleshooting => docs/troubleshooting}/sony-vaio-tinkering.md (100%) rename {troubleshooting => docs/troubleshooting}/tails-troubleshooting.md (100%) rename {troubleshooting => docs/troubleshooting}/thinkpad-troubleshooting.md (100%) diff --git a/building-guides/building-archlinux-template.md b/docs/building/building-archlinux-template.md similarity index 100% rename from building-guides/building-archlinux-template.md rename to docs/building/building-archlinux-template.md diff --git a/building-guides/building-non-fedora-template.md b/docs/building/building-non-fedora-template.md similarity index 100% rename from building-guides/building-non-fedora-template.md rename to docs/building/building-non-fedora-template.md diff --git a/building-guides/building-whonix-template.md b/docs/building/building-whonix-template.md similarity index 100% rename from building-guides/building-whonix-template.md rename to docs/building/building-whonix-template.md diff --git a/configuration-guides/change-time-zone.md b/docs/configuration/change-time-zone.md similarity index 100% rename from configuration-guides/change-time-zone.md rename to docs/configuration/change-time-zone.md diff --git a/configuration-guides/disk-trim.md b/docs/configuration/disk-trim.md similarity index 100% rename from configuration-guides/disk-trim.md rename to docs/configuration/disk-trim.md diff --git a/configuration-guides/external-audio.md b/docs/configuration/external-audio.md similarity index 100% rename from configuration-guides/external-audio.md rename to docs/configuration/external-audio.md diff --git a/configuration-guides/fetchmail.md b/docs/configuration/fetchmail.md similarity index 100% rename from configuration-guides/fetchmail.md rename to docs/configuration/fetchmail.md diff --git a/configuration-guides/install-nvidia-driver.md b/docs/configuration/install-nvidia-driver.md similarity index 100% rename from configuration-guides/install-nvidia-driver.md rename to docs/configuration/install-nvidia-driver.md diff --git a/configuration-guides/multiboot.md b/docs/configuration/multiboot.md similarity index 100% rename from configuration-guides/multiboot.md rename to docs/configuration/multiboot.md diff --git a/configuration-guides/multimedia.md b/docs/configuration/multimedia.md similarity index 100% rename from configuration-guides/multimedia.md rename to docs/configuration/multimedia.md diff --git a/configuration-guides/mutt.md b/docs/configuration/mutt.md similarity index 100% rename from configuration-guides/mutt.md rename to docs/configuration/mutt.md diff --git a/configuration-guides/network-bridge-support.md b/docs/configuration/network-bridge-support.md similarity index 100% rename from configuration-guides/network-bridge-support.md rename to docs/configuration/network-bridge-support.md diff --git a/configuration-guides/network-printer.md b/docs/configuration/network-printer.md similarity index 100% rename from configuration-guides/network-printer.md rename to docs/configuration/network-printer.md diff --git a/configuration-guides/postfix.md b/docs/configuration/postfix.md similarity index 100% rename from configuration-guides/postfix.md rename to docs/configuration/postfix.md diff --git a/configuration-guides/rxvt.md b/docs/configuration/rxvt.md similarity index 100% rename from configuration-guides/rxvt.md rename to docs/configuration/rxvt.md diff --git a/configuration-guides/tips-and-tricks.md b/docs/configuration/tips-and-tricks.md similarity index 100% rename from configuration-guides/tips-and-tricks.md rename to docs/configuration/tips-and-tricks.md diff --git a/configuration-guides/vpn.md b/docs/configuration/vpn.md similarity index 100% rename from configuration-guides/vpn.md rename to docs/configuration/vpn.md diff --git a/configuration-guides/w3m.md b/docs/configuration/w3m.md similarity index 100% rename from configuration-guides/w3m.md rename to docs/configuration/w3m.md diff --git a/configuration-guides/zfs.md b/docs/configuration/zfs.md similarity index 100% rename from configuration-guides/zfs.md rename to docs/configuration/zfs.md diff --git a/customization-guides/dark-theme.md b/docs/customization/dark-theme.md similarity index 100% rename from customization-guides/dark-theme.md rename to docs/customization/dark-theme.md diff --git a/customization-guides/fedora-minimal-template-customization.md b/docs/customization/fedora-minimal-template-customization.md similarity index 100% rename from customization-guides/fedora-minimal-template-customization.md rename to docs/customization/fedora-minimal-template-customization.md diff --git a/customization-guides/language-localization.md b/docs/customization/language-localization.md similarity index 100% rename from customization-guides/language-localization.md rename to docs/customization/language-localization.md diff --git a/customization-guides/removing-templatevm-packages.md b/docs/customization/removing-templatevm-packages.md similarity index 100% rename from customization-guides/removing-templatevm-packages.md rename to docs/customization/removing-templatevm-packages.md diff --git a/customization-guides/windows-template-customization.md b/docs/customization/windows-template-customization.md similarity index 100% rename from customization-guides/windows-template-customization.md rename to docs/customization/windows-template-customization.md diff --git a/os-guides/centos.md b/docs/os/centos.md similarity index 100% rename from os-guides/centos.md rename to docs/os/centos.md diff --git a/os-guides/gentoo.md b/docs/os/gentoo.md similarity index 100% rename from os-guides/gentoo.md rename to docs/os/gentoo.md diff --git a/os-guides/linux-hvm-tips.md b/docs/os/linux-hvm-tips.md similarity index 100% rename from os-guides/linux-hvm-tips.md rename to docs/os/linux-hvm-tips.md diff --git a/os-guides/netbsd.md b/docs/os/netbsd.md similarity index 100% rename from os-guides/netbsd.md rename to docs/os/netbsd.md diff --git a/os-guides/pentesting.md b/docs/os/pentesting.md similarity index 100% rename from os-guides/pentesting.md rename to docs/os/pentesting.md diff --git a/os-guides/pentesting/blackarch.md b/docs/os/pentesting/blackarch.md similarity index 100% rename from os-guides/pentesting/blackarch.md rename to docs/os/pentesting/blackarch.md diff --git a/os-guides/pentesting/kali.md b/docs/os/pentesting/kali.md similarity index 100% rename from os-guides/pentesting/kali.md rename to docs/os/pentesting/kali.md diff --git a/os-guides/pentesting/ptf.md b/docs/os/pentesting/ptf.md similarity index 100% rename from os-guides/pentesting/ptf.md rename to docs/os/pentesting/ptf.md diff --git a/os-guides/ubuntu.md b/docs/os/ubuntu.md similarity index 100% rename from os-guides/ubuntu.md rename to docs/os/ubuntu.md diff --git a/os-guides/windows/windows-tools.md b/docs/os/windows/windows-tools.md similarity index 100% rename from os-guides/windows/windows-tools.md rename to docs/os/windows/windows-tools.md diff --git a/os-guides/windows/windows-vm.md b/docs/os/windows/windows-vm.md similarity index 100% rename from os-guides/windows/windows-vm.md rename to docs/os/windows/windows-vm.md diff --git a/privacy-guides/anonymizing-your-mac-address.md b/docs/privacy/anonymizing-your-mac-address.md similarity index 100% rename from privacy-guides/anonymizing-your-mac-address.md rename to docs/privacy/anonymizing-your-mac-address.md diff --git a/privacy-guides/signal.md b/docs/privacy/signal.md similarity index 100% rename from privacy-guides/signal.md rename to docs/privacy/signal.md diff --git a/privacy-guides/tails.md b/docs/privacy/tails.md similarity index 100% rename from privacy-guides/tails.md rename to docs/privacy/tails.md diff --git a/privacy-guides/torvm.md b/docs/privacy/torvm.md similarity index 100% rename from privacy-guides/torvm.md rename to docs/privacy/torvm.md diff --git a/privacy-guides/whonix.md b/docs/privacy/whonix.md similarity index 100% rename from privacy-guides/whonix.md rename to docs/privacy/whonix.md diff --git a/security-guides/multifactor-authentication.md b/docs/security/multifactor-authentication.md similarity index 100% rename from security-guides/multifactor-authentication.md rename to docs/security/multifactor-authentication.md diff --git a/security-guides/security-guidelines.md b/docs/security/security-guidelines.md similarity index 100% rename from security-guides/security-guidelines.md rename to docs/security/security-guidelines.md diff --git a/security-guides/split-bitcoin.md b/docs/security/split-bitcoin.md similarity index 100% rename from security-guides/split-bitcoin.md rename to docs/security/split-bitcoin.md diff --git a/troubleshooting/application-troubleshooting.md b/docs/troubleshooting/application-troubleshooting.md similarity index 100% rename from troubleshooting/application-troubleshooting.md rename to docs/troubleshooting/application-troubleshooting.md diff --git a/troubleshooting/intel-igfx-troubleshooting.md b/docs/troubleshooting/intel-igfx-troubleshooting.md similarity index 100% rename from troubleshooting/intel-igfx-troubleshooting.md rename to docs/troubleshooting/intel-igfx-troubleshooting.md diff --git a/troubleshooting/macbook-troubleshooting.md b/docs/troubleshooting/macbook-troubleshooting.md similarity index 100% rename from troubleshooting/macbook-troubleshooting.md rename to docs/troubleshooting/macbook-troubleshooting.md diff --git a/troubleshooting/nvidia-troubleshooting.md b/docs/troubleshooting/nvidia-troubleshooting.md similarity index 100% rename from troubleshooting/nvidia-troubleshooting.md rename to docs/troubleshooting/nvidia-troubleshooting.md diff --git a/troubleshooting/sony-vaio-tinkering.md b/docs/troubleshooting/sony-vaio-tinkering.md similarity index 100% rename from troubleshooting/sony-vaio-tinkering.md rename to docs/troubleshooting/sony-vaio-tinkering.md diff --git a/troubleshooting/tails-troubleshooting.md b/docs/troubleshooting/tails-troubleshooting.md similarity index 100% rename from troubleshooting/tails-troubleshooting.md rename to docs/troubleshooting/tails-troubleshooting.md diff --git a/troubleshooting/thinkpad-troubleshooting.md b/docs/troubleshooting/thinkpad-troubleshooting.md similarity index 100% rename from troubleshooting/thinkpad-troubleshooting.md rename to docs/troubleshooting/thinkpad-troubleshooting.md