Commit Graph

3662 Commits

Author SHA1 Message Date
Erik de Castro Lopo
23778a3a60 libFLAC/cpu.c: More pre-processor cleanups 2016-06-25 17:02:06 +10:00
Erik de Castro Lopo
36a0ab100d Fix use of FLAC__HAS_X86INTRIN configure variable 2016-06-20 20:42:44 +10:00
Erik de Castro Lopo
e120037f3c Fix use of FLAC__SSE_OS configure variable 2016-06-20 20:42:44 +10:00
Erik de Castro Lopo
e58b36c8ea Fix nasm compile on OS X / Darwin
Apparently this had been fixes in Audacity and other projects
but no one had bothered to feed them back upstream. Thanks to
lvqcl for researching this and finding the relevant patches.
Thanks to Ozkan Sezer for validating them.

Closes:  https://sourceforge.net/p/flac/bugs/438/
2016-06-14 06:31:25 +10:00
Erik de Castro Lopo
fdc1ccf2bd libFLAC: More metadata_iterators fixes
The previous fixes for metadata_iterators didn't completely fix the problem.

The behavior of chain_prepare_for_write_() must always be the same as the
behavior of FLAC__metadata_chain_check_if_tempfile_needed(). Before this
fix, one check was missing in FLAC__metadata_chain_check_if_tempfile_needed(),
and also chain_prepare_for_write_() checked the sizes of the metadata blocks
*after* making the changes to the chain, while
FLAC__metadata_chain_check_if_tempfile_needed() does it *before* the changes.

This patch changes FLAC__metadata_chain_check_if_tempfile_needed() so that it
keeps some info (lbs_state, lbs_size) about estimated changes and then uses
it to check the block sizes.

It also simplifies FLAC__metadata_chain_check_if_tempfile_needed() a little.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-05-22 11:06:32 +10:00
Erik de Castro Lopo
0b9bcebd78 test/Makefile.lite: Remove call to old script 2016-05-13 06:50:49 +10:00
Erik de Castro Lopo
089caeae8e Makefile.lite: Improved solution to CFLAGS from environment 2016-05-13 06:50:18 +10:00
Erik de Castro Lopo
2a47450d05 Makefile.lite: Pick up CFLAGS from the environment
This allows extra CFLAGS to be set on the command line. Eg

     CFLAGS=Werror make -f Makefile.lite
2016-05-12 19:22:56 +10:00
Tim Blechmann
912bff442e libFLAC: infer cpu type from compiler macros
Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
2016-05-12 08:06:26 +10:00
Erik de Castro Lopo
bbf1e3eaef test_libFLAC++: Fix memory leaks
Memory leaks found using `cppcheck`.
2016-05-08 17:29:00 +10:00
Erik de Castro Lopo
94a61241b0 libFLAC: Add a workaround for a bug in MSVC2105 update2
MSVC2105 update2 compiles the C code:

    abs_residual_partition_sums[partition] =
                  (FLAC__uint32)_mm_cvtsi128_si32(mm_sum);

into this:

    movq    QWORD PTR [rsi], xmm2

while it should be:

    movd    eax, xmm2
    mov     QWORD PTR [rsi], rax

With this patch, MSVC emits:

    movq    QWORD PTR [rsi], xmm2
    mov     DWORD PTR [rsi+4], r9d

so the price of this workaround is 1 extra write instruction per
partition.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-05-05 17:23:52 +10:00
Erik de Castro Lopo
387992bd64 metadata_iterators.c: Limit padding size
Without this fix, its possible for libFLAC to create an oversized
padding metadata block when:

a) it merges existing padding blocks

or
b) it expands padding block during metadata changes

