GKI (arm64) relevant 137 out of 624 changes, affecting 192 files +1647/-1035a4f865ecdbnvmem: core: fix bit offsets of more than one byte [1 file, +17/-7]4327479e55nvmem: core: verify cell's raw_len [1 file, +12/-0]410f8b72e0nvmem: core: update raw_len if the bit reading is required [1 file, +3/-1]7aea1517fbscsi: ufs: Introduce quirk to extend PA_HIBERN8TIME for UFS devices [2 files, +35/-0]b730cb1096virtio_ring: Fix data race by tagging event_triggered as racy for KCSAN [1 file, +1/-1]2998813177dma/mapping.c: dev_dbg support for dma_addressing_limited [1 file, +10/-1]3eec42a17adma-mapping: avoid potential unused data compilation warning [1 file, +8/-4]97edaa0ec6cgroup: Fix compilation issue due to cgroup_mutex not being exported [1 file, +1/-1]f93675793bvhost_task: fix vhost_task_create() documentation [1 file, +1/-1]e22034cbeedma-mapping: Fix warning reported for missing prototype [1 file, +8/-8]4f5553a08ffs/buffer: split locking for pagecache lookups [1 file, +25/-16]e138fc2316fs/buffer: introduce sleeping flavors for pagecache lookups [2 files, +17/-0]a49a4a87cefs/buffer: use sleeping version of __find_get_block() [1 file, +9/-2]f1c5aa614bfs/jbd2: use sleeping version of __find_get_block() [1 file, +9/-6]9ece099e95fs/ext4: use sleeping version of sb_find_get_block() [1 file, +2/-1]64f505b08eblock: fix race between set_blocksize and read paths [4 files, +43/-1]218c838d03io_uring: don't duplicate flushing in io_req_post_cqe [1 file, +8/-3]8014d3e56ebpf: fix possible endless loop in BPF map iteration [1 file, +1/-1]d40ca27602fuse: Return EPERM rather than ENOSYS from link() [1 file, +2/-0]bab0bd1389exfat: call bh_read in get_block only when necessary [1 file, +77/-82]01677e7ee1io_uring/msg: initialise msg request opcode [1 file, +1/-0]e506751b7darm64: Add support for HIP09 Spectre-BHB mitigation [2 files, +3/-0]4f427ca9edtracing: Mark binary printing functions with __printf() attribute [4 files, +18/-21]15787ab82amailbox: use error ret code of of_parse_phandle_with_args() [1 file, +4/-3]f48ee562c0Bluetooth: Disable SCO support if READ_VOICE_SETTING is unsupported/broken [1 file, +3/-0]44b79041c4dql: Fix dql->limit value when reset. [1 file, +1/-1]ac30595154lockdep: Fix wait context check on softirq for PREEMPT_RT [1 file, +18/-0]e63b634806PCI: dwc: ep: Ensure proper iteration over outbound map windows [1 file, +1/-1]37ac2434aaext4: on a remount, only log the ro or r/w state when it has changed [1 file, +4/-3]1d1e1efad1libnvdimm/labels: Fix divide error in nd_label_data_init() [1 file, +2/-1]123bcd8f42pidfs: improve multi-threaded exec and premature thread-group leader exit polling [3 files, +9/-9]8f82cf305ecgroup/rstat: avoid disabling irqs for O(num_cpu) [1 file, +5/-7]a5a507fa5fblk-cgroup: improve policy registration error handling [1 file, +12/-10]94c3cbc69aext4: reorder capability check last [1 file, +2/-2]e658f2d94abpf: Return prog btf_id without capable check [1 file, +2/-2]e2520cc19bPCI: dwc: Use resource start as ioremap() input in dw_pcie_pme_turn_off() [1 file, +1/-1]50452704ecjbd2: do not try to recover wiped journal [1 file, +6/-5]dab35f4921tcp: reorganize tcp_in_ack_event() and tcp_count_delivered() [1 file, +32/-24]555c0b713cbpf: Allow pre-ordering for bpf cgroup progs [5 files, +30/-9]572ed3fb99kconfig: do not clear SYMBOL_VALID when reading include/config/auto.conf [1 file, +12/-7]174dedce64dm: restrict dm device size to 2^63-512 bytes [1 file, +4/-0]2f5f326214ext4: reject the 'data_err=abort' option in nojournal mode [1 file, +12/-0]d0dc233fe2posix-timers: Add cond_resched() to posix_timer_add() search loop [1 file, +1/-0]ae22452d15posix-timers: Ensure that timer initialization is fully visible [1 file, +14/-7]3fb9ee05ectimer_list: Don't use %pK through printk() [1 file, +2/-2]21153e0974netfilter: conntrack: Bound nf_conntrack sysctl writes [1 file, +9/-3]236a87e9d2PNP: Expand length of fixup id string [1 file, +1/-1]6215143ad3arm64/mm: Check pmd_table() in pmd_trans_huge() [1 file, +12/-12]8ad58a7ebaarm64/mm: Check PUD_TYPE_TABLE in pud_bad() [1 file, +2/-1]28306c58dammc: sdhci: Disable SD card clock before changing parameters [1 file, +7/-2]3a75fe58a1usb: xhci: Don't change the status of stalled TDs on failed Stop EP [1 file, +11/-1]101a3b9920printk: Check CON_SUSPEND when unblanking a console [1 file, +12/-2]faba68a86awifi: cfg80211: allow IR in 20 MHz configurations [5 files, +46/-25]c1502fc84dipv6: save dontfrag in cork [2 files, +6/-4]75ae2a3553badblocks: Fix a nonsense WARN_ON() which checks whether a u64 variable < 0 [1 file, +3/-2]7caad075accrypto: lzo - Fix compression buffer overrun [6 files, +106/-28]73d01bcbf2tcp: bring back NUMA dispersion in inet_ehash_locks_alloc() [1 file, +26/-11]1c17190880usb: xhci: set page size to the xHCI-supported size [2 files, +22/-20]93f581d763drm/gem: Test for imported GEM buffers with helper [2 files, +16/-2]c4525b513dnet: phylink: use pl->link_interface in phylink_expects_phy() [1 file, +1/-1]f29c876d72perf/core: Clean up perf_try_init_event() [1 file, +38/-27]af73c8fd73ublk: enforce ublks_max only for unprivileged devices [1 file, +27/-15]592ba27580perf/hw_breakpoint: Return EOPNOTSUPP for unsupported breakpoint type [1 file, +3/-2]3de322a98bscsi: logging: Fix scsi_logging_level bounds [1 file, +3/-1]f33b310eacipv4: fib: Move fib_valid_key_len() to rtm_to_fib_config(). [2 files, +16/-24]564f03a797block: mark bounce buffering as incompatible with integrity [2 files, +5/-2]82209faa87ublk: complete command synchronously on error [1 file, +6/-5]b98aad5e5emedia: uvcvideo: Add sanity check to uvc_ioctl_xu_ctrl_map [1 file, +6/-0]2d6231d5cemedia: uvcvideo: Handle uvc menu translation inside uvc_get_le_value [1 file, +32/-45]e359d62886perf: arm_pmuv3: Call kvm_vcpu_pmu_resync_el0() before enabling counters [1 file, +2/-2]673dde8d3cbpf: Search and add kfuncs in struct_ops prologue and epilogue [1 file, +24/-1]083383aba0cpuidle: menu: Avoid discarding useful information [1 file, +12/-1]20a53c3689loop: check in LO_FLAGS_DIRECT_IO in loop_default_blocksize [1 file, +1/-1]b55a97d1bddm: fix unconditional IO throttle caused by REQ_PREFLUSH [1 file, +6/-2]9f27b38771crypto: ahash - Set default reqsize from ahash_alg [2 files, +7/-0]897c98fb32crypto: skcipher - Zap type in crypto_alloc_sync_skcipher [1 file, +1/-0]4d9fa2ebc0net: ipv6: Init tunnel link-netns before registering dev [4 files, +9/-7]53f42776e4genirq/msi: Store the IOMMU IOVA directly in msi_desc instead of iommu_cookie [2 files, +25/-36]2b129e89b8bpf: don't do clean_live_states when state->loop_entry->branches > 0 [1 file, +4/-0]46ba5757a7bpf: copy_verifier_state() should copy 'loop_entry' field [1 file, +3/-0]82b54455b6PCI: Fix old_size lower bound in calculate_iosize() too [1 file, +2/-4]dc5f5c9d2bhrtimers: Replace hrtimer_clock_to_base_table with switch-case [1 file, +12/-17]000dd6e344ASoC: ops: Enforce platform maximum on initial value [1 file, +28/-1]c4260bf83bASoC: soc-dai: check return value at snd_soc_dai_set_tdm_slot() [1 file, +5/-3]5b1b4cb46dpinctrl: devicetree: do not goto err when probing hogs in pinctrl_dt_to_map [1 file, +8/-2]69689d1138media: v4l: Memset argument to 0 before calling get_mbus_config pad op [2 files, +5/-1]e6e31b0182sched: Reduce the default slice to avoid tasks getting an extra tick [1 file, +3/-3]ef31dc41cfphy: core: don't require set_mode() callback for phy_get_mode() to work [1 file, +4/-3]06daedb443xfrm: prevent high SEQ input in non-ESN mode [1 file, +12/-0]9f2911868aip: fib_rules: Fetch net from fib_rule in fib[46]_rule_configure(). [2 files, +4/-4]7fea5a9140r8152: add vendor/device ID pair for Dell Alienware AW1022z [2 files, +2/-0]16ddd67bb5pstore: Change kmsg_bytes storage size to u32 [3 files, +9/-8]73733c2fdbext4: don't write back data before punch hole in nojournal mode [1 file, +5/-13]1d15319323f2fs: introduce f2fs_base_attr for global sysfs entries [1 file, +52/-22]ded26f9e4cipv4: ip_gre: Fix set but not used warning in ipgre_err() if IPv4-only [1 file, +10/-6]76e56dbe50net: flush_backlog() small changes [1 file, +8/-4]58cdd1ee65bridge: mdb: Allow replace of a host-joined group [2 files, +2/-2]fcabb69674rcu: handle unstable rdp in rcu_read_unlock_strict() [2 files, +11/-2]d402437cdercu: fix header guard for rcu_all_qs() [1 file, +1/-1]887e39ac47perf: Avoid the read if the count is already updated [3 files, +24/-18]c80b2d159cbpf: Use kallsyms to find the function name of a struct_ops's stub function [1 file, +44/-54]46f1c2b508firmware: arm_scmi: Relax duplicate name constraint across protocol ids [1 file, +6/-13]1351052877drm/atomic: clarify the rules around drm_atomic_state->allow_modeset [1 file, +21/-2]9fddd1f154drm: Add valid clones check [1 file, +28/-0]ff214b079dnvme-pci: add quirks for device 126f:1001 [1 file, +3/-0]6d196cae4bnvme-pci: add quirks for WDC Blue SN550 15b7:5009 [1 file, +3/-0]6a09b6bad0ALSA: usb-audio: Fix duplicated name in MIDI substream names [1 file, +12/-4]ad3e83a6c8io_uring/fdinfo: annotate racy sq/cq head/tail reads [1 file, +2/-2]7f7c8c03febtrfs: correct the order of prelim_ref arguments in btrfs__prelim_ref [1 file, +1/-1]8cafd7266f__legitimize_mnt(): check for MNT_SYNC_UMOUNT should be under mount_lock [1 file, +1/-5]28756f22deespintcp: fix skb leaks [3 files, +9/-3]9cbca30102espintcp: remove encap socket caching to avoid reference leak [4 files, +8/-94]b1a687eb15xfrm: Fix UDP GRO handling for some corner cases [2 files, +20/-16]447c8f0c06kernel/fork: only call untrack_pfn_clear() on VMAs duplicated for fork() [1 file, +5/-4]252f78a931xfrm: Sanitize marks before insert [2 files, +6/-0]7207effe47driver core: Split devres APIs to device/devres.h [2 files, +125/-118]1e8b7e96f7Bluetooth: L2CAP: Fix not checking l2cap_chan security level [1 file, +8/-7]cd7f022296loop: don't require ->write_iter for writable files in loop_configure [1 file, +0/-3]873ebaf3c1io_uring: fix overflow resched cqe reordering [1 file, +1/-0]689a205cd9net/tipc: fix slab-use-after-free Read in tipc_aead_encrypt_done [1 file, +5/-0]adb05149a9can: slcan: allow reception of short error messages [1 file, +20/-6]cc55dd28c2can: bcm: add locking for bcm_op runtime updates [1 file, +45/-21]63567ecd99can: bcm: add missing rcu read protection for procfs content [1 file, +9/-4]bf85e49aafALSA: pcm: Fix race of buffer access at PCM OSS layer [3 files, +14/-2]e78908caf1pmdomain: core: Fix error checking in genpd_dev_pm_attach_by_id() [1 file, +1/-1]dc9bdfb9b0drm/edid: fixed the bug that hdr metadata was not reset [1 file, +1/-0]cb9a1019a6Input: xpad - add more controllers [1 file, +3/-0]9b8263cae6highmem: add folio_test_partial_kmap() [2 files, +12/-5]314bf771cbmemcg: always call cond_resched() after fn() [1 file, +2/-4]9da33ce114mm/page_alloc.c: avoid infinite retries caused by cpuset race [1 file, +8/-0]9f9517f156mm: mmap: map MAP_STACK to VM_NOHUGEPAGE only if THP is enabled [1 file, +2/-0]94efb0d656mm: vmalloc: actually use the in-place vrealloc region [1 file, +1/-0]483ac74183mm: vmalloc: only zero-init on vrealloc shrink [1 file, +7/-5]1d45e0170cspi: use container_of_cont() for to_spi_device() [1 file, +1/-4]d28b0305f7err.h: move IOMEM_ERR_PTR() to err.h [2 files, +3/-2]80eb73778dbpf: abort verification if env->cur_state->loop_entry != NULL [1 file, +4/-2]85fb1edd05drm/gem: Internally test import_attach for imported objects [1 file, +1/-2] Changes in 6.12.31 drm/amd/display: Configure DTBCLK_P with OPTC only for dcn401 drm/amd/display: Do not enable replay when vtotal update is pending. drm/amd/display: Correct timing_adjust_pending flag setting. drm/amd/display: Defer BW-optimization-blocked DRR adjustments i2c: designware: Use temporary variable for struct device i2c: designware: Fix an error handling path in i2c_dw_pci_probe() phy: renesas: rcar-gen3-usb2: Move IRQ request in probe phy: renesas: rcar-gen3-usb2: Lock around hardware registers and driver data phy: renesas: rcar-gen3-usb2: Assert PLL reset on PHY power off cpufreq: Add SM8650 to cpufreq-dt-platdev blocklist nvmem: rockchip-otp: Move read-offset into variant-data nvmem: rockchip-otp: add rk3576 variant data nvmem: core: fix bit offsets of more than one byte nvmem: core: verify cell's raw_len nvmem: core: update raw_len if the bit reading is required nvmem: qfprom: switch to 4-byte aligned reads scsi: target: iscsi: Fix timeout on deleted connection scsi: ufs: Introduce quirk to extend PA_HIBERN8TIME for UFS devices virtio_ring: Fix data race by tagging event_triggered as racy for KCSAN dma/mapping.c: dev_dbg support for dma_addressing_limited intel_th: avoid using deprecated page->mapping, index fields mei: vsc: Use struct vsc_tp_packet as vsc-tp tx_buf and rx_buf type dma-mapping: avoid potential unused data compilation warning cgroup: Fix compilation issue due to cgroup_mutex not being exported vhost_task: fix vhost_task_create() documentation vhost-scsi: protect vq->log_used with vq->mutex scsi: mpi3mr: Add level check to control event logging net: enetc: refactor bulk flipping of RX buffers to separate function dma-mapping: Fix warning reported for missing prototype ima: process_measurement() needlessly takes inode_lock() on MAY_READ fs/buffer: split locking for pagecache lookups fs/buffer: introduce sleeping flavors for pagecache lookups fs/buffer: use sleeping version of __find_get_block() fs/ocfs2: use sleeping version of __find_get_block() fs/jbd2: use sleeping version of __find_get_block() fs/ext4: use sleeping version of sb_find_get_block() drm/amd/display: Enable urgent latency adjustment on DCN35 drm/amdgpu: Allow P2P access through XGMI selftests/bpf: Mitigate sockmap_ktls disconnect_after_delete failure block: fix race between set_blocksize and read paths io_uring: don't duplicate flushing in io_req_post_cqe bpf: fix possible endless loop in BPF map iteration samples/bpf: Fix compilation failure for samples/bpf on LoongArch Fedora kconfig: merge_config: use an empty file as initfile x86/fred: Fix system hang during S4 resume with FRED enabled s390/vfio-ap: Fix no AP queue sharing allowed message written to kernel log cifs: Add fallback for SMB2 CREATE without FILE_READ_ATTRIBUTES cifs: Fix querying and creating MF symlinks over SMB1 cifs: Fix negotiate retry functionality smb: client: Store original IO parameters and prevent zero IO sizes fuse: Return EPERM rather than ENOSYS from link() exfat: call bh_read in get_block only when necessary io_uring/msg: initialise msg request opcode NFSv4: Check for delegation validity in nfs_start_delegation_return_locked() NFS: Don't allow waiting for exiting tasks SUNRPC: Don't allow waiting for exiting tasks arm64: Add support for HIP09 Spectre-BHB mitigation iommufd: Extend IOMMU_GET_HW_INFO to report PASID capability tracing: Mark binary printing functions with __printf() attribute ACPI: PNP: Add Intel OC Watchdog IDs to non-PNP device list tpm: Convert warn to dbg in tpm2_start_auth_session() mailbox: pcc: Use acpi_os_ioremap() instead of ioremap() mailbox: use error ret code of of_parse_phandle_with_args() riscv: Allow NOMMU kernels to access all of RAM fbdev: fsl-diu-fb: add missing device_remove_file() fbcon: Use correct erase colour for clearing in fbcon fbdev: core: tileblit: Implement missing margin clearing for tileblit cifs: Set default Netbios RFC1001 server name to hostname in UNC cifs: add validation check for the fields in smb_aces cifs: Fix establishing NetBIOS session for SMB2+ connection NFSv4: Treat ENETUNREACH errors as fatal for state recovery SUNRPC: rpc_clnt_set_transport() must not change the autobind setting SUNRPC: rpcbind should never reset the port to the value '0' spi-rockchip: Fix register out of bounds access ASoC: codecs: wsa884x: Correct VI sense channel mask ASoC: codecs: wsa883x: Correct VI sense channel mask mctp: Fix incorrect tx flow invalidation condition in mctp-i2c net: tn40xx: add pci-id of the aqr105-based Tehuti TN4010 cards net: tn40xx: create swnode for mdio and aqr105 phy and add to mdiobus thermal/drivers/mediatek/lvts: Start sensor interrupts disabled thermal/drivers/qoriq: Power down TMU on system suspend Bluetooth: btmtksdio: Prevent enabling interrupts after IRQ handler removal Bluetooth: Disable SCO support if READ_VOICE_SETTING is unsupported/broken dql: Fix dql->limit value when reset. lockdep: Fix wait context check on softirq for PREEMPT_RT objtool: Properly disable uaccess validation PCI: dwc: ep: Ensure proper iteration over outbound map windows r8169: disable RTL8126 ZRX-DC timeout tools/build: Don't pass test log files to linker pNFS/flexfiles: Report ENETDOWN as a connection error drm/amdgpu/discovery: check ip_discovery fw file available drm/amdkfd: set precise mem ops caps to disabled for gfx 11 and 12 PCI: vmd: Disable MSI remapping bypass under Xen xen/pci: Do not register devices with segments >= 0x10000 ext4: on a remount, only log the ro or r/w state when it has changed libnvdimm/labels: Fix divide error in nd_label_data_init() pidfs: improve multi-threaded exec and premature thread-group leader exit polling staging: vchiq_arm: Create keep-alive thread during probe mmc: host: Wait for Vdd to settle on card power off drm/amdgpu: Skip pcie_replay_count sysfs creation for VF cgroup/rstat: avoid disabling irqs for O(num_cpu) wifi: mt76: only mark tx-status-failed frames as ACKed on mt76x0/2 wifi: mt76: mt7996: fix SER reset trigger on WED reset wifi: mt76: mt7996: revise TXS size wifi: mt76: mt7925: load the appropriate CLC data based on hardware type wifi: mt76: mt7925: fix fails to enter low power mode in suspend state x86/headers: Replace __ASSEMBLY__ with __ASSEMBLER__ in UAPI headers x86/stackprotector/64: Only export __ref_stack_chk_guard on CONFIG_SMP x86/smpboot: Fix INIT delay assignment for extended Intel Families x86/microcode: Update the Intel processor flag scan check x86/mm: Check return value from memblock_phys_alloc_range() i2c: qup: Vote for interconnect bandwidth to DRAM i2c: pxa: fix call balance of i2c->clk handling routines btrfs: make btrfs_discard_workfn() block_group ref explicit btrfs: avoid linker error in btrfs_find_create_tree_block() btrfs: run btrfs_error_commit_super() early btrfs: fix non-empty delayed iputs list on unmount due to async workers btrfs: get zone unusable bytes while holding lock at btrfs_reclaim_bgs_work() btrfs: send: return -ENAMETOOLONG when attempting a path that is too long blk-cgroup: improve policy registration error handling drm/amdgpu: release xcp_mgr on exit drm/amd/display: Guard against setting dispclk low for dcn31x drm/amdgpu: adjust drm_firmware_drivers_only() handling i3c: master: svc: Fix missing STOP for master request s390/tlb: Use mm_has_pgste() instead of mm_alloc_pgste() dlm: make tcp still work in multi-link env clocksource/drivers/timer-riscv: Stop stimecmp when cpu hotplug um: Store full CSGSFS and SS register from mcontext um: Update min_low_pfn to match changes in uml_reserved wifi: mwifiex: Fix HT40 bandwidth issue. bnxt_en: Query FW parameters when the CAPS_CHANGE bit is set riscv: Call secondary mmu notifier when flushing the tlb ext4: reorder capability check last hypfs_create_cpu_files(): add missing check for hypfs_mkdir() failure scsi: st: Tighten the page format heuristics with MODE SELECT scsi: st: ERASE does not change tape location vfio/pci: Handle INTx IRQ_NOTCONNECTED bpf: Return prog btf_id without capable check PCI: dwc: Use resource start as ioremap() input in dw_pcie_pme_turn_off() jbd2: do not try to recover wiped journal tcp: reorganize tcp_in_ack_event() and tcp_count_delivered() rtc: rv3032: fix EERD location objtool: Fix error handling inconsistencies in check() thunderbolt: Do not add non-active NVM if NVM upgrade is disabled for retimer erofs: initialize decompression early spi: spi-mux: Fix coverity issue, unchecked return value ASoC: pcm6240: Drop bogus code handling IRQ as GPIO ASoC: mediatek: mt6359: Add stub for mt6359_accdet_enable_jack_detect bpf: Allow pre-ordering for bpf cgroup progs kbuild: fix argument parsing in scripts/config kconfig: do not clear SYMBOL_VALID when reading include/config/auto.conf crypto: octeontx2 - suppress auth failure screaming due to negative tests dm: restrict dm device size to 2^63-512 bytes net/smc: use the correct ndev to find pnetid by pnetid table xen: Add support for XenServer 6.1 platform device pinctrl-tegra: Restore SFSEL bit when freeing pins mfd: tps65219: Remove TPS65219_REG_TI_DEV_ID check drm/amdgpu/gfx12: don't read registers in mqd init drm/amdgpu/gfx11: don't read registers in mqd init drm/amdgpu: Update SRIOV video codec caps ASoC: sun4i-codec: support hp-det-gpios property clk: qcom: lpassaudiocc-sc7280: Add support for LPASS resets for QCM6490 ext4: reject the 'data_err=abort' option in nojournal mode ext4: do not convert the unwritten extents if data writeback fails RDMA/uverbs: Propagate errors from rdma_lookup_get_uobject() posix-timers: Add cond_resched() to posix_timer_add() search loop posix-timers: Ensure that timer initialization is fully visible net: stmmac: dwmac-rk: Validate GRF and peripheral GRF during probe net: hsr: Fix PRP duplicate detection timer_list: Don't use %pK through printk() wifi: rtw89: set force HE TB mode when connecting to 11ax AP netfilter: conntrack: Bound nf_conntrack sysctl writes PNP: Expand length of fixup id string phy: rockchip: usbdp: Only verify link rates/lanes/voltage when the corresponding set flags are set arm64/mm: Check pmd_table() in pmd_trans_huge() arm64/mm: Check PUD_TYPE_TABLE in pud_bad() mmc: dw_mmc: add exynos7870 DW MMC support mmc: sdhci: Disable SD card clock before changing parameters usb: xhci: Don't change the status of stalled TDs on failed Stop EP wifi: iwlwifi: mvm: fix setting the TK when associated hwmon: (dell-smm) Increment the number of fans iommu: Keep dev->iommu state consistent printk: Check CON_SUSPEND when unblanking a console wifi: iwlwifi: don't warn when if there is a FW error wifi: iwlwifi: w/a FW SMPS mode selection wifi: iwlwifi: fix debug actions order wifi: iwlwifi: mark Br device not integrated wifi: iwlwifi: fix the ECKV UEFI variable name wifi: mac80211: fix warning on disconnect during failed ML reconf wifi: mac80211_hwsim: Fix MLD address translation wifi: cfg80211: allow IR in 20 MHz configurations ipv6: save dontfrag in cork drm/amd/display: remove minimum Dispclk and apply oem panel timing. drm/amd/display: calculate the remain segments for all pipes drm/amd/display: not abort link train when bw is low drm/amd/display: Fix incorrect DPCD configs while Replay/PSR switch gfs2: Check for empty queue in run_queue auxdisplay: charlcd: Partially revert "Move hwidth and bwidth to struct hd44780_common" ASoC: qcom: sm8250: explicitly set format in sm8250_be_hw_params_fixup() badblocks: Fix a nonsense WARN_ON() which checks whether a u64 variable < 0 coresight-etb10: change etb_drvdata spinlock's type to raw_spinlock_t iommu/amd/pgtbl_v2: Improve error handling cpufreq: tegra186: Share policy per cluster watchdog: aspeed: Update bootstatus handling PCI: endpoint: pci-epf-test: Fix double free that causes kernel to oops misc: pci_endpoint_test: Give disabled BARs a distinct error code crypto: lzo - Fix compression buffer overrun crypto: mxs-dcp - Only set OTP_KEY bit for OTP key drm/amdkfd: Set per-process flags only once for gfx9/10/11/12 drm/amdkfd: Set per-process flags only once cik/vi drm/amdgpu: Fix missing drain retry fault the last entry arm64: tegra: p2597: Fix gpio for vdd-1v8-dis regulator arm64: tegra: Resize aperture for the IGX PCIe C5 slot powerpc/prom_init: Fixup missing #size-cells on PowerBook6,7 ALSA: seq: Improve data consistency at polling tcp: bring back NUMA dispersion in inet_ehash_locks_alloc() rtc: ds1307: stop disabling alarms on probe ieee802154: ca8210: Use proper setters and getters for bitwise types drm/xe: Nuke VM's mapping upon close drm/xe: Retry BO allocation soc: samsung: include linux/array_size.h where needed ARM: tegra: Switch DSI-B clock parent to PLLD on Tegra114 media: c8sectpfe: Call of_node_put(i2c_bus) only once in c8sectpfe_probe() usb: xhci: set page size to the xHCI-supported size dm cache: prevent BUG_ON by blocking retries on failed device resumes soc: mediatek: mtk-mutex: Add DPI1 SOF/EOF to MT8188 mutex tables orangefs: Do not truncate file size drm/gem: Test for imported GEM buffers with helper net: phylink: use pl->link_interface in phylink_expects_phy() blk-throttle: don't take carryover for prioritized processing of metadata remoteproc: qcom_wcnss: Handle platforms with only single power domain drm/amdgpu: Do not program AGP BAR regs under SRIOV in gfxhub_v1_0.c drm/amd/display: Ensure DMCUB idle before reset on DCN31/DCN35 drm/amd/display: Skip checking FRL_MODE bit for PCON BW determination drm/amd/display: Fix DMUB reset sequence for DCN401 drm/amd/display: Fix p-state type when p-state is unsupported drm/amd/display: Request HW cursor on DCN3.2 with SubVP perf/core: Clean up perf_try_init_event() media: cx231xx: set device_caps for 417 pinctrl: bcm281xx: Use "unsigned int" instead of bare "unsigned" rcu: Fix get_state_synchronize_rcu_full() GP-start detection net: ethernet: ti: cpsw_new: populate netdev of_node net: phy: nxp-c45-tja11xx: add match_phy_device to TJA1103/TJA1104 dpll: Add an assertion to check freq_supported_num ublk: enforce ublks_max only for unprivileged devices iommufd: Disallow allocating nested parent domain with fault ID media: imx335: Set vblank immediately net: pktgen: fix mpls maximum labels list parsing perf/hw_breakpoint: Return EOPNOTSUPP for unsupported breakpoint type ALSA: hda/realtek: Enable PC beep passthrough for HP EliteBook 855 G7 scsi: logging: Fix scsi_logging_level bounds ipv4: fib: Move fib_valid_key_len() to rtm_to_fib_config(). drm/rockchip: vop2: Add uv swap for cluster window block: mark bounce buffering as incompatible with integrity ublk: complete command synchronously on error media: uvcvideo: Add sanity check to uvc_ioctl_xu_ctrl_map media: uvcvideo: Handle uvc menu translation inside uvc_get_le_value clk: imx8mp: inform CCF of maximum frequency of clocks x86/bugs: Make spectre user default depend on MITIGATION_SPECTRE_V2 hwmon: (gpio-fan) Add missing mutex locks ARM: at91: pm: fix at91_suspend_finish for ZQ calibration drm/mediatek: mtk_dpi: Add checks for reg_h_fre_con existence fpga: altera-cvp: Increase credit timeout perf: arm_pmuv3: Call kvm_vcpu_pmu_resync_el0() before enabling counters soc: apple: rtkit: Use high prio work queue soc: apple: rtkit: Implement OSLog buffers properly wifi: ath12k: Report proper tx completion status to mac80211 PCI: brcmstb: Expand inbound window size up to 64GB PCI: brcmstb: Add a softdep to MIP MSI-X driver firmware: arm_ffa: Set dma_mask for ffa devices drm/xe/vf: Retry sending MMIO request to GUC on timeout error drm/xe/pf: Create a link between PF and VF devices net/mlx5: Avoid report two health errors on same syndrome selftests/net: have `gro.sh -t` return a correct exit code pinctrl: sophgo: avoid to modify untouched bit when setting cv1800 pinconf drm/amdkfd: KFD release_work possible circular locking drm/xe: xe_gen_wa_oob: replace program_invocation_short_name leds: pwm-multicolor: Add check for fwnode_property_read_u32 net: ethernet: mtk_ppe_offload: Allow QinQ, double ETH_P_8021Q only net: xgene-v2: remove incorrect ACPI_PTR annotation bonding: report duplicate MAC address in all situations wifi: ath12k: Improve BSS discovery with hidden SSID in 6 GHz band soc: ti: k3-socinfo: Do not use syscon helper to build regmap bpf: Search and add kfuncs in struct_ops prologue and epilogue Octeontx2-af: RPM: Register driver with PCI subsys IDs x86/build: Fix broken copy command in genimage.sh when making isoimage drm/amd/display: handle max_downscale_src_width fail check drm/amd/display: fix dcn4x init failed drm/amd/display: Fix mismatch type comparison ASoC: mediatek: mt8188: Treat DMIC_GAINx_CUR as non-volatile ASoC: mediatek: mt8188: Add reference for dmic clocks x86/nmi: Add an emergency handler in nmi_desc & use it in nmi_shootdown_cpus() vhost-scsi: Return queue full for page alloc failures during copy vdpa/mlx5: Fix mlx5_vdpa_get_config() endianness on big-endian machines cpuidle: menu: Avoid discarding useful information media: adv7180: Disable test-pattern control on adv7180 media: tc358746: improve calculation of the D-PHY timing registers net/mlx5e: Add correct match to check IPSec syndromes for switchdev mode scsi: mpi3mr: Update timestamp only for supervisor IOCs loop: check in LO_FLAGS_DIRECT_IO in loop_default_blocksize libbpf: Fix out-of-bound read dm: fix unconditional IO throttle caused by REQ_PREFLUSH scsi: scsi_debug: First fixes for tapes net/mlx5: Change POOL_NEXT_SIZE define value and make it global x86/kaslr: Reduce KASLR entropy on most x86 systems crypto: ahash - Set default reqsize from ahash_alg crypto: skcipher - Zap type in crypto_alloc_sync_skcipher net: ipv6: Init tunnel link-netns before registering dev drm/xe/oa: Ensure that polled read returns latest data MIPS: Use arch specific syscall name match function drm/amdgpu: remove all KFD fences from the BO on release x86/locking: Use ALT_OUTPUT_SP() for percpu_{,try_}cmpxchg{64,128}_op() genirq/msi: Store the IOMMU IOVA directly in msi_desc instead of iommu_cookie MIPS: pm-cps: Use per-CPU variables as per-CPU, not per-core clocksource: mips-gic-timer: Enable counter when CPUs start PCI: epf-mhi: Update device ID for SA8775P scsi: mpt3sas: Send a diag reset if target reset fails wifi: rtw88: Fix rtw_init_vht_cap() for RTL8814AU wifi: rtw88: Fix rtw_init_ht_cap() for RTL8814AU wifi: rtw88: Fix rtw_desc_to_mcsrate() to handle MCS16-31 wifi: rtw89: fw: propagate error code from rtw89_h2c_tx() wifi: rtw89: fw: get sb_sel_ver via get_unaligned_le32() wifi: rtw89: fw: add blacklist to avoid obsolete secure firmware wifi: rtw89: 8922a: fix incorrect STA-ID in EHT MU PPDU net: pktgen: fix access outside of user given buffer in pktgen_thread_write() power: supply: axp20x_battery: Update temp sensor for AXP717 from device tree EDAC/ie31200: work around false positive build warning i3c: master: svc: Flush FIFO before sending Dynamic Address Assignment(DAA) mfd: axp20x: AXP717: Add AXP717_TS_PIN_CFG to writeable regs eeprom: ee1004: Check chip before probing irqchip/riscv-imsic: Separate next and previous pointers in IMSIC vector drm/amd/pm: Fetch current power limit from PMFW drm/amd/display: Add support for disconnected eDP streams drm/amd/display: Guard against setting dispclk low when active drm/amd/display: Fix BT2020 YCbCr limited/full range input drm/amd/display: Read LTTPR ALPM caps during link cap retrieval Revert "drm/amd/display: Request HW cursor on DCN3.2 with SubVP" drm/amd/display: Don't treat wb connector as physical in create_validate_stream_for_sink serial: mctrl_gpio: split disable_ms into sync and no_sync APIs RDMA/core: Fix best page size finding when it can cross SG entries pmdomain: imx: gpcv2: use proper helper for property detection can: c_can: Use of_property_present() to test existence of DT property bpf: don't do clean_live_states when state->loop_entry->branches > 0 bpf: copy_verifier_state() should copy 'loop_entry' field eth: mlx4: don't try to complete XDP frames in netpoll PCI: Fix old_size lower bound in calculate_iosize() too ACPI: HED: Always initialize before evged vxlan: Join / leave MC group after remote changes hrtimers: Replace hrtimer_clock_to_base_table with switch-case irqchip/riscv-imsic: Set irq_set_affinity() for IMSIC base media: test-drivers: vivid: don't call schedule in loop net/mlx5: Modify LSB bitmask in temperature event to include only the first bit net/mlx5: Apply rate-limiting to high temperature warning firmware: arm_ffa: Reject higher major version as incompatible firmware: arm_ffa: Handle the presence of host partition in the partition info firmware: xilinx: Dont send linux address to get fpga config get status ASoC: ops: Enforce platform maximum on initial value ASoC: tas2764: Add reg defaults for TAS2764_INT_CLK_CFG ASoC: tas2764: Mark SW_RESET as volatile ASoC: tas2764: Power up/down amp on mute ops ASoC: soc-dai: check return value at snd_soc_dai_set_tdm_slot() pinctrl: devicetree: do not goto err when probing hogs in pinctrl_dt_to_map smack: recognize ipv4 CIPSO w/o categories smack: Revert "smackfs: Added check catlen" kunit: tool: Use qboot on QEMU x86_64 media: i2c: imx219: Correct the minimum vblanking value media: v4l: Memset argument to 0 before calling get_mbus_config pad op net/mlx4_core: Avoid impossible mlx4_db_alloc() order value drm/xe: Stop ignoring errors from xe_ttm_stolen_mgr_init() drm/xe: Fix xe_tile_init_noalloc() error propagation clk: qcom: ipq5018: allow it to be bulid on arm32 clk: qcom: clk-alpha-pll: Do not use random stack value for recalc rate drm/xe/debugfs: fixed the return value of wedged_mode_set drm/xe/debugfs: Add missing xe_pm_runtime_put in wedge_mode_set x86/ibt: Handle FineIBT in handle_cfi_failure() x86/traps: Cleanup and robustify decode_bug() sched: Reduce the default slice to avoid tasks getting an extra tick serial: sh-sci: Update the suspend/resume support pinctrl: renesas: rzg2l: Add suspend/resume support for pull up/down phy: phy-rockchip-samsung-hdptx: Swap the definitions of LCPLL_REF and ROPLL_REF phy: core: don't require set_mode() callback for phy_get_mode() to work phy: exynos5-usbdrd: fix EDS distribution tuning (gs101) soundwire: amd: change the soundwire wake enable/disable sequence soundwire: cadence_master: set frame shape and divider based on actual clk freq net: stmmac: dwmac-loongson: Set correct {tx,rx}_fifo_size drm/amdgpu/mes11: fix set_hw_resources_1 calculation drm/amdkfd: fix missing L2 cache info in topology drm/amdgpu: Set snoop bit for SDMA for MI series drm/amd/display: pass calculated dram_speed_mts to dml2 drm/amd/display: Don't try AUX transactions on disconnected link drm/amdgpu: reset psp->cmd to NULL after releasing the buffer drm/amd/pm: Skip P2S load for SMU v13.0.12 drm/amd/display: Support multiple options during psr entry. Revert "drm/amd/display: Exit idle optimizations before attempt to access PHY" drm/amd/display: Update CR AUX RD interval interpretation drm/amd/display: Initial psr_version with correct setting drm/amd/display: Increase block_sequence array size drm/amd/display: Use Nominal vBlank If Provided Instead Of Capping It drm/amd/display: Populate register address for dentist for dcn401 drm/amdgpu: Use active umc info from discovery drm/amdgpu: enlarge the VBIOS binary size limit drm/amd/display/dm: drop hw_support check in amdgpu_dm_i2c_xfer() scsi: target: spc: Fix loop traversal in spc_rsoc_get_descr() net/mlx5: XDP, Enable TX side XDP multi-buffer support net/mlx5: Extend Ethtool loopback selftest to support non-linear SKB net/mlx5e: set the tx_queue_len for pfifo_fast net/mlx5e: reduce rep rxq depth to 256 for ECPF net/mlx5e: reduce the max log mpwrq sz for ECPF and reps drm/v3d: Add clock handling xfrm: prevent high SEQ input in non-ESN mode wifi: ath12k: fix the ampdu id fetch in the HAL_RX_MPDU_START TLV mptcp: pm: userspace: flags: clearer msg if no remote addr wifi: iwlwifi: use correct IMR dump variable wifi: iwlwifi: don't warn during reprobe wifi: mac80211: don't unconditionally call drv_mgd_complete_tx() wifi: mac80211: remove misplaced drv_mgd_complete_tx() call wifi: mac80211: set ieee80211_prep_tx_info::link_id upon Auth Rx net: fec: Refactor MAC reset to function powerpc/pseries/iommu: memory notifier incorrectly adds TCEs for pmemory powerpc/pseries/iommu: create DDW for devices with DMA mask less than 64-bits arch/powerpc/perf: Check the instruction type before creating sample with perf_mem_data_src ip: fib_rules: Fetch net from fib_rule in fib[46]_rule_configure(). r8152: add vendor/device ID pair for Dell Alienware AW1022z iio: adc: ad7944: don't use storagebits for sizing pstore: Change kmsg_bytes storage size to u32 leds: trigger: netdev: Configure LED blink interval for HW offload ext4: don't write back data before punch hole in nojournal mode ext4: remove writable userspace mappings before truncating page cache wifi: rtw88: Fix download_firmware_validate() for RTL8814AU wifi: rtw88: Fix __rtw_download_firmware() for RTL8814AU wifi: rtw89: coex: Assign value over than 0 to avoid firmware timer hang wifi: rtw89: fw: validate multi-firmware header before getting its size wifi: rtw89: fw: validate multi-firmware header before accessing wifi: rtw89: call power_on ahead before selecting firmware clk: qcom: camcc-sm8250: Use clk_rcg2_shared_ops for some RCGs net: page_pool: avoid false positive warning if NAPI was never added tools/power turbostat: Clustered Uncore MHz counters should honor show/hide options hwmon: (xgene-hwmon) use appropriate type for the latency value f2fs: introduce f2fs_base_attr for global sysfs entries media: qcom: camss: csid: Only add TPG v4l2 ctrl if TPG hardware is available media: qcom: camss: Add default case in vfe_src_pad_code drm/rockchip: vop2: Improve display modes handling on RK3588 HDMI0 eth: fbnic: set IFF_UNICAST_FLT to avoid enabling promiscuous mode when adding unicast addrs tools: ynl-gen: don't output external constants net/mlx5e: Avoid WARN_ON when configuring MQPRIO with HTB offload enabled cpufreq: amd-pstate: Remove unnecessary driver_lock in set_boost vxlan: Annotate FDB data races ipv4: ip_gre: Fix set but not used warning in ipgre_err() if IPv4-only r8169: don't scan PHY addresses > 0 net: flush_backlog() small changes bridge: mdb: Allow replace of a host-joined group ice: init flow director before RDMA ice: treat dyn_allowed only as suggestion rcu: handle quiescent states for PREEMPT_RCU=n, PREEMPT_COUNT=y rcu: handle unstable rdp in rcu_read_unlock_strict() rcu: fix header guard for rcu_all_qs() perf: Avoid the read if the count is already updated ice: count combined queues using Rx/Tx count drm/xe/relay: Don't use GFP_KERNEL for new transactions net/mana: fix warning in the writer of client oob scsi: lpfc: Handle duplicate D_IDs in ndlp search-by D_ID routine scsi: lpfc: Ignore ndlp rport mismatch in dev_loss_tmo callbk scsi: lpfc: Free phba irq in lpfc_sli4_enable_msi() when pci_irq_vector() fails scsi: st: Restore some drive settings after reset wifi: ath12k: Avoid napi_sync() before napi_enable() HID: usbkbd: Fix the bit shift number for LED_KANA arm64: zynqmp: add clock-output-names property in clock nodes ASoC: codecs: pcm3168a: Allow for 24-bit in provider mode ASoC: rt722-sdca: Add some missing readable registers irqchip/riscv-aplic: Add support for hart indexes dm vdo indexer: prevent unterminated string warning dm vdo: use a short static string for thread name prefix drm/ast: Find VBIOS mode from regular display size bpf: Use kallsyms to find the function name of a struct_ops's stub function bpftool: Fix readlink usage in get_fd_type firmware: arm_scmi: Relax duplicate name constraint across protocol ids perf/amd/ibs: Fix perf_ibs_op.cnt_mask for CurCnt perf/amd/ibs: Fix ->config to sample period calculation for OP PMU clk: renesas: rzg2l-cpg: Refactor Runtime PM clock validation wifi: rtl8xxxu: retry firmware download on error wifi: rtw88: Don't use static local variable in rtw8822b_set_tx_power_index_by_rate wifi: rtw89: add wiphy_lock() to work that isn't held wiphy_lock() yet spi: zynqmp-gqspi: Always acknowledge interrupts regulator: ad5398: Add device tree support wifi: ath12k: fix ath12k_hal_tx_cmd_ext_desc_setup() info1 override accel/qaic: Mask out SR-IOV PCI resources drm/xe/pf: Reset GuC VF config when unprovisioning critical resource wifi: ath9k: return by of_get_mac_address wifi: ath12k: Fetch regdb.bin file from board-2.bin wifi: ath12k: Fix end offset bit definition in monitor ring descriptor drm: bridge: adv7511: fill stream capabilities drm/nouveau: fix the broken marco GSP_MSG_MAX_SIZE wifi: ath11k: Use dma_alloc_noncoherent for rx_tid buffer allocation drm/xe: Move suballocator init to after display init drm/xe: Do not attempt to bootstrap VF in execlists mode wifi: rtw89: coex: Separated Wi-Fi connecting event from Wi-Fi scan event drm/xe/sa: Always call drm_suballoc_manager_fini() drm/xe: Reject BO eviction if BO is bound to current VM drm/atomic: clarify the rules around drm_atomic_state->allow_modeset drm/buddy: fix issue that force_merge cannot free all roots drm/panel-edp: Add Starry 116KHD024006 drm: Add valid clones check ASoC: imx-card: Adjust over allocation of memory in imx_card_parse_of() book3s64/radix: Fix compile errors when CONFIG_ARCH_WANT_OPTIMIZE_DAX_VMEMMAP=n pinctrl: meson: define the pull up/down resistor value as 60 kOhm smb: server: smb2pdu: check return value of xa_store() platform/x86/intel: hid: Add Pantherlake support platform/x86: asus-wmi: Disable OOBE state after resume from hibernation platform/x86: ideapad-laptop: add support for some new buttons ASoC: cs42l43: Disable headphone clamps during type detection ASoC: Intel: bytcr_rt5640: Add DMI quirk for Acer Aspire SW3-013 ALSA: hda/realtek: Add quirk for HP Spectre x360 15-df1xxx nvme-pci: add quirks for device 126f:1001 nvme-pci: add quirks for WDC Blue SN550 15b7:5009 ALSA: usb-audio: Fix duplicated name in MIDI substream names nvmet-tcp: don't restore null sk_state_change io_uring/fdinfo: annotate racy sq/cq head/tail reads cifs: Fix and improve cifs_query_path_info() and cifs_query_file_info() cifs: Fix changing times and read-only attr over SMB1 smb_set_file_info() function ASoC: intel/sdw_utils: Add volume limit to cs42l43 speakers btrfs: compression: adjust cb->compressed_folios allocation type btrfs: correct the order of prelim_ref arguments in btrfs__prelim_ref btrfs: handle empty eb->folios in num_extent_folios() btrfs: avoid NULL pointer dereference if no valid csum tree tools: ynl-gen: validate 0 len strings from kernel block: only update request sector if needed wifi: iwlwifi: add support for Killer on MTL x86/Kconfig: make CFI_AUTO_DEFAULT depend on !RUST or Rust >= 1.88 xenbus: Allow PVH dom0 a non-local xenstore drm/amd/display: Call FP Protect Before Mode Programming/Mode Support __legitimize_mnt(): check for MNT_SYNC_UMOUNT should be under mount_lock soundwire: bus: Fix race on the creation of the IRQ domain espintcp: fix skb leaks espintcp: remove encap socket caching to avoid reference leak xfrm: Fix UDP GRO handling for some corner cases dmaengine: idxd: Fix allowing write() from different address spaces x86/sev: Fix operator precedence in GHCB_MSR_VMPL_REQ_LEVEL macro kernel/fork: only call untrack_pfn_clear() on VMAs duplicated for fork() remoteproc: qcom_wcnss: Fix on platforms without fallback regulators clk: sunxi-ng: d1: Add missing divider for MMC mod clocks xfrm: Sanitize marks before insert dmaengine: idxd: Fix ->poll() return value dmaengine: fsl-edma: Fix return code for unhandled interrupts driver core: Split devres APIs to device/devres.h devres: Introduce devm_kmemdup_array() ASoC: SOF: Intel: hda: Fix UAF when reloading module irqchip/riscv-imsic: Start local sync timer on correct CPU perf/x86/intel: Fix segfault with PEBS-via-PT with sample_freq Bluetooth: L2CAP: Fix not checking l2cap_chan security level Bluetooth: btusb: use skb_pull to avoid unsafe access in QCA dump handling ptp: ocp: Limit signal/freq counts in summary output functions bridge: netfilter: Fix forwarding of fragmented packets ice: fix vf->num_mac count with port representors ice: Fix LACP bonds without SRIOV environment idpf: fix null-ptr-deref in idpf_features_check loop: don't require ->write_iter for writable files in loop_configure pinctrl: qcom: switch to devm_register_sys_off_handler() net: dwmac-sun8i: Use parsed internal PHY address instead of 1 net: lan743x: Restore SGMII CTRL register on resume io_uring: fix overflow resched cqe reordering idpf: fix idpf_vport_splitq_napi_poll() sch_hfsc: Fix qlen accounting bug when using peek in hfsc_enqueue() octeontx2-pf: Add AF_XDP non-zero copy support net/tipc: fix slab-use-after-free Read in tipc_aead_encrypt_done octeontx2-af: Set LMT_ENA bit for APR table entries octeontx2-af: Fix APR entry mapping based on APR_LMT_CFG clk: s2mps11: initialise clk_hw_onecell_data::num before accessing ::hws[] in probe() crypto: algif_hash - fix double free in hash_accept padata: do not leak refcount in reorder_work can: slcan: allow reception of short error messages can: bcm: add locking for bcm_op runtime updates can: bcm: add missing rcu read protection for procfs content ASoC: SOF: ipc4-control: Use SOF_CTRL_CMD_BINARY as numid for bytes_ext ASoC: SOF: Intel: hda-bus: Use PIO mode on ACE2+ platforms ASoc: SOF: topology: connect DAI to a single DAI link ASoC: SOF: ipc4-pcm: Delay reporting is only supported for playback direction ALSA: pcm: Fix race of buffer access at PCM OSS layer ALSA: hda/realtek: Add quirk for Lenovo Yoga Pro 7 14ASP10 llc: fix data loss when reading from a socket in llc_ui_recvmsg() can: kvaser_pciefd: Continue parsing DMA buf after dropped RX can: kvaser_pciefd: Fix echo_skb race net: dsa: microchip: linearize skb for tail-tagging switches vmxnet3: update MTU after device quiesce pmdomain: renesas: rcar: Remove obsolete nullify checks pmdomain: core: Fix error checking in genpd_dev_pm_attach_by_id() platform/x86: dell-wmi-sysman: Avoid buffer overflow in current_password_store() thermal: intel: x86_pkg_temp_thermal: Fix bogus trip temperature drm/edid: fixed the bug that hdr metadata was not reset smb: client: Fix use-after-free in cifs_fill_dirent arm64: dts: marvell: uDPU: define pinctrl state for alarm LEDs smb: client: Reset all search buffer pointers when releasing buffer Revert "drm/amd: Keep display off while going into S4" Input: xpad - add more controllers highmem: add folio_test_partial_kmap() memcg: always call cond_resched() after fn() mm/page_alloc.c: avoid infinite retries caused by cpuset race mm: mmap: map MAP_STACK to VM_NOHUGEPAGE only if THP is enabled mm: vmalloc: actually use the in-place vrealloc region mm: vmalloc: only zero-init on vrealloc shrink nilfs2: fix deadlock warnings caused by lock dependency in init_nilfs() Bluetooth: btmtksdio: Check function enabled before doing close Bluetooth: btmtksdio: Do close if SDIO card removed without close Revert "arm64: dts: allwinner: h6: Use RSB for AXP805 PMIC connection" ksmbd: fix stream write failure platform/x86: think-lmi: Fix attribute name usage for non-compliant items spi: use container_of_cont() for to_spi_device() spi: spi-fsl-dspi: restrict register range for regmap access spi: spi-fsl-dspi: Halt the module after a new message transfer spi: spi-fsl-dspi: Reset SR flags before sending a new message err.h: move IOMEM_ERR_PTR() to err.h gcc-15: make 'unterminated string initialization' just a warning gcc-15: disable '-Wunterminated-string-initialization' entirely for now Fix mis-uses of 'cc-option' for warning disablement kbuild: Properly disable -Wunterminated-string-initialization for clang drm/amd/display: Exit idle optimizations before accessing PHY bpf: abort verification if env->cur_state->loop_entry != NULL serial: sh-sci: Save and restore more registers drm/amdkfd: Correct F8_MODE for gfx950 watchdog: aspeed: fix 64-bit division pinctrl: tegra: Fix off by one in tegra_pinctrl_get_group() i3c: master: svc: Fix implicit fallthrough in svc_i3c_master_ibi_work() x86/mm/init: Handle the special case of device private pages in add_pages(), to not increase max_pfn and trigger dma_addressing_limited() bounce buffers bounce buffers drm/gem: Internally test import_attach for imported objects Linux 6.12.31 Change-Id: I017795966fb764f9320a6a0df1571d19e5e631fe Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
1232 lines
40 KiB
C
1232 lines
40 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Macros for manipulating and testing page->flags
|
|
*/
|
|
|
|
#ifndef PAGE_FLAGS_H
|
|
#define PAGE_FLAGS_H
|
|
|
|
#include <linux/types.h>
|
|
#include <linux/bug.h>
|
|
#include <linux/mmdebug.h>
|
|
#ifndef __GENERATING_BOUNDS_H
|
|
#include <linux/mm_types.h>
|
|
#include <generated/bounds.h>
|
|
#endif /* !__GENERATING_BOUNDS_H */
|
|
|
|
/*
|
|
* Various page->flags bits:
|
|
*
|
|
* PG_reserved is set for special pages. The "struct page" of such a page
|
|
* should in general not be touched (e.g. set dirty) except by its owner.
|
|
* Pages marked as PG_reserved include:
|
|
* - Pages part of the kernel image (including vDSO) and similar (e.g. BIOS,
|
|
* initrd, HW tables)
|
|
* - Pages reserved or allocated early during boot (before the page allocator
|
|
* was initialized). This includes (depending on the architecture) the
|
|
* initial vmemmap, initial page tables, crashkernel, elfcorehdr, and much
|
|
* much more. Once (if ever) freed, PG_reserved is cleared and they will
|
|
* be given to the page allocator.
|
|
* - Pages falling into physical memory gaps - not IORESOURCE_SYSRAM. Trying
|
|
* to read/write these pages might end badly. Don't touch!
|
|
* - The zero page(s)
|
|
* - Pages allocated in the context of kexec/kdump (loaded kernel image,
|
|
* control pages, vmcoreinfo)
|
|
* - MMIO/DMA pages. Some architectures don't allow to ioremap pages that are
|
|
* not marked PG_reserved (as they might be in use by somebody else who does
|
|
* not respect the caching strategy).
|
|
* - MCA pages on ia64
|
|
* - Pages holding CPU notes for POWER Firmware Assisted Dump
|
|
* - Device memory (e.g. PMEM, DAX, HMM)
|
|
* Some PG_reserved pages will be excluded from the hibernation image.
|
|
* PG_reserved does in general not hinder anybody from dumping or swapping
|
|
* and is no longer required for remap_pfn_range(). ioremap might require it.
|
|
* Consequently, PG_reserved for a page mapped into user space can indicate
|
|
* the zero page, the vDSO, MMIO pages or device memory.
|
|
*
|
|
* The PG_private bitflag is set on pagecache pages if they contain filesystem
|
|
* specific data (which is normally at page->private). It can be used by
|
|
* private allocations for its own usage.
|
|
*
|
|
* During initiation of disk I/O, PG_locked is set. This bit is set before I/O
|
|
* and cleared when writeback _starts_ or when read _completes_. PG_writeback
|
|
* is set before writeback starts and cleared when it finishes.
|
|
*
|
|
* PG_locked also pins a page in pagecache, and blocks truncation of the file
|
|
* while it is held.
|
|
*
|
|
* page_waitqueue(page) is a wait queue of all tasks waiting for the page
|
|
* to become unlocked.
|
|
*
|
|
* PG_swapbacked is set when a page uses swap as a backing storage. This are
|
|
* usually PageAnon or shmem pages but please note that even anonymous pages
|
|
* might lose their PG_swapbacked flag when they simply can be dropped (e.g. as
|
|
* a result of MADV_FREE).
|
|
*
|
|
* PG_referenced, PG_reclaim are used for page reclaim for anonymous and
|
|
* file-backed pagecache (see mm/vmscan.c).
|
|
*
|
|
* PG_error is set to indicate that an I/O error occurred on this page.
|
|
*
|
|
* PG_arch_1 is an architecture specific page state bit. The generic code
|
|
* guarantees that this bit is cleared for a page when it first is entered into
|
|
* the page cache.
|
|
*
|
|
* PG_hwpoison indicates that a page got corrupted in hardware and contains
|
|
* data with incorrect ECC bits that triggered a machine check. Accessing is
|
|
* not safe since it may cause another machine check. Don't touch!
|
|
*/
|
|
|
|
/*
|
|
* Don't use the pageflags directly. Use the PageFoo macros.
|
|
*
|
|
* The page flags field is split into two parts, the main flags area
|
|
* which extends from the low bits upwards, and the fields area which
|
|
* extends from the high bits downwards.
|
|
*
|
|
* | FIELD | ... | FLAGS |
|
|
* N-1 ^ 0
|
|
* (NR_PAGEFLAGS)
|
|
*
|
|
* The fields area is reserved for fields mapping zone, node (for NUMA) and
|
|
* SPARSEMEM section (for variants of SPARSEMEM that require section ids like
|
|
* SPARSEMEM_EXTREME with !SPARSEMEM_VMEMMAP).
|
|
*/
|
|
enum pageflags {
|
|
PG_locked, /* Page is locked. Don't touch. */
|
|
PG_writeback, /* Page is under writeback */
|
|
PG_referenced,
|
|
PG_uptodate,
|
|
PG_dirty,
|
|
PG_lru,
|
|
PG_head, /* Must be in bit 6 */
|
|
PG_waiters, /* Page has waiters, check its waitqueue. Must be bit #7 and in the same byte as "PG_locked" */
|
|
PG_active,
|
|
PG_workingset,
|
|
PG_error,
|
|
PG_owner_priv_1, /* Owner use. If pagecache, fs may use */
|
|
PG_owner_2, /* Owner use. If pagecache, fs may use */
|
|
PG_arch_1,
|
|
PG_reserved,
|
|
PG_private, /* If pagecache, has fs-private data */
|
|
PG_private_2, /* If pagecache, has fs aux data */
|
|
PG_reclaim, /* To be reclaimed asap */
|
|
PG_swapbacked, /* Page is backed by RAM/swap */
|
|
PG_unevictable, /* Page is "unevictable" */
|
|
#ifdef CONFIG_MMU
|
|
PG_mlocked, /* Page is vma mlocked */
|
|
#endif
|
|
#ifdef CONFIG_MEMORY_FAILURE
|
|
PG_hwpoison, /* hardware poisoned page. Don't touch */
|
|
#endif
|
|
#if defined(CONFIG_PAGE_IDLE_FLAG) && defined(CONFIG_64BIT)
|
|
PG_young,
|
|
PG_idle,
|
|
#endif
|
|
#ifdef CONFIG_ARCH_USES_PG_ARCH_2
|
|
PG_arch_2,
|
|
#endif
|
|
#ifdef CONFIG_ARCH_USES_PG_ARCH_3
|
|
PG_arch_3,
|
|
#endif
|
|
#ifdef CONFIG_64BIT
|
|
PG_oem_reserved_1,
|
|
PG_oem_reserved_2,
|
|
PG_oem_reserved_3,
|
|
PG_oem_reserved_4,
|
|
#endif
|
|
__NR_PAGEFLAGS,
|
|
|
|
PG_readahead = PG_reclaim,
|
|
|
|
/* Anonymous memory (and shmem) */
|
|
PG_swapcache = PG_owner_priv_1, /* Swap page: swp_entry_t in private */
|
|
/* Some filesystems */
|
|
PG_checked = PG_owner_priv_1,
|
|
|
|
/*
|
|
* Depending on the way an anonymous folio can be mapped into a page
|
|
* table (e.g., single PMD/PUD/CONT of the head page vs. PTE-mapped
|
|
* THP), PG_anon_exclusive may be set only for the head page or for
|
|
* tail pages of an anonymous folio. For now, we only expect it to be
|
|
* set on tail pages for PTE-mapped THP.
|
|
*/
|
|
PG_anon_exclusive = PG_owner_2,
|
|
|
|
/*
|
|
* Set if all buffer heads in the folio are mapped.
|
|
* Filesystems which do not use BHs can use it for their own purpose.
|
|
*/
|
|
PG_mappedtodisk = PG_owner_2,
|
|
|
|
/* Two page bits are conscripted by FS-Cache to maintain local caching
|
|
* state. These bits are set on pages belonging to the netfs's inodes
|
|
* when those inodes are being locally cached.
|
|
*/
|
|
PG_fscache = PG_private_2, /* page backed by cache */
|
|
|
|
/* XEN */
|
|
/* Pinned in Xen as a read-only pagetable page. */
|
|
PG_pinned = PG_owner_priv_1,
|
|
/* Pinned as part of domain save (see xen_mm_pin_all()). */
|
|
PG_savepinned = PG_dirty,
|
|
/* Has a grant mapping of another (foreign) domain's page. */
|
|
PG_foreign = PG_owner_priv_1,
|
|
/* Remapped by swiotlb-xen. */
|
|
PG_xen_remapped = PG_owner_priv_1,
|
|
|
|
/* non-lru isolated movable page */
|
|
PG_isolated = PG_reclaim,
|
|
|
|
/* Only valid for buddy pages. Used to track pages that are reported */
|
|
PG_reported = PG_uptodate,
|
|
|
|
#ifdef CONFIG_MEMORY_HOTPLUG
|
|
/* For self-hosted memmap pages */
|
|
PG_vmemmap_self_hosted = PG_owner_priv_1,
|
|
#endif
|
|
|
|
/*
|
|
* Flags only valid for compound pages. Stored in first tail page's
|
|
* flags word. Cannot use the first 8 flags or any flag marked as
|
|
* PF_ANY.
|
|
*/
|
|
|
|
/* At least one page in this folio has the hwpoison flag set */
|
|
PG_has_hwpoisoned = PG_error,
|
|
PG_large_rmappable = PG_workingset, /* anon or file-backed */
|
|
PG_partially_mapped = PG_reclaim, /* was identified to be partially mapped */
|
|
};
|
|
|
|
#define PAGEFLAGS_MASK ((1UL << NR_PAGEFLAGS) - 1)
|
|
|
|
#ifndef __GENERATING_BOUNDS_H
|
|
|
|
#ifdef CONFIG_HUGETLB_PAGE_OPTIMIZE_VMEMMAP
|
|
DECLARE_STATIC_KEY_FALSE(hugetlb_optimize_vmemmap_key);
|
|
|
|
/*
|
|
* Return the real head page struct iff the @page is a fake head page, otherwise
|
|
* return the @page itself. See Documentation/mm/vmemmap_dedup.rst.
|
|
*/
|
|
static __always_inline const struct page *page_fixed_fake_head(const struct page *page)
|
|
{
|
|
if (!static_branch_unlikely(&hugetlb_optimize_vmemmap_key))
|
|
return page;
|
|
|
|
/*
|
|
* Only addresses aligned with PAGE_SIZE of struct page may be fake head
|
|
* struct page. The alignment check aims to avoid access the fields (
|
|
* e.g. compound_head) of the @page[1]. It can avoid touch a (possibly)
|
|
* cold cacheline in some cases.
|
|
*/
|
|
if (IS_ALIGNED((unsigned long)page, PAGE_SIZE) &&
|
|
test_bit(PG_head, &page->flags)) {
|
|
/*
|
|
* We can safely access the field of the @page[1] with PG_head
|
|
* because the @page is a compound page composed with at least
|
|
* two contiguous pages.
|
|
*/
|
|
unsigned long head = READ_ONCE(page[1].compound_head);
|
|
|
|
if (likely(head & 1))
|
|
return (const struct page *)(head - 1);
|
|
}
|
|
return page;
|
|
}
|
|
#else
|
|
static inline const struct page *page_fixed_fake_head(const struct page *page)
|
|
{
|
|
return page;
|
|
}
|
|
#endif
|
|
|
|
static __always_inline int page_is_fake_head(const struct page *page)
|
|
{
|
|
return page_fixed_fake_head(page) != page;
|
|
}
|
|
|
|
static __always_inline unsigned long _compound_head(const struct page *page)
|
|
{
|
|
unsigned long head = READ_ONCE(page->compound_head);
|
|
|
|
if (unlikely(head & 1))
|
|
return head - 1;
|
|
return (unsigned long)page_fixed_fake_head(page);
|
|
}
|
|
|
|
#define compound_head(page) ((typeof(page))_compound_head(page))
|
|
|
|
/**
|
|
* page_folio - Converts from page to folio.
|
|
* @p: The page.
|
|
*
|
|
* Every page is part of a folio. This function cannot be called on a
|
|
* NULL pointer.
|
|
*
|
|
* Context: No reference, nor lock is required on @page. If the caller
|
|
* does not hold a reference, this call may race with a folio split, so
|
|
* it should re-check the folio still contains this page after gaining
|
|
* a reference on the folio.
|
|
* Return: The folio which contains this page.
|
|
*/
|
|
#define page_folio(p) (_Generic((p), \
|
|
const struct page *: (const struct folio *)_compound_head(p), \
|
|
struct page *: (struct folio *)_compound_head(p)))
|
|
|
|
/**
|
|
* folio_page - Return a page from a folio.
|
|
* @folio: The folio.
|
|
* @n: The page number to return.
|
|
*
|
|
* @n is relative to the start of the folio. This function does not
|
|
* check that the page number lies within @folio; the caller is presumed
|
|
* to have a reference to the page.
|
|
*/
|
|
#define folio_page(folio, n) nth_page(&(folio)->page, n)
|
|
|
|
static __always_inline int PageTail(const struct page *page)
|
|
{
|
|
return READ_ONCE(page->compound_head) & 1 || page_is_fake_head(page);
|
|
}
|
|
|
|
static __always_inline int PageCompound(const struct page *page)
|
|
{
|
|
return test_bit(PG_head, &page->flags) ||
|
|
READ_ONCE(page->compound_head) & 1;
|
|
}
|
|
|
|
#define PAGE_POISON_PATTERN -1l
|
|
static inline int PagePoisoned(const struct page *page)
|
|
{
|
|
return READ_ONCE(page->flags) == PAGE_POISON_PATTERN;
|
|
}
|
|
|
|
#ifdef CONFIG_DEBUG_VM
|
|
void page_init_poison(struct page *page, size_t size);
|
|
#else
|
|
static inline void page_init_poison(struct page *page, size_t size)
|
|
{
|
|
}
|
|
#endif
|
|
|
|
static const unsigned long *const_folio_flags(const struct folio *folio,
|
|
unsigned n)
|
|
{
|
|
const struct page *page = &folio->page;
|
|
|
|
VM_BUG_ON_PGFLAGS(page->compound_head & 1, page);
|
|
VM_BUG_ON_PGFLAGS(n > 0 && !test_bit(PG_head, &page->flags), page);
|
|
return &page[n].flags;
|
|
}
|
|
|
|
static unsigned long *folio_flags(struct folio *folio, unsigned n)
|
|
{
|
|
struct page *page = &folio->page;
|
|
|
|
VM_BUG_ON_PGFLAGS(page->compound_head & 1, page);
|
|
VM_BUG_ON_PGFLAGS(n > 0 && !test_bit(PG_head, &page->flags), page);
|
|
return &page[n].flags;
|
|
}
|
|
|
|
/*
|
|
* Page flags policies wrt compound pages
|
|
*
|
|
* PF_POISONED_CHECK
|
|
* check if this struct page poisoned/uninitialized
|
|
*
|
|
* PF_ANY:
|
|
* the page flag is relevant for small, head and tail pages.
|
|
*
|
|
* PF_HEAD:
|
|
* for compound page all operations related to the page flag applied to
|
|
* head page.
|
|
*
|
|
* PF_NO_TAIL:
|
|
* modifications of the page flag must be done on small or head pages,
|
|
* checks can be done on tail pages too.
|
|
*
|
|
* PF_NO_COMPOUND:
|
|
* the page flag is not relevant for compound pages.
|
|
*
|
|
* PF_SECOND:
|
|
* the page flag is stored in the first tail page.
|
|
*/
|
|
#define PF_POISONED_CHECK(page) ({ \
|
|
VM_BUG_ON_PGFLAGS(PagePoisoned(page), page); \
|
|
page; })
|
|
#define PF_ANY(page, enforce) PF_POISONED_CHECK(page)
|
|
#define PF_HEAD(page, enforce) PF_POISONED_CHECK(compound_head(page))
|
|
#define PF_NO_TAIL(page, enforce) ({ \
|
|
VM_BUG_ON_PGFLAGS(enforce && PageTail(page), page); \
|
|
PF_POISONED_CHECK(compound_head(page)); })
|
|
#define PF_NO_COMPOUND(page, enforce) ({ \
|
|
VM_BUG_ON_PGFLAGS(enforce && PageCompound(page), page); \
|
|
PF_POISONED_CHECK(page); })
|
|
#define PF_SECOND(page, enforce) ({ \
|
|
VM_BUG_ON_PGFLAGS(!PageHead(page), page); \
|
|
PF_POISONED_CHECK(&page[1]); })
|
|
|
|
/* Which page is the flag stored in */
|
|
#define FOLIO_PF_ANY 0
|
|
#define FOLIO_PF_HEAD 0
|
|
#define FOLIO_PF_NO_TAIL 0
|
|
#define FOLIO_PF_NO_COMPOUND 0
|
|
#define FOLIO_PF_SECOND 1
|
|
|
|
#define FOLIO_HEAD_PAGE 0
|
|
#define FOLIO_SECOND_PAGE 1
|
|
|
|
/*
|
|
* Macros to create function definitions for page flags
|
|
*/
|
|
#define FOLIO_TEST_FLAG(name, page) \
|
|
static __always_inline bool folio_test_##name(const struct folio *folio) \
|
|
{ return test_bit(PG_##name, const_folio_flags(folio, page)); }
|
|
|
|
#define FOLIO_SET_FLAG(name, page) \
|
|
static __always_inline void folio_set_##name(struct folio *folio) \
|
|
{ set_bit(PG_##name, folio_flags(folio, page)); }
|
|
|
|
#define FOLIO_CLEAR_FLAG(name, page) \
|
|
static __always_inline void folio_clear_##name(struct folio *folio) \
|
|
{ clear_bit(PG_##name, folio_flags(folio, page)); }
|
|
|
|
#define __FOLIO_SET_FLAG(name, page) \
|
|
static __always_inline void __folio_set_##name(struct folio *folio) \
|
|
{ __set_bit(PG_##name, folio_flags(folio, page)); }
|
|
|
|
#define __FOLIO_CLEAR_FLAG(name, page) \
|
|
static __always_inline void __folio_clear_##name(struct folio *folio) \
|
|
{ __clear_bit(PG_##name, folio_flags(folio, page)); }
|
|
|
|
#define FOLIO_TEST_SET_FLAG(name, page) \
|
|
static __always_inline bool folio_test_set_##name(struct folio *folio) \
|
|
{ return test_and_set_bit(PG_##name, folio_flags(folio, page)); }
|
|
|
|
#define FOLIO_TEST_CLEAR_FLAG(name, page) \
|
|
static __always_inline bool folio_test_clear_##name(struct folio *folio) \
|
|
{ return test_and_clear_bit(PG_##name, folio_flags(folio, page)); }
|
|
|
|
#define FOLIO_FLAG(name, page) \
|
|
FOLIO_TEST_FLAG(name, page) \
|
|
FOLIO_SET_FLAG(name, page) \
|
|
FOLIO_CLEAR_FLAG(name, page)
|
|
|
|
#define TESTPAGEFLAG(uname, lname, policy) \
|
|
FOLIO_TEST_FLAG(lname, FOLIO_##policy) \
|
|
static __always_inline int Page##uname(const struct page *page) \
|
|
{ return test_bit(PG_##lname, &policy(page, 0)->flags); }
|
|
|
|
#define SETPAGEFLAG(uname, lname, policy) \
|
|
FOLIO_SET_FLAG(lname, FOLIO_##policy) \
|
|
static __always_inline void SetPage##uname(struct page *page) \
|
|
{ set_bit(PG_##lname, &policy(page, 1)->flags); }
|
|
|
|
#define CLEARPAGEFLAG(uname, lname, policy) \
|
|
FOLIO_CLEAR_FLAG(lname, FOLIO_##policy) \
|
|
static __always_inline void ClearPage##uname(struct page *page) \
|
|
{ clear_bit(PG_##lname, &policy(page, 1)->flags); }
|
|
|
|
#define __SETPAGEFLAG(uname, lname, policy) \
|
|
__FOLIO_SET_FLAG(lname, FOLIO_##policy) \
|
|
static __always_inline void __SetPage##uname(struct page *page) \
|
|
{ __set_bit(PG_##lname, &policy(page, 1)->flags); }
|
|
|
|
#define __CLEARPAGEFLAG(uname, lname, policy) \
|
|
__FOLIO_CLEAR_FLAG(lname, FOLIO_##policy) \
|
|
static __always_inline void __ClearPage##uname(struct page *page) \
|
|
{ __clear_bit(PG_##lname, &policy(page, 1)->flags); }
|
|
|
|
#define TESTSETFLAG(uname, lname, policy) \
|
|
FOLIO_TEST_SET_FLAG(lname, FOLIO_##policy) \
|
|
static __always_inline int TestSetPage##uname(struct page *page) \
|
|
{ return test_and_set_bit(PG_##lname, &policy(page, 1)->flags); }
|
|
|
|
#define TESTCLEARFLAG(uname, lname, policy) \
|
|
FOLIO_TEST_CLEAR_FLAG(lname, FOLIO_##policy) \
|
|
static __always_inline int TestClearPage##uname(struct page *page) \
|
|
{ return test_and_clear_bit(PG_##lname, &policy(page, 1)->flags); }
|
|
|
|
#define PAGEFLAG(uname, lname, policy) \
|
|
TESTPAGEFLAG(uname, lname, policy) \
|
|
SETPAGEFLAG(uname, lname, policy) \
|
|
CLEARPAGEFLAG(uname, lname, policy)
|
|
|
|
#define __PAGEFLAG(uname, lname, policy) \
|
|
TESTPAGEFLAG(uname, lname, policy) \
|
|
__SETPAGEFLAG(uname, lname, policy) \
|
|
__CLEARPAGEFLAG(uname, lname, policy)
|
|
|
|
#define TESTSCFLAG(uname, lname, policy) \
|
|
TESTSETFLAG(uname, lname, policy) \
|
|
TESTCLEARFLAG(uname, lname, policy)
|
|
|
|
#define FOLIO_TEST_FLAG_FALSE(name) \
|
|
static inline bool folio_test_##name(const struct folio *folio) \
|
|
{ return false; }
|
|
#define FOLIO_SET_FLAG_NOOP(name) \
|
|
static inline void folio_set_##name(struct folio *folio) { }
|
|
#define FOLIO_CLEAR_FLAG_NOOP(name) \
|
|
static inline void folio_clear_##name(struct folio *folio) { }
|
|
#define __FOLIO_SET_FLAG_NOOP(name) \
|
|
static inline void __folio_set_##name(struct folio *folio) { }
|
|
#define __FOLIO_CLEAR_FLAG_NOOP(name) \
|
|
static inline void __folio_clear_##name(struct folio *folio) { }
|
|
#define FOLIO_TEST_SET_FLAG_FALSE(name) \
|
|
static inline bool folio_test_set_##name(struct folio *folio) \
|
|
{ return false; }
|
|
#define FOLIO_TEST_CLEAR_FLAG_FALSE(name) \
|
|
static inline bool folio_test_clear_##name(struct folio *folio) \
|
|
{ return false; }
|
|
|
|
#define FOLIO_FLAG_FALSE(name) \
|
|
FOLIO_TEST_FLAG_FALSE(name) \
|
|
FOLIO_SET_FLAG_NOOP(name) \
|
|
FOLIO_CLEAR_FLAG_NOOP(name)
|
|
|
|
#define TESTPAGEFLAG_FALSE(uname, lname) \
|
|
FOLIO_TEST_FLAG_FALSE(lname) \
|
|
static inline int Page##uname(const struct page *page) { return 0; }
|
|
|
|
#define SETPAGEFLAG_NOOP(uname, lname) \
|
|
FOLIO_SET_FLAG_NOOP(lname) \
|
|
static inline void SetPage##uname(struct page *page) { }
|
|
|
|
#define CLEARPAGEFLAG_NOOP(uname, lname) \
|
|
FOLIO_CLEAR_FLAG_NOOP(lname) \
|
|
static inline void ClearPage##uname(struct page *page) { }
|
|
|
|
#define __CLEARPAGEFLAG_NOOP(uname, lname) \
|
|
__FOLIO_CLEAR_FLAG_NOOP(lname) \
|
|
static inline void __ClearPage##uname(struct page *page) { }
|
|
|
|
#define TESTSETFLAG_FALSE(uname, lname) \
|
|
FOLIO_TEST_SET_FLAG_FALSE(lname) \
|
|
static inline int TestSetPage##uname(struct page *page) { return 0; }
|
|
|
|
#define TESTCLEARFLAG_FALSE(uname, lname) \
|
|
FOLIO_TEST_CLEAR_FLAG_FALSE(lname) \
|
|
static inline int TestClearPage##uname(struct page *page) { return 0; }
|
|
|
|
#define PAGEFLAG_FALSE(uname, lname) TESTPAGEFLAG_FALSE(uname, lname) \
|
|
SETPAGEFLAG_NOOP(uname, lname) CLEARPAGEFLAG_NOOP(uname, lname)
|
|
|
|
#define TESTSCFLAG_FALSE(uname, lname) \
|
|
TESTSETFLAG_FALSE(uname, lname) TESTCLEARFLAG_FALSE(uname, lname)
|
|
|
|
__PAGEFLAG(Locked, locked, PF_NO_TAIL)
|
|
FOLIO_FLAG(waiters, FOLIO_HEAD_PAGE)
|
|
PAGEFLAG(Error, error, PF_NO_TAIL) TESTCLEARFLAG(Error, error, PF_NO_TAIL)
|
|
FOLIO_FLAG(referenced, FOLIO_HEAD_PAGE)
|
|
FOLIO_TEST_CLEAR_FLAG(referenced, FOLIO_HEAD_PAGE)
|
|
__FOLIO_SET_FLAG(referenced, FOLIO_HEAD_PAGE)
|
|
PAGEFLAG(Dirty, dirty, PF_HEAD) TESTSCFLAG(Dirty, dirty, PF_HEAD)
|
|
__CLEARPAGEFLAG(Dirty, dirty, PF_HEAD)
|
|
PAGEFLAG(LRU, lru, PF_HEAD) __CLEARPAGEFLAG(LRU, lru, PF_HEAD)
|
|
TESTCLEARFLAG(LRU, lru, PF_HEAD)
|
|
FOLIO_FLAG(active, FOLIO_HEAD_PAGE)
|
|
__FOLIO_CLEAR_FLAG(active, FOLIO_HEAD_PAGE)
|
|
FOLIO_TEST_CLEAR_FLAG(active, FOLIO_HEAD_PAGE)
|
|
PAGEFLAG(Workingset, workingset, PF_HEAD)
|
|
TESTCLEARFLAG(Workingset, workingset, PF_HEAD)
|
|
PAGEFLAG(Checked, checked, PF_NO_COMPOUND) /* Used by some filesystems */
|
|
|
|
/* Xen */
|
|
PAGEFLAG(Pinned, pinned, PF_NO_COMPOUND)
|
|
TESTSCFLAG(Pinned, pinned, PF_NO_COMPOUND)
|
|
PAGEFLAG(SavePinned, savepinned, PF_NO_COMPOUND);
|
|
PAGEFLAG(Foreign, foreign, PF_NO_COMPOUND);
|
|
PAGEFLAG(XenRemapped, xen_remapped, PF_NO_COMPOUND)
|
|
TESTCLEARFLAG(XenRemapped, xen_remapped, PF_NO_COMPOUND)
|
|
|
|
PAGEFLAG(Reserved, reserved, PF_NO_COMPOUND)
|
|
__CLEARPAGEFLAG(Reserved, reserved, PF_NO_COMPOUND)
|
|
__SETPAGEFLAG(Reserved, reserved, PF_NO_COMPOUND)
|
|
FOLIO_FLAG(swapbacked, FOLIO_HEAD_PAGE)
|
|
__FOLIO_CLEAR_FLAG(swapbacked, FOLIO_HEAD_PAGE)
|
|
__FOLIO_SET_FLAG(swapbacked, FOLIO_HEAD_PAGE)
|
|
|
|
/*
|
|
* Private page markings that may be used by the filesystem that owns the page
|
|
* for its own purposes.
|
|
* - PG_private and PG_private_2 cause release_folio() and co to be invoked
|
|
*/
|
|
PAGEFLAG(Private, private, PF_ANY)
|
|
PAGEFLAG(Private2, private_2, PF_ANY) TESTSCFLAG(Private2, private_2, PF_ANY)
|
|
|
|
/* owner_2 can be set on tail pages for anon memory */
|
|
FOLIO_FLAG(owner_2, FOLIO_HEAD_PAGE)
|
|
|
|
/*
|
|
* Only test-and-set exist for PG_writeback. The unconditional operators are
|
|
* risky: they bypass page accounting.
|
|
*/
|
|
TESTPAGEFLAG(Writeback, writeback, PF_NO_TAIL)
|
|
TESTSCFLAG(Writeback, writeback, PF_NO_TAIL)
|
|
PAGEFLAG(MappedToDisk, mappedtodisk, PF_NO_TAIL)
|
|
|
|
/* PG_readahead is only used for reads; PG_reclaim is only for writes */
|
|
PAGEFLAG(Reclaim, reclaim, PF_NO_TAIL)
|
|
TESTCLEARFLAG(Reclaim, reclaim, PF_NO_TAIL)
|
|
FOLIO_FLAG(readahead, FOLIO_HEAD_PAGE)
|
|
FOLIO_TEST_CLEAR_FLAG(readahead, FOLIO_HEAD_PAGE)
|
|
|
|
#ifdef CONFIG_HIGHMEM
|
|
/*
|
|
* Must use a macro here due to header dependency issues. page_zone() is not
|
|
* available at this point.
|
|
*/
|
|
#define PageHighMem(__p) is_highmem_idx(page_zonenum(__p))
|
|
#define folio_test_highmem(__f) is_highmem_idx(folio_zonenum(__f))
|
|
#else
|
|
PAGEFLAG_FALSE(HighMem, highmem)
|
|
#endif
|
|
|
|
/* Does kmap_local_folio() only allow access to one page of the folio? */
|
|
#ifdef CONFIG_DEBUG_KMAP_LOCAL_FORCE_MAP
|
|
#define folio_test_partial_kmap(f) true
|
|
#else
|
|
#define folio_test_partial_kmap(f) folio_test_highmem(f)
|
|
#endif
|
|
|
|
#ifdef CONFIG_SWAP
|
|
static __always_inline bool folio_test_swapcache(const struct folio *folio)
|
|
{
|
|
return folio_test_swapbacked(folio) &&
|
|
test_bit(PG_swapcache, const_folio_flags(folio, 0));
|
|
}
|
|
|
|
FOLIO_SET_FLAG(swapcache, FOLIO_HEAD_PAGE)
|
|
FOLIO_CLEAR_FLAG(swapcache, FOLIO_HEAD_PAGE)
|
|
#else
|
|
FOLIO_FLAG_FALSE(swapcache)
|
|
#endif
|
|
|
|
FOLIO_FLAG(unevictable, FOLIO_HEAD_PAGE)
|
|
__FOLIO_CLEAR_FLAG(unevictable, FOLIO_HEAD_PAGE)
|
|
FOLIO_TEST_CLEAR_FLAG(unevictable, FOLIO_HEAD_PAGE)
|
|
|
|
#ifdef CONFIG_MMU
|
|
FOLIO_FLAG(mlocked, FOLIO_HEAD_PAGE)
|
|
__FOLIO_CLEAR_FLAG(mlocked, FOLIO_HEAD_PAGE)
|
|
FOLIO_TEST_CLEAR_FLAG(mlocked, FOLIO_HEAD_PAGE)
|
|
FOLIO_TEST_SET_FLAG(mlocked, FOLIO_HEAD_PAGE)
|
|
#else
|
|
FOLIO_FLAG_FALSE(mlocked)
|
|
__FOLIO_CLEAR_FLAG_NOOP(mlocked)
|
|
FOLIO_TEST_CLEAR_FLAG_FALSE(mlocked)
|
|
FOLIO_TEST_SET_FLAG_FALSE(mlocked)
|
|
#endif
|
|
|
|
#ifdef CONFIG_MEMORY_FAILURE
|
|
PAGEFLAG(HWPoison, hwpoison, PF_ANY)
|
|
TESTSCFLAG(HWPoison, hwpoison, PF_ANY)
|
|
#define __PG_HWPOISON (1UL << PG_hwpoison)
|
|
#else
|
|
PAGEFLAG_FALSE(HWPoison, hwpoison)
|
|
#define __PG_HWPOISON 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_PAGE_IDLE_FLAG
|
|
#ifdef CONFIG_64BIT
|
|
FOLIO_TEST_FLAG(young, FOLIO_HEAD_PAGE)
|
|
FOLIO_SET_FLAG(young, FOLIO_HEAD_PAGE)
|
|
FOLIO_TEST_CLEAR_FLAG(young, FOLIO_HEAD_PAGE)
|
|
FOLIO_FLAG(idle, FOLIO_HEAD_PAGE)
|
|
#endif
|
|
/* See page_idle.h for !64BIT workaround */
|
|
#else /* !CONFIG_PAGE_IDLE_FLAG */
|
|
FOLIO_FLAG_FALSE(young)
|
|
FOLIO_TEST_CLEAR_FLAG_FALSE(young)
|
|
FOLIO_FLAG_FALSE(idle)
|
|
#endif
|
|
|
|
/*
|
|
* PageReported() is used to track reported free pages within the Buddy
|
|
* allocator. We can use the non-atomic version of the test and set
|
|
* operations as both should be shielded with the zone lock to prevent
|
|
* any possible races on the setting or clearing of the bit.
|
|
*/
|
|
__PAGEFLAG(Reported, reported, PF_NO_COMPOUND)
|
|
|
|
#ifdef CONFIG_MEMORY_HOTPLUG
|
|
PAGEFLAG(VmemmapSelfHosted, vmemmap_self_hosted, PF_ANY)
|
|
#else
|
|
PAGEFLAG_FALSE(VmemmapSelfHosted, vmemmap_self_hosted)
|
|
#endif
|
|
|
|
/*
|
|
* On an anonymous folio mapped into a user virtual memory area,
|
|
* folio->mapping points to its anon_vma, not to a struct address_space;
|
|
* with the PAGE_MAPPING_ANON bit set to distinguish it. See rmap.h.
|
|
*
|
|
* On an anonymous page in a VM_MERGEABLE area, if CONFIG_KSM is enabled,
|
|
* the PAGE_MAPPING_MOVABLE bit may be set along with the PAGE_MAPPING_ANON
|
|
* bit; and then folio->mapping points, not to an anon_vma, but to a private
|
|
* structure which KSM associates with that merged page. See ksm.h.
|
|
*
|
|
* PAGE_MAPPING_KSM without PAGE_MAPPING_ANON is used for non-lru movable
|
|
* page and then folio->mapping points to a struct movable_operations.
|
|
*
|
|
* Please note that, confusingly, "folio_mapping" refers to the inode
|
|
* address_space which maps the folio from disk; whereas "folio_mapped"
|
|
* refers to user virtual address space into which the folio is mapped.
|
|
*
|
|
* For slab pages, since slab reuses the bits in struct page to store its
|
|
* internal states, the folio->mapping does not exist as such, nor do
|
|
* these flags below. So in order to avoid testing non-existent bits,
|
|
* please make sure that folio_test_slab(folio) actually evaluates to
|
|
* false before calling the following functions (e.g., folio_test_anon).
|
|
* See mm/slab.h.
|
|
*/
|
|
#define PAGE_MAPPING_ANON 0x1
|
|
#define PAGE_MAPPING_MOVABLE 0x2
|
|
#define PAGE_MAPPING_KSM (PAGE_MAPPING_ANON | PAGE_MAPPING_MOVABLE)
|
|
#define PAGE_MAPPING_FLAGS (PAGE_MAPPING_ANON | PAGE_MAPPING_MOVABLE)
|
|
|
|
/*
|
|
* Different with flags above, this flag is used only for fsdax mode. It
|
|
* indicates that this page->mapping is now under reflink case.
|
|
*/
|
|
#define PAGE_MAPPING_DAX_SHARED ((void *)0x1)
|
|
|
|
static __always_inline bool folio_mapping_flags(const struct folio *folio)
|
|
{
|
|
return ((unsigned long)folio->mapping & PAGE_MAPPING_FLAGS) != 0;
|
|
}
|
|
|
|
static __always_inline bool PageMappingFlags(const struct page *page)
|
|
{
|
|
return ((unsigned long)page->mapping & PAGE_MAPPING_FLAGS) != 0;
|
|
}
|
|
|
|
static __always_inline bool folio_test_anon(const struct folio *folio)
|
|
{
|
|
return ((unsigned long)folio->mapping & PAGE_MAPPING_ANON) != 0;
|
|
}
|
|
|
|
static __always_inline bool PageAnon(const struct page *page)
|
|
{
|
|
return folio_test_anon(page_folio(page));
|
|
}
|
|
|
|
static __always_inline bool __folio_test_movable(const struct folio *folio)
|
|
{
|
|
return ((unsigned long)folio->mapping & PAGE_MAPPING_FLAGS) ==
|
|
PAGE_MAPPING_MOVABLE;
|
|
}
|
|
|
|
static __always_inline bool __PageMovable(const struct page *page)
|
|
{
|
|
return ((unsigned long)page->mapping & PAGE_MAPPING_FLAGS) ==
|
|
PAGE_MAPPING_MOVABLE;
|
|
}
|
|
|
|
#ifdef CONFIG_KSM
|
|
/*
|
|
* A KSM page is one of those write-protected "shared pages" or "merged pages"
|
|
* which KSM maps into multiple mms, wherever identical anonymous page content
|
|
* is found in VM_MERGEABLE vmas. It's a PageAnon page, pointing not to any
|
|
* anon_vma, but to that page's node of the stable tree.
|
|
*/
|
|
static __always_inline bool folio_test_ksm(const struct folio *folio)
|
|
{
|
|
return ((unsigned long)folio->mapping & PAGE_MAPPING_FLAGS) ==
|
|
PAGE_MAPPING_KSM;
|
|
}
|
|
|
|
static __always_inline bool PageKsm(const struct page *page)
|
|
{
|
|
return folio_test_ksm(page_folio(page));
|
|
}
|
|
#else
|
|
TESTPAGEFLAG_FALSE(Ksm, ksm)
|
|
#endif
|
|
|
|
u64 stable_page_flags(const struct page *page);
|
|
|
|
/**
|
|
* folio_xor_flags_has_waiters - Change some folio flags.
|
|
* @folio: The folio.
|
|
* @mask: Bits set in this word will be changed.
|
|
*
|
|
* This must only be used for flags which are changed with the folio
|
|
* lock held. For example, it is unsafe to use for PG_dirty as that
|
|
* can be set without the folio lock held. It can also only be used
|
|
* on flags which are in the range 0-6 as some of the implementations
|
|
* only affect those bits.
|
|
*
|
|
* Return: Whether there are tasks waiting on the folio.
|
|
*/
|
|
static inline bool folio_xor_flags_has_waiters(struct folio *folio,
|
|
unsigned long mask)
|
|
{
|
|
return xor_unlock_is_negative_byte(mask, folio_flags(folio, 0));
|
|
}
|
|
|
|
/**
|
|
* folio_test_uptodate - Is this folio up to date?
|
|
* @folio: The folio.
|
|
*
|
|
* The uptodate flag is set on a folio when every byte in the folio is
|
|
* at least as new as the corresponding bytes on storage. Anonymous
|
|
* and CoW folios are always uptodate. If the folio is not uptodate,
|
|
* some of the bytes in it may be; see the is_partially_uptodate()
|
|
* address_space operation.
|
|
*/
|
|
static inline bool folio_test_uptodate(const struct folio *folio)
|
|
{
|
|
bool ret = test_bit(PG_uptodate, const_folio_flags(folio, 0));
|
|
/*
|
|
* Must ensure that the data we read out of the folio is loaded
|
|
* _after_ we've loaded folio->flags to check the uptodate bit.
|
|
* We can skip the barrier if the folio is not uptodate, because
|
|
* we wouldn't be reading anything from it.
|
|
*
|
|
* See folio_mark_uptodate() for the other side of the story.
|
|
*/
|
|
if (ret)
|
|
smp_rmb();
|
|
|
|
return ret;
|
|
}
|
|
|
|
static inline bool PageUptodate(const struct page *page)
|
|
{
|
|
return folio_test_uptodate(page_folio(page));
|
|
}
|
|
|
|
static __always_inline void __folio_mark_uptodate(struct folio *folio)
|
|
{
|
|
smp_wmb();
|
|
__set_bit(PG_uptodate, folio_flags(folio, 0));
|
|
}
|
|
|
|
static __always_inline void folio_mark_uptodate(struct folio *folio)
|
|
{
|
|
/*
|
|
* Memory barrier must be issued before setting the PG_uptodate bit,
|
|
* so that all previous stores issued in order to bring the folio
|
|
* uptodate are actually visible before folio_test_uptodate becomes true.
|
|
*/
|
|
smp_wmb();
|
|
set_bit(PG_uptodate, folio_flags(folio, 0));
|
|
}
|
|
|
|
static __always_inline void __SetPageUptodate(struct page *page)
|
|
{
|
|
__folio_mark_uptodate((struct folio *)page);
|
|
}
|
|
|
|
static __always_inline void SetPageUptodate(struct page *page)
|
|
{
|
|
folio_mark_uptodate((struct folio *)page);
|
|
}
|
|
|
|
CLEARPAGEFLAG(Uptodate, uptodate, PF_NO_TAIL)
|
|
|
|
void __folio_start_writeback(struct folio *folio, bool keep_write);
|
|
void set_page_writeback(struct page *page);
|
|
|
|
#define folio_start_writeback(folio) \
|
|
__folio_start_writeback(folio, false)
|
|
#define folio_start_writeback_keepwrite(folio) \
|
|
__folio_start_writeback(folio, true)
|
|
|
|
static __always_inline bool folio_test_head(const struct folio *folio)
|
|
{
|
|
return test_bit(PG_head, const_folio_flags(folio, FOLIO_PF_ANY));
|
|
}
|
|
|
|
static __always_inline int PageHead(const struct page *page)
|
|
{
|
|
PF_POISONED_CHECK(page);
|
|
return test_bit(PG_head, &page->flags) && !page_is_fake_head(page);
|
|
}
|
|
|
|
__SETPAGEFLAG(Head, head, PF_ANY)
|
|
__CLEARPAGEFLAG(Head, head, PF_ANY)
|
|
CLEARPAGEFLAG(Head, head, PF_ANY)
|
|
|
|
/**
|
|
* folio_test_large() - Does this folio contain more than one page?
|
|
* @folio: The folio to test.
|
|
*
|
|
* Return: True if the folio is larger than one page.
|
|
*/
|
|
static inline bool folio_test_large(const struct folio *folio)
|
|
{
|
|
return folio_test_head(folio);
|
|
}
|
|
|
|
static __always_inline void set_compound_head(struct page *page, struct page *head)
|
|
{
|
|
WRITE_ONCE(page->compound_head, (unsigned long)head + 1);
|
|
}
|
|
|
|
static __always_inline void clear_compound_head(struct page *page)
|
|
{
|
|
WRITE_ONCE(page->compound_head, 0);
|
|
}
|
|
|
|
#ifdef CONFIG_TRANSPARENT_HUGEPAGE
|
|
static inline void ClearPageCompound(struct page *page)
|
|
{
|
|
BUG_ON(!PageHead(page));
|
|
ClearPageHead(page);
|
|
}
|
|
FOLIO_FLAG(large_rmappable, FOLIO_SECOND_PAGE)
|
|
FOLIO_FLAG(partially_mapped, FOLIO_SECOND_PAGE)
|
|
#else
|
|
FOLIO_FLAG_FALSE(large_rmappable)
|
|
FOLIO_FLAG_FALSE(partially_mapped)
|
|
#endif
|
|
|
|
#define PG_head_mask ((1UL << PG_head))
|
|
|
|
#ifdef CONFIG_TRANSPARENT_HUGEPAGE
|
|
/*
|
|
* PageHuge() only returns true for hugetlbfs pages, but not for
|
|
* normal or transparent huge pages.
|
|
*
|
|
* PageTransHuge() returns true for both transparent huge and
|
|
* hugetlbfs pages, but not normal pages. PageTransHuge() can only be
|
|
* called only in the core VM paths where hugetlbfs pages can't exist.
|
|
*/
|
|
static inline int PageTransHuge(const struct page *page)
|
|
{
|
|
VM_BUG_ON_PAGE(PageTail(page), page);
|
|
return PageHead(page);
|
|
}
|
|
|
|
/*
|
|
* PageTransCompound returns true for both transparent huge pages
|
|
* and hugetlbfs pages, so it should only be called when it's known
|
|
* that hugetlbfs pages aren't involved.
|
|
*/
|
|
static inline int PageTransCompound(const struct page *page)
|
|
{
|
|
return PageCompound(page);
|
|
}
|
|
|
|
/*
|
|
* PageTransTail returns true for both transparent huge pages
|
|
* and hugetlbfs pages, so it should only be called when it's known
|
|
* that hugetlbfs pages aren't involved.
|
|
*/
|
|
static inline int PageTransTail(const struct page *page)
|
|
{
|
|
return PageTail(page);
|
|
}
|
|
#else
|
|
TESTPAGEFLAG_FALSE(TransHuge, transhuge)
|
|
TESTPAGEFLAG_FALSE(TransCompound, transcompound)
|
|
TESTPAGEFLAG_FALSE(TransCompoundMap, transcompoundmap)
|
|
TESTPAGEFLAG_FALSE(TransTail, transtail)
|
|
#endif
|
|
|
|
#if defined(CONFIG_MEMORY_FAILURE) && defined(CONFIG_TRANSPARENT_HUGEPAGE)
|
|
/*
|
|
* PageHasHWPoisoned indicates that at least one subpage is hwpoisoned in the
|
|
* compound page.
|
|
*
|
|
* This flag is set by hwpoison handler. Cleared by THP split or free page.
|
|
*/
|
|
PAGEFLAG(HasHWPoisoned, has_hwpoisoned, PF_SECOND)
|
|
TESTSCFLAG(HasHWPoisoned, has_hwpoisoned, PF_SECOND)
|
|
#else
|
|
PAGEFLAG_FALSE(HasHWPoisoned, has_hwpoisoned)
|
|
TESTSCFLAG_FALSE(HasHWPoisoned, has_hwpoisoned)
|
|
#endif
|
|
|
|
/*
|
|
* For pages that do not use mapcount, page_type may be used.
|
|
* The low 24 bits of pagetype may be used for your own purposes, as long
|
|
* as you are careful to not affect the top 8 bits. The low bits of
|
|
* pagetype will be overwritten when you clear the page_type from the page.
|
|
*/
|
|
enum pagetype {
|
|
/* 0x00-0x7f are positive numbers, ie mapcount */
|
|
/* Reserve 0x80-0xef for mapcount overflow. */
|
|
PGTY_buddy = 0xf0,
|
|
PGTY_offline = 0xf1,
|
|
PGTY_table = 0xf2,
|
|
PGTY_guard = 0xf3,
|
|
PGTY_hugetlb = 0xf4,
|
|
PGTY_slab = 0xf5,
|
|
PGTY_zsmalloc = 0xf6,
|
|
PGTY_unaccepted = 0xf7,
|
|
|
|
PGTY_mapcount_underflow = 0xff
|
|
};
|
|
|
|
static inline bool page_type_has_type(int page_type)
|
|
{
|
|
return page_type < (PGTY_mapcount_underflow << 24);
|
|
}
|
|
|
|
/* This takes a mapcount which is one more than page->_mapcount */
|
|
static inline bool page_mapcount_is_type(unsigned int mapcount)
|
|
{
|
|
return page_type_has_type(mapcount - 1);
|
|
}
|
|
|
|
static inline bool page_has_type(const struct page *page)
|
|
{
|
|
return page_mapcount_is_type(data_race(page->page_type));
|
|
}
|
|
|
|
#define FOLIO_TYPE_OPS(lname, fname) \
|
|
static __always_inline bool folio_test_##fname(const struct folio *folio) \
|
|
{ \
|
|
return data_race(folio->page.page_type >> 24) == PGTY_##lname; \
|
|
} \
|
|
static __always_inline void __folio_set_##fname(struct folio *folio) \
|
|
{ \
|
|
if (folio_test_##fname(folio)) \
|
|
return; \
|
|
VM_BUG_ON_FOLIO(data_race(folio->page.page_type) != UINT_MAX, \
|
|
folio); \
|
|
folio->page.page_type = (unsigned int)PGTY_##lname << 24; \
|
|
} \
|
|
static __always_inline void __folio_clear_##fname(struct folio *folio) \
|
|
{ \
|
|
if (folio->page.page_type == UINT_MAX) \
|
|
return; \
|
|
VM_BUG_ON_FOLIO(!folio_test_##fname(folio), folio); \
|
|
folio->page.page_type = UINT_MAX; \
|
|
}
|
|
|
|
#define PAGE_TYPE_OPS(uname, lname, fname) \
|
|
FOLIO_TYPE_OPS(lname, fname) \
|
|
static __always_inline int Page##uname(const struct page *page) \
|
|
{ \
|
|
return data_race(page->page_type >> 24) == PGTY_##lname; \
|
|
} \
|
|
static __always_inline void __SetPage##uname(struct page *page) \
|
|
{ \
|
|
if (Page##uname(page)) \
|
|
return; \
|
|
VM_BUG_ON_PAGE(data_race(page->page_type) != UINT_MAX, page); \
|
|
page->page_type = (unsigned int)PGTY_##lname << 24; \
|
|
} \
|
|
static __always_inline void __ClearPage##uname(struct page *page) \
|
|
{ \
|
|
if (page->page_type == UINT_MAX) \
|
|
return; \
|
|
VM_BUG_ON_PAGE(!Page##uname(page), page); \
|
|
page->page_type = UINT_MAX; \
|
|
}
|
|
|
|
/*
|
|
* PageBuddy() indicates that the page is free and in the buddy system
|
|
* (see mm/page_alloc.c).
|
|
*/
|
|
PAGE_TYPE_OPS(Buddy, buddy, buddy)
|
|
|
|
/*
|
|
* PageOffline() indicates that the page is logically offline although the
|
|
* containing section is online. (e.g. inflated in a balloon driver or
|
|
* not onlined when onlining the section).
|
|
* The content of these pages is effectively stale. Such pages should not
|
|
* be touched (read/write/dump/save) except by their owner.
|
|
*
|
|
* When a memory block gets onlined, all pages are initialized with a
|
|
* refcount of 1 and PageOffline(). generic_online_page() will
|
|
* take care of clearing PageOffline().
|
|
*
|
|
* If a driver wants to allow to offline unmovable PageOffline() pages without
|
|
* putting them back to the buddy, it can do so via the memory notifier by
|
|
* decrementing the reference count in MEM_GOING_OFFLINE and incrementing the
|
|
* reference count in MEM_CANCEL_OFFLINE. When offlining, the PageOffline()
|
|
* pages (now with a reference count of zero) are treated like free (unmanaged)
|
|
* pages, allowing the containing memory block to get offlined. A driver that
|
|
* relies on this feature is aware that re-onlining the memory block will
|
|
* require not giving them to the buddy via generic_online_page().
|
|
*
|
|
* Memory offlining code will not adjust the managed page count for any
|
|
* PageOffline() pages, treating them like they were never exposed to the
|
|
* buddy using generic_online_page().
|
|
*
|
|
* There are drivers that mark a page PageOffline() and expect there won't be
|
|
* any further access to page content. PFN walkers that read content of random
|
|
* pages should check PageOffline() and synchronize with such drivers using
|
|
* page_offline_freeze()/page_offline_thaw().
|
|
*/
|
|
PAGE_TYPE_OPS(Offline, offline, offline)
|
|
|
|
extern void page_offline_freeze(void);
|
|
extern void page_offline_thaw(void);
|
|
extern void page_offline_begin(void);
|
|
extern void page_offline_end(void);
|
|
|
|
/*
|
|
* Marks pages in use as page tables.
|
|
*/
|
|
PAGE_TYPE_OPS(Table, table, pgtable)
|
|
|
|
/*
|
|
* Marks guardpages used with debug_pagealloc.
|
|
*/
|
|
PAGE_TYPE_OPS(Guard, guard, guard)
|
|
|
|
FOLIO_TYPE_OPS(slab, slab)
|
|
|
|
/**
|
|
* PageSlab - Determine if the page belongs to the slab allocator
|
|
* @page: The page to test.
|
|
*
|
|
* Context: Any context.
|
|
* Return: True for slab pages, false for any other kind of page.
|
|
*/
|
|
static inline bool PageSlab(const struct page *page)
|
|
{
|
|
return folio_test_slab(page_folio(page));
|
|
}
|
|
|
|
#ifdef CONFIG_HUGETLB_PAGE
|
|
FOLIO_TYPE_OPS(hugetlb, hugetlb)
|
|
#else
|
|
FOLIO_TEST_FLAG_FALSE(hugetlb)
|
|
#endif
|
|
|
|
PAGE_TYPE_OPS(Zsmalloc, zsmalloc, zsmalloc)
|
|
|
|
/*
|
|
* Mark pages that has to be accepted before touched for the first time.
|
|
*
|
|
* Serialized with zone lock.
|
|
*/
|
|
PAGE_TYPE_OPS(Unaccepted, unaccepted, unaccepted)
|
|
|
|
/**
|
|
* PageHuge - Determine if the page belongs to hugetlbfs
|
|
* @page: The page to test.
|
|
*
|
|
* Context: Any context.
|
|
* Return: True for hugetlbfs pages, false for anon pages or pages
|
|
* belonging to other filesystems.
|
|
*/
|
|
static inline bool PageHuge(const struct page *page)
|
|
{
|
|
return folio_test_hugetlb(page_folio(page));
|
|
}
|
|
|
|
/*
|
|
* Check if a page is currently marked HWPoisoned. Note that this check is
|
|
* best effort only and inherently racy: there is no way to synchronize with
|
|
* failing hardware.
|
|
*/
|
|
static inline bool is_page_hwpoison(const struct page *page)
|
|
{
|
|
const struct folio *folio;
|
|
|
|
if (PageHWPoison(page))
|
|
return true;
|
|
folio = page_folio(page);
|
|
return folio_test_hugetlb(folio) && PageHWPoison(&folio->page);
|
|
}
|
|
|
|
static inline bool folio_contain_hwpoisoned_page(struct folio *folio)
|
|
{
|
|
return folio_test_hwpoison(folio) ||
|
|
(folio_test_large(folio) && folio_test_has_hwpoisoned(folio));
|
|
}
|
|
|
|
bool is_free_buddy_page(const struct page *page);
|
|
|
|
PAGEFLAG(Isolated, isolated, PF_ANY);
|
|
|
|
static __always_inline int PageAnonExclusive(const struct page *page)
|
|
{
|
|
VM_BUG_ON_PGFLAGS(!PageAnon(page), page);
|
|
/*
|
|
* HugeTLB stores this information on the head page; THP keeps it per
|
|
* page
|
|
*/
|
|
if (PageHuge(page))
|
|
page = compound_head(page);
|
|
return test_bit(PG_anon_exclusive, &PF_ANY(page, 1)->flags);
|
|
}
|
|
|
|
static __always_inline void SetPageAnonExclusive(struct page *page)
|
|
{
|
|
VM_BUG_ON_PGFLAGS(!PageAnon(page) || PageKsm(page), page);
|
|
VM_BUG_ON_PGFLAGS(PageHuge(page) && !PageHead(page), page);
|
|
set_bit(PG_anon_exclusive, &PF_ANY(page, 1)->flags);
|
|
}
|
|
|
|
static __always_inline void ClearPageAnonExclusive(struct page *page)
|
|
{
|
|
VM_BUG_ON_PGFLAGS(!PageAnon(page) || PageKsm(page), page);
|
|
VM_BUG_ON_PGFLAGS(PageHuge(page) && !PageHead(page), page);
|
|
clear_bit(PG_anon_exclusive, &PF_ANY(page, 1)->flags);
|
|
}
|
|
|
|
static __always_inline void __ClearPageAnonExclusive(struct page *page)
|
|
{
|
|
VM_BUG_ON_PGFLAGS(!PageAnon(page), page);
|
|
VM_BUG_ON_PGFLAGS(PageHuge(page) && !PageHead(page), page);
|
|
__clear_bit(PG_anon_exclusive, &PF_ANY(page, 1)->flags);
|
|
}
|
|
|
|
#ifdef CONFIG_MMU
|
|
#define __PG_MLOCKED (1UL << PG_mlocked)
|
|
#else
|
|
#define __PG_MLOCKED 0
|
|
#endif
|
|
|
|
/*
|
|
* Flags checked when a page is freed. Pages being freed should not have
|
|
* these flags set. If they are, there is a problem.
|
|
*/
|
|
#define PAGE_FLAGS_CHECK_AT_FREE \
|
|
(1UL << PG_lru | 1UL << PG_locked | \
|
|
1UL << PG_private | 1UL << PG_private_2 | \
|
|
1UL << PG_writeback | 1UL << PG_reserved | \
|
|
1UL << PG_active | \
|
|
1UL << PG_unevictable | __PG_MLOCKED | LRU_GEN_MASK)
|
|
|
|
/*
|
|
* Flags checked when a page is prepped for return by the page allocator.
|
|
* Pages being prepped should not have these flags set. If they are set,
|
|
* there has been a kernel bug or struct page corruption.
|
|
*
|
|
* __PG_HWPOISON is exceptional because it needs to be kept beyond page's
|
|
* alloc-free cycle to prevent from reusing the page.
|
|
*/
|
|
#define PAGE_FLAGS_CHECK_AT_PREP \
|
|
((PAGEFLAGS_MASK & ~__PG_HWPOISON) | LRU_GEN_MASK | LRU_REFS_MASK)
|
|
|
|
/*
|
|
* Flags stored in the second page of a compound page. They may overlap
|
|
* the CHECK_AT_FREE flags above, so need to be cleared.
|
|
*/
|
|
#define PAGE_FLAGS_SECOND \
|
|
(0xffUL /* order */ | 1UL << PG_has_hwpoisoned | \
|
|
1UL << PG_large_rmappable | 1UL << PG_partially_mapped)
|
|
|
|
#define PAGE_FLAGS_PRIVATE \
|
|
(1UL << PG_private | 1UL << PG_private_2)
|
|
/**
|
|
* folio_has_private - Determine if folio has private stuff
|
|
* @folio: The folio to be checked
|
|
*
|
|
* Determine if a folio has private stuff, indicating that release routines
|
|
* should be invoked upon it.
|
|
*/
|
|
static inline int folio_has_private(const struct folio *folio)
|
|
{
|
|
return !!(folio->flags & PAGE_FLAGS_PRIVATE);
|
|
}
|
|
|
|
#undef PF_ANY
|
|
#undef PF_HEAD
|
|
#undef PF_NO_TAIL
|
|
#undef PF_NO_COMPOUND
|
|
#undef PF_SECOND
|
|
#endif /* !__GENERATING_BOUNDS_H */
|
|
|
|
#endif /* PAGE_FLAGS_H */
|