mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-10-24 15:37:38 -04:00
Basic optimizations of the Vorbis decoder for the ihp-1x0.
Capable of real-time decoding with cpu freq at 120mhz. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@6527 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
3841348930
commit
024db0a766
22 changed files with 428 additions and 107 deletions
|
@ -14,7 +14,7 @@ ifdef APPEXTRA
|
||||||
INCLUDES += -I$(APPSDIR)/$(APPEXTRA)
|
INCLUDES += -I$(APPSDIR)/$(APPEXTRA)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
TREMOROPTS =
|
TREMOROPTS = -O2
|
||||||
CFLAGS = $(GCCOPTS) $(TREMOROPTS) $(INCLUDES) $(TARGET) $(EXTRA_DEFINES) \
|
CFLAGS = $(GCCOPTS) $(TREMOROPTS) $(INCLUDES) $(TARGET) $(EXTRA_DEFINES) \
|
||||||
-DMEM=${MEMORYSIZE}
|
-DMEM=${MEMORYSIZE}
|
||||||
|
|
||||||
|
|
257
apps/codecs/Tremor/asm_mcf5249.h
Normal file
257
apps/codecs/Tremor/asm_mcf5249.h
Normal file
|
@ -0,0 +1,257 @@
|
||||||
|
/***************************************************************************
|
||||||
|
* __________ __ ___.
|
||||||
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
||||||
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
||||||
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
||||||
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
||||||
|
* \/ \/ \/ \/ \/
|
||||||
|
*
|
||||||
|
* Copyright (C) 2005 by Pedro Vasconcelos
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
/* asm routines for wide math on the MCF5249 */
|
||||||
|
|
||||||
|
#include "os_types.h"
|
||||||
|
|
||||||
|
#if CONFIG_CPU == MCF5249 && !defined(SIMULATOR)
|
||||||
|
|
||||||
|
#ifndef _V_WIDE_MATH
|
||||||
|
#define _V_WIDE_MATH
|
||||||
|
|
||||||
|
//#define MB() asm volatile ("" : : : "memory")
|
||||||
|
#define MB()
|
||||||
|
|
||||||
|
static inline void mcf5249_init_mac(void) {
|
||||||
|
int r;
|
||||||
|
asm volatile ("move.l #0x20, %%macsr;" // frac, truncate, no saturation
|
||||||
|
"movclr.l %%acc0, %[r];" // clear accumulators
|
||||||
|
"move.l %%acc0, %%acc1;"
|
||||||
|
"move.l %%acc0, %%acc2;"
|
||||||
|
"move.l %%acc0, %%acc3;"
|
||||||
|
: [r] "=r" (r));
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline ogg_int32_t MULT32(ogg_int32_t x, ogg_int32_t y) {
|
||||||
|
ogg_int32_t r;
|
||||||
|
asm volatile ("mac.l %[x], %[y], %%acc0;" // multiply into acc
|
||||||
|
"movclr.l %%acc0, %[r];" // move & clear acc
|
||||||
|
"asr.l #1, %[r];" // no overflow test
|
||||||
|
: [r] "=d" (r)
|
||||||
|
: [x] "r" (x), [y] "r" (y)
|
||||||
|
: "cc");
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline ogg_int32_t MULT31(ogg_int32_t x, ogg_int32_t y) {
|
||||||
|
ogg_int32_t r;
|
||||||
|
asm volatile ("mac.l %[x], %[y], %%acc0;" // multiply
|
||||||
|
"movclr.l %%acc0, %[r];" // move and clear
|
||||||
|
: [r] "=r" (r)
|
||||||
|
: [x] "r" (x), [y] "r" (y)
|
||||||
|
: "cc");
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline ogg_int32_t MULT31_SHIFT15(ogg_int32_t x, ogg_int32_t y) {
|
||||||
|
ogg_int32_t r;
|
||||||
|
asm volatile ("mac.l %[x], %[y], %%acc0;" // multiply
|
||||||
|
"movclr.l %%acc0, %[r];" // get higher half
|
||||||
|
"mulu.l %[y], %[x];" // get lower half
|
||||||
|
"asl.l #8, %[r];" // hi << 17
|
||||||
|
"asl.l #8, %[r];"
|
||||||
|
"lsr.l #8, %[x];" // (unsigned)lo >> 15
|
||||||
|
"lsr.l #7, %[x];"
|
||||||
|
"or.l %[x], %[r];" // or
|
||||||
|
: [r] "=&d" (r), [x] "+d" (x)
|
||||||
|
: [y] "d" (y)
|
||||||
|
: "cc");
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline
|
||||||
|
void XPROD31(ogg_int32_t a, ogg_int32_t b,
|
||||||
|
ogg_int32_t t, ogg_int32_t v,
|
||||||
|
ogg_int32_t *x, ogg_int32_t *y)
|
||||||
|
{
|
||||||
|
ogg_int32_t r;
|
||||||
|
asm volatile ("mac.l %[a], %[t], %%acc0;"
|
||||||
|
"mac.l %[b], %[v], %%acc0;"
|
||||||
|
"mac.l %[b], %[t], %%acc1;"
|
||||||
|
"msac.l %[a], %[v], %%acc1;"
|
||||||
|
"movclr.l %%acc0, %[r];"
|
||||||
|
"move.l %[r], (%[x]);"
|
||||||
|
"movclr.l %%acc1, %[r];"
|
||||||
|
"move.l %[r], (%[y]);"
|
||||||
|
: [r] "=&r" (r)
|
||||||
|
: [x] "a" (x), [y] "a" (y),
|
||||||
|
[a] "r" (a), [b] "r" (b), [t] "r" (t), [v] "r" (v)
|
||||||
|
: "cc", "memory");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline
|
||||||
|
void XNPROD31(ogg_int32_t a, ogg_int32_t b,
|
||||||
|
ogg_int32_t t, ogg_int32_t v,
|
||||||
|
ogg_int32_t *x, ogg_int32_t *y)
|
||||||
|
{
|
||||||
|
ogg_int32_t r;
|
||||||
|
asm volatile ("mac.l %[a], %[t], %%acc0;"
|
||||||
|
"msac.l %[b], %[v], %%acc0;"
|
||||||
|
"mac.l %[b], %[t], %%acc1;"
|
||||||
|
"mac.l %[a], %[v], %%acc1;"
|
||||||
|
"movclr.l %%acc0, %[r];"
|
||||||
|
"move.l %[r], (%[x]);"
|
||||||
|
"movclr.l %%acc1, %[r];"
|
||||||
|
"move.l %[r], (%[y]);"
|
||||||
|
: [r] "=&r" (r)
|
||||||
|
: [x] "a" (x), [y] "a" (y),
|
||||||
|
[a] "r" (a), [b] "r" (b), [t] "r" (t), [v] "r" (v)
|
||||||
|
: "cc", "memory");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* no faster way of doing this using the MAC? */
|
||||||
|
#define XPROD32(_a, _b, _t, _v, _x, _y) \
|
||||||
|
{ (_x)=MULT32(_a,_t)+MULT32(_b,_v); \
|
||||||
|
(_y)=MULT32(_b,_t)-MULT32(_a,_v); }
|
||||||
|
|
||||||
|
|
||||||
|
/* asm versions of vector multiplication for window.c */
|
||||||
|
/* assumes MAC is initialized & accumulators cleared */
|
||||||
|
static inline
|
||||||
|
void mcf5249_vect_mult_fw(ogg_int32_t *data, LOOKUP_T *window, int n)
|
||||||
|
{
|
||||||
|
asm volatile ("movem.l (%[d]), %%d0-%%d3;" // loop start
|
||||||
|
"movem.l (%[w]), %%a0-%%a3;" // pre-fetch registers
|
||||||
|
"lea.l (4*4, %[w]), %[w];"
|
||||||
|
"bra 1f;" // jump to loop condition
|
||||||
|
"0:" // loop body
|
||||||
|
// multiply and load next window values
|
||||||
|
"mac.l %%d0, %%a0, (%[w])+, %%a0, %%acc0;"
|
||||||
|
"mac.l %%d1, %%a1, (%[w])+, %%a1, %%acc1;"
|
||||||
|
"mac.l %%d2, %%a2, (%[w])+, %%a2, %%acc2;"
|
||||||
|
"mac.l %%d3, %%a3, (%[w])+, %%a3, %%acc3;"
|
||||||
|
"movclr.l %%acc0, %%d0;" // get the products
|
||||||
|
"movclr.l %%acc1, %%d1;"
|
||||||
|
"movclr.l %%acc2, %%d2;"
|
||||||
|
"movclr.l %%acc3, %%d3;"
|
||||||
|
// store and advance
|
||||||
|
"movem.l %%d0-%%d3, (%[d]);"
|
||||||
|
"lea.l (4*4, %[d]), %[d];"
|
||||||
|
"movem.l (%[d]), %%d0-%%d3;"
|
||||||
|
"subq.l #4, %[n];" // done 4 elements
|
||||||
|
"1: cmpi.l #4, %[n];"
|
||||||
|
"bge 0b;"
|
||||||
|
// multiply final elements
|
||||||
|
"tst.l %[n];"
|
||||||
|
"beq 1f;" // n=0
|
||||||
|
"mac.l %%d0, %%a0, %%acc0;"
|
||||||
|
"movclr.l %%acc0, %%d0;"
|
||||||
|
"move.l %%d0, (%[d])+;"
|
||||||
|
"subq.l #1, %[n];"
|
||||||
|
"beq 1f;" // n=1
|
||||||
|
"mac.l %%d1, %%a1, %%acc0;"
|
||||||
|
"movclr.l %%acc0, %%d1;"
|
||||||
|
"move.l %%d1, (%[d])+;"
|
||||||
|
"subq.l #1, %[n];"
|
||||||
|
"beq 1f;" // n=2
|
||||||
|
// otherwise n = 3
|
||||||
|
"mac.l %%d2, %%a2, %%acc0;"
|
||||||
|
"movclr.l %%acc0, %%d2;"
|
||||||
|
"move.l %%d2, (%[d])+;"
|
||||||
|
"1:"
|
||||||
|
: [n] "+d" (n), [d] "+a" (data), [w] "+a" (window)
|
||||||
|
: : "%d0", "%d1", "%d2", "%d3", "%a0", "%a1", "%a2", "%a3",
|
||||||
|
"cc", "memory");
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline
|
||||||
|
void mcf5249_vect_mult_bw(ogg_int32_t *data, LOOKUP_T *window, int n)
|
||||||
|
{
|
||||||
|
asm volatile ("lea.l (-3*4, %[w]), %[w];" // loop start
|
||||||
|
"movem.l (%[d]), %%d0-%%d3;" // pre-fetch registers
|
||||||
|
"movem.l (%[w]), %%a0-%%a3;"
|
||||||
|
"bra 1f;" // jump to loop condition
|
||||||
|
"0:" // loop body
|
||||||
|
// multiply and load next window value
|
||||||
|
"mac.l %%d0, %%a3, -(%[w]), %%a3, %%acc0;"
|
||||||
|
"mac.l %%d1, %%a2, -(%[w]), %%a2, %%acc1;"
|
||||||
|
"mac.l %%d2, %%a1, -(%[w]), %%a1, %%acc2;"
|
||||||
|
"mac.l %%d3, %%a0, -(%[w]), %%a0, %%acc3;"
|
||||||
|
"movclr.l %%acc0, %%d0;" // get the products
|
||||||
|
"movclr.l %%acc1, %%d1;"
|
||||||
|
"movclr.l %%acc2, %%d2;"
|
||||||
|
"movclr.l %%acc3, %%d3;"
|
||||||
|
// store and advance
|
||||||
|
"movem.l %%d0-%%d3, (%[d]);"
|
||||||
|
"lea.l (4*4, %[d]), %[d];"
|
||||||
|
"movem.l (%[d]), %%d0-%%d3;"
|
||||||
|
"subq.l #4, %[n];" // done 4 elements
|
||||||
|
"1: cmpi.l #4, %[n];"
|
||||||
|
"bge 0b;"
|
||||||
|
// multiply final elements
|
||||||
|
"tst.l %[n];"
|
||||||
|
"beq 1f;" // n=0
|
||||||
|
"mac.l %%d0, %%a3, %%acc0;"
|
||||||
|
"movclr.l %%acc0, %%d0;"
|
||||||
|
"move.l %%d0, (%[d])+;"
|
||||||
|
"subq.l #1, %[n];"
|
||||||
|
"beq 1f;" // n=1
|
||||||
|
"mac.l %%d1, %%a2, %%acc0;"
|
||||||
|
"movclr.l %%acc0, %%d1;"
|
||||||
|
"move.l %%d1, (%[d])+;"
|
||||||
|
"subq.l #1, %[n];"
|
||||||
|
"beq 1f;" // n=2
|
||||||
|
// otherwise n = 3
|
||||||
|
"mac.l %%d2, %%a1, %%acc0;"
|
||||||
|
"movclr.l %%acc0, %%d2;"
|
||||||
|
"move.l %%d2, (%[d])+;"
|
||||||
|
"1:"
|
||||||
|
: [n] "+d" (n), [d] "+a" (data), [w] "+a" (window)
|
||||||
|
: : "%d0", "%d1", "%d2", "%d3", "%a0", "%a1", "%a2", "%a3",
|
||||||
|
"cc", "memory");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline
|
||||||
|
void mcf5249_vect_zero(ogg_int32_t *ptr, int n)
|
||||||
|
{
|
||||||
|
asm volatile ("clr.l %%d0;"
|
||||||
|
"clr.l %%d1;"
|
||||||
|
"clr.l %%d2;"
|
||||||
|
"clr.l %%d3;"
|
||||||
|
// loop start
|
||||||
|
"tst.l %[n];"
|
||||||
|
"bra 1f;"
|
||||||
|
"0: movem.l %%d0-%%d3, (%[ptr]);"
|
||||||
|
"lea (4*4, %[ptr]), %[ptr];"
|
||||||
|
"subq.l #4, %[n];"
|
||||||
|
"1: bgt 0b;"
|
||||||
|
// remaing elements
|
||||||
|
"tst.l %[n];"
|
||||||
|
"beq 1f;" // n=0
|
||||||
|
"clr.l (%[ptr])+;"
|
||||||
|
"subq.l #1, %[n];"
|
||||||
|
"beq 1f;" // n=1
|
||||||
|
"clr.l (%[ptr])+;"
|
||||||
|
"subq.l #1, %[n];"
|
||||||
|
"beq 1f;" // n=2
|
||||||
|
// otherwise n = 3
|
||||||
|
"clr.l (%[ptr])+;"
|
||||||
|
"1:"
|
||||||
|
: [n] "+d" (n), [ptr] "+a" (ptr)
|
||||||
|
:
|
||||||
|
: "%d0","%d1","%d2","%d3","cc","memory");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif
|
|
@ -22,7 +22,7 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "ogg.h"
|
#include "ogg.h"
|
||||||
|
|
||||||
static unsigned long mask[]=
|
static const unsigned long mask[] IDATA_ATTR =
|
||||||
{0x00000000,0x00000001,0x00000003,0x00000007,0x0000000f,
|
{0x00000000,0x00000001,0x00000003,0x00000007,0x0000000f,
|
||||||
0x0000001f,0x0000003f,0x0000007f,0x000000ff,0x000001ff,
|
0x0000001f,0x0000003f,0x0000007f,0x000000ff,0x000001ff,
|
||||||
0x000003ff,0x000007ff,0x00000fff,0x00001fff,0x00003fff,
|
0x000003ff,0x000007ff,0x00000fff,0x00001fff,0x00003fff,
|
||||||
|
|
|
@ -172,8 +172,12 @@ static int _vds_init(vorbis_dsp_state *v,vorbis_info *vi){
|
||||||
v->pcm_storage=ci->blocksizes[1];
|
v->pcm_storage=ci->blocksizes[1];
|
||||||
v->pcm=(ogg_int32_t **)_ogg_malloc(vi->channels*sizeof(*v->pcm));
|
v->pcm=(ogg_int32_t **)_ogg_malloc(vi->channels*sizeof(*v->pcm));
|
||||||
v->pcmret=(ogg_int32_t **)_ogg_malloc(vi->channels*sizeof(*v->pcmret));
|
v->pcmret=(ogg_int32_t **)_ogg_malloc(vi->channels*sizeof(*v->pcmret));
|
||||||
|
|
||||||
|
// pbv: allow for extra padding for windowing
|
||||||
for(i=0;i<vi->channels;i++)
|
for(i=0;i<vi->channels;i++)
|
||||||
v->pcm[i]=(ogg_int32_t *)_ogg_calloc(v->pcm_storage,sizeof(*v->pcm[i]));
|
v->pcm[i]=(ogg_int32_t *)_ogg_calloc(v->pcm_storage,sizeof(*v->pcm[i]));
|
||||||
|
// v->pcm[i]=(ogg_int32_t *)_ogg_calloc(v->pcm_storage,sizeof(*v->pcm[i]));
|
||||||
|
|
||||||
|
|
||||||
/* all 1 (large block) or 0 (small block) */
|
/* all 1 (large block) or 0 (small block) */
|
||||||
/* explicitly set for the sake of clarity */
|
/* explicitly set for the sake of clarity */
|
||||||
|
|
|
@ -306,7 +306,7 @@ long vorbis_book_decodev_set(codebook *book,ogg_int32_t *a,
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
long vorbis_book_decodevv_add(codebook *book,ogg_int32_t **a,\
|
long vorbis_book_decodevv_add(codebook *book,ogg_int32_t **a,
|
||||||
long offset,int ch,
|
long offset,int ch,
|
||||||
oggpack_buffer *b,int n,int point){
|
oggpack_buffer *b,int n,int point){
|
||||||
long i,j,entry;
|
long i,j,entry;
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
#include "../codec.h"
|
#include "../codec.h"
|
||||||
|
|
||||||
#ifdef ROCKBOX_BIG_ENDIAN
|
#ifdef ROCKBOX_BIG_ENDIAN
|
||||||
#define BIG_ENDIAN 1
|
#define BIG_ENDIAN 1
|
||||||
#define LITTLE_ENDIAN 0
|
#define LITTLE_ENDIAN 0
|
||||||
|
@ -9,4 +8,6 @@
|
||||||
#define LITTLE_ENDIAN 1
|
#define LITTLE_ENDIAN 1
|
||||||
#define BIG_ENDIAN 0
|
#define BIG_ENDIAN 0
|
||||||
#endif
|
#endif
|
||||||
#define _LOW_ACCURACY_
|
|
||||||
|
|
||||||
|
// #define _LOW_ACCURACY_
|
||||||
|
|
|
@ -124,7 +124,7 @@ static int icomp(const void *a,const void *b){
|
||||||
static vorbis_look_floor *floor1_look(vorbis_dsp_state *vd,vorbis_info_mode *mi,
|
static vorbis_look_floor *floor1_look(vorbis_dsp_state *vd,vorbis_info_mode *mi,
|
||||||
vorbis_info_floor *in){
|
vorbis_info_floor *in){
|
||||||
|
|
||||||
int *sortpointer[VIF_POSIT+2];
|
static int *sortpointer[VIF_POSIT+2] IDATA_ATTR;
|
||||||
vorbis_info_floor1 *info=(vorbis_info_floor1 *)in;
|
vorbis_info_floor1 *info=(vorbis_info_floor1 *)in;
|
||||||
vorbis_look_floor1 *look=(vorbis_look_floor1 *)_ogg_calloc(1,sizeof(*look));
|
vorbis_look_floor1 *look=(vorbis_look_floor1 *)_ogg_calloc(1,sizeof(*look));
|
||||||
int i,j,n=0;
|
int i,j,n=0;
|
||||||
|
@ -216,7 +216,7 @@ static int render_point(int x0,int x1,int y0,int y1,int x){
|
||||||
# define XdB(n) (n)
|
# define XdB(n) (n)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static const ogg_int32_t FLOOR_fromdB_LOOKUP[256]={
|
static ogg_int32_t FLOOR_fromdB_LOOKUP[256] IDATA_ATTR ={
|
||||||
XdB(0x000000e5), XdB(0x000000f4), XdB(0x00000103), XdB(0x00000114),
|
XdB(0x000000e5), XdB(0x000000f4), XdB(0x00000103), XdB(0x00000114),
|
||||||
XdB(0x00000126), XdB(0x00000139), XdB(0x0000014e), XdB(0x00000163),
|
XdB(0x00000126), XdB(0x00000139), XdB(0x0000014e), XdB(0x00000163),
|
||||||
XdB(0x0000017a), XdB(0x00000193), XdB(0x000001ad), XdB(0x000001c9),
|
XdB(0x0000017a), XdB(0x00000193), XdB(0x000001ad), XdB(0x000001c9),
|
||||||
|
@ -283,14 +283,14 @@ static const ogg_int32_t FLOOR_fromdB_LOOKUP[256]={
|
||||||
XdB(0x69f80e9a), XdB(0x70dafda8), XdB(0x78307d76), XdB(0x7fffffff),
|
XdB(0x69f80e9a), XdB(0x70dafda8), XdB(0x78307d76), XdB(0x7fffffff),
|
||||||
};
|
};
|
||||||
|
|
||||||
static void render_line(int x0,int x1,int y0,int y1,ogg_int32_t *d){
|
static void render_line(int x0,register int x1,int y0,int y1,ogg_int32_t *d){
|
||||||
int dy=y1-y0;
|
int dy=y1-y0;
|
||||||
int adx=x1-x0;
|
register int x=x0;
|
||||||
int ady=abs(dy);
|
register int y=y0;
|
||||||
int base=dy/adx;
|
register int adx=x1-x0;
|
||||||
int sy=(dy<0?base-1:base+1);
|
register int ady=abs(dy);
|
||||||
int x=x0;
|
register int base=dy/adx;
|
||||||
int y=y0;
|
register int sy=(dy<0?base-1:base+1);
|
||||||
int err=0;
|
int err=0;
|
||||||
|
|
||||||
ady-=abs(base*adx);
|
ady-=abs(base*adx);
|
||||||
|
@ -433,7 +433,7 @@ static int floor1_inverse2(vorbis_block *vb,vorbis_look_floor *in,void *memo,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* export hooks */
|
/* export hooks */
|
||||||
vorbis_func_floor floor1_exportbundle={
|
vorbis_func_floor floor1_exportbundle = {
|
||||||
&floor1_unpack,&floor1_look,&floor1_free_info,
|
&floor1_unpack,&floor1_look,&floor1_free_info,
|
||||||
&floor1_free_look,&floor1_inverse1,&floor1_inverse2
|
&floor1_free_look,&floor1_inverse1,&floor1_inverse2
|
||||||
};
|
};
|
||||||
|
|
|
@ -501,7 +501,7 @@ int ogg_page_packets(ogg_page *og){
|
||||||
/* Static CRC calculation table. See older code in CVS for dead
|
/* Static CRC calculation table. See older code in CVS for dead
|
||||||
run-time initialization code. */
|
run-time initialization code. */
|
||||||
|
|
||||||
static ogg_uint32_t crc_lookup[256]={
|
static ogg_uint32_t crc_lookup[256] IDATA_ATTR = {
|
||||||
0x00000000,0x04c11db7,0x09823b6e,0x0d4326d9,
|
0x00000000,0x04c11db7,0x09823b6e,0x0d4326d9,
|
||||||
0x130476dc,0x17c56b6b,0x1a864db2,0x1e475005,
|
0x130476dc,0x17c56b6b,0x1a864db2,0x1e475005,
|
||||||
0x2608edb8,0x22c9f00f,0x2f8ad6d6,0x2b4bcb61,
|
0x2608edb8,0x22c9f00f,0x2f8ad6d6,0x2b4bcb61,
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
#define FROMdB2_SHIFT 3
|
#define FROMdB2_SHIFT 3
|
||||||
#define FROMdB2_MASK 31
|
#define FROMdB2_MASK 31
|
||||||
|
|
||||||
static const ogg_int32_t FROMdB_LOOKUP[FROMdB_LOOKUP_SZ]={
|
static const ogg_int32_t FROMdB_LOOKUP[FROMdB_LOOKUP_SZ] ={
|
||||||
0x003fffff, 0x0028619b, 0x00197a96, 0x0010137a,
|
0x003fffff, 0x0028619b, 0x00197a96, 0x0010137a,
|
||||||
0x000a24b0, 0x00066666, 0x000409c3, 0x00028c42,
|
0x000a24b0, 0x00066666, 0x000409c3, 0x00028c42,
|
||||||
0x00019b8c, 0x000103ab, 0x0000a3d7, 0x00006760,
|
0x00019b8c, 0x000103ab, 0x0000a3d7, 0x00006760,
|
||||||
|
@ -37,7 +37,7 @@ static const ogg_int32_t FROMdB_LOOKUP[FROMdB_LOOKUP_SZ]={
|
||||||
0x0000000b, 0x00000007, 0x00000004, 0x00000003,
|
0x0000000b, 0x00000007, 0x00000004, 0x00000003,
|
||||||
0x00000002, 0x00000001, 0x00000001};
|
0x00000002, 0x00000001, 0x00000001};
|
||||||
|
|
||||||
static const ogg_int32_t FROMdB2_LOOKUP[FROMdB2_LOOKUP_SZ]={
|
static const ogg_int32_t FROMdB2_LOOKUP[FROMdB2_LOOKUP_SZ] ={
|
||||||
0x000001fc, 0x000001f5, 0x000001ee, 0x000001e7,
|
0x000001fc, 0x000001f5, 0x000001ee, 0x000001e7,
|
||||||
0x000001e0, 0x000001d9, 0x000001d2, 0x000001cc,
|
0x000001e0, 0x000001d9, 0x000001d2, 0x000001cc,
|
||||||
0x000001c5, 0x000001bf, 0x000001b8, 0x000001b2,
|
0x000001c5, 0x000001bf, 0x000001b8, 0x000001b2,
|
||||||
|
@ -50,7 +50,7 @@ static const ogg_int32_t FROMdB2_LOOKUP[FROMdB2_LOOKUP_SZ]={
|
||||||
|
|
||||||
#define INVSQ_LOOKUP_I_SHIFT 10
|
#define INVSQ_LOOKUP_I_SHIFT 10
|
||||||
#define INVSQ_LOOKUP_I_MASK 1023
|
#define INVSQ_LOOKUP_I_MASK 1023
|
||||||
static const long INVSQ_LOOKUP_I[64+1]={
|
static const long INVSQ_LOOKUP_I[64+1] ={
|
||||||
92682, 91966, 91267, 90583,
|
92682, 91966, 91267, 90583,
|
||||||
89915, 89261, 88621, 87995,
|
89915, 89261, 88621, 87995,
|
||||||
87381, 86781, 86192, 85616,
|
87381, 86781, 86192, 85616,
|
||||||
|
@ -70,7 +70,7 @@ static const long INVSQ_LOOKUP_I[64+1]={
|
||||||
65536,
|
65536,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const long INVSQ_LOOKUP_IDel[64]={
|
static const long INVSQ_LOOKUP_IDel[64] ={
|
||||||
716, 699, 684, 668,
|
716, 699, 684, 668,
|
||||||
654, 640, 626, 614,
|
654, 640, 626, 614,
|
||||||
600, 589, 576, 565,
|
600, 589, 576, 565,
|
||||||
|
@ -92,7 +92,7 @@ static const long INVSQ_LOOKUP_IDel[64]={
|
||||||
#define COS_LOOKUP_I_SHIFT 9
|
#define COS_LOOKUP_I_SHIFT 9
|
||||||
#define COS_LOOKUP_I_MASK 511
|
#define COS_LOOKUP_I_MASK 511
|
||||||
#define COS_LOOKUP_I_SZ 128
|
#define COS_LOOKUP_I_SZ 128
|
||||||
static const ogg_int32_t COS_LOOKUP_I[COS_LOOKUP_I_SZ+1]={
|
static const ogg_int32_t COS_LOOKUP_I[COS_LOOKUP_I_SZ+1] ={
|
||||||
16384, 16379, 16364, 16340,
|
16384, 16379, 16364, 16340,
|
||||||
16305, 16261, 16207, 16143,
|
16305, 16261, 16207, 16143,
|
||||||
16069, 15986, 15893, 15791,
|
16069, 15986, 15893, 15791,
|
||||||
|
|
|
@ -28,6 +28,8 @@
|
||||||
#include "registry.h"
|
#include "registry.h"
|
||||||
#include "misc.h"
|
#include "misc.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* simplistic, wasteful way of doing this (unique lookup for each
|
/* simplistic, wasteful way of doing this (unique lookup for each
|
||||||
mode/submapping); there should be a central repository for
|
mode/submapping); there should be a central repository for
|
||||||
identical lookups. That will require minor work, so I'm putting it
|
identical lookups. That will require minor work, so I'm putting it
|
||||||
|
@ -124,6 +126,7 @@ static int ilog(unsigned int v){
|
||||||
return(ret);
|
return(ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* also responsible for range checking */
|
/* also responsible for range checking */
|
||||||
static vorbis_info_mapping *mapping0_unpack(vorbis_info *vi,oggpack_buffer *opb){
|
static vorbis_info_mapping *mapping0_unpack(vorbis_info *vi,oggpack_buffer *opb){
|
||||||
int i;
|
int i;
|
||||||
|
@ -176,7 +179,17 @@ static vorbis_info_mapping *mapping0_unpack(vorbis_info *vi,oggpack_buffer *opb)
|
||||||
return(NULL);
|
return(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int seq=0;
|
|
||||||
|
/* IRAM buffer keep the pcm data; only for windows size upto 2048
|
||||||
|
for space restrictions. No real compromise, larger window sizes
|
||||||
|
are only used for very low quality settings (q<0?) */
|
||||||
|
#define IRAM_PCM_SIZE 2048
|
||||||
|
static ogg_int32_t pcm_iram[IRAM_PCM_SIZE] IDATA_ATTR;
|
||||||
|
|
||||||
|
static int seq = 0;
|
||||||
|
|
||||||
|
#define CHANNELS 2 /* max 2 channels on the ihp-1xx (stereo) */
|
||||||
|
|
||||||
static int mapping0_inverse(vorbis_block *vb,vorbis_look_mapping *l){
|
static int mapping0_inverse(vorbis_block *vb,vorbis_look_mapping *l){
|
||||||
vorbis_dsp_state *vd=vb->vd;
|
vorbis_dsp_state *vd=vb->vd;
|
||||||
vorbis_info *vi=vd->vi;
|
vorbis_info *vi=vd->vi;
|
||||||
|
@ -188,11 +201,15 @@ static int mapping0_inverse(vorbis_block *vb,vorbis_look_mapping *l){
|
||||||
int i,j;
|
int i,j;
|
||||||
long n=vb->pcmend=ci->blocksizes[vb->W];
|
long n=vb->pcmend=ci->blocksizes[vb->W];
|
||||||
|
|
||||||
ogg_int32_t **pcmbundle=(ogg_int32_t **)alloca(sizeof(*pcmbundle)*vi->channels);
|
/* statically allocate mapping structures in IRAM */
|
||||||
int *zerobundle=(int *)alloca(sizeof(*zerobundle)*vi->channels);
|
static ogg_int32_t *pcmbundle[CHANNELS] IDATA_ATTR;
|
||||||
|
static int zerobundle[CHANNELS] IDATA_ATTR;
|
||||||
|
static int nonzero[CHANNELS] IDATA_ATTR;
|
||||||
|
static void *floormemo[CHANNELS] IDATA_ATTR;
|
||||||
|
|
||||||
int *nonzero =(int *)alloca(sizeof(*nonzero)*vi->channels);
|
/* test for too many channels;
|
||||||
void **floormemo=(void **)alloca(sizeof(*floormemo)*vi->channels);
|
(maybe this is can be checked at the stream level?) */
|
||||||
|
if (vi->channels > CHANNELS) return (-1);
|
||||||
|
|
||||||
/* time domain information decode (note that applying the
|
/* time domain information decode (note that applying the
|
||||||
information would have to happen later; we'll probably add a
|
information would have to happen later; we'll probably add a
|
||||||
|
@ -272,6 +289,10 @@ static int mapping0_inverse(vorbis_block *vb,vorbis_look_mapping *l){
|
||||||
//for(j=0;j<vi->channels;j++)
|
//for(j=0;j<vi->channels;j++)
|
||||||
//_analysis_output("residue",seq+j,vb->pcm[j],-8,n/2,0,0);
|
//_analysis_output("residue",seq+j,vb->pcm[j],-8,n/2,0,0);
|
||||||
|
|
||||||
|
|
||||||
|
/* pbv: removed this loop by fusion with the following one
|
||||||
|
to avoid recopying data to/from the IRAM */
|
||||||
|
#if 0
|
||||||
/* compute and apply spectral envelope */
|
/* compute and apply spectral envelope */
|
||||||
for(i=0;i<vi->channels;i++){
|
for(i=0;i<vi->channels;i++){
|
||||||
ogg_int32_t *pcm=vb->pcm[i];
|
ogg_int32_t *pcm=vb->pcm[i];
|
||||||
|
@ -279,31 +300,53 @@ static int mapping0_inverse(vorbis_block *vb,vorbis_look_mapping *l){
|
||||||
look->floor_func[submap]->
|
look->floor_func[submap]->
|
||||||
inverse2(vb,look->floor_look[submap],floormemo[i],pcm);
|
inverse2(vb,look->floor_look[submap],floormemo[i],pcm);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//for(j=0;j<vi->channels;j++)
|
//for(j=0;j<vi->channels;j++)
|
||||||
//_analysis_output("mdct",seq+j,vb->pcm[j],-24,n/2,0,1);
|
//_analysis_output("mdct",seq+j,vb->pcm[j],-24,n/2,0,1);
|
||||||
|
|
||||||
/* transform the PCM data; takes PCM vector, vb; modifies PCM vector */
|
/* transform the PCM data; takes PCM vector, vb; modifies PCM vector */
|
||||||
/* only MDCT right now.... */
|
/* only MDCT right now.... */
|
||||||
for(i=0;i<vi->channels;i++){
|
|
||||||
ogg_int32_t *pcm=vb->pcm[i];
|
/* check if we can do this in IRAM */
|
||||||
mdct_backward(n,pcm,pcm);
|
if(n <= IRAM_PCM_SIZE) { /* normal window size: yes */
|
||||||
|
for(i=0;i<vi->channels;i++){
|
||||||
|
ogg_int32_t *pcm=vb->pcm[i];
|
||||||
|
int submap=info->chmuxlist[i];
|
||||||
|
|
||||||
|
if(nonzero[i]) {
|
||||||
|
memcpy(pcm_iram, pcm, sizeof(ogg_int32_t)*n);
|
||||||
|
look->floor_func[submap]->
|
||||||
|
inverse2(vb,look->floor_look[submap],floormemo[i],pcm_iram);
|
||||||
|
mdct_backward(n, pcm_iram, pcm_iram);
|
||||||
|
/* window the data */
|
||||||
|
_vorbis_apply_window(pcm_iram,b->window,ci->blocksizes,vb->lW,vb->W,vb->nW);
|
||||||
|
memcpy(pcm, pcm_iram, sizeof(ogg_int32_t)*n);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
memset(pcm, 0, sizeof(ogg_int32_t)*n);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else { /* large window: no, do it in the normal memory */
|
||||||
|
for(i=0;i<vi->channels;i++){
|
||||||
|
ogg_int32_t *pcm=vb->pcm[i];
|
||||||
|
int submap=info->chmuxlist[i];
|
||||||
|
|
||||||
|
look->floor_func[submap]->
|
||||||
|
inverse2(vb,look->floor_look[submap],floormemo[i],pcm);
|
||||||
|
if(nonzero[i]) {
|
||||||
|
mdct_backward(n, pcm, pcm);
|
||||||
|
/* window the data */
|
||||||
|
_vorbis_apply_window(pcm,b->window,ci->blocksizes,vb->lW,vb->W,vb->nW);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
memset(pcm, 0, sizeof(ogg_int32_t)*n);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//for(j=0;j<vi->channels;j++)
|
//for(j=0;j<vi->channels;j++)
|
||||||
//_analysis_output("imdct",seq+j,vb->pcm[j],-24,n,0,0);
|
//_analysis_output("imdct",seq+j,vb->pcm[j],-24,n,0,0);
|
||||||
|
|
||||||
/* window the data */
|
|
||||||
for(i=0;i<vi->channels;i++){
|
|
||||||
ogg_int32_t *pcm=vb->pcm[i];
|
|
||||||
if(nonzero[i])
|
|
||||||
_vorbis_apply_window(pcm,b->window,ci->blocksizes,vb->lW,vb->W,vb->nW);
|
|
||||||
else
|
|
||||||
for(j=0;j<n;j++)
|
|
||||||
pcm[j]=0;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
//for(j=0;j<vi->channels;j++)
|
//for(j=0;j<vi->channels;j++)
|
||||||
//_analysis_output("window",seq+j,vb->pcm[j],-24,n,0,0);
|
//_analysis_output("window",seq+j,vb->pcm[j],-24,n,0,0);
|
||||||
|
|
||||||
|
@ -313,10 +356,11 @@ static int mapping0_inverse(vorbis_block *vb,vorbis_look_mapping *l){
|
||||||
}
|
}
|
||||||
|
|
||||||
/* export hooks */
|
/* export hooks */
|
||||||
vorbis_func_mapping mapping0_exportbundle={
|
vorbis_func_mapping mapping0_exportbundle ={
|
||||||
&mapping0_unpack,
|
&mapping0_unpack,
|
||||||
&mapping0_look,
|
&mapping0_look,
|
||||||
&mapping0_free_info,
|
&mapping0_free_info,
|
||||||
&mapping0_free_look,
|
&mapping0_free_look,
|
||||||
&mapping0_inverse
|
&mapping0_inverse
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -94,7 +94,7 @@ STIN void mdct_butterfly_16(DATA_TYPE *x){
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 32 point butterfly (in place, 4 register) */
|
/* 32 point butterfly (in place, 4 register) */
|
||||||
STIN void mdct_butterfly_32(DATA_TYPE *x){
|
STIN void mdct_butterfly_32(DATA_TYPE *x){
|
||||||
|
|
||||||
REG_TYPE r0, r1;
|
REG_TYPE r0, r1;
|
||||||
|
|
||||||
|
@ -231,7 +231,7 @@ STIN void mdct_butterfly_generic(DATA_TYPE *x,int points,int step){
|
||||||
}while(T>sincos_lookup0);
|
}while(T>sincos_lookup0);
|
||||||
}
|
}
|
||||||
|
|
||||||
STIN void mdct_butterflies(DATA_TYPE *x,int points,int shift){
|
STIN void mdct_butterflies(DATA_TYPE *x,int points,int shift) {
|
||||||
|
|
||||||
int stages=8-shift;
|
int stages=8-shift;
|
||||||
int i,j;
|
int i,j;
|
||||||
|
@ -243,33 +243,34 @@ STIN void mdct_butterflies(DATA_TYPE *x,int points,int shift){
|
||||||
|
|
||||||
for(j=0;j<points;j+=32)
|
for(j=0;j<points;j+=32)
|
||||||
mdct_butterfly_32(x+j);
|
mdct_butterfly_32(x+j);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned char bitrev[16]={0,8,4,12,2,10,6,14,1,9,5,13,3,11,7,15};
|
|
||||||
|
static const unsigned char bitrev[16]
|
||||||
|
IDATA_ATTR = {0,8,4,12,2,10,6,14,1,9,5,13,3,11,7,15};
|
||||||
|
|
||||||
STIN int bitrev12(int x){
|
STIN int bitrev12(int x){
|
||||||
return bitrev[x>>8]|(bitrev[(x&0x0f0)>>4]<<4)|(((int)bitrev[x&0x00f])<<8);
|
return bitrev[x>>8]|(bitrev[(x&0x0f0)>>4]<<4)|(((int)bitrev[x&0x00f])<<8);
|
||||||
}
|
}
|
||||||
|
|
||||||
STIN void mdct_bitreverse(DATA_TYPE *x,int n,int step,int shift){
|
STIN void mdct_bitreverse(DATA_TYPE *x,int n,int step,int shift) {
|
||||||
|
|
||||||
int bit = 0;
|
int bit = 0;
|
||||||
DATA_TYPE *w0 = x;
|
DATA_TYPE *w0 = x;
|
||||||
DATA_TYPE *w1 = x = w0+(n>>1);
|
DATA_TYPE *w1 = x = w0+(n>>1);
|
||||||
LOOKUP_T *T = (step>=4)?(sincos_lookup0+(step>>1)):sincos_lookup1;
|
LOOKUP_T *T = (step>=4)?(sincos_lookup0+(step>>1)):sincos_lookup1;
|
||||||
LOOKUP_T *Ttop = T+1024;
|
LOOKUP_T *Ttop = T+1024;
|
||||||
DATA_TYPE r2;
|
REG_TYPE r2;
|
||||||
|
|
||||||
do{
|
do{
|
||||||
DATA_TYPE r3 = bitrev12(bit++);
|
REG_TYPE r3 = bitrev12(bit++);
|
||||||
DATA_TYPE *x0 = x + ((r3 ^ 0xfff)>>shift) -1;
|
DATA_TYPE *x0 = x + ((r3 ^ 0xfff)>>shift) -1;
|
||||||
DATA_TYPE *x1 = x + (r3>>shift);
|
DATA_TYPE *x1 = x + (r3>>shift);
|
||||||
|
|
||||||
REG_TYPE r0 = x0[0] + x1[0];
|
REG_TYPE r0 = x0[0] + x1[0];
|
||||||
REG_TYPE r1 = x1[1] - x0[1];
|
REG_TYPE r1 = x1[1] - x0[1];
|
||||||
|
|
||||||
XPROD32( r0, r1, T[1], T[0], &r2, &r3 ); T+=step;
|
XPROD32( r0, r1, T[1], T[0], r2, r3 ); T+=step;
|
||||||
|
|
||||||
w1 -= 4;
|
w1 -= 4;
|
||||||
|
|
||||||
|
@ -287,7 +288,7 @@ STIN void mdct_bitreverse(DATA_TYPE *x,int n,int step,int shift){
|
||||||
r0 = x0[0] + x1[0];
|
r0 = x0[0] + x1[0];
|
||||||
r1 = x1[1] - x0[1];
|
r1 = x1[1] - x0[1];
|
||||||
|
|
||||||
XPROD32( r0, r1, T[1], T[0], &r2, &r3 ); T+=step;
|
XPROD32( r0, r1, T[1], T[0], r2, r3 ); T+=step;
|
||||||
|
|
||||||
r0 = (x0[1] + x1[1])>>1;
|
r0 = (x0[1] + x1[1])>>1;
|
||||||
r1 = (x0[0] - x1[0])>>1;
|
r1 = (x0[0] - x1[0])>>1;
|
||||||
|
@ -299,14 +300,14 @@ STIN void mdct_bitreverse(DATA_TYPE *x,int n,int step,int shift){
|
||||||
w0 += 4;
|
w0 += 4;
|
||||||
}while(T<Ttop);
|
}while(T<Ttop);
|
||||||
do{
|
do{
|
||||||
DATA_TYPE r3 = bitrev12(bit++);
|
REG_TYPE r3 = bitrev12(bit++);
|
||||||
DATA_TYPE *x0 = x + ((r3 ^ 0xfff)>>shift) -1;
|
DATA_TYPE *x0 = x + ((r3 ^ 0xfff)>>shift) -1;
|
||||||
DATA_TYPE *x1 = x + (r3>>shift);
|
DATA_TYPE *x1 = x + (r3>>shift);
|
||||||
|
|
||||||
REG_TYPE r0 = x0[0] + x1[0];
|
REG_TYPE r0 = x0[0] + x1[0];
|
||||||
REG_TYPE r1 = x1[1] - x0[1];
|
REG_TYPE r1 = x1[1] - x0[1];
|
||||||
|
|
||||||
T-=step; XPROD32( r0, r1, T[0], T[1], &r2, &r3 );
|
T-=step; XPROD32( r0, r1, T[0], T[1], r2, r3 );
|
||||||
|
|
||||||
w1 -= 4;
|
w1 -= 4;
|
||||||
|
|
||||||
|
@ -324,7 +325,7 @@ STIN void mdct_bitreverse(DATA_TYPE *x,int n,int step,int shift){
|
||||||
r0 = x0[0] + x1[0];
|
r0 = x0[0] + x1[0];
|
||||||
r1 = x1[1] - x0[1];
|
r1 = x1[1] - x0[1];
|
||||||
|
|
||||||
T-=step; XPROD32( r0, r1, T[0], T[1], &r2, &r3 );
|
T-=step; XPROD32( r0, r1, T[0], T[1], r2, r3 );
|
||||||
|
|
||||||
r0 = (x0[1] + x1[1])>>1;
|
r0 = (x0[1] + x1[1])>>1;
|
||||||
r1 = (x0[0] - x1[0])>>1;
|
r1 = (x0[0] - x1[0])>>1;
|
||||||
|
@ -337,7 +338,8 @@ STIN void mdct_bitreverse(DATA_TYPE *x,int n,int step,int shift){
|
||||||
}while(w0<w1);
|
}while(w0<w1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mdct_backward(int n, DATA_TYPE *in, DATA_TYPE *out){
|
|
||||||
|
void mdct_backward(int n, DATA_TYPE *in, DATA_TYPE *out) {
|
||||||
int n2=n>>1;
|
int n2=n>>1;
|
||||||
int n4=n>>2;
|
int n4=n>>2;
|
||||||
DATA_TYPE *iX;
|
DATA_TYPE *iX;
|
||||||
|
@ -347,6 +349,10 @@ void mdct_backward(int n, DATA_TYPE *in, DATA_TYPE *out){
|
||||||
int shift;
|
int shift;
|
||||||
int step;
|
int step;
|
||||||
|
|
||||||
|
#if CONFIG_CPU == MCF5249
|
||||||
|
mcf5249_init_mac(); /* should be redundant */
|
||||||
|
#endif
|
||||||
|
|
||||||
for (shift=6;!(n&(1<<shift));shift++);
|
for (shift=6;!(n&(1<<shift));shift++);
|
||||||
shift=13-shift;
|
shift=13-shift;
|
||||||
step=2<<shift;
|
step=2<<shift;
|
||||||
|
@ -389,7 +395,6 @@ void mdct_backward(int n, DATA_TYPE *in, DATA_TYPE *out){
|
||||||
|
|
||||||
mdct_butterflies(out+n2,n2,shift);
|
mdct_butterflies(out+n2,n2,shift);
|
||||||
mdct_bitreverse(out,n,step,shift);
|
mdct_bitreverse(out,n,step,shift);
|
||||||
|
|
||||||
/* rotate + window */
|
/* rotate + window */
|
||||||
|
|
||||||
step>>=2;
|
step>>=2;
|
||||||
|
@ -507,4 +512,3 @@ void mdct_backward(int n, DATA_TYPE *in, DATA_TYPE *out){
|
||||||
}while(oX1>oX2);
|
}while(oX1>oX2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,8 +34,10 @@
|
||||||
#define cPI1_8 (0x7641af3d)
|
#define cPI1_8 (0x7641af3d)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern void mdct_forward(int n, DATA_TYPE *in, DATA_TYPE *out);
|
//extern void mdct_forward(int n, DATA_TYPE *in, DATA_TYPE *out);
|
||||||
extern void mdct_backward(int n, DATA_TYPE *in, DATA_TYPE *out);
|
extern void mdct_backward(int n, DATA_TYPE *in, DATA_TYPE *out);
|
||||||
|
//extern void mdct_bitreverse(DATA_TYPE *x,int n,int step,int shift);
|
||||||
|
//extern void mdct_butterflies(DATA_TYPE *x,int points,int shift);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -17,8 +17,10 @@
|
||||||
|
|
||||||
#include "os_types.h"
|
#include "os_types.h"
|
||||||
|
|
||||||
|
/* keep lookup tables in fast IRAM */
|
||||||
|
|
||||||
/* {sin(2*i*PI/4096), cos(2*i*PI/4096)}, with i = 0 to 512 */
|
/* {sin(2*i*PI/4096), cos(2*i*PI/4096)}, with i = 0 to 512 */
|
||||||
static LOOKUP_T sincos_lookup0[1026] = {
|
static LOOKUP_T sincos_lookup0[1026] IDATA_ATTR = {
|
||||||
X(0x00000000), X(0x7fffffff), X(0x003243f5), X(0x7ffff621),
|
X(0x00000000), X(0x7fffffff), X(0x003243f5), X(0x7ffff621),
|
||||||
X(0x006487e3), X(0x7fffd886), X(0x0096cbc1), X(0x7fffa72c),
|
X(0x006487e3), X(0x7fffd886), X(0x0096cbc1), X(0x7fffa72c),
|
||||||
X(0x00c90f88), X(0x7fff6216), X(0x00fb5330), X(0x7fff0943),
|
X(0x00c90f88), X(0x7fff6216), X(0x00fb5330), X(0x7fff0943),
|
||||||
|
@ -279,7 +281,7 @@ static LOOKUP_T sincos_lookup0[1026] = {
|
||||||
};
|
};
|
||||||
|
|
||||||
/* {sin((2*i+1)*PI/4096), cos((2*i+1)*PI/4096)}, with i = 0 to 511 */
|
/* {sin((2*i+1)*PI/4096), cos((2*i+1)*PI/4096)}, with i = 0 to 511 */
|
||||||
static LOOKUP_T sincos_lookup1[1024] = {
|
static LOOKUP_T sincos_lookup1[1024] IDATA_ATTR = {
|
||||||
X(0x001921fb), X(0x7ffffd88), X(0x004b65ee), X(0x7fffe9cb),
|
X(0x001921fb), X(0x7ffffd88), X(0x004b65ee), X(0x7fffe9cb),
|
||||||
X(0x007da9d4), X(0x7fffc251), X(0x00afeda8), X(0x7fff8719),
|
X(0x007da9d4), X(0x7fffc251), X(0x00afeda8), X(0x7fff8719),
|
||||||
X(0x00e23160), X(0x7fff3824), X(0x011474f6), X(0x7ffed572),
|
X(0x00e23160), X(0x7fff3824), X(0x011474f6), X(0x7ffed572),
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#include "os_types.h"
|
#include "os_types.h"
|
||||||
|
|
||||||
#include "asm_arm.h"
|
#include "asm_arm.h"
|
||||||
|
#include "asm_mcf5249.h"
|
||||||
|
|
||||||
|
|
||||||
/* Some prototypes that were not defined elsewhere */
|
/* Some prototypes that were not defined elsewhere */
|
||||||
|
@ -36,7 +37,6 @@ void* alloca(size_t size);
|
||||||
|
|
||||||
#ifndef _LOW_ACCURACY_
|
#ifndef _LOW_ACCURACY_
|
||||||
/* 64 bit multiply */
|
/* 64 bit multiply */
|
||||||
|
|
||||||
//#include <sys/types.h>
|
//#include <sys/types.h>
|
||||||
|
|
||||||
#if BYTE_ORDER==LITTLE_ENDIAN
|
#if BYTE_ORDER==LITTLE_ENDIAN
|
||||||
|
@ -47,9 +47,7 @@ union magic {
|
||||||
} halves;
|
} halves;
|
||||||
ogg_int64_t whole;
|
ogg_int64_t whole;
|
||||||
};
|
};
|
||||||
#endif
|
#elif BYTE_ORDER==BIG_ENDIAN
|
||||||
|
|
||||||
#if BYTE_ORDER==BIG_ENDIAN
|
|
||||||
union magic {
|
union magic {
|
||||||
struct {
|
struct {
|
||||||
ogg_int32_t hi;
|
ogg_int32_t hi;
|
||||||
|
@ -64,7 +62,6 @@ static inline ogg_int32_t MULT32(ogg_int32_t x, ogg_int32_t y) {
|
||||||
magic.whole = (ogg_int64_t)x * y;
|
magic.whole = (ogg_int64_t)x * y;
|
||||||
return magic.halves.hi;
|
return magic.halves.hi;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline ogg_int32_t MULT31(ogg_int32_t x, ogg_int32_t y) {
|
static inline ogg_int32_t MULT31(ogg_int32_t x, ogg_int32_t y) {
|
||||||
return MULT32(x,y)<<1;
|
return MULT32(x,y)<<1;
|
||||||
}
|
}
|
||||||
|
@ -102,7 +99,6 @@ static inline ogg_int32_t MULT31(ogg_int32_t x, ogg_int32_t y) {
|
||||||
static inline ogg_int32_t MULT31_SHIFT15(ogg_int32_t x, ogg_int32_t y) {
|
static inline ogg_int32_t MULT31_SHIFT15(ogg_int32_t x, ogg_int32_t y) {
|
||||||
return (x >> 6) * y; /* y preshifted >>9 */
|
return (x >> 6) * y; /* y preshifted >>9 */
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -122,11 +118,15 @@ static inline ogg_int32_t MULT31_SHIFT15(ogg_int32_t x, ogg_int32_t y) {
|
||||||
* macros.
|
* macros.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* replaced XPROD32 with a macro to avoid memory reference
|
||||||
|
_x, _y are the results (must be l-values) */
|
||||||
|
#define XPROD32(_a, _b, _t, _v, _x, _y) \
|
||||||
|
{ (_x)=MULT32(_a,_t)+MULT32(_b,_v); \
|
||||||
|
(_y)=MULT32(_b,_t)-MULT32(_a,_v); }
|
||||||
|
|
||||||
|
|
||||||
#ifdef __i386__
|
#ifdef __i386__
|
||||||
|
|
||||||
#define XPROD32(_a, _b, _t, _v, _x, _y) \
|
|
||||||
{ *(_x)=MULT32(_a,_t)+MULT32(_b,_v); \
|
|
||||||
*(_y)=MULT32(_b,_t)-MULT32(_a,_v); }
|
|
||||||
#define XPROD31(_a, _b, _t, _v, _x, _y) \
|
#define XPROD31(_a, _b, _t, _v, _x, _y) \
|
||||||
{ *(_x)=MULT31(_a,_t)+MULT31(_b,_v); \
|
{ *(_x)=MULT31(_a,_t)+MULT31(_b,_v); \
|
||||||
*(_y)=MULT31(_b,_t)-MULT31(_a,_v); }
|
*(_y)=MULT31(_b,_t)-MULT31(_a,_v); }
|
||||||
|
@ -136,14 +136,6 @@ static inline ogg_int32_t MULT31_SHIFT15(ogg_int32_t x, ogg_int32_t y) {
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
static inline void XPROD32(ogg_int32_t a, ogg_int32_t b,
|
|
||||||
ogg_int32_t t, ogg_int32_t v,
|
|
||||||
ogg_int32_t *x, ogg_int32_t *y)
|
|
||||||
{
|
|
||||||
*x = MULT32(a, t) + MULT32(b, v);
|
|
||||||
*y = MULT32(b, t) - MULT32(a, v);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void XPROD31(ogg_int32_t a, ogg_int32_t b,
|
static inline void XPROD31(ogg_int32_t a, ogg_int32_t b,
|
||||||
ogg_int32_t t, ogg_int32_t v,
|
ogg_int32_t t, ogg_int32_t v,
|
||||||
ogg_int32_t *x, ogg_int32_t *y)
|
ogg_int32_t *x, ogg_int32_t *y)
|
||||||
|
@ -159,9 +151,7 @@ static inline void XNPROD31(ogg_int32_t a, ogg_int32_t b,
|
||||||
*x = MULT31(a, t) - MULT31(b, v);
|
*x = MULT31(a, t) - MULT31(b, v);
|
||||||
*y = MULT31(b, t) + MULT31(a, v);
|
*y = MULT31(b, t) + MULT31(a, v);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef _V_CLIP_MATH
|
#ifndef _V_CLIP_MATH
|
||||||
|
@ -245,4 +235,3 @@ static inline ogg_int32_t VFLOAT_ADD(ogg_int32_t a,ogg_int32_t ap,
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -24,12 +24,12 @@
|
||||||
# define _V_IFDEFJAIL_H_
|
# define _V_IFDEFJAIL_H_
|
||||||
|
|
||||||
# ifdef __GNUC__
|
# ifdef __GNUC__
|
||||||
# define STIN static __inline__
|
# define STIN static inline
|
||||||
# elif _WIN32
|
# elif _WIN32
|
||||||
# define STIN static __inline
|
# define STIN static __inline__
|
||||||
# endif
|
# endif
|
||||||
#else
|
#else
|
||||||
# define STIN static
|
# define STIN static inline
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef M_PI
|
#ifndef M_PI
|
||||||
|
|
|
@ -31,18 +31,18 @@ extern vorbis_func_residue residue1_exportbundle;
|
||||||
extern vorbis_func_residue residue2_exportbundle;
|
extern vorbis_func_residue residue2_exportbundle;
|
||||||
extern vorbis_func_mapping mapping0_exportbundle;
|
extern vorbis_func_mapping mapping0_exportbundle;
|
||||||
|
|
||||||
vorbis_func_floor *_floor_P[]={
|
vorbis_func_floor *_floor_P[] = {
|
||||||
&floor0_exportbundle,
|
&floor0_exportbundle,
|
||||||
&floor1_exportbundle,
|
&floor1_exportbundle,
|
||||||
};
|
};
|
||||||
|
|
||||||
vorbis_func_residue *_residue_P[]={
|
vorbis_func_residue *_residue_P[] = {
|
||||||
&residue0_exportbundle,
|
&residue0_exportbundle,
|
||||||
&residue1_exportbundle,
|
&residue1_exportbundle,
|
||||||
&residue2_exportbundle,
|
&residue2_exportbundle,
|
||||||
};
|
};
|
||||||
|
|
||||||
vorbis_func_mapping *_mapping_P[]={
|
vorbis_func_mapping *_mapping_P[] = {
|
||||||
&mapping0_exportbundle,
|
&mapping0_exportbundle,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -309,7 +309,7 @@ int res2_inverse(vorbis_block *vb,vorbis_look_residue *vl,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
vorbis_func_residue residue0_exportbundle={
|
const vorbis_func_residue residue0_exportbundle ={
|
||||||
&res0_unpack,
|
&res0_unpack,
|
||||||
&res0_look,
|
&res0_look,
|
||||||
&res0_free_info,
|
&res0_free_info,
|
||||||
|
@ -317,7 +317,7 @@ vorbis_func_residue residue0_exportbundle={
|
||||||
&res0_inverse
|
&res0_inverse
|
||||||
};
|
};
|
||||||
|
|
||||||
vorbis_func_residue residue1_exportbundle={
|
const vorbis_func_residue residue1_exportbundle ={
|
||||||
&res0_unpack,
|
&res0_unpack,
|
||||||
&res0_look,
|
&res0_look,
|
||||||
&res0_free_info,
|
&res0_free_info,
|
||||||
|
@ -325,7 +325,7 @@ vorbis_func_residue residue1_exportbundle={
|
||||||
&res1_inverse
|
&res1_inverse
|
||||||
};
|
};
|
||||||
|
|
||||||
vorbis_func_residue residue2_exportbundle={
|
const vorbis_func_residue residue2_exportbundle ={
|
||||||
&res0_unpack,
|
&res0_unpack,
|
||||||
&res0_look,
|
&res0_look,
|
||||||
&res0_free_info,
|
&res0_free_info,
|
||||||
|
|
|
@ -669,6 +669,10 @@ static int _ov_open1(void *f,OggVorbis_File *vf,char *initial,
|
||||||
int offsettest=(f?callbacks.seek_func(f,0,SEEK_CUR):-1);
|
int offsettest=(f?callbacks.seek_func(f,0,SEEK_CUR):-1);
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
#if CONFIG_CPU == MCF5249
|
||||||
|
mcf5249_init_mac(); /* initialize the Coldfire MAC unit */
|
||||||
|
#endif
|
||||||
|
|
||||||
memset(vf,0,sizeof(*vf));
|
memset(vf,0,sizeof(*vf));
|
||||||
vf->datasource=f;
|
vf->datasource=f;
|
||||||
vf->callbacks = callbacks;
|
vf->callbacks = callbacks;
|
||||||
|
|
|
@ -56,7 +56,6 @@ const void *_vorbis_window(int type, int left){
|
||||||
void _vorbis_apply_window(ogg_int32_t *d,const void *window_p[2],
|
void _vorbis_apply_window(ogg_int32_t *d,const void *window_p[2],
|
||||||
long *blocksizes,
|
long *blocksizes,
|
||||||
int lW,int W,int nW){
|
int lW,int W,int nW){
|
||||||
|
|
||||||
LOOKUP_T *window[2]={window_p[0],window_p[1]};
|
LOOKUP_T *window[2]={window_p[0],window_p[1]};
|
||||||
long n=blocksizes[W];
|
long n=blocksizes[W];
|
||||||
long ln=blocksizes[lW];
|
long ln=blocksizes[lW];
|
||||||
|
@ -68,6 +67,13 @@ void _vorbis_apply_window(ogg_int32_t *d,const void *window_p[2],
|
||||||
long rightbegin=n/2+n/4-rn/4;
|
long rightbegin=n/2+n/4-rn/4;
|
||||||
long rightend=rightbegin+rn/2;
|
long rightend=rightbegin+rn/2;
|
||||||
|
|
||||||
|
#if CONFIG_CPU == MCF5249
|
||||||
|
mcf5249_init_mac(); /* shouldn't be needed, but just in case */
|
||||||
|
mcf5249_vect_zero(&d[0], leftbegin);
|
||||||
|
mcf5249_vect_mult_fw(&d[leftbegin], &window[lW][0], leftend-leftbegin);
|
||||||
|
mcf5249_vect_mult_bw(&d[rightbegin], &window[nW][rn/2-1], rightend-rightbegin);
|
||||||
|
mcf5249_vect_zero(&d[rightend], n-rightend);
|
||||||
|
#else
|
||||||
int i,p;
|
int i,p;
|
||||||
|
|
||||||
for(i=0;i<leftbegin;i++)
|
for(i=0;i<leftbegin;i++)
|
||||||
|
@ -81,4 +87,6 @@ void _vorbis_apply_window(ogg_int32_t *d,const void *window_p[2],
|
||||||
|
|
||||||
for(;i<n;i++)
|
for(;i<n;i++)
|
||||||
d[i]=0;
|
d[i]=0;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,8 @@
|
||||||
|
|
||||||
#include "os_types.h"
|
#include "os_types.h"
|
||||||
|
|
||||||
static LOOKUP_T vwin64[32] = {
|
/* keep small window table in fast IRAM */
|
||||||
|
static LOOKUP_T vwin64[32] IDATA_ATTR = {
|
||||||
X(0x001f0003), X(0x01168c98), X(0x030333c8), X(0x05dfe3a4),
|
X(0x001f0003), X(0x01168c98), X(0x030333c8), X(0x05dfe3a4),
|
||||||
X(0x09a49562), X(0x0e45df18), X(0x13b47ef2), X(0x19dcf676),
|
X(0x09a49562), X(0x0e45df18), X(0x13b47ef2), X(0x19dcf676),
|
||||||
X(0x20a74d83), X(0x27f7137c), X(0x2fabb05a), X(0x37a1105a),
|
X(0x20a74d83), X(0x27f7137c), X(0x2fabb05a), X(0x37a1105a),
|
||||||
|
@ -29,7 +30,7 @@ static LOOKUP_T vwin64[32] = {
|
||||||
X(0x7fdd78a5), X(0x7ff6ec6d), X(0x7ffed0e9), X(0x7ffffc3f),
|
X(0x7fdd78a5), X(0x7ff6ec6d), X(0x7ffed0e9), X(0x7ffffc3f),
|
||||||
};
|
};
|
||||||
|
|
||||||
static LOOKUP_T vwin128[64] = {
|
static LOOKUP_T vwin128[64] IDATA_ATTR = {
|
||||||
X(0x0007c04d), X(0x0045bb89), X(0x00c18b87), X(0x017ae294),
|
X(0x0007c04d), X(0x0045bb89), X(0x00c18b87), X(0x017ae294),
|
||||||
X(0x02714a4e), X(0x03a4217a), X(0x05129952), X(0x06bbb24f),
|
X(0x02714a4e), X(0x03a4217a), X(0x05129952), X(0x06bbb24f),
|
||||||
X(0x089e38a1), X(0x0ab8c073), X(0x0d09a228), X(0x0f8ef6bd),
|
X(0x089e38a1), X(0x0ab8c073), X(0x0d09a228), X(0x0f8ef6bd),
|
||||||
|
@ -48,7 +49,7 @@ static LOOKUP_T vwin128[64] = {
|
||||||
X(0x7ffdcf39), X(0x7fff6dac), X(0x7fffed01), X(0x7fffffc4),
|
X(0x7ffdcf39), X(0x7fff6dac), X(0x7fffed01), X(0x7fffffc4),
|
||||||
};
|
};
|
||||||
|
|
||||||
static LOOKUP_T vwin256[128] = {
|
static LOOKUP_T vwin256[128] IDATA_ATTR = {
|
||||||
X(0x0001f018), X(0x00117066), X(0x00306e9e), X(0x005ee5f1),
|
X(0x0001f018), X(0x00117066), X(0x00306e9e), X(0x005ee5f1),
|
||||||
X(0x009ccf26), X(0x00ea208b), X(0x0146cdea), X(0x01b2c87f),
|
X(0x009ccf26), X(0x00ea208b), X(0x0146cdea), X(0x01b2c87f),
|
||||||
X(0x022dfedf), X(0x02b85ced), X(0x0351cbbd), X(0x03fa317f),
|
X(0x022dfedf), X(0x02b85ced), X(0x0351cbbd), X(0x03fa317f),
|
||||||
|
@ -83,7 +84,7 @@ static LOOKUP_T vwin256[128] = {
|
||||||
X(0x7fffdcd2), X(0x7ffff6d6), X(0x7ffffed0), X(0x7ffffffc),
|
X(0x7fffdcd2), X(0x7ffff6d6), X(0x7ffffed0), X(0x7ffffffc),
|
||||||
};
|
};
|
||||||
|
|
||||||
static LOOKUP_T vwin512[256] = {
|
static LOOKUP_T vwin512[256] IDATA_ATTR = {
|
||||||
X(0x00007c06), X(0x00045c32), X(0x000c1c62), X(0x0017bc4c),
|
X(0x00007c06), X(0x00045c32), X(0x000c1c62), X(0x0017bc4c),
|
||||||
X(0x00273b7a), X(0x003a9955), X(0x0051d51c), X(0x006cede7),
|
X(0x00273b7a), X(0x003a9955), X(0x0051d51c), X(0x006cede7),
|
||||||
X(0x008be2a9), X(0x00aeb22a), X(0x00d55b0d), X(0x00ffdbcc),
|
X(0x008be2a9), X(0x00aeb22a), X(0x00d55b0d), X(0x00ffdbcc),
|
||||||
|
@ -150,7 +151,7 @@ static LOOKUP_T vwin512[256] = {
|
||||||
X(0x7ffffdcd), X(0x7fffff6d), X(0x7fffffed), X(0x7fffffff),
|
X(0x7ffffdcd), X(0x7fffff6d), X(0x7fffffed), X(0x7fffffff),
|
||||||
};
|
};
|
||||||
|
|
||||||
static LOOKUP_T vwin1024[512] = {
|
static LOOKUP_T vwin1024[512] IDATA_ATTR = {
|
||||||
X(0x00001f02), X(0x0001170e), X(0x00030724), X(0x0005ef40),
|
X(0x00001f02), X(0x0001170e), X(0x00030724), X(0x0005ef40),
|
||||||
X(0x0009cf59), X(0x000ea767), X(0x0014775e), X(0x001b3f2e),
|
X(0x0009cf59), X(0x000ea767), X(0x0014775e), X(0x001b3f2e),
|
||||||
X(0x0022fec8), X(0x002bb618), X(0x00356508), X(0x00400b81),
|
X(0x0022fec8), X(0x002bb618), X(0x00356508), X(0x00400b81),
|
||||||
|
@ -281,7 +282,7 @@ static LOOKUP_T vwin1024[512] = {
|
||||||
X(0x7fffffdd), X(0x7ffffff7), X(0x7fffffff), X(0x7fffffff),
|
X(0x7fffffdd), X(0x7ffffff7), X(0x7fffffff), X(0x7fffffff),
|
||||||
};
|
};
|
||||||
|
|
||||||
static LOOKUP_T vwin2048[1024] = {
|
static LOOKUP_T vwin2048[1024] IDATA_ATTR = {
|
||||||
X(0x000007c0), X(0x000045c4), X(0x0000c1ca), X(0x00017bd3),
|
X(0x000007c0), X(0x000045c4), X(0x0000c1ca), X(0x00017bd3),
|
||||||
X(0x000273de), X(0x0003a9eb), X(0x00051df9), X(0x0006d007),
|
X(0x000273de), X(0x0003a9eb), X(0x00051df9), X(0x0006d007),
|
||||||
X(0x0008c014), X(0x000aee1e), X(0x000d5a25), X(0x00100428),
|
X(0x0008c014), X(0x000aee1e), X(0x000d5a25), X(0x00100428),
|
||||||
|
@ -540,6 +541,8 @@ static LOOKUP_T vwin2048[1024] = {
|
||||||
X(0x7ffffffe), X(0x7fffffff), X(0x7fffffff), X(0x7fffffff),
|
X(0x7ffffffe), X(0x7fffffff), X(0x7fffffff), X(0x7fffffff),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* The remaining large window sizes are used only for very low
|
||||||
|
quality Vorbis files so we don't bother to put them in IRAM */
|
||||||
static LOOKUP_T vwin4096[2048] = {
|
static LOOKUP_T vwin4096[2048] = {
|
||||||
X(0x000001f0), X(0x00001171), X(0x00003072), X(0x00005ef5),
|
X(0x000001f0), X(0x00001171), X(0x00003072), X(0x00005ef5),
|
||||||
X(0x00009cf8), X(0x0000ea7c), X(0x00014780), X(0x0001b405),
|
X(0x00009cf8), X(0x0000ea7c), X(0x00014780), X(0x0001b405),
|
||||||
|
@ -1055,7 +1058,7 @@ static LOOKUP_T vwin4096[2048] = {
|
||||||
X(0x7fffffff), X(0x7fffffff), X(0x7fffffff), X(0x7fffffff),
|
X(0x7fffffff), X(0x7fffffff), X(0x7fffffff), X(0x7fffffff),
|
||||||
};
|
};
|
||||||
|
|
||||||
static LOOKUP_T vwin8192[4096] = {
|
static LOOKUP_T vwin8192[4096] = {
|
||||||
X(0x0000007c), X(0x0000045c), X(0x00000c1d), X(0x000017bd),
|
X(0x0000007c), X(0x0000045c), X(0x00000c1d), X(0x000017bd),
|
||||||
X(0x0000273e), X(0x00003a9f), X(0x000051e0), X(0x00006d02),
|
X(0x0000273e), X(0x00003a9f), X(0x000051e0), X(0x00006d02),
|
||||||
X(0x00008c03), X(0x0000aee5), X(0x0000d5a7), X(0x00010049),
|
X(0x00008c03), X(0x0000aee5), X(0x0000d5a7), X(0x00010049),
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
#include "kernel.h"
|
||||||
#include "plugin.h"
|
#include "plugin.h"
|
||||||
|
|
||||||
#if (CONFIG_HWCODEC == MASNONE)
|
#if (CONFIG_HWCODEC == MASNONE)
|
||||||
|
@ -86,6 +86,10 @@ extern char iramstart[];
|
||||||
extern char iramend[];
|
extern char iramend[];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* reserve the PCM buffer in the IRAM area */
|
||||||
|
static char pcmbuf[4096] IDATA_ATTR;
|
||||||
|
|
||||||
/* this is the plugin entry point */
|
/* this is the plugin entry point */
|
||||||
enum plugin_status plugin_start(struct plugin_api* api, void* file)
|
enum plugin_status plugin_start(struct plugin_api* api, void* file)
|
||||||
{
|
{
|
||||||
|
@ -97,7 +101,6 @@ enum plugin_status plugin_start(struct plugin_api* api, void* file)
|
||||||
long n;
|
long n;
|
||||||
int current_section;
|
int current_section;
|
||||||
int eof;
|
int eof;
|
||||||
static char pcmbuf[4096];
|
|
||||||
#if BYTE_ORDER == BIG_ENDIAN
|
#if BYTE_ORDER == BIG_ENDIAN
|
||||||
int i;
|
int i;
|
||||||
char x;
|
char x;
|
||||||
|
@ -121,6 +124,7 @@ enum plugin_status plugin_start(struct plugin_api* api, void* file)
|
||||||
return PLUGIN_ERROR;
|
return PLUGIN_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Create a decoder instance */
|
/* Create a decoder instance */
|
||||||
|
|
||||||
callbacks.read_func=read_handler;
|
callbacks.read_func=read_handler;
|
||||||
|
@ -171,7 +175,6 @@ enum plugin_status plugin_start(struct plugin_api* api, void* file)
|
||||||
|
|
||||||
close_wav(&file_info);
|
close_wav(&file_info);
|
||||||
rb->splash(HZ*2, true, "FINISHED!");
|
rb->splash(HZ*2, true, "FINISHED!");
|
||||||
|
|
||||||
return PLUGIN_OK;
|
return PLUGIN_OK;
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_HWCODEC == MASNONE */
|
#endif /* CONFIG_HWCODEC == MASNONE */
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue