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>
1168 lines
38 KiB
C
1168 lines
38 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* device.h - generic, centralized driver model
|
|
*
|
|
* Copyright (c) 2001-2003 Patrick Mochel <mochel@osdl.org>
|
|
* Copyright (c) 2004-2009 Greg Kroah-Hartman <gregkh@suse.de>
|
|
* Copyright (c) 2008-2009 Novell Inc.
|
|
*
|
|
* See Documentation/driver-api/driver-model/ for more information.
|
|
*/
|
|
|
|
#ifndef _DEVICE_H_
|
|
#define _DEVICE_H_
|
|
|
|
#include <linux/dev_printk.h>
|
|
#include <linux/energy_model.h>
|
|
#include <linux/ioport.h>
|
|
#include <linux/kobject.h>
|
|
#include <linux/klist.h>
|
|
#include <linux/list.h>
|
|
#include <linux/lockdep.h>
|
|
#include <linux/compiler.h>
|
|
#include <linux/types.h>
|
|
#include <linux/mutex.h>
|
|
#include <linux/pm.h>
|
|
#include <linux/atomic.h>
|
|
#include <linux/uidgid.h>
|
|
#include <linux/gfp.h>
|
|
#include <linux/device/bus.h>
|
|
#include <linux/device/class.h>
|
|
#include <linux/device/devres.h>
|
|
#include <linux/device/driver.h>
|
|
#include <linux/cleanup.h>
|
|
#include <linux/android_kabi.h>
|
|
#include <asm/device.h>
|
|
|
|
struct device;
|
|
struct device_private;
|
|
struct device_driver;
|
|
struct driver_private;
|
|
struct module;
|
|
struct class;
|
|
struct subsys_private;
|
|
struct device_node;
|
|
struct fwnode_handle;
|
|
struct iommu_group;
|
|
struct dev_pin_info;
|
|
struct dev_iommu;
|
|
struct msi_device_data;
|
|
|
|
/**
|
|
* struct subsys_interface - interfaces to device functions
|
|
* @name: name of the device function
|
|
* @subsys: subsystem of the devices to attach to
|
|
* @node: the list of functions registered at the subsystem
|
|
* @add_dev: device hookup to device function handler
|
|
* @remove_dev: device hookup to device function handler
|
|
*
|
|
* Simple interfaces attached to a subsystem. Multiple interfaces can
|
|
* attach to a subsystem and its devices. Unlike drivers, they do not
|
|
* exclusively claim or control devices. Interfaces usually represent
|
|
* a specific functionality of a subsystem/class of devices.
|
|
*/
|
|
struct subsys_interface {
|
|
const char *name;
|
|
const struct bus_type *subsys;
|
|
struct list_head node;
|
|
int (*add_dev)(struct device *dev, struct subsys_interface *sif);
|
|
void (*remove_dev)(struct device *dev, struct subsys_interface *sif);
|
|
};
|
|
|
|
int subsys_interface_register(struct subsys_interface *sif);
|
|
void subsys_interface_unregister(struct subsys_interface *sif);
|
|
|
|
int subsys_system_register(const struct bus_type *subsys,
|
|
const struct attribute_group **groups);
|
|
int subsys_virtual_register(const struct bus_type *subsys,
|
|
const struct attribute_group **groups);
|
|
|
|
/*
|
|
* The type of device, "struct device" is embedded in. A class
|
|
* or bus can contain devices of different types
|
|
* like "partitions" and "disks", "mouse" and "event".
|
|
* This identifies the device type and carries type-specific
|
|
* information, equivalent to the kobj_type of a kobject.
|
|
* If "name" is specified, the uevent will contain it in
|
|
* the DEVTYPE variable.
|
|
*/
|
|
struct device_type {
|
|
const char *name;
|
|
const struct attribute_group **groups;
|
|
int (*uevent)(const struct device *dev, struct kobj_uevent_env *env);
|
|
char *(*devnode)(const struct device *dev, umode_t *mode,
|
|
kuid_t *uid, kgid_t *gid);
|
|
void (*release)(struct device *dev);
|
|
|
|
const struct dev_pm_ops *pm;
|
|
};
|
|
|
|
/**
|
|
* struct device_attribute - Interface for exporting device attributes.
|
|
* @attr: sysfs attribute definition.
|
|
* @show: Show handler.
|
|
* @store: Store handler.
|
|
*/
|
|
struct device_attribute {
|
|
struct attribute attr;
|
|
ssize_t (*show)(struct device *dev, struct device_attribute *attr,
|
|
char *buf);
|
|
ssize_t (*store)(struct device *dev, struct device_attribute *attr,
|
|
const char *buf, size_t count);
|
|
};
|
|
|
|
/**
|
|
* struct dev_ext_attribute - Exported device attribute with extra context.
|
|
* @attr: Exported device attribute.
|
|
* @var: Pointer to context.
|
|
*/
|
|
struct dev_ext_attribute {
|
|
struct device_attribute attr;
|
|
void *var;
|
|
};
|
|
|
|
ssize_t device_show_ulong(struct device *dev, struct device_attribute *attr,
|
|
char *buf);
|
|
ssize_t device_store_ulong(struct device *dev, struct device_attribute *attr,
|
|
const char *buf, size_t count);
|
|
ssize_t device_show_int(struct device *dev, struct device_attribute *attr,
|
|
char *buf);
|
|
ssize_t device_store_int(struct device *dev, struct device_attribute *attr,
|
|
const char *buf, size_t count);
|
|
ssize_t device_show_bool(struct device *dev, struct device_attribute *attr,
|
|
char *buf);
|
|
ssize_t device_store_bool(struct device *dev, struct device_attribute *attr,
|
|
const char *buf, size_t count);
|
|
ssize_t device_show_string(struct device *dev, struct device_attribute *attr,
|
|
char *buf);
|
|
|
|
/**
|
|
* DEVICE_ATTR - Define a device attribute.
|
|
* @_name: Attribute name.
|
|
* @_mode: File mode.
|
|
* @_show: Show handler. Optional, but mandatory if attribute is readable.
|
|
* @_store: Store handler. Optional, but mandatory if attribute is writable.
|
|
*
|
|
* Convenience macro for defining a struct device_attribute.
|
|
*
|
|
* For example, ``DEVICE_ATTR(foo, 0644, foo_show, foo_store);`` expands to:
|
|
*
|
|
* .. code-block:: c
|
|
*
|
|
* struct device_attribute dev_attr_foo = {
|
|
* .attr = { .name = "foo", .mode = 0644 },
|
|
* .show = foo_show,
|
|
* .store = foo_store,
|
|
* };
|
|
*/
|
|
#define DEVICE_ATTR(_name, _mode, _show, _store) \
|
|
struct device_attribute dev_attr_##_name = __ATTR(_name, _mode, _show, _store)
|
|
|
|
/**
|
|
* DEVICE_ATTR_PREALLOC - Define a preallocated device attribute.
|
|
* @_name: Attribute name.
|
|
* @_mode: File mode.
|
|
* @_show: Show handler. Optional, but mandatory if attribute is readable.
|
|
* @_store: Store handler. Optional, but mandatory if attribute is writable.
|
|
*
|
|
* Like DEVICE_ATTR(), but ``SYSFS_PREALLOC`` is set on @_mode.
|
|
*/
|
|
#define DEVICE_ATTR_PREALLOC(_name, _mode, _show, _store) \
|
|
struct device_attribute dev_attr_##_name = \
|
|
__ATTR_PREALLOC(_name, _mode, _show, _store)
|
|
|
|
/**
|
|
* DEVICE_ATTR_RW - Define a read-write device attribute.
|
|
* @_name: Attribute name.
|
|
*
|
|
* Like DEVICE_ATTR(), but @_mode is 0644, @_show is <_name>_show,
|
|
* and @_store is <_name>_store.
|
|
*/
|
|
#define DEVICE_ATTR_RW(_name) \
|
|
struct device_attribute dev_attr_##_name = __ATTR_RW(_name)
|
|
|
|
/**
|
|
* DEVICE_ATTR_ADMIN_RW - Define an admin-only read-write device attribute.
|
|
* @_name: Attribute name.
|
|
*
|
|
* Like DEVICE_ATTR_RW(), but @_mode is 0600.
|
|
*/
|
|
#define DEVICE_ATTR_ADMIN_RW(_name) \
|
|
struct device_attribute dev_attr_##_name = __ATTR_RW_MODE(_name, 0600)
|
|
|
|
/**
|
|
* DEVICE_ATTR_RO - Define a readable device attribute.
|
|
* @_name: Attribute name.
|
|
*
|
|
* Like DEVICE_ATTR(), but @_mode is 0444 and @_show is <_name>_show.
|
|
*/
|
|
#define DEVICE_ATTR_RO(_name) \
|
|
struct device_attribute dev_attr_##_name = __ATTR_RO(_name)
|
|
|
|
/**
|
|
* DEVICE_ATTR_ADMIN_RO - Define an admin-only readable device attribute.
|
|
* @_name: Attribute name.
|
|
*
|
|
* Like DEVICE_ATTR_RO(), but @_mode is 0400.
|
|
*/
|
|
#define DEVICE_ATTR_ADMIN_RO(_name) \
|
|
struct device_attribute dev_attr_##_name = __ATTR_RO_MODE(_name, 0400)
|
|
|
|
/**
|
|
* DEVICE_ATTR_WO - Define an admin-only writable device attribute.
|
|
* @_name: Attribute name.
|
|
*
|
|
* Like DEVICE_ATTR(), but @_mode is 0200 and @_store is <_name>_store.
|
|
*/
|
|
#define DEVICE_ATTR_WO(_name) \
|
|
struct device_attribute dev_attr_##_name = __ATTR_WO(_name)
|
|
|
|
/**
|
|
* DEVICE_ULONG_ATTR - Define a device attribute backed by an unsigned long.
|
|
* @_name: Attribute name.
|
|
* @_mode: File mode.
|
|
* @_var: Identifier of unsigned long.
|
|
*
|
|
* Like DEVICE_ATTR(), but @_show and @_store are automatically provided
|
|
* such that reads and writes to the attribute from userspace affect @_var.
|
|
*/
|
|
#define DEVICE_ULONG_ATTR(_name, _mode, _var) \
|
|
struct dev_ext_attribute dev_attr_##_name = \
|
|
{ __ATTR(_name, _mode, device_show_ulong, device_store_ulong), &(_var) }
|
|
|
|
/**
|
|
* DEVICE_INT_ATTR - Define a device attribute backed by an int.
|
|
* @_name: Attribute name.
|
|
* @_mode: File mode.
|
|
* @_var: Identifier of int.
|
|
*
|
|
* Like DEVICE_ULONG_ATTR(), but @_var is an int.
|
|
*/
|
|
#define DEVICE_INT_ATTR(_name, _mode, _var) \
|
|
struct dev_ext_attribute dev_attr_##_name = \
|
|
{ __ATTR(_name, _mode, device_show_int, device_store_int), &(_var) }
|
|
|
|
/**
|
|
* DEVICE_BOOL_ATTR - Define a device attribute backed by a bool.
|
|
* @_name: Attribute name.
|
|
* @_mode: File mode.
|
|
* @_var: Identifier of bool.
|
|
*
|
|
* Like DEVICE_ULONG_ATTR(), but @_var is a bool.
|
|
*/
|
|
#define DEVICE_BOOL_ATTR(_name, _mode, _var) \
|
|
struct dev_ext_attribute dev_attr_##_name = \
|
|
{ __ATTR(_name, _mode, device_show_bool, device_store_bool), &(_var) }
|
|
|
|
/**
|
|
* DEVICE_STRING_ATTR_RO - Define a device attribute backed by a r/o string.
|
|
* @_name: Attribute name.
|
|
* @_mode: File mode.
|
|
* @_var: Identifier of string.
|
|
*
|
|
* Like DEVICE_ULONG_ATTR(), but @_var is a string. Because the length of the
|
|
* string allocation is unknown, the attribute must be read-only.
|
|
*/
|
|
#define DEVICE_STRING_ATTR_RO(_name, _mode, _var) \
|
|
struct dev_ext_attribute dev_attr_##_name = \
|
|
{ __ATTR(_name, (_mode) & ~0222, device_show_string, NULL), (_var) }
|
|
|
|
#define DEVICE_ATTR_IGNORE_LOCKDEP(_name, _mode, _show, _store) \
|
|
struct device_attribute dev_attr_##_name = \
|
|
__ATTR_IGNORE_LOCKDEP(_name, _mode, _show, _store)
|
|
|
|
int device_create_file(struct device *device,
|
|
const struct device_attribute *entry);
|
|
void device_remove_file(struct device *dev,
|
|
const struct device_attribute *attr);
|
|
bool device_remove_file_self(struct device *dev,
|
|
const struct device_attribute *attr);
|
|
int __must_check device_create_bin_file(struct device *dev,
|
|
const struct bin_attribute *attr);
|
|
void device_remove_bin_file(struct device *dev,
|
|
const struct bin_attribute *attr);
|
|
|
|
/* allows to add/remove a custom action to devres stack */
|
|
void devm_remove_action(struct device *dev, void (*action)(void *), void *data);
|
|
void devm_release_action(struct device *dev, void (*action)(void *), void *data);
|
|
|
|
int __devm_add_action(struct device *dev, void (*action)(void *), void *data, const char *name);
|
|
#define devm_add_action(dev, action, data) \
|
|
__devm_add_action(dev, action, data, #action)
|
|
|
|
static inline int __devm_add_action_or_reset(struct device *dev, void (*action)(void *),
|
|
void *data, const char *name)
|
|
{
|
|
int ret;
|
|
|
|
ret = __devm_add_action(dev, action, data, name);
|
|
if (ret)
|
|
action(data);
|
|
|
|
return ret;
|
|
}
|
|
#define devm_add_action_or_reset(dev, action, data) \
|
|
__devm_add_action_or_reset(dev, action, data, #action)
|
|
|
|
/**
|
|
* devm_alloc_percpu - Resource-managed alloc_percpu
|
|
* @dev: Device to allocate per-cpu memory for
|
|
* @type: Type to allocate per-cpu memory for
|
|
*
|
|
* Managed alloc_percpu. Per-cpu memory allocated with this function is
|
|
* automatically freed on driver detach.
|
|
*
|
|
* RETURNS:
|
|
* Pointer to allocated memory on success, NULL on failure.
|
|
*/
|
|
#define devm_alloc_percpu(dev, type) \
|
|
((typeof(type) __percpu *)__devm_alloc_percpu((dev), sizeof(type), \
|
|
__alignof__(type)))
|
|
|
|
void __percpu *__devm_alloc_percpu(struct device *dev, size_t size,
|
|
size_t align);
|
|
void devm_free_percpu(struct device *dev, void __percpu *pdata);
|
|
|
|
struct device_dma_parameters {
|
|
/*
|
|
* a low level driver may set these to teach IOMMU code about
|
|
* sg limitations.
|
|
*/
|
|
unsigned int max_segment_size;
|
|
unsigned int min_align_mask;
|
|
unsigned long segment_boundary_mask;
|
|
};
|
|
|
|
/**
|
|
* enum device_link_state - Device link states.
|
|
* @DL_STATE_NONE: The presence of the drivers is not being tracked.
|
|
* @DL_STATE_DORMANT: None of the supplier/consumer drivers is present.
|
|
* @DL_STATE_AVAILABLE: The supplier driver is present, but the consumer is not.
|
|
* @DL_STATE_CONSUMER_PROBE: The consumer is probing (supplier driver present).
|
|
* @DL_STATE_ACTIVE: Both the supplier and consumer drivers are present.
|
|
* @DL_STATE_SUPPLIER_UNBIND: The supplier driver is unbinding.
|
|
*/
|
|
enum device_link_state {
|
|
DL_STATE_NONE = -1,
|
|
DL_STATE_DORMANT = 0,
|
|
DL_STATE_AVAILABLE,
|
|
DL_STATE_CONSUMER_PROBE,
|
|
DL_STATE_ACTIVE,
|
|
DL_STATE_SUPPLIER_UNBIND,
|
|
};
|
|
|
|
/*
|
|
* Device link flags.
|
|
*
|
|
* STATELESS: The core will not remove this link automatically.
|
|
* AUTOREMOVE_CONSUMER: Remove the link automatically on consumer driver unbind.
|
|
* PM_RUNTIME: If set, the runtime PM framework will use this link.
|
|
* RPM_ACTIVE: Run pm_runtime_get_sync() on the supplier during link creation.
|
|
* AUTOREMOVE_SUPPLIER: Remove the link automatically on supplier driver unbind.
|
|
* AUTOPROBE_CONSUMER: Probe consumer driver automatically after supplier binds.
|
|
* MANAGED: The core tracks presence of supplier/consumer drivers (internal).
|
|
* SYNC_STATE_ONLY: Link only affects sync_state() behavior.
|
|
* INFERRED: Inferred from data (eg: firmware) and not from driver actions.
|
|
*/
|
|
#define DL_FLAG_STATELESS BIT(0)
|
|
#define DL_FLAG_AUTOREMOVE_CONSUMER BIT(1)
|
|
#define DL_FLAG_PM_RUNTIME BIT(2)
|
|
#define DL_FLAG_RPM_ACTIVE BIT(3)
|
|
#define DL_FLAG_AUTOREMOVE_SUPPLIER BIT(4)
|
|
#define DL_FLAG_AUTOPROBE_CONSUMER BIT(5)
|
|
#define DL_FLAG_MANAGED BIT(6)
|
|
#define DL_FLAG_SYNC_STATE_ONLY BIT(7)
|
|
#define DL_FLAG_INFERRED BIT(8)
|
|
#define DL_FLAG_CYCLE BIT(9)
|
|
|
|
/**
|
|
* enum dl_dev_state - Device driver presence tracking information.
|
|
* @DL_DEV_NO_DRIVER: There is no driver attached to the device.
|
|
* @DL_DEV_PROBING: A driver is probing.
|
|
* @DL_DEV_DRIVER_BOUND: The driver has been bound to the device.
|
|
* @DL_DEV_UNBINDING: The driver is unbinding from the device.
|
|
*/
|
|
enum dl_dev_state {
|
|
DL_DEV_NO_DRIVER = 0,
|
|
DL_DEV_PROBING,
|
|
DL_DEV_DRIVER_BOUND,
|
|
DL_DEV_UNBINDING,
|
|
};
|
|
|
|
/**
|
|
* enum device_removable - Whether the device is removable. The criteria for a
|
|
* device to be classified as removable is determined by its subsystem or bus.
|
|
* @DEVICE_REMOVABLE_NOT_SUPPORTED: This attribute is not supported for this
|
|
* device (default).
|
|
* @DEVICE_REMOVABLE_UNKNOWN: Device location is Unknown.
|
|
* @DEVICE_FIXED: Device is not removable by the user.
|
|
* @DEVICE_REMOVABLE: Device is removable by the user.
|
|
*/
|
|
enum device_removable {
|
|
DEVICE_REMOVABLE_NOT_SUPPORTED = 0, /* must be 0 */
|
|
DEVICE_REMOVABLE_UNKNOWN,
|
|
DEVICE_FIXED,
|
|
DEVICE_REMOVABLE,
|
|
};
|
|
|
|
/**
|
|
* struct dev_links_info - Device data related to device links.
|
|
* @suppliers: List of links to supplier devices.
|
|
* @consumers: List of links to consumer devices.
|
|
* @defer_sync: Hook to global list of devices that have deferred sync_state.
|
|
* @status: Driver status information.
|
|
*/
|
|
struct dev_links_info {
|
|
struct list_head suppliers;
|
|
struct list_head consumers;
|
|
struct list_head defer_sync;
|
|
enum dl_dev_state status;
|
|
};
|
|
|
|
/**
|
|
* struct dev_msi_info - Device data related to MSI
|
|
* @domain: The MSI interrupt domain associated to the device
|
|
* @data: Pointer to MSI device data
|
|
*/
|
|
struct dev_msi_info {
|
|
#ifdef CONFIG_GENERIC_MSI_IRQ
|
|
struct irq_domain *domain;
|
|
struct msi_device_data *data;
|
|
#endif
|
|
};
|
|
|
|
/**
|
|
* enum device_physical_location_panel - Describes which panel surface of the
|
|
* system's housing the device connection point resides on.
|
|
* @DEVICE_PANEL_TOP: Device connection point is on the top panel.
|
|
* @DEVICE_PANEL_BOTTOM: Device connection point is on the bottom panel.
|
|
* @DEVICE_PANEL_LEFT: Device connection point is on the left panel.
|
|
* @DEVICE_PANEL_RIGHT: Device connection point is on the right panel.
|
|
* @DEVICE_PANEL_FRONT: Device connection point is on the front panel.
|
|
* @DEVICE_PANEL_BACK: Device connection point is on the back panel.
|
|
* @DEVICE_PANEL_UNKNOWN: The panel with device connection point is unknown.
|
|
*/
|
|
enum device_physical_location_panel {
|
|
DEVICE_PANEL_TOP,
|
|
DEVICE_PANEL_BOTTOM,
|
|
DEVICE_PANEL_LEFT,
|
|
DEVICE_PANEL_RIGHT,
|
|
DEVICE_PANEL_FRONT,
|
|
DEVICE_PANEL_BACK,
|
|
DEVICE_PANEL_UNKNOWN,
|
|
};
|
|
|
|
/**
|
|
* enum device_physical_location_vertical_position - Describes vertical
|
|
* position of the device connection point on the panel surface.
|
|
* @DEVICE_VERT_POS_UPPER: Device connection point is at upper part of panel.
|
|
* @DEVICE_VERT_POS_CENTER: Device connection point is at center part of panel.
|
|
* @DEVICE_VERT_POS_LOWER: Device connection point is at lower part of panel.
|
|
*/
|
|
enum device_physical_location_vertical_position {
|
|
DEVICE_VERT_POS_UPPER,
|
|
DEVICE_VERT_POS_CENTER,
|
|
DEVICE_VERT_POS_LOWER,
|
|
};
|
|
|
|
/**
|
|
* enum device_physical_location_horizontal_position - Describes horizontal
|
|
* position of the device connection point on the panel surface.
|
|
* @DEVICE_HORI_POS_LEFT: Device connection point is at left part of panel.
|
|
* @DEVICE_HORI_POS_CENTER: Device connection point is at center part of panel.
|
|
* @DEVICE_HORI_POS_RIGHT: Device connection point is at right part of panel.
|
|
*/
|
|
enum device_physical_location_horizontal_position {
|
|
DEVICE_HORI_POS_LEFT,
|
|
DEVICE_HORI_POS_CENTER,
|
|
DEVICE_HORI_POS_RIGHT,
|
|
};
|
|
|
|
/**
|
|
* struct device_physical_location - Device data related to physical location
|
|
* of the device connection point.
|
|
* @panel: Panel surface of the system's housing that the device connection
|
|
* point resides on.
|
|
* @vertical_position: Vertical position of the device connection point within
|
|
* the panel.
|
|
* @horizontal_position: Horizontal position of the device connection point
|
|
* within the panel.
|
|
* @dock: Set if the device connection point resides in a docking station or
|
|
* port replicator.
|
|
* @lid: Set if this device connection point resides on the lid of laptop
|
|
* system.
|
|
*/
|
|
struct device_physical_location {
|
|
enum device_physical_location_panel panel;
|
|
enum device_physical_location_vertical_position vertical_position;
|
|
enum device_physical_location_horizontal_position horizontal_position;
|
|
bool dock;
|
|
bool lid;
|
|
};
|
|
|
|
/**
|
|
* struct device - The basic device structure
|
|
* @parent: The device's "parent" device, the device to which it is attached.
|
|
* In most cases, a parent device is some sort of bus or host
|
|
* controller. If parent is NULL, the device, is a top-level device,
|
|
* which is not usually what you want.
|
|
* @p: Holds the private data of the driver core portions of the device.
|
|
* See the comment of the struct device_private for detail.
|
|
* @kobj: A top-level, abstract class from which other classes are derived.
|
|
* @init_name: Initial name of the device.
|
|
* @type: The type of device.
|
|
* This identifies the device type and carries type-specific
|
|
* information.
|
|
* @mutex: Mutex to synchronize calls to its driver.
|
|
* @bus: Type of bus device is on.
|
|
* @driver: Which driver has allocated this
|
|
* @platform_data: Platform data specific to the device.
|
|
* Example: For devices on custom boards, as typical of embedded
|
|
* and SOC based hardware, Linux often uses platform_data to point
|
|
* to board-specific structures describing devices and how they
|
|
* are wired. That can include what ports are available, chip
|
|
* variants, which GPIO pins act in what additional roles, and so
|
|
* on. This shrinks the "Board Support Packages" (BSPs) and
|
|
* minimizes board-specific #ifdefs in drivers.
|
|
* @driver_data: Private pointer for driver specific info.
|
|
* @links: Links to suppliers and consumers of this device.
|
|
* @power: For device power management.
|
|
* See Documentation/driver-api/pm/devices.rst for details.
|
|
* @pm_domain: Provide callbacks that are executed during system suspend,
|
|
* hibernation, system resume and during runtime PM transitions
|
|
* along with subsystem-level and driver-level callbacks.
|
|
* @em_pd: device's energy model performance domain
|
|
* @pins: For device pin management.
|
|
* See Documentation/driver-api/pin-control.rst for details.
|
|
* @msi: MSI related data
|
|
* @numa_node: NUMA node this device is close to.
|
|
* @dma_ops: DMA mapping operations for this device.
|
|
* @dma_mask: Dma mask (if dma'ble device).
|
|
* @coherent_dma_mask: Like dma_mask, but for alloc_coherent mapping as not all
|
|
* hardware supports 64-bit addresses for consistent allocations
|
|
* such descriptors.
|
|
* @bus_dma_limit: Limit of an upstream bridge or bus which imposes a smaller
|
|
* DMA limit than the device itself supports.
|
|
* @dma_range_map: map for DMA memory ranges relative to that of RAM
|
|
* @dma_parms: A low level driver may set these to teach IOMMU code about
|
|
* segment limitations.
|
|
* @dma_pools: Dma pools (if dma'ble device).
|
|
* @dma_mem: Internal for coherent mem override.
|
|
* @cma_area: Contiguous memory area for dma allocations
|
|
* @dma_io_tlb_mem: Software IO TLB allocator. Not for driver use.
|
|
* @dma_io_tlb_pools: List of transient swiotlb memory pools.
|
|
* @dma_io_tlb_lock: Protects changes to the list of active pools.
|
|
* @dma_uses_io_tlb: %true if device has used the software IO TLB.
|
|
* @archdata: For arch-specific additions.
|
|
* @of_node: Associated device tree node.
|
|
* @fwnode: Associated device node supplied by platform firmware.
|
|
* @devt: For creating the sysfs "dev".
|
|
* @id: device instance
|
|
* @devres_lock: Spinlock to protect the resource of the device.
|
|
* @devres_head: The resources list of the device.
|
|
* @class: The class of the device.
|
|
* @groups: Optional attribute groups.
|
|
* @release: Callback to free the device after all references have
|
|
* gone away. This should be set by the allocator of the
|
|
* device (i.e. the bus driver that discovered the device).
|
|
* @iommu_group: IOMMU group the device belongs to.
|
|
* @iommu: Per device generic IOMMU runtime data
|
|
* @physical_location: Describes physical location of the device connection
|
|
* point in the system housing.
|
|
* @removable: Whether the device can be removed from the system. This
|
|
* should be set by the subsystem / bus driver that discovered
|
|
* the device.
|
|
*
|
|
* @offline_disabled: If set, the device is permanently online.
|
|
* @offline: Set after successful invocation of bus type's .offline().
|
|
* @of_node_reused: Set if the device-tree node is shared with an ancestor
|
|
* device.
|
|
* @state_synced: The hardware state of this device has been synced to match
|
|
* the software state of this device by calling the driver/bus
|
|
* sync_state() callback.
|
|
* @can_match: The device has matched with a driver at least once or it is in
|
|
* a bus (like AMBA) which can't check for matching drivers until
|
|
* other devices probe successfully.
|
|
* @dma_coherent: this particular device is dma coherent, even if the
|
|
* architecture supports non-coherent devices.
|
|
* @dma_ops_bypass: If set to %true then the dma_ops are bypassed for the
|
|
* streaming DMA operations (->map_* / ->unmap_* / ->sync_*),
|
|
* and optionall (if the coherent mask is large enough) also
|
|
* for dma allocations. This flag is managed by the dma ops
|
|
* instance from ->dma_supported.
|
|
* @dma_skip_sync: DMA sync operations can be skipped for coherent buffers.
|
|
* @dma_iommu: Device is using default IOMMU implementation for DMA and
|
|
* doesn't rely on dma_ops structure.
|
|
*
|
|
* At the lowest level, every device in a Linux system is represented by an
|
|
* instance of struct device. The device structure contains the information
|
|
* that the device model core needs to model the system. Most subsystems,
|
|
* however, track additional information about the devices they host. As a
|
|
* result, it is rare for devices to be represented by bare device structures;
|
|
* instead, that structure, like kobject structures, is usually embedded within
|
|
* a higher-level representation of the device.
|
|
*/
|
|
struct device {
|
|
struct kobject kobj;
|
|
struct device *parent;
|
|
|
|
struct device_private *p;
|
|
|
|
const char *init_name; /* initial name of the device */
|
|
const struct device_type *type;
|
|
|
|
const struct bus_type *bus; /* type of bus device is on */
|
|
struct device_driver *driver; /* which driver has allocated this
|
|
device */
|
|
void *platform_data; /* Platform specific data, device
|
|
core doesn't touch it */
|
|
void *driver_data; /* Driver data, set and get with
|
|
dev_set_drvdata/dev_get_drvdata */
|
|
struct mutex mutex; /* mutex to synchronize calls to
|
|
* its driver.
|
|
*/
|
|
|
|
struct dev_links_info links;
|
|
struct dev_pm_info power;
|
|
struct dev_pm_domain *pm_domain;
|
|
|
|
#ifdef CONFIG_ENERGY_MODEL
|
|
struct em_perf_domain *em_pd;
|
|
#endif
|
|
|
|
#ifdef CONFIG_PINCTRL
|
|
struct dev_pin_info *pins;
|
|
#endif
|
|
struct dev_msi_info msi;
|
|
#ifdef CONFIG_ARCH_HAS_DMA_OPS
|
|
const struct dma_map_ops *dma_ops;
|
|
#endif
|
|
u64 *dma_mask; /* dma mask (if dma'able device) */
|
|
u64 coherent_dma_mask;/* Like dma_mask, but for
|
|
alloc_coherent mappings as
|
|
not all hardware supports
|
|
64 bit addresses for consistent
|
|
allocations such descriptors. */
|
|
u64 bus_dma_limit; /* upstream dma constraint */
|
|
const struct bus_dma_region *dma_range_map;
|
|
|
|
struct device_dma_parameters *dma_parms;
|
|
|
|
struct list_head dma_pools; /* dma pools (if dma'ble) */
|
|
|
|
#ifdef CONFIG_DMA_DECLARE_COHERENT
|
|
struct dma_coherent_mem *dma_mem; /* internal for coherent mem
|
|
override */
|
|
#endif
|
|
#ifdef CONFIG_DMA_CMA
|
|
struct cma *cma_area; /* contiguous memory area for dma
|
|
allocations */
|
|
#endif
|
|
#ifdef CONFIG_SWIOTLB
|
|
struct io_tlb_mem *dma_io_tlb_mem;
|
|
#endif
|
|
#ifdef CONFIG_SWIOTLB_DYNAMIC
|
|
struct list_head dma_io_tlb_pools;
|
|
spinlock_t dma_io_tlb_lock;
|
|
bool dma_uses_io_tlb;
|
|
#endif
|
|
/* arch specific additions */
|
|
struct dev_archdata archdata;
|
|
|
|
struct device_node *of_node; /* associated device tree node */
|
|
struct fwnode_handle *fwnode; /* firmware device node */
|
|
|
|
#ifdef CONFIG_NUMA
|
|
int numa_node; /* NUMA node this device is close to */
|
|
#endif
|
|
dev_t devt; /* dev_t, creates the sysfs "dev" */
|
|
u32 id; /* device instance */
|
|
|
|
spinlock_t devres_lock;
|
|
struct list_head devres_head;
|
|
|
|
const struct class *class;
|
|
const struct attribute_group **groups; /* optional groups */
|
|
|
|
void (*release)(struct device *dev);
|
|
struct iommu_group *iommu_group;
|
|
struct dev_iommu *iommu;
|
|
|
|
struct device_physical_location *physical_location;
|
|
|
|
enum device_removable removable;
|
|
|
|
bool offline_disabled:1;
|
|
bool offline:1;
|
|
bool of_node_reused:1;
|
|
bool state_synced:1;
|
|
bool can_match:1;
|
|
#if defined(CONFIG_ARCH_HAS_SYNC_DMA_FOR_DEVICE) || \
|
|
defined(CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU) || \
|
|
defined(CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU_ALL)
|
|
bool dma_coherent:1;
|
|
#endif
|
|
#ifdef CONFIG_DMA_OPS_BYPASS
|
|
bool dma_ops_bypass : 1;
|
|
#endif
|
|
#ifdef CONFIG_DMA_NEED_SYNC
|
|
bool dma_skip_sync:1;
|
|
#endif
|
|
#ifdef CONFIG_IOMMU_DMA
|
|
bool dma_iommu:1;
|
|
#endif
|
|
ANDROID_KABI_RESERVE(1);
|
|
ANDROID_KABI_RESERVE(2);
|
|
ANDROID_KABI_RESERVE(3);
|
|
ANDROID_KABI_RESERVE(4);
|
|
ANDROID_KABI_RESERVE(5);
|
|
ANDROID_KABI_RESERVE(6);
|
|
ANDROID_KABI_RESERVE(7);
|
|
ANDROID_KABI_RESERVE(8);
|
|
};
|
|
|
|
/**
|
|
* struct device_link - Device link representation.
|
|
* @supplier: The device on the supplier end of the link.
|
|
* @s_node: Hook to the supplier device's list of links to consumers.
|
|
* @consumer: The device on the consumer end of the link.
|
|
* @c_node: Hook to the consumer device's list of links to suppliers.
|
|
* @link_dev: device used to expose link details in sysfs
|
|
* @status: The state of the link (with respect to the presence of drivers).
|
|
* @flags: Link flags.
|
|
* @rpm_active: Whether or not the consumer device is runtime-PM-active.
|
|
* @kref: Count repeated addition of the same link.
|
|
* @rm_work: Work structure used for removing the link.
|
|
* @supplier_preactivated: Supplier has been made active before consumer probe.
|
|
*/
|
|
struct device_link {
|
|
struct device *supplier;
|
|
struct list_head s_node;
|
|
struct device *consumer;
|
|
struct list_head c_node;
|
|
struct device link_dev;
|
|
enum device_link_state status;
|
|
u32 flags;
|
|
refcount_t rpm_active;
|
|
struct kref kref;
|
|
struct work_struct rm_work;
|
|
bool supplier_preactivated; /* Owned by consumer probe. */
|
|
ANDROID_KABI_RESERVE(1);
|
|
ANDROID_KABI_RESERVE(2);
|
|
};
|
|
|
|
#define kobj_to_dev(__kobj) container_of_const(__kobj, struct device, kobj)
|
|
|
|
/**
|
|
* device_iommu_mapped - Returns true when the device DMA is translated
|
|
* by an IOMMU
|
|
* @dev: Device to perform the check on
|
|
*/
|
|
static inline bool device_iommu_mapped(struct device *dev)
|
|
{
|
|
return (dev->iommu_group != NULL);
|
|
}
|
|
|
|
/* Get the wakeup routines, which depend on struct device */
|
|
#include <linux/pm_wakeup.h>
|
|
|
|
/**
|
|
* dev_name - Return a device's name.
|
|
* @dev: Device with name to get.
|
|
* Return: The kobject name of the device, or its initial name if unavailable.
|
|
*/
|
|
static inline const char *dev_name(const struct device *dev)
|
|
{
|
|
/* Use the init name until the kobject becomes available */
|
|
if (dev->init_name)
|
|
return dev->init_name;
|
|
|
|
return kobject_name(&dev->kobj);
|
|
}
|
|
|
|
/**
|
|
* dev_bus_name - Return a device's bus/class name, if at all possible
|
|
* @dev: struct device to get the bus/class name of
|
|
*
|
|
* Will return the name of the bus/class the device is attached to. If it is
|
|
* not attached to a bus/class, an empty string will be returned.
|
|
*/
|
|
static inline const char *dev_bus_name(const struct device *dev)
|
|
{
|
|
return dev->bus ? dev->bus->name : (dev->class ? dev->class->name : "");
|
|
}
|
|
|
|
__printf(2, 3) int dev_set_name(struct device *dev, const char *name, ...);
|
|
|
|
#ifdef CONFIG_NUMA
|
|
static inline int dev_to_node(struct device *dev)
|
|
{
|
|
return dev->numa_node;
|
|
}
|
|
static inline void set_dev_node(struct device *dev, int node)
|
|
{
|
|
dev->numa_node = node;
|
|
}
|
|
#else
|
|
static inline int dev_to_node(struct device *dev)
|
|
{
|
|
return NUMA_NO_NODE;
|
|
}
|
|
static inline void set_dev_node(struct device *dev, int node)
|
|
{
|
|
}
|
|
#endif
|
|
|
|
static inline struct irq_domain *dev_get_msi_domain(const struct device *dev)
|
|
{
|
|
#ifdef CONFIG_GENERIC_MSI_IRQ
|
|
return dev->msi.domain;
|
|
#else
|
|
return NULL;
|
|
#endif
|
|
}
|
|
|
|
static inline void dev_set_msi_domain(struct device *dev, struct irq_domain *d)
|
|
{
|
|
#ifdef CONFIG_GENERIC_MSI_IRQ
|
|
dev->msi.domain = d;
|
|
#endif
|
|
}
|
|
|
|
static inline void *dev_get_drvdata(const struct device *dev)
|
|
{
|
|
return dev->driver_data;
|
|
}
|
|
|
|
static inline void dev_set_drvdata(struct device *dev, void *data)
|
|
{
|
|
dev->driver_data = data;
|
|
}
|
|
|
|
static inline struct pm_subsys_data *dev_to_psd(struct device *dev)
|
|
{
|
|
return dev ? dev->power.subsys_data : NULL;
|
|
}
|
|
|
|
static inline unsigned int dev_get_uevent_suppress(const struct device *dev)
|
|
{
|
|
return dev->kobj.uevent_suppress;
|
|
}
|
|
|
|
static inline void dev_set_uevent_suppress(struct device *dev, int val)
|
|
{
|
|
dev->kobj.uevent_suppress = val;
|
|
}
|
|
|
|
static inline int device_is_registered(struct device *dev)
|
|
{
|
|
return dev->kobj.state_in_sysfs;
|
|
}
|
|
|
|
static inline void device_enable_async_suspend(struct device *dev)
|
|
{
|
|
if (!dev->power.is_prepared)
|
|
dev->power.async_suspend = true;
|
|
}
|
|
|
|
static inline void device_disable_async_suspend(struct device *dev)
|
|
{
|
|
if (!dev->power.is_prepared)
|
|
dev->power.async_suspend = false;
|
|
}
|
|
|
|
static inline bool device_async_suspend_enabled(struct device *dev)
|
|
{
|
|
return !!dev->power.async_suspend;
|
|
}
|
|
|
|
static inline bool device_pm_not_required(struct device *dev)
|
|
{
|
|
return dev->power.no_pm;
|
|
}
|
|
|
|
static inline void device_set_pm_not_required(struct device *dev)
|
|
{
|
|
dev->power.no_pm = true;
|
|
}
|
|
|
|
static inline void dev_pm_syscore_device(struct device *dev, bool val)
|
|
{
|
|
#ifdef CONFIG_PM_SLEEP
|
|
dev->power.syscore = val;
|
|
#endif
|
|
}
|
|
|
|
static inline void dev_pm_set_driver_flags(struct device *dev, u32 flags)
|
|
{
|
|
dev->power.driver_flags = flags;
|
|
}
|
|
|
|
static inline bool dev_pm_test_driver_flags(struct device *dev, u32 flags)
|
|
{
|
|
return !!(dev->power.driver_flags & flags);
|
|
}
|
|
|
|
static inline void device_lock(struct device *dev)
|
|
{
|
|
mutex_lock(&dev->mutex);
|
|
}
|
|
|
|
static inline int device_lock_interruptible(struct device *dev)
|
|
{
|
|
return mutex_lock_interruptible(&dev->mutex);
|
|
}
|
|
|
|
static inline int device_trylock(struct device *dev)
|
|
{
|
|
return mutex_trylock(&dev->mutex);
|
|
}
|
|
|
|
static inline void device_unlock(struct device *dev)
|
|
{
|
|
mutex_unlock(&dev->mutex);
|
|
}
|
|
|
|
DEFINE_GUARD(device, struct device *, device_lock(_T), device_unlock(_T))
|
|
|
|
static inline void device_lock_assert(struct device *dev)
|
|
{
|
|
lockdep_assert_held(&dev->mutex);
|
|
}
|
|
|
|
static inline bool dev_has_sync_state(struct device *dev)
|
|
{
|
|
if (!dev)
|
|
return false;
|
|
if (dev->driver && dev->driver->sync_state)
|
|
return true;
|
|
if (dev->bus && dev->bus->sync_state)
|
|
return true;
|
|
return false;
|
|
}
|
|
|
|
static inline void dev_set_removable(struct device *dev,
|
|
enum device_removable removable)
|
|
{
|
|
dev->removable = removable;
|
|
}
|
|
|
|
static inline bool dev_is_removable(struct device *dev)
|
|
{
|
|
return dev->removable == DEVICE_REMOVABLE;
|
|
}
|
|
|
|
static inline bool dev_removable_is_valid(struct device *dev)
|
|
{
|
|
return dev->removable != DEVICE_REMOVABLE_NOT_SUPPORTED;
|
|
}
|
|
|
|
/*
|
|
* High level routines for use by the bus drivers
|
|
*/
|
|
int __must_check device_register(struct device *dev);
|
|
void device_unregister(struct device *dev);
|
|
void device_initialize(struct device *dev);
|
|
int __must_check device_add(struct device *dev);
|
|
void device_del(struct device *dev);
|
|
|
|
DEFINE_FREE(device_del, struct device *, if (_T) device_del(_T))
|
|
|
|
int device_for_each_child(struct device *dev, void *data,
|
|
int (*fn)(struct device *dev, void *data));
|
|
int device_for_each_child_reverse(struct device *dev, void *data,
|
|
int (*fn)(struct device *dev, void *data));
|
|
int device_for_each_child_reverse_from(struct device *parent,
|
|
struct device *from, const void *data,
|
|
int (*fn)(struct device *, const void *));
|
|
struct device *device_find_child(struct device *dev, void *data,
|
|
int (*match)(struct device *dev, void *data));
|
|
struct device *device_find_child_by_name(struct device *parent,
|
|
const char *name);
|
|
struct device *device_find_any_child(struct device *parent);
|
|
|
|
int device_rename(struct device *dev, const char *new_name);
|
|
int device_move(struct device *dev, struct device *new_parent,
|
|
enum dpm_order dpm_order);
|
|
int device_change_owner(struct device *dev, kuid_t kuid, kgid_t kgid);
|
|
|
|
static inline bool device_supports_offline(struct device *dev)
|
|
{
|
|
return dev->bus && dev->bus->offline && dev->bus->online;
|
|
}
|
|
|
|
#define __device_lock_set_class(dev, name, key) \
|
|
do { \
|
|
struct device *__d2 __maybe_unused = dev; \
|
|
lock_set_class(&__d2->mutex.dep_map, name, key, 0, _THIS_IP_); \
|
|
} while (0)
|
|
|
|
/**
|
|
* device_lock_set_class - Specify a temporary lock class while a device
|
|
* is attached to a driver
|
|
* @dev: device to modify
|
|
* @key: lock class key data
|
|
*
|
|
* This must be called with the device_lock() already held, for example
|
|
* from driver ->probe(). Take care to only override the default
|
|
* lockdep_no_validate class.
|
|
*/
|
|
#ifdef CONFIG_LOCKDEP
|
|
#define device_lock_set_class(dev, key) \
|
|
do { \
|
|
struct device *__d = dev; \
|
|
dev_WARN_ONCE(__d, !lockdep_match_class(&__d->mutex, \
|
|
&__lockdep_no_validate__), \
|
|
"overriding existing custom lock class\n"); \
|
|
__device_lock_set_class(__d, #key, key); \
|
|
} while (0)
|
|
#else
|
|
#define device_lock_set_class(dev, key) __device_lock_set_class(dev, #key, key)
|
|
#endif
|
|
|
|
/**
|
|
* device_lock_reset_class - Return a device to the default lockdep novalidate state
|
|
* @dev: device to modify
|
|
*
|
|
* This must be called with the device_lock() already held, for example
|
|
* from driver ->remove().
|
|
*/
|
|
#define device_lock_reset_class(dev) \
|
|
do { \
|
|
struct device *__d __maybe_unused = dev; \
|
|
lock_set_novalidate_class(&__d->mutex.dep_map, "&dev->mutex", \
|
|
_THIS_IP_); \
|
|
} while (0)
|
|
|
|
void lock_device_hotplug(void);
|
|
void unlock_device_hotplug(void);
|
|
int lock_device_hotplug_sysfs(void);
|
|
int device_offline(struct device *dev);
|
|
int device_online(struct device *dev);
|
|
|
|
void set_primary_fwnode(struct device *dev, struct fwnode_handle *fwnode);
|
|
void set_secondary_fwnode(struct device *dev, struct fwnode_handle *fwnode);
|
|
void device_set_node(struct device *dev, struct fwnode_handle *fwnode);
|
|
void device_set_of_node_from_dev(struct device *dev, const struct device *dev2);
|
|
|
|
static inline struct device_node *dev_of_node(struct device *dev)
|
|
{
|
|
if (!IS_ENABLED(CONFIG_OF) || !dev)
|
|
return NULL;
|
|
return dev->of_node;
|
|
}
|
|
|
|
static inline int dev_num_vf(struct device *dev)
|
|
{
|
|
if (dev->bus && dev->bus->num_vf)
|
|
return dev->bus->num_vf(dev);
|
|
return 0;
|
|
}
|
|
|
|
/*
|
|
* Root device objects for grouping under /sys/devices
|
|
*/
|
|
struct device *__root_device_register(const char *name, struct module *owner);
|
|
|
|
/* This is a macro to avoid include problems with THIS_MODULE */
|
|
#define root_device_register(name) \
|
|
__root_device_register(name, THIS_MODULE)
|
|
|
|
void root_device_unregister(struct device *root);
|
|
|
|
static inline void *dev_get_platdata(const struct device *dev)
|
|
{
|
|
return dev->platform_data;
|
|
}
|
|
|
|
/*
|
|
* Manual binding of a device to driver. See drivers/base/bus.c
|
|
* for information on use.
|
|
*/
|
|
int __must_check device_driver_attach(const struct device_driver *drv,
|
|
struct device *dev);
|
|
int __must_check device_bind_driver(struct device *dev);
|
|
void device_release_driver(struct device *dev);
|
|
int __must_check device_attach(struct device *dev);
|
|
int __must_check driver_attach(const struct device_driver *drv);
|
|
void device_initial_probe(struct device *dev);
|
|
int __must_check device_reprobe(struct device *dev);
|
|
|
|
bool device_is_bound(struct device *dev);
|
|
|
|
/*
|
|
* Easy functions for dynamically creating devices on the fly
|
|
*/
|
|
__printf(5, 6) struct device *
|
|
device_create(const struct class *cls, struct device *parent, dev_t devt,
|
|
void *drvdata, const char *fmt, ...);
|
|
__printf(6, 7) struct device *
|
|
device_create_with_groups(const struct class *cls, struct device *parent, dev_t devt,
|
|
void *drvdata, const struct attribute_group **groups,
|
|
const char *fmt, ...);
|
|
void device_destroy(const struct class *cls, dev_t devt);
|
|
|
|
int __must_check device_add_groups(struct device *dev,
|
|
const struct attribute_group **groups);
|
|
void device_remove_groups(struct device *dev,
|
|
const struct attribute_group **groups);
|
|
|
|
static inline int __must_check device_add_group(struct device *dev,
|
|
const struct attribute_group *grp)
|
|
{
|
|
const struct attribute_group *groups[] = { grp, NULL };
|
|
|
|
return device_add_groups(dev, groups);
|
|
}
|
|
|
|
static inline void device_remove_group(struct device *dev,
|
|
const struct attribute_group *grp)
|
|
{
|
|
const struct attribute_group *groups[] = { grp, NULL };
|
|
|
|
return device_remove_groups(dev, groups);
|
|
}
|
|
|
|
int __must_check devm_device_add_group(struct device *dev,
|
|
const struct attribute_group *grp);
|
|
|
|
/*
|
|
* get_device - atomically increment the reference count for the device.
|
|
*
|
|
*/
|
|
struct device *get_device(struct device *dev);
|
|
void put_device(struct device *dev);
|
|
|
|
DEFINE_FREE(put_device, struct device *, if (_T) put_device(_T))
|
|
|
|
bool kill_device(struct device *dev);
|
|
|
|
#ifdef CONFIG_DEVTMPFS
|
|
int devtmpfs_mount(void);
|
|
#else
|
|
static inline int devtmpfs_mount(void) { return 0; }
|
|
#endif
|
|
|
|
/* drivers/base/power/shutdown.c */
|
|
void device_shutdown(void);
|
|
|
|
/* debugging and troubleshooting/diagnostic helpers. */
|
|
const char *dev_driver_string(const struct device *dev);
|
|
|
|
/* Device links interface. */
|
|
struct device_link *device_link_add(struct device *consumer,
|
|
struct device *supplier, u32 flags);
|
|
void device_link_del(struct device_link *link);
|
|
void device_link_remove(void *consumer, struct device *supplier);
|
|
void device_links_supplier_sync_state_pause(void);
|
|
void device_links_supplier_sync_state_resume(void);
|
|
void device_link_wait_removal(void);
|
|
|
|
/* Create alias, so I can be autoloaded. */
|
|
#define MODULE_ALIAS_CHARDEV(major,minor) \
|
|
MODULE_ALIAS("char-major-" __stringify(major) "-" __stringify(minor))
|
|
#define MODULE_ALIAS_CHARDEV_MAJOR(major) \
|
|
MODULE_ALIAS("char-major-" __stringify(major) "-*")
|
|
|
|
#endif /* _DEVICE_H_ */
|