diff --git a/calamares.desktop b/calamares.desktop
index 4920c6eb3cbcb17b86ae3f0adb36bc3f6061350d..88cb71e201c7b2df1843bde92477a83e047a4f09 100644
--- a/calamares.desktop
+++ b/calamares.desktop
@@ -3,6 +3,7 @@ Type=Application
 Version=1.0
 Name=Calamares
 GenericName=System Installer
+Keywords=calamares;system;installer
 TryExec=calamares
 Exec=pkexec /usr/bin/calamares
 Comment=Calamares — System Installer
diff --git a/settings.conf b/settings.conf
index 07210980e72bd65a2224087bf1efffdaba7d52dc..4da88a8ddb3f6ea4071b36367d04906566d8b6ea 100644
--- a/settings.conf
+++ b/settings.conf
@@ -79,6 +79,7 @@ sequence:
   - localecfg
 #  - luksbootkeyfile
 #  - luksopenswaphookcfg
+#  - plymouthcfg
   - initcpiocfg
   - initcpio
   - users
diff --git a/src/libcalamares/kdsingleapplicationguard/kdsingleapplicationguard.cpp b/src/libcalamares/kdsingleapplicationguard/kdsingleapplicationguard.cpp
index 6b2a2e13ac20981cc907f00288356cebfeae906f..ea8ccce33a15e0341c551a9e4873c33aa6ec1ed9 100644
--- a/src/libcalamares/kdsingleapplicationguard/kdsingleapplicationguard.cpp
+++ b/src/libcalamares/kdsingleapplicationguard/kdsingleapplicationguard.cpp
@@ -723,7 +723,7 @@ void KDSingleApplicationGuard::Private::create( const QStringList & arguments )
 
     const QString name = QCoreApplication::applicationName();
     if ( name.isEmpty() ) {
-        qWarning( "KDSingleApplicationGuard: QCoreApplication::applicationName must not be emty" );
+        qWarning( "KDSingleApplicationGuard: QCoreApplication::applicationName must not be empty" );
         return;
     }
 
diff --git a/src/modules/grubcfg/main.py b/src/modules/grubcfg/main.py
index 4e05a0d3fe3ec8a59e48cad2a218609271f4b6e9..6229cabdaea9391f7874886f0ed20cd17bf3659d 100644
--- a/src/modules/grubcfg/main.py
+++ b/src/modules/grubcfg/main.py
@@ -23,7 +23,6 @@ import libcalamares
 import os
 import re
 
