diff --git a/src/libtomahawk/infosystem/infosystem.cpp b/src/libtomahawk/infosystem/infosystem.cpp
index c2e3f83bb..48ed2bb26 100644
--- a/src/libtomahawk/infosystem/infosystem.cpp
+++ b/src/libtomahawk/infosystem/infosystem.cpp
@@ -60,80 +60,87 @@ InfoSystem::InfoSystem(QObject *parent)
     qDebug() << Q_FUNC_INFO;
 
     m_infoSystemCacheThreadController = new QThread( this );
-    m_cache = new InfoSystemCache();
-    m_cache->moveToThread( m_infoSystemCacheThreadController );
+    m_cache = QWeakPointer< InfoSystemCache >( new InfoSystemCache() );
+    m_cache.data()->moveToThread( m_infoSystemCacheThreadController );
     m_infoSystemCacheThreadController->start( QThread::IdlePriority );
 
     m_infoSystemWorkerThreadController = new QThread( this );
-    m_worker = new InfoSystemWorker();
-    m_worker->moveToThread( m_infoSystemWorkerThreadController );
+    m_worker = QWeakPointer< InfoSystemWorker>( new InfoSystemWorker() );
+    m_worker.data()->moveToThread( m_infoSystemWorkerThreadController );
     m_infoSystemWorkerThreadController->start();
 
-    QMetaObject::invokeMethod( m_worker, "init", Qt::QueuedConnection );
+    QMetaObject::invokeMethod( m_worker.data(), "init", Qt::QueuedConnection, Q_ARG( QWeakPointer< Tomahawk::InfoSystem::InfoSystemCache >, m_cache ) );
 
     connect( TomahawkSettings::instance(), SIGNAL( changed() ), SLOT( newNam() ) );
 
