flac.git
4 years agoAdd partial_tukey and punchout_tukey apodization functions
Martijn van Beurden [Sun, 10 Aug 2014 08:59:29 +0000 (10:59 +0200)]
Add partial_tukey and punchout_tukey apodization functions

Adds two new apodization functions that seem to perform better than
the apodization functions currently in the codebase and fixes three
existing windows as well.

Its important to note that this patch only affects the encoder stage
that evaluates various possible predictors. Audio encoded with these
new windows will still decode with existing legacy decoders.

= Theory =
These functions are used to window the  audio data at the predictor
stage. These news functions enable the use of only part of the signal
to generate a predictor. This helps  because short transients can
introduce noise into the predictor. The  predictor becomes very good
at prediciting one part of the  signal, instead of mediocre for the
whole block.

Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
4 years agoflac/utils.c : Fix calculation of a tag length.
Erik de Castro Lopo [Sun, 21 Sep 2014 11:11:41 +0000 (21:11 +1000)]
flac/utils.c : Fix calculation of a tag length.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolpc_intrin_sse41.c : Optimize decoding 24 bit files on 32 bit platforms.
Erik de Castro Lopo [Sat, 20 Sep 2014 23:39:15 +0000 (09:39 +1000)]
lpc_intrin_sse41.c : Optimize decoding 24 bit files on 32 bit platforms.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolpc_intrin* : Remove unused code.
Erik de Castro Lopo [Sat, 20 Sep 2014 23:33:39 +0000 (09:33 +1000)]
lpc_intrin* : Remove unused code.

Which in turn simplifies FLAC__lpc_restore_signal_16_intrin_sse2()
function.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agofixed_intrin_sse[23].c : Add new, simpler SSE code.
Erik de Castro Lopo [Sat, 20 Sep 2014 23:28:36 +0000 (09:28 +1000)]
fixed_intrin_sse[23].c : Add new, simpler SSE code.

It's simpler but not faster so it is disabled by default. Maybe it
will be faster on newer CPUs though..

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agostream_encoder_intrin_sse[23].c : Optimize of int32 -> uint64 conversion.
Erik de Castro Lopo [Sat, 20 Sep 2014 22:48:17 +0000 (08:48 +1000)]
stream_encoder_intrin_sse[23].c : Optimize of int32 -> uint64 conversion.

Optimizes int32 -> uint64 conversion by doing zero extension (int32 ->
uint32 -> uint64) instead of sign extension (int32 -> int64 -> uint64).

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agowin_utf8_io.c: Use fputws instead of fwprintf.
Yuta NAKAI [Fri, 12 Sep 2014 14:53:45 +0000 (23:53 +0900)]
win_utf8_io.c: Use fputws instead of fwprintf.

Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
4 years agoMinor clean up of win_utf8_io.
Erik de Castro Lopo [Sat, 20 Sep 2014 22:06:43 +0000 (08:06 +1000)]
Minor clean up of win_utf8_io.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agovorbiscomment.c : Do not write empty vorbiscomment fields.
Erik de Castro Lopo [Fri, 19 Sep 2014 07:35:35 +0000 (17:35 +1000)]
vorbiscomment.c : Do not write empty vorbiscomment fields.

That is, only write vorbis comment fields if they are non-empty.

Patch-from: Janne Hyv√§rinen <cse@sci.fi>

4 years agofixed_intrin_sse[23].c : Simplify XMM -> int64 conversion.
Erik de Castro Lopo [Thu, 18 Sep 2014 11:39:36 +0000 (21:39 +1000)]
fixed_intrin_sse[23].c : Simplify  XMM -> int64 conversion.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agocpu.h : Only define FLAC__SSE_SUPPORTED if FLAC__HAS_X86INTRIN is set.
Erik de Castro Lopo [Thu, 18 Sep 2014 11:35:11 +0000 (21:35 +1000)]
cpu.h : Only define FLAC__SSE_SUPPORTED if FLAC__HAS_X86INTRIN is set.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoRemove old/broken PPC/Altivec code.
Erik de Castro Lopo [Sun, 13 Jul 2014 11:19:48 +0000 (21:19 +1000)]
Remove old/broken PPC/Altivec code.

* Removes FLAC__lpc_restore_signal_asm_ppc_altivec_16*
  from lpc.h and stream_decoder.c