-
 def modify_grub_default(partitions, root_mount_point, distributor):
     """ Configures '/etc/default/grub' for hibernation and plymouth.
 
@@ -35,14 +34,12 @@ def modify_grub_default(partitions, root_mount_point, distributor):
     default_dir = os.path.join(root_mount_point, "etc/default")
     default_grub = os.path.join(default_dir, "grub")
     distributor_replace = distributor.replace("'", "'\\''")
-    plymouth_bin = libcalamares.utils.target_env_call(["sh", "-c", "which plymouth"])
     use_splash = ""
     swap_uuid = ""
 
-    libcalamares.utils.debug("which plymouth exit code: {!s}".format(plymouth_bin))
-
-    if plymouth_bin == 0:
-        use_splash = "splash"
+    if libcalamares.globalstorage.contains("hasPlymouth"):
+        if libcalamares.globalstorage.value("hasPlymouth"):
+            use_splash = "splash"
 
     cryptdevice_params = []
 
diff --git a/src/modules/partition/core/PartitionCoreModule.cpp b/src/modules/partition/core/PartitionCoreModule.cpp
index 0df1525075c0ae5d3234213b137a593c3b60f65d..77333846af34d6b16beb0603348f0af14ad011da 100644
--- a/src/modules/partition/core/PartitionCoreModule.cpp
+++ b/src/modules/partition/core/PartitionCoreModule.cpp
@@ -700,7 +700,6 @@ QList< PartitionCoreModule::SummaryInfo >
 PartitionCoreModule::createSummaryInfo() const
 {
     QList< SummaryInfo > lst;
-    CoreBackend* backend = CoreBackendManager::self()->backend();
     for ( auto deviceInfo : m_deviceInfos )
     {
         if ( !deviceInfo->isDirty() )
@@ -709,7 +708,7 @@ PartitionCoreModule::createSummaryInfo() const
         summaryInfo.deviceName = deviceInfo->device->name();
         summaryInfo.deviceNode = deviceInfo->device->deviceNode();
 
-        Device* deviceBefore = backend->scanDevice( deviceInfo->device->deviceNode() );
+        Device* deviceBefore = deviceInfo->immutableDevice.data();
         summaryInfo.partitionModelBefore = new PartitionModel;
         summaryInfo.partitionModelBefore->init( deviceBefore, m_osproberLines );
         // Make deviceBefore a child of partitionModelBefore so that it is not
diff --git a/src/modules/plymouthcfg/main.py b/src/modules/plymouthcfg/main.py
new file mode 100644
index 0000000000000000000000000000000000000000..9612735cd4e65f39f79d52193e0b34a7fd60c19b
--- /dev/null
+++ b/src/modules/plymouthcfg/main.py
@@ -0,0 +1,61 @@
+#!/usr/bin/env python3
+# -*- coding: utf-8 -*-
+#
+# === This file is part of Calamares - <http://github.com/calamares> ===
+#
+#   Copyright 2016, Artoo <artoo@manjaro.org>
+#
+#   Calamares is free software: you can redistribute it and/or modify
+#   it under the terms of the GNU General Public License as published by
+#   the Free Software Foundation, either version 3 of the License, or
+#   (at your option) any later version.
+#
+#   Calamares is distributed in the hope that it will be useful,
+#   but WITHOUT ANY WARRANTY; without even the implied warranty of
+#   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+#   GNU General Public License for more details.
+#
+#   You should have received a copy of the GNU General Public License
+#   along with Calamares. If not, see <http://www.gnu.org/licenses/>.
+
+import libcalamares
+
+from libcalamares.utils import debug, target_env_call
+
+
+class PlymouthController:
+
+    def __init__(self):
+        self.__root = libcalamares.globalstorage.value('rootMountPoint')
+
+    @property
+    def root(self):
+        return self.__root
+
+    def setTheme(self):
+        plymouth_theme = libcalamares.job.configuration["plymouth_theme"]
+        target_env_call(["sed", "-e", 's|^.*Theme=.*|Theme=' +
+                         plymouth_theme + '|', "-i", "/etc/plymouth/plymouthd.conf"])
+
+    def detect(self):
+        isPlymouth = target_env_call(["which", "plymouth"])
+        debug("which plymouth exit code: {!s}".format(isPlymouth))
+
+        if isPlymouth == 0:
+            libcalamares.globalstorage.insert("hasPlymouth", True)
+        else:
+            libcalamares.globalstorage.insert("hasPlymouth", False)
+
+        return isPlymouth
+
+    def run(self):
+        if self.detect() == 0:
+            if "plymouth_theme" in libcalamares.job.configuration and libcalamares.job.configuration["plymouth_theme"] is not None:
+                self.setTheme()
+        return None
+
+
+def run():
+    pc = PlymouthController()
+    return pc.run()
+
diff --git a/src/modules/plymouthcfg/module.desc b/src/modules/plymouthcfg/module.desc
new file mode 100644
index 0000000000000000000000000000000000000000..f2d2d474362cac6ccf1b4f4b57e63403a3a0a679
--- /dev/null
+++ b/src/modules/plymouthcfg/module.desc
@@ -0,0 +1,5 @@
+---
+type:       "job"
+name:       "plymouthcfg"
+interface:  "python"
+script:     "main.py"
diff --git a/src/modules/plymouthcfg/plymouthcfg.conf b/src/modules/plymouthcfg/plymouthcfg.conf
new file mode 100644
index 0000000000000000000000000000000000000000..6d7ae5c27dd30a26fee585f37ebdc188a055f29f
--- /dev/null
+++ b/src/modules/plymouthcfg/plymouthcfg.conf
@@ -0,0 +1,4 @@
+---
+# The plymouth theme to be set if plymouth binary is present
+# leave commented if packaged default theme should be used
+# plymouth_theme: spinfinity