[CELT-dev] Porting CELt to the C5505

Jean-Marc Valin jean-marc.valin at usherbrooke.ca
Tue Dec 29 16:42:43 PST 2009


Well, obviously if you replace alloca() by malloc(), it's only a matter 
of time 'til you run out of memory. I'm really surprised that the 
compiler doesn't support either alloca() or C99 variable-length arrays. 
The only other option is to fall back on the "pseudo stack", which is 
the default. Any reason this doesn't work?

	Jean-Marc

On 2009-12-29 15:33, Cave, Tony wrote:
> Jean-Marc,
>
> Sorry I have not got back to you, I had a lot to finish off on the run
> up to Xmas vacations. I suspect I have introduced a memory leak. If I
> increase the heap then it increases the number of iteration of encode
> before the crash.
>
> I suspect it is because the modification I made below in stack_alloc.h.
> I made this because I had no alloca function.
>
> /#elif defined(USE_ALLOCA)/
>
> / /
>
> /#define VARDECL(type, var) type *var/
>
> /#define ALLOC(var, size, type) var =
> ((type*)*malloc/*alloca*/(sizeof(type)*(size)));
> memset(var,0,sizeof(type)*(size))*/
>
> /#define SAVE_STACK/
>
> /#define RESTORE_STACK/
>
> /#define ALLOC_STACK/
>
> / /
>
> /#else/
>
> (I attached the file for reference).
>
> I am almost convinced this is the issue as the alloc a would be coming
> out of the heap and not the stack. Can you suggest a better way of
> implementing this? Or a way to make the de-alloc come from the heap
> (i.e. free the malloc)?
>
> Regards,
>
> Tony.
>
> Texas Instruments Limited, 800 Pavilion Drive, Northampton, NN4 7YL.
> Registered in England & Wales under company number 00574102
>
> -----Original Message-----
>
>
> From: Jean-Marc Valin [mailto:Jean-Marc.Valin at USherbrooke.ca]
> Sent: 17 December 2009 16:34
> To: Cave, Tony
> Cc: celt-dev at xiph.org
> Subject: RE: [CELT-dev] Porting CELt to the C5505
>
> Quoting "Cave, Tony" <t-cave at ti.com>:
>
>>  Jean-Marc,
>
>>  I have the codec and testcelt.c building and running, but after 5
>
>>  encode/decode (or 10 enc only) cycles I see something that looks like it
>
>>  popped the stack. What are the stack size requirements?
>
> If it doesn't overflow the stack on the first call, I don't see how it
> would do
>
> so later. What probably happens is that for some reason the stack is never
>
> restored back to its normal value. But just in case, try increasing it a
> bit.
>
> What frame size/number of channels are you using?
>
> Jean-Marc
>
>>  Regards,
>
>>  Tony.
>
>>
>
>>
>
>>  Texas Instruments Limited, 800 Pavilion Drive, Northampton, NN4 7YL.
>
>>  Registered in England & Wales under company number 00574102
>
>>
>
>>  -----Original Message-----
>
>>
>
>>  From: Jean-Marc Valin [mailto:jean-marc.valin at usherbrooke.ca]
>
>>  Sent: 17 December 2009 12:03
>
>>  To: Cave, Tony
>
>>  Cc: celt-dev at xiph.org; Peake, Greg
>
>>  Subject: Re: [CELT-dev] Porting CELt to the C5505
>
>>
>
>>  Hi Tony,
>
>>
>
>>  What do you mean by "create an alloca.h" doesn't the compiler have one?
>
>>  If not, then you might as well create a definition for the VARDECL() and
>
>>  ALLOC() macros (see stack_alloc.h). I would be interested in merging bac
>
>>  the changes. The best way to do that is to send a patch. Ideally, the
>
>>  arch-dependent changes should be clearly separated from the
>
>>  arch-dependent code (within #ifdef or separate file).
>
>>
>
>>  Cheers,
>
>>
>
>>  Jean-Marc
>
>>
>
>>
>
>>  On 17/12/09 03:14, Cave, Tony wrote:
>
>>  > Jean-Marc, Thank you for the tips. I think I have solved the stack
>
>>  > issue (I noticed the C99 array issue and avoided this). I will
>
>>  > probably create an alloca.h (I think this is the correct thing to
>
>>  > do). I am happy to feed back any work I do, if you want me to do this
>
>>  > what is the process?
>
>>  >
>
>>  > Tony.
>
>>  >
>
>>  >
>
>>  > Texas Instruments Limited, 800 Pavilion Drive, Northampton, NN4 7YL.
>
>>  > Registered in England& Wales under company number 00574102
>
>>  >
>
>>  > ----- Original Message -----
>
>>  >
>
>>  > From: Jean-Marc Valin<jean-marc.valin at usherbrooke.ca> To: Cave, Tony
>
>>  > Cc: celt-dev at xiph.org<celt-dev at xiph.org> Sent: Thu Dec 17 03:18:43
>
>>  > 2009Subject: Re: [CELT-dev] Porting CELt to the C5505
>
>>  >
>
>>  > Hi,
>
>>  >
>
>>  > There's are already some C55-specific optimisations in the code. You
>
>>  > can enable them by defining CONFIG_TI_C55X and ENABLE_TI_DSPLIB. As
>
>>  > for the stack allocation, it's just a fallback for compilers that
>
>>  > don't support C99 arrays and have a broken alloca() -- it's always
>
>>  > best not to use it. Still, can you tell me what problem you are
>
>>  > seeing with it?
>
>>  >
>
>>  > Cheers,
>
>>  >
>
>>  > Jean-Marc
>
>>  >
>
>>  > On 16/12/09 05:38, Cave, Tony wrote:
>
>>  >> Hi,
>
>>  >>
>
>>  >> I am an applications engineer for Texas Instruments in the UK. I
>
>>  >> am trying to port the CELT codec to the C5505, this has HW
>
>>  >> accelerated FFT engine
>
>>  >> (http://focus.ti.com/docs/prod/folders/print/tms320vc5505.html).
>
>>  >>
>
>>  >> I am having problems with the stack allocation. Do you have any
>
>>  >> reference code that compiles for the C55x under CCS (code composer
>
>>  >> studio)?
>
>>  >>
>
>>  >> *******************************
>
>>  >>
>
>>  >> Tony Cave
>
>>  >>
>
>>  >> Senior Embedded Processor FAE
>
>>  >>
>
>>  >> Texas Instruments Limited
>
>>  >>
>
>>  >> 3000 Aviator way
>
>>  >>
>
>>  >> Manchester
>
>>  >>
>
>>  >> M22 5TG
>
>>  >>
>
>>  >> Mb: +44-7917-183293
>
>>  >>
>
>>  >> *******************************
>
>>  >>
>
>>  >> Texas Instruments Limited, 800 Pavilion Drive, Northampton, NN4
>
>>  >> 7YL. Registered in England& Wales under company number 00574102
>
>>  >>
>
>>  >>
>
>>  >>
>
>>  >> _______________________________________________ celt-dev mailing
>
>>  >> list celt-dev at xiph.org
>
>>  >> http://lists.xiph.org/mailman/listinfo/celt-dev
>
>>  >
>
>>  >
>
>>  >
>
>>
>
>>
>
>>
>



More information about the celt-dev mailing list