Blame SPECS/annobin.spec

7cfd14
7cfd14
%define __python /opt/rh/gcc-toolset-9/root/usr/bin/python3
7cfd14
%{?scl:%scl_package annobin}
7cfd14
7cfd14
Name:    %{?scl_prefix}annobin
7cfd14
Summary: Annotate and examine compiled binary files
398790
Version: 10.23
7cfd14
Release: 1%{?dist}
7cfd14
License: GPLv3+
7cfd14
# Maintainer: nickc@redhat.com
7cfd14
# Web Page: https://sourceware.org/annobin/
7cfd14
# Watermark Protocol: https://fedoraproject.org/wiki/Toolchain/Watermark
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
398790
# Use "--with tests" to enable the testsuite.
398790
%bcond_with tests
7cfd14
7cfd14
# Use "--without annocheck" to disable the installation of the annocheck program.
7cfd14
%bcond_without annocheck
7cfd14
7cfd14
# Use "--with debuginfod" to force support for debuginfod to be compiled into
7cfd14
# the annocheck program.  By default the configure script will check for
7cfd14
# availablilty at build time, but this might not match the run time situation.
7cfd14
# FIXME: Add a --without debuginfod option to forcefully disable the configure
7cfd14
# time check for debuginfod support.
7cfd14
%bcond_with debuginfod
7cfd14
7cfd14
# Use "--with clangplugin" to enable the building of the annobin plugin for Clang.
7cfd14
%bcond_with clangplugin
7cfd14
7cfd14
# Use "--without gccplugin" to disable the building of the annobin plugin for GCC.
7cfd14
%bcond_without gccplugin
7cfd14
7cfd14
# Use "--with llvmplugin" to enable the building of the annobin plugin for LLVM.
7cfd14
%bcond_with llvmplugin
7cfd14
7cfd14
# Set this to zero to disable the requirement for a specific version of gcc.
7cfd14
# This should only be needed if there is some kind of problem with the version
7cfd14
# checking logic or when building on RHEL-7 or earlier.
7cfd14
%global with_hard_gcc_version_requirement 1
7cfd14
7cfd14
%bcond_with plugin_rebuild
7cfd14
# Allow the building of annobin without using annobin itself.
7cfd14
# This is because if we are bootstrapping a new build environment we can have
7cfd14
# a new version of gcc installed, but without a new of annobin installed.
7cfd14
# (i.e. we are building the new version of annobin to go with the new version
7cfd14
# of gcc).  If the *old* annobin plugin is used whilst building this new
7cfd14
# version, the old plugin will complain that version of gcc for which it
7cfd14
# was built is different from the version of gcc that is now being used, and
7cfd14
# then it will abort.
7cfd14
#
7cfd14
# The default was to use plugin during rebuilds (cf BZ 1630550) but this has
7cfd14
# been changed because of the need to be able to rebuild annobin when a change
7cfd14
# to gcc breaks the version installed into the buildroot.
7cfd14
%if %{without plugin_rebuild}
7cfd14
%undefine _annotated_build
7cfd14
%endif
7cfd14
7cfd14
%{!?llvm_version:%global llvm_version 11.1.0}
7cfd14
%{!?llvm_plugin_dir:%global llvm_plugin_dir %{_libdir}/llvm/%{llvm_version}}
7cfd14
%{!?clang_plugin_dir:%global clang_plugin_dir %{_libdir}/clang/%{llvm_version}}
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
7cfd14
# Source:  https://nickc.fedorapeople.org/annobin-%%{version}.tar.xz
7cfd14
Source:  annobin-%{version}.tar.xz
7cfd14
# For the latest sources use:  git clone git://sourceware.org/git/annobin.git
7cfd14
398790
# Insert patches here, if needed.
398790
# Patch01: annobin.unicode.patch
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
7cfd14
%{?scl:Requires:%scl_runtime}
7cfd14
%{?scl:BuildRequires:%scl_runtime}
7cfd14
%{?scl:BuildRequires:scl-utils-build}
398790
# We need the gcc-toolset-11 version of gcc to build annobin, as otherwise the versions will not match.
7cfd14
%{?scl:Requires:%scl_require_package %{scl} gcc}
7cfd14
7cfd14
BuildRequires: %{?scl_prefix}gcc
7cfd14
7cfd14
%define gcc_for_annobin %{?_scl_root}/usr/bin/gcc
7cfd14
%define gxx_for_annobin %{?_scl_root}/usr/bin/g++
7cfd14
7cfd14
%if %{with gccplugin}
7cfd14
Requires: annobin-plugin-gcc
7cfd14
7cfd14
# [Stolen from gcc-python-plugin]
7cfd14
# GCC will only load plugins that were built against exactly that build of GCC
7cfd14
# We thus need to embed the exact GCC version as a requirement within the
7cfd14
# metadata.
7cfd14
#
7cfd14
# Define "gcc_vr", a variable to hold the VERSION-RELEASE string for the gcc
7cfd14
# we are being built against.
7cfd14
#
7cfd14
# Unfortunately, we can't simply run:
7cfd14
#   rpm -q --qf="%%{version}-%%{release}"
7cfd14
# to determine this, as there's no guarantee of a sane rpm database within
7cfd14
# the chroots created by our build system
7cfd14
#
7cfd14
# So we instead query the version from gcc's output.
7cfd14
#
7cfd14
# gcc.spec has:
7cfd14
#   Version: %%{gcc_version}
7cfd14
#   Release: %%{gcc_release}%%{?dist}
7cfd14
#   ...snip...
7cfd14
#   echo 'Red Hat %%{version}-%%{gcc_release}' > gcc/DEV-PHASE
7cfd14
#
7cfd14
# So, given this output:
7cfd14
#
7cfd14
#   $ gcc --version
7cfd14
#   gcc (GCC) 4.6.1 20110908 (Red Hat 4.6.1-9)
7cfd14
#   Copyright (C) 2011 Free Software Foundation, Inc.
7cfd14
#   This is free software; see the source for copying conditions.  There is NO
7cfd14
#   warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
7cfd14
#
7cfd14
# we can scrape out the "4.6.1" from the version line.
7cfd14
#
7cfd14
# The following implements the above:
7cfd14
7cfd14
%global gcc_vr %(%gcc_for_annobin --version | head -n 1 | sed -e 's|.*(Red\ Hat\ ||g' -e 's|)$||g')
7cfd14
7cfd14
# We need the major version of gcc.
7cfd14
%global gcc_major %(echo "%{gcc_vr}" | cut -f1 -d".")
7cfd14
%global gcc_next  %(v="%{gcc_major}"; echo $((++v)))
7cfd14
7cfd14
# Needed when building the srpm.
7cfd14
%if 0%{?gcc_major} == 0
7cfd14
%global gcc_major 0
7cfd14
%endif
7cfd14
7cfd14
# This is a gcc plugin, hence gcc is required.
7cfd14
%if %{with_hard_gcc_version_requirement}
7cfd14
# BZ 1607430 - There is an exact requirement on the major version of gcc.
7cfd14
Requires: (%{?scl_prefix}gcc >= %{gcc_major} with %{?scl_prefix}gcc < %{gcc_next})
7cfd14
%else
7cfd14
Requires: %{?scl_prefix}gcc
7cfd14
%endif
7cfd14
398790
BuildRequires: %{?scl_prefix}gcc-plugin-devel %{?scl_prefix}gcc-c++
7cfd14
7cfd14
%endif
7cfd14
7cfd14
%if %{with llvmplugin}
7cfd14
Requires: annobin-plugin-llvm
7cfd14
BuildRequires: clang clang-devel llvm llvm-devel compiler-rt
7cfd14
%endif
7cfd14
7cfd14
%if %{with clangplugin}
7cfd14
Requires: annobin-plugin-clang
7cfd14
BuildRequires: clang clang-devel llvm llvm-devel compiler-rt
7cfd14
%endif
7cfd14
7cfd14
# The documentation uses pod2man...
7cfd14
BuildRequires: perl-interpreter perl-podlators gawk
7cfd14
7cfd14
#---------------------------------------------------------------------------
7cfd14
7cfd14
%description
7cfd14
Provides a plugin for GCC that records extra information in the files
7cfd14
that it compiles.
7cfd14
7cfd14
Note - the plugin is automatically enabled in gcc builds via flags
7cfd14
provided by the redhat-rpm-macros package.
7cfd14
7cfd14
%if %{with clangplugin}
7cfd14
Also provides a plugin for Clang which performs a similar function.
7cfd14
%endif
7cfd14
7cfd14
%if %{with llvmplugin}
7cfd14
Also provides a plugin for LLVM which performs a similar function.
7cfd14
%endif
7cfd14
7cfd14
#---------------------------------------------------------------------------
7cfd14
7cfd14
# Now that we have sub-packages for all of the plugins and for annocheck,
7cfd14
# there are no executables left to go into the "annobin" rpm.  But top-level
7cfd14
# packages cannot have "BuildArch: noarch" if sub-packages do have
7cfd14
# architecture requirements, and rpmlint generates an error if an
7cfd14
# architecture specific rpm does not contain any binaries.  So instead all of
7cfd14
# the documentation has been moved into an architecture neutral sub-package,
7cfd14
# and there no longer is a top level annobin rpm at all.
7cfd14
7cfd14
%package docs
7cfd14
Summary: Documentation and shell scripts for use with annobin
7cfd14
BuildArch: noarch
7cfd14
# annobin renamed to annobin-doc in 9.66-1
7cfd14
Provides: %{name} = %{version}-%{release}
7cfd14
Obsoletes: %{name} < 9.66-1
7cfd14
7cfd14
%description docs
7cfd14
Provides the documentation files and example shell scripts for use with annobin.
7cfd14
7cfd14
#----------------------------------------------------------------------------
7cfd14
%if %{with tests}
7cfd14
7cfd14
%package tests
7cfd14
Summary: Test scripts and binaries for checking the behaviour and output of the annobin plugin
7cfd14
Requires: %{name}-docs = %{version}-%{release}
7cfd14
7cfd14
%description tests
7cfd14
Provides a means to test the generation of annotated binaries and the parsing
7cfd14
of the resulting files.
7cfd14
7cfd14
%if %{with debuginfod}
7cfd14
BuildRequires: elfutils-debuginfod-client-devel
7cfd14
%endif
7cfd14
7cfd14
%endif
7cfd14
7cfd14
#----------------------------------------------------------------------------
7cfd14
%if %{with annocheck}
7cfd14
7cfd14
%package annocheck
7cfd14
Summary: A tool for checking the security hardening status of binaries
7cfd14
7cfd14
BuildRequires: %{?scl_prefix}gcc elfutils elfutils-devel elfutils-libelf-devel rpm-devel %{?scl_prefix}binutils-devel
7cfd14
%if %{with debuginfod}
7cfd14
BuildRequires: elfutils-debuginfod-client-devel make
7cfd14
%endif
7cfd14
7cfd14
Requires: %{name}-docs = %{version}-%{release}
7cfd14
7cfd14
%description annocheck
7cfd14
Installs the annocheck program which uses the notes generated by annobin to
7cfd14
check that the specified files were compiled with the correct security
7cfd14
hardening options.
7cfd14
7cfd14
%endif
7cfd14
7cfd14
#----------------------------------------------------------------------------
7cfd14
%if %{with gccplugin}
7cfd14
7cfd14
%package plugin-gcc
7cfd14
Summary: annobin gcc plugin
7cfd14
7cfd14
Requires: %{name}-docs = %{version}-%{release}
7cfd14
Conflicts: annobin <= 9.60-1
7cfd14
7cfd14
%description plugin-gcc
7cfd14
Installs an annobin plugin that can be used by gcc.
7cfd14
7cfd14
%endif
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
%if %{with llvmplugin}
7cfd14
7cfd14
%package plugin-llvm
7cfd14
Summary: annobin llvm plugin
7cfd14
7cfd14
Requires: %{name}-docs = %{version}-%{release}
7cfd14
Conflicts: annobin <= 9.60-1
7cfd14
7cfd14
%description plugin-llvm
7cfd14
Installs an annobin plugin that can be used by llvm tools.
7cfd14
7cfd14
%endif
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
%if %{with clangplugin}
7cfd14
7cfd14
%package plugin-clang
7cfd14
Summary: annobin clang plugin
7cfd14
7cfd14
Requires: %{name}-docs = %{version}-%{release}
7cfd14
Conflicts: annobin <= 9.60-1
7cfd14
7cfd14
%description plugin-clang
7cfd14
Installs an annobin plugin that can be used by clang.
7cfd14
7cfd14
%endif
7cfd14
#---------------------------------------------------------------------------------
7cfd14
7cfd14
%global ANNOBIN_GCC_PLUGIN_DIR %(%gcc_for_annobin --print-file-name=plugin)
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
7cfd14
%prep
7cfd14
if [ -z "%{gcc_vr}" ]; then
7cfd14
    echo "*** Missing gcc_vr spec file macro, cannot continue." >&2
