2006-11-26 18:31:41 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 2006 Tomasz Malesinski
|
|
|
|
*
|
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.
|
2006-11-26 18:31:41 +00:00
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include "config.h"
|
2010-09-09 16:17:21 +00:00
|
|
|
#include "codecs.h"
|
2006-11-26 18:31:41 +00:00
|
|
|
|
2009-02-27 07:30:41 +00:00
|
|
|
struct codec_api *ci DATA_ATTR;
|
2006-11-26 18:31:41 +00:00
|
|
|
|
|
|
|
extern unsigned char plugin_bss_start[];
|
|
|
|
extern unsigned char plugin_end_addr[];
|
|
|
|
|
2010-08-02 20:34:47 +00:00
|
|
|
/* stub, the entry point is called via its reference in __header to
|
|
|
|
* avoid warning with certain compilers */
|
|
|
|
int _start(void) {return 0;}
|
|
|
|
|
2011-04-27 03:08:23 +00:00
|
|
|
enum codec_status codec_start(enum codec_entry_call_reason reason)
|
2006-11-26 18:31:41 +00:00
|
|
|
{
|
2010-06-21 16:53:00 +00:00
|
|
|
#if (CONFIG_PLATFORM & PLATFORM_NATIVE)
|
2011-04-27 03:08:23 +00:00
|
|
|
if (reason == CODEC_LOAD)
|
2010-09-09 16:17:21 +00:00
|
|
|
{
|
2011-04-27 03:08:23 +00:00
|
|
|
#ifdef USE_IRAM
|
|
|
|
extern char iramcopy[], iramstart[], iramend[], iedata[], iend[];
|
|
|
|
size_t iram_size = iramend - iramstart;
|
|
|
|
size_t ibss_size = iend - iedata;
|
|
|
|
if (iram_size > 0 || ibss_size > 0)
|
|
|
|
{
|
|
|
|
ci->memcpy(iramstart, iramcopy, iram_size);
|
|
|
|
ci->memset(iedata, 0, ibss_size);
|
|
|
|
/* make the icache (if it exists) up to date with the new code */
|
2011-12-17 07:27:24 +00:00
|
|
|
ci->commit_discard_idcache();
|
2011-04-27 03:08:23 +00:00
|
|
|
/* barrier to prevent reordering iram copy and BSS clearing,
|
|
|
|
* because the BSS segment alias the IRAM copy.
|
|
|
|
*/
|
|
|
|
asm volatile ("" ::: "memory");
|
|
|
|
}
|
|
|
|
#endif /* PLUGIN_USE_IRAM */
|
|
|
|
ci->memset(plugin_bss_start, 0, plugin_end_addr - plugin_bss_start);
|
|
|
|
/* Some parts of bss may be used via a no-cache alias (at least
|
|
|
|
* portalplayer has this). If we don't clear the cache, those aliases
|
|
|
|
* may read garbage */
|
2011-12-17 07:27:24 +00:00
|
|
|
ci->commit_dcache();
|
2010-09-09 16:17:21 +00:00
|
|
|
}
|
2011-04-27 03:08:23 +00:00
|
|
|
#endif /* CONFIG_PLATFORM */
|
2010-09-09 14:28:58 +00:00
|
|
|
|
2011-04-27 03:08:23 +00:00
|
|
|
/* Note: If for any reason codec_main would not be called with CODEC_LOAD
|
|
|
|
* because the above code failed then it must not be ever be called with
|
|
|
|
* any other value and some strategy to avoid doing so must be conceived */
|
|
|
|
return codec_main(reason);
|
2006-11-26 18:31:41 +00:00
|
|
|
}
|
2009-01-24 03:47:09 +00:00
|
|
|
|
2010-10-10 14:43:40 +00:00
|
|
|
#if defined(CPU_ARM) && (CONFIG_PLATFORM & PLATFORM_NATIVE)
|
2009-01-24 03:47:09 +00:00
|
|
|
void __attribute__((naked)) __div0(void)
|
|
|
|
{
|
|
|
|
asm volatile("bx %0" : : "r"(ci->__div0));
|
|
|
|
}
|
|
|
|
#endif
|