Compare commits
No commits in common. "c8s" and "c9-beta" have entirely different histories.
1
.flac.metadata
Normal file
1
.flac.metadata
Normal file
@ -0,0 +1 @@
|
||||
6ac2e8f1dd18c9b0214c4d81bd70cdc1e943cffe SOURCES/flac-1.3.3.tar.xz
|
@ -1 +0,0 @@
|
||||
1
|
3
.gitignore
vendored
3
.gitignore
vendored
@ -1,2 +1 @@
|
||||
SOURCES/flac-1.3.2.tar.xz
|
||||
/flac-1.3.2.tar.xz
|
||||
SOURCES/flac-1.3.3.tar.xz
|
||||
|
23
SOURCES/flac-cve-2020-0499.patch
Normal file
23
SOURCES/flac-cve-2020-0499.patch
Normal file
@ -0,0 +1,23 @@
|
||||
commit 2e7931c27eb15e387da440a37f12437e35b22dd4
|
||||
Author: Erik de Castro Lopo <erikd@mega-nerd.com>
|
||||
Date: Mon Oct 7 12:55:58 2019 +1100
|
||||
|
||||
libFLAC/bitreader.c: Fix out-of-bounds read
|
||||
|
||||
Credit: Oss-Fuzz
|
||||
Issue: https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=17069
|
||||
Testcase: fuzzer_decoder-5670265022840832
|
||||
|
||||
diff --git a/src/libFLAC/bitreader.c b/src/libFLAC/bitreader.c
|
||||
index 5e4b5918..3df4d02c 100644
|
||||
--- a/src/libFLAC/bitreader.c
|
||||
+++ b/src/libFLAC/bitreader.c
|
||||
@@ -869,7 +869,7 @@ incomplete_lsbs:
|
||||
cwords = br->consumed_words;
|
||||
words = br->words;
|
||||
ucbits = FLAC__BITS_PER_WORD - br->consumed_bits;
|
||||
- b = br->buffer[cwords] << br->consumed_bits;
|
||||
+ b = cwords < br->capacity ? br->buffer[cwords] << br->consumed_bits : 0;
|
||||
} while(cwords >= words && val < end);
|
||||
}
|
||||
|
28
SOURCES/flac-cve-2021-0561.patch
Normal file
28
SOURCES/flac-cve-2021-0561.patch
Normal file
@ -0,0 +1,28 @@
|
||||
commit e1575e4a7c5157cbf4e4a16dbd39b74f7174c7be
|
||||
Author: Neelkamal Semwal <neelkamal.semwal@ittiam.com>
|
||||
Date: Fri Dec 18 22:28:36 2020 +0530
|
||||
|
||||
libFlac: Exit at EOS in verify mode
|
||||
|
||||
When verify mode is enabled, once decoder flags end of stream,
|
||||
encode processing is considered complete.
|
||||
|
||||
CVE-2021-0561
|
||||
|
||||
Signed-off-by: Ralph Giles <giles@thaumas.net>
|
||||
|
||||
diff --git a/src/libFLAC/stream_encoder.c b/src/libFLAC/stream_encoder.c
|
||||
index 4c91247f..7109802c 100644
|
||||
--- a/src/libFLAC/stream_encoder.c
|
||||
+++ b/src/libFLAC/stream_encoder.c
|
||||
@@ -2610,7 +2610,9 @@ FLAC__bool write_bitbuffer_(FLAC__StreamEncoder *encoder, uint32_t samples, FLAC
|
||||
encoder->private_->verify.needs_magic_hack = true;
|
||||
}
|
||||
else {
|
||||
- if(!FLAC__stream_decoder_process_single(encoder->private_->verify.decoder)) {
|
||||
+ if(!FLAC__stream_decoder_process_single(encoder->private_->verify.decoder)
|
||||
+ || (!is_last_block
|
||||
+ && (FLAC__stream_encoder_get_verify_decoder_state(encoder) == FLAC__STREAM_DECODER_END_OF_STREAM))) {
|
||||
FLAC__bitwriter_release_buffer(encoder->private_->frame);
|
||||
FLAC__bitwriter_clear(encoder->private_->frame);
|
||||
if(encoder->protected_->state != FLAC__STREAM_ENCODER_VERIFY_MISMATCH_IN_AUDIO_DATA)
|
@ -1,24 +1,33 @@
|
||||
# Disable if you don't need xmms
|
||||
%global with_xmms !0%{?rhel}
|
||||
|
||||
%if %{with_xmms}
|
||||
%define xmms_inputdir %(xmms-config --input-plugin-dir 2>/dev/null || echo %{_libdir}/xmms/General)
|
||||
%endif
|
||||
|
||||
Summary: An encoder/decoder for the Free Lossless Audio Codec
|
||||
Name: flac
|
||||
Version: 1.3.2
|
||||
Release: 11%{?dist}
|
||||
Version: 1.3.3
|
||||
Release: 10%{?dist}
|
||||
License: BSD and GPLv2+ and GFDL
|
||||
Group: Applications/Multimedia
|
||||
Source0: http://downloads.xiph.org/releases/flac/flac-%{version}.tar.xz
|
||||
URL: http://www.xiph.org/flac/
|
||||
# use our CFLAGS and don't force SSE intrinsics
|
||||
Patch1: flac-cflags.patch
|
||||
# fix memory leak in parsing of vorbis comments
|
||||
Patch2: flac-memleak.patch
|
||||
# disable nasm detection
|
||||
Patch3: flac-nonasm.patch
|
||||
# don't free memory that is still used after realloc() error
|
||||
Patch4: flac-cve-2020-22219.patch
|
||||
Source0: https://downloads.xiph.org/releases/flac/flac-%{version}.tar.xz
|
||||
URL: https://www.xiph.org/flac/
|
||||
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
||||
BuildRequires: libogg-devel
|
||||
BuildRequires: gcc automake autoconf libtool gettext-devel doxygen
|
||||
# xmms-flac subpackage was dropped in 1.3.2-8
|
||||
Obsoletes: xmms-%{name} < 1.3.2-8
|
||||
BuildRequires: gcc gcc-c++ automake autoconf libtool gettext-devel doxygen
|
||||
%if %{with_xmms}
|
||||
BuildRequires: xmms-devel desktop-file-utils
|
||||
Source1: xmms-flac.desktop
|
||||
%endif
|
||||
%ifarch %{ix86}
|
||||
# 2.0 supports symbol visibility
|
||||
BuildRequires: nasm >= 2.0
|
||||
%endif
|
||||
BuildRequires: make
|
||||
|
||||
Patch1: flac-cve-2020-0499.patch
|
||||
# handle end-of-stream when encoding with verification
|
||||
Patch2: flac-cve-2021-0561.patch
|
||||
|
||||
%description
|
||||
FLAC stands for Free Lossless Audio Codec. Grossly oversimplified, FLAC
|
||||
@ -32,7 +41,6 @@ This package contains the command-line tools and documentation.
|
||||
|
||||
%package libs
|
||||
Summary: Libraries for the Free Lossless Audio Codec
|
||||
Group: System Environment/Libraries
|
||||
Obsoletes: flac < 1.2.1-11
|
||||
|
||||
%description libs
|
||||
@ -46,7 +54,6 @@ This package contains the FLAC libraries.
|
||||
|
||||
%package devel
|
||||
Summary: Development libraries and header files from FLAC
|
||||
Group: Development/Libraries
|
||||
Requires: %{name}-libs%{?_isa} = %{version}-%{release}
|
||||
Requires: pkgconfig
|
||||
|
||||
@ -54,12 +61,23 @@ Requires: pkgconfig
|
||||
This package contains all the files needed to develop applications that
|
||||
will use the Free Lossless Audio Codec.
|
||||
|
||||
%if %{with_xmms}
|
||||
%package -n xmms-flac
|
||||
Summary: XMMS plugin needed to play FLAC (Free Lossless Audio Codec) files
|
||||
# The entire FLAC sources are covered by multiple licenses, but the xmms plugin
|
||||
# is only GPLv2+
|
||||
License: GPLv2+
|
||||
|
||||
%description -n xmms-flac
|
||||
FLAC is a Free Lossless Audio Codec. The FLAC format supports streaming,
|
||||
seeking, and archival, and gives 25-75% compression on typical CD audio.
|
||||
This is the input plugin for XMMS to be able to read FLAC files.
|
||||
%endif
|
||||
|
||||
%prep
|
||||
%setup -q
|
||||
%patch1 -p1 -b .cflags
|
||||
%patch2 -p1 -b .memleak
|
||||
%patch3 -p1 -b .nonasm
|
||||
%patch4 -p1 -b .cve-2020-22219
|
||||
%patch1 -p1 -b .cve-2020-0499
|
||||
%patch2 -p1 -b .cve-2021-0561
|
||||
|
||||
%build
|
||||
# use our libtool to avoid problems with RPATH
|
||||
@ -68,14 +86,23 @@ will use the Free Lossless Audio Codec.
|
||||
# -funroll-loops makes encoding about 10% faster
|
||||
export CFLAGS="%{optflags} -funroll-loops"
|
||||
%configure \
|
||||
--htmldir=%{_docdir}/flac/html \
|
||||
%if %{with_xmms}
|
||||
--enable-xmms-plugin \
|
||||
%else
|
||||
--disable-xmms-plugin \
|
||||
%endif
|
||||
--disable-silent-rules \
|
||||
--disable-thorough-tests
|
||||
|
||||
make %{?_smp_mflags}
|
||||
%make_build
|
||||
|
||||
%install
|
||||
make install DESTDIR=%{buildroot}
|
||||
%make_install
|
||||
|
||||
%if %{with_xmms}
|
||||
desktop-file-install --dir=%{buildroot}%{_datadir}/applications %{SOURCE1}
|
||||
%endif
|
||||
|
||||
# split documentation
|
||||
mv %{buildroot}%{_docdir}/flac* ./flac-doc
|
||||
@ -84,9 +111,12 @@ mv flac-doc{/html/api,-devel}
|
||||
rm flac-doc/FLAC.tag
|
||||
|
||||
rm %{buildroot}%{_libdir}/*.la
|
||||
%if %{with_xmms}
|
||||
rm %{buildroot}%{xmms_inputdir}/*.la
|
||||
%endif
|
||||
|
||||
%check
|
||||
make -C test check FLAC__TEST_LEVEL=0 &> /dev/null
|
||||
make check
|
||||
|
||||
%ldconfig_scriptlets libs
|
||||
|
||||
@ -98,7 +128,8 @@ make -C test check FLAC__TEST_LEVEL=0 &> /dev/null
|
||||
|
||||
%files libs
|
||||
%doc AUTHORS COPYING* README
|
||||
%{_libdir}/*.so.*
|
||||
%{_libdir}/libFLAC.so.8*
|
||||
%{_libdir}/libFLAC++.so.6*
|
||||
|
||||
%files devel
|
||||
%doc flac-doc-devel/*
|
||||
@ -107,18 +138,61 @@ make -C test check FLAC__TEST_LEVEL=0 &> /dev/null
|
||||
%{_libdir}/pkgconfig/*
|
||||
%{_datadir}/aclocal/*.m4
|
||||
|
||||
%if %{with_xmms}
|
||||
%files -n xmms-flac
|
||||
%license COPYING.GPL
|
||||
%{_datadir}/applications/xmms-flac.desktop
|
||||
%{xmms_inputdir}/libxmms-flac.so
|
||||
%endif
|
||||
|
||||
%changelog
|
||||
* Mon Sep 25 2023 Miroslav Lichvar <mlichvar@redhat.com> 1.3.2-11
|
||||
- rebuild
|
||||
* Thu May 05 2022 Miroslav Lichvar <mlichvar@redhat.com> 1.3.3-10
|
||||
- handle end-of-stream when encoding with verification (CVE-2021-0561)
|
||||
|
||||
* Mon Sep 18 2023 Miroslav Lichvar <mlichvar@redhat.com> 1.3.2-10
|
||||
- don't free memory that is still used after realloc() error (CVE-2020-22219)
|
||||
* Mon Aug 09 2021 Mohan Boddu <mboddu@redhat.com> - 1.3.3-9
|
||||
- Rebuilt for IMA sigs, glibc 2.34, aarch64 flags
|
||||
Related: rhbz#1991688
|
||||
|
||||
* Thu Sep 20 2018 Miroslav Lichvar <mlichvar@redhat.com> 1.3.2-9
|
||||
- disable nasm to avoid gaps in annobin coverage (#1630561)
|
||||
* Thu Apr 15 2021 Mohan Boddu <mboddu@redhat.com> - 1.3.3-8
|
||||
- Rebuilt for RHEL 9 BETA on Apr 15th 2021. Related: rhbz#1947937
|
||||
|
||||
* Wed May 16 2018 Miroslav Lichvar <mlichvar@redhat.com> 1.3.2-8
|
||||
- drop xmms-flac subpackage (#1578806)
|
||||
* Fri Feb 19 2021 Adam Jackson <ajax@redhat.com> - 1.3.3-7
|
||||
- Fix the previous change to actually build in RHEL
|
||||
|
||||
* Thu Feb 18 2021 Adam Jackson <ajax@redhat.com> - 1.3.3-6
|
||||
- Disable xmms in RHEL
|
||||
|
||||
* Tue Jan 26 2021 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.3-5
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild
|
||||
|
||||
* Thu Jan 07 2021 Miroslav Lichvar <mlichvar@redhat.com> 1.3.3-4
|
||||
- fix out-of-bounds read in decoder (CVE-2020-0499)
|
||||
|
||||
* Mon Jul 27 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.3-3
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild
|
||||
|
||||
* Tue Jan 28 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.3-2
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild
|
||||
|
||||
* Tue Aug 06 2019 Miroslav Lichvar <mlichvar@redhat.com> 1.3.3-1
|
||||
- update to 1.3.3
|
||||
- include soname in file list
|
||||
|
||||
* Thu Jul 25 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.2-12
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild
|
||||
|
||||
* Thu Mar 7 2019 Tim Landscheidt <tim@tim-landscheidt.de> - 1.3.2-11
|
||||
- Remove obsolete requirements for %%post/%%postun scriptlets
|
||||
|
||||
* Tue Feb 05 2019 Miroslav Lichvar <mlichvar@redhat.com> 1.3.2-10
|
||||
- rebuild again
|
||||
- fix indentation in buildrequires
|
||||
|
||||
* Thu Jan 31 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.2-9
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild
|
||||
|
||||
* Fri Jul 13 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.2-8
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild
|
||||
|
||||
* Wed May 02 2018 Miroslav Lichvar <mlichvar@redhat.com> 1.3.2-7
|
||||
- fix memory leak in parsing of vorbis comments (CVE-2017-6888)
|
@ -1,31 +0,0 @@
|
||||
diff -up flac-1.3.2/configure.ac.cflags flac-1.3.2/configure.ac
|
||||
--- flac-1.3.2/configure.ac.cflags 2017-01-02 14:02:15.663046237 +0100
|
||||
+++ flac-1.3.2/configure.ac 2017-01-02 14:04:20.718046015 +0100
|
||||
@@ -390,7 +390,7 @@ if test "x$debug" = xtrue; then
|
||||
else
|
||||
CPPFLAGS="-DNDEBUG $CPPFLAGS"
|
||||
CFLAGS=$(echo "$CFLAGS" | sed 's/-O2//')
|
||||
- CFLAGS="-O3 -funroll-loops $CFLAGS"
|
||||
+ CFLAGS="$user_cflags"
|
||||
fi
|
||||
|
||||
XIPH_GCC_VERSION
|
||||
@@ -400,7 +400,6 @@ if test x$ac_cv_c_compiler_gnu = xyes ;
|
||||
CXXFLAGS="$CXXFLAGS -Wall -Wextra -Wcast-align -Wshadow -Wwrite-strings -Wctor-dtor-privacy -Wnon-virtual-dtor -Wreorder -Wsign-promo -Wundef " # -Wcast-qual -Wbad-function-cast -Wwrite-strings -Woverloaded-virtual -Wmissing-declarations
|
||||
|
||||
XIPH_ADD_CFLAGS([-Wdeclaration-after-statement])
|
||||
- XIPH_ADD_CFLAGS([-D_FORTIFY_SOURCE=2])
|
||||
|
||||
AC_LANG_PUSH([C++])
|
||||
XIPH_ADD_CXXFLAGS([-Weffc++])
|
||||
@@ -426,10 +425,6 @@ if test x$ac_cv_c_compiler_gnu = xyes ;
|
||||
XIPH_ADD_CFLAGS([-fno-inline-small-functions])
|
||||
fi
|
||||
|
||||
- if test "x$asm_optimisation$sse_os" = "xyesyes" ; then
|
||||
- XIPH_ADD_CFLAGS([-msse2])
|
||||
- fi
|
||||
-
|
||||
fi
|
||||
|
||||
case "$host_os" in
|
@ -1,177 +0,0 @@
|
||||
Backported to 1.3.2
|
||||
|
||||
commit 21fe95ee828b0b9b944f6aa0bb02d24fbb981815
|
||||
Author: Martijn van Beurden <mvanb1@gmail.com>
|
||||
Date: Wed Aug 3 13:52:19 2022 +0200
|
||||
|
||||
Add and use _nofree variants of safe_realloc functions
|
||||
|
||||
Parts of the code use realloc like
|
||||
|
||||
x = safe_realloc(x, somesize);
|
||||
|
||||
when this is the case, the safe_realloc variant used must free the
|
||||
old memory block in case it fails, otherwise it will leak. However,
|
||||
there are also instances in the code where handling is different:
|
||||
|
||||
if (0 == (x = safe_realloc(y, somesize)))
|
||||
return false
|
||||
|
||||
in this case, y should not be freed, as y is not set to NULL we
|
||||
could encounter double frees. Here the safe_realloc_nofree
|
||||
functions are used.
|
||||
|
||||
diff -up flac-1.3.2/include/share/alloc.h.cve-2020-22219 flac-1.3.2/include/share/alloc.h
|
||||
--- flac-1.3.2/include/share/alloc.h.cve-2020-22219 2016-12-07 21:10:26.218454157 +0100
|
||||
+++ flac-1.3.2/include/share/alloc.h 2023-08-31 11:32:36.335453612 +0200
|
||||
@@ -161,17 +161,30 @@ static inline void *safe_realloc_(void *
|
||||
free(oldptr);
|
||||
return newptr;
|
||||
}
|
||||
-static inline void *safe_realloc_add_2op_(void *ptr, size_t size1, size_t size2)
|
||||
+static inline void *safe_realloc_nofree_add_2op_(void *ptr, size_t size1, size_t size2)
|
||||
+{
|
||||
+ size2 += size1;
|
||||
+ if(size2 < size1)
|
||||
+ return 0;
|
||||
+ return realloc(ptr, size2);
|
||||
+}
|
||||
+
|
||||
+static inline void *safe_realloc_add_3op_(void *ptr, size_t size1, size_t size2, size_t size3)
|
||||
{
|
||||
size2 += size1;
|
||||
if(size2 < size1) {
|
||||
free(ptr);
|
||||
return 0;
|
||||
}
|
||||
- return realloc(ptr, size2);
|
||||
+ size3 += size2;
|
||||
+ if(size3 < size2) {
|
||||
+ free(ptr);
|
||||
+ return 0;
|
||||
+ }
|
||||
+ return safe_realloc_(ptr, size3);
|
||||
}
|
||||
|
||||
-static inline void *safe_realloc_add_3op_(void *ptr, size_t size1, size_t size2, size_t size3)
|
||||
+static inline void *safe_realloc_nofree_add_3op_(void *ptr, size_t size1, size_t size2, size_t size3)
|
||||
{
|
||||
size2 += size1;
|
||||
if(size2 < size1)
|
||||
@@ -182,7 +195,7 @@ static inline void *safe_realloc_add_3op
|
||||
return realloc(ptr, size3);
|
||||
}
|
||||
|
||||
-static inline void *safe_realloc_add_4op_(void *ptr, size_t size1, size_t size2, size_t size3, size_t size4)
|
||||
+static inline void *safe_realloc_nofree_add_4op_(void *ptr, size_t size1, size_t size2, size_t size3, size_t size4)
|
||||
{
|
||||
size2 += size1;
|
||||
if(size2 < size1)
|
||||
@@ -205,6 +218,15 @@ static inline void *safe_realloc_mul_2op
|
||||
return safe_realloc_(ptr, size1*size2);
|
||||
}
|
||||
|
||||
+static inline void *safe_realloc_nofree_mul_2op_(void *ptr, size_t size1, size_t size2)
|
||||
+{
|
||||
+ if(!size1 || !size2)
|
||||
+ return realloc(ptr, 0); /* preserve POSIX realloc(ptr, 0) semantics */
|
||||
+ if(size1 > SIZE_MAX / size2)
|
||||
+ return 0;
|
||||
+ return realloc(ptr, size1*size2);
|
||||
+}
|
||||
+
|
||||
/* size1 * (size2 + size3) */
|
||||
static inline void *safe_realloc_muladd2_(void *ptr, size_t size1, size_t size2, size_t size3)
|
||||
{
|
||||
@@ -216,4 +238,15 @@ static inline void *safe_realloc_muladd2
|
||||
return safe_realloc_mul_2op_(ptr, size1, size2);
|
||||
}
|
||||
|
||||
+/* size1 * (size2 + size3) */
|
||||
+static inline void *safe_realloc_nofree_muladd2_(void *ptr, size_t size1, size_t size2, size_t size3)
|
||||
+{
|
||||
+ if(!size1 || (!size2 && !size3))
|
||||
+ return realloc(ptr, 0); /* preserve POSIX realloc(ptr, 0) semantics */
|
||||
+ size2 += size3;
|
||||
+ if(size2 < size3)
|
||||
+ return 0;
|
||||
+ return safe_realloc_nofree_mul_2op_(ptr, size1, size2);
|
||||
+}
|
||||
+
|
||||
#endif
|
||||
diff -up flac-1.3.2/src/flac/encode.c.cve-2020-22219 flac-1.3.2/src/flac/encode.c
|
||||
--- flac-1.3.2/src/flac/encode.c.cve-2020-22219 2016-12-07 21:10:26.218454157 +0100
|
||||
+++ flac-1.3.2/src/flac/encode.c 2023-08-31 11:32:36.335453612 +0200
|
||||
@@ -1744,10 +1744,10 @@ static void static_metadata_clear(static
|
||||
static FLAC__bool static_metadata_append(static_metadata_t *m, FLAC__StreamMetadata *d, FLAC__bool needs_delete)
|
||||
{
|
||||
void *x;
|
||||
- if(0 == (x = safe_realloc_muladd2_(m->metadata, sizeof(*m->metadata), /*times (*/m->num_metadata, /*+*/1/*)*/)))
|
||||
+ if(0 == (x = safe_realloc_nofree_muladd2_(m->metadata, sizeof(*m->metadata), /*times (*/m->num_metadata, /*+*/1/*)*/)))
|
||||
return false;
|
||||
m->metadata = (FLAC__StreamMetadata**)x;
|
||||
- if(0 == (x = safe_realloc_muladd2_(m->needs_delete, sizeof(*m->needs_delete), /*times (*/m->num_metadata, /*+*/1/*)*/)))
|
||||
+ if(0 == (x = safe_realloc_nofree_muladd2_(m->needs_delete, sizeof(*m->needs_delete), /*times (*/m->num_metadata, /*+*/1/*)*/)))
|
||||
return false;
|
||||
m->needs_delete = (FLAC__bool*)x;
|
||||
m->metadata[m->num_metadata] = d;
|
||||
diff -up flac-1.3.2/src/flac/foreign_metadata.c.cve-2020-22219 flac-1.3.2/src/flac/foreign_metadata.c
|
||||
--- flac-1.3.2/src/flac/foreign_metadata.c.cve-2020-22219 2016-12-07 21:10:26.222454288 +0100
|
||||
+++ flac-1.3.2/src/flac/foreign_metadata.c 2023-08-31 11:32:36.335453612 +0200
|
||||
@@ -75,7 +75,7 @@ static FLAC__bool copy_data_(FILE *fin,
|
||||
|
||||
static FLAC__bool append_block_(foreign_metadata_t *fm, FLAC__off_t offset, FLAC__uint32 size, const char **error)
|
||||
{
|
||||
- foreign_block_t *fb = safe_realloc_muladd2_(fm->blocks, sizeof(foreign_block_t), /*times (*/fm->num_blocks, /*+*/1/*)*/);
|
||||
+ foreign_block_t *fb = safe_realloc_nofree_muladd2_(fm->blocks, sizeof(foreign_block_t), /*times (*/fm->num_blocks, /*+*/1/*)*/);
|
||||
if(fb) {
|
||||
fb[fm->num_blocks].offset = offset;
|
||||
fb[fm->num_blocks].size = size;
|
||||
diff -up flac-1.3.2/src/libFLAC/bitwriter.c.cve-2020-22219 flac-1.3.2/src/libFLAC/bitwriter.c
|
||||
--- flac-1.3.2/src/libFLAC/bitwriter.c.cve-2020-22219 2016-12-07 21:10:26.222454288 +0100
|
||||
+++ flac-1.3.2/src/libFLAC/bitwriter.c 2023-08-31 11:32:36.335453612 +0200
|
||||
@@ -124,7 +124,7 @@ FLAC__bool bitwriter_grow_(FLAC__BitWrit
|
||||
FLAC__ASSERT(new_capacity > bw->capacity);
|
||||
FLAC__ASSERT(new_capacity >= bw->words + ((bw->bits + bits_to_add + FLAC__BITS_PER_WORD - 1) / FLAC__BITS_PER_WORD));
|
||||
|
||||
- new_buffer = safe_realloc_mul_2op_(bw->buffer, sizeof(bwword), /*times*/new_capacity);
|
||||
+ new_buffer = safe_realloc_nofree_mul_2op_(bw->buffer, sizeof(bwword), /*times*/new_capacity);
|
||||
if(new_buffer == 0)
|
||||
return false;
|
||||
bw->buffer = new_buffer;
|
||||
diff -up flac-1.3.2/src/libFLAC/metadata_object.c.cve-2020-22219 flac-1.3.2/src/libFLAC/metadata_object.c
|
||||
--- flac-1.3.2/src/libFLAC/metadata_object.c.cve-2020-22219 2023-08-31 11:32:36.336453612 +0200
|
||||
+++ flac-1.3.2/src/libFLAC/metadata_object.c 2023-08-31 11:34:18.844405405 +0200
|
||||
@@ -98,7 +98,7 @@ static FLAC__bool free_copy_bytes_(FLAC_
|
||||
/* realloc() failure leaves entry unchanged */
|
||||
static FLAC__bool ensure_null_terminated_(FLAC__byte **entry, unsigned length)
|
||||
{
|
||||
- FLAC__byte *x = safe_realloc_add_2op_(*entry, length, /*+*/1);
|
||||
+ FLAC__byte *x = safe_realloc_nofree_add_2op_(*entry, length, /*+*/1);
|
||||
if (x != NULL) {
|
||||
x[length] = '\0';
|
||||
*entry = x;
|
||||
diff -up flac-1.3.2/src/plugin_common/tags.c.cve-2020-22219 flac-1.3.2/src/plugin_common/tags.c
|
||||
--- flac-1.3.2/src/plugin_common/tags.c.cve-2020-22219 2016-12-07 21:10:26.234454678 +0100
|
||||
+++ flac-1.3.2/src/plugin_common/tags.c 2023-08-31 11:32:36.336453612 +0200
|
||||
@@ -317,7 +317,7 @@ FLAC__bool FLAC_plugin__tags_add_tag_utf
|
||||
const size_t value_len = strlen(value);
|
||||
const size_t separator_len = strlen(separator);
|
||||
FLAC__byte *new_entry;
|
||||
- if(0 == (new_entry = safe_realloc_add_4op_(entry->entry, entry->length, /*+*/value_len, /*+*/separator_len, /*+*/1)))
|
||||
+ if(0 == (new_entry = safe_realloc_nofree_add_4op_(entry->entry, entry->length, /*+*/value_len, /*+*/separator_len, /*+*/1)))
|
||||
return false;
|
||||
memcpy(new_entry+entry->length, separator, separator_len);
|
||||
entry->length += separator_len;
|
||||
diff -up flac-1.3.2/src/share/utf8/iconvert.c.cve-2020-22219 flac-1.3.2/src/share/utf8/iconvert.c
|
||||
--- flac-1.3.2/src/share/utf8/iconvert.c.cve-2020-22219 2016-12-07 21:10:26.234454678 +0100
|
||||
+++ flac-1.3.2/src/share/utf8/iconvert.c 2023-08-31 11:32:36.336453612 +0200
|
||||
@@ -149,7 +149,7 @@ int iconvert(const char *fromcode, const
|
||||
iconv_close(cd1);
|
||||
return ret;
|
||||
}
|
||||
- newbuf = safe_realloc_add_2op_(utfbuf, (ob - utfbuf), /*+*/1);
|
||||
+ newbuf = safe_realloc_nofree_add_2op_(utfbuf, (ob - utfbuf), /*+*/1);
|
||||
if (!newbuf)
|
||||
goto fail;
|
||||
ob = (ob - utfbuf) + newbuf;
|
@ -1,22 +0,0 @@
|
||||
commit 4f47b63e9c971e6391590caf00a0f2a5ed612e67
|
||||
Author: Erik de Castro Lopo <erikd@mega-nerd.com>
|
||||
Date: Sat Apr 8 18:34:49 2017 +1000
|
||||
|
||||
stream_decoder.c: Fix a memory leak
|
||||
|
||||
Leak reported by Secunia Research.
|
||||
|
||||
diff --git a/src/libFLAC/stream_decoder.c b/src/libFLAC/stream_decoder.c
|
||||
index 14d5fe7f..a5527511 100644
|
||||
--- a/src/libFLAC/stream_decoder.c
|
||||
+++ b/src/libFLAC/stream_decoder.c
|
||||
@@ -1753,6 +1753,9 @@ FLAC__bool read_metadata_vorbiscomment_(FLAC__StreamDecoder *decoder, FLAC__Stre
|
||||
}
|
||||
memset (obj->comments[i].entry, 0, obj->comments[i].length) ;
|
||||
if (!FLAC__bitreader_read_byte_block_aligned_no_crc(decoder->private_->input, obj->comments[i].entry, obj->comments[i].length)) {
|
||||
+ /* Current i-th entry is bad, so we delete it. */
|
||||
+ free (obj->comments[i].entry) ;
|
||||
+ obj->comments[i].entry = NULL ;
|
||||
obj->num_comments = i;
|
||||
goto skip;
|
||||
}
|
@ -1,12 +0,0 @@
|
||||
diff -up flac-1.3.2/configure.ac.nonasm flac-1.3.2/configure.ac
|
||||
--- flac-1.3.2/configure.ac.nonasm 2018-09-20 18:07:24.511716480 +0200
|
||||
+++ flac-1.3.2/configure.ac 2018-09-20 18:21:18.727824763 +0200
|
||||
@@ -377,7 +377,7 @@ if test x$have_clock_gettime = xyes; the
|
||||
fi
|
||||
|
||||
# only matters for x86
|
||||
-AC_CHECK_PROGS(NASM, nasm)
|
||||
+#AC_CHECK_PROGS(NASM, nasm)
|
||||
AM_CONDITIONAL(FLaC__HAS_NASM, test -n "$NASM")
|
||||
if test -n "$NASM" ; then
|
||||
AC_DEFINE(FLAC__HAS_NASM)
|
25
gating.yaml
25
gating.yaml
@ -1,25 +0,0 @@
|
||||
--- !Policy
|
||||
product_versions:
|
||||
- fedora-*
|
||||
decision_context: bodhi_update_push_testing
|
||||
subject_type: koji_build
|
||||
rules:
|
||||
- !PassingTestCaseRule {test_case_name: fedora-ci.koji-build./plans/tier1-public.functional}
|
||||
|
||||
#Rawhide
|
||||
--- !Policy
|
||||
product_versions:
|
||||
- fedora-*
|
||||
decision_context: bodhi_update_push_stable
|
||||
subject_type: koji_build
|
||||
rules:
|
||||
- !PassingTestCaseRule {test_case_name: fedora-ci.koji-build./plans/tier1-public.functional}
|
||||
|
||||
#gating rhel
|
||||
--- !Policy
|
||||
product_versions:
|
||||
- rhel-*
|
||||
decision_context: osci_compose_gate
|
||||
rules:
|
||||
- !PassingTestCaseRule {test_case_name: osci.brew-build./plans/tier1-public.functional}
|
||||
- !PassingTestCaseRule {test_case_name: osci.brew-build./plans/tier1-internal.functional}
|
36
plans.fmf
36
plans.fmf
@ -1,36 +0,0 @@
|
||||
/tier1-internal:
|
||||
plan:
|
||||
import:
|
||||
url: https://src.fedoraproject.org/tests/flac.git
|
||||
name: /plans/tier1/internal
|
||||
|
||||
/tier1-public:
|
||||
plan:
|
||||
import:
|
||||
url: https://src.fedoraproject.org/tests/flac.git
|
||||
name: /plans/tier1/public
|
||||
|
||||
/tier2-tier3-internal:
|
||||
plan:
|
||||
import:
|
||||
url: https://src.fedoraproject.org/tests/flac.git
|
||||
name: /plans/tier2-tier3/internal
|
||||
|
||||
/tier2-tier3-public:
|
||||
plan:
|
||||
import:
|
||||
url: https://src.fedoraproject.org/tests/flac.git
|
||||
name: /plans/tier2-tier3/public
|
||||
|
||||
/others-internal:
|
||||
plan:
|
||||
import:
|
||||
url: https://src.fedoraproject.org/tests/flac.git
|
||||
name: /plans/others/internal
|
||||
|
||||
/others-public:
|
||||
plan:
|
||||
import:
|
||||
url: https://src.fedoraproject.org/tests/flac.git
|
||||
name: /plans/others/public
|
||||
|
Loading…
Reference in New Issue
Block a user