- May 21, 2013
-
-
Timothy B. Terriberry authored
http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0068b/CIHBJEHG.html says that "Rd cannot be the same as Rm." http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0068b/CIHBJEHG.html says that "RdLo, RdHi, and Rm must all be different registers." This means that some of the early clobbers I removed really should have been there (to prevent aliasing Rd, RdLo, or RdHi with Rm). It also means that we should reverse some of the operands in the FFT's complex multiplies. This should only affect the ARMv4 optimizations. Thanks to Nils Wallménius for the report. While we're here, audit the commutative pair flags again, since I screwed up at least one of them, and eliminate some dead code.
-
- May 20, 2013
-
-
Timothy B. Terriberry authored
Original patch by Aurélien Zanelli <aurelien.zanelli@parrot.com>: http://lists.xiph.org/pipermail/opus/2013-May/002078.html Revised version: - Add autconf detection (ported from libtheora). - Rename ARM5E to ARMv5E (an ARM5 is not the same thing as ARMv5!). - Use actual macros so they can still be selectively overridden. - Split out ARMv4 parts and add a few more ARMv4 macros. - Label blocks to make them easy to find in generated assembly. - Fix MULT16_32_Q15() so we can pass make check. The MDCT test passes in values larger than 2**30 for b. The new version should be just as fast (or faster, since it's easier to merge the shift with following instructions), and there's no appreciable impact on accuracy (FFT/MDCT SNR actually goes up in most cases). - Fix register constraints. We were using early-clobber flags in a bunch of places that didn't need them, and commutative-pair flags in a bunch of places that weren't actually commutative. This was Jean-Marc's fault (the original code came from Speex). - Simplify silk_CLZ16(). - Port over iFFT C_MULC asm by Andree Buschmann <AndreeBuschmann@t-online.de> from Rockbox. - Speed up the C_MULC asm by using LDRD, allowing more flexible addressing, re-ordering instructions to avoid some stalls, allowing more flexible register allocation, and getting things out of the inline asm block so the compiler can schedule them better. - Add C_MUL and C_MUL4 asm for the FFT to the encoder based, on the new C_MULC. In total, this patch gives a 22.3% speed-up on test_opus_encoder on a 600 MHz Cortex A8 using gcc 4.2.1, When restricted to ARMv4 optimizations, it gives a 9.6% speed-up on the same processor/compiler. On the conformance test vectors: Average mono quality is 97.0583 % Average stereo quality is 97.775 %
-
- May 19, 2013
-
-
Jean-Marc Valin authored
-
- May 16, 2012
-
-
Jean-Marc Valin authored
This reverts commit 9f407afa.
-
- Apr 24, 2012
-
-
Jean-Marc Valin authored
-
- Apr 20, 2012
-
-
Jean-Marc Valin authored
Also added 3rd clause to "master" COPYING file
-
- Sep 14, 2011
-
-
Jean-Marc Valin authored
-
- Aug 02, 2011
-
-
Gregory Maxwell authored
-
- Jul 31, 2011
-
-
non-ascii characters from the source.
-
- Jul 29, 2011
-
-
Jean-Marc Valin authored
-
- Feb 10, 2011
-
-
Jean-Marc Valin authored
Got authorization from all copyright holders
-
- Oct 18, 2009
-
-
Jean-Marc Valin authored
-
- Apr 10, 2008
-
-
Jean-Marc Valin authored
coder
-
- Mar 27, 2008
-
-
Jean-Marc Valin authored
-
Jean-Marc Valin authored
-
- Mar 23, 2008
-
-
Jean-Marc Valin authored
-
- Mar 22, 2008
-
-
Jean-Marc Valin authored
-
- Mar 21, 2008
-
-
Jean-Marc Valin authored
-
Jean-Marc Valin authored
-
- Mar 20, 2008
-
-
Jean-Marc Valin authored
-
Jean-Marc Valin authored
-
- Mar 16, 2008
-
-
Jean-Marc Valin authored
-
- Mar 14, 2008
-
-
Jean-Marc Valin authored
-
- Mar 11, 2008
-
-
Jean-Marc Valin authored
-
- Mar 05, 2008
-
-
Jean-Marc Valin authored
This involved adding kfft_single.[ch] that redefines kiss_fft a second time with a different prefix. All this is still a bit of a mess now. The mask had to be converted to 16-bit input, but we're still using floats to apply it.
-
- Feb 27, 2008
-
-
Jean-Marc Valin authored
intruduces a bit of an encoder-decoder mismatch (Q8 in dB), but it'll be reduced when the interals of quant_energy_mono() are properly converted to fixed-point and oldEBands gets rounded instead of truncated.
-
- Feb 26, 2008
-
-
Jean-Marc Valin authored
-
- Feb 13, 2008
-
-
Jean-Marc Valin authored
-
- Dec 07, 2007
-
-
Jean-Marc Valin authored
-
Jean-Marc Valin authored
-
- Dec 05, 2007
-
-
Jean-Marc Valin authored
-
Jean-Marc Valin authored
-
Jean-Marc Valin authored
-
- Dec 04, 2007
-
-
Jean-Marc Valin authored
-
- Nov 30, 2007
-
-
Jean-Marc Valin authored
-
Jean-Marc Valin authored
-