f39ad01943
So apparently we've been enabling CONFIG_NAMESPACES in Fedora kernels for a very long time even though it was never explicitly set. The kconfig entry for it looks like it should depend on CONFIG_EXPERT (which isn't set), but either the fact that we've had CONFIG_NET_NS, etc enabled explicitly or the fact that it defaults to !EXPERT seems to do something weird with menuconfig and enables it in the final config. Whatever, just turn it back on. It seems to break rtkit-daemon for some reason.
2535 lines
76 KiB
RPMSpec
2535 lines
76 KiB
RPMSpec
# We have to override the new %%install behavior because, well... the kernel is special.
|
|
%global __spec_install_pre %{___build_pre}
|
|
|
|
Summary: The Linux kernel
|
|
|
|
# For a stable, released kernel, released_kernel should be 1. For rawhide
|
|
# and/or a kernel built from an rc or git snapshot, released_kernel should
|
|
# be 0.
|
|
%global released_kernel 0
|
|
|
|
# Sign modules on x86. Make sure the config files match this setting if more
|
|
# architectures are added.
|
|
%ifarch %{ix86} x86_64
|
|
%global signmodules 1
|
|
%else
|
|
%global signmodules 0
|
|
%endif
|
|
|
|
# Save original buildid for later if it's defined
|
|
%if 0%{?buildid:1}
|
|
%global orig_buildid %{buildid}
|
|
%undefine buildid
|
|
%endif
|
|
|
|
###################################################################
|
|
# Polite request for people who spin their own kernel rpms:
|
|
# please modify the "buildid" define in a way that identifies
|
|
# that the kernel isn't the stock distribution kernel, for example,
|
|
# by setting the define to ".local" or ".bz123456". This will be
|
|
# appended to the full kernel version.
|
|
#
|
|
# (Uncomment the '#' and both spaces below to set the buildid.)
|
|
#
|
|
# % define buildid .local
|
|
###################################################################
|
|
|
|
# The buildid can also be specified on the rpmbuild command line
|
|
# by adding --define="buildid .whatever". If both the specfile and
|
|
# the environment define a buildid they will be concatenated together.
|
|
%if 0%{?orig_buildid:1}
|
|
%if 0%{?buildid:1}
|
|
%global srpm_buildid %{buildid}
|
|
%define buildid %{srpm_buildid}%{orig_buildid}
|
|
%else
|
|
%define buildid %{orig_buildid}
|
|
%endif
|
|
%endif
|
|
|
|
# baserelease defines which build revision of this kernel version we're
|
|
# building. We used to call this fedora_build, but the magical name
|
|
# baserelease is matched by the rpmdev-bumpspec tool, which you should use.
|
|
#
|
|
# We used to have some extra magic weirdness to bump this automatically,
|
|
# but now we don't. Just use: rpmdev-bumpspec -c 'comment for changelog'
|
|
# When changing base_sublevel below or going from rc to a final kernel,
|
|
# reset this by hand to 1 (or to 0 and then use rpmdev-bumpspec).
|
|
# scripts/rebase.sh should be made to do that for you, actually.
|
|
#
|
|
# NOTE: baserelease must be > 0 or bad things will happen if you switch
|
|
# to a released kernel (released version will be < rc version)
|
|
#
|
|
# For non-released -rc kernels, this will be appended after the rcX and
|
|
# gitX tags, so a 3 here would become part of release "0.rcX.gitX.3"
|
|
#
|
|
%global baserelease 3
|
|
%global fedora_build %{baserelease}
|
|
|
|
# base_sublevel is the kernel version we're starting with and patching
|
|
# on top of -- for example, 3.1-rc7-git1 starts with a 3.0 base,
|
|
# which yields a base_sublevel of 0.
|
|
%define base_sublevel 7
|
|
|
|
## If this is a released kernel ##
|
|
%if 0%{?released_kernel}
|
|
|
|
# Do we have a -stable update to apply?
|
|
%define stable_update 0
|
|
# Is it a -stable RC?
|
|
%define stable_rc 0
|
|
# Set rpm version accordingly
|
|
%if 0%{?stable_update}
|
|
%define stablerev %{stable_update}
|
|
%define stable_base %{stable_update}
|
|
%if 0%{?stable_rc}
|
|
# stable RCs are incremental patches, so we need the previous stable patch
|
|
%define stable_base %(echo $((%{stable_update} - 1)))
|
|
%endif
|
|
%endif
|
|
%define rpmversion 3.%{base_sublevel}.%{stable_update}
|
|
|
|
## The not-released-kernel case ##
|
|
%else
|
|
# The next upstream release sublevel (base_sublevel+1)
|
|
%define upstream_sublevel %(echo $((%{base_sublevel} + 1)))
|
|
# The rc snapshot level
|
|
%define rcrev 6
|
|
# The git snapshot level
|
|
%define gitrev 3
|
|
# Set rpm version accordingly
|
|
%define rpmversion 3.%{upstream_sublevel}.0
|
|
%endif
|
|
# Nb: The above rcrev and gitrev values automagically define Patch00 and Patch01 below.
|
|
|
|
# What parts do we want to build? We must build at least one kernel.
|
|
# These are the kernels that are built IF the architecture allows it.
|
|
# All should default to 1 (enabled) and be flipped to 0 (disabled)
|
|
# by later arch-specific checks.
|
|
|
|
# The following build options are enabled by default.
|
|
# Use either --without <opt> in your rpmbuild command or force values
|
|
# to 0 in here to disable them.
|
|
#
|
|
# standard kernel
|
|
%define with_up %{?_without_up: 0} %{?!_without_up: 1}
|
|
# kernel-smp (only valid for ppc 32-bit)
|
|
%define with_smp %{?_without_smp: 0} %{?!_without_smp: 1}
|
|
# kernel-PAE (only valid for i686)
|
|
%define with_pae %{?_without_pae: 0} %{?!_without_pae: 1}
|
|
# kernel-debug
|
|
%define with_debug %{?_without_debug: 0} %{?!_without_debug: 1}
|
|
# kernel-doc
|
|
%define with_doc %{?_without_doc: 0} %{?!_without_doc: 1}
|
|
# kernel-headers
|
|
%define with_headers %{?_without_headers: 0} %{?!_without_headers: 1}
|
|
# perf
|
|
%define with_perf %{?_without_perf: 0} %{?!_without_perf: 1}
|
|
# tools
|
|
%define with_tools %{?_without_tools: 0} %{?!_without_tools: 1}
|
|
# kernel-debuginfo
|
|
%define with_debuginfo %{?_without_debuginfo: 0} %{?!_without_debuginfo: 1}
|
|
# kernel-bootwrapper (for creating zImages from kernel + initrd)
|
|
%define with_bootwrapper %{?_without_bootwrapper: 0} %{?!_without_bootwrapper: 1}
|
|
# Want to build a the vsdo directories installed
|
|
%define with_vdso_install %{?_without_vdso_install: 0} %{?!_without_vdso_install: 1}
|
|
# ARM OMAP (Beagle/Panda Board)
|
|
%define with_omap %{?_without_omap: 0} %{?!_without_omap: 1}
|
|
# kernel-tegra (only valid for arm)
|
|
%define with_tegra %{?_without_tegra: 0} %{?!_without_tegra: 1}
|
|
# kernel-kirkwood (only valid for arm)
|
|
%define with_kirkwood %{?_without_kirkwood: 0} %{?!_without_kirkwood: 1}
|
|
#
|
|
# Additional options for user-friendly one-off kernel building:
|
|
#
|
|
# Only build the base kernel (--with baseonly):
|
|
%define with_baseonly %{?_with_baseonly: 1} %{?!_with_baseonly: 0}
|
|
# Only build the smp kernel (--with smponly):
|
|
%define with_smponly %{?_with_smponly: 1} %{?!_with_smponly: 0}
|
|
# Only build the pae kernel (--with paeonly):
|
|
%define with_paeonly %{?_with_paeonly: 1} %{?!_with_paeonly: 0}
|
|
# Only build the debug kernel (--with dbgonly):
|
|
%define with_dbgonly %{?_with_dbgonly: 1} %{?!_with_dbgonly: 0}
|
|
#
|
|
# should we do C=1 builds with sparse
|
|
%define with_sparse %{?_with_sparse: 1} %{?!_with_sparse: 0}
|
|
#
|
|
# build a release kernel on rawhide
|
|
%define with_release %{?_with_release: 1} %{?!_with_release: 0}
|
|
|
|
# Set debugbuildsenabled to 1 for production (build separate debug kernels)
|
|
# and 0 for rawhide (all kernels are debug kernels).
|
|
# See also 'make debug' and 'make release'.
|
|
%define debugbuildsenabled 0
|
|
|
|
# Want to build a vanilla kernel build without any non-upstream patches?
|
|
%define with_vanilla %{?_with_vanilla: 1} %{?!_with_vanilla: 0}
|
|
|
|
# Build the kernel-doc package, but don't fail the build if it botches.
|
|
# Here "true" means "continue" and "false" means "fail the build".
|
|
%if 0%{?released_kernel}
|
|
%define doc_build_fail false
|
|
%else
|
|
%define doc_build_fail true
|
|
%endif
|
|
|
|
%define rawhide_skip_docs 1
|
|
%if 0%{?rawhide_skip_docs}
|
|
%define with_doc 0
|
|
%define doc_build_fail true
|
|
%endif
|
|
|
|
# pkg_release is what we'll fill in for the rpm Release: field
|
|
%if 0%{?released_kernel}
|
|
|
|
%if 0%{?stable_rc}
|
|
%define stable_rctag .rc%{stable_rc}
|
|
%define pkg_release 0%{stable_rctag}.%{fedora_build}%{?buildid}%{?dist}
|
|
%else
|
|
%define pkg_release %{fedora_build}%{?buildid}%{?dist}
|
|
%endif
|
|
|
|
%else
|
|
|
|
# non-released_kernel
|
|
%if 0%{?rcrev}
|
|
%define rctag .rc%rcrev
|
|
%else
|
|
%define rctag .rc0
|
|
%endif
|
|
%if 0%{?gitrev}
|
|
%define gittag .git%gitrev
|
|
%else
|
|
%define gittag .git0
|
|
%endif
|
|
%define pkg_release 0%{?rctag}%{?gittag}.%{fedora_build}%{?buildid}%{?dist}
|
|
|
|
%endif
|
|
|
|
# The kernel tarball/base version
|
|
%define kversion 3.%{base_sublevel}
|
|
|
|
%define make_target bzImage
|
|
|
|
%define KVERREL %{version}-%{release}.%{_target_cpu}
|
|
%define hdrarch %_target_cpu
|
|
%define asmarch %_target_cpu
|
|
|
|
%if 0%{!?nopatches:1}
|
|
%define nopatches 0
|
|
%endif
|
|
|
|
%if %{with_vanilla}
|
|
%define nopatches 1
|
|
%endif
|
|
|
|
%if %{nopatches}
|
|
%define with_bootwrapper 0
|
|
%define variant -vanilla
|
|
%else
|
|
%define variant_fedora -fedora
|
|
%endif
|
|
|
|
%define using_upstream_branch 0
|
|
%if 0%{?upstream_branch:1}
|
|
%define stable_update 0
|
|
%define using_upstream_branch 1
|
|
%define variant -%{upstream_branch}%{?variant_fedora}
|
|
%define pkg_release 0.%{fedora_build}%{upstream_branch_tag}%{?buildid}%{?dist}
|
|
%endif
|
|
|
|
%if !%{debugbuildsenabled}
|
|
%define with_debug 0
|
|
%endif
|
|
|
|
%if !%{with_debuginfo}
|
|
%define _enable_debug_packages 0
|
|
%endif
|
|
%define debuginfodir /usr/lib/debug
|
|
|
|
# kernel-PAE is only built on i686.
|
|
%ifnarch i686
|
|
%define with_pae 0
|
|
%endif
|
|
|
|
# kernel up (unified kernel target), tegra and omap are only built on armv7 hfp/sfp
|
|
%ifnarch armv7hl armv7l
|
|
%define with_omap 0
|
|
%define with_tegra 0
|
|
%endif
|
|
|
|
# kernel-kirkwood is only built for armv5
|
|
%ifnarch armv5tel
|
|
%define with_kirkwood 0
|
|
%endif
|
|
|
|
# if requested, only build base kernel
|
|
%if %{with_baseonly}
|
|
%define with_smp 0
|
|
%define with_pae 0
|
|
%define with_debug 0
|
|
%endif
|
|
|
|
# if requested, only build smp kernel
|
|
%if %{with_smponly}
|
|
%define with_up 0
|
|
%define with_pae 0
|
|
%define with_debug 0
|
|
%endif
|
|
|
|
# if requested, only build pae kernel
|
|
%if %{with_paeonly}
|
|
%define with_up 0
|
|
%define with_smp 0
|
|
%define with_debug 0
|
|
%endif
|
|
|
|
# if requested, only build debug kernel
|
|
%if %{with_dbgonly}
|
|
%if %{debugbuildsenabled}
|
|
%define with_up 0
|
|
%define with_pae 0
|
|
%endif
|
|
%define with_smp 0
|
|
%define with_pae 0
|
|
%define with_tools 0
|
|
%define with_perf 0
|
|
%endif
|
|
|
|
%define all_x86 i386 i686
|
|
|
|
%if %{with_vdso_install}
|
|
# These arches install vdso/ directories.
|
|
%define vdso_arches %{all_x86} x86_64 ppc ppc64 ppc64p7 s390 s390x
|
|
%endif
|
|
|
|
# Overrides for generic default options
|
|
|
|
# only ppc needs a separate smp kernel
|
|
%ifnarch ppc
|
|
%define with_smp 0
|
|
%endif
|
|
|
|
# don't do debug builds on anything but i686 and x86_64
|
|
%ifnarch i686 x86_64
|
|
%define with_debug 0
|
|
%endif
|
|
|
|
# only package docs noarch
|
|
%ifnarch noarch
|
|
%define with_doc 0
|
|
%endif
|
|
|
|
# don't build noarch kernels or headers (duh)
|
|
%ifarch noarch
|
|
%define with_up 0
|
|
%define with_headers 0
|
|
%define with_tools 0
|
|
%define with_perf 0
|
|
%define all_arch_configs kernel-%{version}-*.config
|
|
%endif
|
|
|
|
# bootwrapper is only on ppc
|
|
%ifnarch ppc ppc64 ppc64p7
|
|
%define with_bootwrapper 0
|
|
%endif
|
|
|
|
# sparse blows up on ppc64 and sparc64
|
|
%ifarch ppc64 ppc ppc64p7
|
|
%define with_sparse 0
|
|
%endif
|
|
|
|
# Per-arch tweaks
|
|
|
|
%ifarch %{all_x86}
|
|
%define asmarch x86
|
|
%define hdrarch i386
|
|
%define all_arch_configs kernel-%{version}-i?86*.config
|
|
%define image_install_path boot
|
|
%define kernel_image arch/x86/boot/bzImage
|
|
%endif
|
|
|
|
%ifarch x86_64
|
|
%define asmarch x86
|
|
%define all_arch_configs kernel-%{version}-x86_64*.config
|
|
%define image_install_path boot
|
|
%define kernel_image arch/x86/boot/bzImage
|
|
%endif
|
|
|
|
%ifarch ppc64 ppc64p7
|
|
%define asmarch powerpc
|
|
%define hdrarch powerpc
|
|
%define all_arch_configs kernel-%{version}-ppc64*.config
|
|
%define image_install_path boot
|
|
%define make_target vmlinux
|
|
%define kernel_image vmlinux
|
|
%define kernel_image_elf 1
|
|
%endif
|
|
|
|
%ifarch s390x
|
|
%define asmarch s390
|
|
%define hdrarch s390
|
|
%define all_arch_configs kernel-%{version}-s390x.config
|
|
%define image_install_path boot
|
|
%define make_target image
|
|
%define kernel_image arch/s390/boot/image
|
|
%define with_tools 0
|
|
%endif
|
|
|
|
%ifarch ppc
|
|
%define asmarch powerpc
|
|
%define hdrarch powerpc
|
|
%define all_arch_configs kernel-%{version}-ppc{-,.}*config
|
|
%define image_install_path boot
|
|
%define make_target vmlinux
|
|
%define kernel_image vmlinux
|
|
%define kernel_image_elf 1
|
|
%endif
|
|
|
|
%ifarch %{arm}
|
|
%define all_arch_configs kernel-%{version}-arm*.config
|
|
%define image_install_path boot
|
|
%define asmarch arm
|
|
%define hdrarch arm
|
|
%define make_target bzImage
|
|
%define kernel_image arch/arm/boot/zImage
|
|
# we only build headers/perf/tools on the base arm arches
|
|
# just like we used to only build them on i386 for x86
|
|
%ifarch armv5tel
|
|
%define with_up 0
|
|
%endif
|
|
%ifnarch armv5tel armv7hl
|
|
%define with_headers 0
|
|
%define with_perf 0
|
|
%define with_tools 0
|
|
%endif
|
|
%endif
|
|
|
|
# Should make listnewconfig fail if there's config options
|
|
# printed out?
|
|
%if %{nopatches}%{using_upstream_branch}
|
|
%define listnewconfig_fail 0
|
|
%else
|
|
%define listnewconfig_fail 1
|
|
%endif
|
|
|
|
# To temporarily exclude an architecture from being built, add it to
|
|
# %%nobuildarches. Do _NOT_ use the ExclusiveArch: line, because if we
|
|
# don't build kernel-headers then the new build system will no longer let
|
|
# us use the previous build of that package -- it'll just be completely AWOL.
|
|
# Which is a BadThing(tm).
|
|
|
|
# We only build kernel-headers on the following...
|
|
%define nobuildarches i386 s390
|
|
|
|
%ifarch %nobuildarches
|
|
%define with_up 0
|
|
%define with_smp 0
|
|
%define with_pae 0
|
|
%define with_debuginfo 0
|
|
%define with_perf 0
|
|
%define with_tools 0
|
|
%define _enable_debug_packages 0
|
|
%endif
|
|
|
|
%define with_pae_debug 0
|
|
%if %{with_pae}
|
|
%define with_pae_debug %{with_debug}
|
|
%endif
|
|
|
|
# Architectures we build tools/cpupower on
|
|
%define cpupowerarchs %{ix86} x86_64 ppc ppc64 ppc64p7 %{arm}
|
|
|
|
#
|
|
# Three sets of minimum package version requirements in the form of Conflicts:
|
|
# to versions below the minimum
|
|
#
|
|
|
|
#
|
|
# First the general kernel 2.6 required versions as per
|
|
# Documentation/Changes
|
|
#
|
|
%define kernel_dot_org_conflicts ppp < 2.4.3-3, isdn4k-utils < 3.2-32, nfs-utils < 1.2.5-7.fc17, e2fsprogs < 1.37-4, util-linux < 2.12, jfsutils < 1.1.7-2, reiserfs-utils < 3.6.19-2, xfsprogs < 2.6.13-4, procps < 3.2.5-6.3, oprofile < 0.9.1-2, device-mapper-libs < 1.02.63-2, mdadm < 3.2.1-5
|
|
|
|
#
|
|
# Then a series of requirements that are distribution specific, either
|
|
# because we add patches for something, or the older versions have
|
|
# problems with the newer kernel or lack certain things that make
|
|
# integration in the distro harder than needed.
|
|
#
|
|
%define package_conflicts initscripts < 7.23, udev < 063-6, iptables < 1.3.2-1, ipw2200-firmware < 2.4, iwl4965-firmware < 228.57.2, selinux-policy-targeted < 1.25.3-14, squashfs-tools < 4.0, wireless-tools < 29-3
|
|
|
|
# We moved the drm include files into kernel-headers, make sure there's
|
|
# a recent enough libdrm-devel on the system that doesn't have those.
|
|
%define kernel_headers_conflicts libdrm-devel < 2.4.0-0.15
|
|
|
|
#
|
|
# Packages that need to be installed before the kernel is, because the %%post
|
|
# scripts use them.
|
|
#
|
|
%define kernel_prereq fileutils, module-init-tools >= 3.16-4, initscripts >= 8.11.1-1, grubby >= 8.3-1
|
|
%define initrd_prereq dracut >= 001-7
|
|
|
|
#
|
|
# This macro does requires, provides, conflicts, obsoletes for a kernel package.
|
|
# %%kernel_reqprovconf <subpackage>
|
|
# It uses any kernel_<subpackage>_conflicts and kernel_<subpackage>_obsoletes
|
|
# macros defined above.
|
|
#
|
|
%define kernel_reqprovconf \
|
|
Provides: kernel = %{rpmversion}-%{pkg_release}\
|
|
Provides: kernel-%{_target_cpu} = %{rpmversion}-%{pkg_release}%{?1:.%{1}}\
|
|
Provides: kernel-drm = 4.3.0\
|
|
Provides: kernel-drm-nouveau = 16\
|
|
Provides: kernel-modeset = 1\
|
|
Provides: kernel-uname-r = %{KVERREL}%{?1:.%{1}}\
|
|
Requires(pre): %{kernel_prereq}\
|
|
Requires(pre): %{initrd_prereq}\
|
|
Requires(pre): linux-firmware >= 20120206-0.1.git06c8f81\
|
|
Requires(post): /sbin/new-kernel-pkg\
|
|
Requires(preun): /sbin/new-kernel-pkg\
|
|
Conflicts: %{kernel_dot_org_conflicts}\
|
|
Conflicts: %{package_conflicts}\
|
|
%{expand:%%{?kernel%{?1:_%{1}}_conflicts:Conflicts: %%{kernel%{?1:_%{1}}_conflicts}}}\
|
|
%{expand:%%{?kernel%{?1:_%{1}}_obsoletes:Obsoletes: %%{kernel%{?1:_%{1}}_obsoletes}}}\
|
|
%{expand:%%{?kernel%{?1:_%{1}}_provides:Provides: %%{kernel%{?1:_%{1}}_provides}}}\
|
|
# We can't let RPM do the dependencies automatic because it'll then pick up\
|
|
# a correct but undesirable perl dependency from the module headers which\
|
|
# isn't required for the kernel proper to function\
|
|
AutoReq: no\
|
|
AutoProv: yes\
|
|
%{nil}
|
|
|
|
Name: kernel%{?variant}
|
|
Group: System Environment/Kernel
|
|
License: GPLv2 and Redistributable, no modification permitted
|
|
URL: http://www.kernel.org/
|
|
Version: %{rpmversion}
|
|
Release: %{pkg_release}
|
|
# DO NOT CHANGE THE 'ExclusiveArch' LINE TO TEMPORARILY EXCLUDE AN ARCHITECTURE BUILD.
|
|
# SET %%nobuildarches (ABOVE) INSTEAD
|
|
ExclusiveArch: noarch %{all_x86} x86_64 ppc ppc64 ppc64p7 s390 s390x %{arm}
|
|
ExclusiveOS: Linux
|
|
|
|
%kernel_reqprovconf
|
|
|
|
#
|
|
# List the packages used during the kernel build
|
|
#
|
|
BuildRequires: module-init-tools, patch >= 2.5.4, bash >= 2.03, sh-utils, tar
|
|
BuildRequires: bzip2, xz, findutils, gzip, m4, perl, make >= 3.78, diffutils, gawk
|
|
BuildRequires: gcc >= 3.4.2, binutils >= 2.12, redhat-rpm-config, hmaccalc
|
|
BuildRequires: net-tools, hostname
|
|
BuildRequires: xmlto, asciidoc
|
|
%if %{with_sparse}
|
|
BuildRequires: sparse >= 0.4.1
|
|
%endif
|
|
%if %{with_perf}
|
|
BuildRequires: elfutils-devel zlib-devel binutils-devel newt-devel python-devel perl(ExtUtils::Embed) bison
|
|
BuildRequires: audit-libs-devel
|
|
%endif
|
|
%if %{with_tools}
|
|
BuildRequires: pciutils-devel gettext
|
|
%endif
|
|
BuildConflicts: rhbuildsys(DiskFree) < 500Mb
|
|
%if %{with_debuginfo}
|
|
# Fancy new debuginfo generation introduced in Fedora 8/RHEL 6.
|
|
# The -r flag to find-debuginfo.sh invokes eu-strip --reloc-debug-sections
|
|
# which reduces the number of relocations in kernel module .ko.debug files and
|
|
# was introduced with rpm 4.9 and elfutils 0.153.
|
|
BuildRequires: rpm-build >= 4.9.0-1, elfutils >= elfutils-0.153-1
|
|
%define debuginfo_args --strict-build-id -r
|
|
%endif
|
|
|
|
%if %{signmodules}
|
|
BuildRequires: openssl
|
|
BuildRequires: pesign >= 0.10-4
|
|
%endif
|
|
|
|
Source0: ftp://ftp.kernel.org/pub/linux/kernel/v3.0/linux-%{kversion}.tar.xz
|
|
|
|
%if %{signmodules}
|
|
Source11: x509.genkey
|
|
%endif
|
|
|
|
Source15: merge.pl
|
|
Source16: mod-extra.list
|
|
Source17: mod-extra.sh
|
|
Source18: mod-sign.sh
|
|
%define modsign_cmd %{SOURCE18}
|
|
|
|
Source19: Makefile.release
|
|
Source20: Makefile.config
|
|
Source21: config-debug
|
|
Source22: config-nodebug
|
|
Source23: config-generic
|
|
|
|
Source30: config-x86-generic
|
|
Source31: config-i686-PAE
|
|
Source32: config-x86-32-generic
|
|
|
|
Source40: config-x86_64-generic
|
|
|
|
Source50: config-powerpc-generic
|
|
Source51: config-powerpc32-generic
|
|
Source52: config-powerpc32-smp
|
|
Source53: config-powerpc64
|
|
Source54: config-powerpc64p7
|
|
|
|
Source70: config-s390x
|
|
|
|
# Unified ARM kernels
|
|
Source100: config-armv7
|
|
|
|
# Legacy ARM kernels
|
|
Source105: config-arm-generic
|
|
Source110: config-arm-omap
|
|
Source111: config-arm-tegra
|
|
Source112: config-arm-kirkwood
|
|
|
|
# This file is intentionally left empty in the stock kernel. Its a nicety
|
|
# added for those wanting to do custom rebuilds with altered config opts.
|
|
Source1000: config-local
|
|
|
|
# Sources for kernel-tools
|
|
Source2000: cpupower.service
|
|
Source2001: cpupower.config
|
|
|
|
# Here should be only the patches up to the upstream canonical Linus tree.
|
|
|
|
# For a stable release kernel
|
|
%if 0%{?stable_update}
|
|
%if 0%{?stable_base}
|
|
%define stable_patch_00 patch-3.%{base_sublevel}.%{stable_base}.xz
|
|
Patch00: %{stable_patch_00}
|
|
%endif
|
|
%if 0%{?stable_rc}
|
|
%define stable_patch_01 patch-3.%{base_sublevel}.%{stable_update}-rc%{stable_rc}.xz
|
|
Patch01: %{stable_patch_01}
|
|
%endif
|
|
|
|
# non-released_kernel case
|
|
# These are automagically defined by the rcrev and gitrev values set up
|
|
# near the top of this spec file.
|
|
%else
|
|
%if 0%{?rcrev}
|
|
Patch00: patch-3.%{upstream_sublevel}-rc%{rcrev}.xz
|
|
%if 0%{?gitrev}
|
|
Patch01: patch-3.%{upstream_sublevel}-rc%{rcrev}-git%{gitrev}.xz
|
|
%endif
|
|
%else
|
|
# pre-{base_sublevel+1}-rc1 case
|
|
%if 0%{?gitrev}
|
|
Patch00: patch-3.%{base_sublevel}-git%{gitrev}.xz
|
|
%endif
|
|
%endif
|
|
%endif
|
|
|
|
%if %{using_upstream_branch}
|
|
### BRANCH PATCH ###
|
|
%endif
|
|
|
|
# we also need compile fixes for -vanilla
|
|
Patch04: compile-fixes.patch
|
|
|
|
# build tweak for build ID magic, even for -vanilla
|
|
Patch05: makefile-after_link.patch
|
|
|
|
%if !%{nopatches}
|
|
|
|
|
|
# revert upstream patches we get via other methods
|
|
Patch09: upstream-reverts.patch
|
|
# Git trees.
|
|
|
|
# Standalone patches
|
|
|
|
Patch100: taint-vbox.patch
|
|
|
|
Patch110: vmbugon-warnon.patch
|
|
|
|
Patch390: defaults-acpi-video.patch
|
|
Patch391: acpi-video-dos.patch
|
|
Patch394: acpi-debug-infinite-loop.patch
|
|
Patch396: acpi-sony-nonvs-blacklist.patch
|
|
|
|
Patch450: input-kill-stupid-messages.patch
|
|
Patch452: no-pcspkr-modalias.patch
|
|
|
|
Patch460: serial-460800.patch
|
|
|
|
Patch470: die-floppy-die.patch
|
|
|
|
Patch510: silence-noise.patch
|
|
Patch520: quiet-apm.patch
|
|
Patch530: silence-fbcon-logo.patch
|
|
Patch540: silence-empty-ipi-mask-warning.patch
|
|
|
|
Patch800: crash-driver.patch
|
|
|
|
# crypto/
|
|
|
|
# secure boot
|
|
Patch1000: secure-boot-20130206.patch
|
|
|
|
# virt + ksm patches
|
|
|
|
# DRM
|
|
#atch1700: drm-edid-try-harder-to-fix-up-broken-headers.patch
|
|
#Patch1800: drm-vgem.patch
|
|
|
|
# nouveau + drm fixes
|
|
# intel drm is all merged upstream
|
|
Patch1824: drm-intel-next.patch
|
|
Patch1825: drm-i915-dp-stfu.patch
|
|
|
|
# Quiet boot fixes
|
|
# silence the ACPI blacklist code
|
|
Patch2802: silence-acpi-blacklist.patch
|
|
|
|
# media patches
|
|
Patch2899: v4l-dvb-fixes.patch
|
|
Patch2900: v4l-dvb-update.patch
|
|
Patch2901: v4l-dvb-experimental.patch
|
|
|
|
Patch3000: brcmsmac-double-timeout.patch
|
|
|
|
# fs fixes
|
|
|
|
# NFSv4
|
|
|
|
# patches headed upstream
|
|
Patch10000: fs-proc-devtree-remove_proc_entry.patch
|
|
|
|
Patch12016: disable-i8042-check-on-apple-mac.patch
|
|
|
|
Patch12303: dmar-disable-when-ricoh-multifunction.patch
|
|
|
|
Patch13003: efi-dont-map-boot-services-on-32bit.patch
|
|
|
|
Patch14000: hibernate-freeze-filesystems.patch
|
|
|
|
Patch14010: lis3-improve-handling-of-null-rate.patch
|
|
|
|
|
|
# ARM
|
|
Patch21000: arm-export-read_current_timer.patch
|
|
Patch21001: arm-allnoconfig-error-__LINUX_ARM_ARCH__-undeclared.patch
|
|
|
|
# IMX
|
|
Patch21003: arm-imx-fixdrm.patch
|
|
|
|
# ARM tegra
|
|
Patch21004: arm-tegra-nvec-kconfig.patch
|
|
Patch21005: arm-tegra-usb-no-reset-linux33.patch
|
|
|
|
# versatile
|
|
|
|
#rhbz 754518
|
|
Patch21235: scsi-sd_revalidate_disk-prevent-NULL-ptr-deref.patch
|
|
|
|
Patch22000: weird-root-dentry-name-debug.patch
|
|
|
|
#selinux ptrace child permissions
|
|
Patch22001: selinux-apply-different-permission-to-ptrace-child.patch
|
|
|
|
# Build patch, should go away
|
|
Patch22070: irqnr-build.patch
|
|
|
|
#rhbz 859485
|
|
Patch21226: vt-Drop-K_OFF-for-VC_MUTE.patch
|
|
|
|
#rhbz 863424
|
|
Patch21229: Revert-iwlwifi-fix-the-reclaimed-packet-tracking-upon.patch
|
|
|
|
#rhbz 799564
|
|
Patch21240: Input-increase-struct-ps2dev-cmdbuf-to-8-bytes.patch
|
|
Patch21241: Input-add-support-for-Cypress-PS2-Trackpads.patch
|
|
|
|
# https://fedoraproject.org/wiki/Features/Checkpoint_Restore
|
|
Patch21242: criu-no-expert.patch
|
|
|
|
#rhbz 830151
|
|
Patch21243: mac80211-improve-latency-and-throughput-while-software.patch
|
|
Patch21244: iwlegacy-add-flush-callback.patch
|
|
|
|
#rhbz 903881
|
|
Patch21246: rtlwifi-Fix-scheduling-while-atomic-bug.patch
|
|
|
|
#rhbz 892811
|
|
Patch21247: ath9k_rx_dma_stop_check.patch
|
|
|
|
# END OF PATCH DEFINITIONS
|
|
|
|
%endif
|
|
|
|
BuildRoot: %{_tmppath}/kernel-%{KVERREL}-root
|
|
|
|
%description
|
|
The kernel package contains the Linux kernel (vmlinuz), the core of any
|
|
Linux operating system. The kernel handles the basic functions
|
|
of the operating system: memory allocation, process allocation, device
|
|
input and output, etc.
|
|
|
|
|
|
%package doc
|
|
Summary: Various documentation bits found in the kernel source
|
|
Group: Documentation
|
|
%description doc
|
|
This package contains documentation files from the kernel
|
|
source. Various bits of information about the Linux kernel and the
|
|
device drivers shipped with it are documented in these files.
|
|
|
|
You'll want to install this package if you need a reference to the
|
|
options that can be passed to Linux kernel modules at load time.
|
|
|
|
|
|
%package headers
|
|
Summary: Header files for the Linux kernel for use by glibc
|
|
Group: Development/System
|
|
Obsoletes: glibc-kernheaders < 3.0-46
|
|
Provides: glibc-kernheaders = 3.0-46
|
|
%description headers
|
|
Kernel-headers includes the C header files that specify the interface
|
|
between the Linux kernel and userspace libraries and programs. The
|
|
header files define structures and constants that are needed for
|
|
building most standard programs and are also needed for rebuilding the
|
|
glibc package.
|
|
|
|
%package bootwrapper
|
|
Summary: Boot wrapper files for generating combined kernel + initrd images
|
|
Group: Development/System
|
|
Requires: gzip binutils
|
|
%description bootwrapper
|
|
Kernel-bootwrapper contains the wrapper code which makes bootable "zImage"
|
|
files combining both kernel and initial ramdisk.
|
|
|
|
%package debuginfo-common-%{_target_cpu}
|
|
Summary: Kernel source files used by %{name}-debuginfo packages
|
|
Group: Development/Debug
|
|
%description debuginfo-common-%{_target_cpu}
|
|
This package is required by %{name}-debuginfo subpackages.
|
|
It provides the kernel source files common to all builds.
|
|
|
|
%if %{with_perf}
|
|
%package -n perf
|
|
Summary: Performance monitoring for the Linux kernel
|
|
Group: Development/System
|
|
License: GPLv2
|
|
%description -n perf
|
|
This package contains the perf tool, which enables performance monitoring
|
|
of the Linux kernel.
|
|
|
|
%package -n perf-debuginfo
|
|
Summary: Debug information for package perf
|
|
Group: Development/Debug
|
|
Requires: %{name}-debuginfo-common-%{_target_cpu} = %{version}-%{release}
|
|
AutoReqProv: no
|
|
%description -n perf-debuginfo
|
|
This package provides debug information for the perf package.
|
|
|
|
# Note that this pattern only works right to match the .build-id
|
|
# symlinks because of the trailing nonmatching alternation and
|
|
# the leading .*, because of find-debuginfo.sh's buggy handling
|
|
# of matching the pattern against the symlinks file.
|
|
%{expand:%%global debuginfo_args %{?debuginfo_args} -p '.*%%{_bindir}/perf(\.debug)?|.*%%{_libexecdir}/perf-core/.*|XXX' -o perf-debuginfo.list}
|
|
|
|
%package -n python-perf
|
|
Summary: Python bindings for apps which will manipulate perf events
|
|
Group: Development/Libraries
|
|
%description -n python-perf
|
|
The python-perf package contains a module that permits applications
|
|
written in the Python programming language to use the interface
|
|
to manipulate perf events.
|
|
|
|
%{!?python_sitearch: %global python_sitearch %(%{__python} -c "from distutils.sysconfig import get_python_lib; print get_python_lib(1)")}
|
|
|
|
%package -n python-perf-debuginfo
|
|
Summary: Debug information for package perf python bindings
|
|
Group: Development/Debug
|
|
Requires: %{name}-debuginfo-common-%{_target_cpu} = %{version}-%{release}
|
|
AutoReqProv: no
|
|
%description -n python-perf-debuginfo
|
|
This package provides debug information for the perf python bindings.
|
|
|
|
# the python_sitearch macro should already be defined from above
|
|
%{expand:%%global debuginfo_args %{?debuginfo_args} -p '.*%%{python_sitearch}/perf.so(\.debug)?|XXX' -o python-perf-debuginfo.list}
|
|
|
|
|
|
%endif # with_perf
|
|
|
|
%if %{with_tools}
|
|
%package -n kernel-tools
|
|
Summary: Assortment of tools for the Linux kernel
|
|
Group: Development/System
|
|
License: GPLv2
|
|
Provides: cpupowerutils = 1:009-0.6.p1
|
|
Obsoletes: cpupowerutils < 1:009-0.6.p1
|
|
Provides: cpufreq-utils = 1:009-0.6.p1
|
|
Provides: cpufrequtils = 1:009-0.6.p1
|
|
Obsoletes: cpufreq-utils < 1:009-0.6.p1
|
|
Obsoletes: cpufrequtils < 1:009-0.6.p1
|
|
Obsoletes: cpuspeed < 1:1.5-16
|
|
Requires: kernel-tools-libs = %{version}-%{release}
|
|
%description -n kernel-tools
|
|
This package contains the tools/ directory from the kernel source
|
|
and the supporting documentation.
|
|
|
|
%package -n kernel-tools-libs
|
|
Summary: Libraries for the kernels-tools
|
|
Group: Development/System
|
|
License: GPLv2
|
|
%description -n kernel-tools-libs
|
|
This package contains the libraries built from the tools/ directory
|
|
from the kernel source.
|
|
|
|
%package -n kernel-tools-libs-devel
|
|
Summary: Assortment of tools for the Linux kernel
|
|
Group: Development/System
|
|
License: GPLv2
|
|
Requires: kernel-tools = %{version}-%{release}
|
|
Provides: cpupowerutils-devel = 1:009-0.6.p1
|
|
Obsoletes: cpupowerutils-devel < 1:009-0.6.p1
|
|
Requires: kernel-tools-libs = %{version}-%{release}
|
|
Provides: kernel-tools-devel
|
|
%description -n kernel-tools-libs-devel
|
|
This package contains the development files for the tools/ directory from
|
|
the kernel source.
|
|
|
|
%package -n kernel-tools-debuginfo
|
|
Summary: Debug information for package kernel-tools
|
|
Group: Development/Debug
|
|
Requires: %{name}-debuginfo-common-%{_target_cpu} = %{version}-%{release}
|
|
AutoReqProv: no
|
|
%description -n kernel-tools-debuginfo
|
|
This package provides debug information for package kernel-tools.
|
|
|
|
# Note that this pattern only works right to match the .build-id
|
|
# symlinks because of the trailing nonmatching alternation and
|
|
# the leading .*, because of find-debuginfo.sh's buggy handling
|
|
# of matching the pattern against the symlinks file.
|
|
%{expand:%%global debuginfo_args %{?debuginfo_args} -p '.*%%{_bindir}/centrino-decode(\.debug)?|.*%%{_bindir}/powernow-k8-decode(\.debug)?|.*%%{_bindir}/cpupower(\.debug)?|.*%%{_libdir}/libcpupower.*|XXX' -o kernel-tools-debuginfo.list}
|
|
|
|
%endif # with_tools
|
|
|
|
|
|
#
|
|
# This macro creates a kernel-<subpackage>-debuginfo package.
|
|
# %%kernel_debuginfo_package <subpackage>
|
|
#
|
|
%define kernel_debuginfo_package() \
|
|
%package %{?1:%{1}-}debuginfo\
|
|
Summary: Debug information for package %{name}%{?1:-%{1}}\
|
|
Group: Development/Debug\
|
|
Requires: %{name}-debuginfo-common-%{_target_cpu} = %{version}-%{release}\
|
|
Provides: %{name}%{?1:-%{1}}-debuginfo-%{_target_cpu} = %{version}-%{release}\
|
|
AutoReqProv: no\
|
|
%description -n %{name}%{?1:-%{1}}-debuginfo\
|
|
This package provides debug information for package %{name}%{?1:-%{1}}.\
|
|
This is required to use SystemTap with %{name}%{?1:-%{1}}-%{KVERREL}.\
|
|
%{expand:%%global debuginfo_args %{?debuginfo_args} -p '/.*/%%{KVERREL}%{?1:\.%{1}}/.*|/.*%%{KVERREL}%{?1:\.%{1}}(\.debug)?' -o debuginfo%{?1}.list}\
|
|
%{nil}
|
|
|
|
#
|
|
# This macro creates a kernel-<subpackage>-devel package.
|
|
# %%kernel_devel_package <subpackage> <pretty-name>
|
|
#
|
|
%define kernel_devel_package() \
|
|
%package %{?1:%{1}-}devel\
|
|
Summary: Development package for building kernel modules to match the %{?2:%{2} }kernel\
|
|
Group: System Environment/Kernel\
|
|
Provides: kernel%{?1:-%{1}}-devel-%{_target_cpu} = %{version}-%{release}\
|
|
Provides: kernel-devel-%{_target_cpu} = %{version}-%{release}%{?1:.%{1}}\
|
|
Provides: kernel-devel = %{version}-%{release}%{?1:.%{1}}\
|
|
Provides: kernel-devel-uname-r = %{KVERREL}%{?1:.%{1}}\
|
|
AutoReqProv: no\
|
|
Requires(pre): /usr/bin/find\
|
|
Requires: perl\
|
|
%description -n kernel%{?variant}%{?1:-%{1}}-devel\
|
|
This package provides kernel headers and makefiles sufficient to build modules\
|
|
against the %{?2:%{2} }kernel package.\
|
|
%{nil}
|
|
|
|
#
|
|
# This macro creates a kernel-<subpackage>-modules-extra package.
|
|
# %%kernel_modules-extra_package <subpackage> <pretty-name>
|
|
#
|
|
%define kernel_modules-extra_package() \
|
|
%package %{?1:%{1}-}modules-extra\
|
|
Summary: Extra kernel modules to match the %{?2:%{2} }kernel\
|
|
Group: System Environment/Kernel\
|
|
Provides: kernel%{?1:-%{1}}-modules-extra-%{_target_cpu} = %{version}-%{release}\
|
|
Provides: kernel-modules-extra-%{_target_cpu} = %{version}-%{release}%{?1:.%{1}}\
|
|
Provides: kernel-modules-extra = %{version}-%{release}%{?1:.%{1}}\
|
|
Provides: installonlypkg(kernel-module)\
|
|
Provides: kernel-modules-extra-uname-r = %{KVERREL}%{?1:.%{1}}\
|
|
Requires: kernel-uname-r = %{KVERREL}%{?1:.%{1}}\
|
|
AutoReqProv: no\
|
|
%description -n kernel%{?variant}%{?1:-%{1}}-modules-extra\
|
|
This package provides less commonly used kernel modules for the %{?2:%{2} }kernel package.\
|
|
%{nil}
|
|
|
|
#
|
|
# This macro creates a kernel-<subpackage> and its -devel and -debuginfo too.
|
|
# %%define variant_summary The Linux kernel compiled for <configuration>
|
|
# %%kernel_variant_package [-n <pretty-name>] <subpackage>
|
|
#
|
|
%define kernel_variant_package(n:) \
|
|
%package %1\
|
|
Summary: %{variant_summary}\
|
|
Group: System Environment/Kernel\
|
|
%kernel_reqprovconf\
|
|
%{expand:%%kernel_devel_package %1 %{!?-n:%1}%{?-n:%{-n*}}}\
|
|
%{expand:%%kernel_modules-extra_package %1 %{!?-n:%1}%{?-n:%{-n*}}}\
|
|
%{expand:%%kernel_debuginfo_package %1}\
|
|
%{nil}
|
|
|
|
|
|
# First the auxiliary packages of the main kernel package.
|
|
%kernel_devel_package
|
|
%kernel_modules-extra_package
|
|
%kernel_debuginfo_package
|
|
|
|
|
|
# Now, each variant package.
|
|
|
|
%define variant_summary The Linux kernel compiled for SMP machines
|
|
%kernel_variant_package -n SMP smp
|
|
%description smp
|
|
This package includes a SMP version of the Linux kernel. It is
|
|
required only on machines with two or more CPUs as well as machines with
|
|
hyperthreading technology.
|
|
|
|
Install the kernel-smp package if your machine uses two or more CPUs.
|
|
|
|
|
|
%define variant_summary The Linux kernel compiled for PAE capable machines
|
|
%kernel_variant_package PAE
|
|
%description PAE
|
|
This package includes a version of the Linux kernel with support for up to
|
|
64GB of high memory. It requires a CPU with Physical Address Extensions (PAE).
|
|
The non-PAE kernel can only address up to 4GB of memory.
|
|
Install the kernel-PAE package if your machine has more than 4GB of memory.
|
|
|
|
|
|
%define variant_summary The Linux kernel compiled with extra debugging enabled for PAE capable machines
|
|
%kernel_variant_package PAEdebug
|
|
Obsoletes: kernel-PAE-debug
|
|
%description PAEdebug
|
|
This package includes a version of the Linux kernel with support for up to
|
|
64GB of high memory. It requires a CPU with Physical Address Extensions (PAE).
|
|
The non-PAE kernel can only address up to 4GB of memory.
|
|
Install the kernel-PAE package if your machine has more than 4GB of memory.
|
|
|
|
This variant of the kernel has numerous debugging options enabled.
|
|
It should only be installed when trying to gather additional information
|
|
on kernel bugs, as some of these options impact performance noticably.
|
|
|
|
|
|
%define variant_summary The Linux kernel compiled with extra debugging enabled
|
|
%kernel_variant_package debug
|
|
%description debug
|
|
The kernel package contains the Linux kernel (vmlinuz), the core of any
|
|
Linux operating system. The kernel handles the basic functions
|
|
of the operating system: memory allocation, process allocation, device
|
|
input and output, etc.
|
|
|
|
This variant of the kernel has numerous debugging options enabled.
|
|
It should only be installed when trying to gather additional information
|
|
on kernel bugs, as some of these options impact performance noticably.
|
|
|
|
%define variant_summary The Linux kernel compiled for marvell kirkwood boards
|
|
%kernel_variant_package kirkwood
|
|
%description kirkwood
|
|
This package includes a version of the Linux kernel with support for
|
|
marvell kirkwood based systems, i.e., guruplug, sheevaplug
|
|
|
|
%define variant_summary The Linux kernel compiled for TI-OMAP boards
|
|
%kernel_variant_package omap
|
|
%description omap
|
|
This package includes a version of the Linux kernel with support for
|
|
TI-OMAP based systems, i.e., BeagleBoard-xM.
|
|
|
|
%define variant_summary The Linux kernel compiled for tegra boards
|
|
%kernel_variant_package tegra
|
|
%description tegra
|
|
This package includes a version of the Linux kernel with support for
|
|
nvidia tegra based systems, i.e., trimslice, ac-100.
|
|
|
|
|
|
%prep
|
|
# do a few sanity-checks for --with *only builds
|
|
%if %{with_baseonly}
|
|
%if !%{with_up}%{with_pae}
|
|
echo "Cannot build --with baseonly, up build is disabled"
|
|
exit 1
|
|
%endif
|
|
%endif
|
|
|
|
%if %{with_smponly}
|
|
%if !%{with_smp}
|
|
echo "Cannot build --with smponly, smp build is disabled"
|
|
exit 1
|
|
%endif
|
|
%endif
|
|
|
|
%if "%{baserelease}" == "0"
|
|
echo "baserelease must be greater than zero"
|
|
exit 1
|
|
%endif
|
|
|
|
# more sanity checking; do it quietly
|
|
if [ "%{patches}" != "%%{patches}" ] ; then
|
|
for patch in %{patches} ; do
|
|
if [ ! -f $patch ] ; then
|
|
echo "ERROR: Patch ${patch##/*/} listed in specfile but is missing"
|
|
exit 1
|
|
fi
|
|
done
|
|
fi 2>/dev/null
|
|
|
|
patch_command='patch -p1 -F1 -s'
|
|
ApplyPatch()
|
|
{
|
|
local patch=$1
|
|
shift
|
|
if [ ! -f $RPM_SOURCE_DIR/$patch ]; then
|
|
exit 1
|
|
fi
|
|
%if !%{using_upstream_branch}
|
|
if ! grep -E "^Patch[0-9]+: $patch\$" %{_specdir}/${RPM_PACKAGE_NAME%%%%%{?variant}}.spec ; then
|
|
if [ "${patch:0:8}" != "patch-3." ] ; then
|
|
echo "ERROR: Patch $patch not listed as a source patch in specfile"
|
|
exit 1
|
|
fi
|
|
fi 2>/dev/null
|
|
%endif
|
|
case "$patch" in
|
|
*.bz2) bunzip2 < "$RPM_SOURCE_DIR/$patch" | $patch_command ${1+"$@"} ;;
|
|
*.gz) gunzip < "$RPM_SOURCE_DIR/$patch" | $patch_command ${1+"$@"} ;;
|
|
*.xz) unxz < "$RPM_SOURCE_DIR/$patch" | $patch_command ${1+"$@"} ;;
|
|
*) $patch_command ${1+"$@"} < "$RPM_SOURCE_DIR/$patch" ;;
|
|
esac
|
|
}
|
|
|
|
# don't apply patch if it's empty
|
|
ApplyOptionalPatch()
|
|
{
|
|
local patch=$1
|
|
shift
|
|
if [ ! -f $RPM_SOURCE_DIR/$patch ]; then
|
|
exit 1
|
|
fi
|
|
local C=$(wc -l $RPM_SOURCE_DIR/$patch | awk '{print $1}')
|
|
if [ "$C" -gt 9 ]; then
|
|
ApplyPatch $patch ${1+"$@"}
|
|
fi
|
|
}
|
|
|
|
# First we unpack the kernel tarball.
|
|
# If this isn't the first make prep, we use links to the existing clean tarball
|
|
# which speeds things up quite a bit.
|
|
|
|
# Update to latest upstream.
|
|
%if 0%{?released_kernel}
|
|
%define vanillaversion 3.%{base_sublevel}
|
|
# non-released_kernel case
|
|
%else
|
|
%if 0%{?rcrev}
|
|
%define vanillaversion 3.%{upstream_sublevel}-rc%{rcrev}
|
|
%if 0%{?gitrev}
|
|
%define vanillaversion 3.%{upstream_sublevel}-rc%{rcrev}-git%{gitrev}
|
|
%endif
|
|
%else
|
|
# pre-{base_sublevel+1}-rc1 case
|
|
%if 0%{?gitrev}
|
|
%define vanillaversion 3.%{base_sublevel}-git%{gitrev}
|
|
%else
|
|
%define vanillaversion 3.%{base_sublevel}
|
|
%endif
|
|
%endif
|
|
%endif
|
|
|
|
# %%{vanillaversion} : the full version name, e.g. 2.6.35-rc6-git3
|
|
# %%{kversion} : the base version, e.g. 2.6.34
|
|
|
|
# Use kernel-%%{kversion}%%{?dist} as the top-level directory name
|
|
# so we can prep different trees within a single git directory.
|
|
|
|
# Build a list of the other top-level kernel tree directories.
|
|
# This will be used to hardlink identical vanilla subdirs.
|
|
sharedirs=$(find "$PWD" -maxdepth 1 -type d -name 'kernel-3.*' \
|
|
| grep -x -v "$PWD"/kernel-%{kversion}%{?dist}) ||:
|
|
|
|
# Delete all old stale trees.
|
|
if [ -d kernel-%{kversion}%{?dist} ]; then
|
|
cd kernel-%{kversion}%{?dist}
|
|
for i in linux-*
|
|
do
|
|
if [ -d $i ]; then
|
|
# Just in case we ctrl-c'd a prep already
|
|
rm -rf deleteme.%{_target_cpu}
|
|
# Move away the stale away, and delete in background.
|
|
mv $i deleteme-$i
|
|
rm -rf deleteme* &
|
|
fi
|
|
done
|
|
cd ..
|
|
fi
|
|
|
|
# Generate new tree
|
|
if [ ! -d kernel-%{kversion}%{?dist}/vanilla-%{vanillaversion} ]; then
|
|
|
|
if [ -d kernel-%{kversion}%{?dist}/vanilla-%{kversion} ]; then
|
|
|
|
# The base vanilla version already exists.
|
|
cd kernel-%{kversion}%{?dist}
|
|
|
|
# Any vanilla-* directories other than the base one are stale.
|
|
for dir in vanilla-*; do
|
|
[ "$dir" = vanilla-%{kversion} ] || rm -rf $dir &
|
|
done
|
|
|
|
else
|
|
|
|
rm -f pax_global_header
|
|
# Look for an identical base vanilla dir that can be hardlinked.
|
|
for sharedir in $sharedirs ; do
|
|
if [[ ! -z $sharedir && -d $sharedir/vanilla-%{kversion} ]] ; then
|
|
break
|
|
fi
|
|
done
|
|
if [[ ! -z $sharedir && -d $sharedir/vanilla-%{kversion} ]] ; then
|
|
%setup -q -n kernel-%{kversion}%{?dist} -c -T
|
|
cp -rl $sharedir/vanilla-%{kversion} .
|
|
else
|
|
%setup -q -n kernel-%{kversion}%{?dist} -c
|
|
mv linux-%{kversion} vanilla-%{kversion}
|
|
fi
|
|
|
|
fi
|
|
|
|
%if "%{kversion}" != "%{vanillaversion}"
|
|
|
|
for sharedir in $sharedirs ; do
|
|
if [[ ! -z $sharedir && -d $sharedir/vanilla-%{vanillaversion} ]] ; then
|
|
break
|
|
fi
|
|
done
|
|
if [[ ! -z $sharedir && -d $sharedir/vanilla-%{vanillaversion} ]] ; then
|
|
|
|
cp -rl $sharedir/vanilla-%{vanillaversion} .
|
|
|
|
else
|
|
|
|
# Need to apply patches to the base vanilla version.
|
|
cp -rl vanilla-%{kversion} vanilla-%{vanillaversion}
|
|
cd vanilla-%{vanillaversion}
|
|
|
|
# Update vanilla to the latest upstream.
|
|
# (non-released_kernel case only)
|
|
%if 0%{?rcrev}
|
|
ApplyPatch patch-3.%{upstream_sublevel}-rc%{rcrev}.xz
|
|
%if 0%{?gitrev}
|
|
ApplyPatch patch-3.%{upstream_sublevel}-rc%{rcrev}-git%{gitrev}.xz
|
|
%endif
|
|
%else
|
|
# pre-{base_sublevel+1}-rc1 case
|
|
%if 0%{?gitrev}
|
|
ApplyPatch patch-3.%{base_sublevel}-git%{gitrev}.xz
|
|
%endif
|
|
%endif
|
|
|
|
cd ..
|
|
|
|
fi
|
|
|
|
%endif
|
|
|
|
else
|
|
|
|
# We already have all vanilla dirs, just change to the top-level directory.
|
|
cd kernel-%{kversion}%{?dist}
|
|
|
|
fi
|
|
|
|
# Now build the fedora kernel tree.
|
|
cp -rl vanilla-%{vanillaversion} linux-%{KVERREL}
|
|
|
|
cd linux-%{KVERREL}
|
|
|
|
# released_kernel with possible stable updates
|
|
%if 0%{?stable_base}
|
|
ApplyPatch %{stable_patch_00}
|
|
%endif
|
|
%if 0%{?stable_rc}
|
|
ApplyPatch %{stable_patch_01}
|
|
%endif
|
|
|
|
%if %{using_upstream_branch}
|
|
### BRANCH APPLY ###
|
|
%endif
|
|
|
|
# Drop some necessary files from the source dir into the buildroot
|
|
cp $RPM_SOURCE_DIR/config-* .
|
|
cp %{SOURCE15} .
|
|
|
|
%if !%{debugbuildsenabled}
|
|
%if %{with_release}
|
|
# The normal build is a really debug build and the user has explicitly requested
|
|
# a release kernel. Change the config files into non-debug versions.
|
|
make -f %{SOURCE19} config-release
|
|
%endif
|
|
%endif
|
|
|
|
# Dynamically generate kernel .config files from config-* files
|
|
make -f %{SOURCE20} VERSION=%{version} configs
|
|
|
|
# Merge in any user-provided local config option changes
|
|
%if %{?all_arch_configs:1}%{!?all_arch_configs:0}
|
|
for i in %{all_arch_configs}
|
|
do
|
|
mv $i $i.tmp
|
|
./merge.pl %{SOURCE1000} $i.tmp > $i
|
|
rm $i.tmp
|
|
done
|
|
%endif
|
|
|
|
ApplyPatch makefile-after_link.patch
|
|
|
|
#
|
|
# misc small stuff to make things compile
|
|
#
|
|
ApplyOptionalPatch compile-fixes.patch
|
|
|
|
%if !%{nopatches}
|
|
|
|
# revert patches from upstream that conflict or that we get via other means
|
|
ApplyOptionalPatch upstream-reverts.patch -R
|
|
|
|
ApplyPatch taint-vbox.patch
|
|
|
|
ApplyPatch vmbugon-warnon.patch
|
|
|
|
# Architecture patches
|
|
# x86(-64)
|
|
|
|
#
|
|
# ARM
|
|
#
|
|
ApplyPatch arm-export-read_current_timer.patch
|
|
ApplyPatch arm-allnoconfig-error-__LINUX_ARM_ARCH__-undeclared.patch
|
|
# ApplyPatch arm-tegra-nvec-kconfig.patch
|
|
ApplyPatch arm-tegra-usb-no-reset-linux33.patch
|
|
ApplyPatch arm-imx-fixdrm.patch
|
|
|
|
#
|
|
# bugfixes to drivers and filesystems
|
|
#
|
|
|
|
# ext4
|
|
|
|
# xfs
|
|
|
|
# btrfs
|
|
|
|
# eCryptfs
|
|
|
|
# NFSv4
|
|
|
|
# USB
|
|
|
|
# WMI
|
|
|
|
# ACPI
|
|
ApplyPatch defaults-acpi-video.patch
|
|
ApplyPatch acpi-video-dos.patch
|
|
ApplyPatch acpi-debug-infinite-loop.patch
|
|
ApplyPatch acpi-sony-nonvs-blacklist.patch
|
|
|
|
#
|
|
# PCI
|
|
#
|
|
|
|
#
|
|
# SCSI Bits.
|
|
#
|
|
|
|
# ACPI
|
|
|
|
# ALSA
|
|
|
|
# Networking
|
|
|
|
# Misc fixes
|
|
# The input layer spews crap no-one cares about.
|
|
ApplyPatch input-kill-stupid-messages.patch
|
|
|
|
# stop floppy.ko from autoloading during udev...
|
|
ApplyPatch die-floppy-die.patch
|
|
|
|
ApplyPatch no-pcspkr-modalias.patch
|
|
|
|
# Allow to use 480600 baud on 16C950 UARTs
|
|
ApplyPatch serial-460800.patch
|
|
|
|
# Silence some useless messages that still get printed with 'quiet'
|
|
ApplyPatch silence-noise.patch
|
|
|
|
# Make fbcon not show the penguins with 'quiet'
|
|
ApplyPatch silence-fbcon-logo.patch
|
|
|
|
# no-one cares about these warnings.
|
|
ApplyPatch silence-empty-ipi-mask-warning.patch
|
|
|
|
# Changes to upstream defaults.
|
|
|
|
|
|
# /dev/crash driver.
|
|
ApplyPatch crash-driver.patch
|
|
|
|
# crypto/
|
|
|
|
# secure boot
|
|
ApplyPatch secure-boot-20130206.patch
|
|
|
|
# Assorted Virt Fixes
|
|
|
|
# DRM core
|
|
#ApplyPatch drm-edid-try-harder-to-fix-up-broken-headers.patch
|
|
#ApplyPatch drm-vgem.patch
|
|
|
|
# Nouveau DRM
|
|
|
|
# Intel DRM
|
|
ApplyOptionalPatch drm-intel-next.patch
|
|
ApplyPatch drm-i915-dp-stfu.patch
|
|
|
|
# silence the ACPI blacklist code
|
|
ApplyPatch silence-acpi-blacklist.patch
|
|
ApplyPatch quiet-apm.patch
|
|
|
|
# V4L/DVB updates/fixes/experimental drivers
|
|
# apply if non-empty
|
|
ApplyOptionalPatch v4l-dvb-fixes.patch
|
|
ApplyOptionalPatch v4l-dvb-update.patch
|
|
ApplyOptionalPatch v4l-dvb-experimental.patch
|
|
|
|
# Experiment: Double the length of the brcmsmac transmit timeout.
|
|
ApplyPatch brcmsmac-double-timeout.patch
|
|
|
|
# Patches headed upstream
|
|
ApplyPatch fs-proc-devtree-remove_proc_entry.patch
|
|
|
|
ApplyPatch disable-i8042-check-on-apple-mac.patch
|
|
|
|
# rhbz#605888
|
|
ApplyPatch dmar-disable-when-ricoh-multifunction.patch
|
|
|
|
ApplyPatch efi-dont-map-boot-services-on-32bit.patch
|
|
|
|
# FIXME: REBASE
|
|
#ApplyPatch hibernate-freeze-filesystems.patch
|
|
|
|
ApplyPatch lis3-improve-handling-of-null-rate.patch
|
|
|
|
#rhbz 754518
|
|
ApplyPatch scsi-sd_revalidate_disk-prevent-NULL-ptr-deref.patch
|
|
|
|
ApplyPatch weird-root-dentry-name-debug.patch
|
|
|
|
#selinux ptrace child permissions
|
|
ApplyPatch selinux-apply-different-permission-to-ptrace-child.patch
|
|
|
|
#Build patch, should go away
|
|
ApplyPatch irqnr-build.patch
|
|
|
|
#rhbz 859485
|
|
ApplyPatch vt-Drop-K_OFF-for-VC_MUTE.patch
|
|
|
|
#rhbz 863424
|
|
ApplyPatch Revert-iwlwifi-fix-the-reclaimed-packet-tracking-upon.patch
|
|
|
|
#rhbz 799564
|
|
ApplyPatch Input-increase-struct-ps2dev-cmdbuf-to-8-bytes.patch
|
|
ApplyPatch Input-add-support-for-Cypress-PS2-Trackpads.patch
|
|
|
|
# https://fedoraproject.org/wiki/Features/Checkpoint_Restore
|
|
ApplyPatch criu-no-expert.patch
|
|
|
|
#rhbz 830151
|
|
ApplyPatch mac80211-improve-latency-and-throughput-while-software.patch
|
|
ApplyPatch iwlegacy-add-flush-callback.patch
|
|
|
|
#rhbz 903881
|
|
ApplyPatch rtlwifi-Fix-scheduling-while-atomic-bug.patch
|
|
|
|
#rhbz 892811
|
|
ApplyPatch ath9k_rx_dma_stop_check.patch
|
|
|
|
# END OF PATCH APPLICATIONS
|
|
|
|
%endif
|
|
|
|
# Any further pre-build tree manipulations happen here.
|
|
|
|
chmod +x scripts/checkpatch.pl
|
|
|
|
# This Prevents scripts/setlocalversion from mucking with our version numbers.
|
|
touch .scmversion
|
|
|
|
# only deal with configs if we are going to build for the arch
|
|
%ifnarch %nobuildarches
|
|
|
|
mkdir configs
|
|
|
|
# Remove configs not for the buildarch
|
|
for cfg in kernel-%{version}-*.config; do
|
|
if [ `echo %{all_arch_configs} | grep -c $cfg` -eq 0 ]; then
|
|
rm -f $cfg
|
|
fi
|
|
done
|
|
|
|
%if !%{debugbuildsenabled}
|
|
rm -f kernel-%{version}-*debug.config
|
|
%endif
|
|
|
|
# now run oldconfig over all the config files
|
|
for i in *.config
|
|
do
|
|
mv $i .config
|
|
Arch=`head -1 .config | cut -b 3-`
|
|
make ARCH=$Arch listnewconfig | grep -E '^CONFIG_' >.newoptions || true
|
|
%if %{listnewconfig_fail}
|
|
if [ -s .newoptions ]; then
|
|
cat .newoptions
|
|
exit 1
|
|
fi
|
|
%endif
|
|
rm -f .newoptions
|
|
make ARCH=$Arch oldnoconfig
|
|
echo "# $Arch" > configs/$i
|
|
cat .config >> configs/$i
|
|
done
|
|
# end of kernel config
|
|
%endif
|
|
|
|
# get rid of unwanted files resulting from patch fuzz
|
|
find . \( -name "*.orig" -o -name "*~" \) -exec rm -f {} \; >/dev/null
|
|
|
|
# remove unnecessary SCM files
|
|
find . -name .gitignore -exec rm -f {} \; >/dev/null
|
|
|
|
cd ..
|
|
|
|
###
|
|
### build
|
|
###
|
|
%build
|
|
|
|
%if %{with_sparse}
|
|
%define sparse_mflags C=1
|
|
%endif
|
|
|
|
%if %{with_debuginfo}
|
|
# This override tweaks the kernel makefiles so that we run debugedit on an
|
|
# object before embedding it. When we later run find-debuginfo.sh, it will
|
|
# run debugedit again. The edits it does change the build ID bits embedded
|
|
# in the stripped object, but repeating debugedit is a no-op. We do it
|
|
# beforehand to get the proper final build ID bits into the embedded image.
|
|
# This affects the vDSO images in vmlinux, and the vmlinux image in bzImage.
|
|
export AFTER_LINK=\
|
|
'sh -xc "/usr/lib/rpm/debugedit -b $$RPM_BUILD_DIR -d /usr/src/debug \
|
|
-i $@ > $@.id"'
|
|
%endif
|
|
|
|
cp_vmlinux()
|
|
{
|
|
eu-strip --remove-comment -o "$2" "$1"
|
|
}
|
|
|
|
BuildKernel() {
|
|
MakeTarget=$1
|
|
KernelImage=$2
|
|
Flavour=$3
|
|
Flav=${Flavour:+.${Flavour}}
|
|
InstallName=${4:-vmlinuz}
|
|
|
|
# Pick the right config file for the kernel we're building
|
|
Config=kernel-%{version}-%{_target_cpu}${Flavour:+-${Flavour}}.config
|
|
DevelDir=/usr/src/kernels/%{KVERREL}${Flav}
|
|
|
|
# When the bootable image is just the ELF kernel, strip it.
|
|
# We already copy the unstripped file into the debuginfo package.
|
|
if [ "$KernelImage" = vmlinux ]; then
|
|
CopyKernel=cp_vmlinux
|
|
else
|
|
CopyKernel=cp
|
|
fi
|
|
|
|
KernelVer=%{version}-%{release}.%{_target_cpu}${Flav}
|
|
echo BUILDING A KERNEL FOR ${Flavour} %{_target_cpu}...
|
|
|
|
%if 0%{?stable_update}
|
|
# make sure SUBLEVEL is incremented on a stable release. Sigh 3.x.
|
|
perl -p -i -e "s/^SUBLEVEL.*/SUBLEVEL = %{?stablerev}/" Makefile
|
|
%endif
|
|
|
|
# make sure EXTRAVERSION says what we want it to say
|
|
perl -p -i -e "s/^EXTRAVERSION.*/EXTRAVERSION = -%{release}.%{_target_cpu}${Flav}/" Makefile
|
|
|
|
# if pre-rc1 devel kernel, must fix up PATCHLEVEL for our versioning scheme
|
|
%if !0%{?rcrev}
|
|
%if 0%{?gitrev}
|
|
perl -p -i -e 's/^PATCHLEVEL.*/PATCHLEVEL = %{upstream_sublevel}/' Makefile
|
|
%endif
|
|
%endif
|
|
|
|
# and now to start the build process
|
|
|
|
make -s mrproper
|
|
cp configs/$Config .config
|
|
|
|
%if %{signmodules}
|
|
cp %{SOURCE11} .
|
|
%endif
|
|
|
|
chmod +x scripts/sign-file
|
|
|
|
Arch=`head -1 .config | cut -b 3-`
|
|
echo USING ARCH=$Arch
|
|
|
|
make -s ARCH=$Arch oldnoconfig >/dev/null
|
|
%ifarch %{arm}
|
|
# http://lists.infradead.org/pipermail/linux-arm-kernel/2012-March/091404.html
|
|
make -s ARCH=$Arch V=1 %{?_smp_mflags} $MakeTarget %{?sparse_mflags} KALLSYMS_EXTRA_PASS=1
|
|
|
|
make -s ARCH=$Arch V=1 dtbs
|
|
mkdir -p $RPM_BUILD_ROOT/%{image_install_path}/dtb-$KernelVer
|
|
install -m 644 arch/arm/boot/dts/*.dtb $RPM_BUILD_ROOT/boot/dtb-$KernelVer/
|
|
%else
|
|
make -s ARCH=$Arch V=1 %{?_smp_mflags} $MakeTarget %{?sparse_mflags}
|
|
%endif
|
|
make -s ARCH=$Arch V=1 %{?_smp_mflags} modules %{?sparse_mflags} || exit 1
|
|
|
|
# Start installing the results
|
|
%if %{with_debuginfo}
|
|
mkdir -p $RPM_BUILD_ROOT%{debuginfodir}/boot
|
|
mkdir -p $RPM_BUILD_ROOT%{debuginfodir}/%{image_install_path}
|
|
%endif
|
|
mkdir -p $RPM_BUILD_ROOT/%{image_install_path}
|
|
install -m 644 .config $RPM_BUILD_ROOT/boot/config-$KernelVer
|
|
install -m 644 System.map $RPM_BUILD_ROOT/boot/System.map-$KernelVer
|
|
|
|
# We estimate the size of the initramfs because rpm needs to take this size
|
|
# into consideration when performing disk space calculations. (See bz #530778)
|
|
dd if=/dev/zero of=$RPM_BUILD_ROOT/boot/initramfs-$KernelVer.img bs=1M count=20
|
|
|
|
if [ -f arch/$Arch/boot/zImage.stub ]; then
|
|
cp arch/$Arch/boot/zImage.stub $RPM_BUILD_ROOT/%{image_install_path}/zImage.stub-$KernelVer || :
|
|
fi
|
|
%if %{signmodules}
|
|
# Sign the image if we're using EFI
|
|
%pesign -s -i $KernelImage -o vmlinuz.signed
|
|
mv vmlinuz.signed $KernelImage
|
|
%endif
|
|
$CopyKernel $KernelImage \
|
|
$RPM_BUILD_ROOT/%{image_install_path}/$InstallName-$KernelVer
|
|
chmod 755 $RPM_BUILD_ROOT/%{image_install_path}/$InstallName-$KernelVer
|
|
|
|
# hmac sign the kernel for FIPS
|
|
echo "Creating hmac file: $RPM_BUILD_ROOT/%{image_install_path}/.vmlinuz-$KernelVer.hmac"
|
|
ls -l $RPM_BUILD_ROOT/%{image_install_path}/$InstallName-$KernelVer
|
|
sha512hmac $RPM_BUILD_ROOT/%{image_install_path}/$InstallName-$KernelVer | sed -e "s,$RPM_BUILD_ROOT,," > $RPM_BUILD_ROOT/%{image_install_path}/.vmlinuz-$KernelVer.hmac;
|
|
|
|
mkdir -p $RPM_BUILD_ROOT/lib/modules/$KernelVer
|
|
# Override $(mod-fw) because we don't want it to install any firmware
|
|
# we'll get it from the linux-firmware package and we don't want conflicts
|
|
make -s ARCH=$Arch INSTALL_MOD_PATH=$RPM_BUILD_ROOT modules_install KERNELRELEASE=$KernelVer mod-fw=
|
|
|
|
%ifarch %{vdso_arches}
|
|
make -s ARCH=$Arch INSTALL_MOD_PATH=$RPM_BUILD_ROOT vdso_install KERNELRELEASE=$KernelVer
|
|
if [ ! -s ldconfig-kernel.conf ]; then
|
|
echo > ldconfig-kernel.conf "\
|
|
# Placeholder file, no vDSO hwcap entries used in this kernel."
|
|
fi
|
|
%{__install} -D -m 444 ldconfig-kernel.conf \
|
|
$RPM_BUILD_ROOT/etc/ld.so.conf.d/kernel-$KernelVer.conf
|
|
%endif
|
|
|
|
# And save the headers/makefiles etc for building modules against
|
|
#
|
|
# This all looks scary, but the end result is supposed to be:
|
|
# * all arch relevant include/ files
|
|
# * all Makefile/Kconfig files
|
|
# * all script/ files
|
|
|
|
rm -f $RPM_BUILD_ROOT/lib/modules/$KernelVer/build
|
|
rm -f $RPM_BUILD_ROOT/lib/modules/$KernelVer/source
|
|
mkdir -p $RPM_BUILD_ROOT/lib/modules/$KernelVer/build
|
|
(cd $RPM_BUILD_ROOT/lib/modules/$KernelVer ; ln -s build source)
|
|
# dirs for additional modules per module-init-tools, kbuild/modules.txt
|
|
mkdir -p $RPM_BUILD_ROOT/lib/modules/$KernelVer/extra
|
|
mkdir -p $RPM_BUILD_ROOT/lib/modules/$KernelVer/updates
|
|
# first copy everything
|
|
cp --parents `find -type f -name "Makefile*" -o -name "Kconfig*"` $RPM_BUILD_ROOT/lib/modules/$KernelVer/build
|
|
cp Module.symvers $RPM_BUILD_ROOT/lib/modules/$KernelVer/build
|
|
cp System.map $RPM_BUILD_ROOT/lib/modules/$KernelVer/build
|
|
if [ -s Module.markers ]; then
|
|
cp Module.markers $RPM_BUILD_ROOT/lib/modules/$KernelVer/build
|
|
fi
|
|
# then drop all but the needed Makefiles/Kconfig files
|
|
rm -rf $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/Documentation
|
|
rm -rf $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/scripts
|
|
rm -rf $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/include
|
|
cp .config $RPM_BUILD_ROOT/lib/modules/$KernelVer/build
|
|
cp -a scripts $RPM_BUILD_ROOT/lib/modules/$KernelVer/build
|
|
if [ -d arch/$Arch/scripts ]; then
|
|
cp -a arch/$Arch/scripts $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/arch/%{_arch} || :
|
|
fi
|
|
if [ -f arch/$Arch/*lds ]; then
|
|
cp -a arch/$Arch/*lds $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/arch/%{_arch}/ || :
|
|
fi
|
|
rm -f $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/scripts/*.o
|
|
rm -f $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/scripts/*/*.o
|
|
%ifarch ppc ppc64 ppc64p7
|
|
cp -a --parents arch/powerpc/lib/crtsavres.[So] $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/
|
|
%endif
|
|
if [ -d arch/%{asmarch}/include ]; then
|
|
cp -a --parents arch/%{asmarch}/include $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/
|
|
fi
|
|
# include the machine specific headers for ARM variants, if available.
|
|
%ifarch %{arm}
|
|
if [ -d arch/%{asmarch}/mach-${Flavour}/include ]; then
|
|
cp -a --parents arch/%{asmarch}/mach-${Flavour}/include $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/
|
|
fi
|
|
%endif
|
|
cp -a include $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/include
|
|
|
|
# Make sure the Makefile and version.h have a matching timestamp so that
|
|
# external modules can be built
|
|
touch -r $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/Makefile $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/include/generated/uapi/linux/version.h
|
|
|
|
# Copy .config to include/config/auto.conf so "make prepare" is unnecessary.
|
|
cp $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/.config $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/include/config/auto.conf
|
|
|
|
%if %{with_debuginfo}
|
|
if test -s vmlinux.id; then
|
|
cp vmlinux.id $RPM_BUILD_ROOT/lib/modules/$KernelVer/build/vmlinux.id
|
|
else
|
|
echo >&2 "*** ERROR *** no vmlinux build ID! ***"
|
|
exit 1
|
|
fi
|
|
|
|
#
|
|
# save the vmlinux file for kernel debugging into the kernel-debuginfo rpm
|
|
#
|
|
mkdir -p $RPM_BUILD_ROOT%{debuginfodir}/lib/modules/$KernelVer
|
|
cp vmlinux $RPM_BUILD_ROOT%{debuginfodir}/lib/modules/$KernelVer
|
|
%endif
|
|
|
|
find $RPM_BUILD_ROOT/lib/modules/$KernelVer -name "*.ko" -type f >modnames
|
|
|
|
# mark modules executable so that strip-to-file can strip them
|
|
xargs --no-run-if-empty chmod u+x < modnames
|
|
|
|
# Generate a list of modules for block and networking.
|
|
|
|
grep -F /drivers/ modnames | xargs --no-run-if-empty nm -upA |
|
|
sed -n 's,^.*/\([^/]*\.ko\): *U \(.*\)$,\1 \2,p' > drivers.undef
|
|
|
|
collect_modules_list()
|
|
{
|
|
sed -r -n -e "s/^([^ ]+) \\.?($2)\$/\\1/p" drivers.undef |
|
|
LC_ALL=C sort -u > $RPM_BUILD_ROOT/lib/modules/$KernelVer/modules.$1
|
|
}
|
|
|
|
collect_modules_list networking \
|
|
'register_netdev|ieee80211_register_hw|usbnet_probe|phy_driver_register|rt(l_|2x00)(pci|usb)_probe'
|
|
collect_modules_list block \
|
|
'ata_scsi_ioctl|scsi_add_host|scsi_add_host_with_dma|blk_init_queue|register_mtd_blktrans|scsi_esp_register|scsi_register_device_handler'
|
|
collect_modules_list drm \
|
|
'drm_open|drm_init'
|
|
collect_modules_list modesetting \
|
|
'drm_crtc_init'
|
|
|
|
# detect missing or incorrect license tags
|
|
rm -f modinfo
|
|
while read i
|
|
do
|
|
echo -n "${i#$RPM_BUILD_ROOT/lib/modules/$KernelVer/} " >> modinfo
|
|
/sbin/modinfo -l $i >> modinfo
|
|
done < modnames
|
|
|
|
grep -E -v \
|
|
'GPL( v2)?$|Dual BSD/GPL$|Dual MPL/GPL$|GPL and additional rights$' \
|
|
modinfo && exit 1
|
|
|
|
rm -f modinfo modnames
|
|
|
|
# Call the modules-extra script to move things around
|
|
%{SOURCE17} $RPM_BUILD_ROOT/lib/modules/$KernelVer %{SOURCE16}
|
|
|
|
%if %{signmodules}
|
|
# Save the signing keys so we can sign the modules in __modsign_install_post
|
|
cp signing_key.priv signing_key.priv.sign${Flav}
|
|
cp signing_key.x509 signing_key.x509.sign${Flav}
|
|
%endif
|
|
|
|
# remove files that will be auto generated by depmod at rpm -i time
|
|
for i in alias alias.bin builtin.bin ccwmap dep dep.bin ieee1394map inputmap isapnpmap ofmap pcimap seriomap symbols symbols.bin usbmap devname softdep
|
|
do
|
|
rm -f $RPM_BUILD_ROOT/lib/modules/$KernelVer/modules.$i
|
|
done
|
|
|
|
# Move the devel headers out of the root file system
|
|
mkdir -p $RPM_BUILD_ROOT/usr/src/kernels
|
|
mv $RPM_BUILD_ROOT/lib/modules/$KernelVer/build $RPM_BUILD_ROOT/$DevelDir
|
|
|
|
# This is going to create a broken link during the build, but we don't use
|
|
# it after this point. We need the link to actually point to something
|
|
# when kernel-devel is installed, and a relative link doesn't work across
|
|
# the F17 UsrMove feature.
|
|
ln -sf $DevelDir $RPM_BUILD_ROOT/lib/modules/$KernelVer/build
|
|
|
|
# prune junk from kernel-devel
|
|
find $RPM_BUILD_ROOT/usr/src/kernels -name ".*.cmd" -exec rm -f {} \;
|
|
}
|
|
|
|
###
|
|
# DO it...
|
|
###
|
|
|
|
# prepare directories
|
|
rm -rf $RPM_BUILD_ROOT
|
|
mkdir -p $RPM_BUILD_ROOT/boot
|
|
mkdir -p $RPM_BUILD_ROOT%{_libexecdir}
|
|
|
|
cd linux-%{KVERREL}
|
|
|
|
%if %{with_debug}
|
|
BuildKernel %make_target %kernel_image debug
|
|
%endif
|
|
|
|
%if %{with_pae_debug}
|
|
BuildKernel %make_target %kernel_image PAEdebug
|
|
%endif
|
|
|
|
%if %{with_pae}
|
|
BuildKernel %make_target %kernel_image PAE
|
|
%endif
|
|
|
|
%if %{with_kirkwood}
|
|
BuildKernel %make_target %kernel_image kirkwood
|
|
%endif
|
|
|
|
%if %{with_omap}
|
|
BuildKernel %make_target %kernel_image omap
|
|
%endif
|
|
|
|
%if %{with_tegra}
|
|
BuildKernel %make_target %kernel_image tegra
|
|
%endif
|
|
|
|
%if %{with_up}
|
|
BuildKernel %make_target %kernel_image
|
|
%endif
|
|
|
|
%if %{with_smp}
|
|
BuildKernel %make_target %kernel_image smp
|
|
%endif
|
|
|
|
%global perf_make \
|
|
make %{?_smp_mflags} -C tools/perf -s V=1 WERROR=0 NO_LIBUNWIND=1 HAVE_CPLUS_DEMANGLE=1 prefix=%{_prefix}
|
|
%if %{with_perf}
|
|
# perf
|
|
%{perf_make} all
|
|
%{perf_make} man || %{doc_build_fail}
|
|
%endif
|
|
|
|
%if %{with_tools}
|
|
%ifarch %{cpupowerarchs}
|
|
# cpupower
|
|
# make sure version-gen.sh is executable.
|
|
chmod +x tools/power/cpupower/utils/version-gen.sh
|
|
make %{?_smp_mflags} -C tools/power/cpupower CPUFREQ_BENCH=false
|
|
%ifarch %{ix86}
|
|
pushd tools/power/cpupower/debug/i386
|
|
make %{?_smp_mflags} centrino-decode powernow-k8-decode
|
|
popd
|
|
%endif
|
|
%ifarch x86_64
|
|
pushd tools/power/cpupower/debug/x86_64
|
|
make %{?_smp_mflags} centrino-decode powernow-k8-decode
|
|
popd
|
|
%endif
|
|
%ifarch %{ix86} x86_64
|
|
pushd tools/power/x86/x86_energy_perf_policy/
|
|
make
|
|
popd
|
|
pushd tools/power/x86/turbostat
|
|
make
|
|
popd
|
|
%endif #turbostat/x86_energy_perf_policy
|
|
%endif
|
|
%endif
|
|
|
|
%if %{with_doc}
|
|
# Make the HTML and man pages.
|
|
make htmldocs mandocs || %{doc_build_fail}
|
|
|
|
# sometimes non-world-readable files sneak into the kernel source tree
|
|
chmod -R a=rX Documentation
|
|
find Documentation -type d | xargs chmod u+w
|
|
%endif
|
|
|
|
# In the modsign case, we do 3 things. 1) We check the "flavour" and hard
|
|
# code the value in the following invocations. This is somewhat sub-optimal
|
|
# but we're doing this inside of an RPM macro and it isn't as easy as it
|
|
# could be because of that. 2) We restore the .tmp_versions/ directory from
|
|
# the one we saved off in BuildKernel above. This is to make sure we're
|
|
# signing the modules we actually built/installed in that flavour. 3) We
|
|
# grab the arch and invoke mod-sign.sh command to actually sign the modules.
|
|
#
|
|
# We have to do all of those things _after_ find-debuginfo runs, otherwise
|
|
# that will strip the signature off of the modules.
|
|
|
|
%define __modsign_install_post \
|
|
if [ "%{signmodules}" == "1" ]; then \
|
|
if [ "%{with_pae}" != "0" ]; then \
|
|
mv signing_key.priv.sign.PAE signing_key.priv \
|
|
mv signing_key.x509.sign.PAE signing_key.x509 \
|
|
%{modsign_cmd} $RPM_BUILD_ROOT/lib/modules/%{KVERREL}.PAE/ \
|
|
fi \
|
|
if [ "%{with_debug}" != "0" ]; then \
|
|
mv signing_key.priv.sign.debug signing_key.priv \
|
|
mv signing_key.x509.sign.debug signing_key.x509 \
|
|
%{modsign_cmd} $RPM_BUILD_ROOT/lib/modules/%{KVERREL}.debug/ \
|
|
fi \
|
|
if [ "%{with_pae_debug}" != "0" ]; then \
|
|
mv signing_key.priv.sign.PAEdebug signing_key.priv \
|
|
mv signing_key.x509.sign.PAEdebug signing_key.x509 \
|
|
%{modsign_cmd} $RPM_BUILD_ROOT/lib/modules/%{KVERREL}.PAEdebug/ \
|
|
fi \
|
|
if [ "%{with_up}" != "0" ]; then \
|
|
mv signing_key.priv.sign signing_key.priv \
|
|
mv signing_key.x509.sign signing_key.x509 \
|
|
%{modsign_cmd} $RPM_BUILD_ROOT/lib/modules/%{KVERREL}/ \
|
|
fi \
|
|
fi \
|
|
%{nil}
|
|
|
|
###
|
|
### Special hacks for debuginfo subpackages.
|
|
###
|
|
|
|
# This macro is used by %%install, so we must redefine it before that.
|
|
%define debug_package %{nil}
|
|
|
|
%if %{with_debuginfo}
|
|
|
|
%define __debug_install_post \
|
|
/usr/lib/rpm/find-debuginfo.sh %{debuginfo_args} %{_builddir}/%{?buildsubdir}\
|
|
%{nil}
|
|
|
|
%ifnarch noarch
|
|
%global __debug_package 1
|
|
%files -f debugfiles.list debuginfo-common-%{_target_cpu}
|
|
%defattr(-,root,root)
|
|
%endif
|
|
|
|
%endif
|
|
|
|
#
|
|
# Disgusting hack alert! We need to ensure we sign modules *after* all
|
|
# invocations of strip occur, which is in __debug_install_post if
|
|
# find-debuginfo.sh runs, and __os_install_post if not.
|
|
#
|
|
%define __spec_install_post \
|
|
%{?__debug_package:%{__debug_install_post}}\
|
|
%{__arch_install_post}\
|
|
%{__os_install_post}\
|
|
%{__modsign_install_post}
|
|
|
|
###
|
|
### install
|
|
###
|
|
|
|
%install
|
|
|
|
cd linux-%{KVERREL}
|
|
|
|
%if %{with_doc}
|
|
docdir=$RPM_BUILD_ROOT%{_datadir}/doc/kernel-doc-%{rpmversion}
|
|
man9dir=$RPM_BUILD_ROOT%{_datadir}/man/man9
|
|
|
|
# copy the source over
|
|
mkdir -p $docdir
|
|
tar -h -f - --exclude=man --exclude='.*' -c Documentation | tar xf - -C $docdir
|
|
|
|
# Install man pages for the kernel API.
|
|
mkdir -p $man9dir
|
|
find Documentation/DocBook/man -name '*.9.gz' -print0 |
|
|
xargs -0 --no-run-if-empty %{__install} -m 444 -t $man9dir $m
|
|
ls $man9dir | grep -q '' || > $man9dir/BROKEN
|
|
%endif # with_doc
|
|
|
|
# We have to do the headers install before the tools install because the
|
|
# kernel headers_install will remove any header files in /usr/include that
|
|
# it doesn't install itself.
|
|
|
|
%if %{with_headers}
|
|
# Install kernel headers
|
|
make ARCH=%{hdrarch} INSTALL_HDR_PATH=$RPM_BUILD_ROOT/usr headers_install
|
|
|
|
# Do headers_check but don't die if it fails.
|
|
make ARCH=%{hdrarch} INSTALL_HDR_PATH=$RPM_BUILD_ROOT/usr headers_check \
|
|
> hdrwarnings.txt || :
|
|
if grep -q exist hdrwarnings.txt; then
|
|
sed s:^$RPM_BUILD_ROOT/usr/include/:: hdrwarnings.txt
|
|
# Temporarily cause a build failure if header inconsistencies.
|
|
# exit 1
|
|
fi
|
|
|
|
find $RPM_BUILD_ROOT/usr/include \
|
|
\( -name .install -o -name .check -o \
|
|
-name ..install.cmd -o -name ..check.cmd \) | xargs rm -f
|
|
|
|
# glibc provides scsi headers for itself, for now
|
|
rm -rf $RPM_BUILD_ROOT/usr/include/scsi
|
|
rm -f $RPM_BUILD_ROOT/usr/include/asm*/atomic.h
|
|
rm -f $RPM_BUILD_ROOT/usr/include/asm*/io.h
|
|
rm -f $RPM_BUILD_ROOT/usr/include/asm*/irq.h
|
|
%endif
|
|
|
|
%if %{with_perf}
|
|
# perf tool binary and supporting scripts/binaries
|
|
%{perf_make} DESTDIR=$RPM_BUILD_ROOT install
|
|
|
|
# python-perf extension
|
|
%{perf_make} DESTDIR=$RPM_BUILD_ROOT install-python_ext
|
|
|
|
# perf man pages (note: implicit rpm magic compresses them later)
|
|
%{perf_make} DESTDIR=$RPM_BUILD_ROOT install-man || %{doc_build_fail}
|
|
%endif
|
|
|
|
%if %{with_tools}
|
|
%ifarch %{cpupowerarchs}
|
|
make -C tools/power/cpupower DESTDIR=$RPM_BUILD_ROOT libdir=%{_libdir} mandir=%{_mandir} CPUFREQ_BENCH=false install
|
|
rm -f %{buildroot}%{_libdir}/*.{a,la}
|
|
%find_lang cpupower
|
|
mv cpupower.lang ../
|
|
%ifarch %{ix86}
|
|
pushd tools/power/cpupower/debug/i386
|
|
install -m755 centrino-decode %{buildroot}%{_bindir}/centrino-decode
|
|
install -m755 powernow-k8-decode %{buildroot}%{_bindir}/powernow-k8-decode
|
|
popd
|
|
%endif
|
|
%ifarch x86_64
|
|
pushd tools/power/cpupower/debug/x86_64
|
|
install -m755 centrino-decode %{buildroot}%{_bindir}/centrino-decode
|
|
install -m755 powernow-k8-decode %{buildroot}%{_bindir}/powernow-k8-decode
|
|
popd
|
|
%endif
|
|
chmod 0755 %{buildroot}%{_libdir}/libcpupower.so*
|
|
mkdir -p %{buildroot}%{_unitdir} %{buildroot}%{_sysconfdir}/sysconfig
|
|
install -m644 %{SOURCE2000} %{buildroot}%{_unitdir}/cpupower.service
|
|
install -m644 %{SOURCE2001} %{buildroot}%{_sysconfdir}/sysconfig/cpupower
|
|
%endif
|
|
%ifarch %{ix86} x86_64
|
|
mkdir -p %{buildroot}%{_mandir}/man8
|
|
pushd tools/power/x86/x86_energy_perf_policy
|
|
make DESTDIR=%{buildroot} install
|
|
popd
|
|
pushd tools/power/x86/turbostat
|
|
make DESTDIR=%{buildroot} install
|
|
popd
|
|
%endif #turbostat/x86_energy_perf_policy
|
|
%endif
|
|
|
|
%if %{with_bootwrapper}
|
|
make DESTDIR=$RPM_BUILD_ROOT bootwrapper_install WRAPPER_OBJDIR=%{_libdir}/kernel-wrapper WRAPPER_DTSDIR=%{_libdir}/kernel-wrapper/dts
|
|
%endif
|
|
|
|
|
|
###
|
|
### clean
|
|
###
|
|
|
|
%clean
|
|
rm -rf $RPM_BUILD_ROOT
|
|
|
|
###
|
|
### scripts
|
|
###
|
|
|
|
%if %{with_tools}
|
|
%post -n kernel-tools
|
|
/sbin/ldconfig
|
|
|
|
%postun -n kernel-tools
|
|
/sbin/ldconfig
|
|
%endif
|
|
|
|
#
|
|
# This macro defines a %%post script for a kernel*-devel package.
|
|
# %%kernel_devel_post [<subpackage>]
|
|
#
|
|
%define kernel_devel_post() \
|
|
%{expand:%%post %{?1:%{1}-}devel}\
|
|
if [ -f /etc/sysconfig/kernel ]\
|
|
then\
|
|
. /etc/sysconfig/kernel || exit $?\
|
|
fi\
|
|
if [ "$HARDLINK" != "no" -a -x /usr/sbin/hardlink ]\
|
|
then\
|
|
(cd /usr/src/kernels/%{KVERREL}%{?1:.%{1}} &&\
|
|
/usr/bin/find . -type f | while read f; do\
|
|
hardlink -c /usr/src/kernels/*.fc*.*/$f $f\
|
|
done)\
|
|
fi\
|
|
%{nil}
|
|
|
|
#
|
|
# This macro defines a %%post script for a kernel*-modules-extra package.
|
|
# %%kernel_modules-extra_post [<subpackage>]
|
|
#
|
|
%define kernel_modules_extra_post() \
|
|
%{expand:%%post %{?1:%{1}-}modules-extra}\
|
|
/sbin/depmod -a %{KVERREL}%{?1:.%{1}}\
|
|
%{nil}
|
|
|
|
# This macro defines a %%posttrans script for a kernel package.
|
|
# %%kernel_variant_posttrans [<subpackage>]
|
|
# More text can follow to go at the end of this variant's %%post.
|
|
#
|
|
%define kernel_variant_posttrans() \
|
|
%{expand:%%posttrans %{?1}}\
|
|
/sbin/new-kernel-pkg --package kernel%{?-v:-%{-v*}} --mkinitrd --dracut --depmod --update %{KVERREL}%{?-v:.%{-v*}} || exit $?\
|
|
/sbin/new-kernel-pkg --package kernel%{?1:-%{1}} --rpmposttrans %{KVERREL}%{?1:.%{1}} || exit $?\
|
|
%{nil}
|
|
|
|
#
|
|
# This macro defines a %%post script for a kernel package and its devel package.
|
|
# %%kernel_variant_post [-v <subpackage>] [-r <replace>]
|
|
# More text can follow to go at the end of this variant's %%post.
|
|
#
|
|
%define kernel_variant_post(v:r:) \
|
|
%{expand:%%kernel_devel_post %{?-v*}}\
|
|
%{expand:%%kernel_modules_extra_post %{?-v*}}\
|
|
%{expand:%%kernel_variant_posttrans %{?-v*}}\
|
|
%{expand:%%post %{?-v*}}\
|
|
%{-r:\
|
|
if [ `uname -i` == "x86_64" -o `uname -i` == "i386" ] &&\
|
|
[ -f /etc/sysconfig/kernel ]; then\
|
|
/bin/sed -r -i -e 's/^DEFAULTKERNEL=%{-r*}$/DEFAULTKERNEL=kernel%{?-v:-%{-v*}}/' /etc/sysconfig/kernel || exit $?\
|
|
fi}\
|
|
%{expand:\
|
|
/sbin/new-kernel-pkg --package kernel%{?-v:-%{-v*}} --install %{KVERREL}%{?-v:.%{-v*}} || exit $?\
|
|
}\
|
|
%{nil}
|
|
|
|
#
|
|
# This macro defines a %%preun script for a kernel package.
|
|
# %%kernel_variant_preun <subpackage>
|
|
#
|
|
%define kernel_variant_preun() \
|
|
%{expand:%%preun %{?1}}\
|
|
/sbin/new-kernel-pkg --rminitrd --rmmoddep --remove %{KVERREL}%{?1:.%{1}} || exit $?\
|
|
%{nil}
|
|
|
|
%kernel_variant_preun
|
|
%kernel_variant_post -r kernel-smp
|
|
|
|
%kernel_variant_preun smp
|
|
%kernel_variant_post -v smp
|
|
|
|
%kernel_variant_preun PAE
|
|
%kernel_variant_post -v PAE -r (kernel|kernel-smp)
|
|
|
|
%kernel_variant_preun debug
|
|
%kernel_variant_post -v debug
|
|
|
|
%kernel_variant_post -v PAEdebug -r (kernel|kernel-smp)
|
|
%kernel_variant_preun PAEdebug
|
|
|
|
%kernel_variant_preun kirkwood
|
|
%kernel_variant_post -v kirkwood
|
|
|
|
%kernel_variant_preun omap
|
|
%kernel_variant_post -v omap
|
|
|
|
%kernel_variant_preun tegra
|
|
%kernel_variant_post -v tegra
|
|
|
|
if [ -x /sbin/ldconfig ]
|
|
then
|
|
/sbin/ldconfig -X || exit $?
|
|
fi
|
|
|
|
###
|
|
### file lists
|
|
###
|
|
|
|
%if %{with_headers}
|
|
%files headers
|
|
%defattr(-,root,root)
|
|
/usr/include/*
|
|
%endif
|
|
|
|
%if %{with_bootwrapper}
|
|
%files bootwrapper
|
|
%defattr(-,root,root)
|
|
/usr/sbin/*
|
|
%{_libdir}/kernel-wrapper
|
|
%endif
|
|
|
|
# only some architecture builds need kernel-doc
|
|
%if %{with_doc}
|
|
%files doc
|
|
%defattr(-,root,root)
|
|
%{_datadir}/doc/kernel-doc-%{rpmversion}/Documentation/*
|
|
%dir %{_datadir}/doc/kernel-doc-%{rpmversion}/Documentation
|
|
%dir %{_datadir}/doc/kernel-doc-%{rpmversion}
|
|
%{_datadir}/man/man9/*
|
|
%endif
|
|
|
|
%if %{with_perf}
|
|
%files -n perf
|
|
%defattr(-,root,root)
|
|
%{_bindir}/perf
|
|
%dir %{_libexecdir}/perf-core
|
|
%{_libexecdir}/perf-core/*
|
|
%{_mandir}/man[1-8]/perf*
|
|
%{_sysconfdir}/bash_completion.d/perf
|
|
%doc linux-%{KVERREL}/tools/perf/Documentation/examples.txt
|
|
|
|
%files -n python-perf
|
|
%defattr(-,root,root)
|
|
%{python_sitearch}
|
|
|
|
%if %{with_debuginfo}
|
|
%files -f perf-debuginfo.list -n perf-debuginfo
|
|
%defattr(-,root,root)
|
|
|
|
%files -f python-perf-debuginfo.list -n python-perf-debuginfo
|
|
%defattr(-,root,root)
|
|
%endif
|
|
%endif # with_perf
|
|
|
|
%if %{with_tools}
|
|
%files -n kernel-tools -f cpupower.lang
|
|
%defattr(-,root,root)
|
|
%ifarch %{cpupowerarchs}
|
|
%{_bindir}/cpupower
|
|
%ifarch %{ix86} x86_64
|
|
%{_bindir}/centrino-decode
|
|
%{_bindir}/powernow-k8-decode
|
|
%endif
|
|
%{_unitdir}/cpupower.service
|
|
%{_mandir}/man[1-8]/cpupower*
|
|
%config(noreplace) %{_sysconfdir}/sysconfig/cpupower
|
|
%ifarch %{ix86} x86_64
|
|
%{_bindir}/x86_energy_perf_policy
|
|
%{_mandir}/man8/x86_energy_perf_policy*
|
|
%{_bindir}/turbostat
|
|
%{_mandir}/man8/turbostat*
|
|
%endif
|
|
%endif
|
|
|
|
%if %{with_debuginfo}
|
|
%files -f kernel-tools-debuginfo.list -n kernel-tools-debuginfo
|
|
%defattr(-,root,root)
|
|
%endif
|
|
|
|
%ifarch %{cpupowerarchs}
|
|
%files -n kernel-tools-libs
|
|
%{_libdir}/libcpupower.so.0
|
|
%{_libdir}/libcpupower.so.0.0.0
|
|
|
|
%files -n kernel-tools-libs-devel
|
|
%{_libdir}/libcpupower.so
|
|
%{_includedir}/cpufreq.h
|
|
%endif
|
|
%endif # with_perf
|
|
|
|
# This is %%{image_install_path} on an arch where that includes ELF files,
|
|
# or empty otherwise.
|
|
%define elf_image_install_path %{?kernel_image_elf:%{image_install_path}}
|
|
|
|
#
|
|
# This macro defines the %%files sections for a kernel package
|
|
# and its devel and debuginfo packages.
|
|
# %%kernel_variant_files [-k vmlinux] <condition> <subpackage>
|
|
#
|
|
%define kernel_variant_files(k:) \
|
|
%if %{1}\
|
|
%{expand:%%files %{?2}}\
|
|
%defattr(-,root,root)\
|
|
/%{image_install_path}/%{?-k:%{-k*}}%{!?-k:vmlinuz}-%{KVERREL}%{?2:.%{2}}\
|
|
/%{image_install_path}/.vmlinuz-%{KVERREL}%{?2:.%{2}}.hmac \
|
|
%ifarch %{arm}\
|
|
/%{image_install_path}/dtb-%{KVERREL}%{?2:.%{2}} \
|
|
%endif\
|
|
%attr(600,root,root) /boot/System.map-%{KVERREL}%{?2:.%{2}}\
|
|
/boot/config-%{KVERREL}%{?2:.%{2}}\
|
|
%dir /lib/modules/%{KVERREL}%{?2:.%{2}}\
|
|
/lib/modules/%{KVERREL}%{?2:.%{2}}/kernel\
|
|
/lib/modules/%{KVERREL}%{?2:.%{2}}/build\
|
|
/lib/modules/%{KVERREL}%{?2:.%{2}}/source\
|
|
/lib/modules/%{KVERREL}%{?2:.%{2}}/updates\
|
|
%ifarch %{vdso_arches}\
|
|
/lib/modules/%{KVERREL}%{?2:.%{2}}/vdso\
|
|
/etc/ld.so.conf.d/kernel-%{KVERREL}%{?2:.%{2}}.conf\
|
|
%endif\
|
|
/lib/modules/%{KVERREL}%{?2:.%{2}}/modules.*\
|
|
%ghost /boot/initramfs-%{KVERREL}%{?2:.%{2}}.img\
|
|
%{expand:%%files %{?2:%{2}-}devel}\
|
|
%defattr(-,root,root)\
|
|
/usr/src/kernels/%{KVERREL}%{?2:.%{2}}\
|
|
%{expand:%%files %{?2:%{2}-}modules-extra}\
|
|
%defattr(-,root,root)\
|
|
/lib/modules/%{KVERREL}%{?2:.%{2}}/extra\
|
|
%if %{with_debuginfo}\
|
|
%ifnarch noarch\
|
|
%{expand:%%files -f debuginfo%{?2}.list %{?2:%{2}-}debuginfo}\
|
|
%defattr(-,root,root)\
|
|
%endif\
|
|
%endif\
|
|
%endif\
|
|
%{nil}
|
|
|
|
|
|
%kernel_variant_files %{with_up}
|
|
%kernel_variant_files %{with_smp} smp
|
|
%kernel_variant_files %{with_debug} debug
|
|
%kernel_variant_files %{with_pae} PAE
|
|
%kernel_variant_files %{with_pae_debug} PAEdebug
|
|
%kernel_variant_files %{with_kirkwood} kirkwood
|
|
%kernel_variant_files %{with_omap} omap
|
|
%kernel_variant_files %{with_tegra} tegra
|
|
|
|
# plz don't put in a version string unless you're going to tag
|
|
# and build.
|
|
|
|
# ___________________________________________________________
|
|
# / This branch is for Fedora 19. You probably want to commit \
|
|
# \ to the F-18 branch instead, or in addition to this one. /
|
|
# -----------------------------------------------------------
|
|
# \ ^__^
|
|
# \ (@@)\_______
|
|
# (__)\ )\/\
|
|
# ||----w |
|
|
# || ||
|
|
%changelog
|
|
* Wed Feb 06 2013 Josh Boyer <jwboyer@redhat.com> - 3.8.0-0.rc6.git3.3
|
|
- Enable CONFIG_NAMESPACES everywhere (rhbz 907576)
|
|
- Add patch to fix ath9k dma stop checks (rhbz 892811)
|
|
|
|
* Wed Feb 06 2013 Josh Boyer <jwboyer@redhat.com> - 3.8.0-0.rc6.git3.1
|
|
- Linux v3.8-rc6-98-g1589a3e
|
|
- Add patch to honor MokSBState (rhbz 907406)
|
|
|
|
* Tue Feb 05 2013 Josh Boyer <jwboyer@redhat.com> - 3.8.0-0.rc6.git2.1
|
|
- Linux v3.8-rc6-62-gfe547d7
|
|
- Enable CONFIG_DRM_VMWGFX_FBCON (rhbz 907620)
|
|
- Enable CONFIG_DETECT_HUNG_TASK
|
|
|
|
* Mon Feb 04 2013 Josh Boyer <jwboyer@redhat.com> - 3.8.0-0.rc6.git1.1
|
|
- Linux v3.8-rc6-22-g6edacf0
|
|
- Enable CONFIG_EXT4_DEBUG
|
|
- Fix rtlwifi scheduling while atomic from Larry Finger (rhbz 903881)
|
|
|
|
* Fri Feb 01 2013 Josh Boyer <jwboyer@redhat.com> - 3.8.0-0.rc6.git0.1
|
|
- Linux v3.8-rc6
|
|
- Enable CONFIG_DMA_API_DEBUG
|
|
- Add patches to improve mac80211 latency and throughput (rhbz 830151)
|
|
|
|
* Thu Jan 31 2013 Josh Boyer <jwboyer@redhat.com> - 3.8.0-0.rc5.git3.1
|
|
- Linux v3.8-rc5-245-g04c2eee
|
|
- Enable CONFIG_DEBUG_STACK_USAGE
|
|
|
|
* Wed Jan 30 2013 Josh Boyer <jwboyer@redhat.com> - 3.8.0-0.rc5.git2.1
|
|
- Linux v3.8-rc5-218-ga56e160
|
|
- Enable NAMESPACES and CHECKPOINT_RESTORE on x86_64 for F19 CRIU feature
|
|
- Enable CONFIG_DEBUG_ATOMIC_SLEEP
|
|
|
|
* Tue Jan 29 2013 Josh Boyer <jwboyer@redhat.com> - 3.8.0-0.rc5.git1.1
|
|
- Linux v3.8-rc5-150-g6abb7c2
|
|
|
|
* Tue Jan 29 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- Backport driver for Cypress PS/2 trackpad (rhbz 799564)
|
|
|
|
* Mon Jan 28 2013 Josh Boyer <jwboyer@redhat.com> - 3.8.0-0.rc5.git0.1
|
|
- Linux v3.8-rc5
|
|
- Add patches to fix issues with iwlwifi (rhbz 863424)
|
|
- Enable CONFIG_PROVE_RCU
|
|
|
|
* Sun Jan 27 2013 Peter Robinson <pbrobinson@fedoraproject.org>
|
|
- Reenable perf on ARM (was suppose to be temporary)
|
|
- Build and package dtbs on ARM
|
|
- Enable FB options for qemu vexpress on unified
|
|
|
|
* Fri Jan 25 2013 Kyle McMartin <kmcmarti@redhat.com>
|
|
- Sign all modules with the mod-extra-sign.sh script, ensures nothing gets
|
|
missed because of .config differences between invocations of BuildKernel.
|
|
|
|
* Fri Jan 25 2013 Justin M. Forbes <jforbes@redhat.com>
|
|
- Turn off THP for 32bit
|
|
|
|
* Fri Jan 25 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc4.git5.1
|
|
- Linux v3.8-rc4-277-g66e2d3e
|
|
- Enable slub debug
|
|
|
|
* Thu Jan 24 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- Update secure-boot patchset
|
|
|
|
* Thu Jan 24 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc4.git4.1
|
|
- Linux v3.8-rc4-183-gff7532c
|
|
- Enable lockdep
|
|
|
|
* Wed Jan 23 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc4.git3.1
|
|
- Linux v3.8-rc4-139-g1d85490
|
|
- Enable debug spinlocks
|
|
|
|
* Wed Jan 23 2013 Dave Jones <davej@redhat.com>
|
|
- Remove warnings about empty IPI masks.
|
|
|
|
* Sun Jan 20 2013 Peter Robinson <pbrobinson@fedoraproject.org>
|
|
- Remove obsolete ARM configs
|
|
- Update OMAP config for TI AM35XX SoCs
|
|
- Add patch to fix versatile build failure
|
|
|
|
* Sat Jan 19 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc4.git1.1
|
|
- Linux v3.8-rc4-42-g5da1f88
|
|
|
|
* Fri Jan 18 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc4.git0.1
|
|
- Linux v3.8-rc4
|
|
- Disable debugging options.
|
|
|
|
* Fri Jan 18 2013 Peter Robinson <pbrobinson@fedoraproject.org>
|
|
- Disable problematic PL310 ARM errata
|
|
- Minor ARM config tweaks
|
|
- OMAP DRM driver to fix OMAP kernel build
|
|
|
|
* Wed Jan 16 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- Fix power management sysfs on non-secure boot machines (rhbz 896243)
|
|
|
|
* Wed Jan 16 2013 Dave Jones <davej@redhat.com>
|
|
- Experiment: Double the length of the brcmsmac transmit timeout.
|
|
|
|
* Wed Jan 16 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- Add patch from Stanislaw Gruszka to fix iwlegacy IBSS cleanup (rhbz 886946)
|
|
|
|
* Tue Jan 15 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc3.git2.1
|
|
- Linux v3.8-rc3-293-g406089d
|
|
|
|
* Tue Jan 15 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- Enable CONFIG_DVB_USB_V2 (rhbz 895460)
|
|
|
|
* Mon Jan 14 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- Enable Orinoco drivers in kernel-modules-extra (rhbz 894069)
|
|
|
|
* Mon Jan 14 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc3.git1.1
|
|
- Linux v3.8-rc3-74-gb719f43
|
|
|
|
* Fri Jan 11 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- Update secure-boot patchset
|
|
|
|
* Thu Jan 10 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc3.git0.2
|
|
- Reenable debugging options.
|
|
|
|
* Thu Jan 10 2013 Dave Jones <davej@redhat.com>
|
|
- Drop old Montevina era E1000 workaround.
|
|
|
|
* Thu Jan 10 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc3.git0.1
|
|
- Linux v3.8-rc3
|
|
- Disable debugging options.
|
|
|
|
* Wed Jan 09 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc2.git4.1
|
|
- Linux v3.8-rc2-370-g57a0c1e
|
|
|
|
* Wed Jan 9 2013 Peter Robinson <pbrobinson@fedoraproject.org>
|
|
- Update ARM mvebu config
|
|
|
|
* Wed Jan 09 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- Enable CONFIG_CIFS_DEBUG as it was on before it was split out
|
|
|
|
* Tue Jan 08 2013 Kyle McMartin <kmcmarti@redhat.com>
|
|
- Ensure modules are signed even if *-debuginfo rpms are not produced by
|
|
re-defining __spec_install_post and adding a hook after all strip
|
|
invocations. Ideally, in the future, we could patch the rpm macro and
|
|
remove the re-define from kernel.spec, but that's another windmill to tilt
|
|
at.
|
|
|
|
* Tue Jan 08 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc2.git3.1
|
|
- Linux v3.8-rc2-222-g2a893f9
|
|
|
|
* Mon Jan 07 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc2.git2.1
|
|
- Linux v3.8-rc2-191-gd287b87
|
|
- remove the namei-include.patch, it's upstream now
|
|
|
|
* Mon Jan 07 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc2.git1.2
|
|
- Reenable debugging options.
|
|
|
|
* Mon Jan 7 2013 Peter Robinson <pbrobinson@fedoraproject.org>
|
|
- Further ARM config updates
|
|
- Add patch to fix building omapdrm
|
|
|
|
* Mon Jan 07 2013 Justin M. Forbes <jforbes@redhat.com>
|
|
- Bye sparc
|
|
|
|
* Mon Jan 07 2013 Justin M. Forbes <jforbes@redhat.com>
|
|
- Fix up configs for build
|
|
|
|
* Mon Jan 07 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- Patch to fix efivarfs underflow from Lingzhu Xiang (rhbz 888163)
|
|
|
|
* Sat Jan 5 2013 Peter Robinson <pbrobinson@fedoraproject.org>
|
|
- Initial update of ARM configs for 3.8
|
|
- Enable DRM driver for tegra
|
|
- Drop separate imx kernel. Will be reintroduced soon in unified
|
|
|
|
* Fri Jan 04 2013 Justin M. Forbes <jforbes@redhat.com> - 3.8.0-0.rc2.git1.1
|
|
- Linux v3.8-rc2-116-g5f243b9
|
|
|
|
* Thu Jan 03 2013 Justin M. Forbes <jforbes@redhat.com>
|
|
- Initial 3.8-rc2 rebase
|
|
|
|
* Wed Jan 02 2013 Josh Boyer <jwboyer@redhat.com>
|
|
- BR the hostname package (rhbz 886113)
|
|
|
|
* Tue Dec 18 2012 Dave Jones <davej@redhat.com>
|
|
- On rebases, list new config options.
|
|
(Revert to pre-18 behaviour)
|
|
|
|
* Mon Dec 17 2012 Josh Boyer <jwboyer@redhat.com>
|
|
- Fix oops in sony-laptop setup (rhbz 873107)
|
|
|
|
* Fri Dec 14 2012 Peter Robinson <pbrobinson@fedoraproject.org>
|
|
- Add patch to fix arm imx drm driver build
|
|
|
|
* Wed Dec 12 2012 Josh Boyer <jwboyer@redhat.com>
|
|
- Fix infinite loop in efi signature parser
|
|
- Don't error out if db doesn't exist
|
|
|
|
* Tue Dec 11 2012 Peter Robinson <pbrobinson@fedoraproject.org>
|
|
- Update ARM configs for latest 3.7
|
|
- Drop highbank kernel build variant as its in unified kernel
|
|
|
|
* Tue Dec 11 2012 Josh Boyer <jwboyer@redhat.com>
|
|
- Update secure boot patches to include MoK support
|
|
- Fix IBSS scanning in mac80211 (rhbz 883414)
|
|
|
|
* Tue Dec 11 2012 Dave Jones <davej@redhat.com> - 3.7.0-2
|
|
- Reenable debugging options.
|
|
|
|
* Tue Dec 11 2012 Dave Jones <davej@redhat.com> - 3.7.0-1
|
|
- Linux v3.7
|
|
|
|
###
|
|
# The following Emacs magic makes C-c C-e use UTC dates.
|
|
# Local Variables:
|
|
# rpm-change-log-uses-utc: t
|
|
# End:
|
|
###
|