resulting in a corrupt FLAC file.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-05-01 20:57:18 +10:00
Erik de Castro Lopo
94ff346ad0 Windows/MSVC: Add ENABLE_64_BIT_WORDS macro
Allow setting of ENABLE_64_BIT_WORDS preprocessor variable for
libFLAC_dynamic, libFLAC_static and test_libFLAC projects and x64
platform.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-05-01 20:55:15 +10:00
Erik de Castro Lopo
f3a16f85cf bitwrite.c: Tweaks
* Removes unused FLAC__WORD_ALL_ONES definition.
* Add comment that unused bits of accumulator can contain garbage.
* Turn assert inside FLAC__bitwriter_write_utf8_uint32 into runtime
  check (similar to FLAC__bitwriter_write_utf8_uint64() function).

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-05-01 20:40:28 +10:00
Erik de Castro Lopo
94386fdea5 libFLAC: Add metadata size checks to FLAC library
This follows on from the previous patch.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-05-01 20:36:43 +10:00
Erik de Castro Lopo
516a7ad4d9 flac/metaflac: Limit the size of metadata blocks
Limit allow image file size to slightly less than 2^24 bytes so that
the file size plus extra house keeping data is strictly less that
2^24 bytes in size.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-05-01 20:36:25 +10:00
Erik de Castro Lopo
cf0a6ec709 Fix 'make distcheck' target
Last commit added a new file which was not added to `EXTRA_DIST`.
2016-04-27 10:23:38 +10:00
Erik de Castro Lopo
3de7413a36 cuesheet.c: Allow quotes around ISRC field
With this change, flac now accepts cuesheets where the ISRC field is
enclosed in double quotes. Added a test for this as well.

Closes: https://sourceforge.net/p/flac/bugs/436/
2016-04-26 18:06:16 +10:00
Erik de Castro Lopo
50af1bcf63 libFLAC/stream_decoder.c: Fix typo
Introduced in 1be4f9537e.
2016-03-20 20:49:31 +11:00
Erik de Castro Lopo
9548d4b953 configure.ac: Force FLAC__HAS_OGG to 0 or 1 2016-03-20 20:44:59 +11:00
Erik de Castro Lopo
1be4f9537e libFLAC: Reduce FLAC__HAS_OGG #ifdef crud 2016-03-20 19:28:41 +11:00
Erik de Castro Lopo
eae85ee766 libFLAC/stream_decoder.c: Fix compiling with integer only
Was failing to compile on IA32 with FLAC__INTEGER_ONLY_LIBRARY
defined.

Reported-by: "Joakim Landberg" <joakim.landberg@intel.com>
2016-03-20 17:49:44 +11:00
Erik de Castro Lopo
61607377ed stream_decoder.c: Set obj->num_comments before return
Make sure obj-num_comments gets set on failure conditions.

Patch-from: Robert Shih <robertshih@google.com>
2016-03-20 15:49:23 +11:00
Erik de Castro Lopo
a9f84425cf libFLAC/cpu.c: Use sigemptyset instead of __sigemptyset
The former is POSIX while the later is a GNU glibc-ism that does not
exist in (for example) the Musl C library that is used in OpenWrt.

Reported-by: <neheb@hushmail.com>
2016-03-14 11:27:34 +11:00
Erik de Castro Lopo
c4141f6132 Another Windows build fix
Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-02-11 18:23:34 +11:00
Erik de Castro Lopo
1531034202 test/: Remove two redundant scripts
* test_bin.sh looks like it was a personal use script for the original
  developer Josh Coalson and referenced directories outside the actual
  repository.
* test_wrapper.sh was trivial and un-used.
2016-02-11 09:37:20 +11:00
Erik de Castro Lopo
9cf42fe5e0 Fix autotool warnings 2016-02-10 21:24:41 +11:00
Dave Yeo
50e7aea808 microbench: Add fallback to gettimeofday()
Some operating systems such as OS/2 don't have any of the CLOCK* API
functions so add gettimeofday() as a fallback.

Signed-off-by: Dave Yeo <dave.r.yeo@gmail.com>
Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
2016-02-09 20:30:29 +11:00
Erik de Castro Lopo
ab61102209 More Windows fixes
These fixes got lost in an earlier commit.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-02-09 17:56:55 +11:00
Erik de Castro Lopo
52522f3a71 More make distcheck fixes
* Add two missing files to repo.
* Add files to Makefile.am `EXTRA_DIST` list.
2016-02-09 14:05:50 +11:00
Erik de Castro Lopo
0bb06dc182 test_libFLAC: Fix make distcheck target 2016-02-09 07:01:29 +11:00
Thomas Zander
e5498e87ea Retire FLAC__float and FLAC__double types
Usage of internal aliases for float and double do not provide
substantial value. For integer-only libs, the macro
FLAC__INTEGER_ONLY_LIBRARY is used in the appropriate places
already.

