diff options
Diffstat (limited to 'rbutil/rbutilqt')
-rw-r--r-- | rbutil/rbutilqt/base/bootloaderinstallbase.cpp | 7 | ||||
-rw-r--r-- | rbutil/rbutilqt/base/bootloaderinstallmpio.cpp | 140 | ||||
-rw-r--r-- | rbutil/rbutilqt/base/bootloaderinstallmpio.h | 43 | ||||
-rw-r--r-- | rbutil/rbutilqt/rbutil.ini | 14 | ||||
-rw-r--r-- | rbutil/rbutilqt/rbutilqt.cpp | 2 | ||||
-rw-r--r-- | rbutil/rbutilqt/rbutilqt.pri | 2 | ||||
-rw-r--r-- | rbutil/rbutilqt/rbutilqt.pro | 9 |
7 files changed, 211 insertions, 6 deletions
diff --git a/rbutil/rbutilqt/base/bootloaderinstallbase.cpp b/rbutil/rbutilqt/base/bootloaderinstallbase.cpp index 3a94180aab..cf8b9e12fd 100644 --- a/rbutil/rbutilqt/base/bootloaderinstallbase.cpp +++ b/rbutil/rbutilqt/base/bootloaderinstallbase.cpp @@ -29,6 +29,7 @@ #include "bootloaderinstallchinachip.h" #include "bootloaderinstallams.h" #include "bootloaderinstalltcc.h" +#include "bootloaderinstallmpio.h" #include "utils.h" #if defined(Q_OS_MACX) @@ -64,6 +65,9 @@ BootloaderInstallBase* BootloaderInstallBase::createBootloaderInstaller(QObject* else if(type == "tcc") { return new BootloaderInstallTcc(parent); } + else if(type == "mpio") { + return new BootloaderInstallMpio(parent); + } else { return NULL; } @@ -212,7 +216,7 @@ QString BootloaderInstallBase::postinstallHints(QString model) "<li>After the firmware has been updated reboot your player.</li>"); } if(model == "iaudiox5" || model == "iaudiom5" - || model == "iaudiox5v" || model == "iaudiom3") { + || model == "iaudiox5v" || model == "iaudiom3" || model == "mpioh200") { hint = true; msg += tr("<li>Turn the player off</li>" "<li>Insert the charger</li>"); @@ -224,7 +228,6 @@ QString BootloaderInstallBase::postinstallHints(QString model) "<li>Toggle the battery switch on the player</li>" "<li>Hold <i>Power</i> to boot into Rockbox</li>"); } - msg += "</ol>"; msg += tr("<p><b>Note:</b> You can safely install other parts first, but " "the above steps are <b>required</b> to finish the installation!</p>"); diff --git a/rbutil/rbutilqt/base/bootloaderinstallmpio.cpp b/rbutil/rbutilqt/base/bootloaderinstallmpio.cpp new file mode 100644 index 0000000000..d6db46f0ae --- /dev/null +++ b/rbutil/rbutilqt/base/bootloaderinstallmpio.cpp @@ -0,0 +1,140 @@ +/*************************************************************************** + * __________ __ ___. + * Open \______ \ ____ ____ | | _\_ |__ _______ ___ + * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / + * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < + * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ + * \/ \/ \/ \/ \/ + * + * Copyright (C) 2008 by Dominik Wenger + * $Id: bootloaderinstallams.cpp 24778 2010-02-19 23:45:29Z funman $ + * + * All files in this archive are subject to the GNU General Public License. + * See the file COPYING in the source tree root for full license agreement. + * + * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY + * KIND, either express or implied. + * + ****************************************************************************/ + +#include <QtCore> +#include "bootloaderinstallbase.h" +#include "bootloaderinstallmpio.h" + +#include "../mkmpioboot/mkmpioboot.h" + +BootloaderInstallMpio::BootloaderInstallMpio(QObject *parent) + : BootloaderInstallBase(parent) +{ +} + +QString BootloaderInstallMpio::ofHint() +{ + return tr("Bootloader installation requires you to provide " + "a firmware file of the original firmware (bin file). " + "You need to download this file yourself due to legal " + "reasons. Please refer to the " + "<a href='http://www.rockbox.org/manual.shtml'>manual</a> and " + "the <a href='http://www.rockbox.org/wiki/MPIOHD200Port'>MPIOHD200Port</a> " + "wiki page on how to obtain this file.<br/>" + "Press Ok to continue and browse your computer for the firmware " + "file."); +} + +bool BootloaderInstallMpio::install(void) +{ + if(m_offile.isEmpty()) + return false; + + qDebug() << "[BootloaderInstallMpio] installing bootloader"; + + // download firmware from server + emit logItem(tr("Downloading bootloader file"), LOGINFO); + + connect(this, SIGNAL(downloadDone()), this, SLOT(installStage2())); + downloadBlStart(m_blurl); + + return true; +} + +void BootloaderInstallMpio::installStage2(void) +{ + qDebug() << "[BootloaderInstallMpio] installStage2"; + + int origin = 0xe0000; /* MPIO HD200 bootloader address */ + + m_tempfile.open(); + QString bootfile = m_tempfile.fileName(); + m_tempfile.close(); + + int ret = mkmpioboot(m_offile.toLocal8Bit().data(), bootfile.toLocal8Bit().data(), m_blfile.toLocal8Bit().data(), origin); + + if(ret != 0) + { + QString error; + switch(ret) + { + case -1: + error = tr("Could not open the original firmware."); + break; + case -2: + error = tr("Could not read the original firmware."); + break; + case -3: + error = tr("Loaded firmware file does not look like MPIO OF file."); + break; + case -4: + error = tr("Could not open downloaded bootloader."); + break; + case -5: + error = tr("Place for bootloader in OF file not empty."); + break; + case -6: + error = tr("Could not read the downloaded bootloader."); + break; + case -7: + error = tr("Bootloader checksum error."); + break; + case -8: + error = tr("Could not open outputfile."); + break; + case -9: + error = tr("Could not write outputfile."); + break; + default: + error = tr("Unknown errornumber: %1").arg(ret); + break; + } + + qDebug() << tr("Patching original firmware failed: %1").arg(error); + emit logItem(tr("Patching original firmware failed: %1").arg(error), LOGERROR); + emit done(true); + return; + } + + //end of install + qDebug() << "[BootloaderInstallMpio] install successfull"; + emit logItem(tr("Success: modified firmware file created"), LOGINFO); + logInstall(LogAdd); + emit done(false); + return; +} + +bool BootloaderInstallMpio::uninstall(void) +{ + emit logItem(tr("To uninstall, perform a normal upgrade with an unmodified " + "original firmware"), LOGINFO); + logInstall(LogRemove); + return false; +} + +BootloaderInstallBase::BootloaderType BootloaderInstallMpio::installed(void) +{ + return BootloaderUnknown; +} + +BootloaderInstallBase::Capabilities BootloaderInstallMpio::capabilities(void) +{ + return (Install | NeedsOf); +} + diff --git a/rbutil/rbutilqt/base/bootloaderinstallmpio.h b/rbutil/rbutilqt/base/bootloaderinstallmpio.h new file mode 100644 index 0000000000..8e6c65affe --- /dev/null +++ b/rbutil/rbutilqt/base/bootloaderinstallmpio.h @@ -0,0 +1,43 @@ +/*************************************************************************** + * __________ __ ___. + * Open \______ \ ____ ____ | | _\_ |__ _______ ___ + * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / + * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < + * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ + * \/ \/ \/ \/ \/ + * + * Copyright (C) 2008 by Dominik Wenger + * $Id: bootloaderinstallams.h 22317 2009-08-15 13:04:21Z Domonoky $ + * + * All files in this archive are subject to the GNU General Public License. + * See the file COPYING in the source tree root for full license agreement. + * + * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY + * KIND, either express or implied. + * + ****************************************************************************/ +#ifndef BOOTLOADERINSTALLMPIO_H +#define BOOTLOADERINSTALLMPIO_H + +#include <QtCore> +#include "bootloaderinstallbase.h" + +//! bootloader installation derivate based on mkmpioboot +class BootloaderInstallMpio : public BootloaderInstallBase +{ + Q_OBJECT + public: + BootloaderInstallMpio(QObject *parent); + bool install(void); + bool uninstall(void); + BootloaderInstallBase::BootloaderType installed(void); + Capabilities capabilities(void); + QString ofHint(); + + private: + + private slots: + void installStage2(void); +}; + +#endif diff --git a/rbutil/rbutilqt/rbutil.ini b/rbutil/rbutilqt/rbutil.ini index bcef5d7d49..8fe6395d7c 100644 --- a/rbutil/rbutilqt/rbutil.ini +++ b/rbutil/rbutilqt/rbutil.ini @@ -65,6 +65,7 @@ platform71=samsungyh920 platform72=samsungyh925 platform73=cowond2 platform80=vibe500 +platform90=mpiohd200 [archosplayer] name="Jukebox Player 6000 / Jukebox Studio 5 / 10 / 20" @@ -618,6 +619,19 @@ usberror=0x04098039 configure_modelname=vibe500 encoder=rbspeex +[mpiohd200] +name="MPIO HD200" +buildserver_modelname=mpiohd200 +bootloadermethod=mpio +bootloadername=/mpiohd200/bootloader.mpio +bootloaderfile=/System/HD200_UPG.SYS +manualname= +brand=MPIO +usbid=0x27351004 +configure_modelname=mpiohd200 +encoder=rbspeex +status=disabled + [05ac1240] name="Apple Ipod Nano (Second Generation, DFU Mode)" diff --git a/rbutil/rbutilqt/rbutilqt.cpp b/rbutil/rbutilqt/rbutilqt.cpp index 29ba0e9c81..66e41944f1 100644 --- a/rbutil/rbutilqt/rbutilqt.cpp +++ b/rbutil/rbutilqt/rbutilqt.cpp @@ -43,7 +43,7 @@ #include "progressloggerinterface.h" #include "bootloaderinstallbase.h" - +#include "bootloaderinstallmpio.h" #if defined(Q_OS_LINUX) #include <stdio.h> diff --git a/rbutil/rbutilqt/rbutilqt.pri b/rbutil/rbutilqt/rbutilqt.pri index 53742570df..63d182a0ab 100644 --- a/rbutil/rbutilqt/rbutilqt.pri +++ b/rbutil/rbutilqt/rbutilqt.pri @@ -67,6 +67,7 @@ SOURCES += \ base/bootloaderinstallchinachip.cpp \ base/bootloaderinstallams.cpp \ base/bootloaderinstalltcc.cpp \ + base/bootloaderinstallmpio.cpp \ base/rockboxinfo.cpp \ ../../tools/mkboot.c \ ../../tools/iriver.c \ @@ -133,6 +134,7 @@ HEADERS += \ base/bootloaderinstallchinachip.h \ base/bootloaderinstallams.h \ base/bootloaderinstalltcc.h \ + base/bootloaderinstallmpio.h \ base/rockboxinfo.h \ ../../tools/mkboot.h \ ../../tools/iriver.h \ diff --git a/rbutil/rbutilqt/rbutilqt.pro b/rbutil/rbutilqt/rbutilqt.pro index bb191f59c9..13f31de164 100644 --- a/rbutil/rbutilqt/rbutilqt.pro +++ b/rbutil/rbutilqt/rbutilqt.pro @@ -63,8 +63,11 @@ libmkamsboot.commands = @$(MAKE) \ libmktccboot.commands = @$(MAKE) \ TARGET_DIR=$$MYBUILDDIR -C $$RBBASE_DIR/rbutil/mktccboot \ libmktccboot$$RBLIBPOSTFIX CC=\"$$QMAKE_CC\" -QMAKE_EXTRA_TARGETS += rbspeex libucl libmkamsboot libmktccboot -PRE_TARGETDEPS += rbspeex libucl libmkamsboot libmktccboot +libmkmpioboot.commands = @$(MAKE) \ + TARGET_DIR=$$MYBUILDDIR -C $$RBBASE_DIR/rbutil/mkmpioboot \ + libmkmpioboot$$RBLIBPOSTFIX CC=\"$$QMAKE_CC\" +QMAKE_EXTRA_TARGETS += rbspeex libucl libmkamsboot libmktccboot libmkmpioboot +PRE_TARGETDEPS += rbspeex libucl libmkamsboot libmktccboot libmkmpioboot # rule for creating ctags file tags.commands = ctags -R --c++-kinds=+p --fields=+iaS --extra=+q $(SOURCES) @@ -86,7 +89,7 @@ INCLUDEPATH += $$RBBASE_DIR/rbutil/ipodpatcher $$RBBASE_DIR/rbutil/sansapatcher DEPENDPATH = $$INCLUDEPATH -LIBS += -L$$OUT_PWD -L$$MYBUILDDIR -lrbspeex -lmkamsboot -lmktccboot -lucl +LIBS += -L$$OUT_PWD -L$$MYBUILDDIR -lrbspeex -lmkamsboot -lmktccboot -lmkmpioboot -lucl # check for system speex. Add a custom rule for pre-building librbspeex if not # found. Newer versions of speex are split up into libspeex and libspeexdsp, |