* Removes PPC-specific code from cpu.c and cpu.h
* Removes PPC stuff from libFLAC/Makefile.lite and build/*.mk
* Removes as/gas/PPC-specific stuff from configure.ac and
  libFLAC/Makefile.am*
* Removes libFLAC/ppc folder and remove "src/libFLAC/ppc*/Makefile"
  lines from configure.ac

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agowin_utf8_io.c : Remove redundant line.
Erik de Castro Lopo [Sat, 9 Aug 2014 03:03:56 +0000 (13:03 +1000)]
win_utf8_io.c : Remove redundant line.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agowin_utf8_io.c : Fix potential memory leak.
Erik de Castro Lopo [Sat, 9 Aug 2014 03:02:56 +0000 (13:02 +1000)]
win_utf8_io.c : Fix potential memory leak.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agowin_utf8_io.c : Use vsnprintf_s instead of vsprintf.
Erik de Castro Lopo [Sat, 9 Aug 2014 03:01:19 +0000 (13:01 +1000)]
win_utf8_io.c : Use vsnprintf_s instead of vsprintf.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC/cpu.c : Refactor disabling SSE into a single function.
Erik de Castro Lopo [Sat, 9 Aug 2014 02:51:32 +0000 (12:51 +1000)]
libFLAC/cpu.c : Refactor disabling SSE into a single function.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoinclude/share/endswap.h : Improvements to fallthrough ENDSWAP_*.
Erik de Castro Lopo [Sat, 9 Aug 2014 02:47:20 +0000 (12:47 +1000)]
include/share/endswap.h : Improvements to fallthrough ENDSWAP_*.

According to patch author GCC can optimize expressions like
"(a<<8)|(a>>8)", but has problems with "(a<<8)+(a>>8)".

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC/lpc_intrin_sse.c : New SSE code to calculate autocorrelation.
Erik de Castro Lopo [Sat, 9 Aug 2014 02:32:57 +0000 (12:32 +1000)]
libFLAC/lpc_intrin_sse.c : New SSE code to calculate autocorrelation.

Accelerate FLAC__lpc_compute_autocorrelation_intrin_sse_lag_NN routines for
AMD and newer Intel CPUs (means Core i aka Nehalem and newer). Unfortunately
it's slower on older Intel CPUs.

According to tests at HA:

    <http://www.hydrogenaud.io/forums/index.php?s=&showtopic=101082&view=findpost&p=870753>

  CPU                 flac -5           flac -8

  Athlon XP           +5 %              +2.4 %
  Athlon 64 X2        +9 %              +4 %
  Core i              +7 %              +1 % ... +2.7 %
  Core 2              ?                 -3.5 %

According to Steam HW survey <http://store.steampowered.com/hwsurvey/>
69% of Steam users have SSE4.2 which means that the new code is faster for
them. There are also AMD users that don't have SSE4.2, so 75% of Steam users
should benefit from this patch.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoVarious documentation fixes, merge with website
Martijn van Beurden [Fri, 1 Aug 2014 07:57:38 +0000 (09:57 +0200)]
Various documentation fixes, merge with website

The html documentation was diff'ed to the current website pages
and all difference were merged into the page they weren't yet
incorporated. This includes lots of small fixes and
improvements.

Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
4 years agoFix bug when using -p switch during compression
Martijn van Beurden [Mon, 28 Jul 2014 11:04:56 +0000 (13:04 +0200)]
Fix bug when using -p switch during compression

When using the -p switch during encoding, the encoder should try
different qlp predictor precision steps. However, some faulty code
was too severely restricting the possible steps. This patch lifts
the restriction to match a restriction coded a little further in
the process. This doesn't make using -p worth your while, but at
least it doesn't create larger files now

Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
4 years agolibFLAC/cpu.c : Simplify OS SSE support detection.
Erik de Castro Lopo [Mon, 28 Jul 2014 10:49:09 +0000 (20:49 +1000)]
libFLAC/cpu.c : Simplify OS SSE support detection.

Simplify the code that tries to detect whether OS supports SSE instructions.

a) Linux: "old" vs "new" sigaction

OBSOLETE_SIGCONTEXT_FLAVOR was disabled in Mar 2007 in commit 1ca3a445f.
According to <http://unixhelp.ed.ac.uk/CGI/man-cgi?sigaction>: "Support for
SA_SIGINFO was added in Linux 2.2" (released in Jan 1999). If noone wants to
use FLAC with Linux kernel 2.0 then it's safe to delete this code.

b) MSVC: try/catch vs. sigill_handler

TRY_CATCH_FLAVOR was enabled in Jan 2009 in commit a832ef32. According to the
comment in cpu.c, "sigill_handler flavor resulted in several crash reports on
win32". Also this sigill_handler flavor is not thread-safe.

c) MinGW: fxsave/fxrestore vs. sigill_handler

The code was added Mar 2014 in commit 99d5154f. It's better to use FXSR flavor
instead of sigill_handler flavor. The reasons are the same as for MSVC.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC : SSE optimisations.
Erik de Castro Lopo [Mon, 28 Jul 2014 10:43:54 +0000 (20:43 +1000)]
libFLAC : SSE optimisations.

Add new function:

    FLAC__lpc_compute_residual_from_qlp_coefficients_intrin_sse41()