Also, adapt copyright messages to include 2016.

Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
Closes: https://github.com/xiph/flac/pull/10
2016-02-09 06:50:27 +11:00
Dave Yeo
0435a231c8 Make AVX and AVX2 instructions a configure option
Handy for toolchains or operating systems that don't support AVX or AVX2
like OS/2.

Signed-off-by: Dave Yeo <dave.r.yeo@gmail.com>
Signed-off-by: Erik de Castro Lopo <erikd@mega-nerd.com>
2016-02-08 22:12:37 +11:00
Erik de Castro Lopo
d40a6bc695 libFLAC: Remove win_utf8_io dependency
Path-from: lvqcl <lvqcl.mail@gmail.com>
2016-02-08 22:04:12 +11:00
Erik de Castro Lopo
a5c8e8e14d src/share/utf8/utf8.c: Windows API usage fixes
Patch-from: <lvqcl.mail@gmail.com>
2016-02-08 13:43:00 +11:00
Erik de Castro Lopo
b821ac2dad Remove src/share/utf8/Makefile.am
This file was redundant.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-02-03 10:45:38 +11:00
Erik de Castro Lopo
b05c00186c win_utf8_io: Fix compile error
The function `set_filename_utf8` was defined as static, but the
prototype was missing `static`.
2016-02-02 09:33:16 +11:00
Erik de Castro Lopo
89a0fe1e15 test_streams: Use fopen instead of flac_fopen
test_streams doesn't create/open files with non-ascii filenames,
so there's no need in unicode support.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-02-02 09:20:02 +11:00
Erik de Castro Lopo
c225c4a6db Fix debug build for VS2005
Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-02-02 09:16:51 +11:00
Erik de Castro Lopo
dd83474977 share/utf8: Add missing check
Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-02-01 10:58:51 +11:00
Erik de Castro Lopo
7be5df6c7f Refactoring of win_utf8_io
* Simplifies *print functions.
* Improves file related functions.
* Preparation to move all file related functions into libFLAC.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-01-31 12:42:26 +11:00
Erik de Castro Lopo
7917b60bdb src/share/Makefile.am: Fix EXTRA_DIST
* Remove reference to deleted file charsetmap.h.
* Move utf8/iconvert.h from EXTRA_DIST to utf8_libutf8_la_SOURCES.

Reported-by: lvqcl <lvqcl.mail@gmail.com>
2016-01-31 12:35:57 +11:00
Erik de Castro Lopo
9d99f2db84 locale_hack.h: Fix comment
Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-01-31 09:55:18 +11:00
Erik de Castro Lopo
c547600599 Remove plugin_common library from MSVC build
Previously src/plugin_common library was used by FLAC's own Winamp plugin
(MSVC/Windows) and by the XMMS plugin (*nix). The Winamp plugin is long
gone from FLAC tree, so plugin_common is unused on Windows.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-01-31 09:53:49 +11:00
Erik de Castro Lopo
ba18bd19a8 Fix dependencies for MSVC
Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-01-31 09:50:12 +11:00
Erik de Castro Lopo
04f7b241bc Remove src/share/utf8/charsetmap.h
It was added in 2002 but is not used anywhere.

Reported-by: lvqcl <lvqcl.mail@gmail.com>
2016-01-31 09:47:53 +11:00
Erik de Castro Lopo
aceddf31c9 Windows/MSVC utf8 build fixes
Files share/utf8/charset.c and share/utf8/iconvert.c aren't needed
under Windows. This patch removes them from MSVC build system.

Patch-from: lvqcl <lvqcl.mail@gmail.com>
2016-01-29 07:39:16 +11:00
Erik de Castro Lopo
4288e44605 microbench/util.c: Fix -Wshadow warning 2016-01-26 16:20:00 +11:00
Erik de Castro Lopo
7411724bc9 Fix ioctl/TIOCGWINSZ for OSX 2016-01-26 13:35:24 +11:00
Erik de Castro Lopo
3ff49e606d src/flac/utils.c: Fix for OpenBSD
OpenBSD defineds `TIOCGWINSZ` in `termios.h` which is already being
included, so this fix should work on most POSIX systems.

Closes: https://sourceforge.net/p/flac/bugs/435/
2016-01-26 13:03:31 +11:00