diff --git a/src/plugins/qnx/blackberrycertificate.cpp b/src/plugins/qnx/blackberrycertificate.cpp
index 5f4c84caea58e59716d5cfeb6d3bfa096e9b448b..c97f973ad657fb0a7e128ff3b18db442f5fe9c98 100644
--- a/src/plugins/qnx/blackberrycertificate.cpp
+++ b/src/plugins/qnx/blackberrycertificate.cpp
@@ -31,6 +31,7 @@
 
 #include "blackberrycertificate.h"
 #include "blackberryconfiguration.h"
+#include "blackberryconfigurationmanager.h"
 
 #include <utils/hostosinfo.h>
 
@@ -178,12 +179,16 @@ void BlackBerryCertificate::processError()
 
 QString BlackBerryCertificate::command() const
 {
-    QString command = BlackBerryConfiguration::instance()
-        .qnxEnv().value(QLatin1String("QNX_HOST"))
-        + QLatin1String("/usr/bin/blackberry-keytool");
-
-    if (Utils::HostOsInfo::isWindowsHost())
-        command += QLatin1String(".bat");
+    QString command;
+    // TOOD: Give user choice to select NDK from where to get commands
+    QMultiMap<QString, QString> qnxEnv = BlackBerryConfigurationManager::instance().defaultQnxEnv();
+    if (!qnxEnv.isEmpty()) {
+        command = qnxEnv.value(QLatin1String("QNX_HOST"))
+                + QLatin1String("/usr/bin/blackberry-keytool");
+
+        if (Utils::HostOsInfo::isWindowsHost())
+            command += QLatin1String(".bat");
+    }
 
     return command;
 }
diff --git a/src/plugins/qnx/blackberrycertificatemodel.cpp b/src/plugins/qnx/blackberrycertificatemodel.cpp
index 5837bcea2ec3f1c8c6a1a695c6b2ab238fe82b6b..9f177e2b9d429d6c551b0fb41acdbe3d0ad99a91 100644
--- a/src/plugins/qnx/blackberrycertificatemodel.cpp
+++ b/src/plugins/qnx/blackberrycertificatemodel.cpp
@@ -31,7 +31,7 @@
 
 #include "blackberrycertificatemodel.h"
 #include "blackberrycertificate.h"
-#include "blackberryconfiguration.h"
+#include "blackberryconfigurationmanager.h"
 
 #include <coreplugin/icore.h>
 
@@ -196,9 +196,9 @@ bool BlackBerryCertificateModel::insertCertificate(BlackBerryCertificate *certif
 
 void BlackBerryCertificateModel::load()
 {
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
-    m_certificates = configuration.certificates();
-    m_activeCertificate = configuration.activeCertificate();
+    BlackBerryConfigurationManager &configManager = BlackBerryConfigurationManager::instance();
+    m_certificates = configManager.certificates();
+    m_activeCertificate = configManager.activeCertificate();
 }
 
 } // namespace Internal
diff --git a/src/plugins/qnx/blackberryconfiguration.cpp b/src/plugins/qnx/blackberryconfiguration.cpp
index ca41547337f129756709f5334c2c2a9e710b8572..2f632ac59b0ec07485c5244c3d4d0bcc35c302ce 100644
--- a/src/plugins/qnx/blackberryconfiguration.cpp
+++ b/src/plugins/qnx/blackberryconfiguration.cpp
@@ -31,28 +31,22 @@
 
 #include "blackberryconfiguration.h"
 #include "blackberryqtversion.h"
-#include "blackberrycertificate.h"
-#include "qnxutils.h"
-
-#include <coreplugin/icore.h>
 
-#include <qtsupport/baseqtversion.h>
-#include <qtsupport/qtversionmanager.h>
-#include <qtsupport/qtkitinformation.h>
+#include "qnxutils.h"
 
 #include <projectexplorer/projectexplorerconstants.h>
 #include <projectexplorer/kitmanager.h>
 #include <projectexplorer/kitinformation.h>
-#include <projectexplorer/gcctoolchain.h>
 #include <projectexplorer/toolchainmanager.h>
 
+#include <qtsupport/baseqtversion.h>
+#include <qtsupport/qtversionmanager.h>
+#include <qtsupport/qtkitinformation.h>
+
 #include <qt4projectmanager/qmakekitinformation.h>
 
 #include <debugger/debuggerkitinformation.h>
 
-#include <utils/persistentsettings.h>
-#include <utils/hostosinfo.h>
-
 #include <QFileInfo>
 #include <QDir>
 #include <QMessageBox>