and rewrite function:

    FLAC__lpc_compute_residual_from_qlp_coefficients_16_intrin_sse2()

Testing shows noticeable speed increase on Intel Core i3/5/7 (up to 30%
for -8 mode), AMD Athlon64, Phenom, Bulldozer/Piledriver, but no increase
or even very small speed decrease (~2% for -8 mode) on Intel Core2.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC/bitreader.c : Remove redundant/incorrect comment.
Erik de Castro Lopo [Sun, 27 Jul 2014 11:24:27 +0000 (21:24 +1000)]
libFLAC/bitreader.c : Remove redundant/incorrect comment.

This comment should have been removed in commit eb0c5a37.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC/bitreader : Remove un-needed FLAC__CPUInfo field from FLAC__BitReader.
Erik de Castro Lopo [Sun, 27 Jul 2014 11:21:46 +0000 (21:21 +1000)]
libFLAC/bitreader : Remove un-needed FLAC__CPUInfo field from FLAC__BitReader.

In FLAC 1.2.0, a new field 'FLAC__CPUInfo cpu_info' was added to the
FLAC__BitReader struct. It became useless in 1.3.0 because of various
bitreader optimizations.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoconfigure.ac : Fix --disable-sse option.
Erik de Castro Lopo [Sun, 27 Jul 2014 11:18:08 +0000 (21:18 +1000)]
configure.ac : Fix --disable-sse option.

Based on a patch from lvqcl <lvqcl.mail@gmail.com>.

4 years agoconfigure.ac : Erase default -O2 when setting -O3.
Erik de Castro Lopo [Sun, 27 Jul 2014 00:08:44 +0000 (10:08 +1000)]
configure.ac : Erase default -O2 when setting -O3.

Previously CFLAGS had a -O3 at the start and a -O2 at the end. According
to the GCC docs:

    https://gcc.gnu.org/onlinedocs/gcc-4.9.1/gcc/Optimize-Options.html

    "If you use multiple -O options, with or without level numbers,
    the last such option is the one that is effective" which means that
    GCC doesn't try to use SIMD to vectorize the code, etc."

4 years agoconfigure.ac : Set default CFLAGS to something sensible.
Erik de Castro Lopo [Sat, 26 Jul 2014 08:24:49 +0000 (18:24 +1000)]
configure.ac : Set default CFLAGS to something sensible.

Preserve the CFLAGS value from the time the configure script is run.

4 years agoflac and metaflac : Don't always call setlocale() in Windows.
Erik de Castro Lopo [Sat, 19 Jul 2014 08:17:25 +0000 (18:17 +1000)]
flac and metaflac : Don't always call setlocale() in Windows.

Windows (MSVC, MinGW) versions of setlocale don't care about LC_*
environment variables. For example, flac cannot pass the test for
--until and --skip options the script calls it with --skip=0:01.1001
and it expects decimal comma (--skip=0:01,1001) on some locales.

Solve this (on Windows) by calling setlocale(LC_ALL, "") if some
LC_* variable is set to "C".

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC/.../crc.h : Remove un-nneded parens in FLAC__CRC16_UPDATE macro.
Erik de Castro Lopo [Sat, 19 Jul 2014 08:13:06 +0000 (18:13 +1000)]
libFLAC/.../crc.h : Remove un-nneded parens in FLAC__CRC16_UPDATE macro.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoflac/main.c : Improved option validation with --force-raw-format.
Erik de Castro Lopo [Sun, 13 Jul 2014 10:53:15 +0000 (20:53 +1000)]
flac/main.c : Improved option validation with --force-raw-format.

Patch-from:  lvqcl <lvqcl.mail@gmail.com>

4 years agotest/test_flac.sh : Add --force-raw-format as needed.
Erik de Castro Lopo [Sun, 13 Jul 2014 10:38:57 +0000 (20:38 +1000)]
test/test_flac.sh : Add --force-raw-format as needed.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoinclude/share/endswap.h : Fix default ENDSWAP_16.
Erik de Castro Lopo [Sun, 13 Jul 2014 10:36:57 +0000 (20:36 +1000)]
include/share/endswap.h : Fix default ENDSWAP_16.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agobuild/config.mk : Define CPU_IS_LITTLE_ENDIAN as needed.
Erik de Castro Lopo [Sun, 13 Jul 2014 10:35:11 +0000 (20:35 +1000)]
build/config.mk : Define CPU_IS_LITTLE_ENDIAN as needed.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoMakefile.ams: Add MSVS project files to EXTRA_DIST.
Erik de Castro Lopo [Wed, 9 Jul 2014 09:02:35 +0000 (19:02 +1000)]
Makefile.ams: Add MSVS project files to EXTRA_DIST.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agotest_replaygain.sh : Add --force-raw-format option.
Erik de Castro Lopo [Tue, 8 Jul 2014 11:12:15 +0000 (21:12 +1000)]
test_replaygain.sh : Add --force-raw-format option.