-    connect( m_cache, SIGNAL( info( QString, Tomahawk::InfoSystem::InfoType, QVariant, QVariant, Tomahawk::InfoSystem::InfoCustomData ) ),
+    connect( m_cache.data(), SIGNAL( info( QString, Tomahawk::InfoSystem::InfoType, QVariant, QVariant, Tomahawk::InfoSystem::InfoCustomData ) ),
             this,       SLOT( infoSlot( QString, Tomahawk::InfoSystem::InfoType, QVariant, QVariant, Tomahawk::InfoSystem::InfoCustomData ) ), Qt::UniqueConnection );
 
-    connect( m_worker, SIGNAL( info( QString, Tomahawk::InfoSystem::InfoType, QVariant, QVariant, Tomahawk::InfoSystem::InfoCustomData ) ),
+    connect( m_worker.data(), SIGNAL( info( QString, Tomahawk::InfoSystem::InfoType, QVariant, QVariant, Tomahawk::InfoSystem::InfoCustomData ) ),
             this,       SLOT( infoSlot( QString, Tomahawk::InfoSystem::InfoType, QVariant, QVariant, Tomahawk::InfoSystem::InfoCustomData ) ), Qt::UniqueConnection );
 }
 
 InfoSystem::~InfoSystem()
 {
     qDebug() << Q_FUNC_INFO << " beginning";
-
-    if ( m_infoSystemWorkerThreadController )
-        m_infoSystemWorkerThreadController->quit();
-
-    qDebug() << Q_FUNC_INFO << " sent quit signals";
-
-    if( m_infoSystemWorkerThreadController )
+    qDebug() << "THREAD I'M RUNNING IN: " << QThread::currentThread();
+    
+    if ( !m_worker.isNull() )
     {
-        while( !m_infoSystemWorkerThreadController->isFinished() )
+        QMetaObject::invokeMethod( m_worker.data(), "deleteLater", Qt::QueuedConnection );
+        while( !m_worker.isNull() )
         {
-            qDebug() << Q_FUNC_INFO << " worker thread controller not finished, processing events";
+            qDebug() << Q_FUNC_INFO << " worker not deleted, processing events";
             QCoreApplication::processEvents( QEventLoop::AllEvents, 200 );
             TomahawkUtils::Sleep::msleep( 100 );
         }
 
-        qDebug() << Q_FUNC_INFO << " worker is finished, deleting worker";
-        if( m_worker )
-        {
-            qDebug() << "THREAD I'M RUNNING IN: " << QThread::currentThread();
-            delete m_worker;
-            m_worker = 0;
-        }
+        if ( m_infoSystemWorkerThreadController )
+            m_infoSystemWorkerThreadController->quit();
 
-        qDebug() << Q_FUNC_INFO << " worker finished being deleted";
-        delete m_infoSystemWorkerThreadController;
-        m_infoSystemWorkerThreadController = 0;
+        if( m_infoSystemWorkerThreadController )
+        {
+            while( !m_infoSystemWorkerThreadController->isFinished() )
+            {
+                qDebug() << Q_FUNC_INFO << " worker thread controller not finished, processing events";
+                QCoreApplication::processEvents( QEventLoop::AllEvents, 200 );
+                TomahawkUtils::Sleep::msleep( 100 );
+            }
+            
+            delete m_infoSystemWorkerThreadController;
+            m_infoSystemWorkerThreadController = 0;
+        }
     }
 
     qDebug() << Q_FUNC_INFO << " done deleting worker";
 
-    if ( m_infoSystemCacheThreadController )
-        m_infoSystemCacheThreadController->quit();
-    
-    if( m_infoSystemCacheThreadController )
+    if ( !m_cache.isNull() )
     {
-        while( !m_infoSystemCacheThreadController->isFinished() )
+        QMetaObject::invokeMethod( m_cache.data(), "deleteLater", Qt::QueuedConnection );
+        while( !m_cache.isNull() )
         {
-            qDebug() << Q_FUNC_INFO << " cache thread controller not finished, processing events";
+            qDebug() << Q_FUNC_INFO << " worker not deleted, processing events";
             QCoreApplication::processEvents( QEventLoop::AllEvents, 200 );
             TomahawkUtils::Sleep::msleep( 100 );
         }
-
-        if( m_cache )
+        
+        if ( m_infoSystemCacheThreadController )
+            m_infoSystemCacheThreadController->quit();
+        
+        if( m_infoSystemCacheThreadController )
         {
-            delete m_cache;
-            m_cache = 0;
+            while( !m_infoSystemCacheThreadController->isFinished() )
+            {
+                qDebug() << Q_FUNC_INFO << " worker thread controller not finished, processing events";
+                QCoreApplication::processEvents( QEventLoop::AllEvents, 200 );
+                TomahawkUtils::Sleep::msleep( 100 );
+            }
+            
+            delete m_infoSystemCacheThreadController;
+            m_infoSystemCacheThreadController = 0;
         }
-
-        delete m_infoSystemCacheThreadController;
-        m_infoSystemCacheThreadController = 0;
     }
+    
     qDebug() << Q_FUNC_INFO << " done deleting cache";
 }
 
@@ -142,7 +149,7 @@ void
 InfoSystem::newNam() const
 {
     qDebug() << Q_FUNC_INFO;
-    QMetaObject::invokeMethod( m_worker, "newNam", Qt::QueuedConnection );
+    QMetaObject::invokeMethod( m_worker.data(), "newNam", Qt::QueuedConnection );
 }
 
 
@@ -153,7 +160,7 @@ InfoSystem::getInfo( const QString &caller, const InfoType type, const QVariant&
 
     m_dataTracker[caller][type] = m_dataTracker[caller][type] + 1;
     qDebug() << "current count in dataTracker for type" << type << "is" << m_dataTracker[caller][type];
-    QMetaObject::invokeMethod( m_worker, "getInfo", Qt::QueuedConnection, Q_ARG( QString, caller ), Q_ARG( Tomahawk::InfoSystem::InfoType, type ), Q_ARG( QVariant, input ), Q_ARG( Tomahawk::InfoSystem::InfoCustomData, customData ) );
+    QMetaObject::invokeMethod( m_worker.data(), "getInfo", Qt::QueuedConnection, Q_ARG( QString, caller ), Q_ARG( Tomahawk::InfoSystem::InfoType, type ), Q_ARG( QVariant, input ), Q_ARG( Tomahawk::InfoSystem::InfoCustomData, customData ) );
 }
 
 
@@ -170,7 +177,7 @@ InfoSystem::pushInfo( const QString &caller, const InfoType type, const QVariant
 {
     qDebug() << Q_FUNC_INFO;
 
-    QMetaObject::invokeMethod( m_worker, "pushInfo", Qt::QueuedConnection, Q_ARG( QString, caller ), Q_ARG( Tomahawk::InfoSystem::InfoType, type ), Q_ARG( QVariant, input ) );
+    QMetaObject::invokeMethod( m_worker.data(), "pushInfo", Qt::QueuedConnection, Q_ARG( QString, caller ), Q_ARG( Tomahawk::InfoSystem::InfoType, type ), Q_ARG( QVariant, input ) );
 }
 
 
diff --git a/src/libtomahawk/infosystem/infosystem.h b/src/libtomahawk/infosystem/infosystem.h
index 537dbe9dd..9746521d1 100644
--- a/src/libtomahawk/infosystem/infosystem.h
+++ b/src/libtomahawk/infosystem/infosystem.h
@@ -153,8 +153,6 @@ public:
     void pushInfo( const QString &caller, const InfoType type, const QVariant &input );
     void pushInfo( const QString &caller, const InfoMap &input );
 
-    InfoSystemCache* getCache() const { return m_cache; }
-
 signals:
     void info( QString caller, Tomahawk::InfoSystem::InfoType, QVariant input, QVariant output, Tomahawk::InfoSystem::InfoCustomData customData );
     void finished( QString target );
@@ -167,8 +165,8 @@ public slots:
 private:
     QHash< QString, QHash< InfoType, int > > m_dataTracker;
 
-    InfoSystemCache* m_cache;
-    InfoSystemWorker* m_worker;
+    QWeakPointer< InfoSystemCache > m_cache;
+    QWeakPointer< InfoSystemWorker > m_worker;
     QThread* m_infoSystemCacheThreadController;
     QThread* m_infoSystemWorkerThreadController;
 
@@ -200,5 +198,6 @@ inline uint qHash( Tomahawk::InfoSystem::InfoCriteriaHash hash )
 Q_DECLARE_METATYPE( Tomahawk::InfoSystem::InfoGenericMap );
 Q_DECLARE_METATYPE( Tomahawk::InfoSystem::InfoCustomData );
 Q_DECLARE_METATYPE( Tomahawk::InfoSystem::InfoCriteriaHash );
+Q_DECLARE_METATYPE( QWeakPointer< Tomahawk::InfoSystem::InfoSystemCache > );
 
 #endif // TOMAHAWK_INFOSYSTEM_H
diff --git a/src/libtomahawk/infosystem/infosystemworker.cpp b/src/libtomahawk/infosystem/infosystemworker.cpp
index 2db0df12b..45563871f 100644
--- a/src/libtomahawk/infosystem/infosystemworker.cpp
+++ b/src/libtomahawk/infosystem/infosystemworker.cpp
@@ -54,8 +54,10 @@ InfoSystemWorker::~InfoSystemWorker()
 }
 
 
-void InfoSystemWorker::init()
+void
+InfoSystemWorker::init( QWeakPointer< Tomahawk::InfoSystem::InfoSystemCache> cache )
 {
+    qDebug() << Q_FUNC_INFO << " and cache is " << cache.data();
     InfoPluginPtr enptr( new EchoNestPlugin() );
     m_plugins.append( enptr );
     registerInfoTypes( enptr, enptr.data()->supportedGetTypes(), enptr.data()->supportedPushTypes() );
@@ -66,8 +68,6 @@ void InfoSystemWorker::init()
     m_plugins.append( lfmptr );
     registerInfoTypes( lfmptr, lfmptr.data()->supportedGetTypes(), lfmptr.data()->supportedPushTypes() );
 
-    InfoSystemCache *cache = InfoSystem::instance()->getCache();
-    
     Q_FOREACH( InfoPluginPtr plugin, m_plugins )
     {
         connect(
@@ -81,11 +81,11 @@ void InfoSystemWorker::init()
         connect(
                 plugin.data(),
                 SIGNAL( getCachedInfo( Tomahawk::InfoSystem::InfoCriteriaHash, qint64, QString, Tomahawk::InfoSystem::InfoType, QVariant, Tomahawk::InfoSystem::InfoCustomData ) ),
-                cache,
+                cache.data(),
                 SLOT( getCachedInfoSlot( Tomahawk::InfoSystem::InfoCriteriaHash, qint64, QString, Tomahawk::InfoSystem::InfoType, QVariant, Tomahawk::InfoSystem::InfoCustomData ) )
             );
         connect(
-                cache,
+                cache.data(),
                 SIGNAL( notInCache( Tomahawk::InfoSystem::InfoCriteriaHash, QString, Tomahawk::InfoSystem::InfoType, QVariant, Tomahawk::InfoSystem::InfoCustomData ) ),
                 plugin.data(),
                 SLOT( notInCacheSlot( Tomahawk::InfoSystem::InfoCriteriaHash, QString, Tomahawk::InfoSystem::InfoType, QVariant, Tomahawk::InfoSystem::InfoCustomData ) )
@@ -93,7 +93,7 @@ void InfoSystemWorker::init()
         connect(
                 plugin.data(),
                 SIGNAL( updateCache( Tomahawk::InfoSystem::InfoCriteriaHash, qint64, Tomahawk::InfoSystem::InfoType, QVariant ) ),
-                cache,
+                cache.data(),
                 SLOT( updateCacheSlot( Tomahawk::InfoSystem::InfoCriteriaHash, qint64, Tomahawk::InfoSystem::InfoType, QVariant ) )
             );
         connect(
diff --git a/src/libtomahawk/infosystem/infosystemworker.h b/src/libtomahawk/infosystem/infosystemworker.h
index 536df8698..c7f4ada6d 100644
--- a/src/libtomahawk/infosystem/infosystemworker.h
+++ b/src/libtomahawk/infosystem/infosystemworker.h
@@ -52,7 +52,7 @@ signals:
     void namChanged( QNetworkAccessManager* );
 
 public slots:
-    void init();
+    void init( QWeakPointer< Tomahawk::InfoSystem::InfoSystemCache > cache );
     void getInfo( const QString caller, const Tomahawk::InfoSystem::InfoType type, const QVariant input, const Tomahawk::InfoSystem::InfoCustomData customData );
     void pushInfo( const QString caller, const Tomahawk::InfoSystem::InfoType type, const QVariant input );
     void newNam();
diff --git a/src/tomahawkapp.cpp b/src/tomahawkapp.cpp
index 93e942843..d4c8e0947 100644
--- a/src/tomahawkapp.cpp
+++ b/src/tomahawkapp.cpp
@@ -375,6 +375,7 @@ TomahawkApp::registerMetaTypes()
     qRegisterMetaType< QHash< QString, QVariant > >( "Tomahawk::InfoSystem::InfoCustomData" );
     qRegisterMetaType< QHash< QString, QString > >( "Tomahawk::InfoSystem::InfoCriteriaHash" );
     qRegisterMetaType< Tomahawk::InfoSystem::InfoType >( "Tomahawk::InfoSystem::InfoType" );
+    qRegisterMetaType< QWeakPointer< Tomahawk::InfoSystem::InfoSystemCache > >( "QWeakPointer< Tomahawk::InfoSystem::InfoSystemCache >" );
 }