7cfd14
    exit 1
7cfd14
fi
7cfd14
7cfd14
echo "Requires: (%{?scl_prefix}gcc >= %{gcc_major} and %{?scl_prefix}gcc < %{gcc_next})"
7cfd14
7cfd14
# Cannot use autosetup as it untar's the sources into annobin-<version>
7cfd14
# but then tries to change directory into <scl-prefix>-annobin-<version>.
7cfd14
# %%autosetup -p1
7cfd14
%setup -q -n annobin-%{version}
398790
# %patch01 -p1
398790
# chmod +x tests/unicode-test
7cfd14
7cfd14
# The plugin has to be configured with the same arcane configure
7cfd14
# scripts used by gcc.  Hence we must not allow the Fedora build
7cfd14
# system to regenerate any of the configure files.
7cfd14
touch aclocal.m4 gcc-plugin/config.h.in
7cfd14
touch configure */configure Makefile.in */Makefile.in
7cfd14
# Similarly we do not want to rebuild the documentation.
7cfd14
touch doc/annobin.info
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
7cfd14
%build
7cfd14
7cfd14
export CFLAGS="$CFLAGS $RPM_OPT_FLAGS -I%{?_scl_root}/usr/include"
7cfd14
export LDFLAGS="$LD_FLAGS $RPM_LD_FLAGS -L%{?_scl_root}/usr/lib64 -L%{?_scl_root}/usr/lib"
7cfd14
398790
CONFIG_ARGS="--quiet"
7cfd14
7cfd14
%if %{with debuginfod}
7cfd14
CONFIG_ARGS="$CONFIG_ARGS --with-debuginfod"
7cfd14
%else
7cfd14
# Note - we explicitly disable debuginfod support if it was not configured.
7cfd14
# This is because by default annobin's configue script will assume --with-debuginfod=auto
7cfd14
# and then run a build time test to see if debugingfod is available.  It
7cfd14
# may well be, but the build time environment may not match the run time
7cfd14
# environment, and the rpm will not have a Requirement on the debuginfod
7cfd14
# client.
7cfd14
CONFIG_ARGS="$CONFIG_ARGS --without-debuginfod"
7cfd14
%endif
7cfd14
7cfd14
%if %{with clangplugin}
7cfd14
CONFIG_ARGS="$CONFIG_ARGS --with-clang"
7cfd14
%endif
7cfd14
7cfd14
%if %{without gccplugin}
7cfd14
CONFIG_ARGS="$CONFIG_ARGS --without-gcc-plugin"
398790
%else
398790
CONFIG_ARGS="$CONFIG_ARGS --with-gcc-plugin-dir=%{ANNOBIN_GCC_PLUGIN_DIR}"
7cfd14
%endif
7cfd14
7cfd14
%if %{with llvmplugin}
7cfd14
CONFIG_ARGS="$CONFIG_ARGS --with-llvm"
7cfd14
%endif
7cfd14
7cfd14
%if %{without tests}
7cfd14
CONFIG_ARGS="$CONFIG_ARGS --without-test"
7cfd14
%endif
7cfd14
7cfd14
%if %{without annocheck}
7cfd14
CONFIG_ARGS="$CONFIG_ARGS --without-annocheck"
7cfd14
%endif
7cfd14
398790
%set_build_flags
398790
398790
%ifarch %{ix86} x86_64
398790
# FIXME: There should be a better way to do this.
398790
export CLANG_TARGET_OPTIONS="-fcf-protection"
398790
%endif
398790
7cfd14
%configure ${CONFIG_ARGS} || cat config.log
7cfd14
7cfd14
%make_build
7cfd14
7cfd14
%if %{with plugin_rebuild}
7cfd14
# Rebuild the plugin(s), this time using the plugin itself!  This
7cfd14
# ensures that the plugin works, and that it contains annotations
7cfd14
# of its own.
7cfd14
7cfd14
%if %{with gccplugin}
7cfd14
cp gcc-plugin/.libs/annobin.so.0.0.0 %{_tmppath}/tmp_annobin.so
7cfd14
make -C gcc-plugin clean
7cfd14
BUILD_FLAGS="-fplugin=%{_tmppath}/tmp_annobin.so"
7cfd14
7cfd14
# Disable the standard annobin plugin so that we do get conflicts.
7cfd14
# Note: the "-fplugin=annobin" is here, despite the fact that it will also
7cfd14
# be automatically added to the gcc command line via
7cfd14
# "-specs=/usr/lib/rpm/redhat/redhat-annobin-cc1" because of a bug in gcc's
7cfd14
# plugin command line options handling.  GCC will issue an error saying that
7cfd14
# there is no plugin called "annobin" matching the -fplugin-arg-annobin-disable
7cfd14
# option, despite the fact that there patently is.
7cfd14
BUILD_FLAGS="$BUILD_FLAGS -fplugin=annobin -fplugin-arg-annobin-disable"
7cfd14
7cfd14
# If building on RHEL7, enable the next option as the .attach_to_group
7cfd14
# assembler pseudo op is not available in the assembler.
7cfd14
# BUILD_FLAGS="$BUILD_FLAGS -fplugin-arg-tmp_annobin-no-attach"
7cfd14
7cfd14
make -C gcc-plugin CXXFLAGS="%{optflags} $BUILD_FLAGS"
7cfd14
rm %{_tmppath}/tmp_annobin.so
7cfd14
%endif
7cfd14
7cfd14
%if %{with clangplugin}
7cfd14
cp clang-plugin/annobin-for-clang.so %{_tmppath}/tmp_annobin.so
7cfd14
make -C clang-plugin all CXXFLAGS="%{optflags} $BUILD_FLAGS"
7cfd14
%endif
7cfd14
7cfd14
%if %{with llvmplugin}
7cfd14
cp llvm-plugin/annobin-for-llvm.so %{_tmppath}/tmp_annobin.so
7cfd14
make -C llvm-plugin all CXXFLAGS="%{optflags} $BUILD_FLAGS"
7cfd14
%endif
7cfd14
7cfd14
%endif
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
7cfd14
%install
398790
# PLUGIN_INSTALL_DIR is used by the Clang and LLVM makefiles...
7cfd14
%make_install PLUGIN_INSTALL_DIR=%{buildroot}/%{llvm_plugin_dir}
7cfd14
7cfd14
%if %{with clangplugin}
7cfd14
# Move clang plugin to a seperate directory.
7cfd14
mkdir -p %{buildroot}/%{clang_plugin_dir}
7cfd14
mv %{buildroot}/%{llvm_plugin_dir}/annobin-for-clang.so %{buildroot}/%{clang_plugin_dir}
7cfd14
%endif
7cfd14
7cfd14
rm -f %{buildroot}%{_infodir}/dir
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
7cfd14
%if %{with tests}
7cfd14
%check
398790
# With scl the tests are run with the wrong version of gcc.  Hence
398790
# we allow the tests to fail.
398790
make check GCC=%gcc_for_annobin
7cfd14
if [ -f tests/test-suite.log ]; then
7cfd14
    cat tests/test-suite.log