This test was failing due to the lack of this option.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agosrc/flac/utils.c : Make sure get_console_width() returns value > 0.
Erik de Castro Lopo [Tue, 8 Jul 2014 08:25:11 +0000 (18:25 +1000)]
src/flac/utils.c : Make sure get_console_width() returns value > 0.

Previous version of get_console_width() may return 0 which will result in
a division by 0 in stats_print_name():

console_width = get_console_width();
len = strlen_console(name)+2;
console_chars_left = console_width  - (len % console_width);

Bug-report: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=739613
Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoAdd project files for Visual Studio 2010 and later.
Erik de Castro Lopo [Sun, 6 Jul 2014 10:48:26 +0000 (20:48 +1000)]
Add project files for Visual Studio 2010 and later.

Also allows building for x86-64 Windows.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC : Remove FLAC__bitreader_read_rice_signed_block_asm_ia32_bswap().
Erik de Castro Lopo [Sun, 6 Jul 2014 10:27:28 +0000 (20:27 +1000)]
libFLAC :  Remove FLAC__bitreader_read_rice_signed_block_asm_ia32_bswap().

This function was un-used because it showed no speed improvement over the
C version. As a result the bitreader_read_from_client_() function can be
made static again.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC : Remove FLAC__precompute_partition_info_sums_32bit_asm_ia32_().
Erik de Castro Lopo [Sun, 6 Jul 2014 10:20:58 +0000 (20:20 +1000)]
libFLAC : Remove FLAC__precompute_partition_info_sums_32bit_asm_ia32_().

This function offer no speed up from the C version of the function and were
commented out after the release of 1.3.0. We will now drop them completely.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agostream_encoder : Improve selection of residual accumulator width
Miroslav Lichvar [Thu, 19 Jun 2014 11:04:33 +0000 (13:04 +0200)]
stream_encoder : Improve selection of residual accumulator width

In the precompute_partition_info_sums_ function, instead of selecting
64-bit accumulator when the signal bps is larger than 16, revert to the
original approach based on partition size, but make room for few extra
bits to not overflow with unusual signals where the average residual
magnitude may be larger than bps.

It slightly improves the performance with standard encoding levels and
16-bit files as the 17-bit side channel can still be processed with the
32-bit accumulator and correctly selects the 64-bit accumulator with
very large 16-bit partitions.

This is related to commits 6f7ec60c and 187e596e.

Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
4 years agotest_libFLAC/test_libFLAC.vcproj : One more CPU_IS_LITTLE_ENDIAN fix.
Erik de Castro Lopo [Thu, 3 Jul 2014 23:02:17 +0000 (09:02 +1000)]
test_libFLAC/test_libFLAC.vcproj : One more CPU_IS_LITTLE_ENDIAN fix.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agosrc/ : Remove un-needed MSVC6 workaround.
Erik de Castro Lopo [Thu, 3 Jul 2014 22:31:57 +0000 (08:31 +1000)]
src/ : Remove un-needed MSVC6 workaround.

MSVC6 was not able to cast from a uint64_t to a double and this
commit removes some #ifdef hackery designed to work around this
problem.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agotest_libFLAC/endswap.c : Add casts to prevent compiler warnings.
Erik de Castro Lopo [Thu, 3 Jul 2014 10:24:33 +0000 (20:24 +1000)]
test_libFLAC/endswap.c : Add casts to prevent compiler warnings.

4 years agotest_libFLAC/test_libFLAC.vcproj : Add define for CPU_IS_LITTLE_ENDIAN.
Erik de Castro Lopo [Thu, 3 Jul 2014 09:19:08 +0000 (19:19 +1000)]
test_libFLAC/test_libFLAC.vcproj : Add define for CPU_IS_LITTLE_ENDIAN.

4 years agoFix bswap16 issue on Debian 6.
Ralph Giles [Wed, 2 Jul 2014 21:12:38 +0000 (14:12 -0700)]
Fix bswap16 issue on Debian 6.

Versions of GCC prior to 4.8 didn't provide an implementation
of __builtin_bswap16 on x86_64. Detect those versions and
supply a fallback implementation. A cleaner fix would be
to detect bswap16 independently of bswap32 in configure
and handle them separately.

See https://gcc.gnu.org/bugzilla/show_bug.cgi?id=52624

Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
4 years agotest_libFLAC : Fix Windows build after addidion of endian tests.
Erik de Castro Lopo [Wed, 2 Jul 2014 19:38:09 +0000 (05:38 +1000)]
test_libFLAC : Fix Windows build after addidion of endian tests.