@@ -60,264 +54,129 @@
 namespace Qnx {
 namespace Internal {
 
-namespace {
-const QLatin1String SettingsGroup("BlackBerryConfiguration");
-const QLatin1String NDKLocationKey("NDKLocation");
-const QLatin1String CertificateGroup("Certificates");
-}
-
-BlackBerryConfiguration::BlackBerryConfiguration(QObject *parent)
-    :QObject(parent)
-{
-    loadSettings();
-    connect(Core::ICore::instance(), SIGNAL(saveSettingsRequested()), this, SLOT(saveSettings()));
-}
-
-bool BlackBerryConfiguration::setNdkPath(const QString &ndkPath)
-{
-    if (ndkPath.isEmpty())
-        return false;
-
-    m_config.ndkPath = ndkPath;
-
-    return refresh();
-}
-
-void BlackBerryConfiguration::setupNdkConfigPerQtVersion(const Utils::FileName &qmakePath, ProjectExplorer::GccToolChain *tc)
+BlackBerryConfiguration::BlackBerryConfiguration(const QString &ndkPath, bool isAutoDetected, const QString &displayName)
 {
-    QtSupport::BaseQtVersion *qtVersion = createQtVersion(qmakePath);
-    ProjectExplorer::Kit *deviceKit = createKit(ArmLeV7, qtVersion, tc);
-    ProjectExplorer::Kit *simulatorKit = createKit(X86, qtVersion, tc);
-    if (qtVersion && tc && deviceKit && simulatorKit) {
-        if (!qtVersion->qtAbis().isEmpty())
-            tc->setTargetAbi(qtVersion->qtAbis().first());
-        // register
-        QtSupport::QtVersionManager::instance()->addVersion(qtVersion);
-        ProjectExplorer::ToolChainManager::instance()->registerToolChain(tc);
-        ProjectExplorer::KitManager::instance()->registerKit(deviceKit);
-        ProjectExplorer::KitManager::instance()->registerKit(simulatorKit);
+    m_ndkPath = ndkPath;
+    m_isAutoDetected = isAutoDetected;
+    m_displayName = displayName.isEmpty() ? m_ndkPath.split(QDir::separator()).last() : displayName;
+    m_qnxEnv = QnxUtils::parseEnvironmentFile(QnxUtils::envFilePath(m_ndkPath));
 
-        emit updated();
-    }
-}
-
-bool BlackBerryConfiguration::refresh()
-{
-    m_config.qnxEnv = QnxUtils::parseEnvironmentFile(QnxUtils::envFilePath(m_config.ndkPath));
-
-    QString ndkTarget = m_config.qnxEnv.value(QLatin1String("QNX_TARGET"));
+    QString ndkTarget = m_qnxEnv.value(QLatin1String("QNX_TARGET"));
     QString sep = QString::fromLatin1("%1qnx6").arg(QDir::separator());
-    m_config.targetName = ndkTarget.split(sep).first().split(QDir::separator()).last();
+    m_targetName = ndkTarget.split(sep).first().split(QDir::separator()).last();
 
     if (QDir(ndkTarget).exists())
-        m_config.sysRoot = Utils::FileName::fromString(ndkTarget);
+        m_sysRoot = Utils::FileName::fromString(ndkTarget);
 
-    QString qnxHost = m_config.qnxEnv.value(QLatin1String("QNX_HOST"));
+    QString qnxHost = m_qnxEnv.value(QLatin1String("QNX_HOST"));
     Utils::FileName qmake4Path = QnxUtils::executableWithExtension(Utils::FileName::fromString(qnxHost + QLatin1String("/usr/bin/qmake")));
     Utils::FileName qmake5Path = QnxUtils::executableWithExtension(Utils::FileName::fromString(qnxHost + QLatin1String("/usr/bin/qt5/qmake")));
     Utils::FileName gccPath = QnxUtils::executableWithExtension(Utils::FileName::fromString(qnxHost + QLatin1String("/usr/bin/qcc")));
     Utils::FileName deviceGdbPath = QnxUtils::executableWithExtension(Utils::FileName::fromString(qnxHost + QLatin1String("/usr/bin/ntoarm-gdb")));
     Utils::FileName simulatorGdbPath = QnxUtils::executableWithExtension(Utils::FileName::fromString(qnxHost + QLatin1String("/usr/bin/ntox86-gdb")));
 
-    if ((!qmake4Path.toFileInfo().exists() && !qmake5Path.toFileInfo().exists()) || !gccPath.toFileInfo().exists()
-            || !deviceGdbPath.toFileInfo().exists() || !simulatorGdbPath.toFileInfo().exists() ) {
-        QString errorMessage = tr("The following errors occurred while setting up BB10 Configuration:");
-        if (!qmake4Path.toFileInfo().exists() && !qmake5Path.toFileInfo().exists())
-            errorMessage += QLatin1Char('\n') + tr("- No Qt version found.");
-
-        if (!gccPath.toFileInfo().exists())
-            errorMessage += QLatin1Char('\n') + tr("- No GCC compiler found.");
-
-        if (!deviceGdbPath.toFileInfo().exists())
-            errorMessage += QLatin1Char('\n') + tr("- No GDB debugger found for BB10 Device.");
-
-        if (!simulatorGdbPath.toFileInfo().exists())
-            errorMessage += QLatin1Char('\n') + tr("- No GDB debugger found for BB10 Simulator.");
-
-        QMessageBox::warning(0, tr("Cannot Set up BB10 Configuration"),
-                             errorMessage, QMessageBox::Ok);
-        return false;
-    }
-
     if (qmake4Path.toFileInfo().exists())
-        m_config.qmake4BinaryFile = qmake4Path;
+        m_qmake4BinaryFile = qmake4Path;
 
     if (qmake5Path.toFileInfo().exists())
-        m_config.qmake5BinaryFile = qmake5Path;
-
-    m_config.gccCompiler = gccPath;
-    m_config.deviceDebuger = deviceGdbPath;
-    m_config.simulatorDebuger = simulatorGdbPath;
-
-    return true;
-}
-
-void BlackBerryConfiguration::loadCertificates()
-{
-    QSettings *settings = Core::ICore::settings();
-
-    settings->beginGroup(SettingsGroup);
-    settings->beginGroup(CertificateGroup);
-
-    foreach (const QString &certificateId, settings->childGroups()) {
-        settings->beginGroup(certificateId);
-
-        BlackBerryCertificate *cert =
-            new BlackBerryCertificate(settings->value(QLatin1String(Qnx::Constants::QNX_KEY_PATH)).toString(),
-                    settings->value(QLatin1String(Qnx::Constants::QNX_KEY_AUTHOR)).toString());
-        cert->setParent(this);
+        m_qmake5BinaryFile = qmake5Path;
 
-        if (settings->value(QLatin1String(Qnx::Constants::QNX_KEY_ACTIVE)).toBool())
-            m_config.activeCertificate = cert;
+    if (gccPath.toFileInfo().exists())
+        m_gccCompiler = gccPath;
 
-        m_config.certificates << cert;
+    if (deviceGdbPath.toFileInfo().exists())
+        m_deviceDebuger = deviceGdbPath;
 
-        settings->endGroup();
-    }
+    if (simulatorGdbPath.toFileInfo().exists())
+        m_simulatorDebuger = simulatorGdbPath;
 
-    settings->endGroup();
-    settings->endGroup();
 }
 
-void BlackBerryConfiguration::loadNdkSettings()
+QString BlackBerryConfiguration::ndkPath() const
 {
-    QSettings *settings = Core::ICore::settings();
-
-    settings->beginGroup(SettingsGroup);
-    setNdkPath(settings->value(NDKLocationKey).toString());
-    settings->endGroup();
+    return m_ndkPath;
 }
 
-void BlackBerryConfiguration::saveCertificates()
+QString BlackBerryConfiguration::displayName() const
 {
-    QSettings *settings = Core::ICore::settings();
-
-    settings->beginGroup(SettingsGroup);
-    settings->beginGroup(CertificateGroup);
-
-    settings->remove(QString());
-
-    foreach (const BlackBerryCertificate *cert, m_config.certificates) {
-        settings->beginGroup(cert->id());
-        settings->setValue(QLatin1String(Qnx::Constants::QNX_KEY_PATH), cert->fileName());
-        settings->setValue(QLatin1String(Qnx::Constants::QNX_KEY_AUTHOR), cert->author());
-
-        if (cert == m_config.activeCertificate)
-            settings->setValue(QLatin1String(Qnx::Constants::QNX_KEY_ACTIVE), true);
-
-        settings->endGroup();
-    }
-
-    settings->endGroup();
-    settings->endGroup();
+    return m_displayName;
 }
 
-void BlackBerryConfiguration::saveNdkSettings()
+QString BlackBerryConfiguration::targetName() const
 {
-    if (m_config.ndkPath.isEmpty())
-        return;
-
-    QSettings *settings = Core::ICore::settings();
-    settings->beginGroup(SettingsGroup);
-    settings->setValue(NDKLocationKey, m_config.ndkPath);
-    settings->endGroup();
+    return m_targetName;
 }
 
-void BlackBerryConfiguration::setupNdkConfiguration(const QString &ndkPath)
+bool BlackBerryConfiguration::isAutoDetected() const
 {
-    if (ndkPath.isEmpty())
-        return;
-
-    if (setNdkPath(ndkPath)) {
-        ProjectExplorer::GccToolChain *tc = createGccToolChain();
-
-        if (!m_config.qmake4BinaryFile.isEmpty())
-            setupNdkConfigPerQtVersion(m_config.qmake4BinaryFile, tc);
-
-        if (!m_config.qmake5BinaryFile.isEmpty())
-            setupNdkConfigPerQtVersion(m_config.qmake5BinaryFile, tc);
-    }
+    return m_isAutoDetected;
 }
 
-void BlackBerryConfiguration::cleanNdkConfiguration()
+bool BlackBerryConfiguration::isActive() const
 {
-    QtSupport::BaseQtVersion *qt4Version = QtSupport::QtVersionManager::instance()->qtVersionForQMakeBinary(m_config.qmake4BinaryFile);
-    QtSupport::BaseQtVersion *qt5Version = QtSupport::QtVersionManager::instance()->qtVersionForQMakeBinary(m_config.qmake5BinaryFile);
-    if (qt4Version || qt5Version) {
-        foreach (ProjectExplorer::Kit *kit, ProjectExplorer::KitManager::instance()->kits()) {
-            if (qt4Version && qt4Version == QtSupport::QtKitInformation::qtVersion(kit)) {
-                ProjectExplorer::KitManager::instance()->deregisterKit(kit);
-            } else if (qt5Version && qt5Version == QtSupport::QtKitInformation::qtVersion(kit)) {
-                ProjectExplorer::KitManager::instance()->deregisterKit(kit);
-            }
-        }
-
-        if (qt4Version)
-            QtSupport::QtVersionManager::instance()->removeVersion(qt4Version);
-
-        if (qt5Version)
-            QtSupport::QtVersionManager::instance()->removeVersion(qt5Version);
-
-    }
-
-    foreach (ProjectExplorer::ToolChain* tc, ProjectExplorer::ToolChainManager::instance()->toolChains()) {
-        if (tc->compilerCommand() == m_config.gccCompiler)
-            ProjectExplorer::ToolChainManager::instance()->deregisterToolChain(tc);
-    }
-
-    BlackBerryConfig conf;
-    conf.activeCertificate = m_config.activeCertificate;
-    conf.certificates = m_config.certificates;
-    m_config = conf;
-    emit updated();
-
-    clearNdkSettings();
+    QtSupport::BaseQtVersion *qt4Version = QtSupport::QtVersionManager::instance()->qtVersionForQMakeBinary(m_qmake4BinaryFile);
+    QtSupport::BaseQtVersion *qt5Version = QtSupport::QtVersionManager::instance()->qtVersionForQMakeBinary(m_qmake5BinaryFile);
+    return (qt4Version || qt5Version);
 }
 
-void BlackBerryConfiguration::syncCertificates(QList<BlackBerryCertificate*> certificates,
-        BlackBerryCertificate *activeCertificate)
+bool BlackBerryConfiguration::isValid() const
 {
-    m_config.activeCertificate = activeCertificate;
-
-    foreach (BlackBerryCertificate *cert, m_config.certificates) {
-        if (!certificates.contains(cert))
-            removeCertificate(cert);
-    }
-
-    foreach (BlackBerryCertificate *cert, certificates)
-        addCertificate(cert);
+    return !((m_qmake4BinaryFile.isEmpty() && m_qmake5BinaryFile.isEmpty()) || m_gccCompiler.isEmpty()
+            || m_deviceDebuger.isEmpty() || m_simulatorDebuger.isEmpty());
 }
 
-void BlackBerryConfiguration::addCertificate(BlackBerryCertificate *certificate)
+Utils::FileName BlackBerryConfiguration::qmake4BinaryFile() const
 {
-    if (m_config.certificates.contains(certificate))
-        return;
+    return m_qmake4BinaryFile;
+}
 
-    if (m_config.certificates.isEmpty())
-        m_config.activeCertificate = certificate;
+Utils::FileName BlackBerryConfiguration::qmake5BinaryFile() const
+{
+    return m_qmake5BinaryFile;
+}
 
-    certificate->setParent(this);
-    m_config.certificates << certificate;
+Utils::FileName BlackBerryConfiguration::gccCompiler() const
+{
+    return m_gccCompiler;
 }
 
-void BlackBerryConfiguration::removeCertificate(BlackBerryCertificate *certificate)
+Utils::FileName BlackBerryConfiguration::deviceDebuger() const
 {
-    if (m_config.activeCertificate == certificate)
-        m_config.activeCertificate = 0;
+    return m_deviceDebuger;
+}
 
-    m_config.certificates.removeAll(certificate);
+Utils::FileName BlackBerryConfiguration::simulatorDebuger() const
+{
+    return m_simulatorDebuger;
+}
 
-    delete certificate;
+Utils::FileName BlackBerryConfiguration::sysRoot() const
+{
+    return m_sysRoot;
 }
 
-QList<BlackBerryCertificate*> BlackBerryConfiguration::certificates() const
+QMultiMap<QString, QString> BlackBerryConfiguration::qnxEnv() const
 {
-    return m_config.certificates;
+    return m_qnxEnv;
 }
 
-BlackBerryCertificate * BlackBerryConfiguration::activeCertificate()
+void BlackBerryConfiguration::setupConfigurationPerQtVersion(const Utils::FileName &qmakePath, ProjectExplorer::GccToolChain *tc)
 {
-    return m_config.activeCertificate;
+    if (qmakePath.isEmpty() || !tc)
+        return;
+
+    QtSupport::BaseQtVersion *qtVersion = createQtVersion(qmakePath);
+    ProjectExplorer::Kit *deviceKit = createKit(ArmLeV7, qtVersion, tc);
+    ProjectExplorer::Kit *simulatorKit = createKit(X86, qtVersion, tc);
+    if (qtVersion && tc && deviceKit && simulatorKit) {
+        if (!qtVersion->qtAbis().isEmpty())
+            tc->setTargetAbi(qtVersion->qtAbis().first());
+        // register
+        QtSupport::QtVersionManager::instance()->addVersion(qtVersion);
+        ProjectExplorer::ToolChainManager::instance()->registerToolChain(tc);
+        ProjectExplorer::KitManager::instance()->registerKit(deviceKit);
+        ProjectExplorer::KitManager::instance()->registerKit(simulatorKit);
+    }
 }
 
 QtSupport::BaseQtVersion *BlackBerryConfiguration::createQtVersion(const Utils::FileName &qmakePath)
@@ -325,49 +184,51 @@ QtSupport::BaseQtVersion *BlackBerryConfiguration::createQtVersion(const Utils::
     if (qmakePath.isEmpty())
         return 0;
 
-    QString cpuDir = m_config.qnxEnv.value(QLatin1String("CPUVARDIR"));
+    QString cpuDir = m_qnxEnv.value(QLatin1String("CPUVARDIR"));
     QtSupport::BaseQtVersion *version = QtSupport::QtVersionManager::instance()->qtVersionForQMakeBinary(qmakePath);
     if (version) {
-        QMessageBox::warning(0, tr("Qt Version Already Known"),
-                             tr("This Qt version was already registered."), QMessageBox::Ok);
+        if (!m_isAutoDetected)
+            QMessageBox::warning(0, QObject::tr("Qt Version Already Known"),
+                             QObject::tr("This Qt version was already registered."), QMessageBox::Ok);
         return version;
     }
 
-    version = new BlackBerryQtVersion(QnxUtils::cpudirToArch(cpuDir), qmakePath, false, QString(), m_config.ndkPath);
+    version = new BlackBerryQtVersion(QnxUtils::cpudirToArch(cpuDir), qmakePath, m_isAutoDetected, QString(), m_ndkPath);
     if (!version) {
-        QMessageBox::warning(0, tr("Invalid Qt Version"),
-                             tr("Unable to add BlackBerry Qt version."), QMessageBox::Ok);
+        if (!m_isAutoDetected)
+            QMessageBox::warning(0, QObject::tr("Invalid Qt Version"),
+                             QObject::tr("Unable to add BlackBerry Qt version."), QMessageBox::Ok);
         return 0;
     }
 
-    version->setDisplayName(QString::fromLatin1("Qt %1 BlackBerry 10 (%2)").arg(version->qtVersionString(), m_config.targetName));
-
+    version->setDisplayName(QString::fromLatin1("Qt %1 BlackBerry 10 (%2)").arg(version->qtVersionString(), m_targetName));
     return version;
 }
 
 ProjectExplorer::GccToolChain *BlackBerryConfiguration::createGccToolChain()
 {
-    if ((m_config.qmake4BinaryFile.isEmpty() && m_config.qmake5BinaryFile.isEmpty()) || m_config.gccCompiler.isEmpty())
+    if ((m_qmake4BinaryFile.isEmpty() && m_qmake5BinaryFile.isEmpty()) || m_gccCompiler.isEmpty())
         return 0;
 
     foreach (ProjectExplorer::ToolChain* tc, ProjectExplorer::ToolChainManager::instance()->toolChains()) {
-        if (tc->compilerCommand() == m_config.gccCompiler) {
-            QMessageBox::warning(0, tr("Compiler Already Known"),
-                                 tr("This compiler was already registered."), QMessageBox::Ok);
+        if (tc->compilerCommand() == m_gccCompiler) {
+            if (!m_isAutoDetected)
+                QMessageBox::warning(0, QObject::tr("Compiler Already Known"),
+                                 QObject::tr("This compiler was already registered."), QMessageBox::Ok);
             return dynamic_cast<ProjectExplorer::GccToolChain*>(tc);
         }
     }
 
-    ProjectExplorer::GccToolChain* tc = new ProjectExplorer::GccToolChain(QLatin1String(ProjectExplorer::Constants::GCC_TOOLCHAIN_ID), false);
-    tc->setDisplayName(QString::fromLatin1("GCC BlackBerry 10 (%1)").arg(m_config.targetName));
-    tc->setCompilerCommand(m_config.gccCompiler);
+    ProjectExplorer::GccToolChain* tc = new ProjectExplorer::GccToolChain(QLatin1String(ProjectExplorer::Constants::GCC_TOOLCHAIN_ID), m_isAutoDetected);
+    tc->setDisplayName(QString::fromLatin1("GCC BlackBerry 10 (%1)").arg(m_targetName));
+    tc->setCompilerCommand(m_gccCompiler);
 
     return tc;
 }
 
 ProjectExplorer::Kit *BlackBerryConfiguration::createKit(QnxArchitecture arch, QtSupport::BaseQtVersion *qtVersion, ProjectExplorer::GccToolChain *tc)
 {
-    if (!qtVersion || !tc || m_config.targetName.isEmpty())
+    if (!qtVersion || !tc || m_targetName.isEmpty())
         return 0;
 
     // Check if an identical kit already exists
@@ -375,12 +236,14 @@ ProjectExplorer::Kit *BlackBerryConfiguration::createKit(QnxArchitecture arch, Q
     {
         if (QtSupport::QtKitInformation::qtVersion(kit) == qtVersion && ProjectExplorer::ToolChainKitInformation::toolChain(kit) == tc
                 && ProjectExplorer::DeviceTypeKitInformation::deviceTypeId(kit) == Constants::QNX_BB_OS_TYPE
-                && ProjectExplorer::SysRootKitInformation::sysRoot(kit) == m_config.sysRoot) {
+                && ProjectExplorer::SysRootKitInformation::sysRoot(kit) == m_sysRoot) {
             if ((arch == X86 && Qt4ProjectManager::QmakeKitInformation::mkspec(kit).toString() == QString::fromLatin1("blackberry-x86-qcc")
-                 && Debugger::DebuggerKitInformation::debuggerCommand(kit) == m_config.simulatorDebuger)
-                    || (arch == ArmLeV7 && Debugger::DebuggerKitInformation::debuggerCommand(kit) == m_config.deviceDebuger)) {
-                QMessageBox::warning(0, tr("Kit Already Known"),
-                                     tr("This kit was already registered."), QMessageBox::Ok);
+                 && Debugger::DebuggerKitInformation::debuggerCommand(kit) == m_simulatorDebuger)
+                    || (arch == ArmLeV7 && Debugger::DebuggerKitInformation::debuggerCommand(kit) == m_deviceDebuger)) {
+                if (!m_isAutoDetected)
+                    QMessageBox::warning(0, QObject::tr("Kit Already Known"),
+                                     QObject::tr("This kit was already registered."), QMessageBox::Ok);
+                setSticky(kit);
                 return kit;
             }
         }
@@ -390,121 +253,98 @@ ProjectExplorer::Kit *BlackBerryConfiguration::createKit(QnxArchitecture arch, Q
     QtSupport::QtKitInformation::setQtVersion(kit, qtVersion);
     ProjectExplorer::ToolChainKitInformation::setToolChain(kit, tc);
     if (arch == X86) {
-        Debugger::DebuggerKitInformation::setDebuggerCommand(kit, m_config.simulatorDebuger);
+        Debugger::DebuggerKitInformation::setDebuggerCommand(kit, m_simulatorDebuger);
         Qt4ProjectManager::QmakeKitInformation::setMkspec(kit, Utils::FileName::fromString(QString::fromLatin1("blackberry-x86-qcc")));
         // TODO: Check if the name already exists(?)
-        kit->setDisplayName(tr("BlackBerry 10 (%1 - %2) - Simulator").arg(qtVersion->qtVersionString(), m_config.targetName));
+        kit->setDisplayName(QObject::tr("BlackBerry 10 (%1 - %2) - Simulator").arg(qtVersion->qtVersionString(), m_targetName));
     } else {
-        Debugger::DebuggerKitInformation::setDebuggerCommand(kit, m_config.deviceDebuger);
-        kit->setDisplayName(tr("BlackBerry 10 (%1 - %2)").arg(qtVersion->qtVersionString(), m_config.targetName));
+        Debugger::DebuggerKitInformation::setDebuggerCommand(kit, m_deviceDebuger);
+        kit->setDisplayName(QObject::tr("BlackBerry 10 (%1 - %2)").arg(qtVersion->qtVersionString(), m_targetName));
     }
 
+
+    kit->setAutoDetected(m_isAutoDetected);
     kit->setIconPath(QLatin1String(Constants::QNX_BB_CATEGORY_ICON));
+    setSticky(kit);
     ProjectExplorer::DeviceTypeKitInformation::setDeviceTypeId(kit, Constants::QNX_BB_OS_TYPE);
-    ProjectExplorer::SysRootKitInformation::setSysRoot(kit, m_config.sysRoot);
+    ProjectExplorer::SysRootKitInformation::setSysRoot(kit, m_sysRoot);
 
     return kit;
 }
 
-void BlackBerryConfiguration::loadSettings()
+void BlackBerryConfiguration::setSticky(ProjectExplorer::Kit *kit)
 {
-    loadNdkSettings();
-    loadCertificates();
+    kit->makeSticky(Core::Id("QtSupport.QtInformation"));
+    kit->makeSticky(Core::Id("PE.Profile.ToolChain"));
+    kit->makeSticky(Core::Id("PE.Profile.SysRoot"));
+    kit->makeSticky(Core::Id("PE.Profile.DeviceType"));
+    kit->makeSticky(Core::Id("Debugger.Information"));
+    kit->makeSticky(Core::Id("QtPM4.mkSpecInformation"));
 }
 
-void BlackBerryConfiguration::saveSettings()
+bool BlackBerryConfiguration::activate()
 {
-    saveNdkSettings();
-    saveCertificates();
-}
+    if (!isValid()) {
+        if (m_isAutoDetected)
+            return false;
 
-void BlackBerryConfiguration::clearNdkSettings()
-{
-    QSettings *settings = Core::ICore::settings();
-    settings->beginGroup(SettingsGroup);
-    settings->remove(NDKLocationKey);
-    settings->endGroup();
-}
+        QString errorMessage = QObject::tr("The following errors occurred while activating NDK: %1").arg(m_ndkPath);
+        if (m_qmake4BinaryFile.isEmpty() && m_qmake4BinaryFile.isEmpty())
+            errorMessage += QLatin1Char('\n') + QObject::tr("- No Qt version found.");
 
-BlackBerryConfiguration &BlackBerryConfiguration::instance()
-{
-    if (m_instance == 0)
-        m_instance = new BlackBerryConfiguration();
-    return *m_instance;
-}
-
-QString BlackBerryConfiguration::ndkPath() const
-{
-    return m_config.ndkPath;
-}
+        if (m_gccCompiler.isEmpty())
+            errorMessage += QLatin1Char('\n') + QObject::tr("- No GCC compiler found.");
 
-QString BlackBerryConfiguration::targetName() const
-{
-    return m_config.targetName;
-}
+        if (m_deviceDebuger.isEmpty())
+            errorMessage += QLatin1Char('\n') + QObject::tr("- No GDB debugger found for BB10 Device.");
 
-BlackBerryConfig BlackBerryConfiguration::config() const
-{
-    return m_config;
-}
+        if (!m_simulatorDebuger.isEmpty())
+            errorMessage += QLatin1Char('\n') + QObject::tr("- No GDB debugger found for BB10 Simulator.");
 
-Utils::FileName BlackBerryConfiguration::qmake4Path() const
-{
-    return m_config.qmake4BinaryFile;
-}
+        QMessageBox::warning(0, QObject::tr("Cannot Set up BB10 Configuration"),
+                             errorMessage, QMessageBox::Ok);
+        return false;
+    }
 
-Utils::FileName BlackBerryConfiguration::qmake5Path() const
-{
-    return m_config.qmake5BinaryFile;
-}
+    if (isActive() && !m_isAutoDetected)
+        return true;
 
-Utils::FileName BlackBerryConfiguration::gccPath() const
-{
-    return m_config.gccCompiler;
-}
+    ProjectExplorer::GccToolChain *tc = createGccToolChain();
+    if (!m_qmake4BinaryFile.isEmpty())
+        setupConfigurationPerQtVersion(m_qmake4BinaryFile, tc);
 
-Utils::FileName BlackBerryConfiguration::deviceGdbPath() const
-{
-    return m_config.deviceDebuger;
-}
+    if (!m_qmake4BinaryFile.isEmpty())
+        setupConfigurationPerQtVersion(m_qmake5BinaryFile, tc);
 
-Utils::FileName BlackBerryConfiguration::simulatorGdbPath() const
-{
-    return m_config.simulatorDebuger;
+    return true;
 }
 
-Utils::FileName BlackBerryConfiguration::sysRoot() const
+void BlackBerryConfiguration::deactivate()
 {
-    return m_config.sysRoot;
-}
+    QtSupport::BaseQtVersion *qt4Version = QtSupport::QtVersionManager::instance()->qtVersionForQMakeBinary(m_qmake4BinaryFile);
+    QtSupport::BaseQtVersion *qt5Version = QtSupport::QtVersionManager::instance()->qtVersionForQMakeBinary(m_qmake5BinaryFile);
+    if (qt4Version || qt5Version) {
+        foreach (ProjectExplorer::Kit *kit, ProjectExplorer::KitManager::instance()->kits()) {
+            if (qt4Version && qt4Version == QtSupport::QtKitInformation::qtVersion(kit))
+                ProjectExplorer::KitManager::instance()->deregisterKit(kit);
 
-QString BlackBerryConfiguration::barsignerCskPath() const
-{
-    return QnxUtils::dataDirPath() + QLatin1String("/barsigner.csk");
-}
+            else if (qt5Version && qt5Version == QtSupport::QtKitInformation::qtVersion(kit))
+                ProjectExplorer::KitManager::instance()->deregisterKit(kit);
+        }
 
-QString BlackBerryConfiguration::barsignerDbPath() const
-{
-    return QnxUtils::dataDirPath() + QLatin1String("/barsigner.db");
-}
+        if (qt4Version)
+            QtSupport::QtVersionManager::instance()->removeVersion(qt4Version);
 
-QString BlackBerryConfiguration::defaultKeystorePath() const
-{
-    return QnxUtils::dataDirPath() + QLatin1String("/author.p12");
-}
+        if (qt5Version)
+            QtSupport::QtVersionManager::instance()->removeVersion(qt5Version);
 
-QString BlackBerryConfiguration::defaultDebugTokenPath() const
-{
-    return QnxUtils::dataDirPath() + QLatin1String("/debugtoken.bar");
-}
+    }
 
-// TODO: QnxUtils::parseEnvFile() and qnxEnv() to return Util::Enviroment instead(?)
-QMultiMap<QString, QString> BlackBerryConfiguration::qnxEnv() const
-{
-    return m_config.qnxEnv;
+    foreach (ProjectExplorer::ToolChain* tc, ProjectExplorer::ToolChainManager::instance()->toolChains()) {
+        if (tc->compilerCommand() == m_gccCompiler)
+            ProjectExplorer::ToolChainManager::instance()->deregisterToolChain(tc);
+    }
 }
 
-BlackBerryConfiguration* BlackBerryConfiguration::m_instance = 0;
-
 } // namespace Internal
 } // namespace Qnx
diff --git a/src/plugins/qnx/blackberryconfiguration.h b/src/plugins/qnx/blackberryconfiguration.h
index 8ea1887b10d67791d2fa7b9bf1417a203edea740..2df1430dcfc36fe0fed274e87130ec376953a9f8 100644
--- a/src/plugins/qnx/blackberryconfiguration.h
+++ b/src/plugins/qnx/blackberryconfiguration.h
@@ -42,83 +42,50 @@
 #include <projectexplorer/kit.h>
 #include <projectexplorer/gcctoolchain.h>
 
-#include <QSettings>
 #include <QObject>
 
 namespace Qnx {
 namespace Internal {
 
-class BlackBerryCertificate;
-
-class BlackBerryConfig
-{
-    QString ndkPath;
-    QString targetName;
-    Utils::FileName qmake4BinaryFile;
-    Utils::FileName qmake5BinaryFile;
-    Utils::FileName gccCompiler;
-    Utils::FileName deviceDebuger;
-    Utils::FileName simulatorDebuger;
-    Utils::FileName sysRoot;
-    QMultiMap<QString, QString> qnxEnv;
-    QList<BlackBerryCertificate*> certificates;
-    BlackBerryCertificate *activeCertificate;
-
-    friend class BlackBerryConfiguration;
-};
-
-class BlackBerryConfiguration: public QObject
+class BlackBerryConfiguration
 {
-    Q_OBJECT
 public:
-    static BlackBerryConfiguration &instance();
-    BlackBerryConfig config() const;
-    Utils::FileName qmake4Path() const;
-    Utils::FileName qmake5Path() const;
-    Utils::FileName gccPath() const;
-    Utils::FileName deviceGdbPath() const;
-    Utils::FileName simulatorGdbPath() const;
-    Utils::FileName sysRoot() const;
-    QMultiMap<QString, QString> qnxEnv() const;
-    void setupNdkConfiguration(const QString &ndkPath);
+    BlackBerryConfiguration(const QString& ndkPath, bool isAutoDetected, const QString &displayName = QString());
+    bool activate();
+    void deactivate();
     QString ndkPath() const;
+    QString displayName() const;
     QString targetName() const;
-    QString barsignerCskPath() const;
-    QString barsignerDbPath() const;
-    QString defaultKeystorePath() const;
-    QString defaultDebugTokenPath() const;
-    void loadSettings();
-    void clearNdkSettings();
-    void cleanNdkConfiguration();
-    void syncCertificates(QList<BlackBerryCertificate*> certificates,
-            BlackBerryCertificate *activeCertificate);
-    void addCertificate(BlackBerryCertificate *certificate);
-    void removeCertificate(BlackBerryCertificate *certificate);
-
-    QList<BlackBerryCertificate*> certificates() const;
-    BlackBerryCertificate *activeCertificate();
-
-public slots:
-    void saveSettings();
+    bool isAutoDetected() const;
+    bool isActive() const;
+    bool isValid() const;
+    Utils::FileName qmake4BinaryFile() const;
+    Utils::FileName qmake5BinaryFile() const;
+    Utils::FileName gccCompiler() const;
+    Utils::FileName deviceDebuger() const;
+    Utils::FileName simulatorDebuger() const;
+    Utils::FileName sysRoot() const;
+    QMultiMap<QString, QString> qnxEnv() const;
 
 private:
-    BlackBerryConfiguration(QObject *parent = 0);
-    static BlackBerryConfiguration *m_instance;
-    BlackBerryConfig m_config;
-
-    void loadCertificates();
-    void loadNdkSettings();
-    void saveCertificates();
-    void saveNdkSettings();
-    bool refresh();
-    bool setNdkPath(const QString &ndkPath);
-    void setupNdkConfigPerQtVersion(const Utils::FileName &qmakePath, ProjectExplorer::GccToolChain* tc);
+    QString m_ndkPath;
+    QString m_displayName;
+    QString m_targetName;
+    bool m_isAutoDetected;
+    Utils::FileName m_qmake4BinaryFile;
+    Utils::FileName m_qmake5BinaryFile;
+    Utils::FileName m_gccCompiler;
+    Utils::FileName m_deviceDebuger;
+    Utils::FileName m_simulatorDebuger;
+    Utils::FileName m_sysRoot;
+    QMultiMap<QString, QString> m_qnxEnv;
+
+    void setupConfigurationPerQtVersion(const Utils::FileName &qmakePath, ProjectExplorer::GccToolChain* tc);
     QtSupport::BaseQtVersion* createQtVersion(const Utils::FileName &qmakePath);
     ProjectExplorer::GccToolChain* createGccToolChain();
     ProjectExplorer::Kit* createKit(QnxArchitecture arch, QtSupport::BaseQtVersion* qtVersion, ProjectExplorer::GccToolChain* tc);
+    void setSticky(ProjectExplorer::Kit* kit);
 
-signals:
-    void updated();
 };
 
 } // namespace Internal
diff --git a/src/plugins/qnx/blackberryconfigurationmanager.cpp b/src/plugins/qnx/blackberryconfigurationmanager.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..ec3416cfc67f1b22861e0b4d0c06e3ea8de3ce80
--- /dev/null
+++ b/src/plugins/qnx/blackberryconfigurationmanager.cpp
@@ -0,0 +1,384 @@
+/**************************************************************************
+**
+** Copyright (C) 2011 - 2013 Research In Motion
+**
+** Contact: Research In Motion (blackberry-qt@qnx.com)
+** Contact: KDAB (info@kdab.com)
+**
+** This file is part of Qt Creator.
+**
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and Digia.  For licensing terms and
+** conditions see http://qt.digia.com/licensing.  For further information
+** use the contact form at http://qt.digia.com/contact-us.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file.  Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Digia gives you certain additional
+** rights.  These rights are described in the Digia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+****************************************************************************/
+
+#include "blackberryconfigurationmanager.h"
+#include "blackberrycertificate.h"
+#include "blackberryconfiguration.h"
+
+#include "qnxutils.h"
+
+#include <coreplugin/icore.h>
+
+#include <utils/persistentsettings.h>
+#include <utils/hostosinfo.h>
+
+#include <projectexplorer/kit.h>
+#include <projectexplorer/kitmanager.h>
+#include <projectexplorer/kitinformation.h>
+#include <projectexplorer/toolchainmanager.h>
+
+#include <qtsupport/qtversionmanager.h>
+#include <qtsupport/qtkitinformation.h>
+
+#include <QMessageBox>
+
+namespace Qnx {
+namespace Internal {
+
+namespace {
+const QLatin1String SettingsGroup("BlackBerryConfiguration");
+const QLatin1String NDKLocationKey("NDKLocation");
+const QLatin1String CertificateGroup("Certificates");
+const QLatin1String ManualNDKsGroup("ManualNDKs");
+}
+
+BlackBerryConfigurationManager::BlackBerryConfigurationManager(QObject *parent)
+    :QObject(parent)
+{
+    connect(Core::ICore::instance(), SIGNAL(saveSettingsRequested()), this, SLOT(saveSettings()));
+}
+
+void BlackBerryConfigurationManager::loadCertificates()
+{
+    QSettings *settings = Core::ICore::settings();
+
+    settings->beginGroup(SettingsGroup);
+    settings->beginGroup(CertificateGroup);
+
+    foreach (const QString &certificateId, settings->childGroups()) {
+        settings->beginGroup(certificateId);
+
+        BlackBerryCertificate *cert =
+                new BlackBerryCertificate(settings->value(QLatin1String(Qnx::Constants::QNX_KEY_PATH)).toString(),
+                                          settings->value(QLatin1String(Qnx::Constants::QNX_KEY_AUTHOR)).toString());
+        cert->setParent(this);
+
+        if (settings->value(QLatin1String(Qnx::Constants::QNX_KEY_ACTIVE)).toBool())
+            m_activeCertificate = cert;
+
+        m_certificates << cert;
+
+        settings->endGroup();
+    }
+
+    settings->endGroup();
+    settings->endGroup();
+}
+
+void BlackBerryConfigurationManager::loadManualConfigurations()
+{
+    QSettings *settings = Core::ICore::settings();
+
+    settings->beginGroup(SettingsGroup);
+    settings->beginGroup(ManualNDKsGroup);
+
+    foreach (const QString &manualNdk, settings->childGroups()) {
+        settings->beginGroup(manualNdk);
+        BlackBerryConfiguration *config = new BlackBerryConfiguration(settings->value(NDKLocationKey).toString(),
+                                                                      false);
+        if (!addConfiguration(config))
+            delete config;
+
+        settings->endGroup();
+    }
+
+    settings->endGroup();
+    settings->endGroup();
+}
+
+void BlackBerryConfigurationManager::loadAutoDetectedConfigurations()
+{
+    foreach (const NdkInstallInformation &ndkInfo, QnxUtils::installedNdks()) {
+        BlackBerryConfiguration *config = new BlackBerryConfiguration(ndkInfo.path, true, ndkInfo.name);
+        if (!addConfiguration(config))
+            delete config;
+    }
+}
+
+void BlackBerryConfigurationManager::saveCertificates()
+{
+    QSettings *settings = Core::ICore::settings();
+    settings->beginGroup(SettingsGroup);
+    settings->beginGroup(CertificateGroup);
+
+    settings->remove(QString());
+
+    foreach (const BlackBerryCertificate *cert, m_certificates) {
+        settings->beginGroup(cert->id());
+        settings->setValue(QLatin1String(Qnx::Constants::QNX_KEY_PATH), cert->fileName());
+        settings->setValue(QLatin1String(Qnx::Constants::QNX_KEY_AUTHOR), cert->author());
+
+        if (cert == m_activeCertificate)
+            settings->setValue(QLatin1String(Qnx::Constants::QNX_KEY_ACTIVE), true);
+
+        settings->endGroup();
+    }
+
+    settings->endGroup();
+    settings->endGroup();
+}
+
+void BlackBerryConfigurationManager::saveManualConfigurations()
+{
+    if (manualConfigurations().isEmpty())
+        return;
+
+    QSettings *settings = Core::ICore::settings();
+    settings->beginGroup(SettingsGroup);
+    settings->beginGroup(ManualNDKsGroup);
+
+    foreach (BlackBerryConfiguration *config, manualConfigurations()) {
+        settings->beginGroup(config->displayName());
+        settings->setValue(NDKLocationKey, config->ndkPath());
+        settings->endGroup();
+    }
+
+    settings->endGroup();
+    settings->endGroup();
+}
+
+// Remove no longer available 'auo detected' kits
+void BlackBerryConfigurationManager::clearInvalidConfigurations()
+{
+    QList<NdkInstallInformation> autoNdks = QnxUtils::installedNdks();
+    foreach (ProjectExplorer::Kit *kit, ProjectExplorer::KitManager::instance()->kits()) {
+        if (!kit->isAutoDetected())
+            continue;
+
+        if (kit->displayName().contains(QLatin1String("BlackBerry"))) {
+            // Check if related target is still installed
+            bool isValid = false;
+            foreach (const NdkInstallInformation &ndkInfo, autoNdks) {
+                if (ndkInfo.target == ProjectExplorer::SysRootKitInformation::sysRoot(kit).toString()) {
+                    isValid = true;
+                    break;
+                }
+            }
+
+            if (!isValid) {
+                QtSupport::QtVersionManager::instance()->removeVersion(QtSupport::QtKitInformation::qtVersion(kit));
+                ProjectExplorer::ToolChainManager::instance()->deregisterToolChain(
+                            ProjectExplorer::ToolChainKitInformation::toolChain(kit));
+                ProjectExplorer::KitManager::instance()->deregisterKit(kit);
+            }
+        }
+    }
+}
+
+bool BlackBerryConfigurationManager::addConfiguration(BlackBerryConfiguration *config)
+{
+    foreach (BlackBerryConfiguration *c, m_configs) {
+        if (c->ndkPath() == config->ndkPath()
+                && c->targetName() == config->targetName()) {
+            if (!config->isAutoDetected())
+                QMessageBox::warning(0, tr("NDK Already known"),
+                                 tr("The NDK already has a configuration."), QMessageBox::Ok);
+            return false;
+        }
+    }
+
+    if (config->activate()) {
+        m_configs.append(config);
+        return true;
+    }
+
+    return false;
+}
+
+void BlackBerryConfigurationManager::removeConfiguration(BlackBerryConfiguration *config)
+{
+    if (!config)
+        return;
+
+    if (config->isActive())
+        config->deactivate();
+
+    clearConfigurationSettings(config);
+
+    m_configs.removeAt(m_configs.indexOf(config));
+    delete config;
+}
+
+QList<BlackBerryConfiguration *> BlackBerryConfigurationManager::configurations() const
+{
+    return m_configs;
+}
+
+QList<BlackBerryConfiguration *> BlackBerryConfigurationManager::manualConfigurations() const
+{
+    QList<BlackBerryConfiguration*> manuals;
+    foreach (BlackBerryConfiguration *config, m_configs) {
+        if (!config->isAutoDetected())
+            manuals << config;
+    }
+
+    return manuals;
+}
+
+BlackBerryConfiguration *BlackBerryConfigurationManager::configurationFromNdkPath(const QString &ndkPath) const
+{
+    foreach (BlackBerryConfiguration *config, m_configs) {
+        if (config->ndkPath() == ndkPath)
+            return config;
+    }
+
+    return 0;
+}
+
+void BlackBerryConfigurationManager::syncCertificates(QList<BlackBerryCertificate*> certificates,
+                                                      BlackBerryCertificate *activeCertificate)
+{
+    activeCertificate = activeCertificate;
+
+    foreach (BlackBerryCertificate *cert, certificates) {
+        if (!certificates.contains(cert))
+            removeCertificate(cert);
+    }
+
+    foreach (BlackBerryCertificate *cert, certificates)
+        addCertificate(cert);
+}
+
+void BlackBerryConfigurationManager::addCertificate(BlackBerryCertificate *certificate)
+{
+    if (m_certificates.contains(certificate))
+        return;
+
+    if (m_certificates.isEmpty())
+        m_activeCertificate = certificate;
+
+    certificate->setParent(this);
+    m_certificates << certificate;
+}
+
+void BlackBerryConfigurationManager::removeCertificate(BlackBerryCertificate *certificate)
+{
+    if (m_activeCertificate == certificate)
+        m_activeCertificate = 0;
+
+    m_certificates.removeAll(certificate);
+
+    delete certificate;
+}
+
+QList<BlackBerryCertificate*> BlackBerryConfigurationManager::certificates() const
+{
+    return m_certificates;
+}
+
+BlackBerryCertificate * BlackBerryConfigurationManager::activeCertificate()
+{
+    return m_activeCertificate;
+}
+
+// Returns a valid qnxEnv map from a valid configuration;
+// Needed by other classes to get blackberry process path (keys registration, debug token...)
+QMultiMap<QString, QString> BlackBerryConfigurationManager::defaultQnxEnv()
+{
+    foreach (BlackBerryConfiguration *config, m_configs) {
+        if (!config->qnxEnv().isEmpty())
+            return config->qnxEnv();
+    }
+
+    return QMultiMap<QString, QString>();
+}
+
+void BlackBerryConfigurationManager::loadSettings()
+{
+    clearInvalidConfigurations();
+    loadAutoDetectedConfigurations();
+    loadManualConfigurations();
+    loadCertificates();
+}
+
+void BlackBerryConfigurationManager::clearConfigurationSettings(BlackBerryConfiguration *config)
+{
+    if (!config)
+        return;
+
+    QSettings *settings = Core::ICore::settings();
+    settings->beginGroup(SettingsGroup);
+    settings->beginGroup(ManualNDKsGroup);
+
+    foreach (const QString &manualNdk, settings->childGroups()) {
+        if (manualNdk == config->displayName()) {
+            settings->remove(manualNdk);
+            break;
+        }
+    }
+
+    settings->endGroup();
+    settings->endGroup();
+}
+
+void BlackBerryConfigurationManager::saveSettings()
+{
+    saveManualConfigurations();
+    saveCertificates();
+}
+
+BlackBerryConfigurationManager &BlackBerryConfigurationManager::instance()
+{
+    if (m_instance == 0)
+        m_instance = new BlackBerryConfigurationManager();
+
+    return *m_instance;
+}
+
+BlackBerryConfigurationManager::~BlackBerryConfigurationManager()
+{
+    qDeleteAll(m_configs);
+}
+
+QString BlackBerryConfigurationManager::barsignerCskPath() const
+{
+    return QnxUtils::dataDirPath() + QLatin1String("/barsigner.csk");
+}
+
+QString BlackBerryConfigurationManager::barsignerDbPath() const
+{
+    return QnxUtils::dataDirPath() + QLatin1String("/barsigner.db");
+}
+
+QString BlackBerryConfigurationManager::defaultKeystorePath() const
+{
+    return QnxUtils::dataDirPath() + QLatin1String("/author.p12");
+}
+
+QString BlackBerryConfigurationManager::defaultDebugTokenPath() const
+{
+    return QnxUtils::dataDirPath() + QLatin1String("/debugtoken.bar");
+}
+
+BlackBerryConfigurationManager* BlackBerryConfigurationManager::m_instance = 0;
+
+} // namespace Internal
+} // namespace Qnx
diff --git a/src/plugins/qnx/blackberryconfigurationmanager.h b/src/plugins/qnx/blackberryconfigurationmanager.h
new file mode 100644
index 0000000000000000000000000000000000000000..c76ac4e2028aaf4c37142985ca0299d3e618404d
--- /dev/null
+++ b/src/plugins/qnx/blackberryconfigurationmanager.h
@@ -0,0 +1,97 @@
+/**************************************************************************
+**
+** Copyright (C) 2011 - 2013 Research In Motion
+**
+** Contact: Research In Motion (blackberry-qt@qnx.com)
+** Contact: KDAB (info@kdab.com)
+**
+** This file is part of Qt Creator.
+**
+** Commercial License Usage
+** Licensees holding valid commercial Qt licenses may use this file in
+** accordance with the commercial license agreement provided with the
+** Software or, alternatively, in accordance with the terms contained in
+** a written agreement between you and Digia.  For licensing terms and
+** conditions see http://qt.digia.com/licensing.  For further information
+** use the contact form at http://qt.digia.com/contact-us.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file.  Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Digia gives you certain additional
+** rights.  These rights are described in the Digia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+****************************************************************************/
+
+#ifndef BLACKBERRYCONFIGURATIONMANAGER_H
+#define BLACKBERRYCONFIGURATIONMANAGER_H
+
+#include <utils/environment.h>
+#include <utils/fileutils.h>
+
+#include <QSettings>
+#include <QObject>
+
+namespace Qnx {
+namespace Internal {
+
+class BlackBerryConfiguration;
+class BlackBerryCertificate;
+
+class BlackBerryConfigurationManager : public QObject
+{
+    Q_OBJECT
+public:
+    static BlackBerryConfigurationManager &instance();
+    ~BlackBerryConfigurationManager();
+    bool addConfiguration(BlackBerryConfiguration *config);
+    void removeConfiguration(BlackBerryConfiguration *config);
+    QList<BlackBerryConfiguration*> configurations() const;
+    QList<BlackBerryConfiguration*> manualConfigurations() const;
+    BlackBerryConfiguration *configurationFromNdkPath(const QString &ndkPath) const;
+
+    QString barsignerCskPath() const;
+    QString barsignerDbPath() const;
+    QString defaultKeystorePath() const;
+    QString defaultDebugTokenPath() const;
+    void clearConfigurationSettings(BlackBerryConfiguration *config);
+    void syncCertificates(QList<BlackBerryCertificate*> certificates,
+            BlackBerryCertificate *activeCertificate);
+    void addCertificate(BlackBerryCertificate *certificate);
+    void removeCertificate(BlackBerryCertificate *certificate);
+
+    QList<BlackBerryCertificate*> certificates() const;
+    BlackBerryCertificate *activeCertificate();
+
+    QMultiMap<QString, QString> defaultQnxEnv();
+
+public slots:
+    void loadSettings();
+    void saveSettings();
+
+private:
+    BlackBerryConfigurationManager(QObject *parent = 0);
+    static BlackBerryConfigurationManager *m_instance;
+    QList<BlackBerryConfiguration*> m_configs;
+
+    QList<BlackBerryCertificate*> m_certificates;
+    BlackBerryCertificate *m_activeCertificate;
+
+    void loadCertificates();
+    void loadManualConfigurations();
+    void loadAutoDetectedConfigurations();
+    void saveCertificates();
+    void saveManualConfigurations();
+    void clearInvalidConfigurations();
+};
+
+} // namespace Internal
+} // namespace Qnx
+
+#endif // BLACKBERRYCONFIGURATIONMANAGER_H
diff --git a/src/plugins/qnx/blackberrycsjregistrar.cpp b/src/plugins/qnx/blackberrycsjregistrar.cpp
index 1066d6a2afe8e6a9b2cb2c6c93552a4c1c309d9d..0661f156ccc2f8206eddf29e5e35f4e14abb6bd4 100644
--- a/src/plugins/qnx/blackberrycsjregistrar.cpp
+++ b/src/plugins/qnx/blackberrycsjregistrar.cpp
@@ -30,6 +30,7 @@
 ****************************************************************************/
 
 #include "blackberrycsjregistrar.h"
+#include "blackberryconfigurationmanager.h"
 #include "blackberryconfiguration.h"
 
 #include <utils/hostosinfo.h>
@@ -57,9 +58,15 @@ void BlackBerryCsjRegistrar::tryRegister(const QStringList &csjFiles,
     if (m_process->state() != QProcess::NotRunning)
         return;
 
-    QString command = BlackBerryConfiguration::instance()
-        .qnxEnv().value(QLatin1String("QNX_HOST"))
-        + (QLatin1String("/usr/bin/blackberry-signer"));
+    if (BlackBerryConfigurationManager::instance().configurations().isEmpty())
+        return;
+
+    QMultiMap<QString, QString> qnxEnv = BlackBerryConfigurationManager::instance().defaultQnxEnv();
+    if (qnxEnv.isEmpty())
+        return;
+
+    QString command = qnxEnv.value(QLatin1String("QNX_HOST"))
+                                + (QLatin1String("/usr/bin/blackberry-signer"));
 
     if (Utils::HostOsInfo::isWindowsHost())
         command += QLatin1String(".bat");
diff --git a/src/plugins/qnx/blackberrydebugtokenrequestdialog.cpp b/src/plugins/qnx/blackberrydebugtokenrequestdialog.cpp
index 8728f11c07162597d96679e6069f8e60b1fdb0b9..df7426f90124329a9a6f77a9164916148c0f8d7c 100644
--- a/src/plugins/qnx/blackberrydebugtokenrequestdialog.cpp
+++ b/src/plugins/qnx/blackberrydebugtokenrequestdialog.cpp
@@ -32,7 +32,7 @@
 #include "blackberrydebugtokenrequestdialog.h"
 #include "blackberrydebugtokenrequester.h"
 #include "blackberrydeviceinformation.h"
-#include "blackberryconfiguration.h"
+#include "blackberryconfigurationmanager.h"
 #include "blackberrycertificate.h"
 #include "ui_blackberrydebugtokenrequestdialog.h"
 
@@ -283,9 +283,9 @@ void BlackBerryDebugTokenRequestDialog::setBusy(bool busy)
 
 void BlackBerryDebugTokenRequestDialog::populateComboBox()
 {
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+    BlackBerryConfigurationManager &configManager = BlackBerryConfigurationManager::instance();
 
-    QList<BlackBerryCertificate*> certificates = configuration.certificates();
+    QList<BlackBerryCertificate*> certificates = configManager.certificates();
 
     foreach (const BlackBerryCertificate *certificate, certificates)
         m_ui->keystore->addItem(certificate->fileName());
diff --git a/src/plugins/qnx/blackberrydeviceconnection.cpp b/src/plugins/qnx/blackberrydeviceconnection.cpp
index 5db6264125d9efc571a7861a2aa40177af4813c4..97ccd975f681d870c1dec88096958aad79b76a3e 100644
--- a/src/plugins/qnx/blackberrydeviceconnection.cpp
+++ b/src/plugins/qnx/blackberrydeviceconnection.cpp
@@ -32,6 +32,7 @@
 #include "blackberrydeviceconnection.h"
 
 #include "blackberryconfiguration.h"
+#include "blackberryconfigurationmanager.h"
 #include "qnxutils.h"
 
 #include <projectexplorer/devicesupport/devicemanager.h>
@@ -61,7 +62,11 @@ BlackBerryDeviceConnection::BlackBerryDeviceConnection() :
 void BlackBerryDeviceConnection::connectDevice(const ProjectExplorer::IDevice::ConstPtr &device)
 {
     Utils::Environment env = Utils::Environment::systemEnvironment();
-    QnxUtils::prependQnxMapToEnvironment(BlackBerryConfiguration::instance().qnxEnv(), env);
+
+    QMultiMap<QString, QString> qnxEnv = BlackBerryConfigurationManager::instance().defaultQnxEnv();
+    if (!qnxEnv.isEmpty())
+        QnxUtils::prependQnxMapToEnvironment(qnxEnv, env);
+
     m_process->setEnvironment(env.toStringList());
 
     m_host = device->sshParameters().host;
diff --git a/src/plugins/qnx/blackberrykeyswidget.cpp b/src/plugins/qnx/blackberrykeyswidget.cpp
index d099dc48f6a162f2b3bf9f654dafbfef344430b9..708260b31a160d1ba12d876a1ae56725af4ea0ad 100644
--- a/src/plugins/qnx/blackberrykeyswidget.cpp
+++ b/src/plugins/qnx/blackberrykeyswidget.cpp
@@ -31,7 +31,7 @@
 
 #include "blackberrykeyswidget.h"
 #include "blackberryregisterkeydialog.h"
-#include "blackberryconfiguration.h"
+#include "blackberryconfigurationmanager.h"
 #include "blackberrycertificatemodel.h"
 #include "blackberryimportcertificatedialog.h"
 #include "blackberrycreatecertificatedialog.h"
@@ -75,9 +75,9 @@ BlackBerryKeysWidget::BlackBerryKeysWidget(QWidget *parent) :
 
 void BlackBerryKeysWidget::apply()
 {
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+    BlackBerryConfigurationManager &configManager = BlackBerryConfigurationManager::instance();
 
-    configuration.syncCertificates(m_model->certificates(), m_model->activeCertificate());
+    configManager.syncCertificates(m_model->certificates(), m_model->activeCertificate());
 }
 
 void BlackBerryKeysWidget::registerKey()
@@ -109,12 +109,12 @@ void BlackBerryKeysWidget::unregisterKey()
     if (answer & QMessageBox::No)
         return;
 
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+    BlackBerryConfigurationManager &configManager = BlackBerryConfigurationManager::instance();
 
-    QFile f(configuration.barsignerCskPath());
+    QFile f(configManager.barsignerCskPath());
     f.remove();
 
-    f.setFileName(configuration.barsignerDbPath());
+    f.setFileName(configManager.barsignerDbPath());
     f.remove();
 
     updateRegisterSection();
diff --git a/src/plugins/qnx/blackberryndkprocess.cpp b/src/plugins/qnx/blackberryndkprocess.cpp
index a148c9741b371a02122596fa31fdc017931bee8f..98f4e9ff30e74350bae834e2e454f0f787743750 100644
--- a/src/plugins/qnx/blackberryndkprocess.cpp
+++ b/src/plugins/qnx/blackberryndkprocess.cpp
@@ -31,6 +31,7 @@
 
 #include "blackberryndkprocess.h"
 #include "blackberryconfiguration.h"
+#include "blackberryconfigurationmanager.h"
 
 #include <utils/hostosinfo.h>
 
@@ -54,12 +55,15 @@ BlackBerryNdkProcess::BlackBerryNdkProcess(const QString &command, QObject *pare
 
 QString BlackBerryNdkProcess::command() const
 {
-    QString command = BlackBerryConfiguration::instance()
-        .qnxEnv().value(QLatin1String("QNX_HOST"))
-        + (QLatin1String("/usr/bin/")) + m_command;
-
-    if (Utils::HostOsInfo::isWindowsHost())
-        command += QLatin1String(".bat");
+    QString command;
+    QMultiMap<QString, QString> qnxEnv = BlackBerryConfigurationManager::instance().defaultQnxEnv();
+    if (!qnxEnv.isEmpty()) {
+        command = qnxEnv.value(QLatin1String("QNX_HOST"))
+                + (QLatin1String("/usr/bin/")) + m_command;
+
+        if (Utils::HostOsInfo::isWindowsHost())
+            command += QLatin1String(".bat");
+    }
 
     return command;
 }
diff --git a/src/plugins/qnx/blackberryndksettingswidget.cpp b/src/plugins/qnx/blackberryndksettingswidget.cpp
index d5010221315ef26c035df8f19ccff849b8cb0d63..0be77f4ba67ebe5b50e0a889a1e9ad21993b5ec1 100644
--- a/src/plugins/qnx/blackberryndksettingswidget.cpp
+++ b/src/plugins/qnx/blackberryndksettingswidget.cpp
@@ -35,36 +35,40 @@
 #include "blackberryutils.h"
 #include "blackberrysetupwizard.h"
 
+#include "blackberryconfigurationmanager.h"
+#include "blackberryconfiguration.h"
+
 #include <utils/pathchooser.h>
 
 #include <coreplugin/icore.h>
 
 #include <QMessageBox>
+#include <QFileDialog>
+
+#include <QStandardItemModel>
+#include <QTreeWidgetItem>
 
 namespace Qnx {
 namespace Internal {
 
 BlackBerryNDKSettingsWidget::BlackBerryNDKSettingsWidget(QWidget *parent) :
     QWidget(parent),
-    m_ui(new Ui_BlackBerryNDKSettingsWidget)
+    m_ui(new Ui_BlackBerryNDKSettingsWidget),
+    m_autoDetectedNdks(0),
+    m_manualNdks(0)
 {
-    m_bbConfig = &BlackBerryConfiguration::instance();
+    m_bbConfigManager = &BlackBerryConfigurationManager::instance();
     m_ui->setupUi(this);
-    m_ui->sdkPath->setExpectedKind(Utils::PathChooser::ExistingDirectory);
-    m_ui->sdkPath->setPath(m_bbConfig->ndkPath());
-    m_hasValidSdkPath = QnxUtils::isValidNdkPath(m_ui->sdkPath->path());
+
+    m_ui->removeNdkButton->setEnabled(false);
 
     initInfoTable();
+    initNdkList();
 
     connect(m_ui->wizardButton, SIGNAL(clicked()), this, SLOT(launchBlackBerrySetupWizard()));
-    connect(m_ui->sdkPath, SIGNAL(changed(QString)), this, SLOT(checkSdkPath()));
-    connect(m_ui->removeButton, SIGNAL(clicked()), this, SLOT(cleanConfiguration()));
-    connect(m_bbConfig, SIGNAL(updated()), this, SLOT(updateInfoTable()));
-}
-
-void BlackBerryNDKSettingsWidget::setRemoveButtonVisible(bool visible)
-{
-    m_ui->removeButton->setVisible(visible);
+    connect(m_ui->addNdkButton, SIGNAL(clicked()), this, SLOT(addNdk()));
+    connect(m_ui->removeNdkButton, SIGNAL(clicked()), this, SLOT(removeNdk()));
+    connect(m_ui->ndksTreeWidget, SIGNAL(currentItemChanged(QTreeWidgetItem*,QTreeWidgetItem*)), this, SLOT(updateInfoTable(QTreeWidgetItem*)));
 }
 
 void BlackBerryNDKSettingsWidget::setWizardMessageVisible(bool visible)
@@ -73,9 +77,9 @@ void BlackBerryNDKSettingsWidget::setWizardMessageVisible(bool visible)
     m_ui->wizardButton->setVisible(visible);
 }
 
-QString BlackBerryNDKSettingsWidget::sdkPath() const
+bool BlackBerryNDKSettingsWidget::hasActiveNdk() const
 {
-    return m_ui->sdkPath->path();
+    return !m_bbConfigManager->configurations().isEmpty();
 }
 
 void BlackBerryNDKSettingsWidget::launchBlackBerrySetupWizard() const
@@ -92,30 +96,16 @@ void BlackBerryNDKSettingsWidget::launchBlackBerrySetupWizard() const
     wizard.exec();
 }
 
-void BlackBerryNDKSettingsWidget::checkSdkPath()
+void BlackBerryNDKSettingsWidget::updateInfoTable(QTreeWidgetItem* currentNdk)
 {
-    if (!m_ui->sdkPath->path().isEmpty() &&
-            QnxUtils::isValidNdkPath(m_ui->sdkPath->path())) {
-        m_bbConfig->setupNdkConfiguration(m_ui->sdkPath->path());
-        m_hasValidSdkPath = true;
-    } else {
-        m_hasValidSdkPath = false;
+    QString ndkPath = currentNdk->text(1);
+    if (ndkPath.isEmpty()) {
+        m_ui->removeNdkButton->setEnabled(false);
+        return;
     }
 
-    emit sdkPathChanged(m_ui->sdkPath->path());
-}
-
-bool BlackBerryNDKSettingsWidget::hasValidSdkPath() const
-{
-    return m_hasValidSdkPath;
-}
-
-void BlackBerryNDKSettingsWidget::updateInfoTable()
-{
-    QMultiMap<QString, QString> env = m_bbConfig->qnxEnv();
-
+    QMultiMap<QString, QString> env = QnxUtils::parseEnvironmentFile(QnxUtils::envFilePath(ndkPath));
     if (env.isEmpty()) {
-        // clear
         clearInfoTable();
         return;
     }
@@ -137,30 +127,83 @@ void BlackBerryNDKSettingsWidget::updateInfoTable()
         m_infoModel->appendRow(row);
     }
 
-    m_infoModel->appendRow( QList<QStandardItem*>() << new QStandardItem(QString(QLatin1String("QMAKE 4"))) << new QStandardItem(m_bbConfig->qmake4Path().toString()));
-    m_infoModel->appendRow( QList<QStandardItem*>() << new QStandardItem(QString(QLatin1String("QMAKE 5"))) << new QStandardItem(m_bbConfig->qmake5Path().toString()));
-    m_infoModel->appendRow( QList<QStandardItem*>() << new QStandardItem(QString(QLatin1String("COMPILER"))) << new QStandardItem(m_bbConfig->gccPath().toString()));
+    BlackBerryConfiguration *config = m_bbConfigManager->configurationFromNdkPath(ndkPath);
+    if (!config)
+        return;
+
+    QString qmake4Path = config->qmake4BinaryFile().toString();
+    QString qmake5Path = config->qmake5BinaryFile().toString();
+
+    if (!qmake4Path.isEmpty())
+        m_infoModel->appendRow(QList<QStandardItem*>() << new QStandardItem(QString(QLatin1String("QMAKE 4"))) << new QStandardItem(qmake4Path));
+
+    if (!qmake5Path.isEmpty())
+        m_infoModel->appendRow(QList<QStandardItem*>() << new QStandardItem(QString(QLatin1String("QMAKE 5"))) << new QStandardItem(qmake5Path));
+
+    m_infoModel->appendRow(QList<QStandardItem*>() << new QStandardItem(QString(QLatin1String("COMPILER"))) << new QStandardItem(config->gccCompiler().toString()));
 
-    m_ui->removeButton->setEnabled(true);
+    m_ui->removeNdkButton->setEnabled(!config->isAutoDetected());
+}
+
+void BlackBerryNDKSettingsWidget::updateNdkList()
+{
+    foreach (BlackBerryConfiguration *config, m_bbConfigManager->configurations()) {
+        QTreeWidgetItem *parent = config->isAutoDetected() ? m_autoDetectedNdks : m_manualNdks;
+        QTreeWidgetItem *item = new QTreeWidgetItem(parent);
+        item->setText(0, config->displayName());
+        item->setText(1, config->ndkPath()); // TODO: should be target name for NDKs >= v10.2
+    }
+
+    if (m_autoDetectedNdks->child(0)) {
+        m_autoDetectedNdks->child(0)->setSelected(true);
+        updateInfoTable(m_autoDetectedNdks->child(0));
+    }
 }
 
 void BlackBerryNDKSettingsWidget::clearInfoTable()
 {
     m_infoModel->clear();
-    m_ui->sdkPath->setPath(QString());
-    m_ui->removeButton->setEnabled(false);
 }
 
-void BlackBerryNDKSettingsWidget::cleanConfiguration()
+void BlackBerryNDKSettingsWidget::addNdk()
+{
+    QString selectedPath = QFileDialog::getExistingDirectory(0, tr("Select the NDK path"),
+                                                             QString(),
+                                                             QFileDialog::ShowDirsOnly);
+    if (selectedPath.isEmpty())
+        return;
+
+    BlackBerryConfiguration *config = m_bbConfigManager->configurationFromNdkPath(selectedPath);
+    if (!config) {
+        config = new BlackBerryConfiguration(selectedPath, false);
+        if (!m_bbConfigManager->addConfiguration(config)) {
+            delete config;
+            return;
+        }
+
+        QTreeWidgetItem *item = new QTreeWidgetItem(m_manualNdks);
+        item->setText(0, selectedPath.split(QDir::separator()).last());
+        item->setText(1, selectedPath);
+        updateInfoTable(item);
+    }
+}
+
+void BlackBerryNDKSettingsWidget::removeNdk()
 {
+    QString ndkPath = m_ui->ndksTreeWidget->currentItem()->text(1);
     QMessageBox::StandardButton button =
             QMessageBox::question(Core::ICore::mainWindow(),
                                   tr("Clean BlackBerry 10 Configuration"),
-                                  tr("Are you sure you want to remove the current BlackBerry configuration?"),
+                                  tr("Are you sure you want to remove:\n %1?").arg(ndkPath),
                                   QMessageBox::Yes | QMessageBox::No);
 
-    if (button == QMessageBox::Yes)
-        m_bbConfig->cleanNdkConfiguration();
+    if (button == QMessageBox::Yes) {
+        BlackBerryConfiguration *config = m_bbConfigManager->configurationFromNdkPath(ndkPath);
+        if (config)
+            m_bbConfigManager->removeConfiguration(config);
+            m_manualNdks->removeChild(m_ui->ndksTreeWidget->currentItem());
+    }
+
 }
 
 void BlackBerryNDKSettingsWidget::initInfoTable()
@@ -170,8 +213,27 @@ void BlackBerryNDKSettingsWidget::initInfoTable()
     m_ui->ndkInfosTableView->setModel(m_infoModel);
     m_ui->ndkInfosTableView->verticalHeader()->hide();
     m_ui->ndkInfosTableView->setEditTriggers(QAbstractItemView::NoEditTriggers);
+}
 
-    updateInfoTable();
+void BlackBerryNDKSettingsWidget::initNdkList()
+{
+    m_ui->ndksTreeWidget->header()->setResizeMode(QHeaderView::Stretch);
+    m_ui->ndksTreeWidget->header()->setStretchLastSection(false);
+    m_ui->ndksTreeWidget->setHeaderItem(new QTreeWidgetItem(QStringList() << tr("NDK") << tr("Path")));
+    m_ui->ndksTreeWidget->setTextElideMode(Qt::ElideNone);
+    m_ui->ndksTreeWidget->setColumnCount(2);
+    m_autoDetectedNdks = new QTreeWidgetItem(m_ui->ndksTreeWidget);
+    m_autoDetectedNdks->setText(0, tr("Auto-Detected"));
+    m_autoDetectedNdks->setFirstColumnSpanned(true);
+    m_autoDetectedNdks->setFlags(Qt::ItemIsEnabled);
+    m_manualNdks = new QTreeWidgetItem(m_ui->ndksTreeWidget);
+    m_manualNdks->setText(0, tr("Manual"));
+    m_manualNdks->setFirstColumnSpanned(true);
+    m_manualNdks->setFlags(Qt::ItemIsEnabled);
+
+    m_ui->ndksTreeWidget->expandAll();
+
+    updateNdkList();
 }
 
 } // namespace Internal
diff --git a/src/plugins/qnx/blackberryndksettingswidget.h b/src/plugins/qnx/blackberryndksettingswidget.h
index 5b82972e70822b8309c062c6bf2ed032508c01d4..797ebe10fbca8ed1bafcdc91b5fb9b077685005f 100644
--- a/src/plugins/qnx/blackberryndksettingswidget.h
+++ b/src/plugins/qnx/blackberryndksettingswidget.h
@@ -32,48 +32,47 @@
 #ifndef BLACKBERRYNDKSETTINGSWIDGET_H
 #define BLACKBERRYNDKSETTINGSWIDGET_H
 
-#include "blackberryconfiguration.h"
-
 #include <QWidget>
-#include <QStandardItemModel>
 
+class QStandardItemModel;
+class QTreeWidgetItem;
 
 namespace Qnx {
 namespace Internal {
 
+class BlackBerryConfigurationManager;
 class Ui_BlackBerryNDKSettingsWidget;
 
-
 class BlackBerryNDKSettingsWidget : public QWidget
 {
     Q_OBJECT
 public:
     explicit BlackBerryNDKSettingsWidget(QWidget *parent = 0);
 
-   void setRemoveButtonVisible(bool visible);
    void setWizardMessageVisible(bool visible);
 
-   QString sdkPath() const;
-
-   bool hasValidSdkPath() const;
+   bool hasActiveNdk() const;
 
 signals:
-    void sdkPathChanged(const QString &newPath);
+    void kitsUpdated();
 
 public slots:
     void launchBlackBerrySetupWizard() const;
-    void checkSdkPath();
-    void updateInfoTable();
+    void updateInfoTable(QTreeWidgetItem* currentNdk);
+    void updateNdkList();
     void clearInfoTable();
-    void cleanConfiguration();
+    void addNdk();
+    void removeNdk();
 
 private:
     void initInfoTable();
+    void initNdkList();
+
     Ui_BlackBerryNDKSettingsWidget *m_ui;
-    BlackBerryConfiguration *m_bbConfig;
+    BlackBerryConfigurationManager *m_bbConfigManager;
     QStandardItemModel *m_infoModel;
-    bool m_hasValidSdkPath;
-
+    QTreeWidgetItem *m_autoDetectedNdks;
+    QTreeWidgetItem *m_manualNdks;
 };
 
 } // namespace Internal
diff --git a/src/plugins/qnx/blackberryndksettingswidget.ui b/src/plugins/qnx/blackberryndksettingswidget.ui
index a422c632407b518991512e394adb3c9647bfab1a..442ce13e81653dc5400f0bd439cd0ea3b41cc978 100644
--- a/src/plugins/qnx/blackberryndksettingswidget.ui
+++ b/src/plugins/qnx/blackberryndksettingswidget.ui
@@ -150,39 +150,41 @@
      <item row="0" column="0">
       <layout class="QHBoxLayout" name="horizontalLayout_2">
        <item>
-        <widget class="QLabel" name="label">
-         <property name="text">
-          <string>BlackBerry NDK Path </string>
-         </property>
+        <widget class="QTreeWidget" name="ndksTreeWidget">
+         <column>
+          <property name="text">
+           <string notr="true">1</string>
+          </property>
+         </column>
         </widget>
        </item>
        <item>
-        <widget class="Utils::PathChooser" name="sdkPath" native="true"/>
+        <layout class="QVBoxLayout" name="verticalLayout_2">
+         <item>
+          <widget class="QPushButton" name="addNdkButton">
+           <property name="text">
+            <string>Add NDK</string>
+           </property>
+          </widget>
+         </item>
+         <item>
+          <widget class="QPushButton" name="removeNdkButton">
+           <property name="text">
+            <string>Remove NDK</string>
+           </property>
+          </widget>
+         </item>
+        </layout>
        </item>
       </layout>
      </item>
-     <item row="0" column="1">
-      <widget class="QPushButton" name="removeButton">
-       <property name="text">
-        <string>Remove</string>
-       </property>
-      </widget>
-     </item>
-     <item row="1" column="0">
+     <item row="2" column="0">
       <widget class="QTableView" name="ndkInfosTableView"/>
      </item>
     </layout>
    </item>
   </layout>
  </widget>
- <customwidgets>
-  <customwidget>
-   <class>Utils::PathChooser</class>
-   <extends>QWidget</extends>
-   <header location="global">utils/pathchooser.h</header>
-   <container>1</container>
-  </customwidget>
- </customwidgets>
  <resources/>
  <connections/>
 </ui>
diff --git a/src/plugins/qnx/blackberryregisterkeydialog.cpp b/src/plugins/qnx/blackberryregisterkeydialog.cpp
index 64759c2b83dcccd41c58874ae4d0ad993b4595d9..e97d74ba8c21484991c67d7e359eb582e5ed4672 100644
--- a/src/plugins/qnx/blackberryregisterkeydialog.cpp
+++ b/src/plugins/qnx/blackberryregisterkeydialog.cpp
@@ -31,7 +31,7 @@
 
 #include "blackberryregisterkeydialog.h"
 #include "blackberrycsjregistrar.h"
-#include "blackberryconfiguration.h"
+#include "blackberryconfigurationmanager.h"
 #include "blackberrycertificate.h"
 #include "blackberryutils.h"
 #include "ui_blackberryregisterkeydialog.h"
@@ -69,7 +69,7 @@ BlackBerryRegisterKeyDialog::BlackBerryRegisterKeyDialog(QWidget *parent,
 
     m_okButton->setEnabled(false);
 
-    QFileInfo authorP12(BlackBerryConfiguration::instance().defaultKeystorePath());
+    QFileInfo authorP12(BlackBerryConfigurationManager::instance().defaultKeystorePath());
 
     if (authorP12.exists()) {
         m_ui->genCert->setEnabled(false);
@@ -259,8 +259,8 @@ QString BlackBerryRegisterKeyDialog::keystorePassword() const
 QString BlackBerryRegisterKeyDialog::keystorePath() const
 {
     if (m_ui->genCert->isChecked()) {
-        BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
-        return configuration.defaultKeystorePath();
+        BlackBerryConfigurationManager &configManager = BlackBerryConfigurationManager::instance();
+        return configManager.defaultKeystorePath();
     }
 
     return QString();
@@ -283,7 +283,7 @@ void BlackBerryRegisterKeyDialog::generateDeveloperCertificate()
 
 void BlackBerryRegisterKeyDialog::cleanup() const
 {
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+    BlackBerryConfigurationManager &configuration = BlackBerryConfigurationManager::instance();
 
     QFile f(configuration.barsignerCskPath());
     f.remove();
diff --git a/src/plugins/qnx/blackberrysetupwizard.cpp b/src/plugins/qnx/blackberrysetupwizard.cpp
index 0cd040b3b8ba71f066aa09c6d7ff3455d46a33de..c0cd68f7c10e5718d7c45a3d7c19209b3c43b6b1 100644
--- a/src/plugins/qnx/blackberrysetupwizard.cpp
+++ b/src/plugins/qnx/blackberrysetupwizard.cpp
@@ -34,7 +34,7 @@
 #include "blackberrydeviceconfiguration.h"
 #include "blackberrycsjregistrar.h"
 #include "blackberrycertificate.h"
-#include "blackberryconfiguration.h"
+#include "blackberryconfigurationmanager.h"
 #include "blackberrydebugtokenrequester.h"
 #include "blackberrydebugtokenuploader.h"
 #include "blackberrydeviceinformation.h"
@@ -185,8 +185,8 @@ void BlackBerrySetupWizard::certificateCreated(int status)
         return;
     }
 
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
-    configuration.addCertificate(m_certificate);
+    BlackBerryConfigurationManager &configManager = BlackBerryConfigurationManager::instance();
+    configManager.addCertificate(m_certificate);
 
     emit stepFinished();
 }
@@ -297,7 +297,7 @@ void BlackBerrySetupWizard::setBusy(bool busy)
 
 void BlackBerrySetupWizard::cleanupFiles() const
 {
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+    BlackBerryConfigurationManager &configuration = BlackBerryConfigurationManager::instance();
 
     QFile f(configuration.barsignerCskPath());
     f.remove();
@@ -327,7 +327,7 @@ void BlackBerrySetupWizard::reset()
     m_currentStep = -1;
 
     if (m_certificate) {
-        BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+        BlackBerryConfigurationManager &configuration = BlackBerryConfigurationManager::instance();
         configuration.removeCertificate(m_certificate);
         m_certificate = 0;
     }
@@ -353,7 +353,7 @@ void BlackBerrySetupWizard::createKeys()
 
 void BlackBerrySetupWizard::generateDeveloperCertificate()
 {
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+    BlackBerryConfigurationManager &configuration = BlackBerryConfigurationManager::instance();
 
     m_certificate = new BlackBerryCertificate(configuration.defaultKeystorePath(),
             BlackBerryUtils::getCsjAuthor(rdkPath()), password());
@@ -430,7 +430,7 @@ void BlackBerrySetupWizard::requestDebugToken()
         return;
     }
 
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+    BlackBerryConfigurationManager &configuration = BlackBerryConfigurationManager::instance();
 
     m_requester->requestDebugToken(configuration.defaultDebugTokenPath(),
             password(), configuration.defaultKeystorePath(), password(), m_devicePin);
@@ -443,7 +443,7 @@ void BlackBerrySetupWizard::uploadDebugToken()
         return;
     }
 
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+    BlackBerryConfigurationManager &configuration = BlackBerryConfigurationManager::instance();
 
     m_uploader->uploadDebugToken(configuration.defaultDebugTokenPath(),
             hostName(), devicePassword());
@@ -530,7 +530,7 @@ IDevice::Ptr BlackBerrySetupWizard::device()
             deviceName(), Core::Id(Constants::QNX_BB_OS_TYPE), machineType);
 
     configuration->setSshParameters(sshParams);
-    configuration->setDebugToken(BlackBerryConfiguration::instance().defaultDebugTokenPath());
+    configuration->setDebugToken(BlackBerryConfigurationManager::instance().defaultDebugTokenPath());
 
     return configuration;
 }
diff --git a/src/plugins/qnx/blackberrysetupwizardpages.cpp b/src/plugins/qnx/blackberrysetupwizardpages.cpp
index bc823b206afe12e972a837acb25c80ef89325642..ce42e93e006753357b6342d286c3823831c082f5 100644
--- a/src/plugins/qnx/blackberrysetupwizardpages.cpp
+++ b/src/plugins/qnx/blackberrysetupwizardpages.cpp
@@ -83,9 +83,8 @@ BlackBerrySetupWizardNdkPage::BlackBerrySetupWizardNdkPage(QWidget *parent) :
 
     m_widget = new BlackBerryNDKSettingsWidget(this);
     m_widget->setWizardMessageVisible(false);
-    m_widget->setRemoveButtonVisible(false);
 
-    connect(m_widget, SIGNAL(sdkPathChanged(QString)), this, SIGNAL(completeChanged()));
+    connect(m_widget, SIGNAL(kitsUpdated()), this, SIGNAL(completeChanged()));
 
     QVBoxLayout *layout = new QVBoxLayout;
     layout->addWidget(m_widget);
@@ -99,7 +98,7 @@ BlackBerrySetupWizardNdkPage::~BlackBerrySetupWizardNdkPage()
 
 bool BlackBerrySetupWizardNdkPage::isComplete() const
 {
-    return m_widget->hasValidSdkPath();
+    return m_widget->hasActiveNdk();
 }
 
 //-----------------------------------------------------------------------------
diff --git a/src/plugins/qnx/blackberryutils.cpp b/src/plugins/qnx/blackberryutils.cpp
index dd85493c44087762076a828d5b72ff6e50895731..3693bec2cf9bdf156500035ac535a2bf244f4200 100644
--- a/src/plugins/qnx/blackberryutils.cpp
+++ b/src/plugins/qnx/blackberryutils.cpp
@@ -31,6 +31,7 @@
 
 #include "blackberryutils.h"
 #include "blackberryconfiguration.h"
+#include "blackberryconfigurationmanager.h"
 
 #include <QFileInfo>
 #include <QString>
@@ -41,7 +42,7 @@ using namespace Qnx::Internal;
 
 bool BlackBerryUtils::hasRegisteredKeys()
 {
-    BlackBerryConfiguration &configuration = BlackBerryConfiguration::instance();
+    BlackBerryConfigurationManager &configuration = BlackBerryConfigurationManager::instance();
 
     QFileInfo cskFile(configuration.barsignerCskPath());
 
diff --git a/src/plugins/qnx/qnx.pro b/src/plugins/qnx/qnx.pro
index 16f02fa6f29dae0cd296151fb4933587cf23015b..f138a91270b05f25b87e963ec5921052de18fba9 100644
--- a/src/plugins/qnx/qnx.pro
+++ b/src/plugins/qnx/qnx.pro
@@ -93,7 +93,8 @@ SOURCES += qnxplugin.cpp \
     blackberrysetupwizard.cpp \
     blackberrysetupwizardpages.cpp \
     blackberryutils.cpp \
-    qnxdevicetester.cpp
+    qnxdevicetester.cpp \
+    blackberryconfigurationmanager.cpp
 
 HEADERS += qnxplugin.h\
     qnxconstants.h \
@@ -186,7 +187,8 @@ HEADERS += qnxplugin.h\
     blackberrysetupwizard.h \
     blackberrysetupwizardpages.h \
     blackberryutils.h \
-    qnxdevicetester.h
+    qnxdevicetester.h \
+    blackberryconfigurationmanager.h
 
 FORMS += \
     blackberrydeviceconfigurationwizardsetuppage.ui \
diff --git a/src/plugins/qnx/qnxplugin.cpp b/src/plugins/qnx/qnxplugin.cpp
index 12cf97ebc988f9470710e36b6a5ae7116f9b29ca..019c4412bff4c6f8958204c92f20ff40214bdd99 100644
--- a/src/plugins/qnx/qnxplugin.cpp
+++ b/src/plugins/qnx/qnxplugin.cpp
@@ -51,11 +51,13 @@
 #include "blackberrykeyspage.h"
 #include "blackberrycheckdevmodestepfactory.h"
 #include "blackberrydeviceconnectionmanager.h"
+#include "blackberryconfigurationmanager.h"
 
 #include <coreplugin/icore.h>
 #include <coreplugin/mimedatabase.h>
 #include <projectexplorer/projectexplorer.h>
 #include <projectexplorer/taskhub.h>
+#include <projectexplorer/kitmanager.h>
 
 #include <QtPlugin>
 
@@ -68,6 +70,7 @@ QNXPlugin::QNXPlugin()
 QNXPlugin::~QNXPlugin()
 {
     delete BlackBerryDeviceConnectionManager::instance();
+    delete &BlackBerryConfigurationManager::instance();
 }
 
 bool QNXPlugin::initialize(const QStringList &arguments, QString *errorString)
@@ -111,6 +114,8 @@ bool QNXPlugin::initialize(const QStringList &arguments, QString *errorString)
     }
     addAutoReleasedObject(new BarDescriptorEditorFactory);
 
+    connect(ProjectExplorer::KitManager::instance(), SIGNAL(kitsLoaded()), &BlackBerryConfigurationManager::instance(), SLOT(loadSettings()));
+
     return true;
 }
 
diff --git a/src/plugins/qnx/qnxutils.cpp b/src/plugins/qnx/qnxutils.cpp
index 2da2c9bc1972ebbe86d40a3da92f7b3043fbad09..0c7de30c438a4eae8e848e4e2bc7f2c0e6ac674c 100644
--- a/src/plugins/qnx/qnxutils.cpp
+++ b/src/plugins/qnx/qnxutils.cpp
@@ -262,9 +262,20 @@ QString QnxUtils::qConfigPath()
 
 QString QnxUtils::ndkVersion(const QString &ndkPath)
 {
+    foreach (const NdkInstallInformation &ndkInfo, installedNdks()) {
+        if (!ndkInfo.path.compare(ndkPath, Utils::HostOsInfo::fileNameCaseSensitivity()))
+            return ndkInfo.version;
+    }
+
+    return QString();
+}
+
+QList<NdkInstallInformation> QnxUtils::installedNdks()
+{
+    QList<NdkInstallInformation> ndkList;
     QString ndkConfigPath = qConfigPath();
     if (!QDir(ndkConfigPath).exists())
-        return QString();
+        return ndkList;
 
     QFileInfoList ndkfileList = QDir(ndkConfigPath).entryInfoList(QStringList() << QLatin1String("*.xml"),
                                                                   QDir::Files, QDir::Time);
@@ -285,11 +296,16 @@ QString QnxUtils::ndkVersion(const QString &ndkPath)
         // The file contains only one installation node
         if (!childElt.isNull()) {
             // The file contains only one base node
-            QDomElement elt = childElt.firstChildElement(QLatin1String("base"));
-            if (!elt.text().compare(ndkPath, Utils::HostOsInfo::fileNameCaseSensitivity()))
-                return childElt.firstChildElement(QLatin1String("version")).text();
+            NdkInstallInformation ndkInfo;
+            ndkInfo.path = childElt.firstChildElement(QLatin1String("base")).text();
+            ndkInfo.name = childElt.firstChildElement(QLatin1String("name")).text();
+            ndkInfo.host = childElt.firstChildElement(QLatin1String("host")).text();
+            ndkInfo.target = childElt.firstChildElement(QLatin1String("target")).text();
+            ndkInfo.version = childElt.firstChildElement(QLatin1String("version")).text();
+
+            ndkList.append(ndkInfo);
         }
     }
 
-    return QString();
+    return ndkList;
 }
diff --git a/src/plugins/qnx/qnxutils.h b/src/plugins/qnx/qnxutils.h
index f12518fd31236e61861e039834e1cf35ffe47dd6..6f094cd2366e59cf70ad101f005e542b13ee9c8b 100644
--- a/src/plugins/qnx/qnxutils.h
+++ b/src/plugins/qnx/qnxutils.h
@@ -46,6 +46,16 @@ namespace Internal {
 
 class QnxAbstractQtVersion;
 
+class NdkInstallInformation
+{
+public:
+    QString path;
+    QString name;
+    QString host;
+    QString target;
+    QString version;
+};
+
 class QnxUtils
 {
 public:
@@ -60,6 +70,7 @@ public:
     static QString dataDirPath();
     static QString qConfigPath();
     static QString ndkVersion(const QString& ndkPath);
+    static QList<NdkInstallInformation> installedNdks();
 };
 
 } // namespace Internal