1 /***************************************************************************
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
9 * Copyright (C) 2008 by Dominik Wenger
12 * All files in this archive are subject to the GNU General Public License.
13 * See the file COPYING in the source tree root for full license agreement.
15 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
16 * KIND, either express or implied.
18 ****************************************************************************/
21 #include "bootloaderinstallbase.h"
22 #include "bootloaderinstallams.h"
24 #include "../mkamsboot/mkamsboot.h"
26 BootloaderInstallAms::BootloaderInstallAms(QObject
*parent
)
27 : BootloaderInstallBase(parent
)
31 QString
BootloaderInstallAms::ofHint()
33 return tr("Bootloader installation requires you to provide "
34 "a firmware file of the original firmware (bin file). "
35 "You need to download this file yourself due to legal "
36 "reasons. Please browse the "
37 "<a href='http://forums.sandisk.com/sansa/'>Sansa Forums'</a> "
39 "<a href='http://www.rockbox.org/manual.shtml'>manual</a> and "
40 "the <a href='http://www.rockbox.org/wiki/SansaAMS'>SansaAMS</a> "
41 "wiki page on how to obtain this file.<br/>"
42 "Press Ok to continue and browse your computer for the firmware "
46 bool BootloaderInstallAms::install(void)
48 if(m_offile
.isEmpty())
51 qDebug() << "[BootloaderInstallAms] installing bootloader";
53 // download firmware from server
54 emit
logItem(tr("Downloading bootloader file"), LOGINFO
);
56 connect(this, SIGNAL(downloadDone()), this, SLOT(installStage2()));
57 downloadBlStart(m_blurl
);
62 void BootloaderInstallAms::installStage2(void)
64 qDebug() << "[BootloaderInstallAms] installStage2";
67 unsigned char* of_packed
;
69 unsigned char* rb_packed
;
73 char md5sum
[33]; /* 32 hex digits, plus terminating zero */
85 QString bootfile
= m_tempfile
.fileName();
88 /* Load bootloader file */
89 rb_packed
= load_rockbox_file(bootfile
.toLocal8Bit().data(), &model
,
90 &bootloader_size
,&rb_packedsize
,
91 errstr
,sizeof(errstr
));
92 if (rb_packed
== NULL
)
94 qDebug() << "[BootloaderInstallAms] could not load bootloader: " << bootfile
;
95 emit
logItem(errstr
, LOGERROR
);
96 emit
logItem(tr("Could not load %1").arg(bootfile
), LOGERROR
);
101 /* Load original firmware file */
102 buf
= load_of_file(m_offile
.toLocal8Bit().data(), model
, &len
, &sum
,
103 &firmware_size
, &of_packed
,&of_packedsize
,
104 errstr
, sizeof(errstr
));
107 qDebug() << "[BootloaderInstallAms] could not load OF: " << m_offile
;
108 emit
logItem(errstr
, LOGERROR
);
109 emit
logItem(tr("Could not load %1").arg(m_offile
), LOGERROR
);
115 /* check total size */
116 patchable
= check_sizes(sum
.model
, rb_packedsize
, bootloader_size
,
117 of_packedsize
, firmware_size
, &totalsize
, errstr
, sizeof(errstr
));
121 qDebug() << "[BootloaderInstallAms] No room to insert bootloader";
122 emit
logItem(errstr
, LOGERROR
);
123 emit
logItem(tr("No room to insert bootloader, try another firmware version"),
132 /* patch the firmware */
133 emit
logItem(tr("Patching Firmware..."), LOGINFO
);
135 patch_firmware(sum
.model
,firmware_revision(sum
.model
),firmware_size
,buf
,
136 len
,of_packed
,of_packedsize
,rb_packed
,rb_packedsize
);
141 if(!out
.open(QIODevice::WriteOnly
| QIODevice::Truncate
))
143 qDebug() << "[BootloaderInstallAms] Could not open" << m_blfile
<< "for writing";
144 emit
logItem(tr("Could not open %1 for writing").arg(m_blfile
),LOGERROR
);
152 n
= out
.write((char*)buf
, len
);
156 qDebug() << "[BootloaderInstallAms] Could not write firmware file";
157 emit
logItem(tr("Could not write firmware file"),LOGERROR
);
172 qDebug() << "[BootloaderInstallAms] install successfull";
173 emit
logItem(tr("Success: modified firmware file created"), LOGINFO
);
179 bool BootloaderInstallAms::uninstall(void)
181 emit
logItem(tr("To uninstall, perform a normal upgrade with an unmodified "
182 "original firmware"), LOGINFO
);
183 logInstall(LogRemove
);
187 BootloaderInstallBase::BootloaderType
BootloaderInstallAms::installed(void)
189 return BootloaderUnknown
;
192 BootloaderInstallBase::Capabilities
BootloaderInstallAms::capabilities(void)
194 return (Install
| NeedsOf
);