diff --git a/src/plugins/debugger/debuggerkitconfigwidget.cpp b/src/plugins/debugger/debuggerkitconfigwidget.cpp
index d3ec750b6b65542a38f82de9a8d996810c3f3532..0df34d0f55ca1461f307b27bb87e5ab6be1ed099 100644
--- a/src/plugins/debugger/debuggerkitconfigwidget.cpp
+++ b/src/plugins/debugger/debuggerkitconfigwidget.cpp
@@ -159,26 +159,6 @@ void DebuggerItem::fromMap(const QVariantMap &data)
         if (abi.isValid())
             abis.append(abi);
     }
-
-//    // Check for special 'auto' entry for binary written by the sdktool during
-//    // installation. Try to autodetect.
-//    if (command == QLatin1String("auto")) {
-//        command.clear();
-//        switch (engineType) {
-//        case Debugger::GdbEngineType: // Auto-detect system gdb on Unix
-//            if (Abi::hostAbi().os() != Abi::WindowsOS)
-//                comman = Environment::systemEnvironment().searchInPath(QLatin1String("gdb"));
-//            break;
-//        case Debugger::CdbEngineType: { // Auto-detect system CDB on Windows.
-//             const QPair<QString, QString> cdbs = autoDetectCdbDebugger();
-//             binary = cdbs.second.isEmpty() ? cdbs.first : cdbs.second;
-//        }
-//            break;
-//        default:
-//            break;
-//        }
-//    }
-//    command = FileName::fromString(binary);
 }
 
 QString DebuggerItem::userOutput() const
@@ -330,16 +310,32 @@ DebuggerItem DebuggerKitInformation::debuggerItem(const ProjectExplorer::Kit *k)
     if (!k)
         return DebuggerItem();
 
+    // We used to have:
+    // <valuemap type="QVariantMap" key="Debugger.Information">
+    //    <value type="QString" key="Binary">/data/dev/debugger/gdb-git/gdb/gdb</value>
+    //    <value type="int" key="EngineType">1</value>
+    //  </valuemap>
+    // Starting with 3.0 we have:
+    // <value type="QString" key="Debugger.Information">{75ecf347-f221-44c3-b613-ea1d29929cd4}</value>
+
     QVariant id = k->value(DEBUGGER_INFORMATION);
-    if (!id.isValid())
-        return DebuggerItem();
 
-    DebuggerItem *item = DebuggerItemManager::debuggerFromId(id);
+    QString pathOrUid;
+    if (id.type() == QVariant::Map) // 2.x
+        pathOrUid = id.toMap().value(QLatin1String("Binary")).toString();
+    else if (id.type() == QVariant::String) // 3.x
+        pathOrUid = id.toString();
+
+    DebuggerItem *item;
+    if (pathOrUid.startsWith(QLatin1Char('{')))
+        item = DebuggerItemManager::debuggerFromId(id);
+    else
+        item = DebuggerItemManager::debuggerFromPath(pathOrUid);
+
     QTC_ASSERT(item, return DebuggerItem());
     return *item;
 }
 
-
 void DebuggerKitInformation::setDebuggerItem(Kit *k,
     DebuggerEngineType type, const Utils::FileName &command)
 {
@@ -741,6 +737,14 @@ DebuggerItem *DebuggerItemManager::debuggerFromId(const QVariant &id)
     return 0;
 }
 
+DebuggerItem *DebuggerItemManager::debuggerFromPath(const QString &path)
+{
+    foreach (DebuggerItem *item, theDebuggerItemManager()->m_debuggers)
+        if (item->command.toString() == path)
+            return item;
+    return 0;
+}
+
 QModelIndex DebuggerItemManager::currentIndex() const
 {
     QStandardItem *current = m_itemFromDebugger.value(m_currentDebugger);
diff --git a/src/plugins/debugger/debuggerkitconfigwidget.h b/src/plugins/debugger/debuggerkitconfigwidget.h
index 72503393cbd538ca76a2a1fb75c6026497c3f1d0..fa93c34068a9b3d23cdcf4750cb980a708cb5ad5 100644
--- a/src/plugins/debugger/debuggerkitconfigwidget.h
+++ b/src/plugins/debugger/debuggerkitconfigwidget.h
@@ -71,6 +71,7 @@ public:
     QList<DebuggerItem *> findDebuggers(const ProjectExplorer::Abi &abi) const;
     DebuggerItem *currentDebugger() const { return m_currentDebugger; }
     static DebuggerItem *debuggerFromId(const QVariant &id);
+    static DebuggerItem *debuggerFromPath(const QString &path);
     QModelIndex currentIndex() const;
     void setCurrentIndex(const QModelIndex &index);