2005-11-27 23:55:13 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 2005 by Jens Arnold
|
|
|
|
*
|
|
|
|
* Self-extracting firmware loader to work around the 200KB size limit
|
|
|
|
* for archos player and recorder v1
|
|
|
|
* Decompresses a built-in UCL-compressed image (method 2e) and executes it.
|
|
|
|
*
|
2008-06-28 18:10:04 +00:00
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
2005-11-27 23:55:13 +00:00
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2005-11-30 00:05:40 +00:00
|
|
|
#include "uclimage.h"
|
|
|
|
|
2005-11-27 23:55:13 +00:00
|
|
|
#define ICODE_ATTR __attribute__ ((section (".icode")))
|
|
|
|
|
|
|
|
/* Symbols defined in the linker script */
|
|
|
|
extern char iramcopy[], iramstart[], iramend[];
|
|
|
|
extern char stackend[];
|
|
|
|
extern char loadaddress[], dramend[];
|
|
|
|
|
|
|
|
/* Prototypes */
|
2005-11-28 23:40:57 +00:00
|
|
|
extern void start(void);
|
|
|
|
|
2005-11-27 23:55:13 +00:00
|
|
|
void main(void) ICODE_ATTR;
|
2008-10-28 21:07:53 +00:00
|
|
|
int ucl_nrv2e_decompress_8(const unsigned char *src, unsigned char *dst,
|
|
|
|
unsigned long *dst_len) ICODE_ATTR;
|
2005-11-27 23:55:13 +00:00
|
|
|
|
|
|
|
/* Vector table */
|
|
|
|
void (*vbr[]) (void) __attribute__ ((section (".vectors"))) =
|
|
|
|
{
|
|
|
|
start, (void *)stackend,
|
|
|
|
start, (void *)stackend,
|
|
|
|
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
|
|
|
|
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
|
|
|
|
};
|
|
|
|
|
|
|
|
/** All subsequent functions are executed from IRAM **/
|
|
|
|
|
2005-11-30 00:05:40 +00:00
|
|
|
#define ALIGNED_IMG_SIZE ((sizeof(image) + 3) & ~3)
|
2005-11-27 23:55:13 +00:00
|
|
|
/* This will never return */
|
|
|
|
void main(void)
|
|
|
|
{
|
|
|
|
unsigned long dst_len; /* dummy */
|
2005-11-30 00:05:40 +00:00
|
|
|
unsigned long *src = (unsigned long *)image;
|
|
|
|
unsigned long *dst = (unsigned long *)(dramend - ALIGNED_IMG_SIZE);
|
2005-11-28 23:40:57 +00:00
|
|
|
|
|
|
|
do
|
|
|
|
*dst++ = *src++;
|
|
|
|
while (dst < (unsigned long *)dramend);
|
|
|
|
|
2005-11-30 00:05:40 +00:00
|
|
|
ucl_nrv2e_decompress_8(dramend - ALIGNED_IMG_SIZE, loadaddress, &dst_len);
|
2005-11-27 23:55:13 +00:00
|
|
|
|
|
|
|
asm(
|
|
|
|
"mov.l @%0+,r0 \n"
|
|
|
|
"jmp @r0 \n"
|
2005-11-28 23:40:57 +00:00
|
|
|
"mov.l @%0+,r15 \n"
|
2005-11-27 23:55:13 +00:00
|
|
|
: : "r"(loadaddress) : "r0"
|
|
|
|
);
|
|
|
|
}
|