* Use "share/compat.h" instead of <stdint.h>.
* Update test_libFLAC.vcproj project file.
* Update Makefile.lite build system.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agosrc/flac/main.c : Improve raw format help text help.
Erik de Castro Lopo [Wed, 2 Jul 2014 19:35:55 +0000 (05:35 +1000)]
src/flac/main.c : Improve raw format help text help.

The --endian and --sign options aren't just for raw input, but also
for raw output.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agosrc/flac/encode.c : Fix compression failure warning when encoding from stdin.
Erik de Castro Lopo [Wed, 2 Jul 2014 08:33:30 +0000 (18:33 +1000)]
src/flac/encode.c :  Fix compression failure warning when encoding from stdin.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agotest_libFLAC/md5.c : Fix the tests.
Erik de Castro Lopo [Tue, 1 Jul 2014 10:00:07 +0000 (20:00 +1000)]
test_libFLAC/md5.c : Fix the tests.

The previous version of this test worked on amd64 and powerpc64 but
failed on armhf. Investigation show that the previous version of the
test data was generated for a case where the ARRAY_LEN macro was
exploiting undefined behaviour.
Fix was ditching the ARRAY_LEN macro and then recalculating the
target data.

4 years agotest_libFLAC/endswap.c : Improvements.
Erik de Castro Lopo [Tue, 1 Jul 2014 08:03:08 +0000 (18:03 +1000)]
test_libFLAC/endswap.c : Improvements.

* Print endian-ness of test host.
* Replace ugly macro with C code.
* Add tests for H2LE_16 and H2LE_32 macros.

4 years agosrc/test_libFLAC : Add tests for end swap macros.
Erik de Castro Lopo [Mon, 30 Jun 2014 10:26:39 +0000 (20:26 +1000)]
src/test_libFLAC : Add tests for end swap macros.

4 years agosrc/flac/decode.c : Add comment about ubuf union.
Erik de Castro Lopo [Mon, 30 Jun 2014 09:55:21 +0000 (19:55 +1000)]
src/flac/decode.c : Add comment about ubuf union.

4 years agoinclude/share/endswap.h : Fix fallback ENDSWAP_16 macro.
Erik de Castro Lopo [Sun, 29 Jun 2014 20:28:39 +0000 (06:28 +1000)]
include/share/endswap.h : Fix fallback ENDSWAP_16 macro.

4 years agosrc/flac/encode.c : Fix cast-align warning on ARM systems.
Erik de Castro Lopo [Sun, 29 Jun 2014 12:30:36 +0000 (22:30 +1000)]
src/flac/encode.c : Fix cast-align warning on ARM systems.

Use the union of pointers trick again.

4 years agolibFLAC/md5: Fix for cast-align warnings on ARM.
Erik de Castro Lopo [Sun, 29 Jun 2014 11:52:06 +0000 (21:52 +1000)]
libFLAC/md5: Fix for cast-align warnings on ARM.

Rather than the buffer into format_input_() as a FLAC__byte pointer, pass
it as a pointer to a union of three pointers, one each for for FLAC__byte,
FLAC__int16 and FLAC_int32.
This should have zero measurable performance impact.

4 years agolibFLAC/md5.c : Massive refactoring of format_input_ function.
Erik de Castro Lopo [Sun, 29 Jun 2014 10:21:52 +0000 (20:21 +1000)]
libFLAC/md5.c : Massive refactoring of format_input_ function.

This refactoring is in preparation for fixing the cast-align warning when
compiling on ARM (and possibly others). Testing on stereo 16 bit files
suggests that the difference between the performance of this code and the
old code is negligible (tested only on amd64/linux).

4 years agoinclude/share/endswap.h : Add endswapping of 16 bit values.
Erik de Castro Lopo [Sun, 29 Jun 2014 10:19:59 +0000 (20:19 +1000)]
include/share/endswap.h : Add endswapping of 16 bit values.

Also add macros H2LE_16 and H2LE_32, which do host to little-endian
swapping of 16 and 32 bit values respectively.

4 years agolibFLAC/bitmath : Restore an ASSERT that was removed some time after 1.2.1.
Erik de Castro Lopo [Sat, 28 Jun 2014 11:59:10 +0000 (21:59 +1000)]
libFLAC/bitmath : Restore an ASSERT that was removed some time after 1.2.1.

Restore a FLAC__ASSERT() to bitmath functions FLAC__bitmath_ilog2 and
FLAC__bitmath_ilog2_wide functions. This prevents the return of an
"undefined" value.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC/lpc_intrin_sseN.c : Disambiguate macro names.
Erik de Castro Lopo [Sat, 28 Jun 2014 11:55:25 +0000 (21:55 +1000)]
libFLAC/lpc_intrin_sseN.c : Disambiguate macro names.