7cfd14
fi
7cfd14
7cfd14
%if %{with clangplugin}
7cfd14
# FIXME: RUN CLANG tests
7cfd14
%endif
7cfd14
7cfd14
%if %{with llvmplugin}
7cfd14
# FIXME: RUN LLVM tests
7cfd14
%endif
7cfd14
7cfd14
%endif
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
7cfd14
%files docs
7cfd14
%license COPYING3 LICENSE
7cfd14
%exclude %{_datadir}/doc/annobin-plugin/COPYING3
7cfd14
%exclude %{_datadir}/doc/annobin-plugin/LICENSE
7cfd14
%doc %{_datadir}/doc/annobin-plugin/annotation.proposal.txt
7cfd14
%{_infodir}/annobin.info*
7cfd14
%{_mandir}/man1/annobin.1*
7cfd14
%{_mandir}/man1/built-by.1*
7cfd14
%{_mandir}/man1/check-abi.1*
7cfd14
%{_mandir}/man1/hardened.1*
7cfd14
%{_mandir}/man1/run-on-binaries-in.1*
7cfd14
7cfd14
%if %{with llvmplugin}
7cfd14
%files plugin-llvm
7cfd14
%{llvm_plugin_dir}/annobin-for-llvm.so
7cfd14
%endif
7cfd14
7cfd14
%if %{with clangplugin}
7cfd14
%files plugin-clang
7cfd14
%{clang_plugin_dir}/annobin-for-clang.so
7cfd14
%endif
7cfd14
7cfd14
%if %{with gccplugin}
7cfd14
%files plugin-gcc
7cfd14
%{ANNOBIN_GCC_PLUGIN_DIR}
7cfd14
%endif
7cfd14
7cfd14
%if %{with annocheck}
7cfd14
%files annocheck
7cfd14
%{_bindir}/annocheck
7cfd14
%{_mandir}/man1/annocheck.1*
7cfd14
%endif
7cfd14
7cfd14
#---------------------------------------------------------------------------------
7cfd14
7cfd14
%changelog
398790
* Wed Nov 10 2021 Nick Clifton <nickc@redhat.com> - 10.23-1  (#2020405)
398790
- Annocheck: Add a test for unicode characters in identifiers.
398790
- gcc-plugin: Default to link-order grouping for PPC64LE.  (#2016458)
398790
- Annocheck: Do not fail if a --skip-<name> option does not match a known test.
398790
- ldconfig-test: Skip the LTO check.
398790
- Annocheck: Add more glibc function names.
398790
- gcc-plugin: Fix attaching the .text section to the .text.group section.
398790
- Complain about DT_RPATH for Fedora binaries.
398790
- Better reporting of problems in object files.  (#2013708)
398790
- Add a requirement on llvm-libs for clang and llvm plugins.  (#2014573)
398790
- Fix configuring annocheck without gcc-plugin.
398790
- Annocheck: Better reporting of debuginfod problems.
398790
- Tests: Fix bugs in debuginfod test.
398790
- Annocheck: Add tests based upon recent bug fixes.
398790
- Annocheck: Another tweak to glibc detection code.
398790
- Annocheck: Fix memory corruptions when using --debug-path and when a corrupt note is found.  (#20011438)
398790
- Annocheck: Fix MAYB results for mixed GO/C files.
398790
- Annocheck: Move some messages from VERBOSE to VERBOSE2.
398790
- Annocheck: Scan zero-length tool notes.
398790
- Annocheck: Fix covscan detected flaws.
398790
- plugins: Add more required build options.
398790
- Annocheck: Fix cf-prot test to fail if the CET notes are missing.
398790
- Annocheck: Skip gaps in the .plt section.
398790
- Plugins: Add -g option when building LLVM and Clang.
398790
- Annocheck: Add more cases of glibc startup functions.
398790
- Annocheck: Fix covscan detected problems.
398790
- Annocheck: Add --profile=el8.
398790
- gcc-plugin: Conditionalize generation of branch protection note.
398790
- Annocheck: Ignore gaps containing NOP instructions.
398790
- GCC Plugin: Fix detection of running inside the LTO compiler.  (#2004917)
398790
- Annocheck: Do not insist on the DT_AARCH64_PAC_PLT flag being present in AArch64 binaries.
398790
- Annocheck: With gaps at the start/end of the .text section, check for special symbols before displaying a MAYB result.
398790
- Annocheck: Do not set CFLAGS/LDFLAGS when building.  Take from environment instead.
398790
- Annocheck: Fix exit code when tests PASS.
398790
- Documentation: Add node for each hardening test.
398790
- Documentation: Install online.
398790
- Annocheck: Annote FAIL and MAYB results with URL to documentation
398790
- Annocheck: Add --no-urls and --provide-urls options
398790
- Annocheck: Add --help-<tool> option.
398790
- Annocheck: Fix fuzzing detected failures.
398790
- Annocheck: Add --profile option.
398790
- Docs: Document --profile option and rpminspect.yaml.
398790
- Annocheck: Skip GO/CET checks.  Fix fuzzing detected failures.
398790
- LLVM Plugin: Automatically choose the correct tests to run, based upon the version of Clang installed. (#1997444)
398790
- Annocheck: Fix memory corruption.  (#1996963)
398790
- Annocheck: Fix conditionalization of AArch64's PAC+BTI detection.
398790
- Annocheck: Add linker generated function for ppc64le exceptions.  (#1981410)
398790
- LLVM Plugin: Allow checks to be selected from the command line.
398790
- Annocheck: Examine DW_AT_producer for -flto.    
398790
- Annocheck: Conditionalize detection of AArch64's PAC+BTI protection.
398790
- Annocheck: Add linker generated function for s390x exceptions.  (#1981410)
398790
- Annocheck: Generate MAYB results for gaps in notes covering the .text section.  (#1991943)
398790
- Annocheck: Close DWARF file descriptors once the debug info is no longer needed.  (#1981410)
398790
- LLVM Plugin: Update to build with Clang v13.  (Thanks to: Tom Stellard <tstellar@redhat.com>)
398790
- Annocheck: Fix memory corruption.  (#1988715)
398790
- Annocheck: Skip certain tests for kernel modules.
398790
398790
* Fri Oct 29 2021 Nick Clifton  <nickc@redhat.com> - 9.85-3
398790
- Default to disabling the tests as they are often run with the wrong compiler.
398790
398790
* Thu Oct 28 2021 Nick Clifton  <nickc@redhat.com> - 9.85-2
398790
- Annocheck: Add test for multibyte characters in symbol names.  (#2017368)
398790
398790
* Tue Aug 10 2021 Nick Clifton  <nickc@redhat.com> - 9.85-1
398790
- Annocheck: Detect a missing CET note.  (#1991931)
398790
- Annocheck: Do not report future fails for AArch64 notes.
398790
- Annocheck: Warn about multiple --debug-file, --debug-rpm and --debug-dir options.
398790
- Annocheck: Process files in command line order.  (#1988714)
398790
- Annocheck: Reverse AArch64 PAC+BTI check, ie fail if they are enabled.  (#1984995)
398790
- Annocheck: Add another test exceptions.
398790
- Annocheck: Add some more test exceptions.
398790
- Tests: Skip glibc-notes test if the assembler does not support --generate-missing-build-notes.  (#1978573)
398790
- Tests: Skip objcopy test if objcopy does not support --merge-notes.
398790
398790
* Wed Jun 30 2021 Nick Clifton  <nickc@redhat.com> - 9.79-1
398790
- Annocheck: Fix spelling mistake in -mstack-realign failure message.  (#1977349)
398790
- gcc-plugin: Do not record global versions of stack protection settings in LTO mode, if not set.  (#1958954)
398790
- Annocheck: Remove limit on number of input files.
398790
- Annocheck: Conditionalize test of DF_PIE_1 flag.
398790
- clang/llvm plugins: Build with correct security options.
398790
- Annocheck: Better detection of GO compiler version.
398790
- Annocheck: Better support for symbolic links.
398790
- Annocheck: In verbose mode, report the reason for skipping specific tests.  (#1969584)
398790
7cfd14
* Wed May 26 2021 Nick Clifton  <nickc@redhat.com> - 9.73-1
7cfd14
- annocheck: Improve detection of shared libraries.  (#1958954)
7cfd14
7cfd14
* Tue May 25 2021 Nick Clifton  <nickc@redhat.com> - 9.72-2
7cfd14
- NVR bump to rebuild against latest gcc.
7cfd14
7cfd14
* Thu May 13 2021 Nick Clifton  <nickc@redhat.com> - 9.72-1
7cfd14
- Rebase to 9.72.  (#1957319)
7cfd14
- annocheck: Accept 0 as a valid number for gcc minor versions and release numbers.
7cfd14
- gcc-plugin: Add support for ARM and RISCV targets.
7cfd14
- timing: do not initialise the clock if the timing tool is disabled.
7cfd14
- gcc-plugin: Replace ICE messsages with verbose messages.
7cfd14
- Fix the testsuite so that it can be run in parallel.
7cfd14
- Annocheck: WARN if the annobin plugin was built for a newer version of the compiler than the one on which it was run.  (#1950657)
7cfd14
- Obsolete annobin < 9.66-1 (bug #1949570)
7cfd14
- Annocheck: Improve detection of missing GNU-stack support.
7cfd14
- Correct a package rename (bug #1949570)
7cfd14
- Require docs subpackage by the other ones because of a license
7cfd14
- Build-requiring perl-interpreter is enough
7cfd14
- Fix bz1949570
7cfd14
- Fix anomolies reported by covscan.
7cfd14
- Move documentation into a sub-package.
7cfd14
- gcc-plugin: Use a fixed filename when running in LTO mode.
7cfd14
- Annocheck: Fix detection of special function names.  (#1934189)
7cfd14
- Annocheck: FAIL the deliberate use of -fno-stack-protector, but add some exceptions for glibc.  (#1923439)
7cfd14
- Annocheck: Add colour to some messages.  Skip the deliberate use of -fno-stack-protector.  (#1923439)
7cfd14
- Annocheck: Fix some problems with tests for missing notes.
7cfd14
- Split plugins into separate sub-packages
7cfd14
- Add some GO tests to annocheck.
7cfd14
- Add a future fail for the presence of RPATH in the dynamic tags.
7cfd14
- Add the ability to disable the warning message about -D_FORTIFY_SOURCE being missing.
7cfd14
- Workaround for elflint problems with PPC compiled files.  (#1880634)
7cfd14
- Fix bogus AArch64 test failures.
7cfd14
- Improved testing by annocheck.  Add fixed format message mode.
7cfd14
- Fix inconsistency reporting -fcf-protection and -fstack-clash-protection results.
7cfd14
- Add support for -D_FORTIFY_SOURCE=3.
7cfd14
- annocheck: When a binary is produced both by GAS and GCC, select GAS as the real producer.  (#1906171)
7cfd14
- annocheck: Improve test for LTO compiled binaries that do not have -Wall annotations.  (#1906171)
7cfd14
- annocheck: Mark a missining -D_FORTIFY_SOURCE as a FAIL.
7cfd14
- annocheck: Fix notes analyzer to accept empty PPC64 notes.
7cfd14
- gcc plugin: Tweak generation of end symbols for PPC64 when LTO is active.  (#1898075)
7cfd14
- gcc plugin: Add support for GCC 11's cl_vars array.
7cfd14
- Annocheck: Support enabling/disabling future fails.
7cfd14
- GCC plugin: Always record global notes for the .text.startup,
7cfd14
  .text.exit, .text.hot and .text.cold sections.
7cfd14
- Clang plugin: Add -lLLVM to the build command line.
7cfd14
- Annocheck: Improve reporting of missing -D_FORTIFY_SOURCE option.  (#1898075)
7cfd14
- Annocheck: Improve reporting of missing LTO option.
7cfd14
- Add detecting of gimple compiled binaries.
7cfd14
- Add --without-gcc-plugin option.
7cfd14
- Annocheck: Fix bug parsing DW_AT_producer.
7cfd14
- Add test of .note.gnu.property section for PowerPC.
7cfd14
- Add test of objcopy's ability to merge notes.
7cfd14
- NVR bump for another ELN sidetag rebuild.
7cfd14
- Record the -flto setting and produce a soft warning if it is absent.
7cfd14
- Suppress warnings about _D_GLIBCXX_ASSERTIONS if the source code is known to be something other than C++.
7cfd14
- Correct the directory chosen for 32-bit LLVM and Clang plugins.  (#1884951)
7cfd14
- Allow the use of the SHF_LINK_ORDER section flag to discard unused notes.  (Experimental).
7cfd14
- Enable the build and installation of the LLVM and Clang plugins.  (Experimental).
7cfd14
- gcc-plugin: Fix test for empty PowerPC sections.  (#1880634)
7cfd14
- annocheck: Add tests for the AArch64 BTI and PAC security features.  (#1862478)
7cfd14
- gcc plugin: Use a 4 byte offset for PowerPC start symbols, so that they do not break disassemblies.
7cfd14
- gcc plugin: Correct the detection of 32-bit x86 builds.  (#1876197)
7cfd14
- gcc plugin: Detect any attempt to access the global_options array.
7cfd14
- gcc plugin: Do not complain about missing pre-processor options when examining a preprocessed input file.  (#1862718)
7cfd14
- Use more robust checks for AArch64 options.
7cfd14
- Detect CLANG compiled assembler that is missing IBT support.
7cfd14
7cfd14
* Wed Jul 29 2020 Nick Clifton <nickc@redhat.com> - 9.25-1
7cfd14
- Improved target pointer size discovery.
7cfd14
7cfd14
* Mon Jul 27 2020 Fedora Release Engineering <releng@fedoraproject.org> - 9.24-3
7cfd14
- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild
7cfd14
7cfd14
* Sun Jul 26 2020 Nick Clifton <nickc@redhat.com> - 9.24-2
7cfd14
- Rebuild with plugin enabled to check that suppression works.
7cfd14
7cfd14
* Sun Jul 26 2020 Nick Clifton <nickc@redhat.com> - 9.24-1
7cfd14
- Add support for installing clang and llvm plugins.
7cfd14
- Temporary suppression of aarch64 pointer size check.  (#1860549)
7cfd14
7cfd14
* Sat Jul 25 2020 Peter Robinson <pbrobinson@fedoraproject.org> - 9.23-2
7cfd14
- Rebuild for gcc 10.2
7cfd14
7cfd14
* Wed Jul 01 2020 Nick Clifton <nickc@redhat.com> - 9.23-1
7cfd14
- Annocheck: Do not skip tests of the short-enums notes.  (#1743635)
7cfd14
7cfd14
* Mon Jun 15 2020 Nick Clifton <nickc@redhat.com> - 9.22-1
7cfd14
- Add (optional) llvm plugin.
7cfd14
7cfd14
* Wed Apr 22 2020 Nick Clifton <nickc@redhat.com> - 9.21-1
7cfd14
- Annobin: Fall back on using the flags if the option cannot be found in cl_options.  (#1817659)
7cfd14
7cfd14
* Thu Apr 16 2020 Nick Clifton <nickc@redhat.com> - 9.20-1
7cfd14
- Annocheck: Detect Fortran compiled programs.  (#1824393)
7cfd14
7cfd14
* Wed Apr 01 2020 Nick Clifton <nickc@redhat.com> - 9.19-1
7cfd14
- Annobin: If option name mismatch occurs, seach for the real option.  (#1817452)
7cfd14
7cfd14
* Mon Mar 30 2020 Nick Clifton <nickc@redhat.com> - 9.18-1
7cfd14
- Annocheck: Fix a division by zero error when parsing GO binaries.  (#1818863)
7cfd14
7cfd14
* Fri Mar 27 2020 Nick Clifton <nickc@redhat.com> - 9.16-1
7cfd14
- Annobin: Fix access to the -flto and -fsanitize flags.
7cfd14
7cfd14
* Thu Mar 26 2020 Nick Clifton <nickc@redhat.com> - 9.14-1
7cfd14
- Annobin: Use offsets stored in gcc's cl_option structure to access the global_options array, thus removing the need to check for changes in the size of this structure.
7cfd14
7cfd14
* Thu Mar 26 2020 Nick Clifton <nickc@redhat.com> - 9.13-2
7cfd14
- NVR bump to allow rebuilding against new gcc.
7cfd14
7cfd14
* Thu Mar 12 2020 Nick Clifton <nickc@redhat.com> - 9.13-1
7cfd14
- Rename gcc plugin directory to gcc-plugin.
7cfd14
- Stop annocheck from complaining about missing options when the binary has been built in a mixed environment.
7cfd14
7cfd14
* Thu Mar 12 2020 Nick Clifton <nickc@redhat.com> - 9.12-3
7cfd14
- And again, this time with annotation enabled.  (#1810941)
7cfd14
7cfd14
* Thu Mar 12 2020 Nick Clifton <nickc@redhat.com> - 9.12-2
7cfd14
- NVR bump to enable rebuild against updated gcc.  (#1810941)
7cfd14
7cfd14
* Wed Mar 04 2020 Nick Clifton <nickc@redhat.com> - 9.12-1
7cfd14
- Improve builtby tool.
7cfd14
- Stop annocheck complaining about missing notes when the binary is not compiled by either gcc or clang.
7cfd14
- Skip the check of the ENTRY instruction for binaries not compiled by gcc or clang.  (#1809656)
7cfd14
7cfd14
* Fri Feb 28 2020 Nick Clifton <nickc@redhat.com> - 9.11-1
7cfd14
- Fix infinite loop hangup in annocheck.
7cfd14
- Disable debuginfod support by default.
7cfd14
- Improve parsing of .comment section.
7cfd14
7cfd14
* Thu Feb 27 2020 Nick Clifton <nickc@redhat.com> - 9.10-1
7cfd14
- Fix clang plugin to use hidden symbols.
7cfd14
7cfd14
* Tue Feb 25 2020 Nick Clifton <nickc@redhat.com> - 9.09-1
7cfd14
- Add ability to build clang plugin (disabled by default).
7cfd14
7cfd14
* Mon Feb 17 2020 Nick Clifton <nickc@redhat.com> - 9.08-1
7cfd14
- Annocheck: Fix error printing out the version number.
7cfd14
7cfd14
* Fri Feb 14 2020 Nick Clifton <nickc@redhat.com> - 9.07-1
7cfd14
- Annobin: Add checks of the exact location of the examined switches.
7cfd14
7cfd14
* Tue Feb 11 2020 Nick Clifton <nickc@redhat.com> - 9.06-1
7cfd14
- Annobin: Note when stack clash notes are generated.
7cfd14
- Annocheck: Handle multiple builder IDs in the .comment section.
7cfd14
7cfd14
* Fri Jan 31 2020 Nick Clifton <nickc@redhat.com> - 9.05-1
7cfd14
- Add configure option to suppress building annocheck.
7cfd14
7cfd14
* Fri Jan 31 2020 Nick Clifton <nickc@redhat.com> - 9.04-1
7cfd14
- Fix debuginfod test.
7cfd14
7cfd14
* Thu Jan 30 2020 Nick Clifton <nickc@redhat.com> - 9.03-2
7cfd14
- Correct the build requirement for building with debuginfod support.
7cfd14
7cfd14
* Thu Jan 30 2020 Nick Clifton <nickc@redhat.com> - 9.03-1
7cfd14
- Add debuginfod support.
7cfd14
7cfd14
* Tue Jan 28 2020 Fedora Release Engineering <releng@fedoraproject.org> - 9.01-3
7cfd14
- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild
7cfd14
7cfd14
* Mon Jan 20 2020 Nick Clifton <nickc@redhat.com> - 9.01-2
7cfd14
- Rebuild againt latest gcc-10.
7cfd14
7cfd14
* Mon Jan 20 2020 Nick Clifton <nickc@redhat.com> - 9.01-1
7cfd14
- Add clang plugin (experimental).
7cfd14
7cfd14
* Fri Dec 06 2019 Nick Clifton <nickc@redhat.com> - 8.92-1
7cfd14
- Have annocheck ignore notes with an end address of 0.
7cfd14
7cfd14
* Mon Nov 18 2019 Nick Clifton <nickc@redhat.com> - 8.91-1
7cfd14
- Improve checking of gcc versions.
7cfd14
7cfd14
* Fri Nov 15 2019 Nick Clifton <nickc@redhat.com> - 8.90-1
7cfd14
- Do not skip positive results.
7cfd14
7cfd14
* Fri Nov 01 2019 Nick Clifton <nickc@redhat.com> - 8.88-1
7cfd14
- Generate a WARN result for code compiled with instrumentation enabled.  (#1753918)
7cfd14
7cfd14
* Tue Oct 22 2019 Nick Clifton <nickc@redhat.com> - 8.87-1
7cfd14
- Replace address checks with dladdr1.
7cfd14
7cfd14
* Mon Oct 21 2019 Nick Clifton <nickc@redhat.com> - 8.86-1
7cfd14
- Use libabigail like checking to ensure variable address consistency.
7cfd14
7cfd14
* Wed Oct 16 2019 Nick Clifton <nickc@redhat.com> - 8.85-1
7cfd14
- Skip generation of global notes for hot/cold sections.
7cfd14
7cfd14
* Thu Oct 10 2019 Nick Clifton <nickc@redhat.com> - 8.84-1
7cfd14
- Generate FAIL results if -Wall or -Wformat-security are missing.
7cfd14
7cfd14
* Thu Oct 03 2019 Nick Clifton <nickc@redhat.com> - 8.83-1
7cfd14
- If notes cannot be found in the executable look for them in the debuginfo file, if available.
7cfd14
- Generate a FAIL if notes are missing from the executable/debuginfo file.
7cfd14
- Record and report the setting of the AArcht64 specific -mbranch-protection option.
7cfd14
7cfd14
* Mon Sep 23 2019 Nick Clifton <nickc@redhat.com> - 8.81-1
7cfd14
- Improve detection of GO binaries.
7cfd14
- Add gcc version information to annobin notes.
7cfd14
- Do not complain about missing FORTIFY_SOURCE and GLIBCXX_ASSERTIONS in LTO compilations.
7cfd14
7cfd14
* Wed Sep 04 2019 Nick Clifton <nickc@redhat.com> - 8.79-2
7cfd14
- NVR bump to allow rebuild against latest gcc.  (#1748529)
7cfd14
7cfd14
* Tue Aug 06 2019 Nick Clifton <nickc@redhat.com> - 8.79-1
7cfd14
- Allow compiler used to run tests to be specified on the command line.  (#1723401)
7cfd14
7cfd14
* Tue Aug 06 2019 Nick Clifton <nickc@redhat.com> - 8.78-1
7cfd14
- Fix a memory allocation error in the annobin plugin.  (#1737306)
7cfd14
7cfd14
* Wed Jul 24 2019 Fedora Release Engineering <releng@fedoraproject.org> - 8.77-2
7cfd14
- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild
7cfd14
7cfd14
* Mon Jun 24 2019 Nick Clifton <nickc@redhat.com> - 8.77-1
7cfd14
- Another attempt at fixing the detection and reporting of missing -D_FORTIFY_SOURCE options.  (#1703500)
7cfd14
7cfd14
* Mon Jun 10 22:13:17 CET 2019 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 8.76-4
7cfd14
- Rebuild for RPM 4.15
7cfd14
7cfd14
* Mon Jun 10 15:42:00 CET 2019 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 8.76-3
7cfd14
- Rebuild for RPM 4.15
7cfd14
7cfd14
* Thu Jun 06 2019 Panu Matilainen <pmatilai@redhat.com> - 8.76-2
7cfd14
- Really enable annocheck sub-package
7cfd14
7cfd14
* Tue Apr 30 2019 Nick Clifton <nickc@redhat.com> - 8.76-1
7cfd14
- Report a missing -D_FORTIFY_SOUCRE option if -D_GLIBCXX_ASSERTIONS was detected.  (#1703499)
7cfd14
- Do not report problems with -fstack-protection if the binary was not built by gcc or clang.  (#1703788)    
7cfd14
7cfd14
* Fri Apr 26 2019 Nick Clifton <nickc@redhat.com> - 8.74-1
7cfd14
- Add tests of clang command line options recorded in the DW_AT_producer attribute.
7cfd14
7cfd14
* Wed Apr 24 2019 Nick Clifton <nickc@redhat.com> - 8.73-1
7cfd14
- Fix test for an executable stack segment.  (#1700924)
7cfd14
7cfd14
* Thu Apr 18 2019 Nick Clifton <nickc@redhat.com> - 8.72-1
7cfd14
- Rebuild annobin with the latest rawhide gcc sources.  (#1700923)
7cfd14
7cfd14
* Thu Feb 28 2019 Nick Clifton <nickc@redhat.com> - 8.71-1
7cfd14
- Annobin: Suppress more calls to free() which are triggering memory checker errors.  (#1684148)
7cfd14
7cfd14
* Fri Feb 01 2019 Nick Clifton <nickc@redhat.com> - 8.70-1
7cfd14
- Add section flag matching ability to section size tool.
7cfd14
7cfd14
* Thu Jan 31 2019 Fedora Release Engineering <releng@fedoraproject.org> - 8.69-7
7cfd14
- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild
7cfd14
7cfd14
* Tue Jan 29 2019 Björn Esser <besser82@fedoraproject.org> - 8.69-6
7cfd14
- Use 'with' for rich dependency on gcc
7cfd14
7cfd14
* Tue Jan 29 2019 Björn Esser <besser82@fedoraproject.org> - 8.69-5
7cfd14
- Really fix rhbz#1607430.
7cfd14
7cfd14
* Mon Jan 28 2019 Björn Esser <besser82@fedoraproject.org> - 8.69-4
7cfd14
- Rebuilt with annotations enabled
7cfd14
7cfd14
* Mon Jan 28 2019 Björn Esser <besser82@fedoraproject.org> - 8.69-3
7cfd14
- Fix rpm query for gcc version.
7cfd14
7cfd14
* Mon Jan 28 2019 Nick Clifton <nickc@redhat.com> - 8.69-2
7cfd14
- Add an exact requirement on the major version of gcc. (#1607430)
7cfd14
7cfd14
* Thu Jan 24 2019 Nick Clifton <nickc@redhat.com> - 8.69-1
7cfd14
- Annobin: Add support for .text.startup and .text.exit sections generated by gcc 9.
7cfd14
- Annocheck: Add a note displaying tool.
7cfd14
7cfd14
* Wed Jan 23 2019 Nick Clifton <nickc@redhat.com> - 8.68-1
7cfd14
- Annocheck: Skip checks for -D_FORTIFY_SOURCE and -D_GLIBCXX_ASSERTIONS if there is no compiler generated code in the binary.
7cfd14
7cfd14
* Mon Jan 21 2019 Björn Esser <besser82@fedoraproject.org> - 8.67-3
7cfd14
- Rebuilt with annotations enabled
7cfd14
7cfd14
* Mon Jan 21 2019 Björn Esser <besser82@fedoraproject.org> - 8.67-2
7cfd14
- Rebuilt for GCC 9
7cfd14
7cfd14
* Thu Jan 17 2019 Nick Clifton <nickc@redhat.com> - 8.67-1
7cfd14
- Annocheck: Only skip specific checks for specific symbols.  (#1666823)
7cfd14
- Annobin: Record the setting of the -fomit-frame-pointer option.
7cfd14
7cfd14
* Wed Jan 02 2019 Nick Clifton <nickc@redhat.com> - 8.66-1
7cfd14
- Annocheck: Do not ignore -Og when checking to see if an optimization level has been set.  (#1624162)
7cfd14
7cfd14
* Tue Dec 11 2018 Nick Clifton <nickc@redhat.com> - 8.65-1
7cfd14
- Annobin: Fix handling of multiple .text.unlikely sections.
7cfd14
7cfd14
* Fri Nov 30 2018 Nick Clifton <nickc@redhat.com> - 8.64-1
7cfd14
- Annocheck: Skip gaps in PPC64 executables covered by start_bcax_ symbols.  (#1630564)
7cfd14
7cfd14
* Mon Nov 26 2018 Nick Clifton <nickc@redhat.com> - 8.63-1
7cfd14
- Annocheck: Disable ENDBR test for shared libraries.  (#1652925)
7cfd14
7cfd14
* Mon Nov 26 2018 Nick Clifton <nickc@redhat.com> - 8.62-1
7cfd14
- Annocheck: Add test for ENDBR instruction at entry address of x86/x86_64 executables.  (#1652925)
7cfd14
7cfd14
* Tue Nov 20 2018 David Cantrell <dcantrell@redhat.com> - 8.61-2
7cfd14
- Adjust how the gcc_vr macro is set.
7cfd14
7cfd14
* Mon Nov 19 2018 Nick Clifton <nickc@redhat.com> - 8.61-1
7cfd14
- Fix building with gcc version 4.
7cfd14
7cfd14
* Tue Nov 13 2018 Nick Clifton <nickc@redhat.com> - 8.60-1
7cfd14
- Skip -Wl,-z,now and -Wl,-z,relro checks for non-gcc produced binaries.  (#1624421)
7cfd14
7cfd14
* Mon Nov 05 2018 Nick Clifton <nickc@redhat.com> - 8.59-1
7cfd14
- Ensure GNU Property notes are 8-byte aligned in x86_64 binaries.  (#1645817)
7cfd14
7cfd14
* Thu Oct 18 2018 Nick Clifton <nickc@redhat.com> - 8.58-1
7cfd14
- Skip PPC64 linker stubs created in the middle of text sections (again). (#1630640)
7cfd14
7cfd14
* Thu Oct 18 2018 Nick Clifton <nickc@redhat.com> - 8.57-1
7cfd14
- Suppress free of invalid pointer. (#1638371)
7cfd14
7cfd14
* Thu Oct 18 2018 Nick Clifton <nickc@redhat.com> - 8.56-1
7cfd14
- Skip PPC64 linker stubs created in the middle of text sections. (#1630640)
7cfd14
7cfd14
* Tue Oct 16 2018 Nick Clifton <nickc@redhat.com> - 8.55-1
7cfd14
- Reset the (PPC64) section start symbol to 0 if its section is empty.  (#1638251)
7cfd14
7cfd14
* Thu Oct 11 2018 Nick Clifton <nickc@redhat.com> - 8.53-1
7cfd14
- Also skip virtual thinks created by G++.  (#1630619)
7cfd14
7cfd14
* Wed Oct 10 2018 Nick Clifton <nickc@redhat.com> - 8.52-1
7cfd14
- Use uppercase for all fail/mayb/pass results.  (#1637706)
7cfd14
7cfd14
* Wed Oct 10 2018 Nick Clifton <nickc@redhat.com> - 8.51-1
7cfd14
- Generate notes for unlikely sections.  (#1630620)
7cfd14
7cfd14
* Mon Oct 08 2018 Nick Clifton <nickc@redhat.com> - 8.50-1
7cfd14
- Fix edge case computing section names for end symbols.  (#1637039)
7cfd14
7cfd14
* Mon Oct 08 2018 Nick Clifton <nickc@redhat.com> - 8.49-1
7cfd14
- Skip dynamic checks for binaries without a dynamic segment.  (#1636606)
7cfd14
7cfd14
* Fri Oct 05 2018 Nick Clifton <nickc@redhat.com> - 8.48-1
7cfd14
- Delay generating attach_to_group directives until the end of the compilation.  (#1636265)
7cfd14
7cfd14
* Mon Oct 01 2018 Nick Clifton <nickc@redhat.com> - 8.47-1
7cfd14
- Fix bug introduced in previous delta which would trigger a seg-fault when scanning for gaps.
7cfd14
7cfd14
* Mon Oct 01 2018 Nick Clifton <nickc@redhat.com> - 8.46-1
7cfd14
- Annobin:   Fix section name selection for startup sections.
7cfd14
- Annocheck: Improve gap skipping heuristics.   (#1630574)
7cfd14
7cfd14
* Mon Oct 01 2018 Nick Clifton <nickc@redhat.com> - 8.45-1
7cfd14
- Fix function section support (again).   (#1630574)
7cfd14
7cfd14
* Fri Sep 28 2018 Nick Clifton <nickc@redhat.com> - 8.44-1
7cfd14
- Skip compiler option checks for non-GNU producers.  (#1633749)
7cfd14
7cfd14
* Wed Sep 26 2018 Nick Clifton <nickc@redhat.com> - 8.43-1
7cfd14
- Fix function section support (again).   (#1630574)
7cfd14
7cfd14
* Tue Sep 25 2018 Nick Clifton <nickc@redhat.com> - 8.42-1
7cfd14
- Ignore ppc64le notes where start = end + 2.  (#1632259)
7cfd14
7cfd14
* Tue Sep 25 2018 Nick Clifton <nickc@redhat.com> - 8.41-1
7cfd14
- Make annocheck ignore symbols suffixed with ".end".  (#1639618)
7cfd14
7cfd14
* Mon Sep 24 2018 Nick Clifton <nickc@redhat.com> - 8.40-1
7cfd14
- Reinstate building annobin with annobin enabled.  (#1630550)
7cfd14
7cfd14
* Fri Sep 21 2018 Nick Clifton <nickc@redhat.com> - 8.39-1
7cfd14
- Tweak tests.
7cfd14
7cfd14
* Fri Sep 21 2018 Nick Clifton <nickc@redhat.com> - 8.38-1
7cfd14
- Generate notes and groups for .text.hot and .text.unlikely sections.
7cfd14
- When -ffunction-sections is active, put notes for startup sections into .text.startup.foo rather than .text.foo.
7cfd14
- Similarly put exit section notes into .text.exit.foo.  (#1630574)
7cfd14
- Change annocheck's maybe result for GNU Property note being missing into a PASS if it is not needed and a FAIL if it is needed.
7cfd14
7cfd14
* Wed Sep 19 2018 Nick Clifton <nickc@redhat.com> - 8.37-1
7cfd14
- Make the --skip-* options skip all messages about the specified test.
7cfd14
7cfd14
* Tue Sep 18 2018 Nick Clifton <nickc@redhat.com> - 8.36-1
7cfd14
- Improve error message when an ET_EXEC binary is detected.
7cfd14
7cfd14
* Mon Sep 17 2018 Nick Clifton <nickc@redhat.com> - 8.35-1
7cfd14
- Skip failures for PIC vs PIE.  (#1629698)
7cfd14
7cfd14
* Mon Sep 17 2018 Nick Clifton <nickc@redhat.com> - 8.34-1
7cfd14
- Ensure 4 byte alignment of note sub-sections.  (#1629671)
7cfd14
7cfd14
* Wed Sep 12 2018 Nick Clifton <nickc@redhat.com> - 8.33-1
7cfd14
- Add timing tool to report on speed of the checks.
7cfd14
- Add check for conflicting use of the -fshort-enum option.
7cfd14
- Add check of the GNU Property notes.
7cfd14
- Skip check for -O2 if compiled with -Og.  (#1624162)
7cfd14
7cfd14
* Mon Sep 03 2018 Nick Clifton <nickc@redhat.com> - 8.32-1
7cfd14
- Add test for ET_EXEC binaries.  (#1625627)
7cfd14
- Document --report-unknown option.
7cfd14
7cfd14
* Thu Aug 30 2018 Nick Clifton <nickc@redhat.com> - 8.31-1
7cfd14
- Fix bug in hardened tool which would skip gcc compiled files if the notes were too small.
7cfd14
- Fix bugs in section-size tool.
7cfd14
- Fix bug in built-by tool.
7cfd14
7cfd14
* Wed Aug 29 2018 Nick Clifton <nickc@redhat.com> - 8.30-1
7cfd14
- Generate notes for comdat sections. (#1619267)
7cfd14
7cfd14
* Thu Aug 23 2018 Nick Clifton <nickc@redhat.com> - 8.29-1
7cfd14
- Add more names to the gap skip list. (#1619267)
7cfd14
7cfd14
* Thu Aug 23 2018 Nick Clifton <nickc@redhat.com> - 8.28-1
7cfd14
- Skip gaps covered by _x86.get_pc_thunk and _savegpr symbols. (#1619267)
7cfd14
- Merge ranges where one is wholly covered by another.
7cfd14
7cfd14
* Wed Aug 22 2018 Nick Clifton <nickc@redhat.com> - 8.27-1
7cfd14
- Skip gaps at the end of functions. (#1619267)
7cfd14
7cfd14
* Tue Aug 21 2018 Nick Clifton <nickc@redhat.com> - 8.26-1
7cfd14
- Fix thinko in ppc64 gap detection code. (#1619267)
7cfd14
7cfd14
* Mon Aug 20 2018 Nick Clifton <nickc@redhat.com> - 8.25-1
7cfd14
- Skip gaps at the end of the .text section in ppc64 binaries. (#1619267)
7cfd14
7cfd14
* Wed Aug 15 2018 Nick Clifton <nickc@redhat.com> - 8.24-1
7cfd14
- Skip checks in stack_chk_local_fail.c
7cfd14
- Treat gaps as FAIL results rather than MAYBE.
7cfd14
7cfd14
* Wed Aug 08 2018 Nick Clifton <nickc@redhat.com> - 8.23-1
7cfd14
- Skip checks in __stack_chk_local_fail.
7cfd14
7cfd14
* Wed Aug 08 2018 Nick Clifton <nickc@redhat.com> - 8.22-1
7cfd14
- Reduce version check to gcc major version number only.  Skip compiler option checks if binary not built with gcc.  (#1603089)
7cfd14
7cfd14
* Tue Aug 07 2018 Nick Clifton <nickc@redhat.com> - 8.21-1
7cfd14
- Fix bug in annobin plugin.  Add --section-size=NAME option to annocheck.
7cfd14
7cfd14
* Thu Aug  2 2018 Peter Robinson <pbrobinson@fedoraproject.org> 8.20-2
7cfd14
- rebuild for new gcc
7cfd14
7cfd14
* Thu Aug 02 2018 Nick Clifton <nickc@redhat.com> - 8.20-1
7cfd14
- Correct name of man page for run-on-binaries-in script.  (#1611155)
7cfd14
7cfd14
* Wed Jul 25 2018 Nick Clifton <nickc@redhat.com> - 8.19-1
7cfd14
- Allow $ORIGIN to be at the start of entries in DT_RPATH and DT_RUNPATH.
7cfd14
7cfd14
* Mon Jul 23 2018 Nick Clifton <nickc@redhat.com> - 8.18-1
7cfd14
- Add support for big endian targets.
7cfd14
7cfd14
* Mon Jul 23 2018 Nick Clifton <nickc@redhat.com> - 8.17-1
7cfd14
- Count passes and failures on a per-component basis and report gaps.
7cfd14
7cfd14
* Fri Jul 20 2018 Nick Clifton <nickc@redhat.com> - 8.16-1
7cfd14
- Use our own copy of the targetm.asm_out.function_section() function.  (#159861 comment#17)
7cfd14
7cfd14
* Fri Jul 20 2018 Nick Clifton <nickc@redhat.com> - 8.15-1
7cfd14
- Generate grouped note section name all the time.  (#159861 comment#16)
7cfd14
7cfd14
* Thu Jul 19 2018 Nick Clifton <nickc@redhat.com> - 8.14-1
7cfd14
- Fix section conflict problem.  (#1603071)
7cfd14
7cfd14
* Wed Jul 18 2018 Nick Clifton <nickc@redhat.com> - 8.13-1
7cfd14
- Fix for building with gcc version 4.
7cfd14
- Fix symbol placement in functions with local assembler.
7cfd14
7cfd14
* Tue Jul 17 2018 Nick Clifton <nickc@redhat.com> - 8.12-1
7cfd14
- Fix assertions in range checking code.  Add detection of -U options.
7cfd14
7cfd14
* Tue Jul 17 2018 Nick Clifton <nickc@redhat.com> - 8.11-1
7cfd14
- Handle function sections properly.  Handle .text.startup and .text.unlikely sections.  Improve gap detection and reporting.  (#1601055)
7cfd14
7cfd14
* Thu Jul 12 2018 Fedora Release Engineering <releng@fedoraproject.org> - 8.10-2
7cfd14
- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild
7cfd14
7cfd14
* Thu Jul 12 2018 Nick Clifton <nickc@redhat.com> - 8.10-1
7cfd14
- Fix construction of absolute versions of --dwarf-dir and --debug-rpm options.
7cfd14
7cfd14
* Tue Jul 10 2018 Nick Clifton <nickc@redhat.com> - 8.9-1
7cfd14
- Fix buffer overrun when very long symbol names are encountered.
7cfd14
7cfd14
* Tue Jul 10 2018 Nick Clifton <nickc@redhat.com> - 8.8-1
7cfd14
- Do not force the generation of function notes when -ffunction-sections is active.  (#1598961)
7cfd14
7cfd14
* Mon Jul 09 2018 Nick Clifton <nickc@redhat.com> - 8.7-1
7cfd14
- Skip the .annobin_ prfix when reporting symbols.  (#1599315)
7cfd14
7cfd14
* Mon Jul 09 2018 Nick Clifton <nickc@redhat.com> - 8.6-1
7cfd14
- Use the assembler (c++ mangled) version of function names when switching sections.  (#1598579)
7cfd14
7cfd14
* Mon Jul 09 2018 Nick Clifton <nickc@redhat.com> - 8.5-1
7cfd14
- Do not call function_section.  (#1598961)
7cfd14
7cfd14
* Fri Jul 06 2018 Nick Clifton <nickc@redhat.com> - 8.4-1
7cfd14
- Ignore cross-section gaps.  (#1598551)
7cfd14
7cfd14
* Thu Jul 05 2018 Nick Clifton <nickc@redhat.com> - 8.3-1
7cfd14
- Do not skip empty range notes in object files.  (#1598361)
7cfd14
7cfd14
* Mon Jul 02 2018 Nick Clifton <nickc@redhat.com> - 8.2-1
7cfd14
- Create the start symbol at the start of the function and the end symbol at the end.  (#1596823)
7cfd14
7cfd14
* Mon Jul 02 2018 Nick Clifton <nickc@redhat.com> - 8.1-1
7cfd14
- Fix --debug-rpm when used inside a directory.
7cfd14
7cfd14
* Thu Jun 28 2018 Nick Clifton <nickc@redhat.com> - 8.0-1
7cfd14
- Use a prefix for all annobin generated symbols, and make them hidden.
7cfd14
- Only generate weak symbol definitions for linkonce sections.
7cfd14
7cfd14
* Wed Jun 27 2018 Nick Clifton <nickc@redhat.com> - 7.1-1
7cfd14
- Skip some checks for relocatable object files, and dynamic objects.
7cfd14
- Stop bogus complaints about stackrealignment not being enabled.
7cfd14
7cfd14
* Mon Jun 25 2018 Nick Clifton <nickc@redhat.com> - 7.0-1
7cfd14
- Add -debug-rpm= option to annocheck.
7cfd14
- Only use a 2 byte offset for the initial symbol on PowerPC.
7cfd14
7cfd14
* Fri Jun 22 2018 Nick Clifton <nickc@redhat.com> - 6.6-1
7cfd14
- Use --dwarf-path when looking for build-id based debuginfo files.
7cfd14
7cfd14
* Fri Jun 22 2018 Nick Clifton <nickc@redhat.com> - 6.5-1
7cfd14
- Fix premature closing of dwarf handle.
7cfd14
7cfd14
* Fri Jun 22 2018 Nick Clifton <nickc@redhat.com> - 6.4-1
7cfd14
- Fix scoping bug computing the name of a separate debuginfo file.
7cfd14
7cfd14
* Tue Jun 19 2018 Nick Clifton <nickc@redhat.com> - 6.3-1
7cfd14
- Fix file descriptor leak.
7cfd14
7cfd14
* Tue Jun 19 2018 Nick Clifton <nickc@redhat.com> - 6.2-1
7cfd14
- Add command line options to annocheck to disable individual tests.
7cfd14
7cfd14
* Fri Jun 08 2018 Nick Clifton <nickc@redhat.com> - 6.1-1
7cfd14
- Remove C99-ism from annocheck sources.
7cfd14
7cfd14
* Wed Jun 06 2018 Nick Clifton <nickc@redhat.com> - 6.0-1
7cfd14
- Add the annocheck program.
7cfd14
7cfd14
* Fri Jun 01 2018 Nick Clifton <nickc@redhat.com> - 5.11-1
7cfd14
- Do not use the SHF_GNU_BUILD_NOTE section flag.
7cfd14
7cfd14
* Thu May 31 2018 Nick Clifton <nickc@redhat.com> - 5.10-1
7cfd14
- Remove .sh extension from shell scripts.
7cfd14
7cfd14
* Wed May 30 2018 Nick Clifton <nickc@redhat.com> - 5.9-1
7cfd14
- Record the setting of the -mstackrealign option for i686 binaries.
7cfd14
7cfd14
* Mon May 14 2018 Nick Clifton <nickc@redhat.com> - 5.8-1
7cfd14
- Hide the annobin start of file symbol.
7cfd14
7cfd14
* Tue May 08 2018 Nick Clifton <nickc@redhat.com> - 5.7-1
7cfd14
- Fix script bug in hardended.sh.  (Thanks to: Stefan Sørensen <stefan.sorensen@spectralink.com>)
7cfd14
7cfd14
* Thu May 03 2018 Nick Clifton <nickc@redhat.com> - 5.6-3
7cfd14
- Version number bump so that the plugin can be rebuilt with the latest version of GCC.
7cfd14
7cfd14
* Mon Apr 30 2018 Nick Clifton <nickc@redhat.com> - 5.6-2
7cfd14
- Rebuild the plugin with the newly created plugin enabled.  (#1573082)
7cfd14
7cfd14
* Mon Apr 30 2018 Nick Clifton <nickc@redhat.com> - 5.6-1
7cfd14
- Skip the isa_flags check in the ABI test because the crt[in].o files are compiled with different flags from the test files.
7cfd14
7cfd14
* Fri Apr 20 2018 Nick Clifton <nickc@redhat.com> - 5.3-1
7cfd14
- Add manual pages for annobin and the scripts.
7cfd14
7cfd14
* Tue Apr 03 2018 Nick Clifton <nickc@redhat.com> - 5.2-1
7cfd14
- Do not record a stack protection setting of -1.  (#1563141)
7cfd14
7cfd14
* Tue Mar 20 2018 Nick Clifton <nickc@redhat.com> - 5.1-1
7cfd14
- Do not complain about a dwarf_version value of -1.  (#1557511)
7cfd14
7cfd14
* Thu Mar 15 2018 Nick Clifton <nickc@redhat.com> - 5.0-1
7cfd14
- Bias file start symbols by 2 in order to avoid them confused with function symbols.  (#1554332)
7cfd14
- Version jump is to sync the version number with the annobin plugins internal version number.
7cfd14
7cfd14
* Mon Mar 12 2018 Nick Clifton <nickc@redhat.com> - 3.6-1
7cfd14
- Add --ignore-gaps option to check-abi.sh script.
7cfd14
- Use this option in the abi-test check.
7cfd14
- Tweak hardening test to skip pic and stack protection checks.
7cfd14
7cfd14
* Tue Mar 06 2018 Nick Clifton <nickc@redhat.com> - 3.5-1
7cfd14
- Handle functions with specific assembler names.  (#1552018)
7cfd14
7cfd14
* Fri Feb 23 2018 Nick Clifton <nickc@redhat.com> - 3.4-2
7cfd14
- Add an explicit requirement on the version of gcc used to built the plugin.  (#1547260)
7cfd14
7cfd14
* Fri Feb 09 2018 Nick Clifton <nickc@redhat.com> - 3.4-1
7cfd14
- Change type and size of symbols to STT_NOTYPE/0 so that they do not confuse GDB.  (#1539664)
7cfd14
- Add run-on-binaries-in.sh script to allow the other scripts to be run over a repository.
7cfd14
7cfd14
* Wed Feb 07 2018 Fedora Release Engineering <releng@fedoraproject.org> - 3.3-2
7cfd14
- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild
7cfd14
7cfd14
* Tue Jan 30 2018 Nick Clifton <nickc@redhat.com> - 3.3-1
7cfd14
- Rebase on 3.3 release, which adds support for recording -mcet and -fcf-protection.
7cfd14
7cfd14
* Mon Jan 29 2018 Florian Weimer <fweimer@redhat.com> - 3.2-3
7cfd14
- Rebuild for GCC 8
7cfd14
7cfd14
* Fri Jan 26 2018 Nick Clifton <nickc@redhat.com> - 3.2-2
7cfd14
- Fix the installation of the annobin.info file.
7cfd14
7cfd14
* Fri Jan 26 2018 Nick Clifton <nickc@redhat.com> - 3.2-1
7cfd14
- Rebase on 3.2 release, which now contains documentation!
7cfd14
7cfd14
* Fri Jan 26 2018 Richard W.M. Jones <rjones@redhat.com> - 3.1-3
7cfd14
- Rebuild against GCC 7.3.1.
7cfd14
7cfd14
* Tue Jan 16 2018 Nick Clifton <nickc@redhat.com> - 3.1-2
7cfd14
- Add --with-gcc-plugin-dir option to the configure command line.
7cfd14
7cfd14
* Thu Jan 04 2018 Nick Clifton <nickc@redhat.com> - 3.1-1
7cfd14
- Rebase on version 3.1 sources.
7cfd14
7cfd14
* Mon Dec 11 2017 Nick Clifton <nickc@redhat.com> - 2.5.1-5
7cfd14
- Do not generate notes when there is no output file.  (#1523875)
7cfd14
7cfd14
* Fri Dec 08 2017 Nick Clifton <nickc@redhat.com> - 2.5.1-4
7cfd14
- Invent an input filename when reading from a pipe.  (#1523401)
7cfd14
7cfd14
* Thu Nov 30 2017 Florian Weimer <fweimer@redhat.com> - 2.5.1-3
7cfd14
- Use DECL_ASSEMBLER_NAME for symbol references (#1519165)
7cfd14
7cfd14
* Tue Oct 03 2017 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 2.5.1-2
7cfd14
- Cleanups in spec
7cfd14
7cfd14
* Tue Sep 26 2017 Nick Clifton <nickc@redhat.com> - 2.5.1-1
7cfd14
- Touch the auto-generated files in order to stop them from being regenerated.
7cfd14
7cfd14
* Tue Sep 26 2017 Nick Clifton <nickc@redhat.com> - 2.5-2
7cfd14
- Stop the plugin complaining about compiler datestamp mismatches.
7cfd14
7cfd14
* Thu Sep 21 2017 Nick Clifton <nickc@redhat.com> - 2.4-1
7cfd14
- Tweak tests so that they will run on older machines.
7cfd14
7cfd14
* Thu Sep 21 2017 Nick Clifton <nickc@redhat.com> - 2.3-1
7cfd14
- Add annobin-tests subpackage containing some preliminary tests.
7cfd14
- Remove link-time test for unsupported targets.
7cfd14
7cfd14
* Wed Aug 02 2017 Fedora Release Engineering <releng@fedoraproject.org> - 2.0-3
7cfd14
- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Binutils_Mass_Rebuild
7cfd14
7cfd14
* Mon Jul 31 2017 Florian Weimer <fweimer@redhat.com> - 2.0-2
7cfd14
- Rebuild with binutils fix for ppc64le (#1475636)
7cfd14
7cfd14
* Wed Jun 28 2017 Nick Clifton <nickc@redhat.com> - 2.0-1
7cfd14
- Fixes for problems reported by the package submission review:
7cfd14
   * Add %%license entry to %%file section.
7cfd14
   * Update License and BuildRequires tags.
7cfd14
   * Add Requires tag.
7cfd14
   * Remove %%clean.
7cfd14
   * Add %%check.
7cfd14
   * Clean up the %%changelog.
7cfd14
- Update to use version 2 of the specification and sources.
7cfd14
7cfd14
* Thu May 11 2017 Nick Clifton <nickc@redhat.com> - 1.0-1
7cfd14
- Initial submission.