]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/blobdiff - debian/rules
nbd: make sure request completion won't concurrent
[mirror_ubuntu-jammy-kernel.git] / debian / rules
index 1d53ecc1df7f308da6663195f49c4097c818c15f..732b5eeea63cb9e525fc63eba9daa8e8dde13f0f 100755 (executable)
@@ -39,22 +39,16 @@ do_tools_common?=true
 do_tools_host?=false
 do_tools_perf_jvmti?=false
 do_enforce_all?=false
-ifneq ($(filter noudeb,$(DEB_BUILD_PROFILES)),)
-disable_d_i=true
-endif
 
-# Don't build udebs if $(DEBIAN)/d-i/ doesn't exist
-ifeq ($(wildcard $(DEBIAN)/d-i/.),)
-       disable_d_i=true
-endif
+# Default settings for DKMS modules.
+$(foreach _m,$(all_dkms_modules), \
+  $(eval do_$(_m) ?= $(if $(filter $(_m),$(filter-out $(dkms_exclude),$(dkms_include) $(subst any,$(_m),$(subst $(arch),$(_m),$(dkms_$(_m)_archs))))),true,false)) \
+)
 
-# Don't build tools or udebs in a cross compile environment.
+# Don't build tools in a cross compile environment.
 ifneq ($(DEB_HOST_ARCH),$(DEB_BUILD_ARCH))
        do_tools=false
-       disable_d_i=true
-       do_zfs=false
-       do_dkms_nvidia=false
-       do_dkms_nvidia_server=false
+$(foreach _m,$(all_dkms_modules),$(eval do_$(_m) = false))
 endif
 
 # Are any of the kernel signing options enabled.
@@ -85,10 +79,7 @@ endif
 #  - disable dkms builds as the versions used may have been deleted
 ifneq ($(filter autopkgtest,$(DEB_BUILD_PROFILES)),)
        flavours := $(firstword $(flavours))
-       disable_d_i=true
-       do_zfs=false
-       do_dkms_nvidia=false
-       do_dkms_nvidia_server=false
+$(foreach _m,$(all_dkms_modules),$(eval do_$(_m) = false))
 endif
 
 # Being used to build a mainline build -- turn off things which do not work.
@@ -96,9 +87,7 @@ ifeq ($(do_mainline_build),true)
        do_extras_package=false
        do_tools=false
        no_dumpfile=1
-       do_zfs=false
-       do_dkms_nvidia=false
-       do_dkms_nvidia_server=false
+$(foreach _m,$(all_dkms_modules),$(eval do_$(_m) = false))
        skipabi=true
        skipmodule=true
        skipretpoline=true
@@ -112,9 +101,11 @@ ifneq ($(do_tools),true)
        do_tools_host=
 endif
 
-ifeq ($(do_zfs),false)
-       do_zfs_disable:=$(shell for m in $$(cat $(DROOT)/zfs-modules.ignore); do grep -qxF $$m $(prev_abidir)/../modules.ignore 2>/dev/null || echo $$m >> $(prev_abidir)/../modules.ignore; done)
-endif
+$(foreach _m,$(all_built-in_dkms_modules), \
+  $(if $(filter true,$(do_$(_m))),, \
+    $(eval do_$(_m)_disable := $$(shell for m in $$$$(cat $(DROOT)/$(_m)-modules.ignore); do grep -qxF $$$$m $(prev_abidir)/../modules.ignore 2>/dev/null || echo $$$$m >> $(prev_abidir)/../modules.ignore; done)) \
+  ) \
+)
 
 ifeq ($(do_dkms_wireguard),false)
        do_wireguard_disable:=$(shell for m in $$(cat $(DROOT)/wireguard-modules.ignore); do grep -qxF $$m $(prev_abidir)/../modules.ignore 2>/dev/null || echo $$m >> $(prev_abidir)/../modules.ignore; done)
@@ -123,9 +114,6 @@ endif
 # Either tools package needs the common source preparation
 do_any_tools=$(sort $(filter-out false,$(do_linux_tools) $(do_cloud_tools)))
 
-# Versions of dkms packages.
-dkms_zfs_linux_version=$(shell gawk '/^zfs-linux / { print $$2; }' debian/dkms-versions)
-
 # NVIDIA DKMS package gross series split into desktop and server.
 nvidia_desktop_series=$(shell sed -n -e 's/^nvidia-graphics-drivers-\([0-9][0-9]*\) .*/\1/p' debian/dkms-versions)
 nvidia_server_series=$(shell sed -n -e 's/^nvidia-graphics-drivers-\([0-9][0-9]*-server\) .*/\1/p' debian/dkms-versions)