Previously, the files lpc_intrin_sse2.c and lpc_intrin_sse41.c both defined
macros RESIDUAL_RESULT and DATA_RESULT. This situation made it impossible
to merge these files which we may do at some stage.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agolibFLAC: CPUID detecion improvements.
Erik de Castro Lopo [Sat, 28 Jun 2014 11:50:09 +0000 (21:50 +1000)]
libFLAC: CPUID detecion improvements.

According to docs, it's incorrect to just call CPUID with EAX=1.
One must to ensure that this value is supported.

CPUs that don't support CPUID level 1 are very old, but...
if FLAC tests CPUID presence it should also test CPUID level support.

Also the function FLAC__cpu_have_cpuid_asm_ia32 was simplified
according to the docs at Intel website and in Wikipedia.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoflac: Fix channel order for mono files.
Erik de Castro Lopo [Sat, 28 Jun 2014 11:45:50 +0000 (21:45 +1000)]
flac: Fix channel order for mono files.

* The default channel mask for mono files was 0x0001 (front left) but it
  makes more sense to use 0x0004 (front center) for such files.

* Also FLAC will accept not only mono WAV files with 0x0001 mask, but also
  with 0x0002 (requested at https://sourceforge.net/p/flac/bugs/390/)
  and 0x0004 (e.g. SoX creates mono files with this mask).

* The comment about channel support was updated.

* The error message
     "Use --channel-map=none option to store channels in current order; FLAC files
     must also be decoded with --channel-map=none to restore correct order."
  is misleading: FLAC never changes the order of channels.
  Decoding with this options also sets the channel mask of the resulting WAV
  file to 0. Without this option the mask is equal to the value of
  WAVEFORMATEXTENSIBLE_CHANNEL_MASK tag.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoflac: Fix encoder and decode progress messages with --ogg.
Erik de Castro Lopo [Sat, 28 Jun 2014 11:40:59 +0000 (21:40 +1000)]
flac: Fix encoder and decode progress messages with --ogg.

Problem discussed here:

   http://lists.xiph.org/pipermail/flac-dev/2014-June/004808.html

The values for the interval between two updates (e->stats_mask,
e->stats_frames_interval) were set ~10 years ago, and it is small
for current CPUs. It was now been increased too (0x3f -> 0xff, etc).
The update interval is still less than 1 second.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoflac : Fix handling of raw input option.
Erik de Castro Lopo [Sat, 28 Jun 2014 11:35:40 +0000 (21:35 +1000)]
flac : Fix handling of raw input option.

FLAC was silently ignoring options for raw input for encoding mode (but
prints an error and aborts when _de_coding).

This can lead to bug reports such as https://sourceforge.net/p/flac/bugs/389/

FLAC now prints a message about options misuse for encoding mode.

Help messages were also updated.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agotest_libFLAC/md5.c: Add tests for MD5 calculation.
Erik de Castro Lopo [Fri, 27 Jun 2014 12:02:54 +0000 (22:02 +1000)]
test_libFLAC/md5.c: Add tests for MD5 calculation.

Test all channel counts from 1 to 8 inclusive and all byte widths
from 1 to 4 inclusive.

4 years agoAUTHORS : Tweaks.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:52:52 +0000 (09:52 +1000)]
AUTHORS : Tweaks.

4 years agoflac: Fix padding for --replay-gain option.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:32:57 +0000 (09:32 +1000)]
flac: Fix padding for --replay-gain option.

Patches ported from the flac 1.2.1 maintenance branch.

    http://flac.cvs.sourceforge.net/viewvc/flac/flac/src/flac/encode.c?
    r1=1.194&r2=1.194.2.1&pathrev=FLAC_RELEASE_1_2_1_MAINTENANCE_BRANCH

    http://flac.cvs.sourceforge.net/viewvc/flac/flac/src/flac/main.c?
    r1=1.169&r2=1.169.2.1&pathrev=FLAC_RELEASE_1_2_1_MAINTENANCE_BRANCH

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agostream_decoder : Two read_metadata() fixes from 1.2.1 maintenance branch.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:25:25 +0000 (09:25 +1000)]
stream_decoder : Two read_metadata() fixes from 1.2.1 maintenance branch.

* Fix leaks in read_metadata_() that could occur because of read errors or
  malformed streams.
    http://flac.cvs.sourceforge.net/viewvc/flac/flac/src/libFLAC/
    stream_decoder.c?
    r1=1.147&r2=1.147.2.1&pathrev=FLAC_RELEASE_1_2_1_MAINTENANCE_BRANCH

