From 46bcc2276c5308d1ccc8a2aafae6656e299da0e5 Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> Date: Wed, 12 Feb 2025 13:48:55 -0600 Subject: [PATCH] kernel v5.4.288-bone-rt-r68.1 rebase external git projects and rt: v5.4.288-rt94 BBDTBS: https://openbeagle.org/beagleboard/BeagleBoard-DeviceTrees/-/commit/f72c40d59d211740c0970b0110d6f2cf53b96d16 RT: patch-5.4.288-rt94.patch.xz WIRELESS_REGDB: https://git.kernel.org/pub/scm/linux/kernel/git/wens/wireless-regdb.git/commit/?id=f67f40d009199ee75c906f1ac898b38be981a7f7 BCFSERIAL: https://openbeagle.org/beagleconnect/linux/bcfserial/-/commit/db467023bd136c97c2e13c3a8b9e41dbdfafbc66 Signed-off-by: Robert Nelson <robertcnelson@gmail.com> --- patch.sh | 81 +-- ...-backports-bindeb-pkg-from-linux.git.patch | 8 +- ...0001-backports-wlcore-from-linux.git.patch | 26 +- patches/defconfig | 42 +- ...-BeagleBoard.org-Device-Tree-Changes.patch | 136 ++-- ...https-git.beagleboard.org-beagleconn.patch | 8 +- patches/external/git/BBDTBS | 2 +- patches/external/git/BCFSERIAL | 2 +- patches/external/git/RT | 2 +- patches/external/git/TI_AMX3_CM3 | 1 - patches/external/git/WPANUSB | 2 +- ...01-merge-CONFIG_PREEMPT_RT-Patch-Set.patch | 679 ++++++++++-------- ...-AM335x-CM3-Power-Managment-Firmware.patch | 4 +- ...tps-git.beagleboard.org-beagleconnec.patch | 8 +- .../wpanusb/0002-Add-WPANUSB-driver.patch | 8 +- ...a-ahci-fix-enum-constants-for-gcc-13.patch | 369 ---------- patches/ref_omap2plus_defconfig | 13 +- tools/config-hot-fix.sh | 134 +++- version.sh | 6 +- 19 files changed, 614 insertions(+), 917 deletions(-) rename patches/{soc/ti/beagleboard_dtbs => external/bbb.io}/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch (99%) delete mode 100644 patches/external/git/TI_AMX3_CM3 rename patches/{drivers/ti/firmware => external/ti-amx3-cm3-pm-firmware}/0001-Add-AM335x-CM3-Power-Managment-Firmware.patch (99%) delete mode 100644 patches/fixes/gcc/13/0001-ata-ahci-fix-enum-constants-for-gcc-13.patch diff --git a/patch.sh b/patch.sh index e0960cbb0..fa84c4434 100644 --- a/patch.sh +++ b/patch.sh @@ -111,7 +111,7 @@ wpanusb () { rm -rf ./wpanusb || true fi - ${git_bin} clone https://git.beagleboard.org/beagleconnect/linux/wpanusb --depth=1 + ${git_bin} clone https://openbeagle.org/beagleconnect/linux/wpanusb.git --depth=1 cd ./wpanusb wpanusb_hash=$(git rev-parse HEAD) cd - @@ -122,9 +122,9 @@ wpanusb () { cp -v ../wpanusb/wpanusb.c drivers/net/ieee802154/ ${git_bin} add . - ${git_bin} commit -a -m 'merge: wpanusb: https://git.beagleboard.org/beagleconnect/linux/wpanusb' -m "https://git.beagleboard.org/beagleconnect/linux/wpanusb/-/commit/${wpanusb_hash}" -s + ${git_bin} commit -a -m 'merge: wpanusb: https://git.beagleboard.org/beagleconnect/linux/wpanusb' -m "https://openbeagle.org/beagleconnect/linux/wpanusb/-/commit/${wpanusb_hash}" -s ${git_bin} format-patch -1 -o ../patches/external/wpanusb/ - echo "WPANUSB: https://git.beagleboard.org/beagleconnect/linux/wpanusb/-/commit/${wpanusb_hash}" > ../patches/external/git/WPANUSB + echo "WPANUSB: https://openbeagle.org/beagleconnect/linux/wpanusb/-/commit/${wpanusb_hash}" > ../patches/external/git/WPANUSB rm -rf ../wpanusb/ || true @@ -137,8 +137,6 @@ wpanusb () { wdir="external/wpanusb" number=1 cleanup - - exit 2 fi dir 'external/wpanusb' } @@ -151,7 +149,7 @@ bcfserial () { rm -rf ./bcfserial || true fi - ${git_bin} clone https://git.beagleboard.org/beagleconnect/linux/bcfserial.git --depth=1 + ${git_bin} clone https://openbeagle.org/beagleconnect/linux/bcfserial.git --depth=1 cd ./bcfserial bcfserial_hash=$(git rev-parse HEAD) cd - @@ -161,9 +159,9 @@ bcfserial () { cp -v ../bcfserial/bcfserial.c drivers/net/ieee802154/ ${git_bin} add . - ${git_bin} commit -a -m 'merge: bcfserial: https://git.beagleboard.org/beagleconnect/linux/bcfserial.git' -m "https://git.beagleboard.org/beagleconnect/linux/bcfserial/-/commit/${bcfserial_hash}" -s + ${git_bin} commit -a -m 'merge: bcfserial: https://git.beagleboard.org/beagleconnect/linux/bcfserial.git' -m "https://openbeagle.org/beagleconnect/linux/bcfserial/-/commit/${bcfserial_hash}" -s ${git_bin} format-patch -1 -o ../patches/external/bcfserial/ - echo "BCFSERIAL: https://git.beagleboard.org/beagleconnect/linux/bcfserial/-/commit/${bcfserial_hash}" > ../patches/external/git/BCFSERIAL + echo "BCFSERIAL: https://openbeagle.org/beagleconnect/linux/bcfserial/-/commit/${bcfserial_hash}" > ../patches/external/git/BCFSERIAL rm -rf ../bcfserial/ || true @@ -176,8 +174,6 @@ bcfserial () { wdir="external/bcfserial" number=1 cleanup - - exit 2 fi dir 'external/bcfserial' } @@ -251,45 +247,6 @@ wireless_regdb () { dir 'external/wireless_regdb' } -ti_pm_firmware () { - #https://git.ti.com/gitweb?p=processor-firmware/ti-amx3-cm3-pm-firmware.git;a=shortlog;h=refs/heads/ti-v4.1.y - #regenerate="enable" - if [ "x${regenerate}" = "xenable" ] ; then - cd ../ - if [ -d ./ti-amx3-cm3-pm-firmware ] ; then - rm -rf ./ti-amx3-cm3-pm-firmware || true - fi - - ${git_bin} clone -b ti-v4.1.y git://git.ti.com/processor-firmware/ti-amx3-cm3-pm-firmware.git --depth=1 - cd ./ti-amx3-cm3-pm-firmware - ti_amx3_cm3_hash=$(git rev-parse HEAD) - cd - - - cd ./KERNEL/ - - mkdir -p ./firmware/ || true - cp -v ../ti-amx3-cm3-pm-firmware/bin/am* ./firmware/ - - ${git_bin} add -f ./firmware/am* - ${git_bin} commit -a -m 'Add AM335x CM3 Power Managment Firmware' -m "http://git.ti.com/gitweb/?p=processor-firmware/ti-amx3-cm3-pm-firmware.git;a=commit;h=${ti_amx3_cm3_hash}" -s - ${git_bin} format-patch -1 -o ../patches/drivers/ti/firmware/ - echo "TI_AMX3_CM3: http://git.ti.com/gitweb/?p=processor-firmware/ti-amx3-cm3-pm-firmware.git;a=commit;h=${ti_amx3_cm3_hash}" > ../patches/external/git/TI_AMX3_CM3 - - rm -rf ../ti-amx3-cm3-pm-firmware/ || true - - ${git_bin} reset --hard HEAD^ - - start_cleanup - - ${git} "${DIR}/patches/drivers/ti/firmware/0001-Add-AM335x-CM3-Power-Managment-Firmware.patch" - - wdir="drivers/ti/firmware" - number=1 - cleanup - fi - dir 'drivers/ti/firmware' -} - cleanup_dts_builds () { rm -rf arch/arm/boot/dts/modules.order || true rm -rf arch/arm/boot/dts/.*cmd || true @@ -351,9 +308,9 @@ beagleboard_dtbs () { ${git_bin} add -f arch/arm/boot/dts/ ${git_bin} add -f include/dt-bindings/ - ${git_bin} commit -a -m "Add BeagleBoard.org Device Tree Changes" -m "https://git.beagleboard.org/beagleboard/BeagleBoard-DeviceTrees/-/tree/${branch}" -m "https://git.beagleboard.org/beagleboard/BeagleBoard-DeviceTrees/-/commit/${git_hash}" -s - ${git_bin} format-patch -1 -o ../patches/soc/ti/beagleboard_dtbs/ - echo "BBDTBS: https://git.beagleboard.org/beagleboard/BeagleBoard-DeviceTrees/-/commit/${git_hash}" > ../patches/external/git/BBDTBS + ${git_bin} commit -a -m "Add BeagleBoard.org Device Tree Changes" -m "https://openbeagle.org/beagleboard/BeagleBoard-DeviceTrees/-/tree/${branch}" -m "https://openbeagle.org/beagleboard/BeagleBoard-DeviceTrees/-/commit/${git_hash}" -s + ${git_bin} format-patch -1 -o ../patches/external/bbb.io/ + echo "BBDTBS: https://openbeagle.org/beagleboard/BeagleBoard-DeviceTrees/-/commit/${git_hash}" > ../patches/external/git/BBDTBS rm -rf ../${work_dir}/ || true @@ -361,13 +318,13 @@ beagleboard_dtbs () { start_cleanup - ${git} "${DIR}/patches/soc/ti/beagleboard_dtbs/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch" + ${git} "${DIR}/patches/external/bbb.io/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch" - wdir="soc/ti/beagleboard_dtbs" + wdir="external/bbb.io" number=1 cleanup fi - dir 'soc/ti/beagleboard_dtbs' + dir 'external/bbb.io' } local_patch () { @@ -380,7 +337,6 @@ wpanusb bcfserial rt wireless_regdb -ti_pm_firmware beagleboard_dtbs #local_patch @@ -401,17 +357,17 @@ pre_backports () { post_backports () { if [ ! "x${backport_tag}" = "x" ] ; then cd ~/linux-src/ - ${git_bin} checkout master -f ; ${git_bin} branch -D tmp + ${git_bin} checkout master -f cd - fi - rm -f arch/arm/boot/dts/overlays/*.dtbo || true ${git_bin} add . ${git_bin} commit -a -m "backports: ${subsystem}: from: linux.git" -m "Reference: ${backport_tag}" -s if [ ! -d ../patches/backports/${subsystem}/ ] ; then mkdir -p ../patches/backports/${subsystem}/ fi ${git_bin} format-patch -1 -o ../patches/backports/${subsystem}/ + exit 2 } patch_backports () { @@ -430,7 +386,6 @@ backports () { cp -rv ~/linux-src/drivers/net/wireless/ti/* ./drivers/net/wireless/ti/ post_backports - exit 2 else patch_backports fi @@ -662,11 +617,10 @@ drivers () { # dir 'drivers/ti/mmc' dir 'drivers/greybus' dir 'drivers/bluetooth' -} -fixes () { dir 'fixes/gcc' - dir 'fixes/gcc/13' + + dir 'external/ti-amx3-cm3-pm-firmware' } ### @@ -674,13 +628,12 @@ backports brcmfmac reverts drivers -fixes packaging () { echo "Update: package scripts" do_backport="enable" if [ "x${do_backport}" = "xenable" ] ; then - backport_tag="v5.10.200" + backport_tag="v5.10.234" subsystem="bindeb-pkg" #regenerate="enable" diff --git a/patches/backports/bindeb-pkg/0001-backports-bindeb-pkg-from-linux.git.patch b/patches/backports/bindeb-pkg/0001-backports-bindeb-pkg-from-linux.git.patch index d47252c86..16b032709 100644 --- a/patches/backports/bindeb-pkg/0001-backports-bindeb-pkg-from-linux.git.patch +++ b/patches/backports/bindeb-pkg/0001-backports-bindeb-pkg-from-linux.git.patch @@ -1,9 +1,9 @@ -From 731fa1a584de8eed7c8ad3b367e9ae65cb86d146 Mon Sep 17 00:00:00 2001 +From 5d954606ccb2d81935ad6b30802b34dab73f0a44 Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Fri, 12 May 2023 10:23:20 -0500 +Date: Wed, 12 Feb 2025 13:45:00 -0600 Subject: [PATCH] backports: bindeb-pkg: from: linux.git -Reference: v5.10.179 +Reference: v5.10.234 Signed-off-by: Robert Nelson <robertcnelson@gmail.com> --- scripts/package/builddeb | 119 ++++++++++++++++++++++++--------------- @@ -376,5 +376,5 @@ index 8640c278f1aa..951cc60e5a90 100755 $M $MAKE %{?_smp_mflags} INSTALL_MOD_PATH=%{buildroot} modules_install $MAKE %{?_smp_mflags} INSTALL_HDR_PATH=%{buildroot}/usr headers_install -- -2.39.2 +2.47.2 diff --git a/patches/backports/wlcore/0001-backports-wlcore-from-linux.git.patch b/patches/backports/wlcore/0001-backports-wlcore-from-linux.git.patch index a7f1d8b9f..872f97ec7 100644 --- a/patches/backports/wlcore/0001-backports-wlcore-from-linux.git.patch +++ b/patches/backports/wlcore/0001-backports-wlcore-from-linux.git.patch @@ -1,6 +1,6 @@ -From 5b4075a4dbae7ef06ea211893c4fcfaa6dfbc974 Mon Sep 17 00:00:00 2001 +From e131f619331510e93a16fe436f7e732fe2ffb99a Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Fri, 17 Nov 2023 16:03:55 -0600 +Date: Wed, 12 Feb 2025 13:42:22 -0600 Subject: [PATCH] backports: wlcore: from: linux.git Reference: v5.13.19 @@ -15,7 +15,7 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> drivers/net/wireless/ti/wl1251/reg.h | 2 +- drivers/net/wireless/ti/wl1251/sdio.c | 39 ++--- drivers/net/wireless/ti/wl1251/wl12xx_80211.h | 2 +- - drivers/net/wireless/ti/wl12xx/Kconfig | 8 +- + drivers/net/wireless/ti/wl12xx/Kconfig | 2 +- drivers/net/wireless/ti/wl12xx/reg.h | 2 +- drivers/net/wireless/ti/wl18xx/Kconfig | 2 +- drivers/net/wireless/ti/wlcore/Kconfig | 6 +- @@ -33,7 +33,7 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> drivers/net/wireless/ti/wlcore/sysfs.c | 2 +- drivers/net/wireless/ti/wlcore/wl12xx_80211.h | 2 +- drivers/net/wireless/ti/wlcore/wlcore_i.h | 1 + - 27 files changed, 150 insertions(+), 189 deletions(-) + 27 files changed, 147 insertions(+), 186 deletions(-) diff --git a/drivers/net/wireless/ti/Kconfig b/drivers/net/wireless/ti/Kconfig index b81f2e41a63a..7c0b17a76fe2 100644 @@ -344,24 +344,18 @@ index 7fabe702c4cc..7e28fe435b43 100644 struct wl12xx_ie_header { diff --git a/drivers/net/wireless/ti/wl12xx/Kconfig b/drivers/net/wireless/ti/wl12xx/Kconfig -index e409042ee9a0..786fff288505 100644 +index 9c4511604b67..786fff288505 100644 --- a/drivers/net/wireless/ti/wl12xx/Kconfig +++ b/drivers/net/wireless/ti/wl12xx/Kconfig -@@ -1,10 +1,10 @@ - # SPDX-License-Identifier: GPL-2.0-only - config WL12XX -- tristate "TI wl12xx support" -+ tristate "TI wl12xx support" +@@ -3,7 +3,7 @@ config WL12XX + tristate "TI wl12xx support" depends on MAC80211 -- select WLCORE -- ---help--- -+ select WLCORE + select WLCORE +- ---help--- + help This module adds support for wireless adapters based on TI wl1271, wl1273, wl1281 and wl1283 chipsets. This module does *not* include support for wl1251. For wl1251 support, use the separate homonymous -- driver instead. -+ driver instead. diff --git a/drivers/net/wireless/ti/wl12xx/reg.h b/drivers/net/wireless/ti/wl12xx/reg.h index 247f558ba630..8ff018808020 100644 --- a/drivers/net/wireless/ti/wl12xx/reg.h @@ -1125,5 +1119,5 @@ index 6fab60b0e367..eefae3f867b9 100644 enum wl12xx_flags { -- -2.39.2 +2.47.2 diff --git a/patches/defconfig b/patches/defconfig index 8210cb39c..827b0be3b 100644 --- a/patches/defconfig +++ b/patches/defconfig @@ -1,6 +1,6 @@ # # Automatically generated file; DO NOT EDIT. -# Linux/arm 5.4.257 Kernel Configuration +# Linux/arm 5.4.288 Kernel Configuration # # @@ -29,8 +29,8 @@ CONFIG_HAVE_KERNEL_LZO=y CONFIG_HAVE_KERNEL_LZ4=y # CONFIG_KERNEL_GZIP is not set # CONFIG_KERNEL_LZMA is not set -# CONFIG_KERNEL_XZ is not set -CONFIG_KERNEL_LZO=y +CONFIG_KERNEL_XZ=y +# CONFIG_KERNEL_LZO is not set # CONFIG_KERNEL_LZ4 is not set CONFIG_DEFAULT_HOSTNAME="(none)" CONFIG_SWAP=y @@ -483,7 +483,6 @@ CONFIG_SECCOMP=y # CONFIG_PARAVIRT is not set # CONFIG_PARAVIRT_TIME_ACCOUNTING is not set # CONFIG_XEN is not set -CONFIG_STACKPROTECTOR_PER_TASK=y # end of Kernel Features # @@ -726,11 +725,7 @@ CONFIG_ARCH_HAS_GCOV_PROFILE_ALL=y CONFIG_PLUGIN_HOSTCC="g++" CONFIG_HAVE_GCC_PLUGINS=y -CONFIG_GCC_PLUGINS=y -# CONFIG_GCC_PLUGIN_CYC_COMPLEXITY is not set -# CONFIG_GCC_PLUGIN_LATENT_ENTROPY is not set -# CONFIG_GCC_PLUGIN_RANDSTRUCT is not set -CONFIG_GCC_PLUGIN_ARM_SSP_PER_TASK=y +# CONFIG_GCC_PLUGINS is not set # end of General architecture-dependent options CONFIG_RT_MUTEXES=y @@ -904,7 +899,7 @@ CONFIG_IP_PNP_BOOTP=y CONFIG_IP_PNP_RARP=y CONFIG_NET_IPIP=m CONFIG_NET_IPGRE_DEMUX=m -CONFIG_NET_IP_TUNNEL=m +CONFIG_NET_IP_TUNNEL=y CONFIG_NET_IPGRE=m CONFIG_NET_IPGRE_BROADCAST=y CONFIG_IP_MROUTE_COMMON=y @@ -914,7 +909,7 @@ CONFIG_IP_PIMSM_V1=y CONFIG_IP_PIMSM_V2=y CONFIG_SYN_COOKIES=y CONFIG_NET_IPVTI=m -CONFIG_NET_UDP_TUNNEL=m +CONFIG_NET_UDP_TUNNEL=y CONFIG_NET_FOU=m CONFIG_NET_FOU_IP_TUNNELS=y CONFIG_INET_AH=m @@ -1424,10 +1419,8 @@ CONFIG_NET_SCHED=y # # Queueing/Scheduling # -CONFIG_NET_SCH_CBQ=m CONFIG_NET_SCH_HTB=m CONFIG_NET_SCH_HFSC=m -CONFIG_NET_SCH_ATM=m CONFIG_NET_SCH_PRIO=m CONFIG_NET_SCH_MULTIQ=m CONFIG_NET_SCH_RED=m @@ -1439,7 +1432,6 @@ CONFIG_NET_SCH_CBS=m CONFIG_NET_SCH_ETF=m # CONFIG_NET_SCH_TAPRIO is not set CONFIG_NET_SCH_GRED=m -CONFIG_NET_SCH_DSMARK=m CONFIG_NET_SCH_NETEM=m CONFIG_NET_SCH_DRR=m CONFIG_NET_SCH_MQPRIO=m @@ -1467,7 +1459,7 @@ CONFIG_NET_CLS_U32=m CONFIG_CLS_U32_PERF=y CONFIG_CLS_U32_MARK=y CONFIG_NET_CLS_FLOW=m -CONFIG_NET_CLS_CGROUP=m +CONFIG_NET_CLS_CGROUP=y CONFIG_NET_CLS_BPF=m CONFIG_NET_CLS_FLOWER=m CONFIG_NET_CLS_MATCHALL=m @@ -1692,7 +1684,6 @@ CONFIG_WIRELESS=y CONFIG_WIRELESS_EXT=y CONFIG_WEXT_CORE=y CONFIG_WEXT_PROC=y -CONFIG_WEXT_SPY=y CONFIG_WEXT_PRIV=y CONFIG_CFG80211=m # CONFIG_NL80211_TESTMODE is not set @@ -1794,7 +1785,7 @@ CONFIG_EXTRA_FIRMWARE="regulatory.db regulatory.db.p7s am335x-pm-firmware.elf am CONFIG_EXTRA_FIRMWARE_DIR="firmware" CONFIG_FW_LOADER_USER_HELPER=y # CONFIG_FW_LOADER_USER_HELPER_FALLBACK is not set -# CONFIG_FW_LOADER_COMPRESS is not set +CONFIG_FW_LOADER_COMPRESS=y # end of Firmware loader CONFIG_WANT_DEV_COREDUMP=y @@ -2211,7 +2202,7 @@ CONFIG_NETDEVICES=y CONFIG_MII=y CONFIG_NET_CORE=y CONFIG_BONDING=m -CONFIG_DUMMY=m +CONFIG_DUMMY=y CONFIG_EQUALIZER=m CONFIG_IFB=m CONFIG_NET_TEAM=m @@ -2223,9 +2214,9 @@ CONFIG_NET_TEAM_MODE_LOADBALANCE=m CONFIG_MACVLAN=m CONFIG_MACVTAP=m CONFIG_IPVLAN_L3S=y -CONFIG_IPVLAN=m +CONFIG_IPVLAN=y CONFIG_IPVTAP=m -CONFIG_VXLAN=m +CONFIG_VXLAN=y CONFIG_GENEVE=m CONFIG_GTP=m CONFIG_MACSEC=m @@ -3157,7 +3148,7 @@ CONFIG_GPIO_XRA1403=m # end of USB GPIO expanders # CONFIG_GPIO_MOCKUP is not set -CONFIG_W1=m +CONFIG_W1=y CONFIG_W1_CON=y # @@ -5052,8 +5043,7 @@ CONFIG_USB_MUSB_AM335X_CHILD=y # # MUSB DMA mode # -# CONFIG_MUSB_PIO_ONLY is not set -CONFIG_USB_TI_CPPI41_DMA=y +CONFIG_MUSB_PIO_ONLY=y # CONFIG_USB_DWC3 is not set # CONFIG_USB_DWC2 is not set # CONFIG_USB_CHIPIDEA is not set @@ -6799,6 +6789,9 @@ CONFIG_KEYS=y # CONFIG_ENCRYPTED_KEYS is not set CONFIG_KEY_DH_OPERATIONS=y # CONFIG_SECURITY_DMESG_RESTRICT is not set +CONFIG_PROC_MEM_ALWAYS_FORCE=y +# CONFIG_PROC_MEM_FORCE_PTRACE is not set +# CONFIG_PROC_MEM_NO_FORCE is not set CONFIG_SECURITY=y CONFIG_SECURITYFS=y CONFIG_SECURITY_NETWORK=y @@ -6854,9 +6847,6 @@ CONFIG_LSM="lockdown,yama,loadpin,safesetid,integrity,apparmor,selinux,smack,tom # Memory initialization # CONFIG_INIT_STACK_NONE=y -# CONFIG_GCC_PLUGIN_STRUCTLEAK_USER is not set -# CONFIG_GCC_PLUGIN_STRUCTLEAK_BYREF is not set -# CONFIG_GCC_PLUGIN_STRUCTLEAK_BYREF_ALL is not set # CONFIG_INIT_ON_ALLOC_DEFAULT_ON is not set # CONFIG_INIT_ON_FREE_DEFAULT_ON is not set # end of Memory initialization diff --git a/patches/soc/ti/beagleboard_dtbs/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch b/patches/external/bbb.io/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch similarity index 99% rename from patches/soc/ti/beagleboard_dtbs/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch rename to patches/external/bbb.io/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch index c84383fe0..0703ea82d 100644 --- a/patches/soc/ti/beagleboard_dtbs/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch +++ b/patches/external/bbb.io/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch @@ -1,11 +1,11 @@ -From e2740e215752548cec2b1d1dcb64c98a4141640d Mon Sep 17 00:00:00 2001 +From c49e7c6511646b18928c40b2e1c02b1bac197d8b Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Fri, 17 Nov 2023 16:01:44 -0600 +Date: Wed, 12 Feb 2025 13:39:35 -0600 Subject: [PATCH] Add BeagleBoard.org Device Tree Changes -https://git.beagleboard.org/beagleboard/BeagleBoard-DeviceTrees/-/tree/v5.4.x +https://openbeagle.org/beagleboard/BeagleBoard-DeviceTrees/-/tree/v5.4.x -https://git.beagleboard.org/beagleboard/BeagleBoard-DeviceTrees/-/commit/f72c40d59d211740c0970b0110d6f2cf53b96d16 +https://openbeagle.org/beagleboard/BeagleBoard-DeviceTrees/-/commit/f72c40d59d211740c0970b0110d6f2cf53b96d16 Signed-off-by: Robert Nelson <robertcnelson@gmail.com> --- arch/arm/boot/dts/Makefile | 10 + @@ -16,17 +16,17 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> arch/arm/boot/dts/am335x-bone-jtag.dtsi | 15 + arch/arm/boot/dts/am335x-bone-uboot-univ.dts | 29 + arch/arm/boot/dts/am335x-bone.dts | 7 +- - .../arm/boot/dts/am335x-boneblack-common.dtsi | 6 +- + .../arm/boot/dts/am335x-boneblack-common.dtsi | 7 +- .../boot/dts/am335x-boneblack-uboot-univ.dts | 184 ++ arch/arm/boot/dts/am335x-boneblack-uboot.dts | 192 ++ - .../boot/dts/am335x-boneblack-wireless.dts | 10 +- + .../boot/dts/am335x-boneblack-wireless.dts | 9 +- arch/arm/boot/dts/am335x-boneblack.dts | 151 +- - arch/arm/boot/dts/am335x-boneblue.dts | 574 +++- + arch/arm/boot/dts/am335x-boneblue.dts | 573 +++- .../arm/boot/dts/am335x-bonegreen-common.dtsi | 3 +- .../arm/boot/dts/am335x-bonegreen-gateway.dts | 258 ++ ...am335x-bonegreen-wireless-common-univ.dtsi | 2783 ++++++++++++++++ .../am335x-bonegreen-wireless-uboot-univ.dts | 56 + - .../boot/dts/am335x-bonegreen-wireless.dts | 12 +- + .../boot/dts/am335x-bonegreen-wireless.dts | 11 +- arch/arm/boot/dts/am335x-bonegreen.dts | 7 +- arch/arm/boot/dts/am335x-osd3358-sm-red.dts | 41 +- arch/arm/boot/dts/am335x-osd335x-common.dtsi | 3 +- @@ -34,8 +34,8 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> .../dts/am335x-sancloud-bbe-uboot-univ.dts | 152 + .../boot/dts/am335x-sancloud-bbe-uboot.dts | 151 + arch/arm/boot/dts/am335x-sancloud-bbe.dts | 11 +- - arch/arm/boot/dts/am33xx-l4.dtsi | 204 +- - arch/arm/boot/dts/am33xx.dtsi | 7 +- + arch/arm/boot/dts/am33xx-l4.dtsi | 198 +- + arch/arm/boot/dts/am33xx.dtsi | 4 +- arch/arm/boot/dts/am5728.dtsi | 2 +- arch/arm/boot/dts/am5729-beagleboneai.dts | 754 +++++ .../boot/dts/am57xx-beagle-x15-common.dtsi | 12 +- @@ -102,7 +102,8 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> include/dt-bindings/clock/dra7.h | 28 + include/dt-bindings/clock/omap4.h | 11 + include/dt-bindings/clock/omap5.h | 18 + - 94 files changed, 14298 insertions(+), 244 deletions(-) + include/uapi/linux/input-event-codes.h | 1 - + 95 files changed, 14291 insertions(+), 241 deletions(-) create mode 100644 arch/arm/boot/dts/am335x-abbbi.dts create mode 100644 arch/arm/boot/dts/am335x-bone-common-no-capemgr.dtsi create mode 100644 arch/arm/boot/dts/am335x-bone-common-univ.dtsi @@ -3954,7 +3955,7 @@ index 43bfbce41049..ea138cb34091 100644 &ldo3_reg { diff --git a/arch/arm/boot/dts/am335x-boneblack-common.dtsi b/arch/arm/boot/dts/am335x-boneblack-common.dtsi -index dd932220a8bf..9659835d5874 100644 +index 91f93bc89716..9659835d5874 100644 --- a/arch/arm/boot/dts/am335x-boneblack-common.dtsi +++ b/arch/arm/boot/dts/am335x-boneblack-common.dtsi @@ -1,6 +1,6 @@ @@ -3965,7 +3966,13 @@ index dd932220a8bf..9659835d5874 100644 */ #include <dt-bindings/display/tda998x.h> -@@ -28,7 +28,7 @@ +@@ -22,12 +22,13 @@ + pinctrl-0 = <&emmc_pins>; + bus-width = <8>; + status = "okay"; ++ non-removable; + }; + &am33xx_pinmux { nxp_hdmi_bonelt_pins: nxp_hdmi_bonelt_pins { pinctrl-single,pins = < @@ -3974,7 +3981,7 @@ index dd932220a8bf..9659835d5874 100644 AM33XX_PADCONF(AM335X_PIN_LCD_DATA0, PIN_OUTPUT, MUX_MODE0) AM33XX_PADCONF(AM335X_PIN_LCD_DATA1, PIN_OUTPUT, MUX_MODE0) AM33XX_PADCONF(AM335X_PIN_LCD_DATA2, PIN_OUTPUT, MUX_MODE0) -@@ -54,7 +54,7 @@ +@@ -53,7 +54,7 @@ nxp_hdmi_bonelt_off_pins: nxp_hdmi_bonelt_off_pins { pinctrl-single,pins = < @@ -4372,7 +4379,7 @@ index 000000000000..0129f95c42a6 + "NC"; +}; diff --git a/arch/arm/boot/dts/am335x-boneblack-wireless.dts b/arch/arm/boot/dts/am335x-boneblack-wireless.dts -index e07dd7979586..c34d2ed654d0 100644 +index 3124d94c0b3c..c34d2ed654d0 100644 --- a/arch/arm/boot/dts/am335x-boneblack-wireless.dts +++ b/arch/arm/boot/dts/am335x-boneblack-wireless.dts @@ -1,6 +1,6 @@ @@ -4395,15 +4402,7 @@ index e07dd7979586..c34d2ed654d0 100644 wlan_en_reg: fixedregulator@2 { compatible = "regulator-fixed"; regulator-name = "wlan-en-regulator"; -@@ -75,6 +80,7 @@ - bus-width = <4>; - non-removable; - cap-power-off-card; -+ ti,needs-special-hs-handling; - keep-power-in-suspend; - pinctrl-names = "default"; - pinctrl-0 = <&mmc3_pins &wl18xx_pins>; -@@ -101,7 +107,7 @@ +@@ -102,7 +107,7 @@ }; &gpio3 { @@ -4585,7 +4584,7 @@ index d3928662aed4..cb9cee378870 100644 + "NC"; +}; diff --git a/arch/arm/boot/dts/am335x-boneblue.dts b/arch/arm/boot/dts/am335x-boneblue.dts -index 30b62de86b5b..fd06db61ded6 100644 +index 2f6652ef9a15..fd06db61ded6 100644 --- a/arch/arm/boot/dts/am335x-boneblue.dts +++ b/arch/arm/boot/dts/am335x-boneblue.dts @@ -1,6 +1,6 @@ @@ -4858,15 +4857,7 @@ index 30b62de86b5b..fd06db61ded6 100644 &uart5 { pinctrl-names = "default"; -@@ -389,6 +585,7 @@ - bus-width = <4>; - non-removable; - cap-power-off-card; -+ ti,needs-special-hs-handling; - keep-power-in-suspend; - pinctrl-names = "default"; - pinctrl-0 = <&mmc3_pins &wl18xx_pins>; -@@ -403,12 +600,12 @@ +@@ -404,12 +600,12 @@ }; }; @@ -4885,7 +4876,7 @@ index 30b62de86b5b..fd06db61ded6 100644 &uart3 { pinctrl-names = "default"; -@@ -427,17 +624,352 @@ +@@ -428,17 +624,352 @@ clock-names = "ext-clk", "int-clk"; }; @@ -8376,7 +8367,7 @@ index 000000000000..02fbbe9ece34 + }; +}; diff --git a/arch/arm/boot/dts/am335x-bonegreen-wireless.dts b/arch/arm/boot/dts/am335x-bonegreen-wireless.dts -index 609c8db687ec..d3392ea422b0 100644 +index 4092cd193b8a..d3392ea422b0 100644 --- a/arch/arm/boot/dts/am335x-bonegreen-wireless.dts +++ b/arch/arm/boot/dts/am335x-bonegreen-wireless.dts @@ -1,6 +1,6 @@ @@ -8399,15 +8390,7 @@ index 609c8db687ec..d3392ea422b0 100644 wlan_en_reg: fixedregulator@2 { compatible = "regulator-fixed"; regulator-name = "wlan-en-regulator"; -@@ -75,6 +80,7 @@ - bus-width = <4>; - non-removable; - cap-power-off-card; -+ ti,needs-special-hs-handling; - keep-power-in-suspend; - pinctrl-names = "default"; - pinctrl-0 = <&mmc3_pins &wl18xx_pins>; -@@ -101,7 +107,7 @@ +@@ -102,7 +107,7 @@ }; &gpio1 { @@ -8416,7 +8399,7 @@ index 609c8db687ec..d3392ea422b0 100644 gpio-hog; gpios = <29 GPIO_ACTIVE_HIGH>; output-high; -@@ -118,7 +124,7 @@ +@@ -119,7 +124,7 @@ /* an external pulldown on U21 pin 4. */ &gpio3 { @@ -11240,7 +11223,7 @@ index e5fdb7abb0d5..9bb56d58ac50 100644 reg = <0x68>; interrupt-parent = <&gpio0>; diff --git a/arch/arm/boot/dts/am33xx-l4.dtsi b/arch/arm/boot/dts/am33xx-l4.dtsi -index cacd564b4d28..60d2d0990ea2 100644 +index 8ec6c4500fd5..60d2d0990ea2 100644 --- a/arch/arm/boot/dts/am33xx-l4.dtsi +++ b/arch/arm/boot/dts/am33xx-l4.dtsi @@ -158,6 +158,39 @@ @@ -11393,22 +11376,17 @@ index cacd564b4d28..60d2d0990ea2 100644 }; }; -@@ -1333,9 +1399,12 @@ - ranges = <0x0 0x60000 0x1000>; - - mmc1: mmc@0 { -- compatible = "ti,am335-sdhci"; -+ compatible = "ti,omap4-hsmmc"; -+ ti,dual-volt; +@@ -1337,7 +1403,8 @@ + ti,dual-volt; ti,needs-special-reset; + ti,needs-special-hs-handling; - dmas = <&edma 24 0>, <&edma 25 0>; -+ ti,needs-special-hs-handling; + dmas = <&edma_xbar 24 0 0 + &edma_xbar 25 0 0>; dma-names = "tx", "rx"; interrupts = <64>; reg = <0x0 0x1000>; -@@ -1708,6 +1777,39 @@ +@@ -1710,6 +1777,39 @@ #interrupt-cells = <2>; reg = <0x0 0x1000>; interrupts = <32>; @@ -11448,7 +11426,7 @@ index cacd564b4d28..60d2d0990ea2 100644 }; }; -@@ -1742,6 +1844,39 @@ +@@ -1744,6 +1844,39 @@ #interrupt-cells = <2>; reg = <0x0 0x1000>; interrupts = <62>; @@ -11488,16 +11466,7 @@ index cacd564b4d28..60d2d0990ea2 100644 }; }; -@@ -1824,7 +1959,7 @@ - ranges = <0x0 0xd8000 0x1000>; - - mmc2: mmc@0 { -- compatible = "ti,am335-sdhci"; -+ compatible = "ti,omap4-hsmmc"; - ti,needs-special-reset; - dmas = <&edma 2 0 - &edma 3 0>; -@@ -1911,6 +2046,15 @@ +@@ -1913,6 +2046,15 @@ status = "disabled"; }; @@ -11513,7 +11482,7 @@ index cacd564b4d28..60d2d0990ea2 100644 ehrpwm0: pwm@200 { compatible = "ti,am3352-ehrpwm", "ti,am33xx-ehrpwm"; -@@ -1964,6 +2108,15 @@ +@@ -1966,6 +2108,15 @@ status = "disabled"; }; @@ -11529,7 +11498,7 @@ index cacd564b4d28..60d2d0990ea2 100644 ehrpwm1: pwm@200 { compatible = "ti,am3352-ehrpwm", "ti,am33xx-ehrpwm"; -@@ -2017,6 +2170,15 @@ +@@ -2019,6 +2170,15 @@ status = "disabled"; }; @@ -11546,7 +11515,7 @@ index cacd564b4d28..60d2d0990ea2 100644 compatible = "ti,am3352-ehrpwm", "ti,am33xx-ehrpwm"; diff --git a/arch/arm/boot/dts/am33xx.dtsi b/arch/arm/boot/dts/am33xx.dtsi -index efe36f395bdd..97cd2555e2e8 100644 +index 77fa7c0f2104..97cd2555e2e8 100644 --- a/arch/arm/boot/dts/am33xx.dtsi +++ b/arch/arm/boot/dts/am33xx.dtsi @@ -1,7 +1,7 @@ @@ -11567,19 +11536,6 @@ index efe36f395bdd..97cd2555e2e8 100644 compatible = "simple-bus"; #address-cells = <1>; #size-cells = <1>; -@@ -259,11 +259,10 @@ - ranges = <0x0 0x47810000 0x1000>; - - mmc3: mmc@0 { -- compatible = "ti,am335-sdhci"; -+ compatible = "ti,omap4-hsmmc"; - ti,needs-special-reset; - interrupts = <29>; - reg = <0x0 0x1000>; -- status = "disabled"; - }; - }; - diff --git a/arch/arm/boot/dts/am5728.dtsi b/arch/arm/boot/dts/am5728.dtsi index 82e5427ef6a9..6dfd62599b2f 100644 --- a/arch/arm/boot/dts/am5728.dtsi @@ -16515,6 +16471,18 @@ index e5411938983c..90e0d4b00127 100644 /* dss clocks */ #define OMAP5_DSS_CORE_CLKCTRL OMAP5_CLKCTRL_INDEX(0x20) +diff --git a/include/uapi/linux/input-event-codes.h b/include/uapi/linux/input-event-codes.h +index bf6c2f0b26fd..7f0ae1f411e3 100644 +--- a/include/uapi/linux/input-event-codes.h ++++ b/include/uapi/linux/input-event-codes.h +@@ -598,7 +598,6 @@ + + #define KEY_ALS_TOGGLE 0x230 /* Ambient light sensor */ + #define KEY_ROTATE_LOCK_TOGGLE 0x231 /* Display rotation lock */ +-#define KEY_REFRESH_RATE_TOGGLE 0x232 /* Display refresh rate toggle */ + + #define KEY_BUTTONCONFIG 0x240 /* AL Button Configuration */ + #define KEY_TASKMANAGER 0x241 /* AL Task/Project Manager */ -- -2.39.2 +2.47.2 diff --git a/patches/external/bcfserial/0001-merge-bcfserial-https-git.beagleboard.org-beagleconn.patch b/patches/external/bcfserial/0001-merge-bcfserial-https-git.beagleboard.org-beagleconn.patch index 4a3daae16..2031bbf59 100644 --- a/patches/external/bcfserial/0001-merge-bcfserial-https-git.beagleboard.org-beagleconn.patch +++ b/patches/external/bcfserial/0001-merge-bcfserial-https-git.beagleboard.org-beagleconn.patch @@ -1,10 +1,10 @@ -From ac2021a045505fc8bc85a7a01f7c71e333be6fa8 Mon Sep 17 00:00:00 2001 +From 0adb19e0aff27bbb524e1217adadfe3d9612251c Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Fri, 17 Nov 2023 15:58:47 -0600 +Date: Wed, 12 Feb 2025 13:37:09 -0600 Subject: [PATCH] merge: bcfserial: https://git.beagleboard.org/beagleconnect/linux/bcfserial.git -https://git.beagleboard.org/beagleconnect/linux/bcfserial/-/commit/db467023bd136c97c2e13c3a8b9e41dbdfafbc66 +https://openbeagle.org/beagleconnect/linux/bcfserial/-/commit/db467023bd136c97c2e13c3a8b9e41dbdfafbc66 Signed-off-by: Robert Nelson <robertcnelson@gmail.com> --- drivers/net/ieee802154/bcfserial.c | 680 +++++++++++++++++++++++++++++ @@ -698,5 +698,5 @@ index 000000000000..11a456e56887 +MODULE_VERSION("0.1.1"); +MODULE_LICENSE("GPL v2"); -- -2.39.2 +2.47.2 diff --git a/patches/external/git/BBDTBS b/patches/external/git/BBDTBS index 34da8b6a2..1f0cfa91b 100644 --- a/patches/external/git/BBDTBS +++ b/patches/external/git/BBDTBS @@ -1 +1 @@ -BBDTBS: https://git.beagleboard.org/beagleboard/BeagleBoard-DeviceTrees/-/commit/f72c40d59d211740c0970b0110d6f2cf53b96d16 +BBDTBS: https://openbeagle.org/beagleboard/BeagleBoard-DeviceTrees/-/commit/f72c40d59d211740c0970b0110d6f2cf53b96d16 diff --git a/patches/external/git/BCFSERIAL b/patches/external/git/BCFSERIAL index b6f1e46ac..48b7059c2 100644 --- a/patches/external/git/BCFSERIAL +++ b/patches/external/git/BCFSERIAL @@ -1 +1 @@ -BCFSERIAL: https://git.beagleboard.org/beagleconnect/linux/bcfserial/-/commit/db467023bd136c97c2e13c3a8b9e41dbdfafbc66 +BCFSERIAL: https://openbeagle.org/beagleconnect/linux/bcfserial/-/commit/db467023bd136c97c2e13c3a8b9e41dbdfafbc66 diff --git a/patches/external/git/RT b/patches/external/git/RT index 422f74259..90f85ae38 100644 --- a/patches/external/git/RT +++ b/patches/external/git/RT @@ -1 +1 @@ -RT: patch-5.4.257-rt87.patch.xz +RT: patch-5.4.288-rt94.patch.xz diff --git a/patches/external/git/TI_AMX3_CM3 b/patches/external/git/TI_AMX3_CM3 deleted file mode 100644 index 4a3e66640..000000000 --- a/patches/external/git/TI_AMX3_CM3 +++ /dev/null @@ -1 +0,0 @@ -TI_AMX3_CM3: http://git.ti.com/gitweb/?p=processor-firmware/ti-amx3-cm3-pm-firmware.git;a=commit;h=fb484c5e54f2e31cf0a338d2927a06a2870bcc2c diff --git a/patches/external/git/WPANUSB b/patches/external/git/WPANUSB index 9c86d1e3c..9a588fc7c 100644 --- a/patches/external/git/WPANUSB +++ b/patches/external/git/WPANUSB @@ -1 +1 @@ -WPANUSB: https://git.beagleboard.org/beagleconnect/linux/wpanusb/-/commit/6aa9bf65b9d88a2c9a111e7b4aed03de2be9413d +WPANUSB: https://openbeagle.org/beagleconnect/linux/wpanusb/-/commit/6aa9bf65b9d88a2c9a111e7b4aed03de2be9413d diff --git a/patches/external/rt/0001-merge-CONFIG_PREEMPT_RT-Patch-Set.patch b/patches/external/rt/0001-merge-CONFIG_PREEMPT_RT-Patch-Set.patch index 8fab2e02e..e901ea84b 100644 --- a/patches/external/rt/0001-merge-CONFIG_PREEMPT_RT-Patch-Set.patch +++ b/patches/external/rt/0001-merge-CONFIG_PREEMPT_RT-Patch-Set.patch @@ -1,9 +1,9 @@ -From 87a236cc38588efdabe36b6f1cac39c2817477bd Mon Sep 17 00:00:00 2001 +From 00ca142dc92d2b888b54c976fc12c8c3d72021d3 Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Fri, 17 Nov 2023 16:07:41 -0600 +Date: Wed, 12 Feb 2025 13:39:02 -0600 Subject: [PATCH] merge: CONFIG_PREEMPT_RT Patch Set -patch-5.4.257-rt87.patch.xz +patch-5.4.288-rt94.patch.xz Signed-off-by: Robert Nelson <robertcnelson@gmail.com> --- @@ -254,7 +254,7 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> include/linux/percpu.h | 29 + include/linux/pid.h | 1 + include/linux/posix-timers.h | 11 + - include/linux/preempt.h | 109 +- + include/linux/preempt.h | 139 +- include/linux/printk.h | 44 +- include/linux/printk_ringbuffer.h | 114 + include/linux/radix-tree.h | 6 +- @@ -336,7 +336,7 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> kernel/panic.c | 5 +- kernel/printk/Makefile | 1 - kernel/printk/internal.h | 72 - - kernel/printk/printk.c | 1915 ++++++++--------- + kernel/printk/printk.c | 1919 ++++++++--------- kernel/printk/printk_safe.c | 414 ---- kernel/ptrace.c | 32 +- kernel/rcu/Kconfig | 8 +- @@ -418,7 +418,7 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com> security/apparmor/lsm.c | 2 +- virt/kvm/arm/arch_timer.c | 8 +- virt/kvm/arm/arm.c | 6 +- - 411 files changed, 9823 insertions(+), 3817 deletions(-) + 411 files changed, 9822 insertions(+), 3852 deletions(-) create mode 100644 Documentation/printk-ringbuffer.txt create mode 100644 include/linux/locallock.h create mode 100644 include/linux/mutex_rt.h @@ -1566,7 +1566,7 @@ index a76f8ace9ce6..eb4a361d47d7 100644 +} +#endif diff --git a/arch/arm64/Kconfig b/arch/arm64/Kconfig -index 384b1bf56667..750070cd057a 100644 +index 82eba7ffa1d5..73654de3ca2e 100644 --- a/arch/arm64/Kconfig +++ b/arch/arm64/Kconfig @@ -35,32 +35,32 @@ config ARM64 @@ -2341,10 +2341,10 @@ index c97c01c75566..a2b1b26c472a 100644 config ARCH_HAS_ILOG2_U32 bool diff --git a/arch/parisc/kernel/entry.S b/arch/parisc/kernel/entry.S -index 2f64f112934b..2b33266cdeac 100644 +index 684a19d38198..2e59ca05824f 100644 --- a/arch/parisc/kernel/entry.S +++ b/arch/parisc/kernel/entry.S -@@ -942,14 +942,14 @@ intr_restore: +@@ -941,14 +941,14 @@ intr_restore: rfi nop @@ -2362,7 +2362,7 @@ index 2f64f112934b..2b33266cdeac 100644 * we jump back to intr_restore. */ LDREG PT_IASQ0(%r16), %r20 -@@ -981,7 +981,7 @@ intr_do_resched: +@@ -980,7 +980,7 @@ intr_do_resched: * and preempt_count is 0. otherwise, we continue on * our merry way back to the current running task. */ @@ -2371,7 +2371,7 @@ index 2f64f112934b..2b33266cdeac 100644 .import preempt_schedule_irq,code intr_do_preempt: rsm PSW_SM_I, %r0 /* disable interrupts */ -@@ -1001,7 +1001,7 @@ intr_do_preempt: +@@ -1000,7 +1000,7 @@ intr_do_preempt: nop b,n intr_restore /* ssm PSW_SM_I done by intr_restore */ @@ -2758,7 +2758,7 @@ index ff20c253f273..bba77ded0931 100644 _GLOBAL(call_do_irq) mflr r0 diff --git a/arch/powerpc/kernel/traps.c b/arch/powerpc/kernel/traps.c -index 70b99246dec4..72602ed58cf8 100644 +index 402a05f3a484..bf280b7ebe01 100644 --- a/arch/powerpc/kernel/traps.c +++ b/arch/powerpc/kernel/traps.c @@ -171,7 +171,6 @@ extern void panic_flush_kmsg_start(void) @@ -2988,7 +2988,7 @@ index 2100833adfb6..e448ca0fafcf 100644 pr_cont("SMP "); if (debug_pagealloc_enabled()) diff --git a/arch/s390/kernel/entry.S b/arch/s390/kernel/entry.S -index 5cba1815b8f8..bcbbe275b8fe 100644 +index 6f28f6ca045b..be88fcf2d4d4 100644 --- a/arch/s390/kernel/entry.S +++ b/arch/s390/kernel/entry.S @@ -800,7 +800,7 @@ ENTRY(io_int_handler) @@ -3856,7 +3856,7 @@ index 5c7ee3df4d0b..24bcc28f68d4 100644 /* TLB state for the entry code */ OFFSET(TLB_STATE_user_pcid_flush_mask, tlb_state, user_pcid_flush_mask); diff --git a/arch/x86/kernel/cpu/mshyperv.c b/arch/x86/kernel/cpu/mshyperv.c -index 51d95c4b692c..79ce26ae4029 100644 +index cebbcc6c36ae..11546367c2cf 100644 --- a/arch/x86/kernel/cpu/mshyperv.c +++ b/arch/x86/kernel/cpu/mshyperv.c @@ -83,6 +83,7 @@ __visible void __irq_entry hv_stimer0_vector_handler(struct pt_regs *regs) @@ -3968,10 +3968,10 @@ index 8ef71fa91ff8..764aa37782d1 100644 * Leave lazy mode, flushing any hypercalls made here. * This must be done before restoring TLS segments so diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c -index 8dd1d1c81c79..4e4f3ab153b9 100644 +index 07154cae7a15..2230fcdc6bfb 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c -@@ -7336,6 +7336,14 @@ int kvm_arch_init(void *opaque) +@@ -7338,6 +7338,14 @@ int kvm_arch_init(void *opaque) goto out; } @@ -4155,7 +4155,7 @@ index 9df50fb507ca..10244a1f8fee 100644 } } diff --git a/block/blk-mq.c b/block/blk-mq.c -index 325a5944b4cb..da0bc4e2068d 100644 +index 6d2e897273a1..587145f29ce0 100644 --- a/block/blk-mq.c +++ b/block/blk-mq.c @@ -611,9 +611,17 @@ static void __blk_mq_complete_request(struct request *rq) @@ -4186,7 +4186,7 @@ index 325a5944b4cb..da0bc4e2068d 100644 } static void hctx_unlock(struct blk_mq_hw_ctx *hctx, int srcu_idx) -@@ -1491,14 +1499,14 @@ static void __blk_mq_delay_run_hw_queue(struct blk_mq_hw_ctx *hctx, bool async, +@@ -1507,14 +1515,14 @@ static void __blk_mq_delay_run_hw_queue(struct blk_mq_hw_ctx *hctx, bool async, return; if (!async && !(hctx->flags & BLK_MQ_F_BLOCKING)) { @@ -4459,7 +4459,7 @@ index 364dd5eaebda..e1c12c036056 100644 } \ EXPORT_SYMBOL(get_random_ ##type); diff --git a/drivers/char/tpm/tpm-dev-common.c b/drivers/char/tpm/tpm-dev-common.c -index b99e1941c52c..dc4c0a0a5129 100644 +index fde81ecbd6a3..56e56a09cc90 100644 --- a/drivers/char/tpm/tpm-dev-common.c +++ b/drivers/char/tpm/tpm-dev-common.c @@ -20,7 +20,6 @@ @@ -4543,7 +4543,7 @@ index 9bfe4c5af87e..3e02bc47e6d5 100644 bool "Exynos multi core timer driver" if COMPILE_TEST depends on ARM || ARM64 diff --git a/drivers/clocksource/timer-atmel-tcb.c b/drivers/clocksource/timer-atmel-tcb.c -index 7427b07495a8..ce6627ee161f 100644 +index 906c1bfdccad..d64fdf5a21b7 100644 --- a/drivers/clocksource/timer-atmel-tcb.c +++ b/drivers/clocksource/timer-atmel-tcb.c @@ -28,8 +28,7 @@ @@ -4693,7 +4693,7 @@ index 7427b07495a8..ce6627ee161f 100644 return ret; } -@@ -346,8 +375,6 @@ static void __init tcb_setup_single_chan(struct atmel_tc *tc, int mck_divisor_id +@@ -347,8 +376,6 @@ static void __init tcb_setup_single_chan(struct atmel_tc *tc, int mck_divisor_id writel(ATMEL_TC_SYNC, tcaddr + ATMEL_TC_BCR); } @@ -4702,7 +4702,7 @@ index 7427b07495a8..ce6627ee161f 100644 static const struct of_device_id atmel_tcb_of_match[] = { { .compatible = "atmel,at91rm9200-tcb", .data = (void *)16, }, { .compatible = "atmel,at91sam9x5-tcb", .data = (void *)32, }, -@@ -467,7 +494,11 @@ static int __init tcb_clksrc_init(struct device_node *node) +@@ -468,7 +495,11 @@ static int __init tcb_clksrc_init(struct device_node *node) goto err_disable_t1; /* channel 2: periodic and oneshot timer support */ @@ -4967,7 +4967,7 @@ index fc6c4f81985e..593f36afa57b 100644 help Choose this option if you have an Intel I810 graphics card. If M is diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gpuvm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gpuvm.c -index 49b52ac3e473..cc41c3e159df 100644 +index 06c88dbc5a4a..f6ab66503d3a 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gpuvm.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gpuvm.c @@ -246,11 +246,9 @@ static int amdgpu_amdkfd_remove_eviction_fence(struct amdgpu_bo *bo, @@ -5164,7 +5164,7 @@ index 926272b5a0ca..66c0380fc275 100644 static inline void diff --git a/drivers/gpu/drm/i915/gt/intel_engine_pm.c b/drivers/gpu/drm/i915/gt/intel_engine_pm.c -index 65b5ca74b394..0e48a3d8ea22 100644 +index 910c10ee2c1a..6f8cea099b48 100644 --- a/drivers/gpu/drm/i915/gt/intel_engine_pm.c +++ b/drivers/gpu/drm/i915/gt/intel_engine_pm.c @@ -38,12 +38,15 @@ static int __engine_unpark(struct intel_wakeref *wf) @@ -5314,10 +5314,10 @@ index 24f2944da09d..b8ee3cd14323 100644 TP_PROTO(struct i915_request *rq), TP_ARGS(rq) diff --git a/drivers/gpu/drm/radeon/radeon_display.c b/drivers/gpu/drm/radeon/radeon_display.c -index 27b168936b2a..a3ae52ab9ace 100644 +index c7f50d9f7e37..775093ab9bc3 100644 --- a/drivers/gpu/drm/radeon/radeon_display.c +++ b/drivers/gpu/drm/radeon/radeon_display.c -@@ -1824,6 +1824,7 @@ int radeon_get_crtc_scanoutpos(struct drm_device *dev, unsigned int pipe, +@@ -1829,6 +1829,7 @@ int radeon_get_crtc_scanoutpos(struct drm_device *dev, unsigned int pipe, struct radeon_device *rdev = dev->dev_private; /* preempt_disable_rt() should go right here in PREEMPT_RT patchset. */ @@ -5325,7 +5325,7 @@ index 27b168936b2a..a3ae52ab9ace 100644 /* Get optional system timestamp before query. */ if (stime) -@@ -1916,6 +1917,7 @@ int radeon_get_crtc_scanoutpos(struct drm_device *dev, unsigned int pipe, +@@ -1921,6 +1922,7 @@ int radeon_get_crtc_scanoutpos(struct drm_device *dev, unsigned int pipe, *etime = ktime_get(); /* preempt_enable_rt() should go right here in PREEMPT_RT patchset. */ @@ -5361,7 +5361,7 @@ index 356382a340b2..cb0373c7033d 100644 #include "hv_trace.h" diff --git a/drivers/hv/vmbus_drv.c b/drivers/hv/vmbus_drv.c -index a1cfa7596853..ab454c085d55 100644 +index 01a2eeb2ec96..361f10e5c361 100644 --- a/drivers/hv/vmbus_drv.c +++ b/drivers/hv/vmbus_drv.c @@ -22,6 +22,7 @@ @@ -5397,10 +5397,10 @@ index 6dfa653d30db..29c35eb52414 100644 help Allows a block device to be used as cache for other devices; uses diff --git a/drivers/md/raid5.c b/drivers/md/raid5.c -index f3d60c4b34b8..ed80c4fe4c08 100644 +index 41556f5d4dcb..eae292684eb4 100644 --- a/drivers/md/raid5.c +++ b/drivers/md/raid5.c -@@ -2059,8 +2059,9 @@ static void raid_run_ops(struct stripe_head *sh, unsigned long ops_request) +@@ -2058,8 +2058,9 @@ static void raid_run_ops(struct stripe_head *sh, unsigned long ops_request) struct raid5_percpu *percpu; unsigned long cpu; @@ -5411,7 +5411,7 @@ index f3d60c4b34b8..ed80c4fe4c08 100644 if (test_bit(STRIPE_OP_BIOFILL, &ops_request)) { ops_run_biofill(sh); overlap_clear++; -@@ -2119,7 +2120,8 @@ static void raid_run_ops(struct stripe_head *sh, unsigned long ops_request) +@@ -2118,7 +2119,8 @@ static void raid_run_ops(struct stripe_head *sh, unsigned long ops_request) if (test_and_clear_bit(R5_Overlap, &dev->flags)) wake_up(&sh->raid_conf->wait_for_overlap); } @@ -5421,7 +5421,7 @@ index f3d60c4b34b8..ed80c4fe4c08 100644 } static void free_stripe(struct kmem_cache *sc, struct stripe_head *sh) -@@ -6834,6 +6836,7 @@ static int raid456_cpu_up_prepare(unsigned int cpu, struct hlist_node *node) +@@ -6831,6 +6833,7 @@ static int raid456_cpu_up_prepare(unsigned int cpu, struct hlist_node *node) __func__, cpu); return -ENOMEM; } @@ -5530,7 +5530,7 @@ index e2368bfe3e46..68e640dbe7ef 100644 break; default: diff --git a/drivers/of/base.c b/drivers/of/base.c -index b5c84607a74b..6dd8969992de 100644 +index 6fa209b3557b..d70e93265802 100644 --- a/drivers/of/base.c +++ b/drivers/of/base.c @@ -123,115 +123,38 @@ int __weak of_node_to_nid(struct device_node *np) @@ -5673,7 +5673,7 @@ index b5c84607a74b..6dd8969992de 100644 mutex_unlock(&of_mutex); /* Symlink in /proc as required by userspace ABI */ -@@ -1223,36 +1149,29 @@ struct device_node *of_find_node_by_phandle(phandle handle) +@@ -1259,36 +1185,29 @@ struct device_node *of_find_node_by_phandle(phandle handle) { struct device_node *np = NULL; unsigned long flags; @@ -5722,10 +5722,10 @@ index b5c84607a74b..6dd8969992de 100644 } } diff --git a/drivers/of/dynamic.c b/drivers/of/dynamic.c -index 49b16f76d78e..08fd823edac9 100644 +index ae969630958c..6ea8b2923b19 100644 --- a/drivers/of/dynamic.c +++ b/drivers/of/dynamic.c -@@ -276,7 +276,7 @@ void __of_detach_node(struct device_node *np) +@@ -278,7 +278,7 @@ void __of_detach_node(struct device_node *np) of_node_set_flag(np, OF_DETACHED); /* race with of_find_node_by_phandle() prevented by devtree_lock */ @@ -5755,7 +5755,7 @@ index 24786818e32e..de0042bc7701 100644 static inline void of_overlay_mutex_lock(void) {}; static inline void of_overlay_mutex_unlock(void) {}; diff --git a/drivers/of/overlay.c b/drivers/of/overlay.c -index dc298775f762..4443ecdb77bd 100644 +index b551fe44f2f9..ac037a06bc9c 100644 --- a/drivers/of/overlay.c +++ b/drivers/of/overlay.c @@ -974,8 +974,6 @@ static int of_overlay_apply(const void *fdt, struct device_node *tree, @@ -5786,7 +5786,7 @@ index dc298775f762..4443ecdb77bd 100644 if (ret_apply) devicetree_state_flags |= DTSF_REVERT_FAIL; diff --git a/drivers/pci/switch/switchtec.c b/drivers/pci/switch/switchtec.c -index 2c9c3061894b..90d6eb310e70 100644 +index 0b8325235852..3c547d198b0a 100644 --- a/drivers/pci/switch/switchtec.c +++ b/drivers/pci/switch/switchtec.c @@ -52,10 +52,11 @@ struct switchtec_user { @@ -5862,7 +5862,7 @@ index 2c9c3061894b..90d6eb310e70 100644 ret |= EPOLLIN | EPOLLRDNORM; if (stuser->event_cnt != atomic_read(&stdev->event_cnt)) -@@ -1106,7 +1109,8 @@ static void stdev_kill(struct switchtec_dev *stdev) +@@ -1099,7 +1102,8 @@ static void stdev_kill(struct switchtec_dev *stdev) /* Wake up and kill any users waiting on an MRPC request */ list_for_each_entry_safe(stuser, tmpuser, &stdev->mrpc_queue, list) { @@ -5931,10 +5931,10 @@ index 00ddb3fd940f..dec588885da6 100644 } diff --git a/drivers/scsi/fcoe/fcoe_ctlr.c b/drivers/scsi/fcoe/fcoe_ctlr.c -index d45e8c57051b..734a99681db8 100644 +index 7ce2a0434e1e..4564d1818b86 100644 --- a/drivers/scsi/fcoe/fcoe_ctlr.c +++ b/drivers/scsi/fcoe/fcoe_ctlr.c -@@ -828,7 +828,7 @@ static unsigned long fcoe_ctlr_age_fcfs(struct fcoe_ctlr *fip) +@@ -826,7 +826,7 @@ static unsigned long fcoe_ctlr_age_fcfs(struct fcoe_ctlr *fip) INIT_LIST_HEAD(&del_list); @@ -5943,7 +5943,7 @@ index d45e8c57051b..734a99681db8 100644 list_for_each_entry_safe(fcf, next, &fip->fcfs, list) { deadline = fcf->time + fcf->fka_period + fcf->fka_period / 2; -@@ -864,7 +864,7 @@ static unsigned long fcoe_ctlr_age_fcfs(struct fcoe_ctlr *fip) +@@ -862,7 +862,7 @@ static unsigned long fcoe_ctlr_age_fcfs(struct fcoe_ctlr *fip) sel_time = fcf->time; } } @@ -6279,7 +6279,7 @@ index a79ab53f8e87..b4b21f932be7 100644 static void mtk8250_set_flow_ctrl(struct uart_8250_port *up, int mode) diff --git a/drivers/tty/serial/8250/8250_port.c b/drivers/tty/serial/8250/8250_port.c -index 4770513944d4..6910545bc79e 100644 +index 5d8022cdb50a..310ddd41952a 100644 --- a/drivers/tty/serial/8250/8250_port.c +++ b/drivers/tty/serial/8250/8250_port.c @@ -727,7 +727,7 @@ static void serial8250_set_sleep(struct uart_8250_port *p, int sleep) @@ -6327,7 +6327,7 @@ index 4770513944d4..6910545bc79e 100644 serial8250_rpm_put(up); } -@@ -2074,14 +2074,7 @@ static void serial8250_put_poll_char(struct uart_port *port, +@@ -2077,14 +2077,7 @@ static void serial8250_put_poll_char(struct uart_port *port, struct uart_8250_port *up = up_to_u8250p(port); serial8250_rpm_get(up); @@ -6343,7 +6343,7 @@ index 4770513944d4..6910545bc79e 100644 wait_for_xmitr(up, BOTH_EMPTY); /* -@@ -2094,7 +2087,7 @@ static void serial8250_put_poll_char(struct uart_port *port, +@@ -2097,7 +2090,7 @@ static void serial8250_put_poll_char(struct uart_port *port, * and restore the IER */ wait_for_xmitr(up, BOTH_EMPTY); @@ -6352,7 +6352,7 @@ index 4770513944d4..6910545bc79e 100644 serial8250_rpm_put(up); } -@@ -2409,7 +2402,7 @@ void serial8250_do_shutdown(struct uart_port *port) +@@ -2412,7 +2405,7 @@ void serial8250_do_shutdown(struct uart_port *port) */ spin_lock_irqsave(&port->lock, flags); up->ier = 0; @@ -6361,7 +6361,7 @@ index 4770513944d4..6910545bc79e 100644 spin_unlock_irqrestore(&port->lock, flags); synchronize_irq(port->irq); -@@ -2705,7 +2698,7 @@ serial8250_do_set_termios(struct uart_port *port, struct ktermios *termios, +@@ -2708,7 +2701,7 @@ serial8250_do_set_termios(struct uart_port *port, struct ktermios *termios, if (up->capabilities & UART_CAP_RTOIE) up->ier |= UART_IER_RTOIE; @@ -6370,7 +6370,7 @@ index 4770513944d4..6910545bc79e 100644 if (up->capabilities & UART_CAP_EFR) { unsigned char efr = 0; -@@ -3171,7 +3164,7 @@ EXPORT_SYMBOL_GPL(serial8250_set_defaults); +@@ -3174,7 +3167,7 @@ EXPORT_SYMBOL_GPL(serial8250_set_defaults); #ifdef CONFIG_SERIAL_8250_CONSOLE @@ -6379,7 +6379,7 @@ index 4770513944d4..6910545bc79e 100644 { struct uart_8250_port *up = up_to_u8250p(port); -@@ -3179,6 +3172,18 @@ static void serial8250_console_putchar(struct uart_port *port, int ch) +@@ -3182,6 +3175,18 @@ static void serial8250_console_putchar(struct uart_port *port, int ch) serial_port_out(port, UART_TX, ch); } @@ -6398,7 +6398,7 @@ index 4770513944d4..6910545bc79e 100644 /* * Restore serial console when h/w power-off detected */ -@@ -3205,6 +3210,32 @@ static void serial8250_console_restore(struct uart_8250_port *up) +@@ -3208,6 +3213,32 @@ static void serial8250_console_restore(struct uart_8250_port *up) serial8250_out_MCR(up, up->mcr | UART_MCR_DTR | UART_MCR_RTS); } @@ -6431,7 +6431,7 @@ index 4770513944d4..6910545bc79e 100644 /* * Print a string to the serial port trying not to disturb * any possible real use of the port... -@@ -3217,26 +3248,13 @@ void serial8250_console_write(struct uart_8250_port *up, const char *s, +@@ -3220,26 +3251,13 @@ void serial8250_console_write(struct uart_8250_port *up, const char *s, struct uart_port *port = &up->port; unsigned long flags; unsigned int ier; @@ -6460,7 +6460,7 @@ index 4770513944d4..6910545bc79e 100644 /* check scratch reg to see if port powered off during system sleep */ if (up->canary && (up->canary != serial_port_in(port, UART_SCR))) { -@@ -3244,14 +3262,16 @@ void serial8250_console_write(struct uart_8250_port *up, const char *s, +@@ -3247,14 +3265,16 @@ void serial8250_console_write(struct uart_8250_port *up, const char *s, up->canary = 0; } @@ -6478,7 +6478,7 @@ index 4770513944d4..6910545bc79e 100644 /* * The receive handling will happen properly because the -@@ -3263,8 +3283,7 @@ void serial8250_console_write(struct uart_8250_port *up, const char *s, +@@ -3266,8 +3286,7 @@ void serial8250_console_write(struct uart_8250_port *up, const char *s, if (up->msr_saved_flags) serial8250_modem_status(up); @@ -6488,7 +6488,7 @@ index 4770513944d4..6910545bc79e 100644 serial8250_rpm_put(up); } -@@ -3285,6 +3304,7 @@ static unsigned int probe_baud(struct uart_port *port) +@@ -3288,6 +3307,7 @@ static unsigned int probe_baud(struct uart_port *port) int serial8250_console_setup(struct uart_port *port, char *options, bool probe) { @@ -6496,7 +6496,7 @@ index 4770513944d4..6910545bc79e 100644 int baud = 9600; int bits = 8; int parity = 'n'; -@@ -3293,6 +3313,8 @@ int serial8250_console_setup(struct uart_port *port, char *options, bool probe) +@@ -3296,6 +3316,8 @@ int serial8250_console_setup(struct uart_port *port, char *options, bool probe) if (!port->iobase && !port->membase) return -ENODEV; @@ -6506,10 +6506,10 @@ index 4770513944d4..6910545bc79e 100644 uart_parse_options(options, &baud, &parity, &bits, &flow); else if (probe) diff --git a/drivers/tty/serial/amba-pl011.c b/drivers/tty/serial/amba-pl011.c -index 86084090232d..857588c2622c 100644 +index 5f9d0ae8129d..abaf23095b2b 100644 --- a/drivers/tty/serial/amba-pl011.c +++ b/drivers/tty/serial/amba-pl011.c -@@ -2222,18 +2222,24 @@ pl011_console_write(struct console *co, const char *s, unsigned int count) +@@ -2218,18 +2218,24 @@ pl011_console_write(struct console *co, const char *s, unsigned int count) { struct uart_amba_port *uap = amba_ports[co->index]; unsigned int old_cr = 0, new_cr; @@ -6538,7 +6538,7 @@ index 86084090232d..857588c2622c 100644 /* * First save the CR then disable the interrupts -@@ -2259,8 +2265,7 @@ pl011_console_write(struct console *co, const char *s, unsigned int count) +@@ -2255,8 +2261,7 @@ pl011_console_write(struct console *co, const char *s, unsigned int count) pl011_write(old_cr, uap, REG_CR); if (locked) @@ -6580,10 +6580,10 @@ index 6420ae581a80..0f4f41ed9ffa 100644 static int __init diff --git a/drivers/usb/gadget/function/f_fs.c b/drivers/usb/gadget/function/f_fs.c -index 588a659f245e..b434c894c894 100644 +index 53658162b148..d3e4acddb3ce 100644 --- a/drivers/usb/gadget/function/f_fs.c +++ b/drivers/usb/gadget/function/f_fs.c -@@ -1724,7 +1724,7 @@ static void ffs_data_put(struct ffs_data *ffs) +@@ -1728,7 +1728,7 @@ static void ffs_data_put(struct ffs_data *ffs) ffs_data_clear(ffs); ffs_release_dev(ffs->private_data); BUG_ON(waitqueue_active(&ffs->ev.waitq) || @@ -6669,10 +6669,10 @@ index d94e2b7cddff..5197f7c3d31f 100644 _enter("%p{%pd},%llx", dentry, dentry, vnode->fid.vnode); diff --git a/fs/aio.c b/fs/aio.c -index 1ec5a773d09c..2d3bb9cd8836 100644 +index e8013c7ede27..d9211208e7f2 100644 --- a/fs/aio.c +++ b/fs/aio.c -@@ -1771,7 +1771,7 @@ static int aio_poll_wake(struct wait_queue_entry *wait, unsigned mode, int sync, +@@ -1782,7 +1782,7 @@ static int aio_poll_wake(struct wait_queue_entry *wait, unsigned mode, int sync, list_del_init(&req->wait.entry); list_del(&iocb->ki_list); iocb->ki_res.res = mangle_poll(mask); @@ -6786,10 +6786,10 @@ index 3925a7bfc74d..33f7723fb83e 100644 cifs_dbg(FYI, "%s: for %s\n", __func__, name->name); diff --git a/fs/dcache.c b/fs/dcache.c -index b2a7f1765f0b..d0267103d4b3 100644 +index 78081bdc4931..1561474321fb 100644 --- a/fs/dcache.c +++ b/fs/dcache.c -@@ -2484,9 +2484,10 @@ EXPORT_SYMBOL(d_rehash); +@@ -2491,9 +2491,10 @@ EXPORT_SYMBOL(d_rehash); static inline unsigned start_dir_add(struct inode *dir) { @@ -6802,7 +6802,7 @@ index b2a7f1765f0b..d0267103d4b3 100644 return n; cpu_relax(); } -@@ -2494,26 +2495,30 @@ static inline unsigned start_dir_add(struct inode *dir) +@@ -2501,26 +2502,30 @@ static inline unsigned start_dir_add(struct inode *dir) static inline void end_dir_add(struct inode *dir, unsigned n) { @@ -6845,7 +6845,7 @@ index b2a7f1765f0b..d0267103d4b3 100644 { unsigned int hash = name->hash; struct hlist_bl_head *b = in_lookup_hash(parent, hash); -@@ -2527,7 +2532,7 @@ struct dentry *d_alloc_parallel(struct dentry *parent, +@@ -2534,7 +2539,7 @@ struct dentry *d_alloc_parallel(struct dentry *parent, retry: rcu_read_lock(); @@ -6854,7 +6854,7 @@ index b2a7f1765f0b..d0267103d4b3 100644 r_seq = read_seqbegin(&rename_lock); dentry = __d_lookup_rcu(parent, name, &d_seq); if (unlikely(dentry)) { -@@ -2555,7 +2560,7 @@ struct dentry *d_alloc_parallel(struct dentry *parent, +@@ -2562,7 +2567,7 @@ struct dentry *d_alloc_parallel(struct dentry *parent, } hlist_bl_lock(b); @@ -6863,7 +6863,7 @@ index b2a7f1765f0b..d0267103d4b3 100644 hlist_bl_unlock(b); rcu_read_unlock(); goto retry; -@@ -2628,7 +2633,7 @@ void __d_lookup_done(struct dentry *dentry) +@@ -2635,7 +2640,7 @@ void __d_lookup_done(struct dentry *dentry) hlist_bl_lock(b); dentry->d_flags &= ~DCACHE_PAR_LOOKUP; __hlist_bl_del(&dentry->d_u.d_in_lookup_hash); @@ -6872,7 +6872,7 @@ index b2a7f1765f0b..d0267103d4b3 100644 dentry->d_wait = NULL; hlist_bl_unlock(b); INIT_HLIST_NODE(&dentry->d_u.d_alias); -@@ -3141,6 +3146,8 @@ __setup("dhash_entries=", set_dhash_entries); +@@ -3145,6 +3150,8 @@ __setup("dhash_entries=", set_dhash_entries); static void __init dcache_init_early(void) { @@ -6881,7 +6881,7 @@ index b2a7f1765f0b..d0267103d4b3 100644 /* If hashes are distributed across NUMA nodes, defer * hash allocation until vmalloc space is available. */ -@@ -3157,11 +3164,16 @@ static void __init dcache_init_early(void) +@@ -3161,11 +3168,16 @@ static void __init dcache_init_early(void) NULL, 0, 0); @@ -6898,7 +6898,7 @@ index b2a7f1765f0b..d0267103d4b3 100644 /* * A constructor could be added for stable state like the lists, * but it is probably not worth it because of the cache nature -@@ -3185,6 +3197,10 @@ static void __init dcache_init(void) +@@ -3189,6 +3201,10 @@ static void __init dcache_init(void) NULL, 0, 0); @@ -7127,7 +7127,7 @@ index 512609da8590..4f7855a6c26f 100644 if (!o->nodeid) { /* diff --git a/fs/inode.c b/fs/inode.c -index f7c8c0fe11d4..6797116bac8c 100644 +index 08c898333dbf..e652f224cced 100644 --- a/fs/inode.c +++ b/fs/inode.c @@ -157,7 +157,7 @@ int inode_init_always(struct super_block *sb, struct inode *inode) @@ -7140,10 +7140,10 @@ index f7c8c0fe11d4..6797116bac8c 100644 inode->dirtied_when = 0; diff --git a/fs/jbd2/commit.c b/fs/jbd2/commit.c -index 7bd4b1d4224e..f697c457f3a4 100644 +index 255026497b8c..2a99995fcf08 100644 --- a/fs/jbd2/commit.c +++ b/fs/jbd2/commit.c -@@ -483,10 +483,10 @@ void jbd2_journal_commit_transaction(journal_t *journal) +@@ -479,10 +479,10 @@ void jbd2_journal_commit_transaction(journal_t *journal) if (jh->b_committed_data) { struct buffer_head *bh = jh2bh(jh); @@ -7156,7 +7156,7 @@ index 7bd4b1d4224e..f697c457f3a4 100644 } jbd2_journal_refile_buffer(journal, jh); } -@@ -922,6 +922,7 @@ void jbd2_journal_commit_transaction(journal_t *journal) +@@ -918,6 +918,7 @@ void jbd2_journal_commit_transaction(journal_t *journal) transaction_t *cp_transaction; struct buffer_head *bh; int try_to_free = 0; @@ -7164,7 +7164,7 @@ index 7bd4b1d4224e..f697c457f3a4 100644 jh = commit_transaction->t_forget; spin_unlock(&journal->j_list_lock); -@@ -931,7 +932,7 @@ void jbd2_journal_commit_transaction(journal_t *journal) +@@ -927,7 +928,7 @@ void jbd2_journal_commit_transaction(journal_t *journal) * done with it. */ get_bh(bh); @@ -7173,7 +7173,7 @@ index 7bd4b1d4224e..f697c457f3a4 100644 J_ASSERT_JH(jh, jh->b_transaction == commit_transaction); /* -@@ -1031,8 +1032,10 @@ void jbd2_journal_commit_transaction(journal_t *journal) +@@ -1027,8 +1028,10 @@ void jbd2_journal_commit_transaction(journal_t *journal) try_to_free = 1; } JBUFFER_TRACE(jh, "refile or unfile buffer"); @@ -7187,10 +7187,10 @@ index 7bd4b1d4224e..f697c457f3a4 100644 release_buffer_page(bh); /* Drops bh reference */ else diff --git a/fs/jbd2/journal.c b/fs/jbd2/journal.c -index eeebe64b7c54..b939bad9a8a7 100644 +index 564aedbd867f..69d1f032c6fc 100644 --- a/fs/jbd2/journal.c +++ b/fs/jbd2/journal.c -@@ -362,7 +362,7 @@ int jbd2_journal_write_metadata_buffer(transaction_t *transaction, +@@ -364,7 +364,7 @@ int jbd2_journal_write_metadata_buffer(transaction_t *transaction, /* keep subsequent assertions sane */ atomic_set(&new_bh->b_count, 1); @@ -7199,7 +7199,7 @@ index eeebe64b7c54..b939bad9a8a7 100644 repeat: /* * If a new transaction has already done a buffer copy-out, then -@@ -404,13 +404,13 @@ int jbd2_journal_write_metadata_buffer(transaction_t *transaction, +@@ -406,14 +406,14 @@ int jbd2_journal_write_metadata_buffer(transaction_t *transaction, if (need_copy_out && !done_copy_out) { char *tmp; @@ -7208,6 +7208,7 @@ index eeebe64b7c54..b939bad9a8a7 100644 tmp = jbd2_alloc(bh_in->b_size, GFP_NOFS); if (!tmp) { brelse(new_bh); + free_buffer_head(new_bh); return -ENOMEM; } - jbd_lock_bh_state(bh_in); @@ -7215,7 +7216,7 @@ index eeebe64b7c54..b939bad9a8a7 100644 if (jh_in->b_frozen_data) { jbd2_free(tmp, bh_in->b_size); goto repeat; -@@ -463,7 +463,7 @@ int jbd2_journal_write_metadata_buffer(transaction_t *transaction, +@@ -466,7 +466,7 @@ int jbd2_journal_write_metadata_buffer(transaction_t *transaction, __jbd2_journal_file_buffer(jh_in, transaction, BJ_Shadow); spin_unlock(&journal->j_list_lock); set_buffer_shadow(bh_in); @@ -7224,7 +7225,7 @@ index eeebe64b7c54..b939bad9a8a7 100644 return do_escape | (done_copy_out << 1); } -@@ -2392,6 +2392,8 @@ static struct journal_head *journal_alloc_journal_head(void) +@@ -2397,6 +2397,8 @@ static struct journal_head *journal_alloc_journal_head(void) ret = kmem_cache_zalloc(jbd2_journal_head_cache, GFP_NOFS | __GFP_NOFAIL); } @@ -7233,7 +7234,7 @@ index eeebe64b7c54..b939bad9a8a7 100644 return ret; } -@@ -2511,17 +2513,23 @@ static void __journal_remove_journal_head(struct buffer_head *bh) +@@ -2516,17 +2518,23 @@ static void __journal_remove_journal_head(struct buffer_head *bh) J_ASSERT_BH(bh, buffer_jbd(bh)); J_ASSERT_BH(bh, jh2bh(jh) == bh); BUFFER_TRACE(bh, "remove journal_head"); @@ -7262,7 +7263,7 @@ index eeebe64b7c54..b939bad9a8a7 100644 journal_free_journal_head(jh); } -@@ -2539,9 +2547,11 @@ void jbd2_journal_put_journal_head(struct journal_head *jh) +@@ -2544,9 +2552,11 @@ void jbd2_journal_put_journal_head(struct journal_head *jh) if (!jh->b_jcount) { __journal_remove_journal_head(bh); jbd_unlock_bh_journal_head(bh); @@ -7742,7 +7743,7 @@ index 91c2d3f6d1b3..1670a2aa8020 100644 /* diff --git a/fs/namei.c b/fs/namei.c -index f6708ab8ec7e..e1cf56d0ba08 100644 +index a4cba6991a4d..e99e6d9c947c 100644 --- a/fs/namei.c +++ b/fs/namei.c @@ -1638,7 +1638,7 @@ static struct dentry *__lookup_slow(const struct qstr *name, @@ -7754,7 +7755,7 @@ index f6708ab8ec7e..e1cf56d0ba08 100644 /* Don't go there if it's already dead */ if (unlikely(IS_DEADDIR(inode))) -@@ -3146,7 +3146,7 @@ static int lookup_open(struct nameidata *nd, struct path *path, +@@ -3197,7 +3197,7 @@ static int lookup_open(struct nameidata *nd, struct path *path, struct dentry *dentry; int error, create_error = 0; umode_t mode = op->mode; @@ -7764,7 +7765,7 @@ index f6708ab8ec7e..e1cf56d0ba08 100644 if (unlikely(IS_DEADDIR(dir_inode))) return -ENOENT; diff --git a/fs/namespace.c b/fs/namespace.c -index 5782cd55dfdb..6af700b53c73 100644 +index 281f08eaba5b..7439085dbec5 100644 --- a/fs/namespace.c +++ b/fs/namespace.c @@ -14,6 +14,7 @@ @@ -7854,10 +7855,10 @@ index 28ceee102d0b..7134b07bcc6a 100644 error = NFS_PROTO(dir)->rmdir(dir, &dentry->d_name); trace_nfs_rmdir_exit(dir, dentry, error); diff --git a/fs/nfs/inode.c b/fs/nfs/inode.c -index 3bddf5332b6d..f2c750da4d4d 100644 +index 251f45fee53c..3334a3567ea5 100644 --- a/fs/nfs/inode.c +++ b/fs/nfs/inode.c -@@ -2114,7 +2114,11 @@ static void init_once(void *foo) +@@ -2115,7 +2115,11 @@ static void init_once(void *foo) atomic_long_set(&nfsi->nrequests, 0); atomic_long_set(&nfsi->commit_info.ncommit, 0); atomic_set(&nfsi->commit_info.rpcs_out, 0); @@ -7883,10 +7884,10 @@ index ebd77a301057..28ed21bff818 100644 }; diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c -index c41d14962604..9cec53077c38 100644 +index 632cea3fb91d..356fb574da79 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c -@@ -2990,7 +2990,7 @@ static int _nfs4_open_and_get_state(struct nfs4_opendata *opendata, +@@ -2994,7 +2994,7 @@ static int _nfs4_open_and_get_state(struct nfs4_opendata *opendata, unsigned int seq; int ret; @@ -7895,7 +7896,7 @@ index c41d14962604..9cec53077c38 100644 dir_verifier = nfs_save_change_attribute(dir); ret = _nfs4_proc_open(opendata, ctx); -@@ -3044,7 +3044,7 @@ static int _nfs4_open_and_get_state(struct nfs4_opendata *opendata, +@@ -3048,7 +3048,7 @@ static int _nfs4_open_and_get_state(struct nfs4_opendata *opendata, if (d_inode(dentry) == state->inode) { nfs_inode_attach_open_context(ctx); @@ -7905,10 +7906,10 @@ index c41d14962604..9cec53077c38 100644 } diff --git a/fs/nfs/nfs4state.c b/fs/nfs/nfs4state.c -index 01b185670594..271174f0bde6 100644 +index 1d38484e0a53..f7a5976de705 100644 --- a/fs/nfs/nfs4state.c +++ b/fs/nfs/nfs4state.c -@@ -513,7 +513,7 @@ nfs4_alloc_state_owner(struct nfs_server *server, +@@ -514,7 +514,7 @@ nfs4_alloc_state_owner(struct nfs_server *server, nfs4_init_seqid_counter(&sp->so_seqid); atomic_set(&sp->so_count, 1); INIT_LIST_HEAD(&sp->so_lru); @@ -7917,7 +7918,7 @@ index 01b185670594..271174f0bde6 100644 mutex_init(&sp->so_delegreturn_mutex); return sp; } -@@ -1623,8 +1623,12 @@ static int nfs4_reclaim_open_state(struct nfs4_state_owner *sp, const struct nfs +@@ -1624,8 +1624,12 @@ static int nfs4_reclaim_open_state(struct nfs4_state_owner *sp, const struct nfs * recovering after a network partition or a reboot from a * server that doesn't support a grace period. */ @@ -7931,7 +7932,7 @@ index 01b185670594..271174f0bde6 100644 restart: list_for_each_entry(state, &sp->so_states, open_states) { if (!test_and_clear_bit(ops->state_flag_bit, &state->flags)) -@@ -1685,14 +1689,20 @@ static int nfs4_reclaim_open_state(struct nfs4_state_owner *sp, const struct nfs +@@ -1686,14 +1690,20 @@ static int nfs4_reclaim_open_state(struct nfs4_state_owner *sp, const struct nfs spin_lock(&sp->so_lock); goto restart; } @@ -8144,10 +8145,10 @@ index 5e0eaea47405..92225a4df817 100644 ocfs2_journal_dirty(handle, group_bh); bail: diff --git a/fs/proc/base.c b/fs/proc/base.c -index 77a3eb7c39f5..51d51ee2aecf 100644 +index 34e15da39fdf..5d11c8ffddcc 100644 --- a/fs/proc/base.c +++ b/fs/proc/base.c -@@ -95,6 +95,7 @@ +@@ -96,6 +96,7 @@ #include <linux/sched/stat.h> #include <linux/posix-timers.h> #include <trace/events/oom.h> @@ -8155,7 +8156,7 @@ index 77a3eb7c39f5..51d51ee2aecf 100644 #include "internal.h" #include "fd.h" -@@ -1899,7 +1900,7 @@ bool proc_fill_cache(struct file *file, struct dir_context *ctx, +@@ -1958,7 +1959,7 @@ bool proc_fill_cache(struct file *file, struct dir_context *ctx, child = d_hash_and_lookup(dir, &qname); if (!child) { @@ -8348,10 +8349,10 @@ index a19519f4241d..ef2366a65ba2 100644 static inline void local_bh_disable(void) { diff --git a/include/linux/bpf.h b/include/linux/bpf.h -index 5705cda3c4c4..fd630723200e 100644 +index 6107b537245a..95e0f14ce30f 100644 --- a/include/linux/bpf.h +++ b/include/linux/bpf.h -@@ -541,7 +541,7 @@ int bpf_prog_array_copy(struct bpf_prog_array *old_array, +@@ -545,7 +545,7 @@ int bpf_prog_array_copy(struct bpf_prog_array *old_array, struct bpf_prog *_prog; \ struct bpf_prog_array *_array; \ u32 _ret = 1; \ @@ -8360,7 +8361,7 @@ index 5705cda3c4c4..fd630723200e 100644 rcu_read_lock(); \ _array = rcu_dereference(array); \ if (unlikely(check_non_null && !_array))\ -@@ -555,7 +555,7 @@ int bpf_prog_array_copy(struct bpf_prog_array *old_array, +@@ -559,7 +559,7 @@ int bpf_prog_array_copy(struct bpf_prog_array *old_array, } \ _out: \ rcu_read_unlock(); \ @@ -8369,7 +8370,7 @@ index 5705cda3c4c4..fd630723200e 100644 _ret; \ }) -@@ -589,7 +589,7 @@ _out: \ +@@ -593,7 +593,7 @@ _out: \ u32 ret; \ u32 _ret = 1; \ u32 _cn = 0; \ @@ -8378,7 +8379,7 @@ index 5705cda3c4c4..fd630723200e 100644 rcu_read_lock(); \ _array = rcu_dereference(array); \ _item = &_array->items[0]; \ -@@ -601,7 +601,7 @@ _out: \ +@@ -605,7 +605,7 @@ _out: \ _item++; \ } \ rcu_read_unlock(); \ @@ -8387,7 +8388,7 @@ index 5705cda3c4c4..fd630723200e 100644 if (_ret) \ _ret = (_cn ? NET_XMIT_CN : NET_XMIT_SUCCESS); \ else \ -@@ -618,6 +618,36 @@ _out: \ +@@ -622,6 +622,36 @@ _out: \ #ifdef CONFIG_BPF_SYSCALL DECLARE_PER_CPU(int, bpf_prog_active); @@ -8449,7 +8450,7 @@ index 0575ad84cc55..70e73b8eabaf 100644 /* diff --git a/include/linux/cgroup-defs.h b/include/linux/cgroup-defs.h -index d15884957e7f..8076fa031171 100644 +index f0798d98be8e..7426ac08f340 100644 --- a/include/linux/cgroup-defs.h +++ b/include/linux/cgroup-defs.h @@ -144,9 +144,6 @@ struct cgroup_subsys_state { @@ -8470,7 +8471,7 @@ index d15884957e7f..8076fa031171 100644 /* cgroup basic resource statistics */ struct cgroup_base_stat pending_bstat; /* pending from children */ -@@ -634,7 +630,6 @@ struct cgroup_subsys { +@@ -635,7 +631,6 @@ struct cgroup_subsys { void (*css_released)(struct cgroup_subsys_state *css); void (*css_free)(struct cgroup_subsys_state *css); void (*css_reset)(struct cgroup_subsys_state *css); @@ -8657,10 +8658,10 @@ index de0ad39d4281..07f81c186ce0 100644 static inline void eventfd_ctx_do_read(struct eventfd_ctx *ctx, __u64 *cnt) diff --git a/include/linux/filter.h b/include/linux/filter.h -index 440014875acf..e83b6db44a47 100644 +index 0bec300b2e51..d62007508d41 100644 --- a/include/linux/filter.h +++ b/include/linux/filter.h -@@ -570,7 +570,7 @@ DECLARE_STATIC_KEY_FALSE(bpf_stats_enabled_key); +@@ -574,7 +574,7 @@ DECLARE_STATIC_KEY_FALSE(bpf_stats_enabled_key); #define BPF_PROG_RUN(prog, ctx) ({ \ u32 ret; \ @@ -8669,7 +8670,7 @@ index 440014875acf..e83b6db44a47 100644 if (static_branch_unlikely(&bpf_stats_enabled_key)) { \ struct bpf_prog_stats *stats; \ u64 start = sched_clock(); \ -@@ -585,6 +585,28 @@ DECLARE_STATIC_KEY_FALSE(bpf_stats_enabled_key); +@@ -589,6 +589,28 @@ DECLARE_STATIC_KEY_FALSE(bpf_stats_enabled_key); } \ ret; }) @@ -8698,7 +8699,7 @@ index 440014875acf..e83b6db44a47 100644 #define BPF_SKB_CB_LEN QDISC_CB_PRIV_LEN struct bpf_skb_data_end { -@@ -662,6 +684,7 @@ static inline u8 *bpf_skb_cb(struct sk_buff *skb) +@@ -666,6 +688,7 @@ static inline u8 *bpf_skb_cb(struct sk_buff *skb) return qdisc_skb_cb(skb)->data; } @@ -8706,7 +8707,7 @@ index 440014875acf..e83b6db44a47 100644 static inline u32 __bpf_prog_run_save_cb(const struct bpf_prog *prog, struct sk_buff *skb) { -@@ -687,9 +710,9 @@ static inline u32 bpf_prog_run_save_cb(const struct bpf_prog *prog, +@@ -691,9 +714,9 @@ static inline u32 bpf_prog_run_save_cb(const struct bpf_prog *prog, { u32 res; @@ -8718,7 +8719,7 @@ index 440014875acf..e83b6db44a47 100644 return res; } -@@ -702,9 +725,7 @@ static inline u32 bpf_prog_run_clear_cb(const struct bpf_prog *prog, +@@ -706,9 +729,7 @@ static inline u32 bpf_prog_run_clear_cb(const struct bpf_prog *prog, if (unlikely(prog->cb_access)) memset(cb_data, 0, BPF_SKB_CB_LEN); @@ -8730,10 +8731,10 @@ index 440014875acf..e83b6db44a47 100644 } diff --git a/include/linux/fs.h b/include/linux/fs.h -index 4b1553f570f2..299310d278a2 100644 +index c0967df13715..ac9da6bb2a60 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h -@@ -717,7 +717,7 @@ struct inode { +@@ -719,7 +719,7 @@ struct inode { struct block_device *i_bdev; struct cdev *i_cdev; char *i_link; @@ -8742,7 +8743,7 @@ index 4b1553f570f2..299310d278a2 100644 }; __u32 i_generation; -@@ -856,7 +856,7 @@ static inline loff_t i_size_read(const struct inode *inode) +@@ -858,7 +858,7 @@ static inline loff_t i_size_read(const struct inode *inode) i_size = inode->i_size; } while (read_seqcount_retry(&inode->i_size_seqcount, seq)); return i_size; @@ -8751,7 +8752,7 @@ index 4b1553f570f2..299310d278a2 100644 loff_t i_size; preempt_disable(); -@@ -881,7 +881,7 @@ static inline void i_size_write(struct inode *inode, loff_t i_size) +@@ -883,7 +883,7 @@ static inline void i_size_write(struct inode *inode, loff_t i_size) inode->i_size = i_size; write_seqcount_end(&inode->i_size_seqcount); preempt_enable(); @@ -8910,7 +8911,7 @@ index 900f224bb640..681d31133b7a 100644 } diff --git a/include/linux/idr.h b/include/linux/idr.h -index ac6e946b6767..839da8f2f6f1 100644 +index bbfd934cab22..a6b48f89e7d0 100644 --- a/include/linux/idr.h +++ b/include/linux/idr.h @@ -169,10 +169,7 @@ static inline bool idr_is_empty(const struct idr *idr) @@ -9024,7 +9025,7 @@ index 21619c92c377..5304de2f7838 100644 defined(CONFIG_PREEMPT_TRACER) extern void stop_critical_timings(void); diff --git a/include/linux/jbd2.h b/include/linux/jbd2.h -index b60adc4210b5..518dbb2305cf 100644 +index 45c7e21ba1af..9d709139db11 100644 --- a/include/linux/jbd2.h +++ b/include/linux/jbd2.h @@ -313,7 +313,6 @@ enum jbd_state_bits { @@ -9575,7 +9576,7 @@ index 000000000000..9b6b4def52d4 + +#endif diff --git a/include/linux/mm_types.h b/include/linux/mm_types.h -index 2b3b2fc1cb33..402d2cb6ca77 100644 +index afbe3056a8d7..19e19d42e689 100644 --- a/include/linux/mm_types.h +++ b/include/linux/mm_types.h @@ -12,6 +12,7 @@ @@ -9776,7 +9777,7 @@ index 000000000000..3fcb5edb1d2b + +#endif diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h -index bf623f0e04d6..590bccff0a4a 100644 +index a6bb64dccb88..9d37a400e9c8 100644 --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h @@ -3059,6 +3059,7 @@ struct softnet_data { @@ -10158,7 +10159,7 @@ index 3d10c84a97a9..bad09364b20a 100644 #else struct posix_cputimers { }; diff --git a/include/linux/preempt.h b/include/linux/preempt.h -index bbb68dba37cc..bbc3592b6f04 100644 +index bc3f1aecaa19..bbc3592b6f04 100644 --- a/include/linux/preempt.h +++ b/include/linux/preempt.h @@ -78,10 +78,8 @@ @@ -10354,6 +10355,41 @@ index bbb68dba37cc..bbc3592b6f04 100644 #ifdef CONFIG_PREEMPT_NOTIFIERS struct preempt_notifier; +@@ -322,34 +419,4 @@ static inline void preempt_notifier_init(struct preempt_notifier *notifier, + + #endif + +-/** +- * migrate_disable - Prevent migration of the current task +- * +- * Maps to preempt_disable() which also disables preemption. Use +- * migrate_disable() to annotate that the intent is to prevent migration, +- * but not necessarily preemption. +- * +- * Can be invoked nested like preempt_disable() and needs the corresponding +- * number of migrate_enable() invocations. +- */ +-static __always_inline void migrate_disable(void) +-{ +- preempt_disable(); +-} +- +-/** +- * migrate_enable - Allow migration of the current task +- * +- * Counterpart to migrate_disable(). +- * +- * As migrate_disable() can be invoked nested, only the outermost invocation +- * reenables migration. +- * +- * Currently mapped to preempt_enable(). +- */ +-static __always_inline void migrate_enable(void) +-{ +- preempt_enable(); +-} +- + #endif /* __LINUX_PREEMPT_H */ diff --git a/include/linux/printk.h b/include/linux/printk.h index eb2a093ba042..1fe8068100c2 100644 --- a/include/linux/printk.h @@ -10681,7 +10717,7 @@ index 000000000000..78c05f606a73 + +#endif diff --git a/include/linux/rcupdate.h b/include/linux/rcupdate.h -index c75b38ba4a72..0fa23420bda2 100644 +index bc4b5c905a60..2a6cef3e4ce3 100644 --- a/include/linux/rcupdate.h +++ b/include/linux/rcupdate.h @@ -29,6 +29,7 @@ @@ -10722,7 +10758,7 @@ index c75b38ba4a72..0fa23420bda2 100644 */ #define cond_resched_tasks_rcu_qs() \ do { \ -@@ -281,7 +289,8 @@ static inline void rcu_preempt_sleep_check(void) { } +@@ -312,7 +320,8 @@ static inline void rcu_preempt_sleep_check(void) { } #define rcu_sleep_check() \ do { \ rcu_preempt_sleep_check(); \ @@ -10732,7 +10768,7 @@ index c75b38ba4a72..0fa23420bda2 100644 "Illegal context switch in RCU-bh read-side critical section"); \ RCU_LOCKDEP_WARN(lock_is_held(&rcu_sched_lock_map), \ "Illegal context switch in RCU-sched read-side critical section"); \ -@@ -302,13 +311,6 @@ static inline void rcu_preempt_sleep_check(void) { } +@@ -333,13 +342,6 @@ static inline void rcu_preempt_sleep_check(void) { } * (e.g., __srcu), should this make sense in the future. */ @@ -10746,7 +10782,7 @@ index c75b38ba4a72..0fa23420bda2 100644 #define __rcu_access_pointer(p, space) \ ({ \ typeof(*p) *_________p1 = (typeof(*p) *__force)READ_ONCE(p); \ -@@ -336,54 +338,6 @@ static inline void rcu_preempt_sleep_check(void) { } +@@ -367,54 +369,6 @@ static inline void rcu_preempt_sleep_check(void) { } ((typeof(*p) __force __kernel *)(________p1)); \ }) @@ -10801,7 +10837,7 @@ index c75b38ba4a72..0fa23420bda2 100644 /** * rcu_replace_pointer() - replace an RCU pointer, returning its old value * @rcu_ptr: RCU pointer, whose old value is returned -@@ -600,7 +554,7 @@ do { \ +@@ -631,7 +585,7 @@ do { \ * * You can avoid reading and understanding the next paragraph by * following this rule: don't put anything in an rcu_read_lock() RCU @@ -11706,7 +11742,7 @@ index 1a5f88316b08..1870c233799e 100644 /* Test if 'sig' is valid signal. Use this instead of testing _NSIG directly */ static inline int valid_signal(unsigned long sig) diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h -index 302a2ad67980..31b880d5062e 100644 +index 3191d0ffc6e9..6f4111b37521 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h @@ -294,6 +294,7 @@ struct sk_buff_head { @@ -11717,7 +11753,7 @@ index 302a2ad67980..31b880d5062e 100644 }; struct sk_buff; -@@ -1866,6 +1867,12 @@ static inline void skb_queue_head_init(struct sk_buff_head *list) +@@ -1863,6 +1864,12 @@ static inline void skb_queue_head_init(struct sk_buff_head *list) __skb_queue_head_init(list); } @@ -12312,7 +12348,7 @@ index f3040b0b4b23..3cb02ced141b 100644 #ifndef CONFIG_HAVE_ARCH_WITHIN_STACK_FRAMES static inline int arch_within_stack_frames(const void * const stack, diff --git a/include/linux/trace_events.h b/include/linux/trace_events.h -index a8e9d1a04f82..dd5d97c37394 100644 +index d88622a9db7b..e4ef0088bda1 100644 --- a/include/linux/trace_events.h +++ b/include/linux/trace_events.h @@ -62,6 +62,8 @@ struct trace_entry { @@ -12480,7 +12516,7 @@ index 000000000000..67710bace741 + +#endif diff --git a/include/net/sch_generic.h b/include/net/sch_generic.h -index e8034756cbf8..49176f44b677 100644 +index 6d934ce54c8d..61d165c0af00 100644 --- a/include/net/sch_generic.h +++ b/include/net/sch_generic.h @@ -10,6 +10,7 @@ @@ -12706,7 +12742,7 @@ index deff97217496..7871ec3c9a02 100644 prompt "Preemption Model" default PREEMPT_NONE diff --git a/kernel/bpf/hashtab.c b/kernel/bpf/hashtab.c -index 03a67583f6fb..02b5e8e3c04a 100644 +index 0d14a2a11463..93c73f1dc7cd 100644 --- a/kernel/bpf/hashtab.c +++ b/kernel/bpf/hashtab.c @@ -17,9 +17,62 @@ @@ -12837,7 +12873,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 static inline void htab_elem_set_ptr(struct htab_elem *l, u32 key_size, void __percpu *pptr) { -@@ -306,8 +399,8 @@ static struct bpf_map *htab_map_alloc(union bpf_attr *attr) +@@ -309,8 +402,8 @@ static struct bpf_map *htab_map_alloc(union bpf_attr *attr) bool percpu_lru = (attr->map_flags & BPF_F_NO_COMMON_LRU); bool prealloc = !(attr->map_flags & BPF_F_NO_PREALLOC); struct bpf_htab *htab; @@ -12847,7 +12883,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 htab = kzalloc(sizeof(*htab), GFP_USER); if (!htab) -@@ -369,10 +462,7 @@ static struct bpf_map *htab_map_alloc(union bpf_attr *attr) +@@ -376,10 +469,7 @@ static struct bpf_map *htab_map_alloc(union bpf_attr *attr) else htab->hashrnd = get_random_int(); @@ -12859,7 +12895,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 if (prealloc) { err = prealloc_init(htab); -@@ -580,7 +670,7 @@ static bool htab_lru_map_delete_node(void *arg, struct bpf_lru_node *node) +@@ -587,7 +677,7 @@ static bool htab_lru_map_delete_node(void *arg, struct bpf_lru_node *node) b = __select_bucket(htab, tgt_l->hash); head = &b->head; @@ -12868,7 +12904,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 hlist_nulls_for_each_entry_rcu(l, n, head, hash_node) if (l == tgt_l) { -@@ -588,7 +678,7 @@ static bool htab_lru_map_delete_node(void *arg, struct bpf_lru_node *node) +@@ -595,7 +685,7 @@ static bool htab_lru_map_delete_node(void *arg, struct bpf_lru_node *node) break; } @@ -12877,7 +12913,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 return l == tgt_l; } -@@ -886,8 +976,7 @@ static int htab_map_update_elem(struct bpf_map *map, void *key, void *value, +@@ -893,8 +983,7 @@ static int htab_map_update_elem(struct bpf_map *map, void *key, void *value, */ } @@ -12887,7 +12923,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 l_old = lookup_elem_raw(head, hash, key, key_size); -@@ -928,7 +1017,7 @@ static int htab_map_update_elem(struct bpf_map *map, void *key, void *value, +@@ -935,7 +1024,7 @@ static int htab_map_update_elem(struct bpf_map *map, void *key, void *value, } ret = 0; err: @@ -12896,7 +12932,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 return ret; } -@@ -966,8 +1055,7 @@ static int htab_lru_map_update_elem(struct bpf_map *map, void *key, void *value, +@@ -973,8 +1062,7 @@ static int htab_lru_map_update_elem(struct bpf_map *map, void *key, void *value, return -ENOMEM; memcpy(l_new->key + round_up(map->key_size, 8), value, map->value_size); @@ -12906,7 +12942,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 l_old = lookup_elem_raw(head, hash, key, key_size); -@@ -986,7 +1074,7 @@ static int htab_lru_map_update_elem(struct bpf_map *map, void *key, void *value, +@@ -993,7 +1081,7 @@ static int htab_lru_map_update_elem(struct bpf_map *map, void *key, void *value, ret = 0; err: @@ -12915,7 +12951,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 if (ret) bpf_lru_push_free(&htab->lru, &l_new->lru_node); -@@ -1021,8 +1109,7 @@ static int __htab_percpu_map_update_elem(struct bpf_map *map, void *key, +@@ -1028,8 +1116,7 @@ static int __htab_percpu_map_update_elem(struct bpf_map *map, void *key, b = __select_bucket(htab, hash); head = &b->head; @@ -12925,7 +12961,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 l_old = lookup_elem_raw(head, hash, key, key_size); -@@ -1045,7 +1132,7 @@ static int __htab_percpu_map_update_elem(struct bpf_map *map, void *key, +@@ -1052,7 +1139,7 @@ static int __htab_percpu_map_update_elem(struct bpf_map *map, void *key, } ret = 0; err: @@ -12934,7 +12970,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 return ret; } -@@ -1085,8 +1172,7 @@ static int __htab_lru_percpu_map_update_elem(struct bpf_map *map, void *key, +@@ -1092,8 +1179,7 @@ static int __htab_lru_percpu_map_update_elem(struct bpf_map *map, void *key, return -ENOMEM; } @@ -12944,7 +12980,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 l_old = lookup_elem_raw(head, hash, key, key_size); -@@ -1108,7 +1194,7 @@ static int __htab_lru_percpu_map_update_elem(struct bpf_map *map, void *key, +@@ -1115,7 +1201,7 @@ static int __htab_lru_percpu_map_update_elem(struct bpf_map *map, void *key, } ret = 0; err: @@ -12953,7 +12989,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 if (l_new) bpf_lru_push_free(&htab->lru, &l_new->lru_node); return ret; -@@ -1146,7 +1232,7 @@ static int htab_map_delete_elem(struct bpf_map *map, void *key) +@@ -1153,7 +1239,7 @@ static int htab_map_delete_elem(struct bpf_map *map, void *key) b = __select_bucket(htab, hash); head = &b->head; @@ -12962,7 +12998,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 l = lookup_elem_raw(head, hash, key, key_size); -@@ -1156,7 +1242,7 @@ static int htab_map_delete_elem(struct bpf_map *map, void *key) +@@ -1163,7 +1249,7 @@ static int htab_map_delete_elem(struct bpf_map *map, void *key) ret = 0; } @@ -12971,7 +13007,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 return ret; } -@@ -1178,7 +1264,7 @@ static int htab_lru_map_delete_elem(struct bpf_map *map, void *key) +@@ -1185,7 +1271,7 @@ static int htab_lru_map_delete_elem(struct bpf_map *map, void *key) b = __select_bucket(htab, hash); head = &b->head; @@ -12980,7 +13016,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 l = lookup_elem_raw(head, hash, key, key_size); -@@ -1187,7 +1273,7 @@ static int htab_lru_map_delete_elem(struct bpf_map *map, void *key) +@@ -1194,7 +1280,7 @@ static int htab_lru_map_delete_elem(struct bpf_map *map, void *key) ret = 0; } @@ -12990,7 +13026,7 @@ index 03a67583f6fb..02b5e8e3c04a 100644 bpf_lru_push_free(&htab->lru, &l->lru_node); return ret; diff --git a/kernel/bpf/lpm_trie.c b/kernel/bpf/lpm_trie.c -index 56e6c75d354d..3b3c420bc8ed 100644 +index f726ceb8d7e9..c528721770d0 100644 --- a/kernel/bpf/lpm_trie.c +++ b/kernel/bpf/lpm_trie.c @@ -34,7 +34,7 @@ struct lpm_trie { @@ -13002,7 +13038,7 @@ index 56e6c75d354d..3b3c420bc8ed 100644 }; /* This trie implements a longest prefix match algorithm that can be used to -@@ -315,7 +315,7 @@ static int trie_update_elem(struct bpf_map *map, +@@ -318,7 +318,7 @@ static int trie_update_elem(struct bpf_map *map, if (key->prefixlen > trie->max_prefixlen) return -EINVAL; @@ -13011,7 +13047,7 @@ index 56e6c75d354d..3b3c420bc8ed 100644 /* Allocate and fill a new node */ -@@ -422,7 +422,7 @@ static int trie_update_elem(struct bpf_map *map, +@@ -442,7 +442,7 @@ static int trie_update_elem(struct bpf_map *map, kfree(im_node); } @@ -13020,7 +13056,7 @@ index 56e6c75d354d..3b3c420bc8ed 100644 return ret; } -@@ -442,7 +442,7 @@ static int trie_delete_elem(struct bpf_map *map, void *_key) +@@ -462,7 +462,7 @@ static int trie_delete_elem(struct bpf_map *map, void *_key) if (key->prefixlen > trie->max_prefixlen) return -EINVAL; @@ -13029,7 +13065,7 @@ index 56e6c75d354d..3b3c420bc8ed 100644 /* Walk the tree looking for an exact key/length match and keeping * track of the path we traverse. We will need to know the node -@@ -518,7 +518,7 @@ static int trie_delete_elem(struct bpf_map *map, void *_key) +@@ -538,7 +538,7 @@ static int trie_delete_elem(struct bpf_map *map, void *_key) kfree_rcu(node, rcu); out: @@ -13038,7 +13074,7 @@ index 56e6c75d354d..3b3c420bc8ed 100644 return ret; } -@@ -575,7 +575,7 @@ static struct bpf_map *trie_alloc(union bpf_attr *attr) +@@ -595,7 +595,7 @@ static struct bpf_map *trie_alloc(union bpf_attr *attr) if (ret) goto out_err; @@ -13105,7 +13141,7 @@ index 6e090140b924..b367430e611c 100644 struct pcpu_freelist_node *__pcpu_freelist_pop(struct pcpu_freelist *s) diff --git a/kernel/bpf/stackmap.c b/kernel/bpf/stackmap.c -index 811071c227f1..db07ea23ca7f 100644 +index bd8516d96745..7c22eace06b6 100644 --- a/kernel/bpf/stackmap.c +++ b/kernel/bpf/stackmap.c @@ -40,6 +40,9 @@ static void do_up_read(struct irq_work *entry) @@ -13118,7 +13154,7 @@ index 811071c227f1..db07ea23ca7f 100644 work = container_of(entry, struct stack_map_irq_work, irq_work); up_read_non_owner(work->sem); work->sem = NULL; -@@ -291,10 +294,18 @@ static void stack_map_get_build_id_offset(struct bpf_stack_build_id *id_offs, +@@ -294,10 +297,18 @@ static void stack_map_get_build_id_offset(struct bpf_stack_build_id *id_offs, struct stack_map_irq_work *work = NULL; if (irqs_disabled()) { @@ -13204,10 +13240,10 @@ index de788761b708..f597b34d756b 100644 out: kfree(key); diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c -index 530664693ac4..3e86a9e3242b 100644 +index 013b9062c47c..a26dd71a813f 100644 --- a/kernel/bpf/verifier.c +++ b/kernel/bpf/verifier.c -@@ -8157,26 +8157,48 @@ static bool is_tracing_prog_type(enum bpf_prog_type type) +@@ -8162,26 +8162,48 @@ static bool is_tracing_prog_type(enum bpf_prog_type type) } } @@ -13266,10 +13302,10 @@ index 530664693ac4..3e86a9e3242b 100644 if ((is_tracing_prog_type(prog->type) || diff --git a/kernel/cgroup/cgroup.c b/kernel/cgroup/cgroup.c -index 62a7a5075014..59e107d22b2b 100644 +index 273a8a42cb72..b8999849a228 100644 --- a/kernel/cgroup/cgroup.c +++ b/kernel/cgroup/cgroup.c -@@ -1997,7 +1997,6 @@ static void init_cgroup_housekeeping(struct cgroup *cgrp) +@@ -2006,7 +2006,6 @@ static void init_cgroup_housekeeping(struct cgroup *cgrp) cgrp->dom_cgrp = cgrp; cgrp->max_descendants = INT_MAX; cgrp->max_depth = INT_MAX; @@ -13277,7 +13313,7 @@ index 62a7a5075014..59e107d22b2b 100644 prev_cputime_init(&cgrp->prev_cputime); for_each_subsys(ss, ssid) -@@ -5182,12 +5181,6 @@ static void css_release_work_fn(struct work_struct *work) +@@ -5191,12 +5190,6 @@ static void css_release_work_fn(struct work_struct *work) list_del_rcu(&css->sibling); if (ss) { @@ -13290,7 +13326,7 @@ index 62a7a5075014..59e107d22b2b 100644 cgroup_idr_replace(&ss->css_idr, NULL, css->id); if (ss->css_released) ss->css_released(css); -@@ -5249,7 +5242,6 @@ static void init_and_link_css(struct cgroup_subsys_state *css, +@@ -5258,7 +5251,6 @@ static void init_and_link_css(struct cgroup_subsys_state *css, css->id = -1; INIT_LIST_HEAD(&css->sibling); INIT_LIST_HEAD(&css->children); @@ -13298,7 +13334,7 @@ index 62a7a5075014..59e107d22b2b 100644 css->serial_nr = css_serial_nr_next++; atomic_set(&css->online_cnt, 0); -@@ -5258,9 +5250,6 @@ static void init_and_link_css(struct cgroup_subsys_state *css, +@@ -5267,9 +5259,6 @@ static void init_and_link_css(struct cgroup_subsys_state *css, css_get(css->parent); } @@ -13308,7 +13344,7 @@ index 62a7a5075014..59e107d22b2b 100644 BUG_ON(cgroup_css(cgrp, ss)); } -@@ -5362,7 +5351,6 @@ static struct cgroup_subsys_state *css_create(struct cgroup *cgrp, +@@ -5371,7 +5360,6 @@ static struct cgroup_subsys_state *css_create(struct cgroup *cgrp, err_list_del: list_del_rcu(&css->sibling); err_free_css: @@ -13317,10 +13353,10 @@ index 62a7a5075014..59e107d22b2b 100644 queue_rcu_work(cgroup_destroy_wq, &css->destroy_rwork); return ERR_PTR(err); diff --git a/kernel/cgroup/cpuset.c b/kernel/cgroup/cpuset.c -index 5d50ac2f2652..99266c15b4c0 100644 +index 807fc3fbd5ab..c333d1d86cf5 100644 --- a/kernel/cgroup/cpuset.c +++ b/kernel/cgroup/cpuset.c -@@ -346,7 +346,7 @@ void cpuset_read_unlock(void) +@@ -347,7 +347,7 @@ void cpuset_read_unlock(void) percpu_up_read(&cpuset_rwsem); } @@ -13329,7 +13365,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 static struct workqueue_struct *cpuset_migrate_mm_wq; -@@ -1287,7 +1287,7 @@ static int update_parent_subparts_cpumask(struct cpuset *cpuset, int cmd, +@@ -1288,7 +1288,7 @@ static int update_parent_subparts_cpumask(struct cpuset *cpuset, int cmd, * Newly added CPUs will be removed from effective_cpus and * newly deleted ones will be added back to effective_cpus. */ @@ -13338,7 +13374,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 if (adding) { cpumask_or(parent->subparts_cpus, parent->subparts_cpus, tmp->addmask); -@@ -1306,7 +1306,7 @@ static int update_parent_subparts_cpumask(struct cpuset *cpuset, int cmd, +@@ -1307,7 +1307,7 @@ static int update_parent_subparts_cpumask(struct cpuset *cpuset, int cmd, } parent->nr_subparts_cpus = cpumask_weight(parent->subparts_cpus); @@ -13347,7 +13383,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 return cmd == partcmd_update; } -@@ -1411,7 +1411,7 @@ static void update_cpumasks_hier(struct cpuset *cs, struct tmpmasks *tmp) +@@ -1412,7 +1412,7 @@ static void update_cpumasks_hier(struct cpuset *cs, struct tmpmasks *tmp) continue; rcu_read_unlock(); @@ -13356,7 +13392,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 cpumask_copy(cp->effective_cpus, tmp->new_cpus); if (cp->nr_subparts_cpus && -@@ -1442,7 +1442,7 @@ static void update_cpumasks_hier(struct cpuset *cs, struct tmpmasks *tmp) +@@ -1443,7 +1443,7 @@ static void update_cpumasks_hier(struct cpuset *cs, struct tmpmasks *tmp) = cpumask_weight(cp->subparts_cpus); } } @@ -13365,7 +13401,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 WARN_ON(!is_in_v2_mode() && !cpumask_equal(cp->cpus_allowed, cp->effective_cpus)); -@@ -1570,7 +1570,7 @@ static int update_cpumask(struct cpuset *cs, struct cpuset *trialcs, +@@ -1571,7 +1571,7 @@ static int update_cpumask(struct cpuset *cs, struct cpuset *trialcs, return -EINVAL; } @@ -13374,7 +13410,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 cpumask_copy(cs->cpus_allowed, trialcs->cpus_allowed); /* -@@ -1580,7 +1580,7 @@ static int update_cpumask(struct cpuset *cs, struct cpuset *trialcs, +@@ -1581,7 +1581,7 @@ static int update_cpumask(struct cpuset *cs, struct cpuset *trialcs, cpumask_and(cs->subparts_cpus, cs->subparts_cpus, cs->cpus_allowed); cs->nr_subparts_cpus = cpumask_weight(cs->subparts_cpus); } @@ -13383,7 +13419,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 update_cpumasks_hier(cs, &tmp); -@@ -1774,9 +1774,9 @@ static void update_nodemasks_hier(struct cpuset *cs, nodemask_t *new_mems) +@@ -1775,9 +1775,9 @@ static void update_nodemasks_hier(struct cpuset *cs, nodemask_t *new_mems) continue; rcu_read_unlock(); @@ -13395,7 +13431,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 WARN_ON(!is_in_v2_mode() && !nodes_equal(cp->mems_allowed, cp->effective_mems)); -@@ -1844,9 +1844,9 @@ static int update_nodemask(struct cpuset *cs, struct cpuset *trialcs, +@@ -1845,9 +1845,9 @@ static int update_nodemask(struct cpuset *cs, struct cpuset *trialcs, if (retval < 0) goto done; @@ -13407,7 +13443,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 /* use trialcs->mems_allowed as a temp variable */ update_nodemasks_hier(cs, &trialcs->mems_allowed); -@@ -1937,9 +1937,9 @@ static int update_flag(cpuset_flagbits_t bit, struct cpuset *cs, +@@ -1938,9 +1938,9 @@ static int update_flag(cpuset_flagbits_t bit, struct cpuset *cs, spread_flag_changed = ((is_spread_slab(cs) != is_spread_slab(trialcs)) || (is_spread_page(cs) != is_spread_page(trialcs))); @@ -13419,7 +13455,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 if (!cpumask_empty(trialcs->cpus_allowed) && balance_flag_changed) rebuild_sched_domains_locked(); -@@ -2448,7 +2448,7 @@ static int cpuset_common_seq_show(struct seq_file *sf, void *v) +@@ -2449,7 +2449,7 @@ static int cpuset_common_seq_show(struct seq_file *sf, void *v) cpuset_filetype_t type = seq_cft(sf)->private; int ret = 0; @@ -13428,7 +13464,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 switch (type) { case FILE_CPULIST: -@@ -2470,7 +2470,7 @@ static int cpuset_common_seq_show(struct seq_file *sf, void *v) +@@ -2471,7 +2471,7 @@ static int cpuset_common_seq_show(struct seq_file *sf, void *v) ret = -EINVAL; } @@ -13437,7 +13473,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 return ret; } -@@ -2783,14 +2783,14 @@ static int cpuset_css_online(struct cgroup_subsys_state *css) +@@ -2784,14 +2784,14 @@ static int cpuset_css_online(struct cgroup_subsys_state *css) cpuset_inc(); @@ -13454,7 +13490,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 if (!test_bit(CGRP_CPUSET_CLONE_CHILDREN, &css->cgroup->flags)) goto out_unlock; -@@ -2817,12 +2817,12 @@ static int cpuset_css_online(struct cgroup_subsys_state *css) +@@ -2818,12 +2818,12 @@ static int cpuset_css_online(struct cgroup_subsys_state *css) } rcu_read_unlock(); @@ -13469,7 +13505,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 out_unlock: percpu_up_write(&cpuset_rwsem); put_online_cpus(); -@@ -2878,7 +2878,7 @@ static void cpuset_css_free(struct cgroup_subsys_state *css) +@@ -2879,7 +2879,7 @@ static void cpuset_css_free(struct cgroup_subsys_state *css) static void cpuset_bind(struct cgroup_subsys_state *root_css) { percpu_down_write(&cpuset_rwsem); @@ -13478,7 +13514,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 if (is_in_v2_mode()) { cpumask_copy(top_cpuset.cpus_allowed, cpu_possible_mask); -@@ -2889,7 +2889,7 @@ static void cpuset_bind(struct cgroup_subsys_state *root_css) +@@ -2890,7 +2890,7 @@ static void cpuset_bind(struct cgroup_subsys_state *root_css) top_cpuset.mems_allowed = top_cpuset.effective_mems; } @@ -13487,7 +13523,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 percpu_up_write(&cpuset_rwsem); } -@@ -2986,12 +2986,12 @@ hotplug_update_tasks_legacy(struct cpuset *cs, +@@ -2987,12 +2987,12 @@ hotplug_update_tasks_legacy(struct cpuset *cs, { bool is_empty; @@ -13502,7 +13538,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 /* * Don't call update_tasks_cpumask() if the cpuset becomes empty, -@@ -3028,10 +3028,10 @@ hotplug_update_tasks(struct cpuset *cs, +@@ -3029,10 +3029,10 @@ hotplug_update_tasks(struct cpuset *cs, if (nodes_empty(*new_mems)) *new_mems = parent_cs(cs)->effective_mems; @@ -13515,7 +13551,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 if (cpus_updated) update_tasks_cpumask(cs); -@@ -3193,7 +3193,7 @@ static void cpuset_hotplug_workfn(struct work_struct *work) +@@ -3194,7 +3194,7 @@ static void cpuset_hotplug_workfn(struct work_struct *work) /* synchronize cpus_allowed to cpu_active_mask */ if (cpus_updated) { @@ -13524,7 +13560,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 if (!on_dfl) cpumask_copy(top_cpuset.cpus_allowed, &new_cpus); /* -@@ -3213,17 +3213,17 @@ static void cpuset_hotplug_workfn(struct work_struct *work) +@@ -3214,17 +3214,17 @@ static void cpuset_hotplug_workfn(struct work_struct *work) } } cpumask_copy(top_cpuset.effective_cpus, &new_cpus); @@ -13545,7 +13581,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 update_tasks_nodemask(&top_cpuset); } -@@ -3327,11 +3327,11 @@ void cpuset_cpus_allowed(struct task_struct *tsk, struct cpumask *pmask) +@@ -3328,11 +3328,11 @@ void cpuset_cpus_allowed(struct task_struct *tsk, struct cpumask *pmask) { unsigned long flags; @@ -13559,7 +13595,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 } /** -@@ -3392,11 +3392,11 @@ nodemask_t cpuset_mems_allowed(struct task_struct *tsk) +@@ -3393,11 +3393,11 @@ nodemask_t cpuset_mems_allowed(struct task_struct *tsk) nodemask_t mask; unsigned long flags; @@ -13573,7 +13609,7 @@ index 5d50ac2f2652..99266c15b4c0 100644 return mask; } -@@ -3488,14 +3488,14 @@ bool __cpuset_node_allowed(int node, gfp_t gfp_mask) +@@ -3489,14 +3489,14 @@ bool __cpuset_node_allowed(int node, gfp_t gfp_mask) return true; /* Not hardwall and node outside mems_allowed: scan up cpusets */ @@ -13693,7 +13729,7 @@ index 4a942d4e9763..49315054a1bc 100644 int cgroup_rstat_init(struct cgroup *cgrp) diff --git a/kernel/cpu.c b/kernel/cpu.c -index c08456af0c7f..cd0a0bfbd178 100644 +index ba579bb6b897..e9e807d2bd26 100644 --- a/kernel/cpu.c +++ b/kernel/cpu.c @@ -334,12 +334,12 @@ void lockdep_assert_cpus_held(void) @@ -13789,10 +13825,10 @@ index c08456af0c7f..cd0a0bfbd178 100644 irq_unlock_sparse(); diff --git a/kernel/events/core.c b/kernel/events/core.c -index 875b3c27eab0..7b332babac3a 100644 +index e1e546d742be..714385963f3c 100644 --- a/kernel/events/core.c +++ b/kernel/events/core.c -@@ -9005,7 +9005,6 @@ static void bpf_overflow_handler(struct perf_event *event, +@@ -9099,7 +9099,6 @@ static void bpf_overflow_handler(struct perf_event *event, int ret = 0; ctx.regs = perf_arch_bpf_user_pt_regs(regs); @@ -13800,7 +13836,7 @@ index 875b3c27eab0..7b332babac3a 100644 if (unlikely(__this_cpu_inc_return(bpf_prog_active) != 1)) goto out; rcu_read_lock(); -@@ -9013,7 +9012,6 @@ static void bpf_overflow_handler(struct perf_event *event, +@@ -9107,7 +9106,6 @@ static void bpf_overflow_handler(struct perf_event *event, rcu_read_unlock(); out: __this_cpu_dec(bpf_prog_active); @@ -13808,7 +13844,7 @@ index 875b3c27eab0..7b332babac3a 100644 if (!ret) return; -@@ -10305,7 +10303,7 @@ static struct pmu *perf_init_event(struct perf_event *event) +@@ -10413,7 +10411,7 @@ static struct pmu *perf_init_event(struct perf_event *event) goto unlock; } @@ -13818,7 +13854,7 @@ index 875b3c27eab0..7b332babac3a 100644 if (!ret) goto unlock; diff --git a/kernel/exit.c b/kernel/exit.c -index c764d16328f6..7dcf44e3636a 100644 +index 56d3a099825f..ec404c4dbcd4 100644 --- a/kernel/exit.c +++ b/kernel/exit.c @@ -208,7 +208,7 @@ static void __exit_signal(struct task_struct *tsk) @@ -14372,10 +14408,10 @@ index 45452facff3b..fa253e0db751 100644 obj-$(CONFIG_LOCK_TORTURE_TEST) += locktorture.o obj-$(CONFIG_WW_MUTEX_SELFTEST) += test-ww_mutex.o diff --git a/kernel/locking/lockdep.c b/kernel/locking/lockdep.c -index 0d9ff8b621e6..f5908f9d85a1 100644 +index 7cc790a262de..d3300ae01a37 100644 --- a/kernel/locking/lockdep.c +++ b/kernel/locking/lockdep.c -@@ -4531,6 +4531,7 @@ static void check_flags(unsigned long flags) +@@ -4548,6 +4548,7 @@ static void check_flags(unsigned long flags) } } @@ -14383,7 +14419,7 @@ index 0d9ff8b621e6..f5908f9d85a1 100644 /* * We dont accurately track softirq state in e.g. * hardirq contexts (such as on 4KSTACKS), so only -@@ -4545,6 +4546,7 @@ static void check_flags(unsigned long flags) +@@ -4562,6 +4563,7 @@ static void check_flags(unsigned long flags) DEBUG_LOCKS_WARN_ON(!current->softirqs_enabled); } } @@ -14925,7 +14961,7 @@ index 364d38a0c444..e4a4a56037bb 100644 /* * Once this completes (at least one RCU-sched grace period hence) the diff --git a/kernel/locking/rtmutex.c b/kernel/locking/rtmutex.c -index 734698aec5f9..b9895b574a57 100644 +index 7c727c4944e6..5bf60f282ea0 100644 --- a/kernel/locking/rtmutex.c +++ b/kernel/locking/rtmutex.c @@ -8,6 +8,11 @@ @@ -15587,7 +15623,7 @@ index 734698aec5f9..b9895b574a57 100644 if (ret) break; } -@@ -1223,33 +1631,104 @@ static void rt_mutex_handle_deadlock(int res, int detect_deadlock, +@@ -1225,33 +1633,104 @@ static void rt_mutex_handle_deadlock(int res, int detect_deadlock, } } @@ -15711,7 +15747,7 @@ index 734698aec5f9..b9895b574a57 100644 return 0; } -@@ -1259,16 +1738,26 @@ rt_mutex_slowlock(struct rt_mutex *lock, int state, +@@ -1261,16 +1740,26 @@ rt_mutex_slowlock(struct rt_mutex *lock, int state, if (unlikely(timeout)) hrtimer_start_expires(&timeout->timer, HRTIMER_MODE_ABS); @@ -15733,17 +15769,17 @@ index 734698aec5f9..b9895b574a57 100644 if (unlikely(ret)) { __set_current_state(TASK_RUNNING); - remove_waiter(lock, &waiter); -- rt_mutex_handle_deadlock(ret, chwalk, &waiter); +- rt_mutex_handle_deadlock(ret, chwalk, lock, &waiter); + remove_waiter(lock, waiter); + /* ww_mutex wants to report EDEADLK/EALREADY, let it */ + if (!ww_ctx) -+ rt_mutex_handle_deadlock(ret, chwalk, waiter); ++ rt_mutex_handle_deadlock(ret, chwalk, lock, waiter); + } else if (ww_ctx) { + ww_mutex_account_lock(lock, ww_ctx); } /* -@@ -1276,6 +1765,36 @@ rt_mutex_slowlock(struct rt_mutex *lock, int state, +@@ -1278,6 +1767,36 @@ rt_mutex_slowlock(struct rt_mutex *lock, int state, * unconditionally. We might have to fix that up. */ fixup_rt_mutex_waiters(lock); @@ -15780,7 +15816,7 @@ index 734698aec5f9..b9895b574a57 100644 raw_spin_unlock_irqrestore(&lock->wait_lock, flags); -@@ -1336,7 +1855,8 @@ static inline int rt_mutex_slowtrylock(struct rt_mutex *lock) +@@ -1338,7 +1857,8 @@ static inline int rt_mutex_slowtrylock(struct rt_mutex *lock) * Return whether the current task needs to call rt_mutex_postunlock(). */ static bool __sched rt_mutex_slowunlock(struct rt_mutex *lock, @@ -15790,7 +15826,7 @@ index 734698aec5f9..b9895b574a57 100644 { unsigned long flags; -@@ -1390,7 +1910,7 @@ static bool __sched rt_mutex_slowunlock(struct rt_mutex *lock, +@@ -1392,7 +1912,7 @@ static bool __sched rt_mutex_slowunlock(struct rt_mutex *lock, * * Queue the next waiter for wakeup once we release the wait_lock. */ @@ -15799,7 +15835,7 @@ index 734698aec5f9..b9895b574a57 100644 raw_spin_unlock_irqrestore(&lock->wait_lock, flags); return true; /* call rt_mutex_postunlock() */ -@@ -1404,29 +1924,45 @@ static bool __sched rt_mutex_slowunlock(struct rt_mutex *lock, +@@ -1406,29 +1926,45 @@ static bool __sched rt_mutex_slowunlock(struct rt_mutex *lock, */ static inline int rt_mutex_fastlock(struct rt_mutex *lock, int state, @@ -15849,7 +15885,7 @@ index 734698aec5f9..b9895b574a57 100644 } static inline int -@@ -1442,9 +1978,11 @@ rt_mutex_fasttrylock(struct rt_mutex *lock, +@@ -1444,9 +1980,11 @@ rt_mutex_fasttrylock(struct rt_mutex *lock, /* * Performs the wakeup of the the top-waiter and re-enables preemption. */ @@ -15862,7 +15898,7 @@ index 734698aec5f9..b9895b574a57 100644 /* Pairs with preempt_disable() in rt_mutex_slowunlock() */ preempt_enable(); -@@ -1453,23 +1991,46 @@ void rt_mutex_postunlock(struct wake_q_head *wake_q) +@@ -1455,23 +1993,46 @@ void rt_mutex_postunlock(struct wake_q_head *wake_q) static inline void rt_mutex_fastunlock(struct rt_mutex *lock, bool (*slowfn)(struct rt_mutex *lock, @@ -15914,7 +15950,7 @@ index 734698aec5f9..b9895b574a57 100644 } #ifdef CONFIG_DEBUG_LOCK_ALLOC -@@ -1510,16 +2071,7 @@ EXPORT_SYMBOL_GPL(rt_mutex_lock); +@@ -1512,16 +2073,7 @@ EXPORT_SYMBOL_GPL(rt_mutex_lock); */ int __sched rt_mutex_lock_interruptible(struct rt_mutex *lock) { @@ -15932,7 +15968,7 @@ index 734698aec5f9..b9895b574a57 100644 } EXPORT_SYMBOL_GPL(rt_mutex_lock_interruptible); -@@ -1536,6 +2088,22 @@ int __sched __rt_mutex_futex_trylock(struct rt_mutex *lock) +@@ -1538,6 +2090,22 @@ int __sched __rt_mutex_futex_trylock(struct rt_mutex *lock) return __rt_mutex_slowtrylock(lock); } @@ -15955,7 +15991,7 @@ index 734698aec5f9..b9895b574a57 100644 /** * rt_mutex_timed_lock - lock a rt_mutex interruptible * the timeout structure is provided -@@ -1559,6 +2127,7 @@ rt_mutex_timed_lock(struct rt_mutex *lock, struct hrtimer_sleeper *timeout) +@@ -1561,6 +2129,7 @@ rt_mutex_timed_lock(struct rt_mutex *lock, struct hrtimer_sleeper *timeout) mutex_acquire(&lock->dep_map, 0, 0, _RET_IP_); ret = rt_mutex_timed_fastlock(lock, TASK_INTERRUPTIBLE, timeout, RT_MUTEX_MIN_CHAINWALK, @@ -15963,7 +15999,7 @@ index 734698aec5f9..b9895b574a57 100644 rt_mutex_slowlock); if (ret) mutex_release(&lock->dep_map, 1, _RET_IP_); -@@ -1567,6 +2136,18 @@ rt_mutex_timed_lock(struct rt_mutex *lock, struct hrtimer_sleeper *timeout) +@@ -1569,6 +2138,18 @@ rt_mutex_timed_lock(struct rt_mutex *lock, struct hrtimer_sleeper *timeout) } EXPORT_SYMBOL_GPL(rt_mutex_timed_lock); @@ -15982,7 +16018,7 @@ index 734698aec5f9..b9895b574a57 100644 /** * rt_mutex_trylock - try to lock a rt_mutex * -@@ -1582,10 +2163,7 @@ int __sched rt_mutex_trylock(struct rt_mutex *lock) +@@ -1584,10 +2165,7 @@ int __sched rt_mutex_trylock(struct rt_mutex *lock) { int ret; @@ -15994,7 +16030,7 @@ index 734698aec5f9..b9895b574a57 100644 if (ret) mutex_acquire(&lock->dep_map, 0, 1, _RET_IP_); -@@ -1593,6 +2171,11 @@ int __sched rt_mutex_trylock(struct rt_mutex *lock) +@@ -1595,6 +2173,11 @@ int __sched rt_mutex_trylock(struct rt_mutex *lock) } EXPORT_SYMBOL_GPL(rt_mutex_trylock); @@ -16006,7 +16042,7 @@ index 734698aec5f9..b9895b574a57 100644 /** * rt_mutex_unlock - unlock a rt_mutex * -@@ -1601,16 +2184,13 @@ EXPORT_SYMBOL_GPL(rt_mutex_trylock); +@@ -1603,16 +2186,13 @@ EXPORT_SYMBOL_GPL(rt_mutex_trylock); void __sched rt_mutex_unlock(struct rt_mutex *lock) { mutex_release(&lock->dep_map, 1, _RET_IP_); @@ -16027,7 +16063,7 @@ index 734698aec5f9..b9895b574a57 100644 { lockdep_assert_held(&lock->wait_lock); -@@ -1627,23 +2207,35 @@ bool __sched __rt_mutex_futex_unlock(struct rt_mutex *lock, +@@ -1629,23 +2209,35 @@ bool __sched __rt_mutex_futex_unlock(struct rt_mutex *lock, * avoid inversion prior to the wakeup. preempt_disable() * therein pairs with rt_mutex_postunlock(). */ @@ -16066,7 +16102,7 @@ index 734698aec5f9..b9895b574a57 100644 } /** -@@ -1682,7 +2274,7 @@ void __rt_mutex_init(struct rt_mutex *lock, const char *name, +@@ -1684,7 +2276,7 @@ void __rt_mutex_init(struct rt_mutex *lock, const char *name, if (name && key) debug_rt_mutex_init(lock, name, key); } @@ -16075,7 +16111,7 @@ index 734698aec5f9..b9895b574a57 100644 /** * rt_mutex_init_proxy_locked - initialize and lock a rt_mutex on behalf of a -@@ -1702,6 +2294,14 @@ void rt_mutex_init_proxy_locked(struct rt_mutex *lock, +@@ -1704,6 +2296,14 @@ void rt_mutex_init_proxy_locked(struct rt_mutex *lock, struct task_struct *proxy_owner) { __rt_mutex_init(lock, NULL, NULL); @@ -16090,7 +16126,7 @@ index 734698aec5f9..b9895b574a57 100644 debug_rt_mutex_proxy_lock(lock, proxy_owner); rt_mutex_set_owner(lock, proxy_owner); } -@@ -1724,6 +2324,26 @@ void rt_mutex_proxy_unlock(struct rt_mutex *lock) +@@ -1726,6 +2326,26 @@ void rt_mutex_proxy_unlock(struct rt_mutex *lock) rt_mutex_set_owner(lock, NULL); } @@ -16117,7 +16153,7 @@ index 734698aec5f9..b9895b574a57 100644 /** * __rt_mutex_start_proxy_lock() - Start lock acquisition for another task * @lock: the rt_mutex to take -@@ -1754,6 +2374,34 @@ int __rt_mutex_start_proxy_lock(struct rt_mutex *lock, +@@ -1756,6 +2376,34 @@ int __rt_mutex_start_proxy_lock(struct rt_mutex *lock, if (try_to_take_rt_mutex(lock, task, NULL)) return 1; @@ -16152,7 +16188,7 @@ index 734698aec5f9..b9895b574a57 100644 /* We enforce deadlock detection for futexes */ ret = task_blocks_on_rt_mutex(lock, waiter, task, RT_MUTEX_FULL_CHAINWALK); -@@ -1768,6 +2416,9 @@ int __rt_mutex_start_proxy_lock(struct rt_mutex *lock, +@@ -1770,6 +2418,9 @@ int __rt_mutex_start_proxy_lock(struct rt_mutex *lock, ret = 0; } @@ -16162,7 +16198,7 @@ index 734698aec5f9..b9895b574a57 100644 debug_rt_mutex_print_deadlock(waiter); return ret; -@@ -1853,12 +2504,15 @@ int rt_mutex_wait_proxy_lock(struct rt_mutex *lock, +@@ -1855,12 +2506,15 @@ int rt_mutex_wait_proxy_lock(struct rt_mutex *lock, raw_spin_lock_irq(&lock->wait_lock); /* sleep on the mutex */ set_current_state(TASK_INTERRUPTIBLE); @@ -16179,7 +16215,7 @@ index 734698aec5f9..b9895b574a57 100644 raw_spin_unlock_irq(&lock->wait_lock); return ret; -@@ -1920,3 +2574,99 @@ bool rt_mutex_cleanup_proxy_lock(struct rt_mutex *lock, +@@ -1922,3 +2576,99 @@ bool rt_mutex_cleanup_proxy_lock(struct rt_mutex *lock, return cleanup; } @@ -17210,7 +17246,7 @@ index 472dd462a40c..82915146c92c 100644 + +#endif diff --git a/kernel/panic.c b/kernel/panic.c -index cef79466f941..820da9858417 100644 +index 5559a6e4c457..c84ea2b05d21 100644 --- a/kernel/panic.c +++ b/kernel/panic.c @@ -301,7 +301,6 @@ void panic(const char *fmt, ...) @@ -17230,7 +17266,7 @@ index cef79466f941..820da9858417 100644 kmsg_dump(KMSG_DUMP_PANIC); /* -@@ -588,9 +585,11 @@ static u64 oops_id; +@@ -596,9 +593,11 @@ static u64 oops_id; static int init_oops_id(void) { @@ -17330,7 +17366,7 @@ index b2b0f526f249..000000000000 -static inline bool printk_percpu_data_ready(void) { return false; } -#endif /* CONFIG_PRINTK */ diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c -index bb2198b40756..012d07cbabc6 100644 +index ae1a97dd0c3c..012d07cbabc6 100644 --- a/kernel/printk/printk.c +++ b/kernel/printk/printk.c @@ -45,6 +45,9 @@ @@ -18533,7 +18569,7 @@ index bb2198b40756..012d07cbabc6 100644 return error; } -@@ -1650,144 +1659,128 @@ SYSCALL_DEFINE3(syslog, int, type, char __user *, buf, int, len) +@@ -1650,150 +1659,128 @@ SYSCALL_DEFINE3(syslog, int, type, char __user *, buf, int, len) return do_syslog(type, buf, len, SYSLOG_FROM_READER); } @@ -18756,11 +18792,16 @@ index bb2198b40756..012d07cbabc6 100644 + con->printk_seq = seq; + } -- return 1; +- /* +- * Update @console_may_schedule for trylock because the previous +- * owner may have been schedulable. +- */ +- console_may_schedule = 0; + msg = (struct printk_log *)buf; + format_text(msg, master_seq, ext_text, &ext_len, text, + &len, time); -+ + +- return 1; + if (len == 0 && ext_len == 0) + continue; + @@ -18779,7 +18820,7 @@ index bb2198b40756..012d07cbabc6 100644 } /* -@@ -1795,8 +1788,9 @@ static int console_trylock_spinning(void) +@@ -1801,8 +1788,9 @@ static int console_trylock_spinning(void) * log_buf[start] to log_buf[end - 1]. * The console_lock must be held. */ @@ -18791,7 +18832,7 @@ index bb2198b40756..012d07cbabc6 100644 { struct console *con; -@@ -1806,15 +1800,40 @@ static void call_console_drivers(const char *ext_text, size_t ext_len, +@@ -1812,15 +1800,40 @@ static void call_console_drivers(const char *ext_text, size_t ext_len, return; for_each_console(con) { @@ -18835,7 +18876,7 @@ index bb2198b40756..012d07cbabc6 100644 if (con->flags & CON_EXTENDED) con->write(con, ext_text, ext_len); else -@@ -1822,20 +1841,6 @@ static void call_console_drivers(const char *ext_text, size_t ext_len, +@@ -1828,20 +1841,6 @@ static void call_console_drivers(const char *ext_text, size_t ext_len, } } @@ -18856,7 +18897,7 @@ index bb2198b40756..012d07cbabc6 100644 static inline u32 printk_caller_id(void) { return in_task() ? task_pid_nr(current) : -@@ -1852,101 +1857,95 @@ static struct cont { +@@ -1858,101 +1857,95 @@ static struct cont { char buf[LOG_LINE_MAX]; size_t len; /* length == 0 means unused buffer */ u32 caller_id; /* printk_caller_id() of first print */ @@ -19014,7 +19055,7 @@ index bb2198b40756..012d07cbabc6 100644 if (text_len && text[text_len-1] == '\n') { text_len--; lflags |= LOG_NEWLINE; -@@ -1977,62 +1976,37 @@ int vprintk_store(int facility, int level, +@@ -1983,62 +1976,37 @@ int vprintk_store(int facility, int level, if (dict) lflags |= LOG_NEWLINE; @@ -19100,7 +19141,7 @@ index bb2198b40756..012d07cbabc6 100644 asmlinkage int vprintk(const char *fmt, va_list args) { return vprintk_func(fmt, args); -@@ -2089,39 +2063,6 @@ asmlinkage __visible int printk(const char *fmt, ...) +@@ -2095,39 +2063,6 @@ asmlinkage __visible int printk(const char *fmt, ...) return r; } EXPORT_SYMBOL(printk); @@ -19140,7 +19181,7 @@ index bb2198b40756..012d07cbabc6 100644 #endif /* CONFIG_PRINTK */ #ifdef CONFIG_EARLY_PRINTK -@@ -2362,187 +2303,23 @@ int is_console_locked(void) +@@ -2368,187 +2303,23 @@ int is_console_locked(void) } EXPORT_SYMBOL(is_console_locked); @@ -19328,7 +19369,7 @@ index bb2198b40756..012d07cbabc6 100644 } EXPORT_SYMBOL(console_unlock); -@@ -2593,24 +2370,10 @@ void console_unblank(void) +@@ -2599,24 +2370,10 @@ void console_unblank(void) void console_flush_on_panic(enum con_flush_mode mode) { /* @@ -19356,7 +19397,7 @@ index bb2198b40756..012d07cbabc6 100644 } /* -@@ -2688,7 +2451,6 @@ early_param("keep_bootcon", keep_bootcon_setup); +@@ -2694,7 +2451,6 @@ early_param("keep_bootcon", keep_bootcon_setup); void register_console(struct console *newcon) { int i; @@ -19364,7 +19405,7 @@ index bb2198b40756..012d07cbabc6 100644 struct console *bcon = NULL; struct console_cmdline *c; static bool has_preferred; -@@ -2804,27 +2566,6 @@ void register_console(struct console *newcon) +@@ -2810,27 +2566,6 @@ void register_console(struct console *newcon) if (newcon->flags & CON_EXTENDED) nr_ext_console_drivers++; @@ -19392,7 +19433,7 @@ index bb2198b40756..012d07cbabc6 100644 console_unlock(); console_sysfs_notify(); -@@ -2834,6 +2575,10 @@ void register_console(struct console *newcon) +@@ -2840,6 +2575,10 @@ void register_console(struct console *newcon) * boot consoles, real consoles, etc - this is to ensure that end * users know there might be something in the kernel's log buffer that * went to the bootconsole (that they do not see on the real console) @@ -19403,7 +19444,7 @@ index bb2198b40756..012d07cbabc6 100644 */ pr_info("%sconsole [%s%d] enabled\n", (newcon->flags & CON_BOOT) ? "boot" : "" , -@@ -2977,65 +2722,75 @@ static int __init printk_late_init(void) +@@ -2983,65 +2722,75 @@ static int __init printk_late_init(void) late_initcall(printk_late_init); #if defined CONFIG_PRINTK @@ -19524,7 +19565,7 @@ index bb2198b40756..012d07cbabc6 100644 } int printk_deferred(const char *fmt, ...) -@@ -3157,8 +2912,8 @@ module_param_named(always_kmsg_dump, always_kmsg_dump, bool, S_IRUGO | S_IWUSR); +@@ -3163,8 +2912,8 @@ module_param_named(always_kmsg_dump, always_kmsg_dump, bool, S_IRUGO | S_IWUSR); */ void kmsg_dump(enum kmsg_dump_reason reason) { @@ -19534,7 +19575,7 @@ index bb2198b40756..012d07cbabc6 100644 if ((reason > KMSG_DUMP_OOPS) && !always_kmsg_dump) return; -@@ -3168,21 +2923,18 @@ void kmsg_dump(enum kmsg_dump_reason reason) +@@ -3174,21 +2923,18 @@ void kmsg_dump(enum kmsg_dump_reason reason) if (dumper->max_reason && reason > dumper->max_reason) continue; @@ -19565,7 +19606,7 @@ index bb2198b40756..012d07cbabc6 100644 } rcu_read_unlock(); } -@@ -3209,33 +2961,67 @@ void kmsg_dump(enum kmsg_dump_reason reason) +@@ -3215,33 +2961,67 @@ void kmsg_dump(enum kmsg_dump_reason reason) bool kmsg_dump_get_line_nolock(struct kmsg_dumper *dumper, bool syslog, char *line, size_t size, size_t *len) { @@ -19648,7 +19689,7 @@ index bb2198b40756..012d07cbabc6 100644 } /** -@@ -3258,12 +3044,9 @@ bool kmsg_dump_get_line_nolock(struct kmsg_dumper *dumper, bool syslog, +@@ -3264,12 +3044,9 @@ bool kmsg_dump_get_line_nolock(struct kmsg_dumper *dumper, bool syslog, bool kmsg_dump_get_line(struct kmsg_dumper *dumper, bool syslog, char *line, size_t size, size_t *len) { @@ -19661,7 +19702,7 @@ index bb2198b40756..012d07cbabc6 100644 return ret; } -@@ -3291,74 +3074,101 @@ EXPORT_SYMBOL_GPL(kmsg_dump_get_line); +@@ -3297,74 +3074,101 @@ EXPORT_SYMBOL_GPL(kmsg_dump_get_line); bool kmsg_dump_get_buffer(struct kmsg_dumper *dumper, bool syslog, char *buf, size_t size, size_t *len) { @@ -19815,7 +19856,7 @@ index bb2198b40756..012d07cbabc6 100644 } EXPORT_SYMBOL_GPL(kmsg_dump_get_buffer); -@@ -3374,10 +3184,8 @@ EXPORT_SYMBOL_GPL(kmsg_dump_get_buffer); +@@ -3380,10 +3184,8 @@ EXPORT_SYMBOL_GPL(kmsg_dump_get_buffer); */ void kmsg_dump_rewind_nolock(struct kmsg_dumper *dumper) { @@ -19828,7 +19869,7 @@ index bb2198b40756..012d07cbabc6 100644 } /** -@@ -3390,12 +3198,89 @@ void kmsg_dump_rewind_nolock(struct kmsg_dumper *dumper) +@@ -3396,12 +3198,89 @@ void kmsg_dump_rewind_nolock(struct kmsg_dumper *dumper) */ void kmsg_dump_rewind(struct kmsg_dumper *dumper) { @@ -20426,7 +20467,7 @@ index 7644eda17d62..4d84057d9d1c 100644 between each callback, and (2) affinity or cgroups can be used to force the kthreads to run on whatever set of CPUs is desired. diff --git a/kernel/rcu/rcutorture.c b/kernel/rcu/rcutorture.c -index 3c9feca1eab1..a90d6981e1e4 100644 +index aef4d01c4f61..78abe10f89fa 100644 --- a/kernel/rcu/rcutorture.c +++ b/kernel/rcu/rcutorture.c @@ -60,10 +60,13 @@ MODULE_AUTHOR("Paul E. McKenney <paulmck@linux.ibm.com> and Josh Triplett <josh@ @@ -20573,7 +20614,7 @@ index 3c9feca1eab1..a90d6981e1e4 100644 return mask ?: RCUTORTURE_RDR_RCU; } -@@ -1725,7 +1793,7 @@ static void rcu_torture_fwd_cb_cr(struct rcu_head *rhp) +@@ -1726,7 +1794,7 @@ static void rcu_torture_fwd_cb_cr(struct rcu_head *rhp) // Give the scheduler a chance, even on nohz_full CPUs. static void rcu_torture_fwd_prog_cond_resched(unsigned long iter) { @@ -21728,7 +21769,7 @@ index e83a3f8449f6..c56c315524ae 100644 wait->task = current; if (list_empty(&wait->task_list)) diff --git a/kernel/sched/topology.c b/kernel/sched/topology.c -index e5ebaffc4fef..6b4b8c517a58 100644 +index fc0dcc812a07..6a529e541181 100644 --- a/kernel/sched/topology.c +++ b/kernel/sched/topology.c @@ -502,6 +502,7 @@ static int init_rootdomain(struct root_domain *rd) @@ -21762,7 +21803,7 @@ index b2e1981663b8..1071a1a59675 100644 } #endif /* CONFIG_SECCOMP_FILTER */ diff --git a/kernel/signal.c b/kernel/signal.c -index 1f4293a107b4..4ed9cbe27829 100644 +index fae5a2adc9ec..537db1f102e8 100644 --- a/kernel/signal.c +++ b/kernel/signal.c @@ -20,6 +20,7 @@ @@ -21938,7 +21979,7 @@ index 1f4293a107b4..4ed9cbe27829 100644 if (q) q->flags |= SIGQUEUE_PREALLOC; -@@ -2197,16 +2286,8 @@ static void ptrace_stop(int exit_code, int why, int clear_code, kernel_siginfo_t +@@ -2200,16 +2289,8 @@ static void ptrace_stop(int exit_code, int why, int clear_code, kernel_siginfo_t if (gstop_done && ptrace_reparented(current)) do_notify_parent_cldstop(current, false, why); @@ -21956,7 +21997,7 @@ index 1f4293a107b4..4ed9cbe27829 100644 cgroup_leave_frozen(true); } else { diff --git a/kernel/smp.c b/kernel/smp.c -index be65b76cb803..8ae9476edaf9 100644 +index 76de88dc1699..accf6678dc26 100644 --- a/kernel/smp.c +++ b/kernel/smp.c @@ -395,22 +395,9 @@ int smp_call_function_any(const struct cpumask *mask, @@ -22484,7 +22525,7 @@ index 998d50ee2d9b..9112fc79d24b 100644 wake_up_q(&wakeq); diff --git a/kernel/sysctl.c b/kernel/sysctl.c -index 4f85f7ed42fc..bd725084a173 100644 +index 865e539c7354..e9cfab0576d8 100644 --- a/kernel/sysctl.c +++ b/kernel/sysctl.c @@ -212,6 +212,11 @@ static int proc_do_cad_pid(struct ctl_table *table, int write, @@ -22499,7 +22540,7 @@ index 4f85f7ed42fc..bd725084a173 100644 #endif #ifdef CONFIG_PRINTK -@@ -1524,7 +1529,7 @@ static struct ctl_table vm_table[] = { +@@ -1528,7 +1533,7 @@ static struct ctl_table vm_table[] = { .data = &sysctl_compact_unevictable_allowed, .maxlen = sizeof(int), .mode = 0644, @@ -22508,7 +22549,7 @@ index 4f85f7ed42fc..bd725084a173 100644 .extra1 = SYSCTL_ZERO, .extra2 = SYSCTL_ONE, }, -@@ -2620,6 +2625,28 @@ int proc_dointvec(struct ctl_table *table, int write, +@@ -2624,6 +2629,28 @@ int proc_dointvec(struct ctl_table *table, int write, return do_proc_dointvec(table, write, buffer, lenp, ppos, NULL, NULL); } @@ -22538,10 +22579,10 @@ index 4f85f7ed42fc..bd725084a173 100644 * proc_douintvec - read a vector of unsigned integers * @table: the sysctl table diff --git a/kernel/time/hrtimer.c b/kernel/time/hrtimer.c -index 8e3c9228aec9..d6924b6eaf94 100644 +index 2e4f136bdf6a..d2827aaf256f 100644 --- a/kernel/time/hrtimer.c +++ b/kernel/time/hrtimer.c -@@ -2048,6 +2048,38 @@ SYSCALL_DEFINE2(nanosleep_time32, struct old_timespec32 __user *, rqtp, +@@ -2051,6 +2051,38 @@ SYSCALL_DEFINE2(nanosleep_time32, struct old_timespec32 __user *, rqtp, } #endif @@ -22910,7 +22951,7 @@ index eacb0ca30193..4cdcdf7382b1 100644 const struct k_clock clock_process = { diff --git a/kernel/time/tick-sched.c b/kernel/time/tick-sched.c -index 5093cff93273..422f24bcb262 100644 +index c7b9b1e4af7d..ff695f5e6a4a 100644 --- a/kernel/time/tick-sched.c +++ b/kernel/time/tick-sched.c @@ -273,6 +273,7 @@ static void nohz_full_kick_func(struct irq_work *work) @@ -22938,10 +22979,10 @@ index 5093cff93273..422f24bcb262 100644 } diff --git a/kernel/time/timer.c b/kernel/time/timer.c -index 16a2b62f5f74..86bb218d1df5 100644 +index 6e2dd83a93af..fb4028464dae 100644 --- a/kernel/time/timer.c +++ b/kernel/time/timer.c -@@ -1291,7 +1291,7 @@ static void del_timer_wait_running(struct timer_list *timer) +@@ -1320,7 +1320,7 @@ static void del_timer_wait_running(struct timer_list *timer) u32 tf; tf = READ_ONCE(timer->flags); @@ -22950,7 +22991,7 @@ index 16a2b62f5f74..86bb218d1df5 100644 struct timer_base *base = get_timer_base(tf); /* -@@ -1375,6 +1375,13 @@ int del_timer_sync(struct timer_list *timer) +@@ -1406,6 +1406,13 @@ int timer_delete_sync(struct timer_list *timer) */ WARN_ON(in_irq() && !(timer->flags & TIMER_IRQSAFE)); @@ -22964,7 +23005,7 @@ index 16a2b62f5f74..86bb218d1df5 100644 do { ret = try_to_del_timer_sync(timer); -@@ -1797,6 +1804,8 @@ static __latent_entropy void run_timer_softirq(struct softirq_action *h) +@@ -1827,6 +1834,8 @@ static __latent_entropy void run_timer_softirq(struct softirq_action *h) { struct timer_base *base = this_cpu_ptr(&timer_bases[BASE_STD]); @@ -23011,10 +23052,10 @@ index 4a31763a8c5d..acac5941f825 100644 } diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c -index f9c64329ec15..14dd4bf0821e 100644 +index d084334193bd..e06eb46cdc18 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c -@@ -2381,6 +2381,7 @@ tracing_generic_entry_update(struct trace_entry *entry, unsigned short type, +@@ -2393,6 +2393,7 @@ tracing_generic_entry_update(struct trace_entry *entry, unsigned short type, struct task_struct *tsk = current; entry->preempt_count = pc & 0xff; @@ -23022,7 +23063,7 @@ index f9c64329ec15..14dd4bf0821e 100644 entry->pid = (tsk) ? tsk->pid : 0; entry->type = type; entry->flags = -@@ -2392,8 +2393,11 @@ tracing_generic_entry_update(struct trace_entry *entry, unsigned short type, +@@ -2404,8 +2405,11 @@ tracing_generic_entry_update(struct trace_entry *entry, unsigned short type, ((pc & NMI_MASK ) ? TRACE_FLAG_NMI : 0) | ((pc & HARDIRQ_MASK) ? TRACE_FLAG_HARDIRQ : 0) | ((pc & SOFTIRQ_OFFSET) ? TRACE_FLAG_SOFTIRQ : 0) | @@ -23035,7 +23076,7 @@ index f9c64329ec15..14dd4bf0821e 100644 } EXPORT_SYMBOL_GPL(tracing_generic_entry_update); -@@ -3631,9 +3635,11 @@ static void print_lat_help_header(struct seq_file *m) +@@ -3644,9 +3648,11 @@ static void print_lat_help_header(struct seq_file *m) "# | / _----=> need-resched \n" "# || / _---=> hardirq/softirq \n" "# ||| / _--=> preempt-depth \n" @@ -23050,7 +23091,7 @@ index f9c64329ec15..14dd4bf0821e 100644 } static void print_event_info(struct trace_buffer *buf, struct seq_file *m) -@@ -3669,11 +3675,12 @@ static void print_func_help_header_irq(struct trace_buffer *buf, struct seq_file +@@ -3682,11 +3688,12 @@ static void print_func_help_header_irq(struct trace_buffer *buf, struct seq_file seq_printf(m, "# %.*s _-----=> irqs-off\n", prec, space); seq_printf(m, "# %.*s / _----=> need-resched\n", prec, space); @@ -23068,7 +23109,7 @@ index f9c64329ec15..14dd4bf0821e 100644 } void -@@ -3707,6 +3714,8 @@ print_trace_header(struct seq_file *m, struct trace_iterator *iter) +@@ -3720,6 +3727,8 @@ print_trace_header(struct seq_file *m, struct trace_iterator *iter) "desktop", #elif defined(CONFIG_PREEMPT) "preempt", @@ -23077,7 +23118,7 @@ index f9c64329ec15..14dd4bf0821e 100644 #else "unknown", #endif -@@ -9060,7 +9069,6 @@ void ftrace_dump(enum ftrace_dump_mode oops_dump_mode) +@@ -9106,7 +9115,6 @@ void ftrace_dump(enum ftrace_dump_mode oops_dump_mode) tracing_off(); local_irq_save(flags); @@ -23085,7 +23126,7 @@ index f9c64329ec15..14dd4bf0821e 100644 /* Simulate the iterator */ trace_init_global_iter(&iter); -@@ -9137,7 +9145,6 @@ void ftrace_dump(enum ftrace_dump_mode oops_dump_mode) +@@ -9183,7 +9191,6 @@ void ftrace_dump(enum ftrace_dump_mode oops_dump_mode) atomic_dec(&per_cpu_ptr(iter.trace_buffer->data, cpu)->disabled); } atomic_dec(&dump_running); @@ -23094,7 +23135,7 @@ index f9c64329ec15..14dd4bf0821e 100644 } EXPORT_SYMBOL_GPL(ftrace_dump); diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h -index 21f85c0bd66e..6e03a12ca072 100644 +index 40644e06536c..8a6108edeaaf 100644 --- a/kernel/trace/trace.h +++ b/kernel/trace/trace.h @@ -126,6 +126,7 @@ struct kretprobe_trace_entry_head { @@ -23114,7 +23155,7 @@ index 21f85c0bd66e..6e03a12ca072 100644 #define TRACE_BUF_SIZE 1024 diff --git a/kernel/trace/trace_events.c b/kernel/trace/trace_events.c -index 0c21da12b650..df193197f563 100644 +index 958789fe4cef..3b2b2eac5d10 100644 --- a/kernel/trace/trace_events.c +++ b/kernel/trace/trace_events.c @@ -182,6 +182,8 @@ static int trace_define_common_fields(void) @@ -23230,7 +23271,7 @@ index 8e8551c8b285..8ca917f2cf0b 100644 EXPORT_SYMBOL(on_each_cpu_cond); diff --git a/kernel/workqueue.c b/kernel/workqueue.c -index 856188b0681a..c97f71fa613f 100644 +index a2c4de2a1132..c6409f1374ce 100644 --- a/kernel/workqueue.c +++ b/kernel/workqueue.c @@ -146,7 +146,7 @@ enum { @@ -24014,10 +24055,10 @@ index 8be59f84eaea..c6e083323d1b 100644 } } diff --git a/lib/debugobjects.c b/lib/debugobjects.c -index b0e4301d7495..c364470efbcb 100644 +index 358449383720..2669fd8416fb 100644 --- a/lib/debugobjects.c +++ b/lib/debugobjects.c -@@ -590,7 +590,10 @@ __debug_object_init(void *addr, struct debug_obj_descr *descr, int onstack) +@@ -591,7 +591,10 @@ __debug_object_init(void *addr, struct debug_obj_descr *descr, int onstack) struct debug_obj *obj; unsigned long flags; @@ -24994,7 +25035,7 @@ index fbdc5c70e487..55f540359c70 100644 select XARRAY_MULTI help diff --git a/mm/compaction.c b/mm/compaction.c -index 7a2675dbf3cc..41753103b3de 100644 +index 138edfa834b9..be1666ef7bab 100644 --- a/mm/compaction.c +++ b/mm/compaction.c @@ -1583,7 +1583,11 @@ typedef enum { @@ -25431,7 +25472,7 @@ index d8cde7292bf9..4ee0dde910fd 100644 rcu_read_unlock(); diff --git a/mm/memcontrol.c b/mm/memcontrol.c -index 0140629b7cb2..def119639f70 100644 +index 5ac119509335..2c48edaa1827 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c @@ -63,6 +63,7 @@ @@ -25467,7 +25508,7 @@ index 0140629b7cb2..def119639f70 100644 } void __mod_lruvec_slab_state(void *p, enum node_stat_item idx, int val) -@@ -2283,7 +2288,7 @@ static void drain_all_stock(struct mem_cgroup *root_memcg) +@@ -2289,7 +2294,7 @@ static void drain_all_stock(struct mem_cgroup *root_memcg) * as well as workers from this path always operate on the local * per-cpu data. CPU up doesn't touch memcg_stock at all. */ @@ -25476,7 +25517,7 @@ index 0140629b7cb2..def119639f70 100644 for_each_online_cpu(cpu) { struct memcg_stock_pcp *stock = &per_cpu(memcg_stock, cpu); struct mem_cgroup *memcg; -@@ -2304,7 +2309,7 @@ static void drain_all_stock(struct mem_cgroup *root_memcg) +@@ -2310,7 +2315,7 @@ static void drain_all_stock(struct mem_cgroup *root_memcg) schedule_work_on(cpu, &stock->work); } } @@ -25485,7 +25526,7 @@ index 0140629b7cb2..def119639f70 100644 mutex_unlock(&percpu_charge_mutex); } -@@ -5580,12 +5585,12 @@ static int mem_cgroup_move_account(struct page *page, +@@ -5589,12 +5594,12 @@ static int mem_cgroup_move_account(struct page *page, ret = 0; @@ -25500,7 +25541,7 @@ index 0140629b7cb2..def119639f70 100644 out_unlock: unlock_page(page); out: -@@ -6641,10 +6646,10 @@ void mem_cgroup_commit_charge(struct page *page, struct mem_cgroup *memcg, +@@ -6650,10 +6655,10 @@ void mem_cgroup_commit_charge(struct page *page, struct mem_cgroup *memcg, commit_charge(page, memcg, lrucare); @@ -25513,7 +25554,7 @@ index 0140629b7cb2..def119639f70 100644 if (do_memsw_account() && PageSwapCache(page)) { swp_entry_t entry = { .val = page_private(page) }; -@@ -6713,7 +6718,7 @@ static void uncharge_batch(const struct uncharge_gather *ug) +@@ -6722,7 +6727,7 @@ static void uncharge_batch(const struct uncharge_gather *ug) memcg_oom_recover(ug->memcg); } @@ -25522,7 +25563,7 @@ index 0140629b7cb2..def119639f70 100644 __mod_memcg_state(ug->memcg, MEMCG_RSS, -ug->nr_anon); __mod_memcg_state(ug->memcg, MEMCG_CACHE, -ug->nr_file); __mod_memcg_state(ug->memcg, MEMCG_RSS_HUGE, -ug->nr_huge); -@@ -6721,7 +6726,7 @@ static void uncharge_batch(const struct uncharge_gather *ug) +@@ -6730,7 +6735,7 @@ static void uncharge_batch(const struct uncharge_gather *ug) __count_memcg_events(ug->memcg, PGPGOUT, ug->pgpgout); __this_cpu_add(ug->memcg->vmstats_percpu->nr_page_events, nr_pages); memcg_check_events(ug->memcg, ug->dummy_page); @@ -25531,7 +25572,7 @@ index 0140629b7cb2..def119639f70 100644 if (!mem_cgroup_is_root(ug->memcg)) css_put_many(&ug->memcg->css, nr_pages); -@@ -6884,10 +6889,10 @@ void mem_cgroup_migrate(struct page *oldpage, struct page *newpage) +@@ -6893,10 +6898,10 @@ void mem_cgroup_migrate(struct page *oldpage, struct page *newpage) commit_charge(newpage, memcg, false); @@ -25544,7 +25585,7 @@ index 0140629b7cb2..def119639f70 100644 } DEFINE_STATIC_KEY_FALSE(memcg_sockets_enabled_key); -@@ -7069,6 +7074,7 @@ void mem_cgroup_swapout(struct page *page, swp_entry_t entry) +@@ -7078,6 +7083,7 @@ void mem_cgroup_swapout(struct page *page, swp_entry_t entry) struct mem_cgroup *memcg, *swap_memcg; unsigned int nr_entries; unsigned short oldid; @@ -25552,7 +25593,7 @@ index 0140629b7cb2..def119639f70 100644 VM_BUG_ON_PAGE(PageLRU(page), page); VM_BUG_ON_PAGE(page_count(page), page); -@@ -7114,10 +7120,14 @@ void mem_cgroup_swapout(struct page *page, swp_entry_t entry) +@@ -7123,10 +7129,14 @@ void mem_cgroup_swapout(struct page *page, swp_entry_t entry) * important here to have the interrupts disabled because it is the * only synchronisation we have for updating the per-CPU variables. */ @@ -25568,10 +25609,10 @@ index 0140629b7cb2..def119639f70 100644 if (!mem_cgroup_is_root(memcg)) css_put_many(&memcg->css, nr_entries); diff --git a/mm/memory.c b/mm/memory.c -index d416e329442d..a1b06bc3a7e6 100644 +index 3cde782d2856..0dc9de1ed870 100644 --- a/mm/memory.c +++ b/mm/memory.c -@@ -2169,7 +2169,7 @@ static inline int pte_unmap_same(struct mm_struct *mm, pmd_t *pmd, +@@ -2200,7 +2200,7 @@ static inline int pte_unmap_same(struct mm_struct *mm, pmd_t *pmd, pte_t *page_table, pte_t orig_pte) { int same = 1; @@ -25581,7 +25622,7 @@ index d416e329442d..a1b06bc3a7e6 100644 spinlock_t *ptl = pte_lockptr(mm, pmd); spin_lock(ptl); diff --git a/mm/page_alloc.c b/mm/page_alloc.c -index a3fca320e35a..9e55d8137fc6 100644 +index 0ad582945f54..c599edc1352d 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c @@ -61,6 +61,7 @@ @@ -25938,7 +25979,7 @@ index a3fca320e35a..9e55d8137fc6 100644 return NULL; } -@@ -5830,7 +5905,6 @@ static void __build_all_zonelists(void *data) +@@ -5832,7 +5907,6 @@ static void __build_all_zonelists(void *data) * tty_insert_flip_string_and_push_buffer() on other CPU might be * calling kmalloc(GFP_ATOMIC | __GFP_NOWARN) with port->lock held. */ @@ -25946,7 +25987,7 @@ index a3fca320e35a..9e55d8137fc6 100644 write_seqlock(&zonelist_update_seq); #ifdef CONFIG_NUMA -@@ -5865,7 +5939,6 @@ static void __build_all_zonelists(void *data) +@@ -5867,7 +5941,6 @@ static void __build_all_zonelists(void *data) } write_sequnlock(&zonelist_update_seq); @@ -25954,7 +25995,7 @@ index a3fca320e35a..9e55d8137fc6 100644 local_irq_restore(flags); } -@@ -7704,8 +7777,9 @@ void __init free_area_init(unsigned long *zones_size) +@@ -7706,8 +7779,9 @@ void __init free_area_init(unsigned long *zones_size) static int page_alloc_cpu_dead(unsigned int cpu) { @@ -25965,7 +26006,7 @@ index a3fca320e35a..9e55d8137fc6 100644 drain_pages(cpu); /* -@@ -8642,7 +8716,7 @@ void zone_pcp_reset(struct zone *zone) +@@ -8644,7 +8718,7 @@ void zone_pcp_reset(struct zone *zone) struct per_cpu_pageset *pset; /* avoid races with drain_pages() */ @@ -25974,7 +26015,7 @@ index a3fca320e35a..9e55d8137fc6 100644 if (zone->pageset != &boot_pageset) { for_each_online_cpu(cpu) { pset = per_cpu_ptr(zone->pageset, cpu); -@@ -8651,7 +8725,7 @@ void zone_pcp_reset(struct zone *zone) +@@ -8653,7 +8727,7 @@ void zone_pcp_reset(struct zone *zone) free_percpu(zone->pageset); zone->pageset = &boot_pageset; } @@ -27606,7 +27647,7 @@ index 48ed37cdd22f..3b88d028c7d5 100644 config BQL bool diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c -index e67310a749d2..69fe302fcf62 100644 +index 5d8dda9ec518..fc17b9d2d317 100644 --- a/net/bluetooth/rfcomm/sock.c +++ b/net/bluetooth/rfcomm/sock.c @@ -64,15 +64,13 @@ static void rfcomm_sk_data_ready(struct rfcomm_dlc *d, struct sk_buff *skb) @@ -27672,7 +27713,7 @@ index 591d146a5308..dbf8fdcebc53 100644 do_div(time_spent, repeat); diff --git a/net/core/dev.c b/net/core/dev.c -index a381e87fb380..de2df6c750f0 100644 +index b75c9bebd5c6..1aed6c43ac03 100644 --- a/net/core/dev.c +++ b/net/core/dev.c @@ -218,14 +218,14 @@ static inline struct hlist_head *dev_index_hash(struct net *net, int ifindex) @@ -27708,7 +27749,7 @@ index a381e87fb380..de2df6c750f0 100644 } EXPORT_SYMBOL(__dev_kfree_skb_irq); -@@ -3410,7 +3412,11 @@ static inline int __dev_xmit_skb(struct sk_buff *skb, struct Qdisc *q, +@@ -3437,7 +3439,11 @@ static inline int __dev_xmit_skb(struct sk_buff *skb, struct Qdisc *q, * This permits qdisc->running owner to get the lock more * often and dequeue packets faster. */ @@ -27720,7 +27761,7 @@ index a381e87fb380..de2df6c750f0 100644 if (unlikely(contended)) spin_lock(&q->busylock); -@@ -4213,6 +4219,7 @@ static int enqueue_to_backlog(struct sk_buff *skb, int cpu, +@@ -4240,6 +4246,7 @@ static int enqueue_to_backlog(struct sk_buff *skb, int cpu, rps_unlock(sd); local_irq_restore(flags); @@ -27728,7 +27769,7 @@ index a381e87fb380..de2df6c750f0 100644 atomic_long_inc(&skb->dev->rx_dropped); kfree_skb(skb); -@@ -4427,7 +4434,7 @@ static int netif_rx_internal(struct sk_buff *skb) +@@ -4454,7 +4461,7 @@ static int netif_rx_internal(struct sk_buff *skb) struct rps_dev_flow voidflow, *rflow = &voidflow; int cpu; @@ -27737,7 +27778,7 @@ index a381e87fb380..de2df6c750f0 100644 rcu_read_lock(); cpu = get_rps_cpu(skb->dev, skb, &rflow); -@@ -4437,14 +4444,14 @@ static int netif_rx_internal(struct sk_buff *skb) +@@ -4464,14 +4471,14 @@ static int netif_rx_internal(struct sk_buff *skb) ret = enqueue_to_backlog(skb, cpu, &rflow->last_qtail); rcu_read_unlock(); @@ -27755,7 +27796,7 @@ index a381e87fb380..de2df6c750f0 100644 } return ret; } -@@ -4483,11 +4490,9 @@ int netif_rx_ni(struct sk_buff *skb) +@@ -4510,11 +4517,9 @@ int netif_rx_ni(struct sk_buff *skb) trace_netif_rx_ni_entry(skb); @@ -27769,7 +27810,7 @@ index a381e87fb380..de2df6c750f0 100644 trace_netif_rx_ni_exit(err); return err; -@@ -5868,12 +5873,14 @@ static void net_rps_action_and_irq_enable(struct softnet_data *sd) +@@ -5895,12 +5900,14 @@ static void net_rps_action_and_irq_enable(struct softnet_data *sd) sd->rps_ipi_list = NULL; local_irq_enable(); @@ -27784,7 +27825,7 @@ index a381e87fb380..de2df6c750f0 100644 } static bool sd_has_rps_ipi_waiting(struct softnet_data *sd) -@@ -5903,7 +5910,9 @@ static int process_backlog(struct napi_struct *napi, int quota) +@@ -5930,7 +5937,9 @@ static int process_backlog(struct napi_struct *napi, int quota) while (again) { struct sk_buff *skb; @@ -27794,7 +27835,7 @@ index a381e87fb380..de2df6c750f0 100644 rcu_read_lock(); __netif_receive_skb(skb); rcu_read_unlock(); -@@ -5911,9 +5920,9 @@ static int process_backlog(struct napi_struct *napi, int quota) +@@ -5938,9 +5947,9 @@ static int process_backlog(struct napi_struct *napi, int quota) if (++work >= quota) return work; @@ -27805,7 +27846,7 @@ index a381e87fb380..de2df6c750f0 100644 rps_lock(sd); if (skb_queue_empty(&sd->input_pkt_queue)) { /* -@@ -5951,6 +5960,7 @@ void __napi_schedule(struct napi_struct *n) +@@ -5978,6 +5987,7 @@ void __napi_schedule(struct napi_struct *n) local_irq_save(flags); ____napi_schedule(this_cpu_ptr(&softnet_data), n); local_irq_restore(flags); @@ -27813,7 +27854,7 @@ index a381e87fb380..de2df6c750f0 100644 } EXPORT_SYMBOL(__napi_schedule); -@@ -6402,13 +6412,21 @@ static __latent_entropy void net_rx_action(struct softirq_action *h) +@@ -6429,13 +6439,21 @@ static __latent_entropy void net_rx_action(struct softirq_action *h) unsigned long time_limit = jiffies + usecs_to_jiffies(READ_ONCE(netdev_budget_usecs)); int budget = READ_ONCE(netdev_budget); @@ -27835,7 +27876,7 @@ index a381e87fb380..de2df6c750f0 100644 for (;;) { struct napi_struct *n; -@@ -9957,6 +9975,7 @@ static int dev_cpu_dead(unsigned int oldcpu) +@@ -9984,6 +10002,7 @@ static int dev_cpu_dead(unsigned int oldcpu) raise_softirq_irqoff(NET_TX_SOFTIRQ); local_irq_enable(); @@ -27843,7 +27884,7 @@ index a381e87fb380..de2df6c750f0 100644 #ifdef CONFIG_RPS remsd = oldsd->rps_ipi_list; -@@ -9970,10 +9989,13 @@ static int dev_cpu_dead(unsigned int oldcpu) +@@ -9997,10 +10016,13 @@ static int dev_cpu_dead(unsigned int oldcpu) netif_rx_ni(skb); input_queue_head_incr(oldsd); } @@ -27858,7 +27899,7 @@ index a381e87fb380..de2df6c750f0 100644 return 0; } -@@ -10284,8 +10306,9 @@ static int __init net_dev_init(void) +@@ -10311,8 +10333,9 @@ static int __init net_dev_init(void) INIT_WORK(flush, flush_backlog); @@ -28007,7 +28048,7 @@ index a606ad8e8be2..b7911350f421 100644 * meaning skb_orphan has been called. We NULL sk on the way out * to ensure we don't trigger a BUG_ON() in skb/sk operations diff --git a/net/kcm/kcmsock.c b/net/kcm/kcmsock.c -index 8a8ea7e6774d..5289edc4e6cf 100644 +index 50dceed77ba6..16bb28d32580 100644 --- a/net/kcm/kcmsock.c +++ b/net/kcm/kcmsock.c @@ -385,9 +385,7 @@ static int kcm_parse_func_strparser(struct strparser *strp, struct sk_buff *skb) @@ -28022,7 +28063,7 @@ index 8a8ea7e6774d..5289edc4e6cf 100644 } diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c -index 0582abf5ab71..2a23820a53a4 100644 +index 88bc4a21dda4..e903b048c505 100644 --- a/net/packet/af_packet.c +++ b/net/packet/af_packet.c @@ -57,6 +57,7 @@ @@ -28033,7 +28074,7 @@ index 0582abf5ab71..2a23820a53a4 100644 #include <linux/kmod.h> #include <linux/slab.h> #include <linux/vmalloc.h> -@@ -665,7 +666,7 @@ static void prb_retire_rx_blk_timer_expired(struct timer_list *t) +@@ -720,7 +721,7 @@ static void prb_retire_rx_blk_timer_expired(struct timer_list *t) if (BLOCK_NUM_PKTS(pbd)) { while (atomic_read(&pkc->blk_fill_in_prog)) { /* Waiting for skb_copy_bits to finish... */ @@ -28042,7 +28083,7 @@ index 0582abf5ab71..2a23820a53a4 100644 } } -@@ -927,7 +928,7 @@ static void prb_retire_current_block(struct tpacket_kbdq_core *pkc, +@@ -982,7 +983,7 @@ static void prb_retire_current_block(struct tpacket_kbdq_core *pkc, if (!(status & TP_STATUS_BLK_TMO)) { while (atomic_read(&pkc->blk_fill_in_prog)) { /* Waiting for skb_copy_bits to finish... */ @@ -28052,10 +28093,10 @@ index 0582abf5ab71..2a23820a53a4 100644 } prb_close_block(pkc, pbd, po, status); diff --git a/net/sched/sch_api.c b/net/sched/sch_api.c -index d07146a2d0bb..77f766048187 100644 +index b8dc03a7487e..c9d2fc3d8b59 100644 --- a/net/sched/sch_api.c +++ b/net/sched/sch_api.c -@@ -1266,7 +1266,7 @@ static struct Qdisc *qdisc_create(struct net_device *dev, +@@ -1271,7 +1271,7 @@ static struct Qdisc *qdisc_create(struct net_device *dev, rcu_assign_pointer(sch->stab, stab); } if (tca[TCA_RATE]) { @@ -28189,7 +28230,7 @@ index 35a8295e8f3a..4cea4cdf6ac1 100644 #endif /* __AA_PATH_H */ diff --git a/security/apparmor/lsm.c b/security/apparmor/lsm.c -index 21e03380dd86..269ecd8ed8bb 100644 +index 4c69259b62f1..6cf2226f544a 100644 --- a/security/apparmor/lsm.c +++ b/security/apparmor/lsm.c @@ -44,7 +44,7 @@ @@ -28261,5 +28302,5 @@ index f7150fbeeb55..16501aee45b4 100644 ret = handle_exit(vcpu, run, ret); } -- -2.39.2 +2.47.2 diff --git a/patches/drivers/ti/firmware/0001-Add-AM335x-CM3-Power-Managment-Firmware.patch b/patches/external/ti-amx3-cm3-pm-firmware/0001-Add-AM335x-CM3-Power-Managment-Firmware.patch similarity index 99% rename from patches/drivers/ti/firmware/0001-Add-AM335x-CM3-Power-Managment-Firmware.patch rename to patches/external/ti-amx3-cm3-pm-firmware/0001-Add-AM335x-CM3-Power-Managment-Firmware.patch index f4cf711f6..32931539b 100644 --- a/patches/drivers/ti/firmware/0001-Add-AM335x-CM3-Power-Managment-Firmware.patch +++ b/patches/external/ti-amx3-cm3-pm-firmware/0001-Add-AM335x-CM3-Power-Managment-Firmware.patch @@ -1,6 +1,6 @@ -From 8e37d58ab678fccdf22a4f253e6b01fbc4ed10be Mon Sep 17 00:00:00 2001 +From 91e8915e6d01499b1aab1ef7c0c36385fb6d5b1b Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Fri, 12 May 2023 09:42:52 -0500 +Date: Tue, 18 Jul 2023 16:29:06 -0500 Subject: [PATCH] Add AM335x CM3 Power Managment Firmware http://git.ti.com/gitweb/?p=processor-firmware/ti-amx3-cm3-pm-firmware.git;a=commit;h=fb484c5e54f2e31cf0a338d2927a06a2870bcc2c diff --git a/patches/external/wpanusb/0001-merge-wpanusb-https-git.beagleboard.org-beagleconnec.patch b/patches/external/wpanusb/0001-merge-wpanusb-https-git.beagleboard.org-beagleconnec.patch index 71d1571c7..fdec666f0 100644 --- a/patches/external/wpanusb/0001-merge-wpanusb-https-git.beagleboard.org-beagleconnec.patch +++ b/patches/external/wpanusb/0001-merge-wpanusb-https-git.beagleboard.org-beagleconnec.patch @@ -1,10 +1,10 @@ -From acaf4789d5f7cd5ad8f413d15578649971b1fece Mon Sep 17 00:00:00 2001 +From 69d0077d15bc26891e0daa82c704ae656ea1ac6d Mon Sep 17 00:00:00 2001 From: Robert Nelson <robertcnelson@gmail.com> -Date: Fri, 17 Nov 2023 15:58:24 -0600 +Date: Wed, 12 Feb 2025 13:34:51 -0600 Subject: [PATCH] merge: wpanusb: https://git.beagleboard.org/beagleconnect/linux/wpanusb -https://git.beagleboard.org/beagleconnect/linux/wpanusb/-/commit/6aa9bf65b9d88a2c9a111e7b4aed03de2be9413d +https://openbeagle.org/beagleconnect/linux/wpanusb/-/commit/6aa9bf65b9d88a2c9a111e7b4aed03de2be9413d Signed-off-by: Robert Nelson <robertcnelson@gmail.com> --- drivers/net/ieee802154/wpanusb.c | 778 +++++++++++++++++++++++++++++++ @@ -857,5 +857,5 @@ index 000000000000..52e54fdca737 + __le64 ieee_addr; +} __packed; -- -2.39.2 +2.47.2 diff --git a/patches/external/wpanusb/0002-Add-WPANUSB-driver.patch b/patches/external/wpanusb/0002-Add-WPANUSB-driver.patch index d3dbae59f..1ffce10ef 100644 --- a/patches/external/wpanusb/0002-Add-WPANUSB-driver.patch +++ b/patches/external/wpanusb/0002-Add-WPANUSB-driver.patch @@ -11,7 +11,7 @@ https://github.com/statropy/wpanusb 2 files changed, 10 insertions(+) diff --git a/drivers/net/ieee802154/Kconfig b/drivers/net/ieee802154/Kconfig -index 8af5b7e9f4ed..05561d224441 100644 +index 6d1c83fe3e97..c310472d6714 100644 --- a/drivers/net/ieee802154/Kconfig +++ b/drivers/net/ieee802154/Kconfig @@ -73,6 +73,15 @@ config IEEE802154_ATUSB @@ -28,8 +28,8 @@ index 8af5b7e9f4ed..05561d224441 100644 + * BeagleBoard.org BeagleConnect Freedom + config IEEE802154_ADF7242 - tristate "ADF7242 transceiver driver" - depends on IEEE802154_DRIVERS && MAC802154 + tristate "ADF7242 transceiver driver" + depends on IEEE802154_DRIVERS && MAC802154 diff --git a/drivers/net/ieee802154/Makefile b/drivers/net/ieee802154/Makefile index 0c78b6298060..59442aab9403 100644 --- a/drivers/net/ieee802154/Makefile @@ -43,5 +43,5 @@ index 0c78b6298060..59442aab9403 100644 obj-$(CONFIG_IEEE802154_CA8210) += ca8210.o obj-$(CONFIG_IEEE802154_MCR20A) += mcr20a.o -- -2.29.2 +2.47.2 diff --git a/patches/fixes/gcc/13/0001-ata-ahci-fix-enum-constants-for-gcc-13.patch b/patches/fixes/gcc/13/0001-ata-ahci-fix-enum-constants-for-gcc-13.patch deleted file mode 100644 index 2afc5b34e..000000000 --- a/patches/fixes/gcc/13/0001-ata-ahci-fix-enum-constants-for-gcc-13.patch +++ /dev/null @@ -1,369 +0,0 @@ -From bcd9e528e2c8a2e91dfbebd289e1c44454e96f73 Mon Sep 17 00:00:00 2001 -From: Arnd Bergmann <arnd@arndb.de> -Date: Thu, 8 Jun 2023 23:13:34 +0100 -Subject: [PATCH] ata: ahci: fix enum constants for gcc-13 - -commit f07788079f515ca4a681c5f595bdad19cfbd7b1d upstream. - -gcc-13 slightly changes the type of constant expressions that are defined -in an enum, which triggers a compile time sanity check in libata: - -linux/drivers/ata/libahci.c: In function 'ahci_led_store': -linux/include/linux/compiler_types.h:357:45: error: call to '__compiletime_assert_302' declared with attribute error: BUILD_BUG_ON failed: sizeof(_s) > sizeof(long) -357 | _compiletime_assert(condition, msg, __compiletime_assert_, __COUNTER__) - -The new behavior is that sizeof() returns the same value for the -constant as it does for the enum type, which is generally more sensible -and consistent. - -The problem in libata is that it contains a single enum definition for -lots of unrelated constants, some of which are large positive (unsigned) -integers like 0xffffffff, while others like (1<<31) are interpreted as -negative integers, and this forces the enum type to become 64 bit wide -even though most constants would still fit into a signed 32-bit 'int'. - -Fix this by changing the entire enum definition to use BIT(x) in place -of (1<<x), which results in all values being seen as 'unsigned' and -fitting into an unsigned 32-bit type. - -Link: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=107917 -Link: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=107405 -Reported-by: Luis Machado <luis.machado@arm.com> -Cc: linux-ide@vger.kernel.org -Cc: Damien Le Moal <damien.lemoal@opensource.wdc.com> -Cc: stable@vger.kernel.org -Cc: Randy Dunlap <rdunlap@infradead.org> -Signed-off-by: Arnd Bergmann <arnd@arndb.de> -Tested-by: Luis Machado <luis.machado@arm.com> -Signed-off-by: Damien Le Moal <damien.lemoal@opensource.wdc.com> -[ Modified to account for slight differences in the enum contents in the 5.10.y tree.] -Signed-off-by: Paul Barker <paul.barker@sancloud.com> -Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> ---- - drivers/ata/ahci.h | 245 +++++++++++++++++++++++---------------------- - 1 file changed, 123 insertions(+), 122 deletions(-) - -diff --git a/drivers/ata/ahci.h b/drivers/ata/ahci.h -index 1ce897356993..7cc6feb17e97 100644 ---- a/drivers/ata/ahci.h -+++ b/drivers/ata/ahci.h -@@ -24,6 +24,7 @@ - #include <linux/libata.h> - #include <linux/phy/phy.h> - #include <linux/regulator/consumer.h> -+#include <linux/bits.h> - - /* Enclosure Management Control */ - #define EM_CTRL_MSG_TYPE 0x000f0000 -@@ -54,12 +55,12 @@ enum { - AHCI_PORT_PRIV_FBS_DMA_SZ = AHCI_CMD_SLOT_SZ + - AHCI_CMD_TBL_AR_SZ + - (AHCI_RX_FIS_SZ * 16), -- AHCI_IRQ_ON_SG = (1 << 31), -- AHCI_CMD_ATAPI = (1 << 5), -- AHCI_CMD_WRITE = (1 << 6), -- AHCI_CMD_PREFETCH = (1 << 7), -- AHCI_CMD_RESET = (1 << 8), -- AHCI_CMD_CLR_BUSY = (1 << 10), -+ AHCI_IRQ_ON_SG = BIT(31), -+ AHCI_CMD_ATAPI = BIT(5), -+ AHCI_CMD_WRITE = BIT(6), -+ AHCI_CMD_PREFETCH = BIT(7), -+ AHCI_CMD_RESET = BIT(8), -+ AHCI_CMD_CLR_BUSY = BIT(10), - - RX_FIS_PIO_SETUP = 0x20, /* offset of PIO Setup FIS data */ - RX_FIS_D2H_REG = 0x40, /* offset of D2H Register FIS data */ -@@ -77,37 +78,37 @@ enum { - HOST_CAP2 = 0x24, /* host capabilities, extended */ - - /* HOST_CTL bits */ -- HOST_RESET = (1 << 0), /* reset controller; self-clear */ -- HOST_IRQ_EN = (1 << 1), /* global IRQ enable */ -- HOST_MRSM = (1 << 2), /* MSI Revert to Single Message */ -- HOST_AHCI_EN = (1 << 31), /* AHCI enabled */ -+ HOST_RESET = BIT(0), /* reset controller; self-clear */ -+ HOST_IRQ_EN = BIT(1), /* global IRQ enable */ -+ HOST_MRSM = BIT(2), /* MSI Revert to Single Message */ -+ HOST_AHCI_EN = BIT(31), /* AHCI enabled */ - - /* HOST_CAP bits */ -- HOST_CAP_SXS = (1 << 5), /* Supports External SATA */ -- HOST_CAP_EMS = (1 << 6), /* Enclosure Management support */ -- HOST_CAP_CCC = (1 << 7), /* Command Completion Coalescing */ -- HOST_CAP_PART = (1 << 13), /* Partial state capable */ -- HOST_CAP_SSC = (1 << 14), /* Slumber state capable */ -- HOST_CAP_PIO_MULTI = (1 << 15), /* PIO multiple DRQ support */ -- HOST_CAP_FBS = (1 << 16), /* FIS-based switching support */ -- HOST_CAP_PMP = (1 << 17), /* Port Multiplier support */ -- HOST_CAP_ONLY = (1 << 18), /* Supports AHCI mode only */ -- HOST_CAP_CLO = (1 << 24), /* Command List Override support */ -- HOST_CAP_LED = (1 << 25), /* Supports activity LED */ -- HOST_CAP_ALPM = (1 << 26), /* Aggressive Link PM support */ -- HOST_CAP_SSS = (1 << 27), /* Staggered Spin-up */ -- HOST_CAP_MPS = (1 << 28), /* Mechanical presence switch */ -- HOST_CAP_SNTF = (1 << 29), /* SNotification register */ -- HOST_CAP_NCQ = (1 << 30), /* Native Command Queueing */ -- HOST_CAP_64 = (1 << 31), /* PCI DAC (64-bit DMA) support */ -+ HOST_CAP_SXS = BIT(5), /* Supports External SATA */ -+ HOST_CAP_EMS = BIT(6), /* Enclosure Management support */ -+ HOST_CAP_CCC = BIT(7), /* Command Completion Coalescing */ -+ HOST_CAP_PART = BIT(13), /* Partial state capable */ -+ HOST_CAP_SSC = BIT(14), /* Slumber state capable */ -+ HOST_CAP_PIO_MULTI = BIT(15), /* PIO multiple DRQ support */ -+ HOST_CAP_FBS = BIT(16), /* FIS-based switching support */ -+ HOST_CAP_PMP = BIT(17), /* Port Multiplier support */ -+ HOST_CAP_ONLY = BIT(18), /* Supports AHCI mode only */ -+ HOST_CAP_CLO = BIT(24), /* Command List Override support */ -+ HOST_CAP_LED = BIT(25), /* Supports activity LED */ -+ HOST_CAP_ALPM = BIT(26), /* Aggressive Link PM support */ -+ HOST_CAP_SSS = BIT(27), /* Staggered Spin-up */ -+ HOST_CAP_MPS = BIT(28), /* Mechanical presence switch */ -+ HOST_CAP_SNTF = BIT(29), /* SNotification register */ -+ HOST_CAP_NCQ = BIT(30), /* Native Command Queueing */ -+ HOST_CAP_64 = BIT(31), /* PCI DAC (64-bit DMA) support */ - - /* HOST_CAP2 bits */ -- HOST_CAP2_BOH = (1 << 0), /* BIOS/OS handoff supported */ -- HOST_CAP2_NVMHCI = (1 << 1), /* NVMHCI supported */ -- HOST_CAP2_APST = (1 << 2), /* Automatic partial to slumber */ -- HOST_CAP2_SDS = (1 << 3), /* Support device sleep */ -- HOST_CAP2_SADM = (1 << 4), /* Support aggressive DevSlp */ -- HOST_CAP2_DESO = (1 << 5), /* DevSlp from slumber only */ -+ HOST_CAP2_BOH = BIT(0), /* BIOS/OS handoff supported */ -+ HOST_CAP2_NVMHCI = BIT(1), /* NVMHCI supported */ -+ HOST_CAP2_APST = BIT(2), /* Automatic partial to slumber */ -+ HOST_CAP2_SDS = BIT(3), /* Support device sleep */ -+ HOST_CAP2_SADM = BIT(4), /* Support aggressive DevSlp */ -+ HOST_CAP2_DESO = BIT(5), /* DevSlp from slumber only */ - - /* registers for each SATA port */ - PORT_LST_ADDR = 0x00, /* command list DMA addr */ -@@ -129,24 +130,24 @@ enum { - PORT_DEVSLP = 0x44, /* device sleep */ - - /* PORT_IRQ_{STAT,MASK} bits */ -- PORT_IRQ_COLD_PRES = (1 << 31), /* cold presence detect */ -- PORT_IRQ_TF_ERR = (1 << 30), /* task file error */ -- PORT_IRQ_HBUS_ERR = (1 << 29), /* host bus fatal error */ -- PORT_IRQ_HBUS_DATA_ERR = (1 << 28), /* host bus data error */ -- PORT_IRQ_IF_ERR = (1 << 27), /* interface fatal error */ -- PORT_IRQ_IF_NONFATAL = (1 << 26), /* interface non-fatal error */ -- PORT_IRQ_OVERFLOW = (1 << 24), /* xfer exhausted available S/G */ -- PORT_IRQ_BAD_PMP = (1 << 23), /* incorrect port multiplier */ -- -- PORT_IRQ_PHYRDY = (1 << 22), /* PhyRdy changed */ -- PORT_IRQ_DEV_ILCK = (1 << 7), /* device interlock */ -- PORT_IRQ_CONNECT = (1 << 6), /* port connect change status */ -- PORT_IRQ_SG_DONE = (1 << 5), /* descriptor processed */ -- PORT_IRQ_UNK_FIS = (1 << 4), /* unknown FIS rx'd */ -- PORT_IRQ_SDB_FIS = (1 << 3), /* Set Device Bits FIS rx'd */ -- PORT_IRQ_DMAS_FIS = (1 << 2), /* DMA Setup FIS rx'd */ -- PORT_IRQ_PIOS_FIS = (1 << 1), /* PIO Setup FIS rx'd */ -- PORT_IRQ_D2H_REG_FIS = (1 << 0), /* D2H Register FIS rx'd */ -+ PORT_IRQ_COLD_PRES = BIT(31), /* cold presence detect */ -+ PORT_IRQ_TF_ERR = BIT(30), /* task file error */ -+ PORT_IRQ_HBUS_ERR = BIT(29), /* host bus fatal error */ -+ PORT_IRQ_HBUS_DATA_ERR = BIT(28), /* host bus data error */ -+ PORT_IRQ_IF_ERR = BIT(27), /* interface fatal error */ -+ PORT_IRQ_IF_NONFATAL = BIT(26), /* interface non-fatal error */ -+ PORT_IRQ_OVERFLOW = BIT(24), /* xfer exhausted available S/G */ -+ PORT_IRQ_BAD_PMP = BIT(23), /* incorrect port multiplier */ -+ -+ PORT_IRQ_PHYRDY = BIT(22), /* PhyRdy changed */ -+ PORT_IRQ_DEV_ILCK = BIT(7), /* device interlock */ -+ PORT_IRQ_CONNECT = BIT(6), /* port connect change status */ -+ PORT_IRQ_SG_DONE = BIT(5), /* descriptor processed */ -+ PORT_IRQ_UNK_FIS = BIT(4), /* unknown FIS rx'd */ -+ PORT_IRQ_SDB_FIS = BIT(3), /* Set Device Bits FIS rx'd */ -+ PORT_IRQ_DMAS_FIS = BIT(2), /* DMA Setup FIS rx'd */ -+ PORT_IRQ_PIOS_FIS = BIT(1), /* PIO Setup FIS rx'd */ -+ PORT_IRQ_D2H_REG_FIS = BIT(0), /* D2H Register FIS rx'd */ - - PORT_IRQ_FREEZE = PORT_IRQ_HBUS_ERR | - PORT_IRQ_IF_ERR | -@@ -162,34 +163,34 @@ enum { - PORT_IRQ_PIOS_FIS | PORT_IRQ_D2H_REG_FIS, - - /* PORT_CMD bits */ -- PORT_CMD_ASP = (1 << 27), /* Aggressive Slumber/Partial */ -- PORT_CMD_ALPE = (1 << 26), /* Aggressive Link PM enable */ -- PORT_CMD_ATAPI = (1 << 24), /* Device is ATAPI */ -- PORT_CMD_FBSCP = (1 << 22), /* FBS Capable Port */ -- PORT_CMD_ESP = (1 << 21), /* External Sata Port */ -- PORT_CMD_HPCP = (1 << 18), /* HotPlug Capable Port */ -- PORT_CMD_PMP = (1 << 17), /* PMP attached */ -- PORT_CMD_LIST_ON = (1 << 15), /* cmd list DMA engine running */ -- PORT_CMD_FIS_ON = (1 << 14), /* FIS DMA engine running */ -- PORT_CMD_FIS_RX = (1 << 4), /* Enable FIS receive DMA engine */ -- PORT_CMD_CLO = (1 << 3), /* Command list override */ -- PORT_CMD_POWER_ON = (1 << 2), /* Power up device */ -- PORT_CMD_SPIN_UP = (1 << 1), /* Spin up device */ -- PORT_CMD_START = (1 << 0), /* Enable port DMA engine */ -- -- PORT_CMD_ICC_MASK = (0xf << 28), /* i/f ICC state mask */ -- PORT_CMD_ICC_ACTIVE = (0x1 << 28), /* Put i/f in active state */ -- PORT_CMD_ICC_PARTIAL = (0x2 << 28), /* Put i/f in partial state */ -- PORT_CMD_ICC_SLUMBER = (0x6 << 28), /* Put i/f in slumber state */ -+ PORT_CMD_ASP = BIT(27), /* Aggressive Slumber/Partial */ -+ PORT_CMD_ALPE = BIT(26), /* Aggressive Link PM enable */ -+ PORT_CMD_ATAPI = BIT(24), /* Device is ATAPI */ -+ PORT_CMD_FBSCP = BIT(22), /* FBS Capable Port */ -+ PORT_CMD_ESP = BIT(21), /* External Sata Port */ -+ PORT_CMD_HPCP = BIT(18), /* HotPlug Capable Port */ -+ PORT_CMD_PMP = BIT(17), /* PMP attached */ -+ PORT_CMD_LIST_ON = BIT(15), /* cmd list DMA engine running */ -+ PORT_CMD_FIS_ON = BIT(14), /* FIS DMA engine running */ -+ PORT_CMD_FIS_RX = BIT(4), /* Enable FIS receive DMA engine */ -+ PORT_CMD_CLO = BIT(3), /* Command list override */ -+ PORT_CMD_POWER_ON = BIT(2), /* Power up device */ -+ PORT_CMD_SPIN_UP = BIT(1), /* Spin up device */ -+ PORT_CMD_START = BIT(0), /* Enable port DMA engine */ -+ -+ PORT_CMD_ICC_MASK = (0xfu << 28), /* i/f ICC state mask */ -+ PORT_CMD_ICC_ACTIVE = (0x1u << 28), /* Put i/f in active state */ -+ PORT_CMD_ICC_PARTIAL = (0x2u << 28), /* Put i/f in partial state */ -+ PORT_CMD_ICC_SLUMBER = (0x6u << 28), /* Put i/f in slumber state */ - - /* PORT_FBS bits */ - PORT_FBS_DWE_OFFSET = 16, /* FBS device with error offset */ - PORT_FBS_ADO_OFFSET = 12, /* FBS active dev optimization offset */ - PORT_FBS_DEV_OFFSET = 8, /* FBS device to issue offset */ - PORT_FBS_DEV_MASK = (0xf << PORT_FBS_DEV_OFFSET), /* FBS.DEV */ -- PORT_FBS_SDE = (1 << 2), /* FBS single device error */ -- PORT_FBS_DEC = (1 << 1), /* FBS device error clear */ -- PORT_FBS_EN = (1 << 0), /* Enable FBS */ -+ PORT_FBS_SDE = BIT(2), /* FBS single device error */ -+ PORT_FBS_DEC = BIT(1), /* FBS device error clear */ -+ PORT_FBS_EN = BIT(0), /* Enable FBS */ - - /* PORT_DEVSLP bits */ - PORT_DEVSLP_DM_OFFSET = 25, /* DITO multiplier offset */ -@@ -197,52 +198,52 @@ enum { - PORT_DEVSLP_DITO_OFFSET = 15, /* DITO offset */ - PORT_DEVSLP_MDAT_OFFSET = 10, /* Minimum assertion time */ - PORT_DEVSLP_DETO_OFFSET = 2, /* DevSlp exit timeout */ -- PORT_DEVSLP_DSP = (1 << 1), /* DevSlp present */ -- PORT_DEVSLP_ADSE = (1 << 0), /* Aggressive DevSlp enable */ -+ PORT_DEVSLP_DSP = BIT(1), /* DevSlp present */ -+ PORT_DEVSLP_ADSE = BIT(0), /* Aggressive DevSlp enable */ - - /* hpriv->flags bits */ - - #define AHCI_HFLAGS(flags) .private_data = (void *)(flags) - -- AHCI_HFLAG_NO_NCQ = (1 << 0), -- AHCI_HFLAG_IGN_IRQ_IF_ERR = (1 << 1), /* ignore IRQ_IF_ERR */ -- AHCI_HFLAG_IGN_SERR_INTERNAL = (1 << 2), /* ignore SERR_INTERNAL */ -- AHCI_HFLAG_32BIT_ONLY = (1 << 3), /* force 32bit */ -- AHCI_HFLAG_MV_PATA = (1 << 4), /* PATA port */ -- AHCI_HFLAG_NO_MSI = (1 << 5), /* no PCI MSI */ -- AHCI_HFLAG_NO_PMP = (1 << 6), /* no PMP */ -- AHCI_HFLAG_SECT255 = (1 << 8), /* max 255 sectors */ -- AHCI_HFLAG_YES_NCQ = (1 << 9), /* force NCQ cap on */ -- AHCI_HFLAG_NO_SUSPEND = (1 << 10), /* don't suspend */ -- AHCI_HFLAG_SRST_TOUT_IS_OFFLINE = (1 << 11), /* treat SRST timeout as -- link offline */ -- AHCI_HFLAG_NO_SNTF = (1 << 12), /* no sntf */ -- AHCI_HFLAG_NO_FPDMA_AA = (1 << 13), /* no FPDMA AA */ -- AHCI_HFLAG_YES_FBS = (1 << 14), /* force FBS cap on */ -- AHCI_HFLAG_DELAY_ENGINE = (1 << 15), /* do not start engine on -- port start (wait until -- error-handling stage) */ -- AHCI_HFLAG_NO_DEVSLP = (1 << 17), /* no device sleep */ -- AHCI_HFLAG_NO_FBS = (1 << 18), /* no FBS */ -+ AHCI_HFLAG_NO_NCQ = BIT(0), -+ AHCI_HFLAG_IGN_IRQ_IF_ERR = BIT(1), /* ignore IRQ_IF_ERR */ -+ AHCI_HFLAG_IGN_SERR_INTERNAL = BIT(2), /* ignore SERR_INTERNAL */ -+ AHCI_HFLAG_32BIT_ONLY = BIT(3), /* force 32bit */ -+ AHCI_HFLAG_MV_PATA = BIT(4), /* PATA port */ -+ AHCI_HFLAG_NO_MSI = BIT(5), /* no PCI MSI */ -+ AHCI_HFLAG_NO_PMP = BIT(6), /* no PMP */ -+ AHCI_HFLAG_SECT255 = BIT(8), /* max 255 sectors */ -+ AHCI_HFLAG_YES_NCQ = BIT(9), /* force NCQ cap on */ -+ AHCI_HFLAG_NO_SUSPEND = BIT(10), /* don't suspend */ -+ AHCI_HFLAG_SRST_TOUT_IS_OFFLINE = BIT(11), /* treat SRST timeout as -+ link offline */ -+ AHCI_HFLAG_NO_SNTF = BIT(12), /* no sntf */ -+ AHCI_HFLAG_NO_FPDMA_AA = BIT(13), /* no FPDMA AA */ -+ AHCI_HFLAG_YES_FBS = BIT(14), /* force FBS cap on */ -+ AHCI_HFLAG_DELAY_ENGINE = BIT(15), /* do not start engine on -+ port start (wait until -+ error-handling stage) */ -+ AHCI_HFLAG_NO_DEVSLP = BIT(17), /* no device sleep */ -+ AHCI_HFLAG_NO_FBS = BIT(18), /* no FBS */ - - #ifdef CONFIG_PCI_MSI -- AHCI_HFLAG_MULTI_MSI = (1 << 20), /* per-port MSI(-X) */ -+ AHCI_HFLAG_MULTI_MSI = BIT(20), /* per-port MSI(-X) */ - #else - /* compile out MSI infrastructure */ - AHCI_HFLAG_MULTI_MSI = 0, - #endif -- AHCI_HFLAG_WAKE_BEFORE_STOP = (1 << 22), /* wake before DMA stop */ -- AHCI_HFLAG_YES_ALPM = (1 << 23), /* force ALPM cap on */ -- AHCI_HFLAG_NO_WRITE_TO_RO = (1 << 24), /* don't write to read -- only registers */ -- AHCI_HFLAG_IS_MOBILE = (1 << 25), /* mobile chipset, use -- SATA_MOBILE_LPM_POLICY -- as default lpm_policy */ -- AHCI_HFLAG_SUSPEND_PHYS = (1 << 26), /* handle PHYs during -- suspend/resume */ -- AHCI_HFLAG_IGN_NOTSUPP_POWER_ON = (1 << 27), /* ignore -EOPNOTSUPP -- from phy_power_on() */ -- AHCI_HFLAG_NO_SXS = (1 << 28), /* SXS not supported */ -+ AHCI_HFLAG_WAKE_BEFORE_STOP = BIT(22), /* wake before DMA stop */ -+ AHCI_HFLAG_YES_ALPM = BIT(23), /* force ALPM cap on */ -+ AHCI_HFLAG_NO_WRITE_TO_RO = BIT(24), /* don't write to read -+ only registers */ -+ AHCI_HFLAG_IS_MOBILE = BIT(25), /* mobile chipset, use -+ SATA_MOBILE_LPM_POLICY -+ as default lpm_policy */ -+ AHCI_HFLAG_SUSPEND_PHYS = BIT(26), /* handle PHYs during -+ suspend/resume */ -+ AHCI_HFLAG_IGN_NOTSUPP_POWER_ON = BIT(27), /* ignore -EOPNOTSUPP -+ from phy_power_on() */ -+ AHCI_HFLAG_NO_SXS = BIT(28), /* SXS not supported */ - - /* ap->flags bits */ - -@@ -258,22 +259,22 @@ enum { - EM_MAX_RETRY = 5, - - /* em_ctl bits */ -- EM_CTL_RST = (1 << 9), /* Reset */ -- EM_CTL_TM = (1 << 8), /* Transmit Message */ -- EM_CTL_MR = (1 << 0), /* Message Received */ -- EM_CTL_ALHD = (1 << 26), /* Activity LED */ -- EM_CTL_XMT = (1 << 25), /* Transmit Only */ -- EM_CTL_SMB = (1 << 24), /* Single Message Buffer */ -- EM_CTL_SGPIO = (1 << 19), /* SGPIO messages supported */ -- EM_CTL_SES = (1 << 18), /* SES-2 messages supported */ -- EM_CTL_SAFTE = (1 << 17), /* SAF-TE messages supported */ -- EM_CTL_LED = (1 << 16), /* LED messages supported */ -+ EM_CTL_RST = BIT(9), /* Reset */ -+ EM_CTL_TM = BIT(8), /* Transmit Message */ -+ EM_CTL_MR = BIT(0), /* Message Received */ -+ EM_CTL_ALHD = BIT(26), /* Activity LED */ -+ EM_CTL_XMT = BIT(25), /* Transmit Only */ -+ EM_CTL_SMB = BIT(24), /* Single Message Buffer */ -+ EM_CTL_SGPIO = BIT(19), /* SGPIO messages supported */ -+ EM_CTL_SES = BIT(18), /* SES-2 messages supported */ -+ EM_CTL_SAFTE = BIT(17), /* SAF-TE messages supported */ -+ EM_CTL_LED = BIT(16), /* LED messages supported */ - - /* em message type */ -- EM_MSG_TYPE_LED = (1 << 0), /* LED */ -- EM_MSG_TYPE_SAFTE = (1 << 1), /* SAF-TE */ -- EM_MSG_TYPE_SES2 = (1 << 2), /* SES-2 */ -- EM_MSG_TYPE_SGPIO = (1 << 3), /* SGPIO */ -+ EM_MSG_TYPE_LED = BIT(0), /* LED */ -+ EM_MSG_TYPE_SAFTE = BIT(1), /* SAF-TE */ -+ EM_MSG_TYPE_SES2 = BIT(2), /* SES-2 */ -+ EM_MSG_TYPE_SGPIO = BIT(3), /* SGPIO */ - }; - - struct ahci_cmd_hdr { --- -2.39.2 - diff --git a/patches/ref_omap2plus_defconfig b/patches/ref_omap2plus_defconfig index 40d00575b..726823417 100644 --- a/patches/ref_omap2plus_defconfig +++ b/patches/ref_omap2plus_defconfig @@ -1,6 +1,6 @@ # # Automatically generated file; DO NOT EDIT. -# Linux/arm 5.4.257 Kernel Configuration +# Linux/arm 5.4.288 Kernel Configuration # # @@ -1150,10 +1150,6 @@ CONFIG_AF_RXRPC=m CONFIG_RXKAD=y # CONFIG_AF_KCM is not set CONFIG_WIRELESS=y -CONFIG_WIRELESS_EXT=y -CONFIG_WEXT_CORE=y -CONFIG_WEXT_PROC=y -CONFIG_WEXT_SPY=y CONFIG_CFG80211=m # CONFIG_NL80211_TESTMODE is not set # CONFIG_CFG80211_DEVELOPER_WARNINGS is not set @@ -1469,7 +1465,6 @@ CONFIG_BLK_DEV_LOOP_MIN_COUNT=8 # CONFIG_BLK_DEV_CRYPTOLOOP is not set # CONFIG_BLK_DEV_DRBD is not set # CONFIG_BLK_DEV_NBD is not set -# CONFIG_BLK_DEV_SX8 is not set CONFIG_BLK_DEV_RAM=y CONFIG_BLK_DEV_RAM_COUNT=16 CONFIG_BLK_DEV_RAM_SIZE=16384 @@ -5652,6 +5647,9 @@ CONFIG_KEYS=y # CONFIG_ENCRYPTED_KEYS is not set # CONFIG_KEY_DH_OPERATIONS is not set # CONFIG_SECURITY_DMESG_RESTRICT is not set +CONFIG_PROC_MEM_ALWAYS_FORCE=y +# CONFIG_PROC_MEM_FORCE_PTRACE is not set +# CONFIG_PROC_MEM_NO_FORCE is not set CONFIG_SECURITY=y # CONFIG_SECURITYFS is not set # CONFIG_SECURITY_NETWORK is not set @@ -5725,7 +5723,6 @@ CONFIG_CRYPTO_CRYPTD=m # CONFIG_CRYPTO_AUTHENC is not set # CONFIG_CRYPTO_TEST is not set CONFIG_CRYPTO_SIMD=m -CONFIG_CRYPTO_ENGINE=m # # Public-key cryptography @@ -5850,7 +5847,7 @@ CONFIG_CRYPTO_HW=y # CONFIG_CRYPTO_DEV_OMAP is not set # CONFIG_CRYPTO_DEV_ATMEL_ECC is not set # CONFIG_CRYPTO_DEV_ATMEL_SHA204A is not set -CONFIG_CRYPTO_DEV_VIRTIO=m +# CONFIG_CRYPTO_DEV_VIRTIO is not set # CONFIG_CRYPTO_DEV_SAFEXCEL is not set # CONFIG_CRYPTO_DEV_CCREE is not set CONFIG_ASYMMETRIC_KEY_TYPE=y diff --git a/tools/config-hot-fix.sh b/tools/config-hot-fix.sh index 545423918..8ac465047 100755 --- a/tools/config-hot-fix.sh +++ b/tools/config-hot-fix.sh @@ -82,10 +82,6 @@ config="CONFIG_WIMAX" ; config_disable config="CONFIG_WIMAX_I2400M" ; config_disable config="CONFIG_WIMAX_I2400M_USB" ; config_disable -#Docker.io: -config="CONFIG_CGROUP_HUGETLB" ; config_enable -config="CONFIG_RT_GROUP_SCHED" ; config_enable - #PHY: CONFIG_DP83867_PHY config="CONFIG_DP83867_PHY" ; config_enable @@ -95,6 +91,29 @@ config="CONFIG_REMOTEPROC_CDEV" ; config_enable config="CONFIG_WKUP_M3_RPROC" ; config_enable config="CONFIG_PRU_REMOTEPROC" ; config_module +#Docker.io +./scripts/config --enable CONFIG_NETFILTER_XT_MATCH_IPVS +./scripts/config --enable CONFIG_CGROUP_BPF +./scripts/config --enable CONFIG_BLK_DEV_THROTTLING +./scripts/config --enable CONFIG_NET_CLS_CGROUP +./scripts/config --enable CONFIG_CGROUP_NET_PRIO +./scripts/config --enable CONFIG_IP_NF_TARGET_REDIRECT +./scripts/config --enable CONFIG_IP_VS +./scripts/config --enable CONFIG_IP_VS_NFCT +./scripts/config --enable CONFIG_IP_VS_PROTO_TCP +./scripts/config --enable CONFIG_IP_VS_PROTO_UDP +./scripts/config --enable CONFIG_IP_VS_RR +./scripts/config --enable CONFIG_SECURITY_SELINUX +./scripts/config --enable CONFIG_SECURITY_APPARMOR +./scripts/config --enable CONFIG_VXLAN +./scripts/config --enable CONFIG_IPVLAN +./scripts/config --enable CONFIG_DUMMY +./scripts/config --enable CONFIG_NF_NAT_FTP +./scripts/config --enable CONFIG_NF_CONNTRACK_FTP +./scripts/config --enable CONFIG_NF_NAT_TFTP +./scripts/config --enable CONFIG_NF_CONNTRACK_TFTP +./scripts/config --enable CONFIG_DM_THIN_PROVISIONING + #abi="5.13.0-trunk" #kernel="5.13.9-1~exp2" config="CONFIG_BPF_UNPRIV_DEFAULT_OFF" ; config_enable @@ -146,11 +165,30 @@ config="CONFIG_USB_CONFIGFS_F_UVC" ; config_enable config="CONFIG_USB_CONFIGFS_F_PRINTER" ; config_enable #2022.03.01 fix W1, needs to be a module now... -config="CONFIG_W1" ; config_module +config="CONFIG_W1" ; config_enable config="CONFIG_W1_MASTER_GPIO" ; config_module config="CONFIG_W1_SLAVE_DS2430" ; config_module config="CONFIG_W1_SLAVE_DS2433_CRC" ; config_enable +#2022.03.18 Re-Enable UIO PRUSS +config="CONFIG_UIO_PDRV_GENIRQ" ; config_module +config="CONFIG_UIO_PRUSS" ; config_module + +#2022.12.25: still totally broken.. +#[ 26.460634] tps65217-charger tps65217-charger: DMA mask not set +#[ 26.581296] genirq: Flags mismatch irq 53. 00002000 (tps65217-charger) vs. 00002000 (vbus) +#[ 26.739119] tps65217-charger tps65217-charger: Unable to register irq 53 err -16 +#[ 26.842097] tps65217-charger: probe of tps65217-charger failed with error -16 +config="CONFIG_CHARGER_TPS65217" ; config_disable + +#2023.07.10 +config="CONFIG_GCC_PLUGINS" ; config_disable + +#2023.07.14 +# MUSB DMA mode +config="CONFIG_MUSB_PIO_ONLY" ; config_enable +config="CONFIG_USB_TI_CPPI41_DMA" ; config_disable + # We recommend to turn off Real-Time group scheduling in the # kernel when using systemd. RT group scheduling effectively # makes RT scheduling unavailable for most userspace, since it @@ -185,4 +223,90 @@ config="CONFIG_W1_SLAVE_DS2433_CRC" ; config_enable #removed in 6.7-rc1 ./scripts/config --disable CONFIG_DEV_APPLETALK +#09.02.00.005 +./scripts/config --module CONFIG_VIDEO_TI_VIP +./scripts/config --module CONFIG_VIDEO_OV1063X + +#20240305: regression on discord, some systemd can no longer load *.xz modules... +./scripts/config --disable CONFIG_MODULE_DECOMPRESS + +#enable CONFIG_DYNAMIC_FTRACE +./scripts/config --enable CONFIG_FUNCTION_TRACER +./scripts/config --enable CONFIG_DYNAMIC_FTRACE + +./scripts/config --disable CONFIG_MODULE_COMPRESS_GZIP +./scripts/config --enable CONFIG_MODULE_COMPRESS_XZ +./scripts/config --disable CONFIG_MODULE_COMPRESS_ZSTD +./scripts/config --enable CONFIG_GPIO_AGGREGATOR +./scripts/config --module CONFIG_PWM_GPIO + +#10.00.05 +./scripts/config --module CONFIG_RPMSG_PRU + +#new in v6.12.x +./scripts/config --enable CONFIG_RPMB +./scripts/config --module CONFIG_ADXL380_SPI +./scripts/config --module CONFIG_ADXL380_I2C +./scripts/config --module CONFIG_AD4000 +./scripts/config --module CONFIG_AD4695 +./scripts/config --module CONFIG_PAC1921 +./scripts/config --module CONFIG_LTC2664 +./scripts/config --module CONFIG_ENS210 +./scripts/config --module CONFIG_BH1745 +./scripts/config --module CONFIG_SDP500 +./scripts/config --module CONFIG_HX9023S +./scripts/config --module CONFIG_AW96103 + +#debian 6.12~rc6-1~exp1 +./scripts/config --enable CONFIG_ZONE_DEVICE +./scripts/config --module CONFIG_IP_VS_TWOS +./scripts/config --module CONFIG_VIDEO_OV5648 +./scripts/config --enable CONFIG_DRM_DISPLAY_DP_AUX_CHARDEV +./scripts/config --module CONFIG_TI_PRUSS + +#debian 6.12.6-1 +./scripts/config --enable CONFIG_ZRAM_BACKEND_LZ4 +./scripts/config --enable CONFIG_ZRAM_BACKEND_LZ4HC +./scripts/config --enable CONFIG_ZRAM_BACKEND_ZSTD +./scripts/config --enable CONFIG_ZRAM_BACKEND_DEFLATE +./scripts/config --enable CONFIG_ZRAM_DEF_COMP_LZ4 +./scripts/config --set-str CONFIG_ZRAM_DEF_COMP "lz4" + +#new in v6.14 +./scripts/config --module CONFIG_NTSYNC +./scripts/config --module CONFIG_PPS_GENERATOR +./scripts/config --module CONFIG_SENSORS_CRPS +./scripts/config --module CONFIG_SENSORS_TPS25990 +./scripts/config --module CONFIG_BD79703 +./scripts/config --module CONFIG_OPT4060 +./scripts/config --enable CONFIG_FPROBE + +#TI: 11.00.01 +./scripts/config --enable CONFIG_SRAM_DMA_HEAP +./scripts/config --module CONFIG_CC33XX +./scripts/config --module CONFIG_CC33XX_SDIO +./scripts/config --module CONFIG_VIDEO_IMX390 +./scripts/config --enable CONFIG_DMABUF_HEAPS +./scripts/config --enable CONFIG_DMABUF_HEAPS_SYSTEM +./scripts/config --enable CONFIG_DMABUF_HEAPS_CMA +./scripts/config --enable CONFIG_DMABUF_HEAPS_CARVEOUT + +#debian Trixie has fubared lz4/lz4c, back to xz for stabilty... +# LZ4 arch/arm/boot/compressed/piggy_data +#Error : stdout won't be used ! Do you want multiple input files (-m) ? +#make[3]: *** [arch/arm/boot/compressed/Makefile:156: arch/arm/boot/compressed/piggy_data] Error 1 + +./scripts/config --disable CONFIG_KERNEL_LZO +./scripts/config --disable CONFIG_KERNEL_LZ4 +./scripts/config --enable CONFIG_KERNEL_XZ + +#configure CONFIG_EXTRA_FIRMWARE +./scripts/config --set-str CONFIG_EXTRA_FIRMWARE "regulatory.db regulatory.db.p7s am335x-pm-firmware.elf am335x-bone-scale-data.bin am335x-evm-scale-data.bin am43x-evm-scale-data.bin" +./scripts/config --enable CONFIG_FW_LOADER_COMPRESS +./scripts/config --enable CONFIG_FW_LOADER_COMPRESS_XZ +./scripts/config --enable CONFIG_FW_LOADER_COMPRESS_ZSTD + +#BeagleBoard.org +./scripts/config --enable CONFIG_MSPM0_I2C + cd ${DIR}/ diff --git a/version.sh b/version.sh index de4224036..bdec5f09c 100644 --- a/version.sh +++ b/version.sh @@ -50,11 +50,11 @@ linux_repo="https://kernel.googlesource.com/pub/scm/linux/kernel/git/torvalds/li linux_stable_repo="https://kernel.googlesource.com/pub/scm/linux/kernel/git/stable/linux.git" # KERNEL_REL=5.4 -KERNEL_TAG=${KERNEL_REL}.257 +KERNEL_TAG=${KERNEL_REL}.288 #https://mirrors.edge.kernel.org/pub/linux/kernel/projects/rt/5.4/ -kernel_rt=".257-rt87" +kernel_rt=".288-rt94" #Kernel Build -BUILD=${build_prefix}68 +BUILD=${build_prefix}68.1 #v6.X-rcX + upto SHA #prev_KERNEL_SHA="" -- GitLab