@@ -135,26 +123,17 @@ binary: binary-indep binary-arch
 
 build: build-arch build-indep
 
-clean: debian/control debian/canonical-certs.pem
+clean: debian/control debian/canonical-certs.pem debian/canonical-revoked-certs.pem
        dh_testdir
        dh_testroot
        dh_clean
 
-ifeq ($(disable_d_i),)
-       # d-i stuff
-       rm -rf $(DEBIAN)/d-i-$(arch)
-       # Generated on the fly.
-       rm -f $(DEBIAN)/d-i/firmware/$(arch)/kernel-image
-endif
-
        # normal build junk
        rm -rf $(DEBIAN)/abi/$(release)-$(revision)
        rm -rf $(builddir)
        rm -f $(stampdir)/stamp-*
        rm -rf $(DEBIAN)/linux-*
 
-       # This gets rid of the d-i packages in control
-       cp -f $(DEBIAN)/control.stub $(DROOT)/control
        cp $(DEBIAN)/changelog debian/changelog
 
        # Install the copyright information.
@@ -178,9 +157,6 @@ distclean: clean
 # Builds the image, arch headers and debug packages
 include $(DROOT)/rules.d/2-binary-arch.mk
 
-# Rules for building the udebs ($(DEBIAN)-installer)
-include $(DROOT)/rules.d/5-udebs.mk
-
 # Builds the source, doc and linux-headers indep packages
 include $(DROOT)/rules.d/3-binary-indep.mk
 
@@ -204,6 +180,7 @@ endif
 $(DEBIAN)/control.stub:                                \
                $(DROOT)/scripts/control-create         \
                $(control_files)                        \
+               $(DROOT)/control.d/flavour-module.stub  \
                $(DEBIAN)/changelog                     \
                $(wildcard $(DEBIAN)/control.d/* $(DEBIAN)/sub-flavours/*.vars)
        for i in $(control_files); do                                           \
@@ -228,18 +205,7 @@ $(DEBIAN)/control.stub:                            \
 
 .PHONY: debian/control
 debian/control: $(DEBIAN)/control.stub
-       echo "# placebo control.stub for kernel-wedge flow change" >debian/control.stub
        cp $(DEBIAN)/control.stub debian/control
-ifeq ($(disable_d_i),)
-       # start new paragraph in debian/control
-       echo >> debian/control
-       # append udeb packages
-       export KW_DEFCONFIG_DIR=$(DEBIAN)/d-i && \
-       export KW_CONFIG_DIR=$(DEBIAN)/d-i && \
-       LANG=C kernel-wedge gen-control $(release)-$(abinum) | \
-               grep-dctrl -FArchitecture $(arch) \
-               >>$(CURDIR)/debian/control
-endif
 
 debian/canonical-certs.pem: $(wildcard $(DROOT)/certs/*-all.pem) $(wildcard $(DROOT)/certs/*-$(arch).pem) $(wildcard $(DEBIAN)/certs/*-all.pem) $(wildcard $(DEBIAN)/certs/*-$(arch).pem)
        for cert in $(sort $(notdir $^));                                       \
@@ -252,3 +218,15 @@ debian/canonical-certs.pem: $(wildcard $(DROOT)/certs/*-all.pem) $(wildcard $(DR
                        fi;                                                     \
                done;                                                           \
        done >"$@"
+
+debian/canonical-revoked-certs.pem: $(wildcard $(DROOT)/revoked-certs/*-all.pem) $(wildcard $(DROOT)/revoked-certs/*-$(arch).pem) $(wildcard $(DEBIAN)/revoked-certs/*-all.pem) $(wildcard $(DEBIAN)/revoked-certs/*-$(arch).pem)
+       for cert in $(sort $(notdir $^));                                       \
+       do                                                                      \
+               for dir in $(DEBIAN) $(DROOT);                                  \
+               do                                                              \
+                       if [ -f "$$dir/revoked-certs/$$cert" ]; then            \
+                               cat "$$dir/revoked-certs/$$cert";               \
+                               break;                                          \
+                       fi;                                                     \
+               done;                                                           \
+       done >"$@"