* Fix metadata block initialization bug in read_metadata_().
    http://flac.cvs.sourceforge.net/viewvc/flac/flac/src/libFLAC/
    stream_decoder.c?
    r1=1.147.2.1&r2=1.147.2.2&pathrev=FLAC_RELEASE_1_2_1_MAINTENANCE_BRANCH

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoREADME updates.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:21:05 +0000 (09:21 +1000)]
README updates.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agotest/test_replaygain.sh : Update tests after work aroind for GCC bug.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:19:59 +0000 (09:19 +1000)]
test/test_replaygain.sh : Update tests after work aroind for GCC bug.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoUnderscore fixes.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:17:26 +0000 (09:17 +1000)]
Underscore fixes.

* Replace _declspec with __declspec.
* Replace __wgetmainargs_ with __wgetmainargs_t and __wgetmainargs
  with wgetmainargs because identifiers with leading underscores are
  reserved for the compiler.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoUpdate URLs as nedeed.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:12:06 +0000 (09:12 +1000)]
Update URLs as nedeed.

Sourceforge.net links updated as nedeed with some of them
being changed to point to xiph.org/flac.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoCorreections for comments.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:10:28 +0000 (09:10 +1000)]
Correections for comments.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoRemove un-needed code.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:08:47 +0000 (09:08 +1000)]
Remove un-needed code.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoFix VS project file for iffscan.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:07:34 +0000 (09:07 +1000)]
Fix VS project file for iffscan.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoreplaygain_analysis: Add include guard for <stdint.h>.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:06:00 +0000 (09:06 +1000)]
replaygain_analysis: Add include guard for <stdint.h>.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agoVcprojs : Remove include/share from include paths.
Erik de Castro Lopo [Fri, 27 Jun 2014 23:03:54 +0000 (09:03 +1000)]
Vcprojs : Remove include/share from include paths.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

4 years agosrc/flac/decode.c : Fix a cast-align warning from GCC.
Erik de Castro Lopo [Fri, 27 Jun 2014 11:58:26 +0000 (21:58 +1000)]
src/flac/decode.c : Fix a cast-align warning from GCC.

The old code was creating an array of FLAC__int8, and then casting
that to a set of signed and unsigned 16 and 32 bit integers. This
was replaced with a single union containing all the requred array.

This solution means that there are fewer pointer casts and actually
gives the compiler more information with which to generate fast code.

4 years agoAUTHORS : Update and add contributors.
Erik de Castro Lopo [Fri, 27 Jun 2014 10:11:18 +0000 (20:11 +1000)]
AUTHORS : Update and add contributors.

4 years agoFurther updates to the Makefile.lite build system.
Evan Ramos [Thu, 26 Jun 2014 22:25:48 +0000 (17:25 -0500)]
Further updates to the Makefile.lite build system.

Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
4 years agoFix Makefile.lite build system on Linux.
Erik de Castro Lopo [Thu, 26 Jun 2014 09:18:29 +0000 (19:18 +1000)]
Fix Makefile.lite build system on Linux.

4 years ago.gitignore : Tweaked.
Erik de Castro Lopo [Thu, 26 Jun 2014 09:02:39 +0000 (19:02 +1000)]
.gitignore : Tweaked.

4 years agoUpdate Makefile.lite build system.
Evan Ramos [Mon, 23 Jun 2014 21:24:49 +0000 (16:24 -0500)]
Update Makefile.lite build system.

Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
4 years agoreplaygain_analysis : Rename float_t -> flac_float_t.
Erik de Castro Lopo [Tue, 24 Jun 2014 11:00:58 +0000 (21:00 +1000)]
replaygain_analysis : Rename float_t -> flac_float_t.

There were a number of reports that float_t clashed with a type
defined in Linux system header files.

5 years agoMakefile.ams : Drop passing of include/share as an include directory.
Erik de Castro Lopo [Mon, 16 Jun 2014 04:23:50 +0000 (14:23 +1000)]
Makefile.ams : Drop passing of include/share as an include directory.

Some files needed to be updated to incude "share/xxx.h" instead of
"xxx.h".

Suggested-by: lvqcl <lvqcl.mail@gmail.com>
5 years agoreplaygain_analysis : Switch to standard C sized integer types.
Erik de Castro Lopo [Sun, 15 Jun 2014 21:24:43 +0000 (07:24 +1000)]
replaygain_analysis : Switch to standard C sized integer types.

5 years agoregainplay_analysis : Work around GCC optimizer bug.
Erik de Castro Lopo [Sun, 15 Jun 2014 10:32:45 +0000 (20:32 +1000)]
regainplay_analysis : Work around GCC optimizer bug.

Discussion: http://lists.xiph.org/pipermail/flac-dev/2014-June/004720.html
Patch-from: lvqcl <lvqcl.mail@gmail.com>

5 years agoRevert "Replace FLAC__CPU_X86_64 with FLaC__CPU_X86_64."
Erik de Castro Lopo [Sun, 15 Jun 2014 10:29:34 +0000 (20:29 +1000)]
Revert "Replace FLAC__CPU_X86_64 with FLaC__CPU_X86_64."

