Compare commits
No commits in common. "imports/c9-beta/redhat-rpm-config-194-1.el9" and "c8" have entirely different histories.
imports/c9
...
c8
@ -1,18 +0,0 @@
|
|||||||
#!/bin/bash -e
|
|
||||||
|
|
||||||
# If using normal root, avoid changing anything.
|
|
||||||
if [ -z "$RPM_BUILD_ROOT" -o "$RPM_BUILD_ROOT" = "/" ]; then
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Defined as %py_reproducible_pyc_path macro and passed here as
|
|
||||||
# the first command-line argument
|
|
||||||
path_to_fix=$1
|
|
||||||
|
|
||||||
# First, check that the parser is available:
|
|
||||||
if [ ! -x /usr/bin/marshalparser ]; then
|
|
||||||
echo "ERROR: If %py_reproducible_pyc_path is defined, you have to also BuildRequire: /usr/bin/marshalparser !"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
find "$path_to_fix" -type f -name "*.pyc" | xargs /usr/bin/marshalparser --fix --overwrite
|
|
20
SOURCES/brp-kmod-restore-perms
Executable file
20
SOURCES/brp-kmod-restore-perms
Executable file
@ -0,0 +1,20 @@
|
|||||||
|
#! /bin/bash -f
|
||||||
|
|
||||||
|
## A counterpart of brp-kmod-set-exec-bits that restores original kmod
|
||||||
|
## file permissions
|
||||||
|
|
||||||
|
# If using normal root, avoid changing anything.
|
||||||
|
[ -n "$RPM_BUILD_ROOT" -a "$RPM_BUILD_ROOT" != "/" ] || exit 0
|
||||||
|
|
||||||
|
# Checking for required programs
|
||||||
|
which chmod >/dev/null || exit 0
|
||||||
|
|
||||||
|
[ -r "$RPM_BUILD_ROOT/kmod-permissions.list" ] || exit 0
|
||||||
|
|
||||||
|
while read perm path; do
|
||||||
|
[ -n "$perm" ] || continue
|
||||||
|
|
||||||
|
chmod "$perm" "$RPM_BUILD_ROOT/$path"
|
||||||
|
done < "$RPM_BUILD_ROOT/kmod-permissions.list"
|
||||||
|
|
||||||
|
rm -f "$RPM_BUILD_ROOT/kmod-permissions.list"
|
14
SOURCES/brp-kmod-set-exec-bit
Executable file
14
SOURCES/brp-kmod-set-exec-bit
Executable file
@ -0,0 +1,14 @@
|
|||||||
|
#! /bin/bash -fx
|
||||||
|
|
||||||
|
## A hack for making brp-strip taking into account kmod files
|
||||||
|
|
||||||
|
# If using normal root, avoid changing anything.
|
||||||
|
[ -n "$RPM_BUILD_ROOT" -a "$RPM_BUILD_ROOT" != "/" ] || exit 0
|
||||||
|
|
||||||
|
# Checking for required programs
|
||||||
|
which find chmod >/dev/null || exit 0
|
||||||
|
|
||||||
|
find "$RPM_BUILD_ROOT" \
|
||||||
|
-name '*.ko' \
|
||||||
|
-printf '%#m %P\n' \
|
||||||
|
-exec chmod u+x '{}' \; > "$RPM_BUILD_ROOT/kmod-permissions.list"
|
@ -1,4 +1,4 @@
|
|||||||
#!/bin/sh -efu
|
#!/bin/sh -f
|
||||||
# Force creating of DSO symlinks.
|
# Force creating of DSO symlinks.
|
||||||
|
|
||||||
# If using normal root, avoid changing anything.
|
# If using normal root, avoid changing anything.
|
||||||
@ -6,8 +6,5 @@ if [ -z "$RPM_BUILD_ROOT" -o "$RPM_BUILD_ROOT" = "/" ]; then
|
|||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Create an empty config file for ldconfig to shut up a warning
|
/sbin/ldconfig -N -r "$RPM_BUILD_ROOT"
|
||||||
config=$(mktemp -p "$RPM_BUILD_ROOT")
|
|
||||||
/sbin/ldconfig -f $(basename "$config") -N -r "$RPM_BUILD_ROOT"
|
|
||||||
rm -f "$config"
|
|
||||||
# TODO: warn if it created new symlinks and guide people.
|
# TODO: warn if it created new symlinks and guide people.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash -eu
|
#!/bin/bash
|
||||||
|
|
||||||
# If using normal root, avoid changing anything.
|
# If using normal root, avoid changing anything.
|
||||||
if [ -z "$RPM_BUILD_ROOT" -o "$RPM_BUILD_ROOT" = "/" ]; then
|
if [ -z "$RPM_BUILD_ROOT" -o "$RPM_BUILD_ROOT" = "/" ]; then
|
||||||
@ -76,7 +76,7 @@ cd "$RPM_BUILD_ROOT"
|
|||||||
# (Take care to exclude filenames which would mangle "file" output).
|
# (Take care to exclude filenames which would mangle "file" output).
|
||||||
find -executable -type f ! -path '*:*' ! -path $'*\n*' \
|
find -executable -type f ! -path '*:*' ! -path $'*\n*' \
|
||||||
| file -N --mime-type -f - \
|
| file -N --mime-type -f - \
|
||||||
| grep -P ".+(?=: (text/|application/javascript))" \
|
| grep -P ".+(?=: text/)" \
|
||||||
| {
|
| {
|
||||||
fail=0
|
fail=0
|
||||||
while IFS= read -r line; do
|
while IFS= read -r line; do
|
||||||
@ -142,9 +142,11 @@ while IFS= read -r line; do
|
|||||||
# /whatsoever/env foo → /whatsoever/foo
|
# /whatsoever/env foo → /whatsoever/foo
|
||||||
shebang=$(echo "$shebang" | sed -r -e 's@^(.+/)env (.+)$@\1\2@')
|
shebang=$(echo "$shebang" | sed -r -e 's@^(.+/)env (.+)$@\1\2@')
|
||||||
|
|
||||||
# If the shebang now starts with /bin, change it to /usr/bin
|
# Replace python3 with the desired Python 3 shebang,
|
||||||
# https://bugzilla.redhat.com/show_bug.cgi?id=1581757
|
# if passed as an non-empty environment variable PYTHON3
|
||||||
shebang=$(echo "$shebang" | sed -r -e 's@^/bin/@/usr/bin/@')
|
if [ -n "${PYTHON3:+x}" ]; then
|
||||||
|
shebang=$(echo "$shebang" | sed -r -e "s@/usr/bin/python3(\s|$)@${PYTHON3}\1@")
|
||||||
|
fi
|
||||||
|
|
||||||
# Replace ambiguous python with python2
|
# Replace ambiguous python with python2
|
||||||
py_shebang=$(echo "$shebang" | sed -r -e 's@/usr/bin/python(\s|$)@/usr/bin/python2\1@')
|
py_shebang=$(echo "$shebang" | sed -r -e 's@/usr/bin/python(\s|$)@/usr/bin/python2\1@')
|
||||||
|
@ -1,141 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
errors_terminate=$2
|
|
||||||
|
|
||||||
# Usage of %_python_bytecompile_extra is not allowed anymore
|
|
||||||
# See: https://fedoraproject.org/wiki/Changes/No_more_automagic_Python_bytecompilation_phase_3
|
|
||||||
# Therefore $1 ($default_python) is not needed and is invoked with "" by default.
|
|
||||||
# $default_python stays in the arguments for backward compatibility and $extra for the following check:
|
|
||||||
extra=$3
|
|
||||||
if [ 0$extra -eq 1 ]; then
|
|
||||||
echo -e "%_python_bytecompile_extra is discontinued, use %py_byte_compile instead.\nSee: https://fedoraproject.org/wiki/Changes/No_more_automagic_Python_bytecompilation_phase_3" >/dev/stderr
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# If using normal root, avoid changing anything.
|
|
||||||
if [ -z "$RPM_BUILD_ROOT" -o "$RPM_BUILD_ROOT" = "/" ]; then
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Figure out how deep we need to descend. We could pick an insanely high
|
|
||||||
# number and hope it's enough, but somewhere, somebody's sure to run into it.
|
|
||||||
depth=`(find "$RPM_BUILD_ROOT" -type f -name "*.py" -print0 ; echo /) | \
|
|
||||||
xargs -0 -n 1 dirname | sed 's,[^/],,g' | sort -u | tail -n 1 | wc -c`
|
|
||||||
if [ -z "$depth" -o "$depth" -le "1" ]; then
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
# This function now implements Python byte-compilation in three different ways:
|
|
||||||
# Python >= 3.4 and < 3.9 uses a new module compileall2 - https://github.com/fedora-python/compileall2
|
|
||||||
# Python < 3.4 (inc. Python 2) uses compileall module from stdlib with some hacks
|
|
||||||
# When we drop support for Python 2, we'd be able to use all compileall2 features like:
|
|
||||||
# - -s and -p options to manipulate with a path baked into pyc files instead of $real_libdir
|
|
||||||
# - -o 0 -o 1 to produce multiple files in one run - each with a different optimization level - instead of $options
|
|
||||||
# - removed useless $depth - both compileall and compileall2 are limited by sys.getrecursionlimit()
|
|
||||||
# These changes will make this script much simpler
|
|
||||||
# In Python >= 3.9, compileall2 was merged back to standard library (compileall) so we can use it directly again.
|
|
||||||
function python_bytecompile()
|
|
||||||
{
|
|
||||||
local options=$1
|
|
||||||
local python_binary=$2
|
|
||||||
local exclude=$3
|
|
||||||
local python_libdir=$4
|
|
||||||
local depth=$5 # Not used for Python >= 3.4
|
|
||||||
local real_libdir=$6 # Not used for Python >= 3.4
|
|
||||||
|
|
||||||
python_version=$($python_binary -c "import sys; sys.stdout.write('{0.major}{0.minor}'.format(sys.version_info))")
|
|
||||||
|
|
||||||
#
|
|
||||||
# Python 3.9 and higher
|
|
||||||
#
|
|
||||||
if [ "$python_version" -ge 39 ]; then
|
|
||||||
|
|
||||||
[ ! -z $exclude ] && exclude="-x '$exclude'"
|
|
||||||
# -q disables verbose output
|
|
||||||
# -f forces the process to overwrite existing compiled files
|
|
||||||
# -x excludes paths defined by regex
|
|
||||||
# -e excludes symbolic links pointing outside the build root
|
|
||||||
# -x and -e together implements the same functionality as the Filter class below
|
|
||||||
# -s strips $RPM_BUILD_ROOT from the path
|
|
||||||
# -p prepends the leading slash to the path to make it absolute
|
|
||||||
$python_binary -B $options -m compileall -q -f $exclude -s $RPM_BUILD_ROOT -p / -e $RPM_BUILD_ROOT $python_libdir
|
|
||||||
|
|
||||||
#
|
|
||||||
# Python 3.4 and higher
|
|
||||||
#
|
|
||||||
elif [ "$python_version" -ge 34 ]; then
|
|
||||||
|
|
||||||
[ ! -z $exclude ] && exclude="-x '$exclude'"
|
|
||||||
# /usr/lib/rpm/redhat/ contains compileall2 Python module
|
|
||||||
# -q disables verbose output
|
|
||||||
# -f forces the process to overwrite existing compiled files
|
|
||||||
# -x excludes paths defined by regex
|
|
||||||
# -e excludes symbolic links pointing outside the build root
|
|
||||||
# -x and -e together implements the same functionality as the Filter class below
|
|
||||||
# -s strips $RPM_BUILD_ROOT from the path
|
|
||||||
# -p prepends the leading slash to the path to make it absolute
|
|
||||||
PYTHONPATH=/usr/lib/rpm/redhat/ $python_binary -B $options -m compileall2 -q -f $exclude -s $RPM_BUILD_ROOT -p / -e $RPM_BUILD_ROOT $python_libdir
|
|
||||||
else
|
|
||||||
#
|
|
||||||
# Python 3.3 and lower (incl. Python 2)
|
|
||||||
#
|
|
||||||
|
|
||||||
cat << EOF | $python_binary $options
|
|
||||||
import compileall, sys, os, re
|
|
||||||
|
|
||||||
python_libdir = "$python_libdir"
|
|
||||||
depth = $depth
|
|
||||||
real_libdir = "$real_libdir"
|
|
||||||
build_root = "$RPM_BUILD_ROOT"
|
|
||||||
exclude = r"$exclude"
|
|
||||||
|
|
||||||
class Filter:
|
|
||||||
def search(self, path):
|
|
||||||
ret = not os.path.realpath(path).startswith(build_root)
|
|
||||||
if exclude:
|
|
||||||
ret = ret or re.search(exclude, path)
|
|
||||||
return ret
|
|
||||||
|
|
||||||
sys.exit(not compileall.compile_dir(python_libdir, depth, real_libdir, force=1, rx=Filter(), quiet=1))
|
|
||||||
EOF
|
|
||||||
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# .pyc/.pyo files embed a "magic" value, identifying the ABI version of Python
|
|
||||||
# bytecode that they are for.
|
|
||||||
#
|
|
||||||
# The files below RPM_BUILD_ROOT could be targeting multiple versions of
|
|
||||||
# python (e.g. a single build that emits several subpackages e.g. a
|
|
||||||
# python26-foo subpackage, a python31-foo subpackage etc)
|
|
||||||
#
|
|
||||||
# Support this by assuming that below each /usr/lib/python$VERSION/, all
|
|
||||||
# .pyc/.pyo files are to be compiled for /usr/bin/python$VERSION.
|
|
||||||
#
|
|
||||||
# For example, below /usr/lib/python2.6/, we're targeting /usr/bin/python2.6
|
|
||||||
# and below /usr/lib/python3.1/, we're targeting /usr/bin/python3.1
|
|
||||||
|
|
||||||
# Disable Python hash seed randomization
|
|
||||||
# This should help with byte-compilation reproducibility: https://bugzilla.redhat.com/show_bug.cgi?id=1686078
|
|
||||||
export PYTHONHASHSEED=0
|
|
||||||
|
|
||||||
shopt -s nullglob
|
|
||||||
for python_libdir in `find "$RPM_BUILD_ROOT" -type d|grep -E "/(usr|app)/lib(64)?/python[0-9]\.[0-9]+$"`;
|
|
||||||
do
|
|
||||||
python_binary=$(basename $python_libdir)
|
|
||||||
real_libdir=${python_libdir/$RPM_BUILD_ROOT/}
|
|
||||||
echo "Bytecompiling .py files below $python_libdir using $python_binary"
|
|
||||||
|
|
||||||
# Generate normal (.pyc) byte-compiled files.
|
|
||||||
python_bytecompile "" "$python_binary" "" "$python_libdir" "$depth" "$real_libdir"
|
|
||||||
if [ $? -ne 0 -a 0$errors_terminate -ne 0 ]; then
|
|
||||||
# One or more of the files had a syntax error
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Generate optimized (.pyo) byte-compiled files.
|
|
||||||
python_bytecompile "-O" "$python_binary" "" "$python_libdir" "$depth" "$real_libdir"
|
|
||||||
if [ $? -ne 0 -a 0$errors_terminate -ne 0 ]; then
|
|
||||||
# One or more of the files had a syntax error
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
done
|
|
@ -1,17 +0,0 @@
|
|||||||
#!/usr/bin/sh
|
|
||||||
# If using normal root, avoid changing anything.
|
|
||||||
if [ -z "$RPM_BUILD_ROOT" ] || [ "$RPM_BUILD_ROOT" = "/" ]; then
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
STRIP=${1:-strip}
|
|
||||||
NCPUS=${RPM_BUILD_NCPUS:-1}
|
|
||||||
|
|
||||||
case `uname -a` in
|
|
||||||
Darwin*) exit 0 ;;
|
|
||||||
*) ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Strip ELF binaries
|
|
||||||
find "$RPM_BUILD_ROOT" -type f -name '*.[ao]' \! -regex "$RPM_BUILD_ROOT/*usr/lib/debug.*" -print0 | \
|
|
||||||
eu-elfclassify --not-program --not-library --not-linux-kernel-module --stdin0 --print0 | xargs -0 -r -P$NCPUS -n32 sh -c "$STRIP -p -R .gnu.lto_* -R .gnu.debuglto_* -N __gnu_lto_v1 \"\$@\"" ARG0
|
|
@ -17,9 +17,9 @@ Prior to that, some common problems in autotools scripts are
|
|||||||
automatically patched across the source tree.
|
automatically patched across the source tree.
|
||||||
|
|
||||||
As a side effect, this will set the environment variables `CFLAGS`,
|
As a side effect, this will set the environment variables `CFLAGS`,
|
||||||
`CXXFLAGS`, `FFLAGS`, `FCFLAGS`, `LDFLAGS` and `LT_SYS_LIBRARY_PATH`,
|
`CXXFLAGS`, `FFLAGS`, `FCFLAGS`, and `LDFLAGS`, so they can be used by
|
||||||
so they can be used by makefiles and other build tools. (However,
|
makefiles and other build tools. (However, existing values for this
|
||||||
existing values for these variables are not overwritten.)
|
variables are not overwritten.)
|
||||||
|
|
||||||
If your package does not use autoconf, you can still set the same
|
If your package does not use autoconf, you can still set the same
|
||||||
environment variables using
|
environment variables using
|
||||||
@ -46,9 +46,6 @@ Individual build flags are also available through RPM macros:
|
|||||||
driver. At the start of the `%build` section, the environment
|
driver. At the start of the `%build` section, the environment
|
||||||
variable `RPM_LD_FLAGS` is set to this value.
|
variable `RPM_LD_FLAGS` is set to this value.
|
||||||
|
|
||||||
The variable `LT_SYS_LIBRARY_PATH` is defined here to prevent the `libtool`
|
|
||||||
script (v2.4.6+) from hardcoding %_libdir into the binaries' RPATH.
|
|
||||||
|
|
||||||
These RPM macros do not alter shell environment variables.
|
These RPM macros do not alter shell environment variables.
|
||||||
|
|
||||||
For some other build tools separate mechanisms exist:
|
For some other build tools separate mechanisms exist:
|
||||||
@ -70,7 +67,7 @@ For building shared objects, you must compile with `-fPIC` in
|
|||||||
|
|
||||||
For other considerations involving shared objects, see:
|
For other considerations involving shared objects, see:
|
||||||
|
|
||||||
* [Fedora Packaging Guidelines: Shared Libraries](https://docs.fedoraproject.org/en-US/packaging-guidelines/#_shared_libraries)
|
* [Fedora Packaging Guidelines: Shared Libraries](https://fedoraproject.org/wiki/Packaging:Guidelines#Shared_Libraries)
|
||||||
|
|
||||||
# Customizing compiler and other build flags
|
# Customizing compiler and other build flags
|
||||||
|
|
||||||
@ -78,33 +75,6 @@ It is possible to set RPM macros to change some aspects of the
|
|||||||
compiler flags. Changing these flags should be used as a last
|
compiler flags. Changing these flags should be used as a last
|
||||||
recourse if other workarounds are not available.
|
recourse if other workarounds are not available.
|
||||||
|
|
||||||
### Toolchain selection
|
|
||||||
|
|
||||||
The default toolchain uses GCC, and the `%toolchain` macro is defined
|
|
||||||
as `gcc`.
|
|
||||||
|
|
||||||
It is enough to override `toolchain` macro and all relevant macro for C/C++
|
|
||||||
compilers will be switched. Either in the spec or in the command-line.
|
|
||||||
|
|
||||||
%global toolchain clang
|
|
||||||
|
|
||||||
or:
|
|
||||||
|
|
||||||
rpmbuild -D "toolchain clang" …
|
|
||||||
|
|
||||||
Inside a spec file it is also possible to determine which toolchain is in use
|
|
||||||
by testing the same macro. For example:
|
|
||||||
|
|
||||||
%if "%{toolchain}" == "gcc"
|
|
||||||
BuildRequires: gcc
|
|
||||||
%endif
|
|
||||||
|
|
||||||
or:
|
|
||||||
|
|
||||||
%if "%{toolchain}" == "clang"
|
|
||||||
BuildRequires: clang compiler-rt
|
|
||||||
%endif
|
|
||||||
|
|
||||||
### Disable autotools compatibility patching
|
### Disable autotools compatibility patching
|
||||||
|
|
||||||
By default, the invocation of the `%configure` macro replaces
|
By default, the invocation of the `%configure` macro replaces
|
||||||
@ -118,24 +88,6 @@ are set as well during libtool-. This can be switched off using:
|
|||||||
|
|
||||||
%global _configure_libtool_hardening_hack 0
|
%global _configure_libtool_hardening_hack 0
|
||||||
|
|
||||||
Further patching happens in LTO mode, see below.
|
|
||||||
|
|
||||||
### Disabling Link-Time Optimization
|
|
||||||
|
|
||||||
By default, builds use link-time optimization. In this build mode,
|
|
||||||
object code is generated at the time of the final link, by combining
|
|
||||||
information from all available translation units, and taking into
|
|
||||||
account which symbols are exported.
|
|
||||||
|
|
||||||
To disable this optimization, include this in the spec file:
|
|
||||||
|
|
||||||
%define _lto_cflags %{nil}
|
|
||||||
|
|
||||||
If LTO is enabled, `%configure` applies some common required fixes to
|
|
||||||
`configure` scripts. To disable that, define the RPM macro
|
|
||||||
`_fix_broken_configure_for_lto` as `true` (sic; it has to be a shell
|
|
||||||
command).
|
|
||||||
|
|
||||||
### Lazy binding
|
### Lazy binding
|
||||||
|
|
||||||
If your package depends on the semantics of lazy binding (e.g., it has
|
If your package depends on the semantics of lazy binding (e.g., it has
|
||||||
@ -177,21 +129,6 @@ recognized, so it has to come after the hardening flags on the command
|
|||||||
line (it has to be added at the end of `CFLAGS`, or specified after
|
line (it has to be added at the end of `CFLAGS`, or specified after
|
||||||
the `CFLAGS` variable contents).
|
the `CFLAGS` variable contents).
|
||||||
|
|
||||||
### Keeping dependencies on unused shared objects
|
|
||||||
|
|
||||||
By default, ELF shared objects which are listed on the linker command
|
|
||||||
line, but which have no referencing symbols in the preceding objects,
|
|
||||||
are not added to the output file during the final link.
|
|
||||||
|
|
||||||
In order to keep dependencies on shared objects even if none of
|
|
||||||
their symbols are used, include this in the RPM spec file:
|
|
||||||
|
|
||||||
%undefine _ld_as_needed
|
|
||||||
|
|
||||||
For example, this can be required if shared objects are used for their
|
|
||||||
side effects in ELF constructors, or for making them available to
|
|
||||||
dynamically loaded plugins.
|
|
||||||
|
|
||||||
### Strict symbol checks in the link editor (ld)
|
### Strict symbol checks in the link editor (ld)
|
||||||
|
|
||||||
Optionally, the link editor will refuse to link shared objects which
|
Optionally, the link editor will refuse to link shared objects which
|
||||||
@ -224,18 +161,6 @@ to the RPM spec file to disable these strict checks. Alternatively,
|
|||||||
you can pass `-z undefs` to ld (written as `-Wl,-z,undefs` on the gcc
|
you can pass `-z undefs` to ld (written as `-Wl,-z,undefs` on the gcc
|
||||||
command line). The latter needs binutils 2.29.1-12.fc28 or later.
|
command line). The latter needs binutils 2.29.1-12.fc28 or later.
|
||||||
|
|
||||||
### Legacy -fcommon
|
|
||||||
|
|
||||||
Since version 10, [gcc defaults to `-fno-common`](https://gcc.gnu.org/gcc-10/porting_to.html#common).
|
|
||||||
Builds may fail with `multiple definition of ...` errors.
|
|
||||||
|
|
||||||
As a short term workaround for such failure,
|
|
||||||
it is possible to add `-fcommon` to the flags by defining `%_legacy_common_support`.
|
|
||||||
|
|
||||||
%define _legacy_common_support 1
|
|
||||||
|
|
||||||
Properly fixing the failure is always preferred!
|
|
||||||
|
|
||||||
### Post-build ELF object processing
|
### Post-build ELF object processing
|
||||||
|
|
||||||
By default, DWARF debugging information is separated from installed
|
By default, DWARF debugging information is separated from installed
|
||||||
@ -286,15 +211,6 @@ These steps can be skipped by undefining the corresponding macros:
|
|||||||
processes static `.a` archives instead.
|
processes static `.a` archives instead.
|
||||||
* `__brp_strip_comment_note`: This step removes unallocated `.note`
|
* `__brp_strip_comment_note`: This step removes unallocated `.note`
|
||||||
sections, and `.comment` sections from ELF files.
|
sections, and `.comment` sections from ELF files.
|
||||||
* `__brp_strip_lto`: This step removes GCC LTO intermediate representation
|
|
||||||
in ELF sections starting with `.gnu.lto_` and `.gnu.debuglto_`. Skipping
|
|
||||||
this step is strongly discouraged because the tight coupling of LTO
|
|
||||||
data with the GCC version. The underlying tool is again determined by the
|
|
||||||
`__strip` macro.
|
|
||||||
* `__brp_llvm_compile_lto_elf`: This step replaces LLVM bitcode files
|
|
||||||
with object files, thereby removing LLVM bitcode from the installed
|
|
||||||
files. This transformation is applied to object files in static `.a`
|
|
||||||
archives, too.
|
|
||||||
* `__brp_ldconfig`: For each shared object on the library search path
|
* `__brp_ldconfig`: For each shared object on the library search path
|
||||||
whose soname does not match its file name, a symbolic link from the
|
whose soname does not match its file name, a symbolic link from the
|
||||||
soname to the file name is created. This way, these shared objects
|
soname to the file name is created. This way, these shared objects
|
||||||
@ -348,12 +264,6 @@ The general (architecture-independent) build flags are:
|
|||||||
it possible to unwind the stack (using C++ `throw` or Rust panics)
|
it possible to unwind the stack (using C++ `throw` or Rust panics)
|
||||||
from C callback functions if a C library supports non-local exits
|
from C callback functions if a C library supports non-local exits
|
||||||
from them (e.g., via `longjmp`).
|
from them (e.g., via `longjmp`).
|
||||||
* `-fasynchronous-unwind-tables`: Generate full unwind information
|
|
||||||
covering all program points. This is required for support of
|
|
||||||
asynchronous cancellation and proper unwinding from signal
|
|
||||||
handlers. It also makes performance and debugging tools more
|
|
||||||
useful because unwind information is available without having to
|
|
||||||
install (and load) debugging information.
|
|
||||||
* `-Wp,-D_GLIBCXX_ASSERTIONS`: Enable lightweight assertions in the
|
* `-Wp,-D_GLIBCXX_ASSERTIONS`: Enable lightweight assertions in the
|
||||||
C++ standard library, such as bounds checking for the subscription
|
C++ standard library, such as bounds checking for the subscription
|
||||||
operator on vectors. (This flag is added to both `CFLAGS` and
|
operator on vectors. (This flag is added to both `CFLAGS` and
|
||||||
@ -370,17 +280,9 @@ The general (architecture-independent) build flags are:
|
|||||||
vulnerabilities can result where the stack overlaps with the heap,
|
vulnerabilities can result where the stack overlaps with the heap,
|
||||||
or thread stacks spill into other regions of memory.) This flag is
|
or thread stacks spill into other regions of memory.) This flag is
|
||||||
fully ABI-compatible and has adds very little run-time overhead.
|
fully ABI-compatible and has adds very little run-time overhead.
|
||||||
This flag is currently not available on aarch64 with the `clang` toolchain.
|
|
||||||
* `-flto=auto`: Enable link-time optimization (LTO), using `make` job server
|
|
||||||
integration for parallel processing. (`gcc` toolchain only)
|
|
||||||
* `-ffat-lto-objects`: Generate EFL object files which contain both
|
|
||||||
object code and LTO intermediate representation. (`gcc` toolchain only)
|
|
||||||
* `-flto`: Enable link-time optimization. (`clang` toolchain only)
|
|
||||||
* `-grecord-gcc-switches`: Include select GCC command line switches in
|
* `-grecord-gcc-switches`: Include select GCC command line switches in
|
||||||
the DWARF debugging information. This is useful for detecting the
|
the DWARF debugging information. This is useful for detecting the
|
||||||
presence of certain build flags and general hardening coverage.
|
presence of certain build flags and general hardening coverage.
|
||||||
* `-fcommon`: This optional flag is used to build legacy software
|
|
||||||
which relies on C tentative definitions. It is disabled by default.
|
|
||||||
|
|
||||||
For hardened builds (which are enabled by default, see above for how
|
For hardened builds (which are enabled by default, see above for how
|
||||||
to disable them), the flag
|
to disable them), the flag
|
||||||
@ -408,9 +310,8 @@ command line. It adds the following flag to the command line:
|
|||||||
To support [binary watermarks for ELF
|
To support [binary watermarks for ELF
|
||||||
objects](https://fedoraproject.org/wiki/Toolchain/Watermark) using
|
objects](https://fedoraproject.org/wiki/Toolchain/Watermark) using
|
||||||
annobin, the `-specs=/usr/lib/rpm/redhat/redhat-annobin-cc1` flag is
|
annobin, the `-specs=/usr/lib/rpm/redhat/redhat-annobin-cc1` flag is
|
||||||
added by default (with the `gcc` toolchain). This can be switched off
|
added by default. This can be switched off by undefining the
|
||||||
by undefining the `%_annotated_build` RPM macro (see above). Binary
|
`%_annotated_build` RPM macro (see above).
|
||||||
watermarks are currently disabled with the `clang` toolchain.
|
|
||||||
|
|
||||||
### Architecture-specific compiler flags
|
### Architecture-specific compiler flags
|
||||||
|
|
||||||
@ -423,30 +324,43 @@ not), but their selection depends on the architecture:
|
|||||||
the same compilation. For such architectures, the RPM build process
|
the same compilation. For such architectures, the RPM build process
|
||||||
explicitly selects the architecture variant by passing this compiler
|
explicitly selects the architecture variant by passing this compiler
|
||||||
flag.
|
flag.
|
||||||
|
* `-fasynchronous-unwind-tables`: Generate full unwind information
|
||||||
|
covering all program points. This is required for support of
|
||||||
|
asynchronous cancellation and proper unwinding from signal
|
||||||
|
handlers. It also makes performance and debugging tools more
|
||||||
|
useful because unwind information is available without having to
|
||||||
|
install (and load) debugging ienformation.
|
||||||
|
Asynchronous unwind tables are enabled for aarch64, i686, s390x,
|
||||||
|
and x86_64. They are not needed on ppc64le due
|
||||||
|
to architectural differences in stack management. On these
|
||||||
|
architectures, `-fexceptions` (see above) still enables regular
|
||||||
|
unwind tables (or they are enabled by default even without this
|
||||||
|
option).
|
||||||
|
* `-funwind-tables`: A subset of the unwind information restricted
|
||||||
|
to actual call sites. Used on ppc64le. Also implied by
|
||||||
|
`-fexceptions`.
|
||||||
|
|
||||||
In addition, `redhat-rpm-config` re-selects the built-in default
|
In addition, `redhat-rpm-config` re-selects the built-in default
|
||||||
tuning in the `gcc` package. These settings are:
|
tuning in the `gcc` package. These settings are:
|
||||||
|
|
||||||
* **i686**: `-march=i686` is used to select a minmum support CPU level
|
* **i686**: `-march=x86-64` is used to select a minimum supported
|
||||||
of i686 (corresponding to the Pentium Pro). SSE2 support is
|
CPU level matching the baseline for the x86_64 architecture.
|
||||||
enabled with `-msse2` (so only CPUs with SSE2 support can run the
|
`-mtune=generic` activates tuning for a current blend of CPUs.
|
||||||
compiled code; SSE2 was introduced first with the Pentium 4).
|
`-mfpmath=sse` uses the SSE2 unit for floating point math,
|
||||||
`-mtune=generic` activates tuning for a current blend of CPUs
|
instead of the legacy i387 FPU, avoiding issues related to excess
|
||||||
(under the assumption that most users of i686 packages obtain them
|
precision. `-mstackrealign` ensures that the generated code
|
||||||
through an x86_64 installation on current hardware).
|
does not assume 16-byte stack alignment (as required by the current
|
||||||
`-mfpmath=sse` instructs GCC to use the SSE2 unit for floating
|
i386 ABI), but stays compatible with application code compiled
|
||||||
point math to avoid excess precision issues. `-mstackrealign`
|
before the introduction of 16-byte stack alignment along with SSE2
|
||||||
avoids relying on the stack alignment guaranteed by the current
|
support.
|
||||||
version of the i386 ABI.
|
* **ppc64le**: `-mcpu=power8 -mtune=power8` selects a minimum supported
|
||||||
* **ppc64le**: `-mcpu=power9 -mtune=power9` selects a minimum supported
|
CPU level of POWER8 (the first CPU with ppc64le support) and tunes
|
||||||
CPU level of POWER9.
|
for POWER8.
|
||||||
* **s390x**: `-march=z14 -mtune=z15` specifies a minimum supported CPU
|
* **s390x**: `-march=z13 -mtune=z14` specifies a minimum supported CPU
|
||||||
level of z14, while optimizing for a subsequent CPU generation
|
level of z13, while optimizing for a subsequent CPU generation
|
||||||
(z15).
|
(z14).
|
||||||
* **x86_64**: `-march=x86-64-v2 -mtune=generic` builds for the
|
* **x86_64**: `-mtune=generic` selects tuning which is expected to
|
||||||
[x86-64-v2 micro-architecture level](https://gitlab.com/x86-psABIs/x86-64-ABI/-/blob/master/x86-64-ABI/low-level-sys-info.tex)
|
beneficial for a broad range of current CPUs.
|
||||||
and selects tuning which is expected to beneficial for a broad range
|
|
||||||
of current CPUs.
|
|
||||||
* **aarch64** does not have any architecture-specific tuning.
|
* **aarch64** does not have any architecture-specific tuning.
|
||||||
|
|
||||||
# Individual linker flags
|
# Individual linker flags
|
||||||
@ -463,10 +377,6 @@ to the compiler driver `gcc`, and not directly to the link editor
|
|||||||
dynamic linker is instructed to revoke write permissions after
|
dynamic linker is instructed to revoke write permissions after
|
||||||
dynamic linking. Full protection of relocation data requires the
|
dynamic linking. Full protection of relocation data requires the
|
||||||
`-z now` flag (see below).
|
`-z now` flag (see below).
|
||||||
* `--as-needed`: In the final link, only generate ELF dependencies
|
|
||||||
for shared objects that actually provide symbols required by the link.
|
|
||||||
Shared objects which are not needed to fulfill symbol dependencies
|
|
||||||
are essentially ignored due to this flag.
|
|
||||||
* `-z defs`: Refuse to link shared objects (DSOs) with undefined symbols
|
* `-z defs`: Refuse to link shared objects (DSOs) with undefined symbols
|
||||||
(optional, see above).
|
(optional, see above).
|
||||||
|
|
||||||
|
@ -1,294 +0,0 @@
|
|||||||
-- Convenience Lua functions that can be used within rpm macros
|
|
||||||
|
|
||||||
-- Reads an rpm variable. Unlike a basic rpm.expand("{?foo}"), returns nil if
|
|
||||||
-- the variable is unset, which is convenient in lua tests and enables
|
|
||||||
-- differentiating unset variables from variables set to ""
|
|
||||||
local function read(rpmvar)
|
|
||||||
if not rpmvar or
|
|
||||||
(rpm.expand("%{" .. rpmvar .. "}") == "%{" .. rpmvar .. "}") then
|
|
||||||
return nil
|
|
||||||
else
|
|
||||||
return rpm.expand("%{?" .. rpmvar .. "}")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Returns true if the macro that called this function had flag set
|
|
||||||
-- – for example, hasflag("z") would give the following results:
|
|
||||||
-- %foo -z bar → true
|
|
||||||
-- %foo -z → true
|
|
||||||
-- %foo → false
|
|
||||||
local function hasflag(flag)
|
|
||||||
return (rpm.expand("%{-" .. flag .. "}") ~= "")
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Returns the argument passed to flag in the macro that called this function
|
|
||||||
-- – for example, readflag("z") would give the following results:
|
|
||||||
-- %foo -z bar → bar
|
|
||||||
-- %foo → nil
|
|
||||||
-- %foo -z "" → empty string
|
|
||||||
-- %foo -z '' → empty string
|
|
||||||
local function readflag(flag)
|
|
||||||
if not hasflag(flag) then
|
|
||||||
return nil
|
|
||||||
else
|
|
||||||
local a = rpm.expand("%{-" .. flag .. "*}")
|
|
||||||
-- Handle "" and '' as empty strings
|
|
||||||
if (a == '""') or (a == "''") then
|
|
||||||
a = ''
|
|
||||||
end
|
|
||||||
return a
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Sets a spec variable; echoes the result if verbose
|
|
||||||
local function explicitset(rpmvar, value, verbose)
|
|
||||||
local value = value
|
|
||||||
if (value == nil) or (value == "") then
|
|
||||||
value = "%{nil}"
|
|
||||||
end
|
|
||||||
rpm.define(rpmvar .. " " .. value)
|
|
||||||
if verbose then
|
|
||||||
rpm.expand("%{warn:Setting %%{" .. rpmvar .. "} = " .. value .. "}")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Unsets a spec variable if it is defined; echoes the result if verbose
|
|
||||||
local function explicitunset(rpmvar, verbose)
|
|
||||||
if (rpm.expand("%{" .. rpmvar .. "}") ~= "%{" .. rpmvar .. "}") then
|
|
||||||
rpm.define(rpmvar .. " %{nil}")
|
|
||||||
if verbose then
|
|
||||||
rpm.expand("%{warn:Unsetting %%{" .. rpmvar .. "}}")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Sets a spec variable, if not already set; echoes the result if verbose
|
|
||||||
local function safeset(rpmvar, value, verbose)
|
|
||||||
if (rpm.expand("%{" .. rpmvar .. "}") == "%{" .. rpmvar .. "}") then
|
|
||||||
explicitset(rpmvar,value,verbose)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Aliases a list of rpm variables to the same variables suffixed with 0 (and
|
|
||||||
-- vice versa); echoes the result if verbose
|
|
||||||
local function zalias(rpmvars, verbose)
|
|
||||||
for _, sfx in ipairs({{"","0"},{"0",""}}) do
|
|
||||||
for _, rpmvar in ipairs(rpmvars) do
|
|
||||||
local toalias = "%{?" .. rpmvar .. sfx[1] .. "}"
|
|
||||||
if (rpm.expand(toalias) ~= "") then
|
|
||||||
safeset(rpmvar .. sfx[2], toalias, verbose)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Takes a list of rpm variable roots and a suffix and alias current<root> to
|
|
||||||
-- <root><suffix> if it resolves to something not empty
|
|
||||||
local function setcurrent(rpmvars, suffix, verbose)
|
|
||||||
for _, rpmvar in ipairs(rpmvars) do
|
|
||||||
if (rpm.expand("%{?" .. rpmvar .. suffix .. "}") ~= "") then
|
|
||||||
explicitset( "current" .. rpmvar, "%{" .. rpmvar .. suffix .. "}", verbose)
|
|
||||||
else
|
|
||||||
explicitunset("current" .. rpmvar, verbose)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Echo the list of rpm variables, with suffix, if set
|
|
||||||
local function echovars(rpmvars, suffix)
|
|
||||||
for _, rpmvar in ipairs(rpmvars) do
|
|
||||||
rpmvar = rpmvar .. suffix
|
|
||||||
local header = string.sub(" " .. rpmvar .. ": ",1,21)
|
|
||||||
rpm.expand("%{?" .. rpmvar .. ":%{echo:" .. header .. "%{?" .. rpmvar .. "}}}")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Returns an array, indexed by suffix, containing the non-empy values of
|
|
||||||
-- <rpmvar><suffix>, with suffix an integer string or the empty string
|
|
||||||
local function getsuffixed(rpmvar)
|
|
||||||
local suffixes = {}
|
|
||||||
zalias({rpmvar})
|
|
||||||
for suffix=0,9999 do
|
|
||||||
local value = rpm.expand("%{?" .. rpmvar .. suffix .. "}")
|
|
||||||
if (value ~= "") then
|
|
||||||
suffixes[tostring(suffix)] = value
|
|
||||||
end
|
|
||||||
end
|
|
||||||
-- rpm convention is to alias no suffix to zero suffix
|
|
||||||
-- only add no suffix if zero suffix is different
|
|
||||||
local value = rpm.expand("%{?" .. rpmvar .. "}")
|
|
||||||
if (value ~= "") and (value ~= suffixes["0"]) then
|
|
||||||
suffixes[""] = value
|
|
||||||
end
|
|
||||||
return suffixes
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Returns the list of suffixes, including the empty string, for which
|
|
||||||
-- <rpmvar><suffix> is set to a non empty value
|
|
||||||
local function getsuffixes(rpmvar)
|
|
||||||
suffixes = {}
|
|
||||||
for suffix in pairs(getsuffixed(rpmvar)) do
|
|
||||||
table.insert(suffixes,suffix)
|
|
||||||
end
|
|
||||||
table.sort(suffixes,
|
|
||||||
function(a,b) return (tonumber(a) or 0) < (tonumber(b) or 0) end)
|
|
||||||
return suffixes
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Returns the suffix for which <rpmvar><suffix> has a non-empty value that
|
|
||||||
-- matches best the beginning of the value string
|
|
||||||
local function getbestsuffix(rpmvar, value)
|
|
||||||
local best = nil
|
|
||||||
local currentmatch = ""
|
|
||||||
for suffix, setvalue in pairs(getsuffixed(rpmvar)) do
|
|
||||||
if (string.len(setvalue) > string.len(currentmatch)) and
|
|
||||||
(string.find(value, "^" .. setvalue)) then
|
|
||||||
currentmatch = setvalue
|
|
||||||
best = suffix
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return best
|
|
||||||
end
|
|
||||||
|
|
||||||
-- %writevars core
|
|
||||||
local function writevars(macrofile, rpmvars)
|
|
||||||
for _, rpmvar in ipairs(rpmvars) do
|
|
||||||
print("sed -i 's\029" .. string.upper("@@" .. rpmvar .. "@@") ..
|
|
||||||
"\029" .. rpm.expand( "%{" .. rpmvar .. "}" ) ..
|
|
||||||
"\029g' " .. macrofile .. "\n")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- https://github.com/rpm-software-management/rpm/issues/566
|
|
||||||
-- Reformat a text intended to be used used in a package description, removing
|
|
||||||
-- rpm macro generation artefacts.
|
|
||||||
-- – remove leading and ending empty lines
|
|
||||||
-- – trim intermediary empty lines to a single line
|
|
||||||
-- – fold on spaces
|
|
||||||
-- Should really be a %%{wordwrap:…} verb
|
|
||||||
local function wordwrap(text)
|
|
||||||
text = rpm.expand(text .. "\n")
|
|
||||||
text = string.gsub(text, "\t", " ")
|
|
||||||
text = string.gsub(text, "\r", "\n")
|
|
||||||
text = string.gsub(text, " +\n", "\n")
|
|
||||||
text = string.gsub(text, "\n+\n", "\n\n")
|
|
||||||
text = string.gsub(text, "^\n", "")
|
|
||||||
text = string.gsub(text, "\n( *)[-*—][ ]+", "\n%1– ")
|
|
||||||
output = ""
|
|
||||||
for line in string.gmatch(text, "[^\n]*\n") do
|
|
||||||
local pos = 0
|
|
||||||
local advance = ""
|
|
||||||
for word in string.gmatch(line, "%s*[^%s]*\n?") do
|
|
||||||
local wl, bad = utf8.len(word)
|
|
||||||
if not wl then
|
|
||||||
print("%{warn:Invalid UTF-8 sequence detected in:}" ..
|
|
||||||
"%{warn:" .. word .. "}" ..
|
|
||||||
"%{warn:It may produce unexpected results.}")
|
|
||||||
wl = bad
|
|
||||||
end
|
|
||||||
if (pos == 0) then
|
|
||||||
advance, n = string.gsub(word, "^(%s*– ).*", "%1")
|
|
||||||
if (n == 0) then
|
|
||||||
advance = string.gsub(word, "^(%s*).*", "%1")
|
|
||||||
end
|
|
||||||
advance = string.gsub(advance, "– ", " ")
|
|
||||||
pos = pos + wl
|
|
||||||
elseif (pos + wl < 81) or
|
|
||||||
((pos + wl == 81) and string.match(word, "\n$")) then
|
|
||||||
pos = pos + wl
|
|
||||||
else
|
|
||||||
word = advance .. string.gsub(word, "^%s*", "")
|
|
||||||
output = output .. "\n"
|
|
||||||
pos = utf8.len(word)
|
|
||||||
end
|
|
||||||
output = output .. word
|
|
||||||
if pos > 80 then
|
|
||||||
pos = 0
|
|
||||||
if not string.match(word, "\n$") then
|
|
||||||
output = output .. "\n"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
output = string.gsub(output, "\n*$", "\n")
|
|
||||||
return output
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Because rpmbuild will fail if a subpackage is declared before the source
|
|
||||||
-- package itself, provide a source package declaration shell as fallback.
|
|
||||||
local function srcpkg(verbose)
|
|
||||||
if verbose then
|
|
||||||
rpm.expand([[
|
|
||||||
%{echo:Creating a header for the SRPM from %%{source_name}, %%{source_summary} and}
|
|
||||||
%{echo:%%{source_description}. If that is not the intended result, please declare the}
|
|
||||||
%{echo:SRPM header and set %%{source_name} in your spec file before calling a macro}
|
|
||||||
%{echo:that creates other package headers.}
|
|
||||||
]])
|
|
||||||
end
|
|
||||||
print(rpm.expand([[
|
|
||||||
Name: %{source_name}
|
|
||||||
Summary: %{source_summary}
|
|
||||||
%description
|
|
||||||
%wordwrap -v source_description
|
|
||||||
]]))
|
|
||||||
explicitset("currentname", "%{source_name}", verbose)
|
|
||||||
end
|
|
||||||
|
|
||||||
-- %new_package core
|
|
||||||
local function new_package(source_name, pkg_name, name_suffix, first, verbose)
|
|
||||||
-- Safety net when the wrapper is used in conjunction with traditional syntax
|
|
||||||
if (not first) and (not source_name) then
|
|
||||||
rpm.expand([[
|
|
||||||
%{warn:Something already set a package name. However, %%{source_name} is not set.}
|
|
||||||
%{warn:Please set %%{source_name} to the SRPM name to ensure reliable processing.}
|
|
||||||
]])
|
|
||||||
if name_suffix then
|
|
||||||
print(rpm.expand("%package " .. name_suffix))
|
|
||||||
else
|
|
||||||
print(rpm.expand("%package -n " .. pkg_name))
|
|
||||||
end
|
|
||||||
return
|
|
||||||
end
|
|
||||||
-- New processing
|
|
||||||
if not (pkg_name or name_suffix or source_name) then
|
|
||||||
rpm.expand([[
|
|
||||||
%{error:You need to set %%{source_name} or provide explicit package naming!}
|
|
||||||
]])
|
|
||||||
end
|
|
||||||
if name_suffix then
|
|
||||||
print(rpm.expand("%package " .. name_suffix))
|
|
||||||
explicitset("currentname", "%{source_name}-" .. name_suffix, verbose)
|
|
||||||
else
|
|
||||||
if not source_name then
|
|
||||||
source_name = pkg_name
|
|
||||||
end
|
|
||||||
if (pkg_name == source_name) then
|
|
||||||
safeset("source_name", source_name, verbose)
|
|
||||||
print(rpm.expand("Name: %{source_name}"))
|
|
||||||
else
|
|
||||||
if source_name and first then
|
|
||||||
srcpkg(verbose)
|
|
||||||
end
|
|
||||||
print(rpm.expand("%package -n " .. pkg_name))
|
|
||||||
end
|
|
||||||
explicitset("currentname", pkg_name, verbose)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return {
|
|
||||||
read = read,
|
|
||||||
hasflag = hasflag,
|
|
||||||
readflag = readflag,
|
|
||||||
explicitset = explicitset,
|
|
||||||
explicitunset = explicitunset,
|
|
||||||
safeset = safeset,
|
|
||||||
zalias = zalias,
|
|
||||||
setcurrent = setcurrent,
|
|
||||||
echovars = echovars,
|
|
||||||
getsuffixed = getsuffixed,
|
|
||||||
getsuffixes = getsuffixes,
|
|
||||||
getbestsuffix = getbestsuffix,
|
|
||||||
writevars = writevars,
|
|
||||||
wordwrap = wordwrap,
|
|
||||||
new_package = new_package,
|
|
||||||
}
|
|
@ -25,7 +25,7 @@ function check_rhl {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function check_rhel {
|
function check_rhel {
|
||||||
egrep -q "(Enterprise|Advanced|CentOS)" $RELEASEFILE && echo $DISTNUM
|
egrep -q "(Enterprise|Advanced)" $RELEASEFILE && echo $DISTNUM
|
||||||
}
|
}
|
||||||
|
|
||||||
function check_fedora {
|
function check_fedora {
|
||||||
|
@ -30,7 +30,7 @@ done
|
|||||||
|
|
||||||
is_kmod=1
|
is_kmod=1
|
||||||
for f in $filelist; do
|
for f in $filelist; do
|
||||||
if [ $(echo "$f" | sed -r -ne 's:^.*/lib/modules/(.*)/(.*).ko$:\2:p') ]
|
if [ $(echo "$f" | sed -r -ne 's:^.*/lib/modules/(.*)/(.*)\.ko(\.gz|\.bz2|\.xz)?$:\2:p') ]
|
||||||
then
|
then
|
||||||
is_kernel=1;
|
is_kernel=1;
|
||||||
fi
|
fi
|
||||||
|
48
SOURCES/find-provides.ksyms
Executable file
48
SOURCES/find-provides.ksyms
Executable file
@ -0,0 +1,48 @@
|
|||||||
|
#! /bin/bash
|
||||||
|
|
||||||
|
IFS=$'\n'
|
||||||
|
|
||||||
|
for module in $(grep -E '/lib/modules/.+\.ko(\.gz|\.bz2|\.xz)?$'); do
|
||||||
|
tmpfile=""
|
||||||
|
if [ "x${module%.ko}" = "x${module}" ]; then
|
||||||
|
tmpfile=$(mktemp -t ${0##*/}.XXXXXX.ko)
|
||||||
|
proc_bin=
|
||||||
|
case "${module##*.}" in
|
||||||
|
xz)
|
||||||
|
proc_bin=xz
|
||||||
|
;;
|
||||||
|
bz2)
|
||||||
|
proc_bin=bzip2
|
||||||
|
;;
|
||||||
|
gz)
|
||||||
|
proc_bin=gzip
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
[ -n "$proc_bin" ] || continue
|
||||||
|
|
||||||
|
"$proc_bin" -d -c - < "$module" > "$tmpfile" || continue
|
||||||
|
module="$tmpfile"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n $(nm $module | sed -r -ne 's:^0*([0-9a-f]+) A __crc_(.+):0x\1 \2:p') ]]; then
|
||||||
|
nm $module \
|
||||||
|
| sed -r -ne 's:^0*([0-9a-f]+) A __crc_(.+):0x\1 \2:p' \
|
||||||
|
| awk --non-decimal-data '{printf("ksym(%s) = 0x%08x\n", $2, $1)}' \
|
||||||
|
| LC_ALL=C sort -u
|
||||||
|
else
|
||||||
|
ELFRODATA=$(readelf -R .rodata $module | awk '/0x/{printf $2$3$4$5}')
|
||||||
|
if [[ -n $(readelf -h $module | grep "little endian") ]]; then
|
||||||
|
RODATA=$(echo $ELFRODATA | sed 's/\(..\)\(..\)\(..\)\(..\)/\4\3\2\1/g')
|
||||||
|
else
|
||||||
|
RODATA=$ELFRODATA
|
||||||
|
fi
|
||||||
|
for sym in $(nm $module | sed -r -ne 's:^0*([0-9a-f]+) R __crc_(.+):0x\1 \2:p'); do
|
||||||
|
echo $sym $RODATA
|
||||||
|
done \
|
||||||
|
| awk --non-decimal-data '{printf("ksym(%s) = 0x%08s\n", $2, substr($3,($1*2)+1,8))}' \
|
||||||
|
| LC_ALL=C sort -u
|
||||||
|
fi
|
||||||
|
|
||||||
|
[ -z "$tmpfile" ] || rm -f -- "$tmpfile"
|
||||||
|
done
|
@ -22,7 +22,7 @@ filelist=`sed "s/[]['\"*?{}]/\\\\\&/g"`
|
|||||||
unset is_kmod
|
unset is_kmod
|
||||||
|
|
||||||
for f in $filelist; do
|
for f in $filelist; do
|
||||||
if [ $(echo "$f" | sed -r -ne 's:^.*/lib/modules/(.*)/(.*).ko$:\2:p') ]
|
if [ $(echo "$f" | sed -r -ne 's:^.*/lib/modules/(.*)/(.*)\.ko(\.gz|\.bz2|\.xz)?$:\2:p') ]
|
||||||
then
|
then
|
||||||
is_kmod=1;
|
is_kmod=1;
|
||||||
elif [ $(echo "$f" | sed -r -ne 's:^.*/boot/(.*):\1:p') ]
|
elif [ $(echo "$f" | sed -r -ne 's:^.*/boot/(.*):\1:p') ]
|
||||||
@ -32,8 +32,7 @@ for f in $filelist; do
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
# Disabling for now while the Fedora kernel doesn't produce kABI deps.
|
[ -x /usr/lib/rpm/redhat/find-requires.ksyms ] && [ "$is_kmod" ] &&
|
||||||
#[ -x /usr/lib/rpm/redhat/find-requires.ksyms ] && [ "$is_kmod" ] &&
|
printf "%s\n" "${filelist[@]}" | /usr/lib/rpm/redhat/find-requires.ksyms
|
||||||
# printf "%s\n" "${filelist[@]}" | /usr/lib/rpm/redhat/find-requires.ksyms
|
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
|
155
SOURCES/find-requires.ksyms
Executable file
155
SOURCES/find-requires.ksyms
Executable file
@ -0,0 +1,155 @@
|
|||||||
|
#! /bin/bash
|
||||||
|
#
|
||||||
|
# This script is called during external module building to create dependencies
|
||||||
|
# both upon the RHEL kernel, and on additional external modules. Symbols that
|
||||||
|
# cannot be reconciled against those provided by the kernel are assumed to be
|
||||||
|
# provided by an external module and "ksym" replaces th regular "kernel" dep.
|
||||||
|
|
||||||
|
IFS=$'\n'
|
||||||
|
|
||||||
|
# Extract all of the symbols provided by this module.
|
||||||
|
all_provides() {
|
||||||
|
for module in "$@"; do
|
||||||
|
tmpfile=""
|
||||||
|
if [ "x${module%.ko}" = "x${module}" ]; then
|
||||||
|
tmpfile=$(mktemp -t ${0##*/}.XXXXXX.ko)
|
||||||
|
proc_bin=
|
||||||
|
case "${module##*.}" in
|
||||||
|
xz)
|
||||||
|
proc_bin=xz
|
||||||
|
;;
|
||||||
|
bz2)
|
||||||
|
proc_bin=bzip2
|
||||||
|
;;
|
||||||
|
gz)
|
||||||
|
proc_bin=gzip
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
[ -n "$proc_bin" ] || continue
|
||||||
|
|
||||||
|
"$proc_bin" -d -c - < "$module" > "$tmpfile" || continue
|
||||||
|
module="$tmpfile"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n $(nm "$module" | sed -r -ne 's:^0*([0-9a-f]+) A __crc_(.+):0x\1 \2:p') ]]; then
|
||||||
|
nm "$module" \
|
||||||
|
| sed -r -ne 's:^0*([0-9a-f]+) A __crc_(.+):0x\1 \2:p' \
|
||||||
|
| awk --non-decimal-data '{printf("%s:0x%08x\n", $2, $1)}'
|
||||||
|
else
|
||||||
|
ELFRODATA=$(readelf -R .rodata "$module" | awk '/0x/{printf $2$3$4$5}')
|
||||||
|
if [[ -n $(readelf -h "$module" | grep "little endian") ]]; then
|
||||||
|
RODATA=$(echo $ELFRODATA | sed 's/\(..\)\(..\)\(..\)\(..\)/\4\3\2\1/g')
|
||||||
|
else
|
||||||
|
RODATA=$ELFRODATA
|
||||||
|
fi
|
||||||
|
for sym in $(nm "$module" | sed -r -ne 's:^0*([0-9a-f]+) R __crc_(.+):0x\1 \2:p'); do
|
||||||
|
echo $sym $RODATA
|
||||||
|
done \
|
||||||
|
| awk --non-decimal-data '{printf("%s:0x%08s\n", $2, substr($3,($1*2)+1,8))}'
|
||||||
|
fi
|
||||||
|
|
||||||
|
[ -z "$tmpfile" ] || rm -f -- "$tmpfile"
|
||||||
|
done \
|
||||||
|
| LC_ALL=C sort -k1,1 -u
|
||||||
|
}
|
||||||
|
|
||||||
|
# Extract all of the requirements of this module.
|
||||||
|
all_requires() {
|
||||||
|
for module in "$@"; do
|
||||||
|
set -- $(/sbin/modinfo -F vermagic "$module" | sed -e 's: .*::' -e q)
|
||||||
|
/sbin/modprobe --dump-modversions "$module" \
|
||||||
|
| awk --non-decimal-data '
|
||||||
|
BEGIN { FS = "\t" ; OFS = "\t" }
|
||||||
|
{printf("%s:0x%08x\n", $2, $1)}' \
|
||||||
|
| sed -r -e 's:$:\t'"$1"':'
|
||||||
|
done \
|
||||||
|
| LC_ALL=C sort -k1,1 -u
|
||||||
|
}
|
||||||
|
|
||||||
|
# Filter out requirements fulfilled by the module itself.
|
||||||
|
mod_requires() {
|
||||||
|
LC_ALL=C join -t $'\t' -j 1 -v 1 \
|
||||||
|
<(all_requires "$@") \
|
||||||
|
<(all_provides "$@") \
|
||||||
|
| LC_ALL=C sort -k1,1 -u
|
||||||
|
}
|
||||||
|
|
||||||
|
if ! [ -e /sbin/modinfo -a -e /sbin/modprobe ]; then
|
||||||
|
cat > /dev/null
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
check_kabi() {
|
||||||
|
arch=$(uname -m)
|
||||||
|
kabi_file="/lib/modules/kabi-current/kabi_whitelist_$arch"
|
||||||
|
|
||||||
|
# If not installed, output a warning and return (continue)
|
||||||
|
if [ ! -f "$kabi_file" ]; then
|
||||||
|
echo "" >&2
|
||||||
|
echo "********************************************************************************" >&2
|
||||||
|
echo "*********************** KERNEL ABI COMPATIBILITY WARNING ***********************" >&2
|
||||||
|
echo "********************************************************************************" >&2
|
||||||
|
echo "The kernel ABI reference files (provided by "kabi-whitelists") were not found." >&2
|
||||||
|
echo "No compatibility check was performed. Please install the kABI reference files" >&2
|
||||||
|
echo "and rebuild if you would like to verify compatibility with kernel ABI." >&2
|
||||||
|
echo "" >&2
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
unset non_kabi
|
||||||
|
for symbol in "$@"; do
|
||||||
|
if ! egrep "^[[:space:]]$symbol\$" $kabi_file >/dev/null; then
|
||||||
|
non_kabi=("${non_kabi[@]}" "$symbol")
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ ${#non_kabi[@]} -gt 0 ]; then
|
||||||
|
echo "" >&2
|
||||||
|
echo "********************************************************************************" >&2
|
||||||
|
echo "*********************** KERNEL ABI COMPATIBILITY WARNING ***********************" >&2
|
||||||
|
echo "********************************************************************************" >&2
|
||||||
|
echo "The following kernel symbols are not guaranteed to remain compatible with" >&2
|
||||||
|
echo "future kernel updates to this RHEL release:" >&2
|
||||||
|
echo "" >&2
|
||||||
|
for symbol in "${non_kabi[@]}"; do
|
||||||
|
printf "\t$symbol\n" >&2
|
||||||
|
done
|
||||||
|
echo "" >&2
|
||||||
|
echo "Red Hat recommends that you consider using only official kernel ABI symbols" >&2
|
||||||
|
echo "where possible. Requests for additions to the kernel ABI can be filed with" >&2
|
||||||
|
echo "your partner or customer representative (component: driver-update-program)." >&2
|
||||||
|
echo "" >&2
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
modules=($(grep -E '/lib/modules/.+\.ko(\.gz|\.bz2|\.xz)?$'))
|
||||||
|
if [ ${#modules[@]} -gt 0 ]; then
|
||||||
|
kernel=$(/sbin/modinfo -F vermagic "${modules[0]}" | sed -e 's: .*::' -e q)
|
||||||
|
|
||||||
|
# get all that kernel provides
|
||||||
|
symvers=$(mktemp -t ${0##*/}.XXXXX)
|
||||||
|
|
||||||
|
cat /usr/src/kernels/$kernel/Module.symvers | awk '
|
||||||
|
BEGIN { FS = "\t" ; OFS = "\t" }
|
||||||
|
{ print $2 ":" $1 }
|
||||||
|
' \
|
||||||
|
| sed -r -e 's:$:\t'"$kernel"':' \
|
||||||
|
| LC_ALL=C sort -k1,1 -u > $symvers
|
||||||
|
|
||||||
|
# Symbols matching with the kernel get a "kernel" dependency
|
||||||
|
mod_req=$(mktemp -t mod_req.XXXXX)
|
||||||
|
mod_requires "${modules[@]}" > "$mod_req"
|
||||||
|
LC_ALL=C join -t $'\t' -j 1 $symvers "$mod_req" | LC_ALL=C sort -u \
|
||||||
|
| awk 'BEGIN { FS = "[\t:]" ; OFS = "\t" } { print "kernel(" $1 ") = " $2 }'
|
||||||
|
|
||||||
|
# Symbols from elsewhere get a "ksym" dependency
|
||||||
|
LC_ALL=C join -t $'\t' -j 1 -v 2 $symvers "$mod_req" | LC_ALL=C sort -u \
|
||||||
|
| awk 'BEGIN { FS = "[\t:]" ; OFS = "\t" } { print "ksym(" $1 ") = " $2 }'
|
||||||
|
|
||||||
|
# Check kABI if the kabi-whitelists package is installed
|
||||||
|
# Do this last so we can try to output this error at the end
|
||||||
|
kabi_check_symbols=($(LC_ALL=C join -t $'\t' -j 1 $symvers "$mod_req" | LC_ALL=C sort -u \
|
||||||
|
| awk 'BEGIN { FS = "[\t:]" ; OFS = "\t" } { print $1 }'))
|
||||||
|
check_kabi "${kabi_check_symbols[@]}"
|
||||||
|
fi
|
14
SOURCES/firmware.prov
Normal file
14
SOURCES/firmware.prov
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
#
|
||||||
|
# firmware.prov - Automatically extract any and all firmware dependencies from
|
||||||
|
# kernel object (.ko) files and add to RPM deps.
|
||||||
|
|
||||||
|
IFS=$'\n'
|
||||||
|
|
||||||
|
for module in $(grep -E '/lib/modules/.+\.ko(\.gz|\.bz2|\.xz)?$') $*;
|
||||||
|
do
|
||||||
|
for firmware in `/sbin/modinfo -F firmware $module`;
|
||||||
|
do
|
||||||
|
echo "firmware($firmware)"
|
||||||
|
done
|
||||||
|
done
|
@ -1,312 +0,0 @@
|
|||||||
-- Lua code used by macros.forge and derivatives
|
|
||||||
|
|
||||||
-- Computes the suffix of a version string, removing vprefix if it matches
|
|
||||||
-- For example with vprefix 1.2.3: 1.2.3.rc2 → .rc2 but 1.2.30 → 1.2.30 not 0
|
|
||||||
local function getversionsuffix(vstring,vprefix)
|
|
||||||
if (string.sub(vstring, 1, #vprefix) == vprefix) and
|
|
||||||
(not string.match(string.sub(vstring, #vprefix + 1), "^%.?%d")) then
|
|
||||||
return string.sub(vstring, #vprefix + 1)
|
|
||||||
else
|
|
||||||
return vstring
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Check if an identified url is sane
|
|
||||||
local function checkforgeurl(url, id, silent)
|
|
||||||
local checkedurl = nil
|
|
||||||
local checkedid = nil
|
|
||||||
local urlpatterns = {
|
|
||||||
gitlab = {
|
|
||||||
pattern = 'https://[^/]+/[^/]+/[^/#?]+',
|
|
||||||
description = 'https://(…[-.])gitlab[-.]…/owner/repo'},
|
|
||||||
pagure = {
|
|
||||||
pattern = 'https://[^/]+/[^/#?]+',
|
|
||||||
description = 'https://pagure.io/repo'},
|
|
||||||
pagure_ns = {
|
|
||||||
pattern = 'https://[^/]+/[^/]+/[^/#?]+',
|
|
||||||
description = 'https://pagure.io/namespace/repo'},
|
|
||||||
pagure_fork = {
|
|
||||||
pattern = 'https://[^/]+/fork/[^/]+/[^/#?]+',
|
|
||||||
description = 'https://pagure.io/fork/owner/repo'},
|
|
||||||
pagure_ns_fork = {
|
|
||||||
pattern = 'https://[^/]+/fork/[^/]+/[^/]+/[^/#?]+',
|
|
||||||
description = 'https://pagure.io/fork/owner/namespace/repo'},
|
|
||||||
["gitea.com"] = {
|
|
||||||
pattern = 'https://[^/]+/[^/]+/[^/#?]+',
|
|
||||||
description = 'https://gitea.com/owner/repo'},
|
|
||||||
github = {
|
|
||||||
pattern = 'https://[^/]+/[^/]+/[^/#?]+',
|
|
||||||
description = 'https://(…[-.])github[-.]…/owner/repo'},
|
|
||||||
["code.googlesource.com"] = {
|
|
||||||
pattern = 'https://code.googlesource.com/[^#?]*[^/#?]+',
|
|
||||||
description = 'https://code.googlesource.com/…/repo'},
|
|
||||||
["bitbucket.org"] = {
|
|
||||||
pattern = 'https://[^/]+/[^/]+/[^/#?]+',
|
|
||||||
description = 'https://bitbucket.org/owner/repo'}}
|
|
||||||
if (urlpatterns[id] ~= nil) then
|
|
||||||
checkedurl = string.match(url,urlpatterns[id]["pattern"])
|
|
||||||
if (checkedurl == nil) then
|
|
||||||
if not silent then
|
|
||||||
rpm.expand("%{error:" .. id .. " URLs must match " .. urlpatterns[id]["description"] .. " !}")
|
|
||||||
end
|
|
||||||
else
|
|
||||||
checkedid = id
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return checkedurl, checkedid
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Check if an url matches a known forge
|
|
||||||
local function idforge(url, silent)
|
|
||||||
local forgeurl = nil
|
|
||||||
local forge = nil
|
|
||||||
if (url ~= "") then
|
|
||||||
forge = string.match(url, "^[^:]+://([^/]+)/")
|
|
||||||
if (forge == nil) then
|
|
||||||
if not silent then
|
|
||||||
rpm.expand("%{error:URLs must include a protocol such as https:// and a path starting with / !}")
|
|
||||||
end
|
|
||||||
else
|
|
||||||
if (forge == "pagure.io") then
|
|
||||||
if string.match(url, "[^:]+://pagure.io/fork/[^/]+/[^/]+/[^/]+") then
|
|
||||||
forge = "pagure_ns_fork"
|
|
||||||
elseif string.match(url, "[^:]+://pagure.io/fork/[^/]+/[^/]+") then
|
|
||||||
forge = "pagure_fork"
|
|
||||||
elseif string.match(url, "[^:]+://pagure.io/[^/]+/[^/]+") then
|
|
||||||
forge = "pagure_ns"
|
|
||||||
elseif string.match(url, "[^:]+://pagure.io/[^/]+") then
|
|
||||||
forge = "pagure"
|
|
||||||
end
|
|
||||||
elseif (string.match(forge, "^gitlab[%.-]") or string.match(forge, "[%.-]gitlab[%.]")) then
|
|
||||||
forge = "gitlab"
|
|
||||||
elseif (string.match(forge, "^github[%.-]") or string.match(forge, "[%.-]github[%.]")) then
|
|
||||||
forge = "github"
|
|
||||||
end
|
|
||||||
forgeurl, forge = checkforgeurl(url, forge, silent)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return forgeurl, forge
|
|
||||||
end
|
|
||||||
|
|
||||||
-- The forgemeta macro main processing function
|
|
||||||
-- See the documentation in the macros.forge file for argument description
|
|
||||||
-- Also called directly by gometa
|
|
||||||
local function meta(suffix, verbose, informative, silent)
|
|
||||||
local fedora = require "fedora.common"
|
|
||||||
local ismain = (suffix == "") or (suffix == "0")
|
|
||||||
if ismain then
|
|
||||||
fedora.zalias({"forgeurl", "forgesource", "forgesetupargs",
|
|
||||||
"archivename", "archiveext", "archiveurl",
|
|
||||||
"topdir", "extractdir", "repo", "owner", "namespace",
|
|
||||||
"scm", "tag", "commit", "shortcommit", "branch", "version",
|
|
||||||
"date", "distprefix"}, verbose)
|
|
||||||
end
|
|
||||||
local variables = {
|
|
||||||
default = {
|
|
||||||
scm = "git",
|
|
||||||
archiveext = "tar.bz2",
|
|
||||||
repo = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "^[^:]+://[^/]+/[^/]+/([^/?#]+)"))}',
|
|
||||||
archivename = "%{repo" .. suffix .. "}-%{ref" .. suffix .. "}",
|
|
||||||
topdir = "%{archivename" .. suffix .. "}" },
|
|
||||||
gitlab = {
|
|
||||||
archiveurl = "%{forgeurl" .. suffix .. "}/-/archive/%{ref" .. suffix .. "}/%{archivename" .. suffix .. "}.%{archiveext" .. suffix .. "}" },
|
|
||||||
pagure = {
|
|
||||||
archiveext = "tar.gz",
|
|
||||||
repo = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "^[^:]+://[^/]+/([^/?#]+)"))}',
|
|
||||||
archiveurl = "%{forgeurl" .. suffix .. "}/archive/%{ref" .. suffix .. "}/%{archivename" .. suffix .. "}.%{archiveext" .. suffix .. "}" },
|
|
||||||
pagure_ns = {
|
|
||||||
archiveext = "tar.gz",
|
|
||||||
namespace = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "^[^:]+://[^/]+/([^/]+)/[^/?#]+"))}',
|
|
||||||
repo = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "^[^:]+://[^/]+/[^/]+/([^/?#]+)"))}',
|
|
||||||
archivename = "%{namespace" .. suffix .. "}-%{repo" .. suffix .. "}-%{ref" .. suffix .. "}",
|
|
||||||
archiveurl = "%{forgeurl" .. suffix .. "}/archive/%{ref" .. suffix .. "}/%{archivename" .. suffix .. "}.%{archiveext" .. suffix .. "}" },
|
|
||||||
pagure_fork = {
|
|
||||||
archiveext = "tar.gz",
|
|
||||||
owner = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "https://[^/]+/fork/([^/]+)/[^/?#]+"))}',
|
|
||||||
repo = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "https://[^/]+/fork/[^/]+/([^/?#]+)"))}',
|
|
||||||
archivename = "%{owner" .. suffix .. "}-%{repo" .. suffix .. "}-%{ref" .. suffix .. "}",
|
|
||||||
archiveurl = "%{forgeurl" .. suffix .. "}/archive/%{ref" .. suffix .. "}/%{archivename" .. suffix .. "}.%{archiveext" .. suffix .. "}" },
|
|
||||||
pagure_ns_fork = {
|
|
||||||
owner = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "https://[^/]+/fork/([^/]+)/[^/]+/[^/?#]+"))}',
|
|
||||||
namespace = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "https://[^/]+/fork/[^/]+/([^/]+)/[^/?#]+")}',
|
|
||||||
repo = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "https://[^/]+/fork/[^/]+/[^/]+/([^/?#]+)")}',
|
|
||||||
archivename = "%{owner" .. suffix .. "}-%{namespace" .. suffix .. "}-%{repo" .. suffix .. "}-%{ref" .. suffix .. "}",
|
|
||||||
archiveurl = "%{forgeurl" .. suffix .. "}/archive/%{ref" .. suffix .. "}/%{archivename" .. suffix .. "}.%{archiveext" .. suffix .. "}" },
|
|
||||||
["gitea.com"] = {
|
|
||||||
archiveext = "tar.gz",
|
|
||||||
archivename = "%{fileref" .. suffix .. "}",
|
|
||||||
archiveurl = "%{forgeurl" .. suffix .. "}/archive/%{ref" .. suffix .. "}.%{archiveext" .. suffix .. "}",
|
|
||||||
topdir = "%{repo}" },
|
|
||||||
github = {
|
|
||||||
archiveext = "tar.gz",
|
|
||||||
archivename = "%{repo" .. suffix .. "}-%{fileref" .. suffix .. "}",
|
|
||||||
archiveurl = "%{forgeurl" .. suffix .. "}/archive/%{ref" .. suffix .. "}/%{archivename" .. suffix .. "}.%{archiveext" .. suffix .. "}" },
|
|
||||||
["code.googlesource.com"] = {
|
|
||||||
archiveext = "tar.gz",
|
|
||||||
repo = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "^[^:]+://.+/([^/?#]+)"))}',
|
|
||||||
archiveurl = "%{forgeurl" .. suffix .. "}/+archive/%{ref" .. suffix .. "}.%{archiveext" .. suffix .. "}",
|
|
||||||
topdir = "" },
|
|
||||||
["bitbucket.org"] = {
|
|
||||||
shortcommit = '%{lua:print(string.sub(rpm.expand("%{commit' .. suffix .. '}"), 1, 12))}',
|
|
||||||
owner = '%{lua:print(string.match(rpm.expand("%{forgeurl' .. suffix .. '}"), "^[^:]+://[^/]+/([^/?#]+)"))}',
|
|
||||||
archivename = "%{owner" .. suffix .. "}-%{repo" .. suffix .. "}-%{shortcommit" .. suffix .. "}",
|
|
||||||
archiveurl = "%{forgeurl" .. suffix .. "}/get/%{ref" .. suffix .. "}.%{archiveext" .. suffix .. "}" } }
|
|
||||||
-- Packaging a moving branch is quite a bad idea, but since at least Gitlab
|
|
||||||
-- will treat branches and tags the same way better support branches explicitly
|
|
||||||
-- than have packagers hijack %{tag} to download branch states
|
|
||||||
local spec = {}
|
|
||||||
for _, v in ipairs({'forgeurl','tag','commit','branch','version'}) do
|
|
||||||
spec[v] = rpm.expand("%{?" .. v .. suffix .. "}")
|
|
||||||
end
|
|
||||||
-- Compute the reference of the object to fetch
|
|
||||||
local isrelease = false
|
|
||||||
if (spec["tag"] ~= "") then ref = "%{?tag" .. suffix .. "}"
|
|
||||||
elseif (spec["commit"] ~= "") then ref = "%{?commit" .. suffix .. "}"
|
|
||||||
elseif (spec["branch"] ~= "") then ref = "%{?branch" .. suffix .. "}"
|
|
||||||
else ref = "%{?version" .. suffix .. "}"
|
|
||||||
isrelease = true
|
|
||||||
end
|
|
||||||
if (rpm.expand(ref) == "") then
|
|
||||||
if (suffix == "") then
|
|
||||||
rpm.expand("%{error:You need to define Version:, %{commit} or %{tag} before the macro invocation !}")
|
|
||||||
else
|
|
||||||
rpm.expand("%{error:You need to define %{version" .. suffix .. "}, %{commit" .. suffix .. "} or %{tag" .. suffix .. "} before the macro invocation !}")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
local forgeurl = spec["forgeurl"]
|
|
||||||
-- For backwards compatibility only
|
|
||||||
local expliciturl = rpm.expand("%{?-u*}")
|
|
||||||
if (expliciturl ~= "") then
|
|
||||||
rpm.expand("%{warn:-u use in %%forgemeta is deprecated, use -z instead to select a separate set of rpm variables!}")
|
|
||||||
forgeurl = expliciturl
|
|
||||||
end
|
|
||||||
local forge
|
|
||||||
forgeurl, forge = idforge(forgeurl, silent)
|
|
||||||
if (forge ~= nil) then
|
|
||||||
fedora.explicitset("forgeurl" .. suffix, forgeurl, verbose)
|
|
||||||
-- Custom processing of quirky forges that can not be handled with simple variables
|
|
||||||
if (forge == "github") then
|
|
||||||
-- Workaround the way GitHub injects "v"s before some version strings (but not all!)
|
|
||||||
-- To package one of the minority of sane GitHub projects that do not munge their version
|
|
||||||
-- strings set tag to %{version} in your spec
|
|
||||||
local fileref = ref
|
|
||||||
if (ref == "%{?version" .. suffix .. "}") then
|
|
||||||
ref = "v" .. ref
|
|
||||||
elseif (fileref ~= "%{?commit" .. suffix .. "}") and
|
|
||||||
string.match(rpm.expand(fileref), "^v[%d]") then
|
|
||||||
fileref = string.gsub(rpm.expand(fileref), "^v", "")
|
|
||||||
elseif (string.match(rpm.expand(fileref), "/")) then
|
|
||||||
fileref = string.gsub(rpm.expand(fileref), "/", "-")
|
|
||||||
end
|
|
||||||
fedora.safeset("fileref" .. suffix, fileref, verbose)
|
|
||||||
elseif (forge == "gitea.com") then
|
|
||||||
-- Workaround the way gitea mangles /s in ref names
|
|
||||||
local fileref = ref
|
|
||||||
fileref = string.gsub(rpm.expand(fileref), "/", "-")
|
|
||||||
fedora.safeset("fileref" .. suffix, fileref, verbose)
|
|
||||||
elseif (forge == "code.googlesource.com") then
|
|
||||||
if (ref == "%{?version" .. suffix .. "}") then
|
|
||||||
ref = "v" .. ref
|
|
||||||
end
|
|
||||||
elseif (forge == "bitbucket.org") then
|
|
||||||
if (spec["commit"] == "") then
|
|
||||||
rpm.expand("%{error:All BitBucket URLs require commit value knowledge: you need to define %{commit}!}")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
fedora.safeset("ref" .. suffix, ref, verbose)
|
|
||||||
-- Mass setting of the remaining variables
|
|
||||||
for k,v in pairs(variables[forge]) do
|
|
||||||
fedora.safeset(k .. suffix, variables[forge][k], verbose)
|
|
||||||
end
|
|
||||||
for k,v in pairs(variables["default"]) do
|
|
||||||
if (variables[forge][k] == nil) then
|
|
||||||
fedora.safeset(k .. suffix, variables["default"][k], verbose)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
-- Generic rules
|
|
||||||
for _, v in ipairs({'archiveurl','archivename','archiveext','topdir'}) do
|
|
||||||
spec[v] = rpm.expand("%{?" .. v .. suffix .. "}")
|
|
||||||
end
|
|
||||||
-- Source URL processing (computing the forgesource spec variable)
|
|
||||||
local forgesource = "%{archiveurl" .. suffix .. "}"
|
|
||||||
if (string.match(spec["archiveurl"], "/([^/]+)$") ~= spec["archivename"] .. "." .. spec["archiveext"]) then
|
|
||||||
forgesource = "%{?archiveurl" .. suffix .. "}#/%{?archivename" .. suffix .. "}.%{archiveext" .. suffix .. "}"
|
|
||||||
end
|
|
||||||
fedora.safeset("forgesource" .. suffix, forgesource, verbose)
|
|
||||||
-- Setup processing (computing the forgesetup and extractdir variables)
|
|
||||||
local forgesetupargs = "-n %{extractdir" .. suffix .. "}"
|
|
||||||
local extractdir = "%{topdir" .. suffix .. "}"
|
|
||||||
if (spec["topdir"] == "") then
|
|
||||||
forgesetupargs = "-c " .. forgesetupargs
|
|
||||||
extractdir = "%{archivename" .. suffix .. "}"
|
|
||||||
end
|
|
||||||
if not ismain then
|
|
||||||
if (spec["topdir"] ~= "") then
|
|
||||||
forgesetupargs = "-T -D -b " .. suffix .. " " .. forgesetupargs
|
|
||||||
else
|
|
||||||
forgesetupargs = "-T -D -a " .. suffix .. " " .. forgesetupargs
|
|
||||||
end
|
|
||||||
end
|
|
||||||
fedora.safeset("forgesetupargs" .. suffix, forgesetupargs, verbose)
|
|
||||||
fedora.safeset("extractdir" .. suffix, extractdir, verbose)
|
|
||||||
-- dist processing (computing the correct prefix for snapshots)
|
|
||||||
local distprefix = ""
|
|
||||||
if not isrelease then
|
|
||||||
distprefix = string.lower(rpm.expand(ref))
|
|
||||||
if (ref == "%{?commit" .. suffix .. "}") then
|
|
||||||
distprefix = string.sub(distprefix, 1, 7)
|
|
||||||
elseif (ref ~= "%{?branch" .. suffix .. "}") then
|
|
||||||
distprefix = string.gsub(distprefix, "[%p%s]+", ".")
|
|
||||||
distprefix = string.gsub(distprefix, "^" .. string.lower(rpm.expand("%{?repo}")) .. "%.?", "")
|
|
||||||
local v = string.gsub(rpm.expand("%{version}"), "[%p%s]+", ".")
|
|
||||||
for _, p in ipairs({'','v','v.','version','version.','tags.v', 'tags.v.'}) do
|
|
||||||
distprefix = getversionsuffix(distprefix, p .. v)
|
|
||||||
end
|
|
||||||
distprefix = string.gsub(distprefix, "^%.", "")
|
|
||||||
end
|
|
||||||
if (distprefix ~= "") then
|
|
||||||
distprefix = "%{scm" .. suffix .. "}" .. distprefix
|
|
||||||
date = rpm.expand("%{?date" .. suffix .. "}")
|
|
||||||
if (date ~= "") then
|
|
||||||
distprefix = date .. distprefix
|
|
||||||
else
|
|
||||||
distprefix = "%([ -r %{_sourcedir}/%{archivename" .. suffix .. "}.%{archiveext" .. suffix .. "} ] && date +%Y%m%d -u -r %{_sourcedir}/%{archivename" .. suffix .. "}.%{archiveext" .. suffix .. "})" .. distprefix
|
|
||||||
end
|
|
||||||
distprefix = "." .. distprefix
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if (spec["version"] ~= "") and
|
|
||||||
(spec["version"] ~= "0") and
|
|
||||||
(spec["version"] ~= rpm.expand("%{?version}")) then
|
|
||||||
distprefix = ".%{version" .. suffix .. "}" .. distprefix
|
|
||||||
end
|
|
||||||
if (rpm.expand(distprefix) ~= "") then
|
|
||||||
if not ismain then
|
|
||||||
distprefix = string.gsub(distprefix, "^%.", ".s")
|
|
||||||
end
|
|
||||||
fedora.safeset ("distprefix" .. suffix, distprefix, verbose)
|
|
||||||
end
|
|
||||||
if ismain then
|
|
||||||
fedora.zalias({"forgeurl", "forgesource", "forgesetupargs",
|
|
||||||
"archivename", "archiveext", "archiveurl",
|
|
||||||
"topdir", "extractdir", "repo", "owner", "namespace",
|
|
||||||
"scm", "shortcommit", "distprefix"}, verbose)
|
|
||||||
end
|
|
||||||
-- Final spec variable summary if the macro was called with -i
|
|
||||||
if informative then
|
|
||||||
rpm.expand("%{echo:Packaging variables read or set by %%forgemeta}")
|
|
||||||
fedora.echovars({"forgeurl", "forgesource", "forgesetupargs",
|
|
||||||
"archivename", "archiveext", "archiveurl",
|
|
||||||
"topdir", "extractdir", "repo", "owner", "namespace",
|
|
||||||
"scm", "tag", "commit", "shortcommit", "branch", "version",
|
|
||||||
"date", "distprefix"}, suffix)
|
|
||||||
fedora.echovars({"dist"},"")
|
|
||||||
rpm.expand("%{echo: (snapshot date is either manually supplied or computed once %%{_sourcedir}/%%{archivename" .. suffix .. "}.%%{archiveext" .. suffix .. "} is available)}")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return {
|
|
||||||
meta = meta,
|
|
||||||
}
|
|
||||||
|
|
2
SOURCES/kabi.attr
Normal file
2
SOURCES/kabi.attr
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
%__kabi_provides %{_rpmconfigdir}/kabi.sh
|
||||||
|
%__kabi_path ^(/boot/symvers-.*|/lib/modules/[1-9].*/symvers)\.gz$
|
13
SOURCES/kabi.sh
Normal file
13
SOURCES/kabi.sh
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/bash +x
|
||||||
|
#
|
||||||
|
# kabi.sh - Automatically extract any kernel symbol checksum from the
|
||||||
|
# symvers file and add to RPM deps. This is used to move the
|
||||||
|
# checksum checking from modprobe to rpm install for 3rd party
|
||||||
|
# modules (so they can fail during install and not at load).
|
||||||
|
|
||||||
|
IFS=$'\n'
|
||||||
|
|
||||||
|
for symvers in $(grep -E '(/boot/symvers-.*|/lib/modules/[1-9].*/symvers)\.gz') "$@";
|
||||||
|
do
|
||||||
|
zcat $symvers | awk ' {print "kernel(" $2 ") = " $1 }'
|
||||||
|
done
|
2
SOURCES/kmod.attr
Normal file
2
SOURCES/kmod.attr
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
%__kmod_provides %{_rpmconfigdir}/kmod.prov
|
||||||
|
%__kmod_path ^/lib/modules/.*$
|
28
SOURCES/kmod.prov
Normal file
28
SOURCES/kmod.prov
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
#!/bin/sh +x
|
||||||
|
# Kernel build can have many thousands of modules.
|
||||||
|
# kmod.prov is run for every one of them.
|
||||||
|
# Try to make this script run as fast as we can.
|
||||||
|
# For example, use shell string ops instead of external programs
|
||||||
|
# where possible.
|
||||||
|
|
||||||
|
IFS=$'\n'
|
||||||
|
|
||||||
|
read -r fname || exit
|
||||||
|
|
||||||
|
# Only process files from .../lib/modules/... subtree
|
||||||
|
[ "${fname#*/lib/modules/*}" != "$fname" ] || exit 0
|
||||||
|
|
||||||
|
kmod=${fname##*/} # like basename, but faster
|
||||||
|
|
||||||
|
if [ "$kmod" = "modules.builtin" ]; then
|
||||||
|
for j in $(cat -- "$fname"); do
|
||||||
|
echo "kmod(${j##*/})"
|
||||||
|
done
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
kmod=${kmod%.gz}
|
||||||
|
kmod=${kmod%.xz}
|
||||||
|
if [ "${kmod%.ko}" != "$kmod" ]; then
|
||||||
|
echo "kmod($kmod)"
|
||||||
|
fi
|
349
SOURCES/kmodtool
Executable file
349
SOURCES/kmodtool
Executable file
@ -0,0 +1,349 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# kmodtool - Helper script for building kernel module RPMs
|
||||||
|
# An original version appeared in Fedora. This version is
|
||||||
|
# generally called only by the %kernel_module_package RPM macro
|
||||||
|
# during the process of building Driver Update Packages (which
|
||||||
|
# are also known as "kmods" in the Fedora community).
|
||||||
|
#
|
||||||
|
# Copyright (c) 2003-2010 Ville Skyttä <ville.skytta@iki.fi>,
|
||||||
|
# Thorsten Leemhuis <fedora@leemhuis.info>
|
||||||
|
# Jon Masters <jcm@redhat.com>
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
# the following conditions:
|
||||||
|
#
|
||||||
|
# The above copyright notice and this permission notice shall be
|
||||||
|
# included in all copies or substantial portions of the Software.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
# Changelog:
|
||||||
|
#
|
||||||
|
# 2010/07/28 - Add fixes for filelists in line with LF standard
|
||||||
|
# - Remove now defunct "framepointer" kernel variant
|
||||||
|
# - Change version to "rhel6-rh2" as a consequence.
|
||||||
|
#
|
||||||
|
# 2010/01/10 - Simplified for RHEL6. We are working on upstream
|
||||||
|
# moving to a newer format and in any case do not
|
||||||
|
# need to retain support for really old systems.
|
||||||
|
|
||||||
|
shopt -s extglob
|
||||||
|
|
||||||
|
myprog="kmodtool"
|
||||||
|
myver="0.10.10_rhel8"
|
||||||
|
knownvariants=@(debug|kdump|zfcpdump)
|
||||||
|
kmod_name=
|
||||||
|
kver=
|
||||||
|
verrel=
|
||||||
|
variant=
|
||||||
|
|
||||||
|
get_verrel ()
|
||||||
|
{
|
||||||
|
verrel=${1:-$(uname -r)}
|
||||||
|
verrel=${verrel/%[.+]$knownvariants/}
|
||||||
|
}
|
||||||
|
|
||||||
|
print_verrel ()
|
||||||
|
{
|
||||||
|
get_verrel "$@"
|
||||||
|
echo "${verrel}"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_variant ()
|
||||||
|
{
|
||||||
|
get_verrel "$@"
|
||||||
|
variant=${1:-$(uname -r)}
|
||||||
|
variant=${variant/#$verrel?(.+)/}
|
||||||
|
variant=${variant:-'""'}
|
||||||
|
}
|
||||||
|
|
||||||
|
print_variant ()
|
||||||
|
{
|
||||||
|
get_variant $@
|
||||||
|
echo "${variant}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Detect flavor separator character. We have to do that due to
|
||||||
|
# a systemd-tailored patch for kernel spec[1][2] introduced in Fedora and then
|
||||||
|
# imported in RHEL 8 that broke all OOT kmod infrastructure for the flavored
|
||||||
|
# kernels.
|
||||||
|
#
|
||||||
|
# [1] https://lists.fedoraproject.org/pipermail/kernel/2013-June/004262.html
|
||||||
|
# [2] https://src.fedoraproject.org/rpms/kernel/c/faf25207dc86666a611c45ae3ffaf385c170bd2a
|
||||||
|
#
|
||||||
|
# $1 - kver
|
||||||
|
# $2 - variant
|
||||||
|
get_variant_char ()
|
||||||
|
{
|
||||||
|
variant="$2"
|
||||||
|
[ "$variant" != "default" ] || variant=""
|
||||||
|
|
||||||
|
get_verrel "$1"
|
||||||
|
|
||||||
|
variant_char=""
|
||||||
|
[ -n "$variant" ] || return 0
|
||||||
|
|
||||||
|
# We expect that the flavored kernel is already installed in the buildroot
|
||||||
|
variant_char="+"
|
||||||
|
[ -e "/usr/src/kernels/${verrel}+${variant}" ] && return 0
|
||||||
|
|
||||||
|
variant_char="."
|
||||||
|
}
|
||||||
|
|
||||||
|
print_variant_char ()
|
||||||
|
{
|
||||||
|
get_variant_char "$@"
|
||||||
|
echo "${variant_char}"
|
||||||
|
}
|
||||||
|
|
||||||
|
print_kernel_source ()
|
||||||
|
{
|
||||||
|
get_variant_char "$@"
|
||||||
|
echo "/usr/src/kernels/${verrel}${variant_char}${variant}"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_filelist() {
|
||||||
|
local IFS=$'\n'
|
||||||
|
filelist=($(cat))
|
||||||
|
|
||||||
|
if [ ${#filelist[@]} -gt 0 ];
|
||||||
|
then
|
||||||
|
for ((n = 0; n < ${#filelist[@]}; n++));
|
||||||
|
do
|
||||||
|
line="${filelist[n]}"
|
||||||
|
line=$(echo "$line" \
|
||||||
|
| sed -e "s/%verrel/$verrel/g" \
|
||||||
|
| sed -e "s/%variant/$variant/g" \
|
||||||
|
| sed -e "s/%dashvariant/$dashvariant/g" \
|
||||||
|
| sed -e "s/%dotvariant/$dotvariant/g" \
|
||||||
|
| sed -e "s/\+%1/$dotvariant/g" \
|
||||||
|
| sed -e "s/\.%1/$dotvariant/g" \
|
||||||
|
| sed -e "s/\-%1/$dotvariant/g" \
|
||||||
|
| sed -e "s/%2/$verrel/g")
|
||||||
|
echo "$line"
|
||||||
|
done
|
||||||
|
else
|
||||||
|
echo "%defattr(644,root,root,755)"
|
||||||
|
echo "/lib/modules/${verrel}${dotvariant}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
get_rpmtemplate ()
|
||||||
|
{
|
||||||
|
local variant="${1}"
|
||||||
|
|
||||||
|
get_variant_char "${verrel}" "${variant}"
|
||||||
|
|
||||||
|
local dashvariant="${variant:+-${variant}}"
|
||||||
|
local dotvariant="${variant:+${variant_char}${variant}}"
|
||||||
|
|
||||||
|
echo "%package -n kmod-${kmod_name}${dashvariant}"
|
||||||
|
|
||||||
|
if [ -z "$kmod_provides_summary" ]; then
|
||||||
|
echo "Summary: ${kmod_name} kernel module(s)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$kmod_provides_group" ]; then
|
||||||
|
echo "Group: System Environment/Kernel"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -z "$kmod_version" ]; then
|
||||||
|
echo "Version: %{kmod_version}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -z "$kmod_release" ]; then
|
||||||
|
echo "Release: %{kmod_release}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Turn of the internal dep generator so we will use the kmod scripts.
|
||||||
|
echo "%global _use_internal_dependency_generator 0"
|
||||||
|
|
||||||
|
cat <<EOF
|
||||||
|
Provides: kernel-modules >= ${verrel}${dotvariant}
|
||||||
|
Provides: kernel${dashvariant}-modules >= ${verrel}
|
||||||
|
Provides: ${kmod_name}-kmod = %{?epoch:%{epoch}:}%{version}-%{release}
|
||||||
|
Requires(post): /usr/sbin/depmod
|
||||||
|
Requires(postun): /usr/sbin/depmod
|
||||||
|
Requires(post): /usr/sbin/weak-modules
|
||||||
|
Requires(postun): /usr/sbin/weak-modules
|
||||||
|
EOF
|
||||||
|
|
||||||
|
if [ "yes" != "$nobuildreqs" ]
|
||||||
|
then
|
||||||
|
cat <<EOF
|
||||||
|
BuildRequires: kernel${dashvariant}-devel
|
||||||
|
BuildRequires: kernel-abi-whitelists
|
||||||
|
BuildRequires: redhat-rpm-config kernel-rpm-macros
|
||||||
|
BuildRequires: elfutils-libelf-devel kmod
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "" != "$override_preamble" ]
|
||||||
|
then
|
||||||
|
cat "$override_preamble"
|
||||||
|
fi
|
||||||
|
|
||||||
|
cat <<EOF
|
||||||
|
%description -n kmod-${kmod_name}${dashvariant}
|
||||||
|
This package provides the ${kmod_name} kernel modules built for
|
||||||
|
the Linux kernel ${verrel}${dotvariant} for the %{_target_cpu}
|
||||||
|
family of processors.
|
||||||
|
EOF
|
||||||
|
|
||||||
|
##############################################################################
|
||||||
|
## The following are not part of this script directly, they are scripts ##
|
||||||
|
## that will be executed by RPM during various stages of package processing ##
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
cat <<EOF
|
||||||
|
%post -n kmod-${kmod_name}${dashvariant}
|
||||||
|
if [ -e "/boot/System.map-${verrel}${dotvariant}" ]; then
|
||||||
|
/usr/sbin/depmod -aeF "/boot/System.map-${verrel}${dotvariant}" "${verrel}${dotvariant}" > /dev/null || :
|
||||||
|
fi
|
||||||
|
|
||||||
|
modules=( \$(find /lib/modules/${verrel}${dotvariant}/extra/${kmod_name} | grep '\.ko$') )
|
||||||
|
if [ -x "/usr/sbin/weak-modules" ]; then
|
||||||
|
printf '%s\n' "\${modules[@]}" \
|
||||||
|
| /usr/sbin/weak-modules --add-modules
|
||||||
|
fi
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat <<EOF
|
||||||
|
%preun -n kmod-${kmod_name}${dashvariant}
|
||||||
|
rpm -ql kmod-${kmod_name}${dashvariant}-%{kmod_version}-%{kmod_release}.$(arch) | grep '\.ko$' > /var/run/rpm-kmod-${kmod_name}${dashvariant}-modules
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat <<EOF
|
||||||
|
%postun -n kmod-${kmod_name}${dashvariant}
|
||||||
|
if [ -e "/boot/System.map-${verrel}${dotvariant}" ]; then
|
||||||
|
/usr/sbin/depmod -aeF "/boot/System.map-${verrel}${dotvariant}" "${verrel}${dotvariant}" > /dev/null || :
|
||||||
|
fi
|
||||||
|
|
||||||
|
modules=( \$(cat /var/run/rpm-kmod-${kmod_name}${dashvariant}-modules) )
|
||||||
|
rm /var/run/rpm-kmod-${kmod_name}${dashvariant}-modules
|
||||||
|
if [ -x "/usr/sbin/weak-modules" ]; then
|
||||||
|
printf '%s\n' "\${modules[@]}" \
|
||||||
|
| /usr/sbin/weak-modules --remove-modules
|
||||||
|
fi
|
||||||
|
EOF
|
||||||
|
|
||||||
|
echo "%files -n kmod-${kmod_name}${dashvariant}"
|
||||||
|
|
||||||
|
if [ "" == "$override_filelist" ];
|
||||||
|
then
|
||||||
|
echo "%defattr(644,root,root,755)"
|
||||||
|
echo "/lib/modules/${verrel}${dotvariant}"
|
||||||
|
else
|
||||||
|
cat "$override_filelist" | get_filelist
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
print_rpmtemplate ()
|
||||||
|
{
|
||||||
|
kmod_name="${1}"
|
||||||
|
shift
|
||||||
|
kver="${1}"
|
||||||
|
get_verrel "${1}"
|
||||||
|
shift
|
||||||
|
if [ -z "${kmod_name}" ] ; then
|
||||||
|
echo "Please provide the kmodule-name as first parameter." >&2
|
||||||
|
exit 2
|
||||||
|
elif [ -z "${kver}" ] ; then
|
||||||
|
echo "Please provide the kver as second parameter." >&2
|
||||||
|
exit 2
|
||||||
|
elif [ -z "${verrel}" ] ; then
|
||||||
|
echo "Couldn't find out the verrel." >&2
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
for variant in "$@" ; do
|
||||||
|
if [ "default" == "$variant" ];
|
||||||
|
then
|
||||||
|
get_rpmtemplate ""
|
||||||
|
else
|
||||||
|
get_rpmtemplate "${variant}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
usage ()
|
||||||
|
{
|
||||||
|
cat <<EOF
|
||||||
|
You called: ${invocation}
|
||||||
|
|
||||||
|
Usage: ${myprog} <command> <option>+
|
||||||
|
Commands:
|
||||||
|
verrel <uname>
|
||||||
|
- Get "base" version-release.
|
||||||
|
variant <uname>
|
||||||
|
- Get variant from uname.
|
||||||
|
variant_char <uname> <variant>
|
||||||
|
- Get kernel variant separator character.
|
||||||
|
kernel_source <uname> <variant>
|
||||||
|
- Get path to kernel source directory.
|
||||||
|
rpmtemplate <mainpgkname> <uname> <variants>
|
||||||
|
- Return a template for use in a source RPM
|
||||||
|
version
|
||||||
|
- Output version number and exit.
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
invocation="$(basename ${0}) $@"
|
||||||
|
while [ "${1}" ] ; do
|
||||||
|
case "${1}" in
|
||||||
|
verrel)
|
||||||
|
shift
|
||||||
|
print_verrel "$@"
|
||||||
|
exit $?
|
||||||
|
;;
|
||||||
|
variant)
|
||||||
|
shift
|
||||||
|
print_variant "$@"
|
||||||
|
exit $?
|
||||||
|
;;
|
||||||
|
variant_char)
|
||||||
|
shift
|
||||||
|
print_variant_char "$@"
|
||||||
|
exit $?
|
||||||
|
;;
|
||||||
|
kernel_source)
|
||||||
|
shift
|
||||||
|
print_kernel_source "$@"
|
||||||
|
exit $?
|
||||||
|
;;
|
||||||
|
rpmtemplate)
|
||||||
|
shift
|
||||||
|
print_rpmtemplate "$@"
|
||||||
|
exit $?
|
||||||
|
;;
|
||||||
|
version)
|
||||||
|
echo "${myprog} ${myver}"
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Error: Unknown option '${1}'." >&2
|
||||||
|
usage >&2
|
||||||
|
exit 2
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
# Local variables:
|
||||||
|
# mode: sh
|
||||||
|
# sh-indentation: 2
|
||||||
|
# indent-tabs-mode: nil
|
||||||
|
# End:
|
||||||
|
# ex: ts=2 sw=2 et
|
168
SOURCES/macros
168
SOURCES/macros
@ -18,31 +18,12 @@
|
|||||||
|
|
||||||
%_fmoddir %{_libdir}/gfortran/modules
|
%_fmoddir %{_libdir}/gfortran/modules
|
||||||
|
|
||||||
%source_date_epoch_from_changelog 1
|
|
||||||
|
|
||||||
%_enable_debug_packages 1
|
%_enable_debug_packages 1
|
||||||
%_include_minidebuginfo 1
|
%_include_minidebuginfo 1
|
||||||
%_include_gdb_index 1
|
%_include_gdb_index 1
|
||||||
%_debugsource_packages 1
|
%_debugsource_packages 1
|
||||||
%_debuginfo_subpackages 1
|
%_debuginfo_subpackages 1
|
||||||
|
|
||||||
# GCC toolchain
|
|
||||||
%__cc_gcc gcc
|
|
||||||
%__cxx_gcc g++
|
|
||||||
%__cpp_gcc gcc -E
|
|
||||||
|
|
||||||
# Clang toolchain
|
|
||||||
%__cc_clang clang
|
|
||||||
%__cxx_clang clang++
|
|
||||||
%__cpp_clang clang-cpp
|
|
||||||
|
|
||||||
# Default to the GCC toolchain
|
|
||||||
%toolchain gcc
|
|
||||||
|
|
||||||
%__cc %{expand:%%{__cc_%{toolchain}}}
|
|
||||||
%__cxx %{expand:%%{__cxx_%{toolchain}}}
|
|
||||||
%__cpp %{expand:%%{__cpp_%{toolchain}}}
|
|
||||||
|
|
||||||
#==============================================================================
|
#==============================================================================
|
||||||
# ---- compiler flags.
|
# ---- compiler flags.
|
||||||
|
|
||||||
@ -63,34 +44,25 @@
|
|||||||
# the flags, while intended for ld, are still passed through the gcc
|
# the flags, while intended for ld, are still passed through the gcc
|
||||||
# compiler driver. At the beginning of %%build, the environment
|
# compiler driver. At the beginning of %%build, the environment
|
||||||
# variable RPM_LD_FLAGS to this value.
|
# variable RPM_LD_FLAGS to this value.
|
||||||
# When clang is used as a linker driver, it does not auto-detect the LTO
|
%build_ldflags -Wl,-z,relro %{_ld_symbols_flags} %{_hardened_ldflags}
|
||||||
# bytecode and neither does bfd, so we need to explicitly pass the -flto
|
|
||||||
# flag when linking.
|
|
||||||
%build_ldflags -Wl,-z,relro %{_ld_as_needed_flags} %{_ld_symbols_flags} %{_hardened_ldflags} %{_annotation_ldflags} %[ "%{toolchain}" == "clang" ? "%{?_lto_cflags}" : "" ]
|
|
||||||
|
|
||||||
# Expands to shell code to set the compiler/linker environment
|
# Expands to shell code to seot the compiler/linker environment
|
||||||
# variables CFLAGS, CXXFLAGS, FFLAGS, FCFLAGS, LDFLAGS if they have
|
# variables CFLAGS, CXXFLAGS, FFLAGS, FCFLAGS, LDFLAGS if they have
|
||||||
# not been set already. RPM_OPT_FLAGS and RPM_LD_FLAGS have already
|
# not been set already. RPM_OPT_FLAGS and RPM_LD_FLAGS have already
|
||||||
# been set implicitly at the start of the %%build section.
|
# been set implicitly at the start of the %%build section.
|
||||||
# LT_SYS_LIBRARY_PATH is used by libtool script.
|
|
||||||
%set_build_flags \
|
%set_build_flags \
|
||||||
CFLAGS="${CFLAGS:-%{build_cflags}}" ; export CFLAGS ; \
|
CFLAGS="${CFLAGS:-%{build_cflags}}" ; export CFLAGS ; \
|
||||||
CXXFLAGS="${CXXFLAGS:-%{build_cxxflags}}" ; export CXXFLAGS ; \
|
CXXFLAGS="${CXXFLAGS:-%{build_cxxflags}}" ; export CXXFLAGS ; \
|
||||||
FFLAGS="${FFLAGS:-%{build_fflags}}" ; export FFLAGS ; \
|
FFLAGS="${FFLAGS:-%{build_fflags}}" ; export FFLAGS ; \
|
||||||
FCFLAGS="${FCFLAGS:-%{build_fflags}}" ; export FCFLAGS ; \
|
FCFLAGS="${FCFLAGS:-%{build_fflags}}" ; export FCFLAGS ; \
|
||||||
LDFLAGS="${LDFLAGS:-%{build_ldflags}}" ; export LDFLAGS ; \
|
LDFLAGS="${LDFLAGS:-%{build_ldflags}}" ; export LDFLAGS
|
||||||
LT_SYS_LIBRARY_PATH="${LT_SYS_LIBRARY_PATH:-%_libdir:}" ; export LT_SYS_LIBRARY_PATH ; \
|
|
||||||
CC="${CC:-%{__cc}}" ; export CC ; \
|
|
||||||
CXX="${CXX:-%{__cxx}}" ; export CXX
|
|
||||||
|
|
||||||
# Internal-only. Do not use. Expand a variable and strip the flags
|
# Internal-only. Do not use. Expand a variable and strip the flags
|
||||||
# not suitable to extension builders.
|
# not suitable to extension builders.
|
||||||
%__extension_strip_flags() %{lua:
|
%__extension_strip_flags() %{lua:
|
||||||
local name = rpm.expand("%{1}")
|
local name = rpm.expand("%{1}")
|
||||||
local value = " " .. rpm.expand("%{build_" .. name .. "}")
|
local value = " " .. rpm.expand("%{build_" .. name .. "}")
|
||||||
local specs_pattern = "%s+-specs=[^%s]+"
|
local result = string.gsub(value, "%s+-specs=[^%s]+", " ")
|
||||||
local lto_flags_pattern = rpm.expand("%{?_lto_cflags}"):gsub("[%-%.]", "%%%1")
|
|
||||||
local result = value:gsub(specs_pattern, " "):gsub(lto_flags_pattern, "")
|
|
||||||
print(result)
|
print(result)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,16 +80,6 @@ print(result)
|
|||||||
%__global_fcflags %{build_fflags}
|
%__global_fcflags %{build_fflags}
|
||||||
%__global_ldflags %{build_ldflags}
|
%__global_ldflags %{build_ldflags}
|
||||||
|
|
||||||
# Architecture-specific support. Internal. Do not use directly.
|
|
||||||
|
|
||||||
%__cflags_arch_x86_64 %[0%{?rhel} >= 9 ? "-march=x86-64-v2" : ""]
|
|
||||||
|
|
||||||
# Also used for s390.
|
|
||||||
%__cflags_arch_s390x %[0%{?rhel} >= 9 ? "-march=z14 -mtune=z15" : "-march=zEC12 -mtune=z13"]
|
|
||||||
|
|
||||||
# Also used for ppc64le.
|
|
||||||
%__cflags_arch_ppc64le %[0%{?rhel} >= 9 ? "-mcpu=power9 -mtune=power9" : "-mcpu=power8 -mtune=power8"]
|
|
||||||
|
|
||||||
#==============================================================================
|
#==============================================================================
|
||||||
# ---- configure and makeinstall.
|
# ---- configure and makeinstall.
|
||||||
#
|
#
|
||||||
@ -128,49 +90,8 @@ print(result)
|
|||||||
# Eventually we'll want to turn this on by default, but this gives packagers a
|
# Eventually we'll want to turn this on by default, but this gives packagers a
|
||||||
# way to turn it back off.
|
# way to turn it back off.
|
||||||
# %_configure_disable_silent_rules 1
|
# %_configure_disable_silent_rules 1
|
||||||
|
|
||||||
# This fixes various easy resolved configure tests that are compromised by LTO.
|
|
||||||
#
|
|
||||||
# We use this within the standard %configure macro, but also make it available
|
|
||||||
# for packages which don't use %configure
|
|
||||||
#
|
|
||||||
# The first three are common ways to test for the existence of a function, so
|
|
||||||
# we ensure the reference to the function is preserved
|
|
||||||
#
|
|
||||||
# The fourth are constants used to then try to generate NaNs and other key
|
|
||||||
# floating point numbers. We then use those special FP numbers to try and
|
|
||||||
# raise a SIGFPE. By declaring x & y volatile we prevent the optimizers
|
|
||||||
# from removing the computation
|
|
||||||
#
|
|
||||||
# The fifth (and worst) addresses problems with autoconf/libtool's approach
|
|
||||||
# to extracting symbols from .o files and generating C code. In an LTO world
|
|
||||||
# types matter much more closely and you can't have an object in one context
|
|
||||||
# that is a function definition and a simple scalar variable in another.
|
|
||||||
# Thankfully HP-UX has always had that restriction and is supported by
|
|
||||||
# autoconf/libtool. The insane sed script replaces the "generic" code with
|
|
||||||
# the HP-UX version.
|
|
||||||
#
|
|
||||||
# If we do not make changes, we put the original file back. This avoids
|
|
||||||
# unnecessary rebuilds of things that may have dependencies on the configure
|
|
||||||
# files.
|
|
||||||
#
|
|
||||||
%_fix_broken_configure_for_lto \
|
|
||||||
for file in $(find . -type f -name configure -print); do \
|
|
||||||
%{__sed} -r --in-place=.backup 's/^char \\(\\*f\\) \\(\\) = /__attribute__ ((used)) char (*f) () = /g' $file; \
|
|
||||||
diff -u $file.backup $file && mv $file.backup $file \
|
|
||||||
%{__sed} -r --in-place=.backup 's/^char \\(\\*f\\) \\(\\);/__attribute__ ((used)) char (*f) ();/g' $file; \
|
|
||||||
diff -u $file.backup $file && mv $file.backup $file \
|
|
||||||
%{__sed} -r --in-place=.backup 's/^char \\$2 \\(\\);/__attribute__ ((used)) char \\$2 ();/g' $file; \
|
|
||||||
diff -u $file.backup $file && mv $file.backup $file \
|
|
||||||
%{__sed} --in-place=.backup '1{$!N;$!N};$!N;s/int x = 1;\\nint y = 0;\\nint z;\\nint nan;/volatile int x = 1; volatile int y = 0; volatile int z, nan;/;P;D' $file; \
|
|
||||||
diff -u $file.backup $file && mv $file.backup $file \
|
|
||||||
%{__sed} --in-place=.backup 's#^lt_cv_sys_global_symbol_to_cdecl=.*#lt_cv_sys_global_symbol_to_cdecl="sed -n -e '"'"'s/^T .* \\\\(.*\\\\)$/extern int \\\\1();/p'"'"' -e '"'"'s/^$symcode* .* \\\\(.*\\\\)$/extern char \\\\1;/p'"'"'"#' $file; \
|
|
||||||
diff -u $file.backup $file && mv $file.backup $file \
|
|
||||||
done
|
|
||||||
|
|
||||||
%configure \
|
%configure \
|
||||||
%{set_build_flags}; \
|
%{set_build_flags}; \
|
||||||
[ "%{_lto_cflags}"x != x ] && %{_fix_broken_configure_for_lto}; \
|
|
||||||
[ "%_configure_gnuconfig_hack" = 1 ] && for i in $(find $(dirname %{_configure}) -name config.guess -o -name config.sub) ; do \
|
[ "%_configure_gnuconfig_hack" = 1 ] && for i in $(find $(dirname %{_configure}) -name config.guess -o -name config.sub) ; do \
|
||||||
[ -f /usr/lib/rpm/redhat/$(basename $i) ] && %{__rm} -f $i && %{__cp} -fv /usr/lib/rpm/redhat/$(basename $i) $i ; \
|
[ -f /usr/lib/rpm/redhat/$(basename $i) ] && %{__rm} -f $i && %{__cp} -fv /usr/lib/rpm/redhat/$(basename $i) $i ; \
|
||||||
done ; \
|
done ; \
|
||||||
@ -196,6 +117,19 @@ print(result)
|
|||||||
--mandir=%{_mandir} \\\
|
--mandir=%{_mandir} \\\
|
||||||
--infodir=%{_infodir}
|
--infodir=%{_infodir}
|
||||||
|
|
||||||
|
# Maximum number of CPU's to use when building, 0 for unlimited.
|
||||||
|
#
|
||||||
|
# This was for some time capped at 16. Please see
|
||||||
|
# https://bugzilla.redhat.com/show_bug.cgi?id=669638 and
|
||||||
|
# https://bugzilla.redhat.com/show_bug.cgi?id=1384938 for the situation
|
||||||
|
# surrounding this.
|
||||||
|
#%_smp_ncpus_max 0
|
||||||
|
%_smp_mflags %([ -z "$RPM_BUILD_NCPUS" ] \\\
|
||||||
|
&& RPM_BUILD_NCPUS="`/usr/bin/getconf _NPROCESSORS_ONLN`"; \\\
|
||||||
|
ncpus_max=%{?_smp_ncpus_max}; \\\
|
||||||
|
if [ -n "$ncpus_max" ] && [ "$ncpus_max" -gt 0 ] && [ "$RPM_BUILD_NCPUS" -gt "$ncpus_max" ]; then RPM_BUILD_NCPUS="$ncpus_max"; fi; \\\
|
||||||
|
if [ "$RPM_BUILD_NCPUS" -gt 1 ]; then echo "-j$RPM_BUILD_NCPUS"; fi)
|
||||||
|
|
||||||
#==============================================================================
|
#==============================================================================
|
||||||
# ---- Build policy macros.
|
# ---- Build policy macros.
|
||||||
#
|
#
|
||||||
@ -221,17 +155,15 @@ print(result)
|
|||||||
%__brp_ldconfig /usr/lib/rpm/redhat/brp-ldconfig
|
%__brp_ldconfig /usr/lib/rpm/redhat/brp-ldconfig
|
||||||
%__brp_compress /usr/lib/rpm/brp-compress
|
%__brp_compress /usr/lib/rpm/brp-compress
|
||||||
%__brp_strip /usr/lib/rpm/brp-strip %{__strip}
|
%__brp_strip /usr/lib/rpm/brp-strip %{__strip}
|
||||||
%__brp_strip_lto /usr/lib/rpm/redhat/brp-strip-lto %{__strip}
|
|
||||||
%__brp_strip_comment_note /usr/lib/rpm/brp-strip-comment-note %{__strip} %{__objdump}
|
%__brp_strip_comment_note /usr/lib/rpm/brp-strip-comment-note %{__strip} %{__objdump}
|
||||||
%__brp_strip_static_archive /usr/lib/rpm/brp-strip-static-archive %{__strip}
|
%__brp_strip_static_archive /usr/lib/rpm/brp-strip-static-archive %{__strip}
|
||||||
%__brp_python_bytecompile /usr/lib/rpm/redhat/brp-python-bytecompile "" "%{?_python_bytecompile_errors_terminate_build}" "%{?_python_bytecompile_extra}"
|
%__brp_python_bytecompile /usr/lib/rpm/brp-python-bytecompile "" %{?_python_bytecompile_errors_terminate_build}
|
||||||
%__brp_fix_pyc_reproducibility /usr/lib/rpm/redhat/brp-fix-pyc-reproducibility
|
|
||||||
%__brp_python_hardlink /usr/lib/rpm/brp-python-hardlink
|
%__brp_python_hardlink /usr/lib/rpm/brp-python-hardlink
|
||||||
# __brp_mangle_shebangs_exclude - shebangs to exclude
|
# __brp_mangle_shebangs_exclude - shebangs to exclude
|
||||||
# __brp_mangle_shebangs_exclude_file - file from which to get shebangs to exclude
|
# __brp_mangle_shebangs_exclude_file - file from which to get shebangs to exclude
|
||||||
# __brp_mangle_shebangs_exclude_from - files to ignore
|
# __brp_mangle_shebangs_exclude_from - files to ignore
|
||||||
# __brp_mangle_shebangs_exclude_from_file - file from which to get files to ignore
|
# __brp_mangle_shebangs_exclude_from_file - file from which to get files to ignore
|
||||||
%__brp_mangle_shebangs /usr/lib/rpm/redhat/brp-mangle-shebangs %{?__brp_mangle_shebangs_exclude:--shebangs "%{?__brp_mangle_shebangs_exclude}"} %{?__brp_mangle_shebangs_exclude_file:--shebangs-from "%{__brp_mangle_shebangs_exclude_file}"} %{?__brp_mangle_shebangs_exclude_from:--files "%{?__brp_mangle_shebangs_exclude_from}"} %{?__brp_mangle_shebangs_exclude_from_file:--files-from "%{__brp_mangle_shebangs_exclude_from_file}"}
|
%__brp_mangle_shebangs PYTHON3="%{__python3}" /usr/lib/rpm/redhat/brp-mangle-shebangs %{?__brp_mangle_shebangs_exclude:--shebangs "%{?__brp_mangle_shebangs_exclude}"} %{?__brp_mangle_shebangs_exclude_file:--shebangs-from "%{__brp_mangle_shebangs_exclude_file}"} %{?__brp_mangle_shebangs_exclude_from:--files "%{?__brp_mangle_shebangs_exclude_from}"} %{?__brp_mangle_shebangs_exclude_from_file:--files-from "%{__brp_mangle_shebangs_exclude_from_file}"}
|
||||||
|
|
||||||
%__os_install_post \
|
%__os_install_post \
|
||||||
%{?__brp_ldconfig} \
|
%{?__brp_ldconfig} \
|
||||||
@ -240,10 +172,8 @@ print(result)
|
|||||||
%{?__brp_strip} \
|
%{?__brp_strip} \
|
||||||
%{?__brp_strip_comment_note} \
|
%{?__brp_strip_comment_note} \
|
||||||
} \
|
} \
|
||||||
%{?__brp_strip_lto} \
|
|
||||||
%{?__brp_strip_static_archive} \
|
%{?__brp_strip_static_archive} \
|
||||||
%{?py_auto_byte_compile:%{?__brp_python_bytecompile}} \
|
%{?py_auto_byte_compile:%{?__brp_python_bytecompile}} \
|
||||||
%{?py_reproducible_pyc_path:%{?__brp_fix_pyc_reproducibility} "%{py_reproducible_pyc_path}"} \
|
|
||||||
%{?__brp_python_hardlink} \
|
%{?__brp_python_hardlink} \
|
||||||
%{?__brp_mangle_shebangs} \
|
%{?__brp_mangle_shebangs} \
|
||||||
%{nil}
|
%{nil}
|
||||||
@ -269,74 +199,40 @@ print(result)
|
|||||||
#
|
#
|
||||||
## Should python bytecompilation errors terminate a build?
|
## Should python bytecompilation errors terminate a build?
|
||||||
%_python_bytecompile_errors_terminate_build 1
|
%_python_bytecompile_errors_terminate_build 1
|
||||||
## Should python bytecompilation compile outisde python specific directories?
|
|
||||||
%_python_bytecompile_extra 0
|
|
||||||
|
|
||||||
# Use SHA-256 for FILEDIGESTS instead of default MD5
|
# Use SHA-256 for FILEDIGESTS instead of default MD5
|
||||||
%_source_filedigest_algorithm 8
|
%_source_filedigest_algorithm 8
|
||||||
%_binary_filedigest_algorithm 8
|
%_binary_filedigest_algorithm 8
|
||||||
|
|
||||||
# Use Zstandard compression for binary payloads
|
# Use XZ compression for binary payloads
|
||||||
%_binary_payload w19.zstdio
|
%_binary_payload w2.xzdio
|
||||||
|
|
||||||
%_hardening_gcc_cflags -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1
|
%_hardening_cflags -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1
|
||||||
%_hardening_clang_cflags --config /usr/lib/rpm/redhat/redhat-hardened-clang.cfg
|
|
||||||
%_hardening_cflags %{expand:%%{_hardening_%{toolchain}_cflags}} -fstack-protector-strong
|
|
||||||
# we don't escape symbols '~', '"', etc. so be careful when changing this
|
# we don't escape symbols '~', '"', etc. so be careful when changing this
|
||||||
%_hardening_ldflags -Wl,-z,now %[ "%{toolchain}" == "gcc" ? "-specs=/usr/lib/rpm/redhat/redhat-hardened-ld" : "" ]
|
%_hardening_ldflags -Wl,-z,now -specs=/usr/lib/rpm/redhat/redhat-hardened-ld
|
||||||
|
|
||||||
# Harden packages by default for Fedora 23+:
|
# Harden packages by default for Fedora 23:
|
||||||
# https://fedorahosted.org/fesco/ticket/1384 (accepted on 2014-02-11)
|
# https://fedorahosted.org/fesco/ticket/1384 (accepted on 2014-02-11)
|
||||||
# Use "%undefine _hardened_build" to disable.
|
# Use "%undefine _hardened_build" to disable.
|
||||||
%_hardened_build 1
|
%_hardened_build 1
|
||||||
%_hardened_cflags %{?_hardened_build:%{_hardening_cflags}}
|
%_hardened_cflags %{?_hardened_build:%{_hardening_cflags}}
|
||||||
%_hardened_ldflags %{?_hardened_build:%{_hardening_ldflags}}
|
%_hardened_ldflags %{?_hardened_build:%{_hardening_ldflags}}
|
||||||
|
|
||||||
# Add extra information to binary objects created by the compiler:
|
%_annobin_cflags -specs=/usr/lib/rpm/redhat/redhat-annobin-cc1
|
||||||
|
|
||||||
|
# Add extra information to binary objects created by gcc for Fedora 28:
|
||||||
# https://pagure.io/fesco/issue/1780 (accepted on 2017-10-30)
|
# https://pagure.io/fesco/issue/1780 (accepted on 2017-10-30)
|
||||||
# Use "%undefine _annotated_build" to disable.
|
# Use "%undefine _annotated_build" to disable.
|
||||||
%_annotated_build 1
|
%_annotated_build 1
|
||||||
%_annobin_gcc_plugin -specs=/usr/lib/rpm/redhat/redhat-annobin-cc1
|
%_annotated_cflags %{?_annotated_build:%{_annobin_cflags}}
|
||||||
# The annobin plugin is not built for clang yet
|
|
||||||
%_annobin_clang_plugin %dnl-fplugin=/usr/lib64/clang/`clang -dumpversion`/lib/annobin.so
|
|
||||||
%_annotation_cflags %{?_annotated_build:%{expand:%%{_annobin_%{toolchain}_plugin}}}
|
|
||||||
%_annotation_ldflags %{?_lto_cflags:%{_annotation_cflags}}
|
|
||||||
|
|
||||||
# Fail linking if there are undefined symbols. Required for proper
|
# Fail linking if there are undefined symbols. Required for proper
|
||||||
# ELF symbol versioning support. Disabled by default.
|
# ELF symbol versioning support. Disabled by default.
|
||||||
# Use "%define _ld_strict_symbol_defs 1" to enable.
|
# Use "%define _strict_symbol_defs_build 1" to enable.
|
||||||
#%_ld_strict_symbol_defs 1
|
#%_strict_symbol_defs_build 1
|
||||||
%_ld_symbols_flags %{?_ld_strict_symbol_defs:-Wl,-z,defs}
|
%_ld_symbols_flags %{?_strict_symbol_defs_build:-Wl,-z,defs}
|
||||||
|
|
||||||
# https://fedoraproject.org/wiki/Changes/RemoveExcessiveLinking
|
%__global_compiler_flags -O2 -g -pipe -Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -Wp,-D_GLIBCXX_ASSERTIONS -fexceptions -fstack-protector-strong -grecord-gcc-switches %{_hardened_cflags} %{_annotated_cflags}
|
||||||
# use "%undefine _ld_as_needed" to disable.
|
|
||||||
%_ld_as_needed 1
|
|
||||||
%_ld_as_needed_flags %{?_ld_as_needed:-Wl,--as-needed}
|
|
||||||
|
|
||||||
# LTO is the default in Fedora.
|
|
||||||
# "%define _lto_cflags %{nil}" to opt out
|
|
||||||
#
|
|
||||||
# We currently have -ffat-lto-objects turned on out of an abundance of
|
|
||||||
# caution. To remove it we need to do a check of the installed .o/.a files
|
|
||||||
# to verify they have real sections/symbols after LTO stripping. That
|
|
||||||
# way we can detect installing an unusable .o/.a file. This is on the TODO
|
|
||||||
# list for F34.
|
|
||||||
%_gcc_lto_cflags -flto=auto -ffat-lto-objects
|
|
||||||
%_clang_lto_cflags -flto
|
|
||||||
%_lto_cflags %{expand:%%{_%{toolchain}_lto_cflags}}
|
|
||||||
|
|
||||||
%_general_options -O2 %{?_lto_cflags} -fexceptions -g -grecord-gcc-switches -pipe
|
|
||||||
%_warning_options -Wall -Werror=format-security
|
|
||||||
%_preprocessor_defines -Wp,-D_FORTIFY_SOURCE=2 -Wp,-D_GLIBCXX_ASSERTIONS
|
|
||||||
|
|
||||||
# Common variables are no longer generated by default by gcc and clang
|
|
||||||
# If they are needed then add "%define _legacy_common_support 1" to the spec file.
|
|
||||||
%_legacy_options %{?_legacy_common_support: -fcommon}
|
|
||||||
|
|
||||||
%__global_compiler_flags %{_general_options} %{_warning_options} %{_preprocessor_defines} %{_hardened_cflags} %{_annotation_cflags} %{_legacy_options}
|
|
||||||
|
|
||||||
# Automatically trim changelog entries after 2 years
|
|
||||||
%_changelog_trimtime %{lua:print(os.time() - 2 * 365 * 86400)}
|
|
||||||
|
|
||||||
#==============================================================================
|
#==============================================================================
|
||||||
# ---- Generic auto req/prov filtering macros
|
# ---- Generic auto req/prov filtering macros
|
||||||
|
@ -1,16 +1,16 @@
|
|||||||
# Fedora macros, safe to use after the SRPM build stage
|
# Some miscellaneous Fedora-related macros
|
||||||
|
|
||||||
# Lists files matching inclusion globs, excluding files matching exclusion
|
# List files matching inclusion globs, excluding files matching exclusion blogs
|
||||||
# globs
|
# Optional parameters:
|
||||||
# – globs are space-separated lists of shell globs. Such lists require
|
# – -i "<globs>" inclusion globs
|
||||||
# %{quote:} use when passed as rpm arguments or flags.
|
# – -x "<globs>" exclusion globs
|
||||||
# Control variables, flags and arguments:
|
# Globs are space-separated lists of shell globs. Such lists require %{quote:}
|
||||||
# %{listfiles_include} inclusion globs
|
# use for safe rpm argument passing.
|
||||||
# %{listfiles_exclude} exclusion globs
|
# Alternatively, set the following rpm variables before calling the macro:
|
||||||
# -i <globs> inclusion globs
|
# – “listfiles_include” inclusion globs
|
||||||
# -x <globs> exclusion globs
|
# — “listfiles_exclude” exclusion globs
|
||||||
# … arguments passed to the macro without flags will be
|
# Arguments passed to the macro without flags will be interpreted as inclusion
|
||||||
# interpreted as inclusion globs
|
# globs.
|
||||||
%listfiles(i:x:) %{expand:
|
%listfiles(i:x:) %{expand:
|
||||||
%if %{lua: print(string.len(rpm.expand("%{?-i*}%{?listfiles_include}%*")))}
|
%if %{lua: print(string.len(rpm.expand("%{?-i*}%{?listfiles_include}%*")))}
|
||||||
listfiles_include=$(realpath -e --relative-base=. %{?-i*} %{?listfiles_include} %* | sort -u)
|
listfiles_include=$(realpath -e --relative-base=. %{?-i*} %{?listfiles_include} %* | sort -u)
|
||||||
@ -26,11 +26,9 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
# https://github.com/rpm-software-management/rpm/issues/581
|
# https://github.com/rpm-software-management/rpm/issues/581
|
||||||
# Writes the contents of a list of rpm variables to a macro file
|
# Write the contents of a list of rpm variables to a macro file.
|
||||||
# Control variables, flags and arguments:
|
# The target file must contain the corresponding anchors.
|
||||||
# -f <filename> the macro file to process:
|
# For example %writevars -f myfile foo bar will replace:
|
||||||
# – it must contain corresponding anchors
|
|
||||||
# – for example %writevars -f myfile foo bar will replace:
|
|
||||||
# @@FOO@@ with the rpm evaluation of %{foo} and
|
# @@FOO@@ with the rpm evaluation of %{foo} and
|
||||||
# @@BAR@@ with the rpm evaluation of %{bar}
|
# @@BAR@@ with the rpm evaluation of %{bar}
|
||||||
# in myfile
|
# in myfile
|
||||||
@ -61,3 +59,21 @@ if data ~= "" then
|
|||||||
print(rpm.expand("--data='%{SOURCE" .. data .. "}' "))
|
print(rpm.expand("--data='%{SOURCE" .. data .. "}' "))
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# gpgverify verifies signed sources. There is documentation in the script.
|
||||||
|
%gpgverify(k:s:d:) %{lua:
|
||||||
|
local script = rpm.expand("%{_rpmconfigdir}/redhat/gpgverify ")
|
||||||
|
local keyring = rpm.expand("%{-k*}")
|
||||||
|
local signature = rpm.expand("%{-s*}")
|
||||||
|
local data = rpm.expand("%{-d*}")
|
||||||
|
print(script)
|
||||||
|
if keyring ~= "" then
|
||||||
|
print(rpm.expand("--keyring='%{SOURCE" .. keyring .. "}' "))
|
||||||
|
end
|
||||||
|
if signature ~= "" then
|
||||||
|
print(rpm.expand("--signature='%{SOURCE" .. signature .. "}' "))
|
||||||
|
end
|
||||||
|
if data ~= "" then
|
||||||
|
print(rpm.expand("--data='%{SOURCE" .. data .. "}' "))
|
||||||
|
end
|
||||||
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Fedora macros, safe to use at SRPM build stage
|
# Some miscellaneous Fedora-related macros
|
||||||
|
|
||||||
# A directory for rpm macros
|
# A directory for rpm macros
|
||||||
%rpmmacrodir /usr/lib/rpm/macros.d
|
%rpmmacrodir /usr/lib/rpm/macros.d
|
||||||
@ -6,38 +6,3 @@
|
|||||||
# A directory for appdata metainfo. This has changed between releases so a
|
# A directory for appdata metainfo. This has changed between releases so a
|
||||||
# macro is useful.
|
# macro is useful.
|
||||||
%_metainfodir %{_datadir}/metainfo
|
%_metainfodir %{_datadir}/metainfo
|
||||||
|
|
||||||
# A directory for SWID tag files describing the installation
|
|
||||||
%_swidtagdir %{_prefix}/lib/swidtag/fedoraproject.org
|
|
||||||
|
|
||||||
# Applies the fedora.wordwrap filter to the content of an rpm variable, and
|
|
||||||
# prints the result.
|
|
||||||
# – putting multiple lines of UTF-8 text inside a variable is usually
|
|
||||||
# accomplished with %{expand:some_text}
|
|
||||||
# Control variables, flags and arguments:
|
|
||||||
# -v <variable_name> (default value: _description)
|
|
||||||
%wordwrap(v:) %{lua:
|
|
||||||
local fedora = require "fedora.common"
|
|
||||||
local variable = "%{?" .. rpm.expand("%{-v*}%{!-v:_description}") .. "}"
|
|
||||||
print(fedora.wordwrap(variable))
|
|
||||||
}
|
|
||||||
|
|
||||||
# A single Name: and %package substitute
|
|
||||||
# Control variables, flags and arguments:
|
|
||||||
# %{source_name} the SRPM name
|
|
||||||
# %{source_summary} the SRPM summary
|
|
||||||
# %{source_description} the SRPM description
|
|
||||||
# -n <name> declare a package named <name>
|
|
||||||
# (%package-like behavior)
|
|
||||||
# -v be verbose
|
|
||||||
# %1 declare a package named %{source_name}-%{%1}
|
|
||||||
# (%package-like behavior)
|
|
||||||
%new_package(n:v) %{lua:
|
|
||||||
local fedora = require "fedora.common"
|
|
||||||
local pkg_name = fedora.readflag("n")
|
|
||||||
local verbose = fedora.hasflag("v")
|
|
||||||
local name_suffix = fedora.read("1")
|
|
||||||
local source_name = fedora.read("source_name")
|
|
||||||
local first = not ( fedora.read("name") or fedora.read("currentname") )
|
|
||||||
fedora.new_package(source_name, pkg_name, name_suffix, first, verbose)
|
|
||||||
}
|
|
||||||
|
@ -1,70 +1,282 @@
|
|||||||
# Computes forge-related variables for use in the rest of the spec file
|
# Map forge information to rpm metadata. This macro will compute default spec
|
||||||
# Control variables, flags and arguments:
|
# variable values.
|
||||||
# %{forgeurl<number>} the project url on the target forge
|
#
|
||||||
# %{tag<number>} the packaged tag, OR
|
# The following spec variables SHOULD be set before calling the macro:
|
||||||
# %{commit<number>} the packaged commit, OR
|
#
|
||||||
# %{version<number>} the packaged version
|
# forgeurl the project url on the forge, strongly recommended;
|
||||||
# – %{version}/%{version0} are set via:
|
# alternatively, use -u <url>
|
||||||
# Version:
|
# Version if applicable, set it with Version: <version>
|
||||||
# – because git is lacking a built-in version
|
# tag if applicable
|
||||||
# reference, %{version<number>} will be translated
|
# commit if applicable
|
||||||
# into %{tag<number>} using unreliable heuristics;
|
#
|
||||||
# set %{tag<number>} directly if those fail
|
# The macro will attempt to compute and set the following variables if they are
|
||||||
# %{date<number>} the packaged timestamp
|
# not already set by the packager:
|
||||||
# … %forgemeta will compute a huge number of variables:
|
#
|
||||||
# — the packager can override it by setting some of
|
# forgesource an URL that can be used as SourceX: value
|
||||||
# those before the %forgemeta call
|
# forgesetupargs the correct arguments to pass to %setup for this source
|
||||||
# – use the -i flag to list those variables
|
# used by %forgesetup and %forgeautosetup
|
||||||
# -z <number> only process the zth block of definitions
|
# archivename the source archive filename, without extentions
|
||||||
# "" for the no-suffix block
|
# archiveext the source archive filename extensions, without leading dot
|
||||||
# -i list the resulting variable values
|
# archiveurl the url that can be used to download the source archive,
|
||||||
# -s silently ignore problems in %{forgeurl<number>}
|
# without renaming
|
||||||
# -v be verbose
|
# scm the scm type, when packaging code snapshots: commits or tags
|
||||||
# -a process all sources in one go, instead of using
|
#
|
||||||
# separate -z calls
|
# If the macro is unable to parse your forgeurl value set at least archivename
|
||||||
%forgemeta(z:isva) %{lua:
|
# and archiveurl before calling it.
|
||||||
local fedora = require "fedora.common"
|
#
|
||||||
local forge = require "fedora.srpm.forge"
|
# Most of the computed variables are both overridable and optional. However,
|
||||||
local verbose = rpm.expand("%{-v}") ~= ""
|
# the macro WILL REDEFINE %{dist} when packaging a snapshot (commit or tag).
|
||||||
local informative = rpm.expand("%{-i}") ~= ""
|
# The previous %{dist} value will be lost. Don’t call the macro if you don’t
|
||||||
local silent = rpm.expand("%{-s}") ~= ""
|
# wish %{dist} to be changed.
|
||||||
local processall = (rpm.expand("%{-a}") ~= "") and (rpm.expand("%{-z}") == "")
|
#
|
||||||
if processall then
|
# Optional parameters:
|
||||||
for _,s in pairs(fedora.getsuffixes("forgeurl")) do
|
# -u <url> Ignore forgeurl even if it exists and use <url> instead. Note
|
||||||
forge.meta(s,verbose,informative,silent)
|
# that the macro will still end up setting <url> as the forgeurl
|
||||||
|
# spec variable if it manages to parse it.
|
||||||
|
# -s Silently ignore problems in forgeurl, use it if it can be parsed,
|
||||||
|
# ignore it otherwise.
|
||||||
|
# -p Restore problem handling, override -s.
|
||||||
|
# -v Be verbose and print every spec variable the macro sets.
|
||||||
|
# -i Print some info about the state of spec variables the macro may use or
|
||||||
|
# set at the end of the processing.
|
||||||
|
%forgemeta(u:spvi) %{lua:
|
||||||
|
local forgeurl = rpm.expand("%{?-u*}")
|
||||||
|
if (forgeurl == "") then
|
||||||
|
forgeurl = rpm.expand("%{?forgeurl}")
|
||||||
|
end
|
||||||
|
local silent = false
|
||||||
|
local verbose = false
|
||||||
|
local informative = false
|
||||||
|
if (rpm.expand("%{?-s}") ~= "") then
|
||||||
|
silent = true
|
||||||
|
end
|
||||||
|
if (rpm.expand("%{?-p}") ~= "") then
|
||||||
|
silent = false
|
||||||
|
end
|
||||||
|
if (rpm.expand("%{?-v}") ~= "") then
|
||||||
|
verbose = true
|
||||||
|
end
|
||||||
|
if (rpm.expand("%{?-i}") ~= "") then
|
||||||
|
informative = true
|
||||||
|
end
|
||||||
|
local tag = rpm.expand("%{?tag}")
|
||||||
|
local commit = rpm.expand("%{?commit}")
|
||||||
|
-- Be explicit about the spec variables we’re setting
|
||||||
|
local function explicitset(rpmvariable,value)
|
||||||
|
rpm.define(rpmvariable .. " " .. value)
|
||||||
|
if verbose then
|
||||||
|
rpm.expand("%{echo:Setting %%{" .. rpmvariable .. "} = " .. value .. "\\n}")
|
||||||
end
|
end
|
||||||
else
|
end
|
||||||
forge.meta(rpm.expand("%{-z*}"),verbose,informative,silent)
|
-- Never ever stomp on a spec variable the packager already set
|
||||||
|
local function safeset(rpmvariable,value)
|
||||||
|
if (rpm.expand("%{?" .. rpmvariable .. "}") == "") then
|
||||||
|
explicitset(rpmvariable,value)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- Set spec variable values for each known software publishing service
|
||||||
|
if (forgeurl ~= "") then
|
||||||
|
local forge = string.match(forgeurl, "^[^:]+://([^/]+)/")
|
||||||
|
if (forge == nil) then
|
||||||
|
if not silent then
|
||||||
|
rpm.expand("%{error:URLs must include a protocol such as https:// and a path starting with / !\\n}")
|
||||||
|
end
|
||||||
|
else
|
||||||
|
if (string.match(forge, "^gitlab[%.-]") or string.match(forge, "[%.-]gitlab[%.]")) then
|
||||||
|
forgeurl = string.match(forgeurl, "https://[^/]+/[^/]+/[^/#?]+")
|
||||||
|
if (forgeurl == nil) then
|
||||||
|
if not silent then
|
||||||
|
rpm.expand("%{error:Gitlab URLs must match https://(…[-.])gitlab[-.]…/owner/repo !\\n}")
|
||||||
|
end
|
||||||
|
else
|
||||||
|
explicitset("forgeurl", forgeurl)
|
||||||
|
if (commit == "") then
|
||||||
|
rpm.expand("%{error:All Gitlab URLs require commit value knowledge: you need to define %{commit}!\\nPlease vote on https://gitlab.com/gitlab-org/gitlab-ce/issues/38830\\n}")
|
||||||
|
end
|
||||||
|
safeset("archiveext", "tar.bz2")
|
||||||
|
safeset("forgesetupargs", "-n %{archivename}")
|
||||||
|
if (commit ~= "") or (tag ~= "") then
|
||||||
|
safeset("scm", "git")
|
||||||
|
end
|
||||||
|
local owner = string.match(forgeurl, "^[^:]+://[^/]+/([^/]+)")
|
||||||
|
local repo = string.match(forgeurl, "^[^:]+://[^/]+/[^/]+/([^/]+)")
|
||||||
|
local version = rpm.expand("%{?version}")
|
||||||
|
if (version ~= "") and (version ~= "0") and (tag == "") then
|
||||||
|
-- GitLab does not have strong versionning semantics
|
||||||
|
-- Some projects use "version" as release tag, others "v" + "version"
|
||||||
|
-- Tag value needs to be explicitly declared before calling the macro
|
||||||
|
-- in the second case
|
||||||
|
tag = version
|
||||||
|
safeset("tag", tag)
|
||||||
|
end
|
||||||
|
if (tag ~= "") then
|
||||||
|
safeset("archivename", repo .. "-%{tag}-%{commit}")
|
||||||
|
safeset("archiveurl", "%{forgeurl}/repository/%{tag}/archive.%{archiveext}")
|
||||||
|
else
|
||||||
|
safeset("archivename", repo .. "-%{commit}")
|
||||||
|
safeset("archiveurl", "%{forgeurl}/repository/%{commit}/archive.%{archiveext}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if (string.match(forge, "^github[%.-]") or string.match(forge, "[%.-]github[%.]")) then
|
||||||
|
forgeurl = string.match(forgeurl, "https://[^/]+/[^/]+/[^/#?]+")
|
||||||
|
if (forgeurl == nil) then
|
||||||
|
if not silent then
|
||||||
|
rpm.expand("%{error:GitHub URLs must match https://(…[-.])github[-.]…/owner/repo !\\n}")
|
||||||
|
end
|
||||||
|
else
|
||||||
|
explicitset("forgeurl", forgeurl)
|
||||||
|
safeset("archiveext", "tar.gz")
|
||||||
|
local forgesetupargs = "-n %{archivename}"
|
||||||
|
if (commit ~= "") or (tag ~= "") then
|
||||||
|
safeset("scm", "git")
|
||||||
|
end
|
||||||
|
local owner = string.match(forgeurl, "^[^:]+://[^/]+/([^/]+)")
|
||||||
|
local repo = string.match(forgeurl, "^[^:]+://[^/]+/[^/]+/([^/]+)")
|
||||||
|
if (tag ~= "") then
|
||||||
|
-- if upstream used a version suffix such as -rc1 or -beta it will not
|
||||||
|
-- be a valid version string for rpm but github will accept it fine and
|
||||||
|
-- use the same naming as for other versions: v prefix in the tag and
|
||||||
|
-- archivename, no v prefix in the topdir naming inside the archive
|
||||||
|
local version = rpm.expand("%{?version}")
|
||||||
|
if version ~= "" and
|
||||||
|
(string.match(tag, "^v" .. version .. "[^%d]") or
|
||||||
|
string.match(tag, "^v" .. version .. "$")) then
|
||||||
|
forgesetupargs = "-n " .. repo .. "-" .. string.gsub(tag, "^v", "")
|
||||||
|
end
|
||||||
|
safeset("archivename", repo .. "-%{tag}")
|
||||||
|
safeset("archiveurl", "%{forgeurl}/archive/%{tag}.%{archiveext}")
|
||||||
|
else
|
||||||
|
if (commit ~= "") then
|
||||||
|
safeset("archivename", repo .. "-%{commit}")
|
||||||
|
safeset("archiveurl", "%{forgeurl}/archive/%{commit}/" .. repo .. "-%{commit}.%{archiveext}")
|
||||||
|
else
|
||||||
|
safeset("archivename", repo .. "-%{version}")
|
||||||
|
safeset("archiveurl", "%{forgeurl}/archive/v%{version}.%{archiveext}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
safeset("forgesetupargs", forgesetupargs)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if (forge == "code.googlesource.com") then
|
||||||
|
forgeurl = string.match(forgeurl, "https://code.googlesource.com/[^#?]*[^/#?]+")
|
||||||
|
if (forgeurl == nil) then
|
||||||
|
if not silent then
|
||||||
|
rpm.expand("%{error:Googlesource URLs must match https://code.googlesource.com/…/repo !\\n}")
|
||||||
|
end
|
||||||
|
else
|
||||||
|
explicitset("forgeurl", forgeurl)
|
||||||
|
safeset("archiveext", "tar.gz")
|
||||||
|
safeset("forgesetupargs", "-c")
|
||||||
|
if (commit ~= "") or (tag ~= "") then
|
||||||
|
safeset("scm", "git")
|
||||||
|
end
|
||||||
|
local repo = string.match(forgeurl, "^[^:]+://.+/([^/?#]+)")
|
||||||
|
if (tag ~= "") then
|
||||||
|
safeset("archivename", repo .. "-%{tag}")
|
||||||
|
safeset("archiveurl", "%{forgeurl}/+archive/%{tag}.%{archiveext}")
|
||||||
|
else
|
||||||
|
if (commit ~= "") then
|
||||||
|
safeset("archivename", repo .. "-%{commit}")
|
||||||
|
safeset("archiveurl", "%{forgeurl}/+archive/%{commit}.%{archiveext}")
|
||||||
|
else
|
||||||
|
safeset("archivename", repo .. "-v%{version}")
|
||||||
|
safeset("archiveurl", "%{forgeurl}/+archive/v%{version}.%{archiveext}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if (forge == "bitbucket.org") then
|
||||||
|
forgeurl = string.match(forgeurl, "https://[^/]+/[^/]+/[^/#?]+")
|
||||||
|
if (forgeurl == nil) then
|
||||||
|
if not silent then
|
||||||
|
rpm.expand("%{error:BitBucket URLs must match https://bitbucket.org/owner/repo !\\n}")
|
||||||
|
end
|
||||||
|
else
|
||||||
|
explicitset("forgeurl", forgeurl)
|
||||||
|
if (commit == "") then
|
||||||
|
rpm.expand("%{error:All BitBucket URLs require commit value knowledge: you need to define %{commit}!\\n}")
|
||||||
|
end
|
||||||
|
local shortcommit = string.sub(commit, 1, 12)
|
||||||
|
safeset("archiveext", "tar.bz2")
|
||||||
|
-- Default to git even though BitBucket allows choosing between several SCMs
|
||||||
|
-- Set scm to hg for example before calling the macro if your project does not use git
|
||||||
|
safeset("scm", "git")
|
||||||
|
local owner = string.match(forgeurl, "^[^:]+://[^/]+/([^/]+)")
|
||||||
|
local repo = string.match(forgeurl, "^[^:]+://[^/]+/[^/]+/([^/]+)")
|
||||||
|
safeset("archivename", owner .. "-" .. repo .. "-" .. shortcommit)
|
||||||
|
safeset("forgesetupargs", "-n %{archivename}")
|
||||||
|
if (tag ~= "") then
|
||||||
|
safeset("archiveurl", "%{forgeurl}/get/%{tag}.%{archiveext}")
|
||||||
|
else
|
||||||
|
safeset("archiveurl", "%{forgeurl}/get/%{commit}.%{archiveext}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if (forge == "pagure.io") then
|
||||||
|
if not silent then
|
||||||
|
rpm.expand("%{error:https://pagure.io/pagure/issue/861 needs to be resolved before the “pagure.io”\\nsoftware publishing service can be supported.\\n}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- Final tests to check forgeurl was successfuly parsed
|
||||||
|
if not silent then
|
||||||
|
if (rpm.expand("%{?archivename}") == "") or (rpm.expand("%{?archiveurl}") == "") then
|
||||||
|
rpm.expand("%{error:Automation for the “" .. forge .. "”\\nsoftware publishing service is not implemented yet.\\nPlease extend the %%forgemeta macro!\\n}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- Set defaults if forgeurl is missing or does not parse
|
||||||
|
local archivename = rpm.expand("%{?archivename}")
|
||||||
|
safeset("archiveext", "tar.gz")
|
||||||
|
if (archivename ~= "") then
|
||||||
|
safeset("forgesetupargs", "-n %{archivename}")
|
||||||
|
end
|
||||||
|
if (commit ~= "") or (tag ~= "") then
|
||||||
|
safeset("scm", "git")
|
||||||
|
end
|
||||||
|
-- Source URL processing (computing the forgesource spec variable)
|
||||||
|
local archiveurl = rpm.expand("%{?archiveurl}")
|
||||||
|
local archiveext = rpm.expand("%{?archiveext}")
|
||||||
|
if (archivename ~= "") and (archiveurl ~= "") then
|
||||||
|
if (string.match(archiveurl, "/([^/]+)$") == archivename .. "." .. archiveext) then
|
||||||
|
safeset("forgesource", "%{archiveurl}")
|
||||||
|
else
|
||||||
|
safeset("forgesource", "%{?archiveurl}#/%{?archivename}.%{archiveext}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- dist processing (computing the correct pefix for snapshots)
|
||||||
|
local distprefix = rpm.expand("%{?tag}")
|
||||||
|
local version = rpm.expand("%{?version}")
|
||||||
|
if (distprefix == version) or (distprefix == "v" .. version) then
|
||||||
|
distprefix = ""
|
||||||
|
end
|
||||||
|
if (distprefix == "") then
|
||||||
|
distprefix = string.sub(rpm.expand("%{?commit}"), 1, 7)
|
||||||
|
end
|
||||||
|
if (distprefix ~= "") then
|
||||||
|
local dist = ".%([ -r %{_sourcedir}/%{archivename}.%{archiveext} ] && date +%Y%m%d -u -r %{_sourcedir}/%{archivename}.%{archiveext})%{scm}" .. string.gsub(distprefix, "-",".") .. rpm.expand("%{?dist}")
|
||||||
|
explicitset("dist", dist)
|
||||||
|
end
|
||||||
|
-- Final spec variable summary if the macro was called with -i
|
||||||
|
if informative then
|
||||||
|
rpm.expand("%{echo:Forge-specific packaging variables\\n}")
|
||||||
|
rpm.expand("%{echo: forgeurl: %{?forgeurl}\\n}")
|
||||||
|
rpm.expand("%{echo: forgesource: %{?forgesource}\\n}")
|
||||||
|
rpm.expand("%{echo: forgesetupargs: %{?forgesetupargs}\\n}")
|
||||||
|
rpm.expand("%{echo:Generic variables\\n}")
|
||||||
|
rpm.expand("%{echo: archivename: %{?archivename}\\n}")
|
||||||
|
rpm.expand("%{echo: archiveext: %{?archiveext}\\n}")
|
||||||
|
rpm.expand("%{echo: archiveurl: %{?archiveurl}\\n}")
|
||||||
|
rpm.expand("%{echo: scm: %{?scm}\\n}")
|
||||||
|
rpm.expand("%{echo: tag: %{?tag}\\n}")
|
||||||
|
rpm.expand("%{echo: commit: %{?commit}\\n}")
|
||||||
|
rpm.expand("%{echo: dist: %{?dist} (snapshot date is computed once %%{_sourcedir}/%%{archivename}.%%{archiveext} is available)\\n}")
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
|
|
||||||
# Unpacks sources computed by %forgemeta
|
# Convenience macro to relay computed arguments to %setup
|
||||||
# Control variables, flags and arguments:
|
%forgesetup(a:b:cDn:Tq) %setup %{?forgesetupargs} %{-a} %{-b} %{-c} %{-D} %{-n} %{-T} %{-q}
|
||||||
# %{forgesource<number>} the source archive that will be processed
|
|
||||||
# %{forgesetupargs<number>} %setup arguments
|
|
||||||
|
|
||||||
# -z <number> only process the zth block of definitions
|
# Convenience macro to relay computed arguments to %autosetup
|
||||||
# "" for the no-suffix block
|
%forgeautosetup(a:b:cDn:TvNS:p:) %autosetup %{?forgesetupargs} %{-a} %{-b} %{-c} %{-D} %{-n} %{-T} %{-v} %{-N} %{-S} %{-p}
|
||||||
# -v be verbose
|
|
||||||
# -a process all sources in one go, instead of using
|
|
||||||
# separate -z calls
|
|
||||||
%forgesetup(z:va) %{lua:
|
|
||||||
local fedora = require "fedora.common"
|
|
||||||
if (rpm.expand("%{-z}") == "") and (rpm.expand("%{-a}") ~= "") then
|
|
||||||
for _,s in pairs(fedora.getsuffixes("forgesetupargs")) do
|
|
||||||
print(rpm.expand("%setup %{!-v:-q} %{?forgesetupargs" .. s .. "}\\n"))
|
|
||||||
end
|
|
||||||
else
|
|
||||||
print( rpm.expand("%setup %{!-v:-q} %{?forgesetupargs" .. rpm.expand("%{-z*}") .. "}\\n"))
|
|
||||||
end
|
|
||||||
}
|
|
||||||
|
|
||||||
# Calls %autosetup using %forgemeta results
|
|
||||||
# – this will probably be removed since it is unsafe in presence of multiple
|
|
||||||
# sources
|
|
||||||
# Control variables, flags and arguments:
|
|
||||||
# -z <number> process the zth block of definitions
|
|
||||||
# -v -N -S -p relayed to %autosetup
|
|
||||||
%forgeautosetup(z:vNS:p:q) %{lua:
|
|
||||||
print(rpm.expand("%autosetup %{-v} %{-N} %{?-S} %{?-p} %{?forgesetupargs" .. rpm.expand("%{-z*}") .. "}\\n"))
|
|
||||||
}
|
|
||||||
|
3
SOURCES/macros.kernel-srpm
Normal file
3
SOURCES/macros.kernel-srpm
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# kernel_arches lists what arches the full kernel is built for.
|
||||||
|
|
||||||
|
%kernel_arches x86_64 s390x ppc64le aarch64 %{arm}
|
97
SOURCES/macros.kmp
Normal file
97
SOURCES/macros.kmp
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
# Use these macros to differentiate between RH and other KMP implementation(s).
|
||||||
|
%global redhat_kernel_module_package 1
|
||||||
|
%global kernel_module_package_release 1
|
||||||
|
|
||||||
|
%global redhat_kmp_has_post_hooks 1
|
||||||
|
|
||||||
|
%__brp_kmod_set_exec_bit /usr/lib/rpm/redhat/brp-kmod-set-exec-bit
|
||||||
|
%__brp_kmod_restore_perms /usr/lib/rpm/redhat/brp-kmod-restore-perms
|
||||||
|
|
||||||
|
%__kmod_brps_added 0
|
||||||
|
|
||||||
|
%__find_provides /usr/lib/rpm/redhat/find-provides
|
||||||
|
%__find_requires /usr/lib/rpm/redhat/find-requires
|
||||||
|
|
||||||
|
#kernel_module_package [ -n name ] [ -v version ] [ -r release ] [ -s script ]
|
||||||
|
# [ -f filelist] [ -x ] [ -p preamble ] flavor flavor ...
|
||||||
|
|
||||||
|
%kernel_module_package_buildreqs %global kmodtool_generate_buildreqs 1 \
|
||||||
|
kernel-devel kernel-abi-whitelists redhat-rpm-config kernel-rpm-macros elfutils-libelf-devel kmod
|
||||||
|
|
||||||
|
%kernel_module_package(n:v:r:s:f:xp:) %{expand:%( \
|
||||||
|
## An ugly hack: we want kmods to be processed by find-debuginfo,
|
||||||
|
## but it processes only files with executable permission set.
|
||||||
|
## It is important now since, as of now, if debuginfo package
|
||||||
|
## is enabled (and it is enabled), there's an RPM build error
|
||||||
|
## as a result of lack of ether absence or emptiness of
|
||||||
|
## debugsourcefiles.list (which is likely a bug in RPM, but it looks
|
||||||
|
## like that there's no obvious fix and apparently no one have
|
||||||
|
## any issues with this).
|
||||||
|
## In order to minimise intrusiveness, usually (in Red Hat-built kmod
|
||||||
|
## RPMs) *.ko files just have executable permission being set as a part
|
||||||
|
## of %build section. There are two caveats with kmp, however:
|
||||||
|
## * We have no control over %build section itself (and it wasn't
|
||||||
|
## required previously)
|
||||||
|
## * Changing the criteria used in find-debuginfo.sh/brp-strip
|
||||||
|
## for selecting files that have to undergo debug section separation
|
||||||
|
## may introduce regression.
|
||||||
|
## As a result, we insert additional hooks in __spec_install_post
|
||||||
|
## (__brp_kmod_set_exec_bit in the beginning and
|
||||||
|
## __brp_kmod_restore_perms in the end) that (temporarily) set
|
||||||
|
## executable permission for *.ko files so find-debuginfo.sh will pick
|
||||||
|
## them up.
|
||||||
|
## Unfortunately, __spec_install_post's body is copied here since
|
||||||
|
## we want that __debug_package macro expansion has been performed
|
||||||
|
## lazily and it looks like RPM has no ability to provide a body
|
||||||
|
## of a macro verbatim.
|
||||||
|
if [ 0 = "%{__kmod_brps_added}" ]; then \
|
||||||
|
echo "%%global __spec_install_post \\\\" \
|
||||||
|
echo " %%{?__brp_kmod_set_exec_bit} \\\\" \
|
||||||
|
echo " %%%%{?__debug_package:%%%%{__debug_install_post}} \\\\" \
|
||||||
|
echo " %%{__arch_install_post} \\\\" \
|
||||||
|
echo " %%{__os_install_post} \\\\" \
|
||||||
|
echo " %%{?__brp_kmod_pre_sign_process} \\\\" \
|
||||||
|
echo " %%{?__brp_kmod_sign} \\\\" \
|
||||||
|
echo " %%{?__brp_kmod_post_sign_process} \\\\" \
|
||||||
|
echo " %%{?__brp_kmod_compress} \\\\" \
|
||||||
|
echo " %%{?__brp_kmod_post_compress_process} \\\\" \
|
||||||
|
echo " %%{?__brp_kmod_restore_perms} \\\\" \
|
||||||
|
echo "%%{nil}" \
|
||||||
|
fi \
|
||||||
|
%global __kmod_brps_added 1 \
|
||||||
|
%global kmodtool %{-s*}%{!-s:/usr/lib/rpm/redhat/kmodtool} \
|
||||||
|
%global kmod_version %{-v*}%{!-v:%{version}} \
|
||||||
|
%global kmod_release %{-r*}%{!-r:%{release}} \
|
||||||
|
%global latest_kernel %({ rpm -q --qf '%%{VERSION}-%%{RELEASE}.%%{ARCH}\\\\n' `rpm -qa | egrep "^kernel(-rt|-aarch64)?-devel" | /usr/lib/rpm/redhat/rpmsort -r | head -n 1`; echo '%%%%{nil}'; } | head -n 1) \
|
||||||
|
%{!?kernel_version:%{expand:%%global kernel_version %{latest_kernel}}} \
|
||||||
|
%global kverrel %(%{kmodtool} verrel %{?kernel_version} 2>/dev/null) \
|
||||||
|
flavors="default" \
|
||||||
|
if [ -z "%*" ]; then \
|
||||||
|
flavors_to_build=$flavors \
|
||||||
|
elif [ -z "%{-x}" ]; then \
|
||||||
|
flavors_to_build="%*" \
|
||||||
|
else \
|
||||||
|
flavors_to_build=" $flavors "\
|
||||||
|
for i in %* \
|
||||||
|
do \
|
||||||
|
flavors_to_build=${flavors_to_build//$i /}
|
||||||
|
done \
|
||||||
|
fi \
|
||||||
|
echo "%%global flavors_to_build ${flavors_to_build:-%%nil}" \
|
||||||
|
echo "%%global kernel_source() \\\$([ default = \"%%%%{1}\" ] && echo \"/usr/src/kernels//%%%%kverrel\" || %{kmodtool} kernel_source \"%%%%{kverrel}\" \"%%%%{1}\" 2>/dev/null || { ls -Ud \"/usr/src/kernels///%%%%{kverrel}\"[.+]\"%%%%{1}\" | sort -V | tail -n 1; } || echo \"/usr/src/kernels////%%%%kverrel.%%%%1\")" \
|
||||||
|
echo "%%global kernel_module_package_moddir() extra" \
|
||||||
|
if [ ! -z "%{-f*}" ] \
|
||||||
|
then \
|
||||||
|
filelist="%{-f*}" \
|
||||||
|
fi \
|
||||||
|
if [ ! -z "%{-p*}" ] \
|
||||||
|
then \
|
||||||
|
preamble="%{-p*}" \
|
||||||
|
fi \
|
||||||
|
nobuildreqs="yes" \
|
||||||
|
if [ "x%{kmodtool_generate_buildreqs}" != "x1" ] \
|
||||||
|
then \
|
||||||
|
nobuildreqs="no" \
|
||||||
|
fi \
|
||||||
|
override_filelist="$filelist" override_preamble="$preamble" nobuildreqs="$nobuildreqs" kmod_version=%kmod_version kmod_release=%kmod_release %{kmodtool} rpmtemplate %{-n*}%{!-n:%name} %{kverrel} $flavors_to_build 2>/dev/null \
|
||||||
|
)}
|
@ -1,2 +1,2 @@
|
|||||||
# arches that ldc builds on
|
# arches that ldc builds on
|
||||||
%ldc_arches %{ix86} x86_64 %{arm} aarch64
|
%ldc_arches %{ix86} x86_64 %{arm} %{power64}
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
# valgrind_arches lists what arches Valgrind works on
|
# valgrind_arches lists what arches Valgrind works on
|
||||||
|
|
||||||
%valgrind_arches %{ix86} x86_64 ppc ppc64 ppc64le s390x armv7hl aarch64
|
%valgrind_arches %{ix86} x86_64 ppc ppc64 ppc64le armv7hl aarch64 s390x
|
||||||
|
@ -4,4 +4,4 @@
|
|||||||
%_vpath_srcdir .
|
%_vpath_srcdir .
|
||||||
|
|
||||||
# directory (doesn't need to exist) where all generated build files will be placed
|
# directory (doesn't need to exist) where all generated build files will be placed
|
||||||
%_vpath_builddir %{_vendor}-%{_target_os}-build
|
%_vpath_builddir %_target_platform
|
||||||
|
78
SOURCES/modalias.prov
Normal file
78
SOURCES/modalias.prov
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
#! /bin/bash -efu
|
||||||
|
|
||||||
|
# heavily based upon find-suggests.ksyms by Andreas Gruenbacher <agruen@suse.de>.
|
||||||
|
# with modifications by Michael Brown <Michael_E_Brown@dell.com>
|
||||||
|
#
|
||||||
|
# -- added module versioning info to modalias() symbols
|
||||||
|
# -- removed code which inspects spec files.
|
||||||
|
|
||||||
|
IFS=$'\n'
|
||||||
|
|
||||||
|
#
|
||||||
|
# Initially, dont generate modalias() lines for kernel package. This needs
|
||||||
|
# additional discussion. Would like to eventually add them for
|
||||||
|
# completeness, so that we can determine when drivers are folded into
|
||||||
|
# mainline kernel.
|
||||||
|
#
|
||||||
|
is_kernel_package=""
|
||||||
|
case "${1:-}" in
|
||||||
|
kernel-module-*) ;; # Fedora kernel module package names start with
|
||||||
|
# kernel-module.
|
||||||
|
kernel*) is_kernel_package=1 ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if ! [ -z "$is_kernel_package" ]; then
|
||||||
|
cat > /dev/null
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check for presence of the commands used
|
||||||
|
which /sbin/modinfo >/dev/null || exit 0
|
||||||
|
which sed >/dev/null || exit 0
|
||||||
|
which sort >/dev/null || exit 0
|
||||||
|
|
||||||
|
print_modaliases() {
|
||||||
|
declare class=$1 variants=$2 pos=$3
|
||||||
|
if [ -n "$variants" ]; then
|
||||||
|
echo "${class:0:pos}[$variants]${class:pos+1}"
|
||||||
|
else
|
||||||
|
[ -z "$class" ] || echo "$class"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
combine_modaliases() {
|
||||||
|
declare tag class variants="" pos="" n
|
||||||
|
read class
|
||||||
|
while read tag; do
|
||||||
|
for ((n=0; n<${#class}; n++)); do
|
||||||
|
if [ "*" != "${class:n:1}" -a \
|
||||||
|
"${class:0:n}" = "${tag:0:n}" -a \
|
||||||
|
"${class:n+1}" = "${tag:n+1}" ] &&
|
||||||
|
( [ -z "$pos" ] || [ $n = $pos ] ); then
|
||||||
|
variants="${variants:-${class:n:1}}${tag:n:1}"
|
||||||
|
pos=$n
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if [ $n -eq ${#class} ]; then
|
||||||
|
print_modaliases "$class" "$variants" "$pos"
|
||||||
|
variants=
|
||||||
|
pos=
|
||||||
|
class=$tag
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
print_modaliases "$class" "$variants" "$pos"
|
||||||
|
}
|
||||||
|
|
||||||
|
for module in $(grep -E '/lib/modules/.+\.ko(\.gz|\.bz2|\.xz)?$') "$@"; do
|
||||||
|
# | head -n1 because some modules have *two* version tags. *cough*b44*cough*
|
||||||
|
modver=$(/sbin/modinfo -F version "$module"| head -n1)
|
||||||
|
modver=${modver//[^0-9a-zA-Z._]/_}
|
||||||
|
# only add version tag if it has a version
|
||||||
|
[ -z "$modver" ] || modver=" = $modver"
|
||||||
|
|
||||||
|
/sbin/modinfo -F alias "$module" \
|
||||||
|
| sed -nre "s,[^][0-9a-zA-Z._:*?/-],_,g; s,(.+),modalias(\\1)$modver,p"
|
||||||
|
done \
|
||||||
|
| sort -u \
|
||||||
|
| combine_modaliases
|
@ -3,7 +3,7 @@
|
|||||||
# should be the destination of the redhat-annobin-cc1 symlink.
|
# should be the destination of the redhat-annobin-cc1 symlink.
|
||||||
|
|
||||||
# Author: Nick Clifton <nickc@redhat.com>
|
# Author: Nick Clifton <nickc@redhat.com>
|
||||||
# Copyright (c) 2021-2022 Red Hat.
|
# Copyright (c) 2021 Red Hat.
|
||||||
#
|
#
|
||||||
# This is free software; you can redistribute it and/or modify it
|
# This is free software; you can redistribute it and/or modify it
|
||||||
# under the terms of the GNU General Public License as published
|
# under the terms of the GNU General Public License as published
|
||||||
|
@ -1 +0,0 @@
|
|||||||
-fPIE
|
|
@ -3,10 +3,10 @@ include: /usr/lib/rpm/rpmrc
|
|||||||
optflags: i386 %{__global_compiler_flags} -m32 -march=i386 -mtune=generic -fasynchronous-unwind-tables -fstack-clash-protection
|
optflags: i386 %{__global_compiler_flags} -m32 -march=i386 -mtune=generic -fasynchronous-unwind-tables -fstack-clash-protection
|
||||||
optflags: i486 %{__global_compiler_flags} -m32 -march=i486 -fasynchronous-unwind-tables -fstack-clash-protection
|
optflags: i486 %{__global_compiler_flags} -m32 -march=i486 -fasynchronous-unwind-tables -fstack-clash-protection
|
||||||
optflags: i586 %{__global_compiler_flags} -m32 -march=i586 -mtune=generic -fasynchronous-unwind-tables -fstack-clash-protection
|
optflags: i586 %{__global_compiler_flags} -m32 -march=i586 -mtune=generic -fasynchronous-unwind-tables -fstack-clash-protection
|
||||||
optflags: i686 %{__global_compiler_flags} -m32 -march=i686 -mtune=generic -msse2 -mfpmath=sse -mstackrealign -fasynchronous-unwind-tables -fstack-clash-protection -fcf-protection
|
optflags: i686 %{__global_compiler_flags} -m32 -march=x86-64 -mtune=generic -mfpmath=sse -mstackrealign -fasynchronous-unwind-tables -fstack-clash-protection -fcf-protection
|
||||||
optflags: athlon %{__global_compiler_flags} -m32 -march=athlon -fasynchronous-unwind-tables -fstack-clash-protection
|
optflags: athlon %{__global_compiler_flags} -m32 -march=athlon -fasynchronous-unwind-tables -fstack-clash-protection
|
||||||
optflags: ia64 %{__global_compiler_flags}
|
optflags: ia64 %{__global_compiler_flags}
|
||||||
optflags: x86_64 %{__global_compiler_flags} -m64 %{__cflags_arch_x86_64} -mtune=generic -fasynchronous-unwind-tables -fstack-clash-protection -fcf-protection
|
optflags: x86_64 %{__global_compiler_flags} -m64 -mtune=generic -fasynchronous-unwind-tables -fstack-clash-protection -fcf-protection
|
||||||
|
|
||||||
optflags: alpha %{__global_compiler_flags} -mieee
|
optflags: alpha %{__global_compiler_flags} -mieee
|
||||||
optflags: alphaev5 %{__global_compiler_flags} -mieee -mcpu=ev5
|
optflags: alphaev5 %{__global_compiler_flags} -mieee -mcpu=ev5
|
||||||
@ -24,12 +24,12 @@ optflags: sparc64v %{__global_compiler_flags} -m64 -mcpu=niagara
|
|||||||
|
|
||||||
optflags: m68k %{__global_compiler_flags}
|
optflags: m68k %{__global_compiler_flags}
|
||||||
|
|
||||||
optflags: ppc %{__global_compiler_flags} -m32 -fasynchronous-unwind-tables
|
optflags: ppc %{__global_compiler_flags} -m32 -funwind-tables
|
||||||
optflags: ppciseries %{__global_compiler_flags} -m32
|
optflags: ppciseries %{__global_compiler_flags} -m32
|
||||||
optflags: ppcpseries %{__global_compiler_flags} -m32
|
optflags: ppcpseries %{__global_compiler_flags} -m32
|
||||||
optflags: ppc64 %{__global_compiler_flags} -m64 -fasynchronous-unwind-tables -fstack-clash-protection
|
optflags: ppc64 %{__global_compiler_flags} -m64 -funwind-tables -fstack-clash-protection
|
||||||
optflags: ppc64p7 %{__global_compiler_flags} -m64 -O3 -mcpu=power7 -mtune=power7 -fasynchronous-unwind-tables -fstack-clash-protection
|
optflags: ppc64p7 %{__global_compiler_flags} -m64 -O3 -mcpu=power7 -mtune=power7 -funwind-tables -fstack-clash-protection
|
||||||
optflags: ppc64le %{__global_compiler_flags} -m64 %{__cflags_arch_ppc64le} -fasynchronous-unwind-tables -fstack-clash-protection
|
optflags: ppc64le %{__global_compiler_flags} -m64 -mcpu=power8 -mtune=power8 -funwind-tables -fstack-clash-protection
|
||||||
optflags: ppc64iseries %{__global_compiler_flags} -m64
|
optflags: ppc64iseries %{__global_compiler_flags} -m64
|
||||||
optflags: ppc64pseries %{__global_compiler_flags} -m64
|
optflags: ppc64pseries %{__global_compiler_flags} -m64
|
||||||
optflags: ppc8260 %{__global_compiler_flags} -m32
|
optflags: ppc8260 %{__global_compiler_flags} -m32
|
||||||
@ -71,12 +71,12 @@ optflags: atariclone %{__global_compiler_flags}
|
|||||||
optflags: milan %{__global_compiler_flags}
|
optflags: milan %{__global_compiler_flags}
|
||||||
optflags: hades %{__global_compiler_flags}
|
optflags: hades %{__global_compiler_flags}
|
||||||
|
|
||||||
optflags: s390 %{__global_compiler_flags} -m31 %{__cflags_arch_s390x} -fasynchronous-unwind-tables
|
optflags: s390 %{__global_compiler_flags} -m31 -march=z13 -mtune=z14 -fasynchronous-unwind-tables
|
||||||
optflags: s390x %{__global_compiler_flags} -m64 %{__cflags_arch_s390x} -fasynchronous-unwind-tables -fstack-clash-protection
|
optflags: s390x %{__global_compiler_flags} -m64 -march=z13 -mtune=z14 -fasynchronous-unwind-tables -fstack-clash-protection
|
||||||
|
|
||||||
optflags: aarch64 %{__global_compiler_flags} -fasynchronous-unwind-tables %[ "%{toolchain}" == "gcc" ? "-fstack-clash-protection" : "" ]
|
optflags: aarch64 %{__global_compiler_flags} -fasynchronous-unwind-tables -fstack-clash-protection
|
||||||
|
|
||||||
optflags: riscv64 %{__global_compiler_flags} -fasynchronous-unwind-tables %[ "%{toolchain}" == "gcc" ? "-fstack-clash-protection" : "" ]
|
optflags: riscv64 %{__global_compiler_flags}
|
||||||
|
|
||||||
# set build arch to fedora buildarches on hardware capable of running it
|
# set build arch to fedora buildarches on hardware capable of running it
|
||||||
# saves having to do rpmbuild --target=
|
# saves having to do rpmbuild --target=
|
||||||
|
76
SOURCES/rpmsort
Executable file
76
SOURCES/rpmsort
Executable file
@ -0,0 +1,76 @@
|
|||||||
|
#! /usr/bin/perl -w
|
||||||
|
|
||||||
|
# This program is free software; you can redistribute it and/or
|
||||||
|
# modify it under the terms of the GNU General Public License
|
||||||
|
# as published by the Free Software Foundation; either version 2
|
||||||
|
# of the License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
|
||||||
|
# USA.
|
||||||
|
|
||||||
|
use Getopt::Long qw(:config gnu_getopt);
|
||||||
|
|
||||||
|
sub rpm_cmp_versions {
|
||||||
|
my ($evr1, $evr2) = @_;
|
||||||
|
|
||||||
|
sub _rpm_cmp {
|
||||||
|
my ($s1, $s2) = @_;
|
||||||
|
|
||||||
|
return defined $s1 <=> defined $s2
|
||||||
|
unless defined $s1 && defined $s2;
|
||||||
|
|
||||||
|
my ($r, $x1, $x2);
|
||||||
|
do {
|
||||||
|
$s1 =~ s/^[^a-zA-Z0-9]+//;
|
||||||
|
$s2 =~ s/^[^a-zA-Z0-9]+//;
|
||||||
|
if ($s1 =~ /^\d/ || $s2 =~ /^\d/) {
|
||||||
|
$s1 =~ s/^0*(\d*)//; $x1 = $1;
|
||||||
|
$s2 =~ s/^0*(\d*)//; $x2 = $1;
|
||||||
|
$r = length $x1 <=> length $x2 || $x1 cmp $x2;
|
||||||
|
} else {
|
||||||
|
$s1 =~ s/^([a-zA-Z]*)//; $x1 = $1;
|
||||||
|
$s2 =~ s/^([a-zA-Z]*)//; $x2 = $1;
|
||||||
|
return 0
|
||||||
|
if $x1 eq '' && $x2 eq '';
|
||||||
|
$r = $x1 cmp $x2;
|
||||||
|
}
|
||||||
|
} until $r;
|
||||||
|
return $r;
|
||||||
|
}
|
||||||
|
|
||||||
|
my ($e1, $v1, $r1) = $evr1 =~ /^(?:(\d*):)?(.*?)(?:-([^-]*))?$/;
|
||||||
|
my ($e2, $v2, $r2) = $evr2 =~ /^(?:(\d*):)?(.*?)(?:-([^-]*))?$/;
|
||||||
|
my $r = _rpm_cmp($e1 || 0, $e2 || 0);
|
||||||
|
$r = _rpm_cmp($v1, $v2)
|
||||||
|
unless $r;
|
||||||
|
$r = _rpm_cmp($r1, $r2)
|
||||||
|
unless $r;
|
||||||
|
return $r;
|
||||||
|
}
|
||||||
|
|
||||||
|
my $reorder = sub { return @_ };
|
||||||
|
my $key = 0;
|
||||||
|
|
||||||
|
GetOptions ("r|reverse" => sub { $reorder = sub { return reverse @_ } },
|
||||||
|
"k|key=i" => \$key)
|
||||||
|
or do {
|
||||||
|
print STDERR "Usage\n";
|
||||||
|
exit 1;
|
||||||
|
};
|
||||||
|
|
||||||
|
if ($key == 0) {
|
||||||
|
# Sort by entire lines
|
||||||
|
map { print } &$reorder(sort { rpm_cmp_versions($a, $b) } <>);
|
||||||
|
} else {
|
||||||
|
# Sort by field $key
|
||||||
|
my @data = map { [(split)[$key-1], $_] } <>;
|
||||||
|
map { print } &$reorder(map { $_->[1] }
|
||||||
|
sort { rpm_cmp_versions($a->[0], $b->[0]) } @data);
|
||||||
|
}
|
40
SOURCES/symset-table
Executable file
40
SOURCES/symset-table
Executable file
@ -0,0 +1,40 @@
|
|||||||
|
#! /bin/sh
|
||||||
|
|
||||||
|
# Create a table of all symbol sets defined in all /boot/symsets*.tar.gz
|
||||||
|
# files.
|
||||||
|
#
|
||||||
|
# Format:
|
||||||
|
# kernelrelease/modver/symbol <tab> symset <tab> symset_hash
|
||||||
|
#
|
||||||
|
# This table is needed for computing the appropriate Requires: tags for
|
||||||
|
# kernel module packages.
|
||||||
|
|
||||||
|
tmpdir=$(mktemp -t -d ${0##*/}.XXXXXX)
|
||||||
|
trap "cd / ; rm -rf $tmpdir" EXIT
|
||||||
|
cd $tmpdir
|
||||||
|
|
||||||
|
shopt -s nullglob
|
||||||
|
for symsets in /boot/symsets-*.tar.gz; do
|
||||||
|
zcat $symsets \
|
||||||
|
| tar xf -
|
||||||
|
done
|
||||||
|
|
||||||
|
for symsets in /usr/src/kernels/*/symsets-*.tar.gz; do
|
||||||
|
zcat $symsets \
|
||||||
|
| tar xf -
|
||||||
|
done
|
||||||
|
|
||||||
|
for symsets in *; do
|
||||||
|
krel=${symsets#symsets-}
|
||||||
|
for symset in $symsets/*; do
|
||||||
|
class=${symset##*/} ; class=${class%.*}
|
||||||
|
hash=${symset##*.}
|
||||||
|
awk '
|
||||||
|
BEGIN { FS = "\t" ; OFS = "\t" }
|
||||||
|
{ sub(/0x0*/, "", $1)
|
||||||
|
print krel "/" $1 "/" $2, class, hash }
|
||||||
|
' krel="$krel" class="$class" hash="$hash" $symset
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
||||||
|
# vim:shiftwidth=4 softtabstop=4
|
@ -6,26 +6,30 @@
|
|||||||
|
|
||||||
Summary: Red Hat specific rpm configuration files
|
Summary: Red Hat specific rpm configuration files
|
||||||
Name: redhat-rpm-config
|
Name: redhat-rpm-config
|
||||||
Version: 194
|
Version: 131
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
# No version specified.
|
# No version specified.
|
||||||
License: GPL+
|
License: GPL+
|
||||||
|
Group: Development/System
|
||||||
URL: https://src.fedoraproject.org/rpms/redhat-rpm-config
|
URL: https://src.fedoraproject.org/rpms/redhat-rpm-config
|
||||||
|
|
||||||
# Core rpm settings
|
# Core rpm settings
|
||||||
Source0: macros
|
Source0: macros
|
||||||
Source1: rpmrc
|
Source1: rpmrc
|
||||||
|
|
||||||
|
# kabi provides generator
|
||||||
|
Source20: kabi.attr
|
||||||
|
Source21: kabi.sh
|
||||||
|
|
||||||
# gcc specs files for hardened builds
|
# gcc specs files for hardened builds
|
||||||
Source50: redhat-hardened-cc1
|
Source50: redhat-hardened-cc1
|
||||||
Source51: redhat-hardened-ld
|
Source51: redhat-hardened-ld
|
||||||
Source52: redhat-hardened-clang.cfg
|
|
||||||
|
|
||||||
# gcc specs files for annobin builds
|
# gcc specs files for annobin builds
|
||||||
Source60: redhat-annobin-cc1
|
Source52: redhat-annobin-cc1
|
||||||
Source61: redhat-annobin-select-gcc-built-plugin
|
Source53: redhat-annobin-select-gcc-built-plugin
|
||||||
Source62: redhat-annobin-select-annobin-built-plugin
|
Source54: redhat-annobin-select-annobin-built-plugin
|
||||||
Source63: redhat-annobin-plugin-select.sh
|
Source55: redhat-annobin-plugin-select.sh
|
||||||
|
|
||||||
# The macros defined by these files are for things that need to be defined
|
# The macros defined by these files are for things that need to be defined
|
||||||
# at srpm creation time when it is not feasible to require the base packages
|
# at srpm creation time when it is not feasible to require the base packages
|
||||||
@ -40,10 +44,12 @@ Source105: macros.valgrind-srpm
|
|||||||
|
|
||||||
# Other misc macros
|
# Other misc macros
|
||||||
Source150: macros.dwz
|
Source150: macros.dwz
|
||||||
|
Source151: macros.kmp
|
||||||
Source152: macros.vpath
|
Source152: macros.vpath
|
||||||
Source153: macros.forge
|
Source153: macros.forge
|
||||||
Source154: macros.ldconfig
|
Source154: macros.ldconfig
|
||||||
Source155: macros.fedora-misc
|
Source155: macros.kernel-srpm
|
||||||
|
Source156: macros.fedora-misc
|
||||||
|
|
||||||
# Build policy scripts
|
# Build policy scripts
|
||||||
# this comes from https://github.com/rpm-software-management/rpm/pull/344
|
# this comes from https://github.com/rpm-software-management/rpm/pull/344
|
||||||
@ -51,20 +57,19 @@ Source155: macros.fedora-misc
|
|||||||
# and an echo when the mangling happens
|
# and an echo when the mangling happens
|
||||||
Source201: brp-mangle-shebangs
|
Source201: brp-mangle-shebangs
|
||||||
|
|
||||||
# this comes from rpm itself
|
|
||||||
# however, now we can do Fedora changes within
|
|
||||||
Source202: brp-python-bytecompile
|
|
||||||
|
|
||||||
# for fixing pyc files reproducibility with marshalparser
|
|
||||||
# https://github.com/fedora-python/marshalparser
|
|
||||||
Source203: brp-fix-pyc-reproducibility
|
|
||||||
|
|
||||||
# Dependency generator scripts (deprecated)
|
# Dependency generator scripts (deprecated)
|
||||||
Source300: find-provides
|
Source300: find-provides
|
||||||
|
Source301: find-provides.ksyms
|
||||||
Source304: find-requires
|
Source304: find-requires
|
||||||
|
Source305: find-requires.ksyms
|
||||||
|
Source308: firmware.prov
|
||||||
|
Source309: modalias.prov
|
||||||
|
|
||||||
# Misc helper scripts
|
# Misc helper scripts
|
||||||
Source400: dist.sh
|
Source400: dist.sh
|
||||||
|
Source401: rpmsort
|
||||||
|
Source402: symset-table
|
||||||
|
Source403: kmodtool
|
||||||
Source404: gpgverify
|
Source404: gpgverify
|
||||||
|
|
||||||
# 2016-10-02 snapshots from http://git.savannah.gnu.org/gitweb/?p=config.git
|
# 2016-10-02 snapshots from http://git.savannah.gnu.org/gitweb/?p=config.git
|
||||||
@ -72,15 +77,14 @@ Source500: config.guess
|
|||||||
Source501: config.sub
|
Source501: config.sub
|
||||||
|
|
||||||
# Dependency generators & their rules
|
# Dependency generators & their rules
|
||||||
|
Source600: kmod.attr
|
||||||
|
Source601: kmod.prov
|
||||||
Source602: libsymlink.attr
|
Source602: libsymlink.attr
|
||||||
|
|
||||||
# BRPs
|
# BRPs
|
||||||
Source700: brp-ldconfig
|
Source700: brp-ldconfig
|
||||||
Source701: brp-strip-lto
|
Source701: brp-kmod-set-exec-bit
|
||||||
|
Source702: brp-kmod-restore-perms
|
||||||
# Convenience lua functions
|
|
||||||
Source800: common.lua
|
|
||||||
Source801: forge.lua
|
|
||||||
|
|
||||||
# Documentation
|
# Documentation
|
||||||
Source900: buildflags.md
|
Source900: buildflags.md
|
||||||
@ -90,30 +94,20 @@ BuildRequires: perl-generators
|
|||||||
Requires: coreutils
|
Requires: coreutils
|
||||||
|
|
||||||
Requires: efi-srpm-macros
|
Requires: efi-srpm-macros
|
||||||
Requires: fonts-srpm-macros
|
|
||||||
Requires: ghc-srpm-macros
|
Requires: ghc-srpm-macros
|
||||||
Requires: go-srpm-macros
|
Requires: go-srpm-macros
|
||||||
# ↓ Provides kmod.attr originally shipped by us
|
|
||||||
Requires: kernel-srpm-macros >= 1.0-6
|
|
||||||
Requires: lua-srpm-macros
|
|
||||||
Requires: ocaml-srpm-macros
|
Requires: ocaml-srpm-macros
|
||||||
Requires: openblas-srpm-macros
|
Requires: openblas-srpm-macros
|
||||||
Requires: perl-srpm-macros
|
Requires: perl-srpm-macros
|
||||||
# ↓ Provides compileall2 Python module
|
Requires: python-srpm-macros
|
||||||
Requires: python-srpm-macros >= 3-46
|
Requires: python3-rpm-macros
|
||||||
Requires: qt5-srpm-macros
|
|
||||||
Requires: rust-srpm-macros
|
Requires: rust-srpm-macros
|
||||||
|
Requires: qt5-srpm-macros
|
||||||
%if ! 0%{?rhel}
|
|
||||||
Requires: fpc-srpm-macros
|
|
||||||
Requires: gnat-srpm-macros
|
|
||||||
Requires: nim-srpm-macros
|
|
||||||
%endif
|
|
||||||
|
|
||||||
Requires: rpm >= 4.11.0
|
Requires: rpm >= 4.11.0
|
||||||
Requires: dwz >= 0.4
|
Requires: dwz >= 0.4
|
||||||
Requires: zip
|
Requires: zip
|
||||||
Requires: (annobin if (gcc or clang))
|
Requires: (annobin if gcc)
|
||||||
Requires: (gcc-plugin-annobin if gcc)
|
Requires: (gcc-plugin-annobin if gcc)
|
||||||
|
|
||||||
# for brp-mangle-shebangs
|
# for brp-mangle-shebangs
|
||||||
@ -123,8 +117,13 @@ Requires: %{_bindir}/grep
|
|||||||
Requires: %{_bindir}/sed
|
Requires: %{_bindir}/sed
|
||||||
Requires: %{_bindir}/xargs
|
Requires: %{_bindir}/xargs
|
||||||
|
|
||||||
|
# iconv modules have been split out of glibc into a separate package (#1971664)
|
||||||
|
# so let's ensure packages that require them at build time but haven't yet
|
||||||
|
# added an explicit BuildRequires will continue to work (#2013328)
|
||||||
|
Requires: glibc-gconv-extra
|
||||||
|
|
||||||
# -fstack-clash-protection and -fcf-protection require GCC 8.
|
# -fstack-clash-protection and -fcf-protection require GCC 8.
|
||||||
Conflicts: gcc < 8.0.1-0.22
|
Conflicts: gcc < 8
|
||||||
|
|
||||||
Provides: system-rpm-config = %{version}-%{release}
|
Provides: system-rpm-config = %{version}-%{release}
|
||||||
|
|
||||||
@ -133,6 +132,16 @@ Provides: system-rpm-config = %{version}-%{release}
|
|||||||
%description
|
%description
|
||||||
Red Hat specific rpm configuration files.
|
Red Hat specific rpm configuration files.
|
||||||
|
|
||||||
|
%package -n kernel-rpm-macros
|
||||||
|
Summary: Macros and scripts for building kernel module packages.
|
||||||
|
Requires: redhat-rpm-config >= 13
|
||||||
|
|
||||||
|
# for brp-kmod-set-exec-bit
|
||||||
|
Requires: %{_bindir}/find
|
||||||
|
|
||||||
|
%description -n kernel-rpm-macros
|
||||||
|
Macros and scripts for building kernel module packages.
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
# Not strictly necessary but allows working on file names instead
|
# Not strictly necessary but allows working on file names instead
|
||||||
# of source numbers in install section
|
# of source numbers in install section
|
||||||
@ -145,12 +154,13 @@ install -p -m 644 -t %{buildroot}%{rrcdir} macros rpmrc
|
|||||||
install -p -m 444 -t %{buildroot}%{rrcdir} redhat-hardened-*
|
install -p -m 444 -t %{buildroot}%{rrcdir} redhat-hardened-*
|
||||||
install -p -m 444 -t %{buildroot}%{rrcdir} redhat-annobin-*
|
install -p -m 444 -t %{buildroot}%{rrcdir} redhat-annobin-*
|
||||||
install -p -m 755 -t %{buildroot}%{rrcdir} config.*
|
install -p -m 755 -t %{buildroot}%{rrcdir} config.*
|
||||||
install -p -m 755 -t %{buildroot}%{rrcdir} dist.sh
|
install -p -m 755 -t %{buildroot}%{rrcdir} dist.sh rpmsort symset-table kmodtool
|
||||||
install -p -m 755 -t %{buildroot}%{rrcdir} gpgverify
|
install -p -m 755 -t %{buildroot}%{rrcdir} gpgverify
|
||||||
install -p -m 755 -t %{buildroot}%{rrcdir} brp-*
|
install -p -m 755 -t %{buildroot}%{rrcdir} brp-*
|
||||||
|
|
||||||
install -p -m 755 -t %{buildroot}%{rrcdir} find-*
|
install -p -m 755 -t %{buildroot}%{rrcdir} find-*
|
||||||
mkdir -p %{buildroot}%{rrcdir}/find-provides.d
|
mkdir -p %{buildroot}%{rrcdir}/find-provides.d
|
||||||
|
install -p -m 755 -t %{buildroot}%{rrcdir}/find-provides.d firmware.prov modalias.prov
|
||||||
|
|
||||||
install -p -m 755 -t %{buildroot}%{rrcdir} brp-*
|
install -p -m 755 -t %{buildroot}%{rrcdir} brp-*
|
||||||
|
|
||||||
@ -159,23 +169,56 @@ install -p -m 644 -t %{buildroot}%{_rpmconfigdir}/macros.d macros.*
|
|||||||
|
|
||||||
mkdir -p %{buildroot}%{_fileattrsdir}
|
mkdir -p %{buildroot}%{_fileattrsdir}
|
||||||
install -p -m 644 -t %{buildroot}%{_fileattrsdir} *.attr
|
install -p -m 644 -t %{buildroot}%{_fileattrsdir} *.attr
|
||||||
|
install -p -m 755 -t %{buildroot}%{_rpmconfigdir} kmod.prov
|
||||||
|
|
||||||
mkdir -p %{buildroot}%{_rpmluadir}/fedora/{rpm,srpm}
|
install -p -m 644 %{SOURCE20} %{buildroot}%{_fileattrsdir}/kabi.attr
|
||||||
install -p -m 644 -t %{buildroot}%{_rpmluadir}/fedora common.lua
|
install -p -m 755 %{SOURCE21} %{buildroot}%{_rpmconfigdir}/kabi.sh
|
||||||
install -p -m 644 -t %{buildroot}%{_rpmluadir}/fedora/srpm forge.lua
|
|
||||||
|
|
||||||
# This trigger is used to decide which version of the annobin plugin for gcc
|
# This trigger is used to decide which version of the annobin plugin for gcc
|
||||||
# should be used. See comments in the script for full details.
|
# should be used. See comments in the script for full details.
|
||||||
|
#
|
||||||
|
# Note: for RHEL the rpm containing the annobin built plugin is called
|
||||||
|
# "annobin", whereas in Fedora it is called "annobin-plugin-gcc". This is
|
||||||
|
# for historical reasons and will change with the introduction of RHEL-10.
|
||||||
|
#
|
||||||
|
# Note - whilst "gcc-plugin-annobin" requires "gcc" and hence in theory we
|
||||||
|
# do not need to trigger on "gcc", the redhat-annobin-plugin-select.sh
|
||||||
|
# script invokes gcc to determine the version of the gcc plugin, and this
|
||||||
|
# can be significant.
|
||||||
|
#
|
||||||
|
# For example, suppose that version N of gcc is installed and that annobin
|
||||||
|
# version A (built by gcc version N) is also installed. Then a new version
|
||||||
|
# of gcc is released. If the rpms are updated in this order:
|
||||||
|
# gcc-plugin-annobin
|
||||||
|
# gcc
|
||||||
|
# then when the trigger for gcc-plugin-annobin is run, the script will see
|
||||||
|
# (the not yet updated) gcc is currently version N, which matches the current
|
||||||
|
# annobin plugin A, so no changes are necessary. Then gcc is updated and,
|
||||||
|
# if the trigger below did not include "gcc", the script would not run again
|
||||||
|
# and so now you would have an out of date version of the annobin plugin.
|
||||||
|
#
|
||||||
|
# Alternatively imagine installing gcc and annobin for the first time.
|
||||||
|
# If the installation order is:
|
||||||
|
# gcc
|
||||||
|
# annobin-plugin-gcc
|
||||||
|
# gcc-plugin-annobin
|
||||||
|
# then the installation of gcc will not cause the gcc-plugin-annobin to be
|
||||||
|
# selected, since it does not exist yet. Then annobin-plugin-gcc is installed
|
||||||
|
# and since it is the only plugin, it will be selected. Then
|
||||||
|
# gcc-plugin-annobin is installed, and if the trigger below was not set to
|
||||||
|
# run on gcc-plugin-annobin, it would pass unnoticed.
|
||||||
|
#
|
||||||
|
# Hence it is necessary to trigger on both gcc and gcc-plugin-annobin.
|
||||||
|
|
||||||
%triggerin -- annobin gcc-plugin-annobin
|
%triggerin -- annobin gcc-plugin-annobin gcc
|
||||||
%{rrcdir}/redhat-annobin-plugin-select.sh
|
%{rrcdir}/redhat-annobin-plugin-select.sh
|
||||||
%end
|
%end
|
||||||
|
|
||||||
# We also trigger when annobin is uninstalled. This allows us to switch
|
# We also trigger when an annobin plugin is uninstalled. This allows us to switch
|
||||||
# over to the gcc generated version of the plugin. It does not matter if
|
# over to the other version of the plugin. It does not matter if
|
||||||
# gcc is uninstalled, since if that happens the plugin cannot be used.
|
# gcc is uninstalled, since if that happens the plugin cannot be used.
|
||||||
|
|
||||||
%triggerpostun -- annobin
|
%triggerpostun -- annobin gcc-plugin-annobin
|
||||||
%{rrcdir}/redhat-annobin-plugin-select.sh
|
%{rrcdir}/redhat-annobin-plugin-select.sh
|
||||||
%end
|
%end
|
||||||
|
|
||||||
@ -183,7 +226,8 @@ install -p -m 644 -t %{buildroot}%{_rpmluadir}/fedora/srpm forge.lua
|
|||||||
%dir %{rrcdir}
|
%dir %{rrcdir}
|
||||||
%{rrcdir}/macros
|
%{rrcdir}/macros
|
||||||
%{rrcdir}/rpmrc
|
%{rrcdir}/rpmrc
|
||||||
%{rrcdir}/brp-*
|
%{rrcdir}/brp-mangle-shebangs
|
||||||
|
%{rrcdir}/brp-ldconfig
|
||||||
%{rrcdir}/dist.sh
|
%{rrcdir}/dist.sh
|
||||||
%{rrcdir}/gpgverify
|
%{rrcdir}/gpgverify
|
||||||
%{rrcdir}/redhat-hardened-*
|
%{rrcdir}/redhat-hardened-*
|
||||||
@ -193,17 +237,15 @@ install -p -m 644 -t %{buildroot}%{_rpmluadir}/fedora/srpm forge.lua
|
|||||||
%{rrcdir}/find-requires
|
%{rrcdir}/find-requires
|
||||||
%{rrcdir}/brp-ldconfig
|
%{rrcdir}/brp-ldconfig
|
||||||
%{_fileattrsdir}/*.attr
|
%{_fileattrsdir}/*.attr
|
||||||
|
%{_rpmconfigdir}/kmod.prov
|
||||||
%{_rpmconfigdir}/macros.d/macros.*-srpm
|
%{_rpmconfigdir}/macros.d/macros.*-srpm
|
||||||
%{_rpmconfigdir}/macros.d/macros.dwz
|
%{_rpmconfigdir}/macros.d/macros.dwz
|
||||||
%{_rpmconfigdir}/macros.d/macros.forge
|
%{_rpmconfigdir}/macros.d/macros.forge
|
||||||
%{_rpmconfigdir}/macros.d/macros.ldconfig
|
%{_rpmconfigdir}/macros.d/macros.ldconfig
|
||||||
%{_rpmconfigdir}/macros.d/macros.vpath
|
%{_rpmconfigdir}/macros.d/macros.vpath
|
||||||
|
%{_rpmconfigdir}/macros.d/macros.kernel-srpm
|
||||||
%{_rpmconfigdir}/macros.d/macros.fedora-misc
|
%{_rpmconfigdir}/macros.d/macros.fedora-misc
|
||||||
%dir %{_rpmluadir}/fedora
|
%{_rpmconfigdir}/kabi.sh
|
||||||
%dir %{_rpmluadir}/fedora/srpm
|
|
||||||
%dir %{_rpmluadir}/fedora/rpm
|
|
||||||
%{_rpmluadir}/fedora/*.lua
|
|
||||||
%{_rpmluadir}/fedora/srpm/*lua
|
|
||||||
|
|
||||||
%attr(0755,-,-) %{rrcdir}/redhat-annobin-plugin-select.sh
|
%attr(0755,-,-) %{rrcdir}/redhat-annobin-plugin-select.sh
|
||||||
%verify(owner group mode) %{rrcdir}/redhat-annobin-cc1
|
%verify(owner group mode) %{rrcdir}/redhat-annobin-cc1
|
||||||
@ -212,304 +254,129 @@ install -p -m 644 -t %{buildroot}%{_rpmluadir}/fedora/srpm forge.lua
|
|||||||
|
|
||||||
%doc buildflags.md
|
%doc buildflags.md
|
||||||
|
|
||||||
|
%files -n kernel-rpm-macros
|
||||||
|
%dir %{rrcdir}/find-provides.d
|
||||||
|
%{rrcdir}/brp-kmod-set-exec-bit
|
||||||
|
%{rrcdir}/brp-kmod-restore-perms
|
||||||
|
%{rrcdir}/kmodtool
|
||||||
|
%{rrcdir}/rpmsort
|
||||||
|
%{rrcdir}/symset-table
|
||||||
|
%{rrcdir}/find-provides.ksyms
|
||||||
|
%{rrcdir}/find-requires.ksyms
|
||||||
|
%{rrcdir}/find-provides.d/firmware.prov
|
||||||
|
%{rrcdir}/find-provides.d/modalias.prov
|
||||||
|
%{_rpmconfigdir}/macros.d/macros.kmp
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
* Thu Feb 17 2022 Nick Clifton <nickc@redhat.com> - 194-1
|
* Wed Feb 08 2023 Nick Clifton <nickc@redhat.com> - 131-1
|
||||||
- Use the correct package names for the triggers.
|
- Fix triggers for the installation and removal of gcc-plugin-annobin. (#2168233)
|
||||||
- Resolves: rhbz#2030671
|
|
||||||
|
|
||||||
* Tue Feb 15 2022 Nick Clifton <nickc@redhat.com> - 193-1
|
* Tue Apr 05 2022 Nick Clifton <nickc@redhat.com> = 130-1
|
||||||
- Fix bugs in plugin selection script.
|
|
||||||
- Resolves: rhbz#2030671
|
|
||||||
|
|
||||||
* Tue Feb 01 2022 Nick Clifton <nickc@redhat.com> - 192-1
|
|
||||||
- Select between gcc-built and annobin-built versions of the annobin plugin.
|
- Select between gcc-built and annobin-built versions of the annobin plugin.
|
||||||
- Resolves: rhbz#2030671
|
(#2067153)
|
||||||
|
|
||||||
* Wed Dec 08 2021 Miro Hrončok <mhroncok@redhat.com> - 191-1
|
* Wed Mar 23 2022 Michal Domonkos <mdomonko@redhat.com> - 129-1
|
||||||
- brp-mangle-shebangs: also mangle shebangs of JavaScript executables
|
- Fix handling of files without newlines in brp-mangle-shebang (#2063036)
|
||||||
- Resolves: rhbz#2030427
|
|
||||||
|
|
||||||
* Thu Dec 02 2021 Neal Gompa <ngompa@centosproject.org> - 190-1
|
* Wed Jan 05 2022 Eugene Syromiatnikov <esyr@redhat.com> - 128-1
|
||||||
- Make vpath builddir not include arch-specific info
|
- modalias.prov: handle compressed kmods, sanitise alias/version strings
|
||||||
Resolves: rhbz#1984679
|
(#1976000)
|
||||||
|
|
||||||
* Tue Nov 16 2021 Florian Weimer <fweimer@redhat.com> - 189-1
|
* Mon Dec 13 2021 Michal Domonkos <mdomonko@redhat.com> - 127-1
|
||||||
- buildflags.md: Documentation updates (#2005080)
|
- Add Requires: glibc-gconv-extras to cover for the split (#2013328)
|
||||||
|
|
||||||
* Tue Aug 24 2021 Florian Weimer <fweimer@redhat.com> - 188-1
|
* Mon Nov 29 2021 Florian Weimer <fweimer@redhat.com> - 126-1
|
||||||
- redhat-rpm-config: Enable x86-64-v2 baseline for Clang/LLVM (#1890170)
|
- buildflags.md: Documentation updates (#2005079)
|
||||||
|
|
||||||
* Tue Aug 10 2021 Mohan Boddu <mboddu@redhat.com> - 187-2
|
* Fri Nov 27 2020 Florian Festi <ffesti@redhat.com> - 125-1
|
||||||
- Rebuilt for IMA sigs, glibc 2.34, aarch64 flags
|
- Add missing macros.fedora-misc file (#1874576)
|
||||||
Related: rhbz#1991688
|
|
||||||
|
|
||||||
* Fri Jul 30 2021 Florian Weimer <fweimer@redhat.com> - 187-1
|
* Mon Nov 09 2020 Florian Festi <ffesti@redhat.com> - 124-1
|
||||||
- Active GCC plugin during LTO linking (#1983727)
|
- Add macros.kernel-srpm (#1874578)
|
||||||
|
- Added gpgverify (#1874576)
|
||||||
|
|
||||||
* Thu Jul 22 2021 Florian Weimer <fweimer@redhat.com> - 186-1
|
* Tue Jun 16 2020 Florian Festi <ffesti@redhat.com> - 123-1
|
||||||
- aarch64: Do not build with -mbranch-protection=standard (#1984652)
|
- Update kmod.prov for better performance (#1794491)
|
||||||
|
- Backport performance improvements for brp-mangle-shebangs (#1794779)
|
||||||
|
|
||||||
* Tue May 25 2021 Michal Domonkos <mdomonko@redhat.com> - 185-3
|
* Mon Feb 24 2020 Michal Domonkos <mdomonko@redhat.com> - 122-1
|
||||||
- Bump release for a rebuild in a sidetag
|
- Fix argument shift in %%__brp_python_bytecompile (#1724567)
|
||||||
|
|
||||||
* Wed May 12 2021 Michal Domonkos <mdomonko@redhat.com> - 185-1
|
* Tue Nov 26 2019 Eugene Syromiatnikov <esyr@redhat.com> - 121-1
|
||||||
- Drop kernel-rpm-macros subpackage & kmod.attr
|
- macros.kmp: add post-install hooks for kmod processing (#1664478, #1673200)
|
||||||
- Resolves: #1959924
|
|
||||||
|
|
||||||
* Wed Apr 21 2021 Michal Domonkos <mdomonko@redhat.com> - 184-1
|
* Thu Jul 04 2019 Florian Festi <ffesti@redhat.com> - 120-1
|
||||||
- Drop {fpc,gnat,nim}-srpm-macros dependencies on RHEL
|
- Fix permission for various build scripts (#1719363)
|
||||||
|
|
||||||
* Fri Apr 16 2021 Mohan Boddu <mboddu@redhat.com> - 183-2
|
* Tue Jun 04 2019 Florian Festi <ffesti@redhat.com> - 119-1
|
||||||
- Rebuilt for RHEL 9 BETA on Apr 15th 2021. Related: rhbz#1947937
|
- Remove -eu param from shell scripts (#1686413)
|
||||||
|
|
||||||
* Thu Apr 15 2021 Florian Weimer <fweimer@redhat.com> - 183-1
|
* Mon May 20 2019 Florian Weimer <fweimer@redhat.com> - 118-1
|
||||||
- ppc64le: Update ISA baseline to POWER9 (#1876584)
|
- Build flags: Add support for extension builders (#1661186)
|
||||||
- s390x: Update ISA baseline to z14 (#1876479)
|
|
||||||
|
|
||||||
* Mon Mar 22 2021 Lumír Balhar <lbalhar@redhat.com> - 182-1
|
* Wed Apr 17 2019 Panu Matilainen <pmatilai@redhat.com> - 117-1
|
||||||
- Fix handling of files without newlines in brp-mangle-shebang
|
- Add s390x to valgrind supported architectures (#1659106)
|
||||||
|
|
||||||
* Wed Mar 10 2021 Kalev Lember <klember@redhat.com> - 181-1
|
* Wed Feb 06 2019 Eugene Syromiatnikov <esyr@redhat.com> - 116-1
|
||||||
- BRP Python Bytecompile: Avoid hardcoding /usr/bin prefix for python
|
- Forward-port RHEL-specific kmodtool/macros.kmp changes from RHEL 7,
|
||||||
|
update kmodtool script for RHEL 8 (#1658414, #1666162)
|
||||||
|
|
||||||
* Tue Jan 19 2021 Florian Weimer <fweimer@redhat.com> - 180-1
|
* Sat Sep 15 2018 Eugene Syromiatnikov <esyr@redhat.com> - 115-1
|
||||||
- Use -march=x86-64-v2 only for the gcc toolchain
|
- Revert back to usage of join in find-requires.ksym:mod_requires()
|
||||||
|
as generated "Requires:" and "Provides:" lists have different format
|
||||||
|
and unsuitable for processing with comm (#1622016)
|
||||||
|
|
||||||
* Tue Jan 19 2021 Florian Weimer <fweimer@redhat.com> - 179-1
|
* Fri Aug 24 2018 Eugene Syromiatnikov <esyr@redhat.com> - 114-1
|
||||||
- x86_64: Enable -march=x86-64-v2 for ELN, following GCC.
|
- Add support for compressed kernel modules to find-provides,
|
||||||
|
find-provides.ksyms, find-requires, find-requires.ksyms, firmware.prov
|
||||||
|
(#1622019)
|
||||||
|
|
||||||
* Sun Nov 29 2020 Miro Hrončok <mhroncok@redhat.com> - 178-1
|
* Mon Aug 20 2018 Eugene Syromiatnikov <esyr@redhat.com> - 113-1
|
||||||
- BRP Python Bytecompile: Also detect Python files in /app/lib/pythonX.Y
|
- Fix generation for kernel module symbol version dependencies for the case
|
||||||
|
when module depends on the symbol with the same name as one present in kernel
|
||||||
|
but a different version (#1622016)
|
||||||
|
|
||||||
* Tue Oct 27 2020 Tom Stellard <tstellar@redhat.com> - 177-1
|
* Mon Aug 13 2018 Eugene Syromiatnikov <esyr@redhat.com> - 112-1
|
||||||
- Add back -fcf-protection flag for x86_64
|
- Re-instantiate support for old symvers path (#1571186)
|
||||||
|
|
||||||
* Tue Oct 20 2020 Florian Weimer <fweimer@redhat.com> - 176-1
|
* Mon Aug 13 2018 Eugene Syromiatnikov <esyr@redhat.com> - 111-1
|
||||||
- s390x: Tune for z14 (as in Red Hat Enterprise Linux 8)
|
- Add dependency generator for kABI provides (#1571186)
|
||||||
|
|
||||||
* Mon Oct 5 2020 Florian Weimer <fweimer@redhat.com> - 175-1
|
* Thu Aug 9 2018 Marek Polacek <polacek@redhat.com> - 110-1
|
||||||
- s390x: Switch Fedora ELN to z13 baseline
|
- Use -march=z13 -mtune=z14 for s390{,x} (#1573944)
|
||||||
|
- Drop s390x from %%{valgrind_arches}
|
||||||
|
|
||||||
* Fri Sep 11 2020 Miro Hrončok <mhroncok@redhat.com> - 172-1
|
* Mon Jul 23 2018 Peter Jones <pjones@redhat.com> - 109-1
|
||||||
- Filter out LTO flags from %%extension flags macros
|
- Add Requires: efi-srpm-macros for %%{efi}
|
||||||
- Fixes: rhbz#1877652
|
|
||||||
|
|
||||||
* Wed Sep 2 2020 Michel Alexandre Salim <salimma@fedoraproject.org> - 171-1
|
|
||||||
- Add Requires: lua-srpm-macros
|
|
||||||
|
|
||||||
* Fri Aug 21 2020 Tom Stellard <tstellar@redhat.com> - 170-1
|
|
||||||
- Enable -fstack-clash-protection for clang on x86, s390x, and ppc64le
|
|
||||||
|
|
||||||
* Thu Aug 20 2020 Tom Stellard <tstellar@redhat.com> - 169-1
|
|
||||||
- Add -flto to ldflags for clang toolchain
|
|
||||||
|
|
||||||
* Thu Aug 20 2020 Neal Gompa <ngompa13@gmail.com> - 168-1
|
|
||||||
- Fix CC/CXX exports so arguments are included in exported variable
|
|
||||||
- Allow overrides of CC/CXX like CFLAGS and CXXFLAGS from shell variables
|
|
||||||
|
|
||||||
* Mon Aug 03 2020 Troy Dawson <tdawson@redhat.com> - 167-1
|
|
||||||
- Add Requires: kernel-srpm-macros
|
|
||||||
|
|
||||||
* Thu Jul 30 2020 Jeff Law <law@redhat.com> - 166-1
|
|
||||||
- Use -flto=auto for GCC to speed up builds
|
|
||||||
|
|
||||||
* Tue Jul 28 2020 Tom Stellard <tstellar@redhat.com> - 165-1
|
|
||||||
- Only use supported lto flags for clang toolchain
|
|
||||||
|
|
||||||
* Thu Jul 23 2020 Lumír Balhar <lbalhar@redhat.com> - 164-1
|
|
||||||
- Disable Python hash seed randomization in brp-python-bytecompile
|
|
||||||
|
|
||||||
* Tue Jul 21 2020 Jeff Law <law@redhat.com> - 163-1
|
|
||||||
- Enable LTO by default
|
|
||||||
|
|
||||||
* Thu Jul 16 2020 Lumír Balhar <lbalhar@redhat.com> - 162-1
|
|
||||||
- New script brp-fix-pyc-reproducibility
|
|
||||||
|
|
||||||
* Tue Jun 16 2020 Lumír Balhar <lbalhar@redhat.com> - 161-2
|
|
||||||
- Use stdlib compileall for Python >= 3.9
|
|
||||||
|
|
||||||
* Mon Jun 15 2020 Lumír Balhar <lbalhar@redhat.com> - 161-1
|
|
||||||
- No more automagic Python bytecompilation (phase 3)
|
|
||||||
https://fedoraproject.org/wiki/Changes/No_more_automagic_Python_bytecompilation_phase_3
|
|
||||||
|
|
||||||
* Thu Jun 04 2020 Igor Raits <ignatenkobrain@fedoraproject.org> - 160-1
|
|
||||||
- Fix broken %%configure
|
|
||||||
|
|
||||||
* Wed Jun 03 2020 Igor Raits <ignatenkobrain@fedoraproject.org> - 159-1
|
|
||||||
- Fixes for new_package macro
|
|
||||||
|
|
||||||
* Wed Jun 03 2020 Igor Raits <ignatenkobrain@fedoraproject.org> - 158-1
|
|
||||||
- Add option to choose C/C++ toolchain
|
|
||||||
|
|
||||||
* Sat May 30 2020 Jeff Law <law@redhat.com> - 157-1
|
|
||||||
- When LTO is enabled, fix broken configure files.
|
|
||||||
|
|
||||||
* Sat May 30 2020 Nicolas Mailhot <nim@fedoraproject.org> - 156-1
|
|
||||||
- Add new_package macro and associated lua framework.
|
|
||||||
|
|
||||||
* Sat May 23 2020 Nicolas Mailhot <nim@fedoraproject.org> - 155-1
|
|
||||||
- forge: add gitea support
|
|
||||||
|
|
||||||
* Thu Apr 09 2020 Panu Matilainen <pmatilai@redhat.com> - 154-1
|
|
||||||
- Optimize kernel module provides by using a parametric generator
|
|
||||||
|
|
||||||
* Thu Feb 20 2020 Jason L Tibbitts III <tibbs@math.uh.edu> - 153-1
|
|
||||||
- Add dependency on fonts-srpm-macros, as those have now been approved by FPC.
|
|
||||||
|
|
||||||
* Thu Feb 20 2020 Jeff Law <law@redhat.com> - 152-1
|
|
||||||
- Use eu-elfclassify to only run strip on ELF relocatables
|
|
||||||
and archive libraries.
|
|
||||||
|
|
||||||
* Fri Feb 14 2020 Igor Raits <ignatenkobrain@fedoraproject.org> - 151-1
|
|
||||||
- Fixup parallel algorithm for brp-strip-lto
|
|
||||||
|
|
||||||
* Fri Feb 14 2020 Jeff Law <law@redhat.com> - 150-1
|
|
||||||
- Strip LTO sections/symbols from installed .o/.a files
|
|
||||||
|
|
||||||
* Thu Jan 23 2020 Jeff Law <law@redhat.com> - 149-1
|
|
||||||
- Allow conditionally adding -fcommon to CFLAGS by defining %%_legacy_common_support
|
|
||||||
|
|
||||||
* Mon Jan 20 2020 Florian Weimer <fweimer@redhat.com> - 148-1
|
|
||||||
- Reenable annobin after GCC 10 integration (#1792892)
|
|
||||||
|
|
||||||
* Mon Jan 20 2020 Florian Weimer <fweimer@redhat.com> - 147-1
|
|
||||||
- Temporarily disable annobin for GCC 10 (#1792892)
|
|
||||||
|
|
||||||
* Thu Dec 05 2019 Denys Vlasenko <dvlasenk@redhat.com> - 146-1
|
|
||||||
- kmod.prov: fix and speed it up
|
|
||||||
|
|
||||||
* Tue Dec 03 15:48:18 CET 2019 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 145-1
|
|
||||||
- %%set_build_flags: define LT_SYS_LIBRARY_PATH
|
|
||||||
|
|
||||||
* Thu Nov 21 2019 Denys Vlasenko <dvlasenk@redhat.com> - 144-1
|
|
||||||
- Speed up brp-mangle-shebangs.
|
|
||||||
|
|
||||||
* Tue Nov 05 2019 Lumír Balhar <lbalhar@redhat.com> - 143-1
|
|
||||||
- Fix brp-python-bytecompile with the new features from compileall2
|
|
||||||
- Resolves: rhbz#1595265
|
|
||||||
|
|
||||||
* Fri Nov 01 2019 Miro Hrončok <mhroncok@redhat.com> - 142-1
|
|
||||||
- Fix the simple API of %%gpgverify.
|
|
||||||
|
|
||||||
* Thu Aug 22 2019 Jason L Tibbitts III <tibbs@math.uh.edu> - 141-2
|
|
||||||
- Simplify the API of %%gpgverify.
|
|
||||||
|
|
||||||
* Thu Jul 25 2019 Richard W.M. Jones <rjones@redhat.com> - 140-2
|
|
||||||
- Bump version and rebuild.
|
|
||||||
|
|
||||||
* Sat Jul 20 2019 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 140-1
|
|
||||||
- Fixup python-srpm-macros version
|
|
||||||
|
|
||||||
* Wed Jul 17 2019 Lumír Balhar <lbalhar@redhat.com> - 139-1
|
|
||||||
- Use compileall2 Python module for byte-compilation in brp-python-bytecompile
|
|
||||||
|
|
||||||
* Tue Jul 09 2019 Miro Hrončok <mhroncok@redhat.com> - 138-1
|
|
||||||
- Move brp-python-bytecompile from rpm, so we can easily adapt it
|
|
||||||
|
|
||||||
* Mon Jul 08 2019 Nicolas Mailhot <nim@fedoraproject.org> - 137-1
|
|
||||||
- listfiles: make it robust against all kinds of “interesting” inputs
|
|
||||||
- wordwrap: make list indenting smarter, to produce something with enough
|
|
||||||
structure that it can be converted into AppStream metadata
|
|
||||||
|
|
||||||
* Mon Jul 08 2019 Robert-André Mauchin <zebob.m@gmail.com> - 136-1
|
|
||||||
- Revert "Fix expansion in listfiles_exclude/listfiles_include"
|
|
||||||
|
|
||||||
* Mon Jul 08 2019 Nicolas Mailhot <nim@fedoraproject.org> - 135-1
|
|
||||||
- Fix expansion in listfiles_exclude/listfiles_include
|
|
||||||
|
|
||||||
* Mon Jul 01 2019 Florian Festi <ffesti@redhat.com> - 134-1
|
|
||||||
- Switch binary payload compression to Zstandard level 19
|
|
||||||
|
|
||||||
* Thu Jun 27 2019 Vít Ondruch <vondruch@redhat.com> - 133-2
|
|
||||||
- Enable RPM to set SOURCE_DATE_EPOCH environment variable.
|
|
||||||
|
|
||||||
* Tue Jun 25 08:13:50 CEST 2019 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 133-1
|
|
||||||
- Expand listfiles_exclude/listfiles_include
|
|
||||||
|
|
||||||
* Tue Jun 11 2019 Jitka Plesnikova <jplesnik@redhat.com> - 132-1
|
|
||||||
- Remove perl macro refugees
|
|
||||||
|
|
||||||
* Mon Jun 10 2019 Panu Matilainen <pmatilai@redhat.com> - 131-1
|
|
||||||
- Provide temporary shelter for rpm 4.15 perl macro refugees
|
|
||||||
|
|
||||||
* Tue Jun 04 2019 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 130-1
|
|
||||||
- New macro for wrapping text — %%wordwrap
|
|
||||||
- Smal fix for %%listfiles with no arguments
|
|
||||||
|
|
||||||
* Thu May 30 2019 Björn Persson <Bjorn@Rombobjörn.se> - 129-1
|
|
||||||
- Added gpgverify.
|
|
||||||
|
|
||||||
* Tue Jan 15 2019 Panu Matilainen <pmatilai@redhat.com> - 128-1
|
|
||||||
- Drop redundant _smp_mflag re-definition, use the one from rpm instead
|
|
||||||
|
|
||||||
* Thu Dec 20 2018 Florian Weimer <fweimer@redhat.com> - 127-1
|
|
||||||
- Build flags: Add support for extension builders (#1543394)
|
|
||||||
|
|
||||||
* Mon Dec 17 2018 Panu Matilainen <pmatilai@redhat.com> - 126-1
|
|
||||||
- Silence the annoying warning from ldconfig brp-script (#1540971)
|
|
||||||
|
|
||||||
* Thu Nov 15 2018 Miro Hrončok <mhroncok@redhat.com> - 125-1
|
|
||||||
- Make automagic Python bytecompilation optional
|
|
||||||
https://fedoraproject.org/wiki/Changes/No_more_automagic_Python_bytecompilation_phase_2
|
|
||||||
|
|
||||||
* Thu Nov 08 2018 Jason L Tibbitts III <tibbs@math.uh.edu> - 124-1
|
|
||||||
- forge: add more distprefix cleaning (bz1646724)
|
|
||||||
|
|
||||||
* Mon Oct 22 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 123-1
|
|
||||||
- Add -q option to %%forgesetup
|
|
||||||
|
|
||||||
* Sat Oct 20 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 122-1
|
|
||||||
- Allow multiple calls to forge macros
|
|
||||||
|
|
||||||
* Thu Oct 11 2018 Jan Pazdziora <jpazdziora@redhat.com> - 121-1
|
|
||||||
- Add %_swidtagdir for directory for SWID tag files describing the
|
|
||||||
installation.
|
|
||||||
|
|
||||||
* Mon Sep 10 2018 Miro Hrončok <mhroncok@redhat.com> - 120-1
|
|
||||||
- Make ambiguous python shebangs error
|
|
||||||
https://fedoraproject.org/wiki/Changes/Make_ambiguous_python_shebangs_error
|
|
||||||
|
|
||||||
* Mon Aug 20 2018 Kalev Lember <klember@redhat.com> - 119-1
|
|
||||||
- Add aarch64 to ldc arches
|
|
||||||
|
|
||||||
* Wed Aug 15 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 118-1
|
|
||||||
- Enable --as-needed by default
|
|
||||||
|
|
||||||
* Mon Jul 16 2018 Miro Hrončok <mhroncok@redhat.com> - 117-1
|
|
||||||
- Mangle /bin shebnags to /usr/bin ones (#1581757)
|
|
||||||
|
|
||||||
* Tue Jul 10 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 116-1
|
|
||||||
- Add option to add -Wl,--as-needed into LDFLAGS
|
|
||||||
|
|
||||||
* Mon Jul 09 2018 Kalev Lember <klember@redhat.com> - 115-1
|
|
||||||
- Disable non-functional ppc64 support for ldc packages
|
|
||||||
|
|
||||||
* Tue Jun 26 2018 Panu Matilainen <pmatilai@redhat.com> - 114-1
|
|
||||||
- Fix kernel ABI related strings (Peter Oros, #26)
|
|
||||||
- Automatically trim changelog to two years (Zbigniew Jędrzejewski-Szmek, #22)
|
|
||||||
- Cosmetics cleanups (Zbigniew Jędrzejewski-Szmek, #22)
|
|
||||||
|
|
||||||
* Mon Jun 18 2018 Florian Weimer <fweimer@redhat.com> - 113-1
|
|
||||||
- Build flags: Require SSE2 on i686 (#1592212)
|
|
||||||
|
|
||||||
* Mon May 28 2018 Miro Hrončok <mhroncok@redhat.com> - 112-1
|
|
||||||
- Add a possibility to opt-out form automagic Python bytecompilation
|
|
||||||
https://fedoraproject.org/wiki/Changes/No_more_automagic_Python_bytecompilation
|
|
||||||
|
|
||||||
* Wed May 02 2018 Peter Jones <pjones@redhat.com> - 111-1
|
|
||||||
- brp-mangle-shebangs: add %%{__brp_mangle_shebangs_exclude_file} and
|
- brp-mangle-shebangs: add %%{__brp_mangle_shebangs_exclude_file} and
|
||||||
%%{__brp_mangle_shebangs_exclude_from_file} to allow you to specify files
|
%%{__brp_mangle_shebangs_exclude_from_file} to allow you to specify files
|
||||||
containing the shebangs to be ignore and files to be ignored regexps,
|
containing the shebangs to be ignore and files to be ignored regexps,
|
||||||
respectively, so that they can be generated during the package build.
|
respectively, so that they can be generated during the package build.
|
||||||
|
|
||||||
* Wed May 2 2018 Florian Weimer <fweimer@redhat.com> - 110-1
|
* Mon Jul 09 2018 Tomas Orsava <torsava@redhat.com> - 108-1
|
||||||
- Reflect -fasynchronous-unwind-tables GCC default on POWER (#1550914)
|
- Impement changing python3 shebangs in brp-mangle-shebangs
|
||||||
|
- Added a dependency on python3-rpm-macros
|
||||||
|
|
||||||
* Wed May 2 2018 Florian Weimer <fweimer@redhat.com> - 109-1
|
* Tue Jul 03 2018 Tomas Orsava <torsava@redhat.com> - 107.3-3.1
|
||||||
- Use plain -fcf-protection compiler flag, without -mcet (#1570823)
|
- Bump release
|
||||||
|
|
||||||
* Tue May 01 2018 Peter Jones <pjones@redhat.com> - 108-1
|
* Thu Jun 28 2018 Tomas Orsava <torsava@redhat.com> - 107.3-3
|
||||||
- Add Requires: efi-srpm-macros for %%{efi}
|
- The brp-python-bytecompile script no longer accepts two arguments, as the
|
||||||
|
first argument has been obsoleted
|
||||||
|
- Modified the definition of %%__brp_python_bytecompile to match the new scheme
|
||||||
|
|
||||||
|
* Thu Jun 28 2018 Florian Festi <ffesti@redhat.com> - 107.3-2
|
||||||
|
- Replace find-provides.ksyms and find-requires.ksyms by RHEL 7.6 versions (#1571186)
|
||||||
|
|
||||||
|
* Thu Jun 07 2018 Florian Festi <ffesti@redhat.com> - 107.3-1
|
||||||
|
- Remove dependencies to fpc-srpm-macros, gnat-srpm-macros and nim-srpm-macros
|
||||||
|
|
||||||
|
* Fri Jun 1 2018 Florian Weimer <fweimer@redhat.com> - 107.2-1
|
||||||
|
- i686: Build with -mstackrealign (#1478332)
|
||||||
|
- Update documentation for i686 build flags (#1554855)
|
||||||
|
|
||||||
|
* Fri May 4 2018 Florian Weimer <fweimer@redhat.com> - 107.1-1
|
||||||
|
- Use plain -fcf-protection compiler flag, without -mcet (#1574937)
|
||||||
|
|
||||||
* Fri Apr 20 2018 Jason L Tibbitts III <tibbs@math.uh.edu> - 107-1
|
* Fri Apr 20 2018 Jason L Tibbitts III <tibbs@math.uh.edu> - 107-1
|
||||||
- Add %%_metainfodir macro.
|
- Add %%_metainfodir macro.
|
||||||
|
Loading…
Reference in New Issue
Block a user