This reverts commit 151739921b74fbf31420358a5fbeb094efa017ed.

This patch only when part way to replace all FLAC_* with FLaC_*
and its really not worth going all the way.

5 years agoReplace FLAC__CPU_X86_64 with FLaC__CPU_X86_64.
Erik de Castro Lopo [Sun, 1 Jun 2014 07:31:02 +0000 (17:31 +1000)]
Replace FLAC__CPU_X86_64 with FLaC__CPU_X86_64.

Previous autorconf versions had problems with variable begining witj
'FLAC_' (autoconf uses 'AC_').

Reported-by: lvqcl <lvqcl.mail@gmail.com>
5 years agosrc/ : Fix two typos.
Erik de Castro Lopo [Sun, 1 Jun 2014 07:29:32 +0000 (17:29 +1000)]
src/ : Fix two typos.

* 'norrmal' -> 'normal'.
* 'fames' -> 'frames'.

Reported-by: lvqcl <lvqcl.mail@gmail.com>
5 years agoconfigure.ac : Add -fvisibility=hidden to OSX build.
Erik de Castro Lopo [Sun, 25 May 2014 09:42:53 +0000 (19:42 +1000)]
configure.ac : Add -fvisibility=hidden to OSX build.

Patch-from : Ozkan Sezer <sezeroz@gmail.com>

5 years agoreplaygain_synthesis.c : Replace an int64_t/int32_t operation with a shift.
Erik de Castro Lopo [Sun, 18 May 2014 03:40:15 +0000 (13:40 +1000)]
replaygain_synthesis.c : Replace an int64_t/int32_t operation with a shift.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

5 years agosrc/share/replaygain_synthesis/ : Remove old fast float math hack.
Erik de Castro Lopo [Sun, 18 May 2014 03:18:14 +0000 (13:18 +1000)]
src/share/replaygain_synthesis/ : Remove old fast float math hack.

Old code was for the Intel compiler, had no appreciable performance benefits
and doesn't actually work with current version of that compiler.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

5 years agoRemove Monkey's Audio from FLAC.sln.
Erik de Castro Lopo [Wed, 14 May 2014 11:57:05 +0000 (21:57 +1000)]
Remove Monkey's Audio from FLAC.sln.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

5 years agoPurge src/monkeys_audio_utilities/ tree.
Erik de Castro Lopo [Wed, 14 May 2014 11:48:03 +0000 (21:48 +1000)]
Purge src/monkeys_audio_utilities/ tree.

Monkey's Audio Utilities seem to have been dead for some time.

5 years agolibFLAC/ : Refactoring and add comments.
Erik de Castro Lopo [Wed, 14 May 2014 11:27:31 +0000 (21:27 +1000)]
libFLAC/ : Refactoring and add comments.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

5 years agoreplaygain_synthesis.h : Fix FLAC_SHARE__MAX_SUPPORTED_CHANNELS.
Erik de Castro Lopo [Sun, 11 May 2014 10:24:27 +0000 (03:24 -0700)]
replaygain_synthesis.h : Fix FLAC_SHARE__MAX_SUPPORTED_CHANNELS.

Was previously hard coded as 2 when it should be FLAC__MAX_CHANNELS.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

5 years agosrc/libFLAC/memory.c : Wrap inclusion of <stdint.h> in #ifdef.
Erik de Castro Lopo [Sun, 11 May 2014 10:06:45 +0000 (03:06 -0700)]
src/libFLAC/memory.c : Wrap inclusion of <stdint.h> in #ifdef.

Lack of the #ifdef was causing problems on VS2008.

5 years agosrc/flac/decode.c : Decode WAVEFORMATEXTENSIBLE_CHANNEL_MASK.
Erik de Castro Lopo [Sun, 27 Apr 2014 19:10:12 +0000 (05:10 +1000)]
src/flac/decode.c : Decode WAVEFORMATEXTENSIBLE_CHANNEL_MASK.

When decoding, read the contents of the WAVEFORMATEXTENSIBLE_CHANNEL_MASK
tag and write write the channel mask to the WAV file.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

5 years agolibFLAC/stream_encoder.c : Fix if else wibble.
Erik de Castro Lopo [Tue, 15 Apr 2014 08:36:40 +0000 (18:36 +1000)]
libFLAC/stream_encoder.c : Fix if else wibble.

Patch-from: lvqcl <lvqcl.mail@gmail.com>

5 years agosrc/flac/utils.c : Fix compile guard for ioctl().
Erik de Castro Lopo [Tue, 15 Apr 2014 08:31:58 +0000 (18:31 +1000)]
src/flac/utils.c : Fix compile guard for ioctl().