f4b76e8165
https://source.android.com/docs/security/bulletin/2023-04-01 CVE-2022-4696 CVE-2023-20941 * tag 'ASB-2023-04-05_11-5.4' of https://android.googlesource.com/kernel/common: UPSTREAM: ext4: fix kernel BUG in 'ext4_write_inline_data_end()' UPSTREAM: hid: bigben_probe(): validate report count UPSTREAM: HID: bigben: use spinlock to safely schedule workers BACKPORT: of: base: Skip CPU nodes with "fail"/"fail-..." status UPSTREAM: HID: bigben_worker() remove unneeded check on report_field UPSTREAM: HID: bigben: use spinlock to protect concurrent accesses UPSTREAM: hwrng: virtio - add an internal buffer UPSTREAM: ext4: fix another off-by-one fsmap error on 1k block filesystems UPSTREAM: ext4: refuse to create ea block when umounted UPSTREAM: ext4: optimize ea_inode block expansion UPSTREAM: ext4: allocate extended attribute value in vmalloc area BACKPORT: FROMGIT: cgroup: Use separate src/dst nodes when preloading css_sets for migration Revert "iommu: Add gfp parameter to iommu_ops::map" Revert "iommu/amd: Pass gfp flags to iommu_map_page() in amd_iommu_map()" Revert "RDMA/usnic: use iommu_map_atomic() under spin_lock()" Linux 5.4.233 bpf: add missing header file include Revert "net/sched: taprio: make qdisc_leaf() see the per-netdev-queue pfifo child qdiscs" ext4: Fix function prototype mismatch for ext4_feat_ktype wifi: mwifiex: Add missing compatible string for SD8787 uaccess: Add speculation barrier to copy_from_user() mac80211: mesh: embedd mesh_paths and mpp_paths into ieee80211_if_mesh drm/i915/gvt: fix double free bug in split_2MB_gtt_entry alarmtimer: Prevent starvation by small intervals and SIG_IGN powerpc: dts: t208x: Disable 10G on MAC1 and MAC2 can: kvaser_usb: hydra: help gcc-13 to figure out cmd_len KVM: VMX: Execute IBPB on emulated VM-exit when guest has IBRS KVM: x86: Fail emulation during EMULTYPE_SKIP on any exception random: always mix cycle counter in add_latent_entropy() powerpc: dts: t208x: Mark MAC1 and MAC2 as 10G wifi: rtl8xxxu: gen2: Turn on the rate control drm/etnaviv: don't truncate physical page address drm: etnaviv: fix common struct sg_table related issues scatterlist: add generic wrappers for iterating over sgtable objects dma-mapping: add generic helpers for mapping sgtable objects Linux 5.4.232 iommu/amd: Pass gfp flags to iommu_map_page() in amd_iommu_map() net: sched: sch: Fix off by one in htb_activate_prios() ASoC: SOF: Intel: hda-dai: fix possible stream_tag leak nilfs2: fix underflow in second superblock position calculations kvm: initialize all of the kvm_debugregs structure before sending it to userspace i40e: Add checking for null for nlmsg_find_attr() ipv6: Fix tcp socket connection with DSCP. ipv6: Fix datagram socket connection with DSCP. ixgbe: add double of VLAN header when computing the max MTU net: mpls: fix stale pointer if allocation fails during device rename net: stmmac: Restrict warning on disabling DMA store and fwd mode bnxt_en: Fix mqprio and XDP ring checking logic net: stmmac: fix order of dwmac5 FlexPPS parametrization sequence net/usb: kalmia: Don't pass act_len in usb_bulk_msg error path dccp/tcp: Avoid negative sk_forward_alloc by ipv6_pinfo.pktoptions. sctp: sctp_sock_filter(): avoid list_entry() on possibly empty list net: bgmac: fix BCM5358 support by setting correct flags i40e: add double of VLAN header when computing the max MTU ixgbe: allow to increase MTU to 3K with XDP enabled revert "squashfs: harden sanity check in squashfs_read_xattr_id_table" net: Fix unwanted sign extension in netdev_stats_to_stats64() Revert "mm: Always release pages to the buddy allocator in memblock_free_late()." hugetlb: check for undefined shift on 32 bit architectures sched/psi: Fix use-after-free in ep_remove_wait_queue() ALSA: hda/realtek - fixed wrong gpio assigned ALSA: hda/conexant: add a new hda codec SN6180 mmc: mmc_spi: fix error handling in mmc_spi_probe() mmc: sdio: fix possible resource leaks in some error paths ipv4: Fix incorrect route flushing when source address is deleted Revert "ipv4: Fix incorrect route flushing when source address is deleted" xfs: sync lazy sb accounting on quiesce of read-only mounts xfs: prevent UAF in xfs_log_item_in_current_chkpt xfs: fix the forward progress assertion in xfs_iwalk_run_callbacks xfs: ensure inobt record walks always make forward progress xfs: fix missing CoW blocks writeback conversion retry xfs: only relog deferred intent items if free space in the log gets low xfs: expose the log push threshold xfs: periodically relog deferred intent items xfs: change the order in which child and parent defer ops are finished xfs: fix an incore inode UAF in xfs_bui_recover xfs: clean up xfs_bui_item_recover iget/trans_alloc/ilock ordering xfs: clean up bmap intent item recovery checking xfs: xfs_defer_capture should absorb remaining transaction reservation xfs: xfs_defer_capture should absorb remaining block reservations xfs: proper replay of deferred ops queued during log recovery xfs: fix finobt btree block recovery ordering xfs: log new intent items created as part of finishing recovered intent items xfs: refactor xfs_defer_finish_noroll xfs: turn dfp_intent into a xfs_log_item xfs: merge the ->diff_items defer op into ->create_intent xfs: merge the ->log_item defer op into ->create_intent xfs: factor out a xfs_defer_create_intent helper xfs: remove the xfs_inode_log_item_t typedef xfs: remove the xfs_efd_log_item_t typedef xfs: remove the xfs_efi_log_item_t typedef netfilter: nft_tproxy: restrict to prerouting hook btrfs: free device in btrfs_close_devices for a single device filesystem aio: fix mremap after fork null-deref nvme-fc: fix a missing queue put in nvmet_fc_ls_create_association s390/decompressor: specify __decompress() buf len to avoid overflow net: sched: sch: Bounds check priority net: stmmac: do not stop RX_CLK in Rx LPI state for qcs404 SoC net/rose: Fix to not accept on connected socket tools/virtio: fix the vringh test for virtio ring changes ASoC: cs42l56: fix DT probe selftests/bpf: Verify copy_register_state() preserves parent/live fields migrate: hugetlb: check for hugetlb shared PMD in node migration bpf: Always return target ifindex in bpf_fib_lookup nvme-pci: Move enumeration by class to be last in the table arm64: dts: meson-axg: Make mmc host controller interrupts level-sensitive arm64: dts: meson-g12-common: Make mmc host controller interrupts level-sensitive arm64: dts: meson-gx: Make mmc host controller interrupts level-sensitive riscv: Fixup race condition on PG_dcache_clean in flush_icache_pte ceph: flush cap releases when the session is flushed usb: typec: altmodes/displayport: Fix probe pin assign check usb: core: add quirk for Alcor Link AK9563 smartcard reader net: USB: Fix wrong-direction WARNING in plusb.c pinctrl: intel: Restore the pins that used to be in Direct IRQ mode pinctrl: single: fix potential NULL dereference pinctrl: aspeed: Fix confusing types in return value ALSA: pci: lx6464es: fix a debug loop selftests: forwarding: lib: quote the sysctl values rds: rds_rm_zerocopy_callback() use list_first_entry() ice: Do not use WQ_MEM_RECLAIM flag for workqueue ionic: clean interrupt before enabling queue to avoid credit race net: phy: meson-gxl: use MMD access dummy stubs for GXL, internal PHY bonding: fix error checking in bond_debug_reregister() xfrm: fix bug with DSCP copy to v6 from v4 tunnel RDMA/usnic: use iommu_map_atomic() under spin_lock() iommu: Add gfp parameter to iommu_ops::map IB/IPoIB: Fix legacy IPoIB due to wrong number of queues IB/hfi1: Restore allocated resources on failed copyout can: j1939: do not wait 250 ms if the same addr was already claimed tracing: Fix poll() and select() do not work on per_cpu trace_pipe and trace_pipe_raw ALSA: emux: Avoid potential array out-of-bound in snd_emux_xg_control() btrfs: zlib: zero-initialize zlib workspace btrfs: limit device extents to the device size iio:adc:twl6030: Enable measurement of VAC wifi: brcmfmac: Check the count value of channel spec to prevent out-of-bounds reads f2fs: fix to do sanity check on i_extra_isize in is_alive() fbdev: smscufx: fix error handling code in ufx_usb_probe powerpc/imc-pmu: Revert nest_init_lock to being a mutex serial: 8250_dma: Fix DMA Rx rearm race serial: 8250_dma: Fix DMA Rx completion race xprtrdma: Fix regbuf data not freed in rpcrdma_req_create() mm: swap: properly update readahead statistics in unuse_pte_range() nvmem: core: fix cell removal on error Squashfs: fix handling and sanity checking of xattr_ids count mm/swapfile: add cond_resched() in get_swap_pages() fpga: stratix10-soc: Fix return value check in s10_ops_write_init() mm: hugetlb: proc: check for hugetlb shared PMD in /proc/PID/smaps riscv: disable generation of unwind tables parisc: Wire up PTRACE_GETREGS/PTRACE_SETREGS for compat case parisc: Fix return code of pdc_iodc_print() iio:adc:twl6030: Enable measurements of VUSB, VBAT and others iio: adc: berlin2-adc: Add missing of_node_put() in error path iio: hid: fix the retval in accel_3d_capture_sample efi: Accept version 2 of memory attributes table watchdog: diag288_wdt: fix __diag288() inline assembly watchdog: diag288_wdt: do not use stack buffers for hardware data fbcon: Check font dimension limits Input: i8042 - add Clevo PCX0DX to i8042 quirk table Input: i8042 - add TUXEDO devices to i8042 quirk tables Input: i8042 - merge quirk tables Input: i8042 - move __initconst to fix code styling warning vc_screen: move load of struct vc_data pointer in vcs_read() to avoid UAF usb: gadget: f_fs: Fix unbalanced spinlock in __ffs_ep0_queue_wait usb: dwc3: qcom: enable vbus override when in OTG dr-mode usb: dwc3: dwc3-qcom: Fix typo in the dwc3 vbus override API iio: adc: stm32-dfsdm: fill module aliases net/x25: Fix to not accept on connected socket i2c: rk3x: fix a bunch of kernel-doc warnings scsi: iscsi_tcp: Fix UAF during login when accessing the shost ipaddress scsi: target: core: Fix warning on RT kernels efi: fix potential NULL deref in efi_mem_reserve_persistent net: openvswitch: fix flow memory leak in ovs_flow_cmd_new virtio-net: Keep stop() to follow mirror sequence of open() selftests: net: udpgso_bench_tx: Cater for pending datagrams zerocopy benchmarking selftests: net: udpgso_bench: Fix racing bug between the rx/tx programs selftests: net: udpgso_bench_rx/tx: Stop when wrong CLI args are provided selftests: net: udpgso_bench_rx: Fix 'used uninitialized' compiler warning ata: libata: Fix sata_down_spd_limit() when no link speed is reported can: j1939: fix errant WARN_ON_ONCE in j1939_session_deactivate net: phy: meson-gxl: Add generic dummy stubs for MMD register access squashfs: harden sanity check in squashfs_read_xattr_id_table netfilter: br_netfilter: disable sabotage_in hook after first suppression netrom: Fix use-after-free caused by accept on already connected socket fix "direction" argument of iov_iter_kvec() fix iov_iter_bvec() "direction" argument WRITE is "data source", not destination... scsi: Revert "scsi: core: map PQ=1, PDT=other values to SCSI_SCAN_TARGET_PRESENT" arm64: dts: imx8mm: Fix pad control for UART1_DTE_RX ALSA: hda/via: Avoid potential array out-of-bound in add_secret_dac_path() ASoC: Intel: bytcr_rt5651: Drop reference count of ACPI device after use bus: sunxi-rsb: Fix error handling in sunxi_rsb_init() firewire: fix memory leak for payload of request subaction to IEC 61883-1 FCP region Linux 5.4.231 Revert "xprtrdma: Fix regbuf data not freed in rpcrdma_req_create()" usb: host: xhci-plat: add wakeup entry at sysfs Bluetooth: fix null ptr deref on hci_sync_conn_complete_evt ipv6: ensure sane device mtu in tunnels exit: Use READ_ONCE() for all oops/warn limit reads docs: Fix path paste-o for /sys/kernel/warn_count panic: Expose "warn_count" to sysfs panic: Introduce warn_limit panic: Consolidate open-coded panic_on_warn checks exit: Allow oops_limit to be disabled exit: Expose "oops_count" to sysfs exit: Put an upper limit on how often we can oops ia64: make IA64_MCA_RECOVERY bool instead of tristate csky: Fix function name in csky_alignment() and die() h8300: Fix build errors from do_exit() to make_task_dead() transition hexagon: Fix function name in die() objtool: Add a missing comma to avoid string concatenation exit: Add and use make_task_dead. mm: kasan: do not panic if both panic_on_warn and kasan_multishot set panic: unset panic_on_warn inside panic() sysctl: add a new register_sysctl_init() interface dmaengine: imx-sdma: Fix a possible memory leak in sdma_transfer_init blk-cgroup: fix missing pd_online_fn() while activating policy bpf: Skip task with pid=1 in send_signal_common() ARM: dts: imx: Fix pca9547 i2c-mux node name x86/asm: Fix an assembler warning with current binutils clk: Fix pointer casting to prevent oops in devm_clk_release() perf/x86/amd: fix potential integer overflow on shift of a int netfilter: conntrack: unify established states for SCTP paths x86/i8259: Mark legacy PIC interrupts with IRQ_LEVEL block: fix and cleanup bio_check_ro nfsd: Ensure knfsd shuts down when the "nfsd" pseudofs is unmounted Revert "Input: synaptics - switch touchpad on HP Laptop 15-da3001TU to RMI mode" net: mdio-mux-meson-g12a: force internal PHY off on mux switch net: xgene: Move shared header file into include/linux net/phy/mdio-i2c: Move header file to include/linux/mdio net/tg3: resolve deadlock in tg3_reset_task() during EEH thermal: intel: int340x: Add locking to int340x_thermal_get_trip_type() net: ravb: Fix possible hang if RIS2_QFF1 happen sctp: fail if no bound addresses can be used for a given scope net/sched: sch_taprio: do not schedule in taprio_reset() netrom: Fix use-after-free of a listening socket. netfilter: conntrack: fix vtag checks for ABORT/SHUTDOWN_COMPLETE ipv4: prevent potential spectre v1 gadget in fib_metrics_match() ipv4: prevent potential spectre v1 gadget in ip_metrics_convert() netlink: annotate data races around sk_state netlink: annotate data races around dst_portid and dst_group netlink: annotate data races around nlk->portid netfilter: nft_set_rbtree: skip elements in transaction from garbage collection net: fix UaF in netns ops registration error path netlink: prevent potential spectre v1 gadgets EDAC/qcom: Do not pass llcc_driv_data as edac_device_ctl_info's pvt_info EDAC/device: Respect any driver-supplied workqueue polling value ARM: 9280/1: mm: fix warning on phys_addr_t to void pointer assignment thermal: intel: int340x: Protect trip temperature from concurrent updates KVM: x86/vmx: Do not skip segment attributes if unusable bit is set cifs: Fix oops due to uncleared server->smbd_conn in reconnect ftrace/scripts: Update the instructions for ftrace-bisect.sh trace_events_hist: add check for return value of 'create_hist_field' tracing: Make sure trace_printk() can output as soon as it can be used module: Don't wait for GOING modules scsi: hpsa: Fix allocation size for scsi_host_alloc() Bluetooth: hci_sync: cancel cmd_timer if hci_open failed Revert "Revert "xhci: Set HCD flag to defer primary roothub registration"" fs: reiserfs: remove useless new_opts in reiserfs_remount netfilter: conntrack: do not renew entry stuck in tcp SYN_SENT state Revert "selftests/bpf: check null propagation only neither reg is PTR_TO_BTF_ID" mmc: sdhci-esdhc-imx: correct the tuning start tap and step setting mmc: sdhci-esdhc-imx: disable the CMD CRC check for standard tuning mmc: sdhci-esdhc-imx: clear pending interrupt and halt cqhci lockref: stop doing cpu_relax in the cmpxchg loop platform/x86: asus-nb-wmi: Add alternate mapping for KEY_SCREENLOCK platform/x86: touchscreen_dmi: Add info for the CSL Panther Tab HD scsi: hisi_sas: Set a port invalid only if there are no devices attached when refreshing port id KVM: s390: interrupt: use READ_ONCE() before cmpxchg() spi: spidev: remove debug messages that access spidev->spi without locking ASoC: fsl-asoc-card: Fix naming of AC'97 CODEC widgets ASoC: fsl_ssi: Rename AC'97 streams to avoid collisions with AC'97 CODEC cpufreq: armada-37xx: stop using 0 as NULL pointer s390/debug: add _ASM_S390_ prefix to header guard drm: Add orientation quirk for Lenovo ideapad D330-10IGL ASoC: fsl_micfil: Correct the number of steps on SX controls cpufreq: Add Tegra234 to cpufreq-dt-platdev blocklist tcp: fix rate_app_limited to default to 1 net: dsa: microchip: ksz9477: port map correction in ALU table entry register driver core: Fix test_async_probe_init saves device in wrong array w1: fix WARNING after calling w1_process() w1: fix deadloop in __w1_remove_master_device() tcp: avoid the lookup process failing to get sk in ehash table dmaengine: xilinx_dma: call of_node_put() when breaking out of for_each_child_of_node() dmaengine: xilinx_dma: Fix devm_platform_ioremap_resource error handling dmaengine: xilinx_dma: use devm_platform_ioremap_resource() HID: betop: check shape of output reports net: macb: fix PTP TX timestamp failure due to packet padding dmaengine: Fix double increment of client_count in dma_chan_get() drm/panfrost: fix GENERIC_ATOMIC64 dependency net: mlx5: eliminate anonymous module_init & module_exit usb: gadget: f_fs: Ensure ep0req is dequeued before free_request usb: gadget: f_fs: Prevent race during ffs_ep0_queue_wait HID: revert CHERRY_MOUSE_000C quirk net: stmmac: fix invalid call to mdiobus_get_phy() HID: check empty report_list in bigben_probe() HID: check empty report_list in hid_validate_values() net: mdio: validate parameter addr in mdiobus_get_phy() net: usb: sr9700: Handle negative len l2tp: Don't sleep and disable BH under writer-side sk_callback_lock l2tp: Serialize access to sk_user_data with sk_callback_lock net: fix a concurrency bug in l2tp_tunnel_register() net/sched: sch_taprio: fix possible use-after-free wifi: rndis_wlan: Prevent buffer overflow in rndis_query_oid gpio: mxc: Always set GPIOs used as interrupt source to INPUT mode net: wan: Add checks for NULL for utdm in undo_uhdlc_init and unmap_si_regs net: nfc: Fix use-after-free in local_cleanup() phy: rockchip-inno-usb2: Fix missing clk_disable_unprepare() in rockchip_usb2phy_power_on() bpf: Fix pointer-leak due to insufficient speculative store bypass mitigation amd-xgbe: Delay AN timeout during KR training amd-xgbe: TX Flow Ctrl Registers are h/w ver dependent affs: initialize fsdata in affs_truncate() IB/hfi1: Fix expected receive setup error exit issues IB/hfi1: Reserve user expected TIDs IB/hfi1: Reject a zero-length user expected buffer RDMA/core: Fix ib block iterator counter overflow tomoyo: fix broken dependency on *.conf.default EDAC/highbank: Fix memory leak in highbank_mc_probe() HID: intel_ish-hid: Add check for ishtp_dma_tx_map ARM: imx: add missing of_node_put() ARM: imx35: Retrieve the IIM base address from devicetree ARM: imx31: Retrieve the IIM base address from devicetree ARM: imx27: Retrieve the SYSCTRL base address from devicetree ARM: dts: imx6qdl-gw560x: Remove incorrect 'uart-has-rtscts' memory: mvebu-devbus: Fix missing clk_disable_unprepare in mvebu_devbus_probe() memory: atmel-sdramc: Fix missing clk_disable_unprepare in atmel_ramc_probe() clk: Provide new devm_clk helpers for prepared and enabled clocks clk: generalize devm_clk_get() a bit Linux 5.4.230 mm/khugepaged: fix collapse_pte_mapped_thp() to allow anon_vma x86/fpu: Use _Alignof to avoid undefined behavior in TYPE_ALIGN drm/amd/display: Fix COLOR_SPACE_YCBCR2020_TYPE matrix drm/amd/display: Fix set scaling doesn's work drm/i915: re-disable RC6p on Sandy Bridge gsmi: fix null-deref in gsmi_get_variable serial: atmel: fix incorrect baudrate setup dmaengine: tegra210-adma: fix global intr clear serial: pch_uart: Pass correct sg to dma_unmap_sg() dt-bindings: phy: g12a-usb3-pcie-phy: fix compatible string documentation usb-storage: apply IGNORE_UAS only for HIKSEMI MD202 on RTL9210 usb: gadget: f_ncm: fix potential NULL ptr deref in ncm_bitrate() usb: gadget: g_webcam: Send color matching descriptor per frame usb: typec: altmodes/displayport: Fix pin assignment calculation usb: typec: altmodes/displayport: Add pin assignment helper usb: host: ehci-fsl: Fix module alias USB: serial: cp210x: add SCALANCE LPE-9000 device id USB: gadgetfs: Fix race between mounting and unmounting cifs: do not include page data when checking signature btrfs: fix race between quota rescan and disable leading to NULL pointer deref mmc: sunxi-mmc: Fix clock refcount imbalance during unbind comedi: adv_pci1760: Fix PWM instruction handling usb: core: hub: disable autosuspend for TI TUSB8041 misc: fastrpc: Fix use-after-free race condition for maps misc: fastrpc: Don't remove map on creater_process and device_release USB: misc: iowarrior: fix up header size for USB_DEVICE_ID_CODEMERCS_IOW100 USB: serial: option: add Quectel EM05CN modem USB: serial: option: add Quectel EM05CN (SG) modem USB: serial: option: add Quectel EC200U modem USB: serial: option: add Quectel EM05-G (RS) modem USB: serial: option: add Quectel EM05-G (CS) modem USB: serial: option: add Quectel EM05-G (GR) modem prlimit: do_prlimit needs to have a speculation check xhci: Detect lpm incapable xHC USB3 roothub ports from ACPI tables usb: acpi: add helper to check port lpm capability using acpi _DSM xhci: Add a flag to disable USB3 lpm on a xhci root port level. xhci: Add update_hub_device override for PCI xHCI hosts xhci: Fix null pointer dereference when host dies usb: xhci: Check endpoint is valid before dereferencing it xhci-pci: set the dma max_seg_size ALSA: hda/realtek - Turn on power early drm/i915/gt: Reset twice efi: fix userspace infinite retry read efivars after EFI runtime services page fault nilfs2: fix general protection fault in nilfs_btree_insert() Add exception protection processing for vd in axi_chan_handle_err function wifi: brcmfmac: fix regression for Broadcom PCIe wifi devices f2fs: let's avoid panic if extent_tree is not created RDMA/srp: Move large values to a new enum for gcc13 net/ethtool/ioctl: return -EOPNOTSUPP if we have no phy stats selftests/bpf: check null propagation only neither reg is PTR_TO_BTF_ID pNFS/filelayout: Fix coalescing test for single DS Revert "net: add atomic_long_t to net_device_stats fields" Revert "PM/devfreq: governor: Add a private governor_data for governor" Linux 5.4.229 tipc: call tipc_lxc_xmit without holding node_read_lock ocfs2: fix freeing uninitialized resource on ocfs2_dlm_shutdown tipc: Add a missing case of TIPC_DIRECT_MSG type tty: serial: tegra: Handle RX transfer in PIO mode if DMA wasn't started tipc: fix use-after-free in tipc_disc_rcv() Revert "usb: ulpi: defer ulpi_register on ulpi_read_id timeout" mm: Always release pages to the buddy allocator in memblock_free_late(). efi: fix NULL-deref in init error path arm64: cmpxchg_double*: hazard against entire exchange variable arm64: atomics: remove LL/SC trampolines arm64: atomics: format whitespace consistently drm/virtio: Fix GEM handle creation UAF x86/resctrl: Fix task CLOSID/RMID update race x86/resctrl: Use task_curr() instead of task_struct->on_cpu to prevent unnecessary IPI iommu/mediatek-v1: Fix an error handling path in mtk_iommu_v1_probe() iommu/mediatek-v1: Add error handle for mtk_iommu_probe net/mlx5: Fix ptp max frequency adjustment range net/mlx5: Rename ptp clock info net/sched: act_mpls: Fix warning during failed attribute validation nfc: pn533: Wait for out_urb's completion in pn533_usb_send_frame() hvc/xen: lock console list traversal tipc: fix unexpected link reset due to discovery messages tipc: eliminate checking netns if node established tipc: improve throughput between nodes in netns regulator: da9211: Use irq handler when ready EDAC/device: Fix period calculation in edac_device_reset_delay_period() x86/boot: Avoid using Intel mnemonics in AT&T syntax asm powerpc/imc-pmu: Fix use of mutex in IRQs disabled section netfilter: ipset: Fix overflow before widen in the bitmap_ip_create() function. ext4: fix uninititialized value in 'ext4_evict_inode' ext4: fix use-after-free in ext4_orphan_cleanup ext4: lost matching-pair of trace in ext4_truncate ext4: fix bug_on in __es_tree_search caused by bad quota inode quota: Factor out setup of quota inode jbd2: use the correct print format usb: ulpi: defer ulpi_register on ulpi_read_id timeout wifi: wilc1000: sdio: fix module autoloading ipv6: raw: Deduct extension header length in rawv6_push_pending_frames ixgbe: fix pci device refcount leak platform/x86: sony-laptop: Don't turn off 0x153 keyboard backlight during probe drm/msm/adreno: Make adreno quirks not overwrite each other cifs: Fix uninitialized memory read for smb311 posix symlink create ALSA: hda/hdmi: Add a HP device 0x8715 to force connect list ALSA: pcm: Move rwsem lock inside snd_ctl_elem_read to prevent UAF net/ulp: prevent ULP without clone op from entering the LISTEN status s390/percpu: add READ_ONCE() to arch_this_cpu_to_op_simple() s390/kexec: fix ipl report address for kdump perf auxtrace: Fix address filter duplicate symbol selection docs: Fix the docs build with Sphinx 6.0 efi: tpm: Avoid READ_ONCE() for accessing the event log KVM: arm64: Fix S1PTW handling on RO memslots net: sched: disallow noqueue for qdisc classes driver core: Fix bus_type.match() error handling in __driver_attach() selftests: set the BUILD variable to absolute path selftests: Fix kselftest O=objdir build from cluttering top level objdir parisc: Align parisc MADV_XXX constants with all other architectures mbcache: Avoid nesting of cache->c_list_lock under bit locks hfs/hfsplus: avoid WARN_ON() for sanity check, use proper error handling hfs/hfsplus: use WARN_ON for sanity check ext4: don't allow journal inode to have encrypt flag riscv: uaccess: fix type of 0 variable on error in get_user() nfsd: fix handling of readdir in v4root vs. mount upcall timeout x86/bugs: Flush IBP in ib_prctl_set() ASoC: Intel: bytcr_rt5640: Add quirk for the Advantech MICA-071 tablet udf: Fix extension of the last extent in the file caif: fix memory leak in cfctrl_linkup_request() drm/i915: unpin on error in intel_vgpu_shadow_mm_pin() usb: rndis_host: Secure rndis_query check against int overflow drivers/net/bonding/bond_3ad: return when there's no aggregator perf tools: Fix resources leak in perf_data__open_dir() net: sched: cbq: dont intepret cls results when asked to drop net: sched: atm: dont intepret cls results when asked to drop RDMA/mlx5: Fix validation of max_rd_atomic caps for DC RDMA/uverbs: Silence shiftTooManyBitsSigned warning net: phy: xgmiitorgmii: Fix refcount leak in xgmiitorgmii_probe net: amd-xgbe: add missed tasklet_kill vhost: fix range used in translate_desc() nfc: Fix potential resource leaks qlcnic: prevent ->dcb use-after-free on qlcnic_dcb_enable() failure net: sched: fix memory leak in tcindex_set_parms net: hns3: add interrupts re-initialization while doing VF FLR nfsd: shut down the NFSv4 state objects before the filecache bpf: pull before calling skb_postpull_rcsum() SUNRPC: ensure the matching upcall is in-flight upon downcall ext4: fix deadlock due to mbcache entry corruption mbcache: automatically delete entries from cache on freeing ext4: fix race when reusing xattr blocks ext4: unindent codeblock in ext4_xattr_block_set() ext4: remove EA inode entry from mbcache on inode eviction mbcache: add functions to delete entry if unused mbcache: don't reclaim used entries ext4: use kmemdup() to replace kmalloc + memcpy fs: ext4: initialize fsdata in pagecache_write() ext4: use memcpy_to_page() in pagecache_write() mm/highmem: Lift memcpy_[to|from]_page to core ext4: correct inconsistent error msg in nojournal mode ext4: goto right label 'failed_mount3a' ravb: Fix "failed to switch device to config mode" message during unbind KVM: nVMX: Properly expose ENABLE_USR_WAIT_PAUSE control to L1 KVM: VMX: Fix the spelling of CPU_BASED_USE_TSC_OFFSETTING KVM: VMX: Rename NMI_PENDING to NMI_WINDOW KVM: VMX: Rename INTERRUPT_PENDING to INTERRUPT_WINDOW KVM: retpolines: x86: eliminate retpoline from vmx.c exit handlers KVM: x86: optimize more exit handlers in vmx.c perf probe: Fix to get the DW_AT_decl_file and DW_AT_call_file as unsinged data perf probe: Use dwarf_attr_integrate as generic DWARF attr accessor dm thin: resume even if in FAIL mode media: s5p-mfc: Fix in register read and write for H264 media: s5p-mfc: Clear workbit to handle error condition media: s5p-mfc: Fix to handle reference queue during finishing PM/devfreq: governor: Add a private governor_data for governor btrfs: replace strncpy() with strscpy() ext4: allocate extended attribute value in vmalloc area ext4: avoid unaccounted block allocation when expanding inode ext4: initialize quota before expanding inode in setproject ioctl ext4: fix inode leak in ext4_xattr_inode_create() on an error path ext4: avoid BUG_ON when creating xattrs ext4: fix error code return to user-space in ext4_get_branch() ext4: fix corruption when online resizing a 1K bigalloc fs ext4: fix delayed allocation bug in ext4_clu_mapped for bigalloc + inline ext4: init quota for 'old.inode' in 'ext4_rename' ext4: fix bug_on in __es_tree_search caused by bad boot loader inode ext4: fix reserved cluster accounting in __es_remove_extent() ext4: add helper to check quota inums ext4: add EXT4_IGET_BAD flag to prevent unexpected bad inode ext4: fix undefined behavior in bit shift for ext4_check_flag_values ext4: add inode table check in __ext4_get_inode_loc to aovid possible infinite loop drm/vmwgfx: Validate the box size for the snooped cursor drm/connector: send hotplug uevent on connector cleanup device_cgroup: Roll back to original exceptions after copy failure parisc: led: Fix potential null-ptr-deref in start_task() iommu/amd: Fix ivrs_acpihid cmdline parsing code crypto: n2 - add missing hash statesize PCI/sysfs: Fix double free in error path PCI: Fix pci_device_is_present() for VFs by checking PF ipmi: fix use after free in _ipmi_destroy_user() ima: Fix a potential NULL pointer access in ima_restore_measurement_list mtd: spi-nor: Check for zero erase size in spi_nor_find_best_erase_type() ipmi: fix long wait in unload when IPMI disconnect efi: Add iMac Pro 2017 to uefi skip cert quirk md/bitmap: Fix bitmap chunk size overflow issues cifs: fix missing display of three mount options cifs: fix confusing debug message media: dvb-core: Fix UAF due to refcount races at releasing media: dvb-core: Fix double free in dvb_register_device() ARM: 9256/1: NWFPE: avoid compiler-generated __aeabi_uldivmod tracing: Fix infinite loop in tracing_read_pipe on overflowed print_trace_line tracing/hist: Fix wrong return value in parse_action_params() x86/microcode/intel: Do not retry microcode reloading on the APs tracing/hist: Fix out-of-bound write on 'action_data.var_ref_idx' dm cache: set needs_check flag after aborting metadata dm cache: Fix UAF in destroy() dm clone: Fix UAF in clone_dtr() dm integrity: Fix UAF in dm_integrity_dtr() dm thin: Fix UAF in run_timer_softirq() dm thin: Use last transaction's pmd->root when commit failed dm thin: Fix ABBA deadlock between shrink_slab and dm_pool_abort_metadata dm cache: Fix ABBA deadlock between shrink_slab and dm_cache_metadata_abort binfmt: Fix error return code in load_elf_fdpic_binary() binfmt: Move install_exec_creds after setup_new_exec to match binfmt_elf cpufreq: Init completion before kobject_init_and_add() selftests: Use optional USERCFLAGS and USERLDFLAGS arm64: dts: qcom: sdm850-lenovo-yoga-c630: correct I2C12 pins drive strength ARM: ux500: do not directly dereference __iomem btrfs: fix resolving backrefs for inline extent followed by prealloc mmc: sdhci-sprd: Disable CLK_AUTO when the clock is less than 400K ktest.pl minconfig: Unset configs instead of just removing them kest.pl: Fix grub2 menu handling for rebooting soc: qcom: Select REMAP_MMIO for LLCC driver media: stv0288: use explicitly signed char net/af_packet: make sure to pull mac header net/af_packet: add VLAN support for AF_PACKET SOCK_RAW GSO SUNRPC: Don't leak netobj memory when gss_read_proxy_verf() fails tpm: tpm_tis: Add the missed acpi_put_table() to fix memory leak tpm: tpm_crb: Add the missed acpi_put_table() to fix memory leak mmc: vub300: fix warning - do not call blocking ops when !TASK_RUNNING f2fs: should put a page when checking the summary info mm, compaction: fix fast_isolate_around() to stay within boundaries md: fix a crash in mempool_free pnode: terminate at peers of source ALSA: line6: fix stack overflow in line6_midi_transmit ALSA: line6: correct midi status byte when receiving data from podxt ovl: Use ovl mounter's fsuid and fsgid in ovl_link() hfsplus: fix bug causing custom uid and gid being unable to be assigned with mount HID: plantronics: Additional PIDs for double volume key presses quirk HID: multitouch: fix Asus ExpertBook P2 P2451FA trackpoint powerpc/rtas: avoid scheduling in rtas_os_term() powerpc/rtas: avoid device tree lookups in rtas_os_term() objtool: Fix SEGFAULT nvme: fix the NVME_CMD_EFFECTS_CSE_MASK definition nvme: resync include/linux/nvme.h with nvmecli ata: ahci: Fix PCS quirk application for suspend nvme-pci: fix doorbell buffer value endianness cifs: fix oops during encryption media: dvbdev: fix refcnt bug media: dvbdev: fix build warning due to comments gcov: add support for checksum field regulator: core: fix deadlock on regulator enable iio: adc128s052: add proper .data members in adc128_of_match table iio: adc: ad_sigma_delta: do not use internal iio_dev lock reiserfs: Add missing calls to reiserfs_security_free() HID: wacom: Ensure bootloader PID is usable in hidraw mode usb: dwc3: core: defer probe on ulpi_read_id timeout ALSA: hda/hdmi: Add HP Device 0x8711 to force connect list ALSA: hda/realtek: Add quirk for Lenovo TianYi510Pro-14IOB pstore: Make sure CONFIG_PSTORE_PMSG selects CONFIG_RT_MUTEXES pstore: Switch pmsg_lock to an rt_mutex to avoid priority inversion ASoC: rt5670: Remove unbalanced pm_runtime_put() ASoC: rockchip: spdif: Add missing clk_disable_unprepare() in rk_spdif_runtime_resume() ASoC: wm8994: Fix potential deadlock ASoC: rockchip: pdm: Add missing clk_disable_unprepare() in rockchip_pdm_runtime_resume() ASoC: audio-graph-card: fix refcount leak of cpu_ep in __graph_for_each_link() ASoC: mediatek: mt8173-rt5650-rt5514: fix refcount leak in mt8173_rt5650_rt5514_dev_probe() ASoC: Intel: Skylake: Fix driver hang during shutdown ALSA: hda: add snd_hdac_stop_streams() helper ALSA/ASoC: hda: move/rename snd_hdac_ext_stop_streams to hdac_stream.c orangefs: Fix kmemleak in orangefs_{kernel,client}_debug_init() orangefs: Fix kmemleak in orangefs_prepare_debugfs_help_string() drm/sti: Fix return type of sti_{dvo,hda,hdmi}_connector_mode_valid() drm/fsl-dcu: Fix return type of fsl_dcu_drm_connector_mode_valid() hugetlbfs: fix null-ptr-deref in hugetlbfs_parse_param() clk: st: Fix memory leak in st_of_quadfs_setup() media: si470x: Fix use-after-free in si470x_int_in_callback() mmc: f-sdh30: Add quirks for broken timeout clock capability regulator: core: fix use_count leakage when handling boot-on blk-mq: fix possible memleak when register 'hctx' failed media: dvb-usb: fix memory leak in dvb_usb_adapter_init() media: dvbdev: adopts refcnt to avoid UAF media: dvb-frontends: fix leak of memory fw bpf: Prevent decl_tag from being referenced in func_proto arg ppp: associate skb with a device at tx mrp: introduce active flags to prevent UAF when applicant uninit net: add atomic_long_t to net_device_stats fields md/raid1: stop mdx_raid1 thread when raid1 array run failed drivers/md/md-bitmap: check the return value of md_bitmap_get_counter() drm/sti: Use drm_mode_copy() drm/rockchip: Use drm_mode_copy() s390/lcs: Fix return type of lcs_start_xmit() s390/netiucv: Fix return type of netiucv_tx() s390/ctcm: Fix return type of ctc{mp,}m_tx() igb: Do not free q_vector unless new one was allocated wifi: brcmfmac: Fix potential shift-out-of-bounds in brcmf_fw_alloc_request() hamradio: baycom_epp: Fix return type of baycom_send_packet() net: ethernet: ti: Fix return type of netcp_ndo_start_xmit() bpf: make sure skb->len != 0 when redirecting to a tunneling device ipmi: fix memleak when unload ipmi driver ASoC: codecs: rt298: Add quirk for KBL-R RVP platform wifi: ar5523: Fix use-after-free on ar5523_cmd() timed out wifi: ath9k: verify the expected usb_endpoints are present brcmfmac: return error when getting invalid max_flowrings from dongle drm/etnaviv: add missing quirks for GC300 hfs: fix OOB Read in __hfs_brec_find acct: fix potential integer overflow in encode_comp_t() nilfs2: fix shift-out-of-bounds/overflow in nilfs_sb2_bad_offset() ACPICA: Fix error code path in acpi_ds_call_control_method() fs: jfs: fix shift-out-of-bounds in dbDiscardAG udf: Avoid double brelse() in udf_rename() fs: jfs: fix shift-out-of-bounds in dbAllocAG binfmt_misc: fix shift-out-of-bounds in check_special_flags rcu: Fix __this_cpu_read() lockdep warning in rcu_force_quiescent_state() net: stream: purge sk_error_queue in sk_stream_kill_queues() myri10ge: Fix an error handling path in myri10ge_probe() rxrpc: Fix missing unlock in rxrpc_do_sendmsg() net_sched: reject TCF_EM_SIMPLE case for complex ematch module mailbox: zynq-ipi: fix error handling while device_register() fails skbuff: Account for tail adjustment during pull operations openvswitch: Fix flow lookup to use unmasked key rtc: mxc_v2: Add missing clk_disable_unprepare() r6040: Fix kmemleak in probe and remove nfc: pn533: Clear nfc_target before being used mISDN: hfcmulti: don't call dev_kfree_skb/kfree_skb() under spin_lock_irqsave() mISDN: hfcpci: don't call dev_kfree_skb/kfree_skb() under spin_lock_irqsave() mISDN: hfcsusb: don't call dev_kfree_skb/kfree_skb() under spin_lock_irqsave() nfsd: under NFSv4.1, fix double svc_xprt_put on rpc_create failure NFSD: Add tracepoints to NFSD's duplicate reply cache nfsd: Define the file access mode enum for tracing rtc: pic32: Move devm_rtc_allocate_device earlier in pic32_rtc_probe() rtc: st-lpc: Add missing clk_disable_unprepare in st_rtc_probe() remoteproc: qcom_q6v5_pas: Fix missing of_node_put() in adsp_alloc_memory_region() remoteproc: sysmon: fix memory leak in qcom_add_sysmon_subdev() pwm: sifive: Call pwm_sifive_update_clock() while mutex is held selftests/powerpc: Fix resource leaks powerpc/hv-gpci: Fix hv_gpci event list powerpc/83xx/mpc832x_rdb: call platform_device_put() in error case in of_fsl_spi_probe() powerpc/perf: callchain validate kernel stack pointer bounds powerpc/xive: add missing iounmap() in error path in xive_spapr_populate_irq_data() cxl: Fix refcount leak in cxl_calc_capp_routing powerpc/52xx: Fix a resource leak in an error handling path macintosh/macio-adb: check the return value of ioremap() macintosh: fix possible memory leak in macio_add_one_device() iommu/fsl_pamu: Fix resource leak in fsl_pamu_probe() iommu/amd: Fix pci device refcount leak in ppr_notifier() rtc: pcf85063: Fix reading alarm rtc: snvs: Allow a time difference on clock register read include/uapi/linux/swab: Fix potentially missing __always_inline RDMA/siw: Fix pointer cast warning power: supply: fix null pointer dereferencing in power_supply_get_battery_info HSI: omap_ssi_core: Fix error handling in ssi_init() perf symbol: correction while adjusting symbol perf trace: Handle failure when trace point folder is missed perf trace: Use macro RAW_SYSCALL_ARGS_NUM to replace number perf trace: Add a strtoul() method to 'struct syscall_arg_fmt' perf trace: Allow associating scnprintf routines with well known arg names perf trace: Add the syscall_arg_fmt pointer to syscall_arg perf trace: Factor out the initialization of syscal_arg_fmt->scnprintf perf trace: Separate 'struct syscall_fmt' definition from syscall_fmts variable perf trace: Return error if a system call doesn't exist power: supply: fix residue sysfs file in error handle route of __power_supply_register() HSI: omap_ssi_core: fix possible memory leak in ssi_probe() HSI: omap_ssi_core: fix unbalanced pm_runtime_disable() fbdev: uvesafb: Fixes an error handling path in uvesafb_probe() fbdev: vermilion: decrease reference count in error path fbdev: via: Fix error in via_core_init() fbdev: pm2fb: fix missing pci_disable_device() fbdev: ssd1307fb: Drop optional dependency samples: vfio-mdev: Fix missing pci_disable_device() in mdpy_fb_probe() tracing/hist: Fix issue of losting command info in error_log usb: storage: Add check for kcalloc i2c: ismt: Fix an out-of-bounds bug in ismt_access() vme: Fix error not catched in fake_init() staging: rtl8192e: Fix potential use-after-free in rtllib_rx_Monitor() staging: rtl8192u: Fix use after free in ieee80211_rx() i2c: pxa-pci: fix missing pci_disable_device() on error in ce4100_i2c_probe chardev: fix error handling in cdev_device_add() mcb: mcb-parse: fix error handing in chameleon_parse_gdd() drivers: mcb: fix resource leak in mcb_probe() usb: gadget: f_hid: fix refcount leak on error path usb: gadget: f_hid: fix f_hidg lifetime vs cdev usb: gadget: f_hid: optional SETUP/SET_REPORT mode usb: roles: fix of node refcount leak in usb_role_switch_is_parent() counter: stm32-lptimer-cnt: fix the check on arr and cmp registers update cxl: fix possible null-ptr-deref in cxl_pci_init_afu|adapter() cxl: fix possible null-ptr-deref in cxl_guest_init_afu|adapter() misc: sgi-gru: fix use-after-free error in gru_set_context_option, gru_fault and gru_handle_user_call_os misc: tifm: fix possible memory leak in tifm_7xx1_switch_media() misc: ocxl: fix possible name leak in ocxl_file_register_afu() test_firmware: fix memory leak in test_firmware_init() serial: sunsab: Fix error handling in sunsab_init() serial: altera_uart: fix locking in polling mode tty: serial: altera_uart_{r,t}x_chars() need only uart_port tty: serial: clean up stop-tx part in altera_uart_tx_chars() serial: pch: Fix PCI device refcount leak in pch_request_dma() serial: pl011: Do not clear RX FIFO & RX interrupt in unthrottle. serial: amba-pl011: avoid SBSA UART accessing DMACR register usb: typec: tcpci: fix of node refcount leak in tcpci_register_port() usb: typec: Check for ops->exit instead of ops->enter in altmode_exit staging: vme_user: Fix possible UAF in tsi148_dma_list_add usb: fotg210-udc: Fix ages old endianness issues uio: uio_dmem_genirq: Fix deadlock between irq config and handling uio: uio_dmem_genirq: Fix missing unlock in irq configuration vfio: platform: Do not pass return buffer to ACPI _RST method class: fix possible memory leak in __class_register() serial: tegra: Read DMA status before terminating tty: serial: tegra: Activate RX DMA transfer by request drivers: dio: fix possible memory leak in dio_init() IB/IPoIB: Fix queue count inconsistency for PKEY child interfaces hwrng: geode - Fix PCI device refcount leak hwrng: amd - Fix PCI device refcount leak crypto: img-hash - Fix variable dereferenced before check 'hdev->req' orangefs: Fix sysfs not cleanup when dev init failed RDMA/hfi1: Fix error return code in parse_platform_config() crypto: omap-sham - Use pm_runtime_resume_and_get() in omap_sham_probe() f2fs: avoid victim selection from previous victim section RDMA/nldev: Add checks for nla_nest_start() in fill_stat_counter_qps() scsi: snic: Fix possible UAF in snic_tgt_create() scsi: fcoe: Fix transport not deattached when fcoe_if_init() fails scsi: ipr: Fix WARNING in ipr_init() scsi: fcoe: Fix possible name leak when device_register() fails scsi: hpsa: Fix possible memory leak in hpsa_add_sas_device() scsi: hpsa: Fix error handling in hpsa_add_sas_host() scsi: mpt3sas: Fix possible resource leaks in mpt3sas_transport_port_add() crypto: tcrypt - Fix multibuffer skcipher speed test mem leak scsi: hpsa: Fix possible memory leak in hpsa_init_one() RDMA/rxe: Fix NULL-ptr-deref in rxe_qp_do_cleanup() when socket create failed crypto: ccree - Make cc_debugfs_global_fini() available for module init function RDMA/hfi: Decrease PCI device reference count in error path PCI: Check for alloc failure in pci_request_irq() crypto: ccree - Remove debugfs when platform_driver_register failed crypto: ccree - swap SHA384 and SHA512 larval hashes at build time scsi: scsi_debug: Fix a warning in resp_write_scat() RDMA/siw: Set defined status for work completion with undefined status RDMA/nldev: Return "-EAGAIN" if the cm_id isn't from expected port RDMA/siw: Fix immediate work request flush to completion queue f2fs: fix normal discard process RDMA/core: Fix order of nldev_exit call apparmor: Use pointer to struct aa_label for lbs_cred apparmor: Fix abi check to include v8 abi apparmor: fix lockdep warning when removing a namespace apparmor: fix a memleak in multi_transaction_new() stmmac: fix potential division by 0 Bluetooth: RFCOMM: don't call kfree_skb() under spin_lock_irqsave() Bluetooth: hci_core: don't call kfree_skb() under spin_lock_irqsave() Bluetooth: hci_bcsp: don't call kfree_skb() under spin_lock_irqsave() Bluetooth: hci_h5: don't call kfree_skb() under spin_lock_irqsave() Bluetooth: hci_ll: don't call kfree_skb() under spin_lock_irqsave() Bluetooth: hci_qca: don't call kfree_skb() under spin_lock_irqsave() Bluetooth: btusb: don't call kfree_skb() under spin_lock_irqsave() ntb_netdev: Use dev_kfree_skb_any() in interrupt context net: lan9303: Fix read error execution path can: tcan4x5x: Remove invalid write in clear_interrupts net: amd-xgbe: Check only the minimum speed for active/passive cables net: amd-xgbe: Fix logic around active and passive cables net: amd: lance: don't call dev_kfree_skb() under spin_lock_irqsave() hamradio: don't call dev_kfree_skb() under spin_lock_irqsave() net: ethernet: dnet: don't call dev_kfree_skb() under spin_lock_irqsave() net: emaclite: don't call dev_kfree_skb() under spin_lock_irqsave() net: apple: bmac: don't call dev_kfree_skb() under spin_lock_irqsave() net: apple: mace: don't call dev_kfree_skb() under spin_lock_irqsave() net/tunnel: wait until all sk_user_data reader finish before releasing the sock net: farsync: Fix kmemleak when rmmods farsync ethernet: s2io: don't call dev_kfree_skb() under spin_lock_irqsave() of: overlay: fix null pointer dereferencing in find_dup_cset_node_entry() and find_dup_cset_prop() drivers: net: qlcnic: Fix potential memory leak in qlcnic_sriov_init() net: stmmac: selftests: fix potential memleak in stmmac_test_arpoffload() net: defxx: Fix missing err handling in dfx_init() net: vmw_vsock: vmci: Check memcpy_from_msg() clk: socfpga: Fix memory leak in socfpga_gate_init() clk: socfpga: use clk_hw_register for a5/c5 clk: socfpga: clk-pll: Remove unused variable 'rc' blktrace: Fix output non-blktrace event when blk_classic option enabled wifi: brcmfmac: Fix error return code in brcmf_sdio_download_firmware() wifi: rtl8xxxu: Add __packed to struct rtl8723bu_c2h spi: spi-gpio: Don't set MOSI as an input if not 3WIRE mode clk: samsung: Fix memory leak in _samsung_clk_register_pll() media: coda: Add check for kmalloc media: coda: Add check for dcoda_iram_alloc media: c8sectpfe: Add of_node_put() when breaking out of loop mmc: mmci: fix return value check of mmc_add_host() mmc: wbsd: fix return value check of mmc_add_host() mmc: via-sdmmc: fix return value check of mmc_add_host() mmc: meson-gx: fix return value check of mmc_add_host() mmc: omap_hsmmc: fix return value check of mmc_add_host() mmc: atmel-mci: fix return value check of mmc_add_host() mmc: wmt-sdmmc: fix return value check of mmc_add_host() mmc: vub300: fix return value check of mmc_add_host() mmc: toshsd: fix return value check of mmc_add_host() mmc: rtsx_usb_sdmmc: fix return value check of mmc_add_host() mmc: pxamci: fix return value check of mmc_add_host() mmc: mxcmmc: fix return value check of mmc_add_host() mmc: moxart: fix return value check of mmc_add_host() mmc: alcor: fix return value check of mmc_add_host() NFSv4.x: Fail client initialisation if state manager thread can't run SUNRPC: Fix missing release socket in rpc_sockname() xprtrdma: Fix regbuf data not freed in rpcrdma_req_create() ALSA: mts64: fix possible null-ptr-defer in snd_mts64_interrupt media: saa7164: fix missing pci_disable_device() bpf, sockmap: fix race in sock_map_free() regulator: core: fix resource leak in regulator_register() configfs: fix possible memory leak in configfs_create_dir() hsr: Avoid double remove of a node. clk: qcom: clk-krait: fix wrong div2 functions regulator: core: fix module refcount leak in set_supply() wifi: cfg80211: Fix not unregister reg_pdev when load_builtin_regdb_keys() fails spi: spidev: mask SPI_CS_HIGH in SPI_IOC_RD_MODE bonding: uninitialized variable in bond_miimon_inspect() bpf, sockmap: Fix data loss caused by using apply_bytes on ingress redirect bpf, sockmap: Fix repeated calls to sock_put() when msg has more_data netfilter: conntrack: set icmpv6 redirects as RELATED ASoC: pcm512x: Fix PM disable depth imbalance in pcm512x_probe drm/amdgpu: Fix PCI device refcount leak in amdgpu_atrm_get_bios() drm/radeon: Fix PCI device refcount leak in radeon_atrm_get_bios() ASoC: mediatek: mt8173: Enable IRQ when pdata is ready wifi: iwlwifi: mvm: fix double free on tx path. ALSA: asihpi: fix missing pci_disable_device() NFSv4: Fix a deadlock between nfs4_open_recover_helper() and delegreturn NFSv4.2: Fix initialisation of struct nfs4_label NFSv4.2: Fix a memory stomp in decode_attr_security_label NFSv4.2: Clear FATTR4_WORD2_SECURITY_LABEL when done decoding ASoC: mediatek: mtk-btcvsd: Add checks for write and read of mtk_btcvsd_snd ASoC: dt-bindings: wcd9335: fix reset line polarity in example drm/tegra: Add missing clk_disable_unprepare() in tegra_dc_probe() media: s5p-mfc: Add variant data for MFC v7 hardware for Exynos 3250 SoC media: dvb-usb: az6027: fix null-ptr-deref in az6027_i2c_xfer() media: dvb-core: Fix ignored return value in dvb_register_frontend() pinctrl: pinconf-generic: add missing of_node_put() clk: imx: replace osc_hdmi with dummy clk: imx8mn: correct the usb1_ctrl parent to be usb_bus media: imon: fix a race condition in send_packet() mtd: maps: pxa2xx-flash: fix memory leak in probe bonding: fix link recovery in mode 2 when updelay is nonzero bonding: Rename slave_arr to usable_slaves bonding: Export skip slave logic to function clk: rockchip: Fix memory leak in rockchip_clk_register_pll() regulator: core: use kfree_const() to free space conditionally ALSA: seq: fix undefined behavior in bit shift for SNDRV_SEQ_FILTER_USE_EVENT ALSA: pcm: fix undefined behavior in bit shift for SNDRV_PCM_RATE_KNOT HID: hid-sensor-custom: set fixed size for custom attributes bpf: Move skb->len == 0 checks into __bpf_redirect media: videobuf-dma-contig: use dma_mmap_coherent media: platform: exynos4-is: Fix error handling in fimc_md_init() media: solo6x10: fix possible memory leak in solo_sysfs_init() Input: elants_i2c - properly handle the reset GPIO when power is off mtd: lpddr2_nvm: Fix possible null-ptr-deref wifi: ath10k: Fix return value in ath10k_pci_init() ima: Fix misuse of dereference of pointer in template_desc_init_fields() integrity: Fix memory leakage in keyring allocation error path amdgpu/pm: prevent array underflow in vega20_odn_edit_dpm_table() regulator: core: fix unbalanced of node refcount in regulator_dev_lookup() ASoC: pxa: fix null-pointer dereference in filter() drm/mediatek: Modify dpi power on/off sequence. drm/radeon: Add the missed acpi_put_table() to fix memory leak rxrpc: Fix ack.bufferSize to be 0 when generating an ack net, proc: Provide PROC_FS=n fallback for proc_create_net_single_write() media: camss: Clean up received buffers on failed start of streaming wifi: rsi: Fix handling of 802.3 EAPOL frames sent via control port mtd: Fix device name leak when register device failed in add_mtd_device() bpf: propagate precision in ALU/ALU64 operations media: vivid: fix compose size exceed boundary ima: Handle -ESTALE returned by ima_filter_rule_match() ima: Fix fall-through warnings for Clang ima: Rename internal filter rule functions drm/panel/panel-sitronix-st7701: Remove panel on DSI attach failure spi: Update reference to struct spi_controller clk: renesas: r9a06g032: Repair grave increment error can: kvaser_usb: Compare requested bittiming parameters with actual parameters in do_set_{,data}_bittiming can: kvaser_usb: Add struct kvaser_usb_busparams can: kvaser_usb_leaf: Fix bogus restart events can: kvaser_usb_leaf: Fix wrong CAN state after stopping can: kvaser_usb_leaf: Fix improved state not being reported can: kvaser_usb_leaf: Set Warning state even without bus errors can: kvaser_usb: kvaser_usb_leaf: Handle CMD_ERROR_EVENT can: kvaser_usb: kvaser_usb_leaf: Rename {leaf,usbcan}_cmd_error_event to {leaf,usbcan}_cmd_can_error_event can: kvaser_usb: kvaser_usb_leaf: Get capabilities from device can: kvaser_usb: do not increase tx statistics when sending error message frames media: i2c: ad5820: Fix error path pata_ipx4xx_cf: Fix unsigned comparison with less than zero wifi: rtl8xxxu: Fix reading the vendor of combo chips wifi: ath9k: hif_usb: Fix use-after-free in ath9k_hif_usb_reg_in_cb() wifi: ath9k: hif_usb: fix memory leak of urbs in ath9k_hif_usb_dealloc_tx_urbs() rapidio: devices: fix missing put_device in mport_cdev_open hfs: Fix OOB Write in hfs_asc2mac relay: fix type mismatch when allocating memory in relay_create_buf() eventfd: change int to __u64 in eventfd_signal() ifndef CONFIG_EVENTFD rapidio: fix possible UAF when kfifo_alloc() fails fs: sysv: Fix sysv_nblocks() returns wrong value MIPS: OCTEON: warn only once if deprecated link status is being used MIPS: BCM63xx: Add check for NULL for clk in clk_enable platform/x86: mxm-wmi: fix memleak in mxm_wmi_call_mx[ds|mx]() PM: runtime: Do not call __rpm_callback() from rpm_idle() PM: runtime: Improve path in rpm_idle() when no callback xen/privcmd: Fix a possible warning in privcmd_ioctl_mmap_resource() x86/xen: Fix memory leak in xen_init_lock_cpu() x86/xen: Fix memory leak in xen_smp_intr_init{_pv}() xen/events: only register debug interrupt for 2-level events uprobes/x86: Allow to probe a NOP instruction with 0x66 prefix ACPICA: Fix use-after-free in acpi_ut_copy_ipackage_to_ipackage() clocksource/drivers/sh_cmt: Make sure channel clock supply is enabled rapidio: rio: fix possible name leak in rio_register_mport() rapidio: fix possible name leaks when rio_add_device() fails ocfs2: fix memory leak in ocfs2_mount_volume() ocfs2: rewrite error handling of ocfs2_fill_super ocfs2: ocfs2_mount_volume does cleanup job before return error debugfs: fix error when writing negative value to atomic_t debugfs file docs: fault-injection: fix non-working usage of negative values lib/notifier-error-inject: fix error when writing -errno to debugfs file libfs: add DEFINE_SIMPLE_ATTRIBUTE_SIGNED for signed value cpufreq: amd_freq_sensitivity: Add missing pci_dev_put() genirq/irqdesc: Don't try to remove non-existing sysfs files nfsd: don't call nfsd_file_put from client states seqfile display EDAC/i10nm: fix refcount leak in pci_get_dev_wrapper() irqchip: gic-pm: Use pm_runtime_resume_and_get() in gic_probe() perf/x86/intel/uncore: Fix reference count leak in hswep_has_limit_sbox() PNP: fix name memory leak in pnp_alloc_dev() selftests/efivarfs: Add checking of the test return value MIPS: vpe-cmp: fix possible memory leak while module exiting MIPS: vpe-mt: fix possible memory leak while module exiting ocfs2: fix memory leak in ocfs2_stack_glue_init() lib/fonts: fix undefined behavior in bit shift for get_default_font proc: fixup uptime selftest timerqueue: Use rb_entry_safe() in timerqueue_getnext() perf: Fix possible memleak in pmu_dev_alloc() selftests/ftrace: event_triggers: wait longer for test_event_enable fs: don't audit the capability check in simple_xattr_list() PM: hibernate: Fix mistake in kerneldoc comment alpha: fix syscall entry in !AUDUT_SYSCALL case cpuidle: dt: Return the correct numbers of parsed idle states tpm/tpm_crb: Fix error message in __crb_relinquish_locality() pstore: Avoid kcore oops by vmap()ing with VM_IOREMAP ARM: mmp: fix timer_read delay pstore/ram: Fix error return code in ramoops_probe() arm64: dts: armada-3720-turris-mox: Add missing interrupt for RTC ARM: dts: turris-omnia: Add switch port 6 node ARM: dts: turris-omnia: Add ethernet aliases ARM: dts: armada-39x: Fix assigned-addresses for every PCIe Root Port ARM: dts: armada-38x: Fix assigned-addresses for every PCIe Root Port ARM: dts: armada-375: Fix assigned-addresses for every PCIe Root Port ARM: dts: armada-xp: Fix assigned-addresses for every PCIe Root Port ARM: dts: armada-370: Fix assigned-addresses for every PCIe Root Port ARM: dts: dove: Fix assigned-addresses for every PCIe Root Port arm64: dts: mediatek: mt6797: Fix 26M oscillator unit name arm64: dts: mt2712-evb: Fix usb vbus regulators unit names arm64: dts: mt2712-evb: Fix vproc fixed regulators unit names arm64: dts: mt2712e: Fix unit address for pinctrl node arm64: dts: mt2712e: Fix unit_address_vs_reg warning for oscillators perf/smmuv3: Fix hotplug callback leak in arm_smmu_pmu_init() perf: arm_dsu: Fix hotplug callback leak in dsu_pmu_init() soc: ti: smartreflex: Fix PM disable depth imbalance in omap_sr_probe soc: ti: knav_qmss_queue: Fix PM disable depth imbalance in knav_queue_probe soc: ti: knav_qmss_queue: Use pm_runtime_resume_and_get instead of pm_runtime_get_sync arm: dts: spear600: Fix clcd interrupt drivers: soc: ti: knav_qmss_queue: Mark knav_acc_firmwares as static arm64: dts: qcom: sdm845-cheza: fix AP suspend pin bias ARM: dts: qcom: apq8064: fix coresight compatible usb: musb: remove extra check in musb_gadget_vbus_draw net: loopback: use NET_NAME_PREDICTABLE for name_assign_type Bluetooth: L2CAP: Fix u8 overflow HID: uclogic: Add HID_QUIRK_HIDINPUT_FORCE quirk HID: ite: Enable QUIRK_TOUCHPAD_ON_OFF_REPORT on Acer Aspire Switch V 10 HID: ite: Enable QUIRK_TOUCHPAD_ON_OFF_REPORT on Acer Aspire Switch 10E HID: ite: Add support for Acer S1002 keyboard-dock xen-netback: move removal of "hotplug-status" to the right place igb: Initialize mailbox message for VF reset USB: serial: f81534: fix division by zero on line-speed change USB: serial: f81232: fix division by zero on line-speed change USB: serial: cp210x: add Kamstrup RF sniffer PIDs USB: serial: option: add Quectel EM05-G modem usb: gadget: uvc: Prevent buffer overflow in setup handler udf: Fix extending file within last block udf: Do not bother looking for prealloc extents if i_lenExtents matches i_size udf: Fix preallocation discarding at indirect extent boundary udf: Discard preallocation before extending file with a hole tracing/ring-buffer: Only do full wait when cpu != RING_BUFFER_ALL_CPUS ANDROID: Add more hvc devices for virtio-console. Revert "can: af_can: fix NULL pointer dereference in can_rcv_filter" ANDROID: Revert "tracing/ring-buffer: Have polling block on watermark" Linux 5.4.228 ASoC: ops: Correct bounds check for second channel on SX controls can: mcba_usb: Fix termination command argument can: sja1000: fix size of OCR_MODE_MASK define pinctrl: meditatek: Startup with the IRQs disabled ASoC: ops: Check bounds for second channel in snd_soc_put_volsw_sx() nfp: fix use-after-free in area_cache_get() block: unhash blkdev part inode when the part is deleted mm/hugetlb: fix races when looking up a CONT-PTE/PMD size hugetlb page x86/smpboot: Move rcu_cpu_starting() earlier net: bpf: Allow TC programs to call BPF_FUNC_skb_change_head Linux 5.4.227 can: esd_usb: Allow REC and TEC to return to zero net: mvneta: Fix an out of bounds check ipv6: avoid use-after-free in ip6_fragment() net: plip: don't call kfree_skb/dev_kfree_skb() under spin_lock_irq() xen/netback: fix build warning ethernet: aeroflex: fix potential skb leak in greth_init_rings() ipv4: Fix incorrect route flushing when table ID 0 is used ipv4: Fix incorrect route flushing when source address is deleted tipc: Fix potential OOB in tipc_link_proto_rcv() net: hisilicon: Fix potential use-after-free in hix5hd2_rx() net: hisilicon: Fix potential use-after-free in hisi_femac_rx() net: thunderx: Fix missing destroy_workqueue of nicvf_rx_mode_wq net: stmmac: fix "snps,axi-config" node property parsing nvme initialize core quirks before calling nvme_init_subsystem NFC: nci: Bounds check struct nfc_target arrays i40e: Disallow ip4 and ip6 l4_4_bytes i40e: Fix for VF MAC address 0 i40e: Fix not setting default xps_cpus after reset net: mvneta: Prevent out of bounds read in mvneta_config_rss() xen-netfront: Fix NULL sring after live migration net: encx24j600: Fix invalid logic in reading of MISTAT register net: encx24j600: Add parentheses to fix precedence mac802154: fix missing INIT_LIST_HEAD in ieee802154_if_add() selftests: rtnetlink: correct xfrm policy rule in kci_test_ipsec_offload net: dsa: ksz: Check return value Bluetooth: Fix not cleanup led when bt_init fails Bluetooth: 6LoWPAN: add missing hci_dev_put() in get_l2cap_conn() af_unix: Get user_ns from in_skb in unix_diag_get_exact(). igb: Allocate MSI-X vector when testing e1000e: Fix TX dispatch condition gpio: amd8111: Fix PCI device reference count leak drm/bridge: ti-sn65dsi86: Fix output polarity setting bug ca8210: Fix crash by zero initializing data ieee802154: cc2520: Fix error return code in cc2520_hw_init() can: af_can: fix NULL pointer dereference in can_rcv_filter HID: core: fix shift-out-of-bounds in hid_report_raw_event HID: hid-lg4ff: Add check for empty lbuf HID: usbhid: Add ALWAYS_POLL quirk for some mice drm/shmem-helper: Remove errant put in error path KVM: s390: vsie: Fix the initialization of the epoch extension (epdx) field mm/gup: fix gup_pud_range() for dax memcg: fix possible use-after-free in memcg_write_event_control() media: v4l2-dv-timings.c: fix too strict blanking sanity checks Revert "net: dsa: b53: Fix valid setting for MDB entries" xen/netback: don't call kfree_skb() with interrupts disabled xen/netback: do some code cleanup xen/netback: Ensure protocol headers don't fall in the non-linear area mm/khugepaged: invoke MMU notifiers in shmem/file collapse paths mm/khugepaged: fix GUP-fast interaction by sending IPI mm/khugepaged: take the right locks for page table retraction net: usb: qmi_wwan: add u-blox 0x1342 composition 9p/xen: check logical size for buffer size fbcon: Use kzalloc() in fbcon_prepare_logo() regulator: twl6030: fix get status of twl6032 regulators ASoC: soc-pcm: Add NULL check in BE reparenting btrfs: send: avoid unaligned encoded writes when attempting to clone range ALSA: seq: Fix function prototype mismatch in snd_seq_expand_var_event regulator: slg51000: Wait after asserting CS pin 9p/fd: Use P9_HDRSZ for header size ARM: dts: rockchip: disable arm_global_timer on rk3066 and rk3188 ARM: 9266/1: mm: fix no-MMU ZERO_PAGE() implementation ARM: 9251/1: perf: Fix stacktraces for tracepoint events in THUMB2 kernels ARM: dts: rockchip: rk3188: fix lcdc1-rgb24 node name ARM: dts: rockchip: fix ir-receiver node names arm: dts: rockchip: fix node name for hym8563 rtc arm64: dts: rockchip: keep I2S1 disabled for GPIO function on ROCK Pi 4 series Conflicts: Documentation/devicetree/bindings/phy/amlogic,meson-g12a-usb3-pcie-phy.yaml arch/arm64/boot/dts/vendor/bindings/phy/amlogic,g12a-usb3-pcie-phy.yaml arch/arm64/boot/dts/vendor/bindings/phy/amlogic,meson-g12a-usb3-pcie-phy.yaml arch/arm64/include/asm/atomic_ll_sc.h drivers/edac/qcom_edac.c drivers/net/ethernet/stmicro/stmmac/dwmac-qcom-ethqos.c drivers/net/ethernet/stmicro/stmmac/stmmac_hwtstamp.c drivers/net/ethernet/stmicro/stmmac/stmmac_main.c drivers/usb/gadget/function/f_fs.c drivers/usb/host/xhci-plat.c sound/soc/soc-pcm.c Change-Id: I4e8cffcac6c78ecf1a16d24ee01551747552fdf2
2040 lines
64 KiB
C
2040 lines
64 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
#ifndef _LINUX_KERNEL_TRACE_H
|
|
#define _LINUX_KERNEL_TRACE_H
|
|
|
|
#include <linux/fs.h>
|
|
#include <linux/atomic.h>
|
|
#include <linux/sched.h>
|
|
#include <linux/clocksource.h>
|
|
#include <linux/ring_buffer.h>
|
|
#include <linux/mmiotrace.h>
|
|
#include <linux/tracepoint.h>
|
|
#include <linux/ftrace.h>
|
|
#include <linux/hw_breakpoint.h>
|
|
#include <linux/trace_seq.h>
|
|
#include <linux/trace_events.h>
|
|
#include <linux/compiler.h>
|
|
#include <linux/glob.h>
|
|
|
|
#ifdef CONFIG_FTRACE_SYSCALLS
|
|
#include <asm/unistd.h> /* For NR_SYSCALLS */
|
|
#include <asm/syscall.h> /* some archs define it here */
|
|
#endif
|
|
|
|
enum trace_type {
|
|
__TRACE_FIRST_TYPE = 0,
|
|
|
|
TRACE_FN,
|
|
TRACE_CTX,
|
|
TRACE_WAKE,
|
|
TRACE_STACK,
|
|
TRACE_PRINT,
|
|
TRACE_BPRINT,
|
|
TRACE_MMIO_RW,
|
|
TRACE_MMIO_MAP,
|
|
TRACE_BRANCH,
|
|
TRACE_GRAPH_RET,
|
|
TRACE_GRAPH_ENT,
|
|
TRACE_USER_STACK,
|
|
TRACE_BLK,
|
|
TRACE_BPUTS,
|
|
TRACE_HWLAT,
|
|
TRACE_RAW_DATA,
|
|
|
|
__TRACE_LAST_TYPE,
|
|
};
|
|
|
|
|
|
#undef __field
|
|
#define __field(type, item) type item;
|
|
|
|
#undef __field_struct
|
|
#define __field_struct(type, item) __field(type, item)
|
|
|
|
#undef __field_desc
|
|
#define __field_desc(type, container, item)
|
|
|
|
#undef __array
|
|
#define __array(type, item, size) type item[size];
|
|
|
|
#undef __array_desc
|
|
#define __array_desc(type, container, item, size)
|
|
|
|
#undef __dynamic_array
|
|
#define __dynamic_array(type, item) type item[];
|
|
|
|
#undef F_STRUCT
|
|
#define F_STRUCT(args...) args
|
|
|
|
#undef FTRACE_ENTRY
|
|
#define FTRACE_ENTRY(name, struct_name, id, tstruct, print, filter) \
|
|
struct struct_name { \
|
|
struct trace_entry ent; \
|
|
tstruct \
|
|
}
|
|
|
|
#undef FTRACE_ENTRY_DUP
|
|
#define FTRACE_ENTRY_DUP(name, name_struct, id, tstruct, printk, filter)
|
|
|
|
#undef FTRACE_ENTRY_REG
|
|
#define FTRACE_ENTRY_REG(name, struct_name, id, tstruct, print, \
|
|
filter, regfn) \
|
|
FTRACE_ENTRY(name, struct_name, id, PARAMS(tstruct), PARAMS(print), \
|
|
filter)
|
|
|
|
#undef FTRACE_ENTRY_PACKED
|
|
#define FTRACE_ENTRY_PACKED(name, struct_name, id, tstruct, print, \
|
|
filter) \
|
|
FTRACE_ENTRY(name, struct_name, id, PARAMS(tstruct), PARAMS(print), \
|
|
filter) __packed
|
|
|
|
#include "trace_entries.h"
|
|
|
|
/*
|
|
* syscalls are special, and need special handling, this is why
|
|
* they are not included in trace_entries.h
|
|
*/
|
|
struct syscall_trace_enter {
|
|
struct trace_entry ent;
|
|
int nr;
|
|
unsigned long args[];
|
|
};
|
|
|
|
struct syscall_trace_exit {
|
|
struct trace_entry ent;
|
|
int nr;
|
|
long ret;
|
|
};
|
|
|
|
struct kprobe_trace_entry_head {
|
|
struct trace_entry ent;
|
|
unsigned long ip;
|
|
};
|
|
|
|
struct kretprobe_trace_entry_head {
|
|
struct trace_entry ent;
|
|
unsigned long func;
|
|
unsigned long ret_ip;
|
|
};
|
|
|
|
/*
|
|
* trace_flag_type is an enumeration that holds different
|
|
* states when a trace occurs. These are:
|
|
* IRQS_OFF - interrupts were disabled
|
|
* IRQS_NOSUPPORT - arch does not support irqs_disabled_flags
|
|
* NEED_RESCHED - reschedule is requested
|
|
* HARDIRQ - inside an interrupt handler
|
|
* SOFTIRQ - inside a softirq handler
|
|
*/
|
|
enum trace_flag_type {
|
|
TRACE_FLAG_IRQS_OFF = 0x01,
|
|
TRACE_FLAG_IRQS_NOSUPPORT = 0x02,
|
|
TRACE_FLAG_NEED_RESCHED = 0x04,
|
|
TRACE_FLAG_HARDIRQ = 0x08,
|
|
TRACE_FLAG_SOFTIRQ = 0x10,
|
|
TRACE_FLAG_PREEMPT_RESCHED = 0x20,
|
|
TRACE_FLAG_NMI = 0x40,
|
|
};
|
|
|
|
#define TRACE_BUF_SIZE 1024
|
|
|
|
struct trace_array;
|
|
|
|
/*
|
|
* The CPU trace array - it consists of thousands of trace entries
|
|
* plus some other descriptor data: (for example which task started
|
|
* the trace, etc.)
|
|
*/
|
|
struct trace_array_cpu {
|
|
atomic_t disabled;
|
|
void *buffer_page; /* ring buffer spare */
|
|
|
|
unsigned long entries;
|
|
unsigned long saved_latency;
|
|
unsigned long critical_start;
|
|
unsigned long critical_end;
|
|
unsigned long critical_sequence;
|
|
unsigned long nice;
|
|
unsigned long policy;
|
|
unsigned long rt_priority;
|
|
unsigned long skipped_entries;
|
|
u64 preempt_timestamp;
|
|
pid_t pid;
|
|
kuid_t uid;
|
|
char comm[TASK_COMM_LEN];
|
|
|
|
bool ignore_pid;
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
bool ftrace_ignore_pid;
|
|
#endif
|
|
};
|
|
|
|
struct tracer;
|
|
struct trace_option_dentry;
|
|
|
|
struct trace_buffer {
|
|
struct trace_array *tr;
|
|
struct ring_buffer *buffer;
|
|
struct trace_array_cpu __percpu *data;
|
|
u64 time_start;
|
|
int cpu;
|
|
};
|
|
|
|
#define TRACE_FLAGS_MAX_SIZE 32
|
|
|
|
struct trace_options {
|
|
struct tracer *tracer;
|
|
struct trace_option_dentry *topts;
|
|
};
|
|
|
|
struct trace_pid_list {
|
|
int pid_max;
|
|
unsigned long *pids;
|
|
};
|
|
|
|
typedef bool (*cond_update_fn_t)(struct trace_array *tr, void *cond_data);
|
|
|
|
/**
|
|
* struct cond_snapshot - conditional snapshot data and callback
|
|
*
|
|
* The cond_snapshot structure encapsulates a callback function and
|
|
* data associated with the snapshot for a given tracing instance.
|
|
*
|
|
* When a snapshot is taken conditionally, by invoking
|
|
* tracing_snapshot_cond(tr, cond_data), the cond_data passed in is
|
|
* passed in turn to the cond_snapshot.update() function. That data
|
|
* can be compared by the update() implementation with the cond_data
|
|
* contained wihin the struct cond_snapshot instance associated with
|
|
* the trace_array. Because the tr->max_lock is held throughout the
|
|
* update() call, the update() function can directly retrieve the
|
|
* cond_snapshot and cond_data associated with the per-instance
|
|
* snapshot associated with the trace_array.
|
|
*
|
|
* The cond_snapshot.update() implementation can save data to be
|
|
* associated with the snapshot if it decides to, and returns 'true'
|
|
* in that case, or it returns 'false' if the conditional snapshot
|
|
* shouldn't be taken.
|
|
*
|
|
* The cond_snapshot instance is created and associated with the
|
|
* user-defined cond_data by tracing_cond_snapshot_enable().
|
|
* Likewise, the cond_snapshot instance is destroyed and is no longer
|
|
* associated with the trace instance by
|
|
* tracing_cond_snapshot_disable().
|
|
*
|
|
* The method below is required.
|
|
*
|
|
* @update: When a conditional snapshot is invoked, the update()
|
|
* callback function is invoked with the tr->max_lock held. The
|
|
* update() implementation signals whether or not to actually
|
|
* take the snapshot, by returning 'true' if so, 'false' if no
|
|
* snapshot should be taken. Because the max_lock is held for
|
|
* the duration of update(), the implementation is safe to
|
|
* directly retrieven and save any implementation data it needs
|
|
* to in association with the snapshot.
|
|
*/
|
|
struct cond_snapshot {
|
|
void *cond_data;
|
|
cond_update_fn_t update;
|
|
};
|
|
|
|
/*
|
|
* The trace array - an array of per-CPU trace arrays. This is the
|
|
* highest level data structure that individual tracers deal with.
|
|
* They have on/off state as well:
|
|
*/
|
|
struct trace_array {
|
|
struct list_head list;
|
|
char *name;
|
|
struct trace_buffer trace_buffer;
|
|
#ifdef CONFIG_TRACER_MAX_TRACE
|
|
/*
|
|
* The max_buffer is used to snapshot the trace when a maximum
|
|
* latency is reached, or when the user initiates a snapshot.
|
|
* Some tracers will use this to store a maximum trace while
|
|
* it continues examining live traces.
|
|
*
|
|
* The buffers for the max_buffer are set up the same as the trace_buffer
|
|
* When a snapshot is taken, the buffer of the max_buffer is swapped
|
|
* with the buffer of the trace_buffer and the buffers are reset for
|
|
* the trace_buffer so the tracing can continue.
|
|
*/
|
|
struct trace_buffer max_buffer;
|
|
bool allocated_snapshot;
|
|
#endif
|
|
#if defined(CONFIG_TRACER_MAX_TRACE) || defined(CONFIG_HWLAT_TRACER)
|
|
unsigned long max_latency;
|
|
#endif
|
|
struct trace_pid_list __rcu *filtered_pids;
|
|
/*
|
|
* max_lock is used to protect the swapping of buffers
|
|
* when taking a max snapshot. The buffers themselves are
|
|
* protected by per_cpu spinlocks. But the action of the swap
|
|
* needs its own lock.
|
|
*
|
|
* This is defined as a arch_spinlock_t in order to help
|
|
* with performance when lockdep debugging is enabled.
|
|
*
|
|
* It is also used in other places outside the update_max_tr
|
|
* so it needs to be defined outside of the
|
|
* CONFIG_TRACER_MAX_TRACE.
|
|
*/
|
|
arch_spinlock_t max_lock;
|
|
int buffer_disabled;
|
|
#ifdef CONFIG_FTRACE_SYSCALLS
|
|
int sys_refcount_enter;
|
|
int sys_refcount_exit;
|
|
struct trace_event_file __rcu *enter_syscall_files[NR_syscalls];
|
|
struct trace_event_file __rcu *exit_syscall_files[NR_syscalls];
|
|
#endif
|
|
int stop_count;
|
|
int clock_id;
|
|
int nr_topts;
|
|
bool clear_trace;
|
|
int buffer_percent;
|
|
unsigned int n_err_log_entries;
|
|
struct tracer *current_trace;
|
|
unsigned int trace_flags;
|
|
unsigned char trace_flags_index[TRACE_FLAGS_MAX_SIZE];
|
|
unsigned int flags;
|
|
raw_spinlock_t start_lock;
|
|
struct list_head err_log;
|
|
struct dentry *dir;
|
|
struct dentry *options;
|
|
struct dentry *percpu_dir;
|
|
struct dentry *event_dir;
|
|
struct trace_options *topts;
|
|
struct list_head systems;
|
|
struct list_head events;
|
|
struct trace_event_file *trace_marker_file;
|
|
cpumask_var_t tracing_cpumask; /* only trace on set CPUs */
|
|
int ref;
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
struct ftrace_ops *ops;
|
|
struct trace_pid_list __rcu *function_pids;
|
|
#ifdef CONFIG_DYNAMIC_FTRACE
|
|
/* All of these are protected by the ftrace_lock */
|
|
struct list_head func_probes;
|
|
struct list_head mod_trace;
|
|
struct list_head mod_notrace;
|
|
#endif
|
|
/* function tracing enabled */
|
|
int function_enabled;
|
|
#endif
|
|
int time_stamp_abs_ref;
|
|
struct list_head hist_vars;
|
|
#ifdef CONFIG_TRACER_SNAPSHOT
|
|
struct cond_snapshot *cond_snapshot;
|
|
#endif
|
|
};
|
|
|
|
enum {
|
|
TRACE_ARRAY_FL_GLOBAL = (1 << 0)
|
|
};
|
|
|
|
extern struct list_head ftrace_trace_arrays;
|
|
|
|
extern struct mutex trace_types_lock;
|
|
|
|
extern int trace_array_get(struct trace_array *tr);
|
|
extern void trace_array_put(struct trace_array *tr);
|
|
extern int tracing_check_open_get_tr(struct trace_array *tr);
|
|
|
|
extern int tracing_set_time_stamp_abs(struct trace_array *tr, bool abs);
|
|
extern int tracing_set_clock(struct trace_array *tr, const char *clockstr);
|
|
|
|
extern bool trace_clock_in_ns(struct trace_array *tr);
|
|
|
|
/*
|
|
* The global tracer (top) should be the first trace array added,
|
|
* but we check the flag anyway.
|
|
*/
|
|
static inline struct trace_array *top_trace_array(void)
|
|
{
|
|
struct trace_array *tr;
|
|
|
|
if (list_empty(&ftrace_trace_arrays))
|
|
return NULL;
|
|
|
|
tr = list_entry(ftrace_trace_arrays.prev,
|
|
typeof(*tr), list);
|
|
WARN_ON(!(tr->flags & TRACE_ARRAY_FL_GLOBAL));
|
|
return tr;
|
|
}
|
|
|
|
#define FTRACE_CMP_TYPE(var, type) \
|
|
__builtin_types_compatible_p(typeof(var), type *)
|
|
|
|
#undef IF_ASSIGN
|
|
#define IF_ASSIGN(var, entry, etype, id) \
|
|
if (FTRACE_CMP_TYPE(var, etype)) { \
|
|
var = (typeof(var))(entry); \
|
|
WARN_ON(id != 0 && (entry)->type != id); \
|
|
break; \
|
|
}
|
|
|
|
/* Will cause compile errors if type is not found. */
|
|
extern void __ftrace_bad_type(void);
|
|
|
|
/*
|
|
* The trace_assign_type is a verifier that the entry type is
|
|
* the same as the type being assigned. To add new types simply
|
|
* add a line with the following format:
|
|
*
|
|
* IF_ASSIGN(var, ent, type, id);
|
|
*
|
|
* Where "type" is the trace type that includes the trace_entry
|
|
* as the "ent" item. And "id" is the trace identifier that is
|
|
* used in the trace_type enum.
|
|
*
|
|
* If the type can have more than one id, then use zero.
|
|
*/
|
|
#define trace_assign_type(var, ent) \
|
|
do { \
|
|
IF_ASSIGN(var, ent, struct ftrace_entry, TRACE_FN); \
|
|
IF_ASSIGN(var, ent, struct ctx_switch_entry, 0); \
|
|
IF_ASSIGN(var, ent, struct stack_entry, TRACE_STACK); \
|
|
IF_ASSIGN(var, ent, struct userstack_entry, TRACE_USER_STACK);\
|
|
IF_ASSIGN(var, ent, struct print_entry, TRACE_PRINT); \
|
|
IF_ASSIGN(var, ent, struct bprint_entry, TRACE_BPRINT); \
|
|
IF_ASSIGN(var, ent, struct bputs_entry, TRACE_BPUTS); \
|
|
IF_ASSIGN(var, ent, struct hwlat_entry, TRACE_HWLAT); \
|
|
IF_ASSIGN(var, ent, struct raw_data_entry, TRACE_RAW_DATA);\
|
|
IF_ASSIGN(var, ent, struct trace_mmiotrace_rw, \
|
|
TRACE_MMIO_RW); \
|
|
IF_ASSIGN(var, ent, struct trace_mmiotrace_map, \
|
|
TRACE_MMIO_MAP); \
|
|
IF_ASSIGN(var, ent, struct trace_branch, TRACE_BRANCH); \
|
|
IF_ASSIGN(var, ent, struct ftrace_graph_ent_entry, \
|
|
TRACE_GRAPH_ENT); \
|
|
IF_ASSIGN(var, ent, struct ftrace_graph_ret_entry, \
|
|
TRACE_GRAPH_RET); \
|
|
__ftrace_bad_type(); \
|
|
} while (0)
|
|
|
|
/*
|
|
* An option specific to a tracer. This is a boolean value.
|
|
* The bit is the bit index that sets its value on the
|
|
* flags value in struct tracer_flags.
|
|
*/
|
|
struct tracer_opt {
|
|
const char *name; /* Will appear on the trace_options file */
|
|
u32 bit; /* Mask assigned in val field in tracer_flags */
|
|
};
|
|
|
|
/*
|
|
* The set of specific options for a tracer. Your tracer
|
|
* have to set the initial value of the flags val.
|
|
*/
|
|
struct tracer_flags {
|
|
u32 val;
|
|
struct tracer_opt *opts;
|
|
struct tracer *trace;
|
|
};
|
|
|
|
/* Makes more easy to define a tracer opt */
|
|
#define TRACER_OPT(s, b) .name = #s, .bit = b
|
|
|
|
|
|
struct trace_option_dentry {
|
|
struct tracer_opt *opt;
|
|
struct tracer_flags *flags;
|
|
struct trace_array *tr;
|
|
struct dentry *entry;
|
|
};
|
|
|
|
/**
|
|
* struct tracer - a specific tracer and its callbacks to interact with tracefs
|
|
* @name: the name chosen to select it on the available_tracers file
|
|
* @init: called when one switches to this tracer (echo name > current_tracer)
|
|
* @reset: called when one switches to another tracer
|
|
* @start: called when tracing is unpaused (echo 1 > tracing_on)
|
|
* @stop: called when tracing is paused (echo 0 > tracing_on)
|
|
* @update_thresh: called when tracing_thresh is updated
|
|
* @open: called when the trace file is opened
|
|
* @pipe_open: called when the trace_pipe file is opened
|
|
* @close: called when the trace file is released
|
|
* @pipe_close: called when the trace_pipe file is released
|
|
* @read: override the default read callback on trace_pipe
|
|
* @splice_read: override the default splice_read callback on trace_pipe
|
|
* @selftest: selftest to run on boot (see trace_selftest.c)
|
|
* @print_headers: override the first lines that describe your columns
|
|
* @print_line: callback that prints a trace
|
|
* @set_flag: signals one of your private flags changed (trace_options file)
|
|
* @flags: your private flags
|
|
*/
|
|
struct tracer {
|
|
const char *name;
|
|
int (*init)(struct trace_array *tr);
|
|
void (*reset)(struct trace_array *tr);
|
|
void (*start)(struct trace_array *tr);
|
|
void (*stop)(struct trace_array *tr);
|
|
int (*update_thresh)(struct trace_array *tr);
|
|
void (*open)(struct trace_iterator *iter);
|
|
void (*pipe_open)(struct trace_iterator *iter);
|
|
void (*close)(struct trace_iterator *iter);
|
|
void (*pipe_close)(struct trace_iterator *iter);
|
|
ssize_t (*read)(struct trace_iterator *iter,
|
|
struct file *filp, char __user *ubuf,
|
|
size_t cnt, loff_t *ppos);
|
|
ssize_t (*splice_read)(struct trace_iterator *iter,
|
|
struct file *filp,
|
|
loff_t *ppos,
|
|
struct pipe_inode_info *pipe,
|
|
size_t len,
|
|
unsigned int flags);
|
|
#ifdef CONFIG_FTRACE_STARTUP_TEST
|
|
int (*selftest)(struct tracer *trace,
|
|
struct trace_array *tr);
|
|
#endif
|
|
void (*print_header)(struct seq_file *m);
|
|
enum print_line_t (*print_line)(struct trace_iterator *iter);
|
|
/* If you handled the flag setting, return 0 */
|
|
int (*set_flag)(struct trace_array *tr,
|
|
u32 old_flags, u32 bit, int set);
|
|
/* Return 0 if OK with change, else return non-zero */
|
|
int (*flag_changed)(struct trace_array *tr,
|
|
u32 mask, int set);
|
|
struct tracer *next;
|
|
struct tracer_flags *flags;
|
|
int enabled;
|
|
int ref;
|
|
bool print_max;
|
|
bool allow_instances;
|
|
#ifdef CONFIG_TRACER_MAX_TRACE
|
|
bool use_max_tr;
|
|
#endif
|
|
/* True if tracer cannot be enabled in kernel param */
|
|
bool noboot;
|
|
};
|
|
|
|
|
|
/* Only current can touch trace_recursion */
|
|
|
|
/*
|
|
* For function tracing recursion:
|
|
* The order of these bits are important.
|
|
*
|
|
* When function tracing occurs, the following steps are made:
|
|
* If arch does not support a ftrace feature:
|
|
* call internal function (uses INTERNAL bits) which calls...
|
|
* The function callback, which can use the FTRACE bits to
|
|
* check for recursion.
|
|
*/
|
|
enum {
|
|
TRACE_BUFFER_BIT,
|
|
TRACE_BUFFER_NMI_BIT,
|
|
TRACE_BUFFER_IRQ_BIT,
|
|
TRACE_BUFFER_SIRQ_BIT,
|
|
|
|
/* Start of function recursion bits */
|
|
TRACE_FTRACE_BIT,
|
|
TRACE_FTRACE_NMI_BIT,
|
|
TRACE_FTRACE_IRQ_BIT,
|
|
TRACE_FTRACE_SIRQ_BIT,
|
|
TRACE_FTRACE_TRANSITION_BIT,
|
|
|
|
/* Internal use recursion bits */
|
|
TRACE_INTERNAL_BIT,
|
|
TRACE_INTERNAL_NMI_BIT,
|
|
TRACE_INTERNAL_IRQ_BIT,
|
|
TRACE_INTERNAL_SIRQ_BIT,
|
|
TRACE_INTERNAL_TRANSITION_BIT,
|
|
|
|
TRACE_BRANCH_BIT,
|
|
/*
|
|
* Abuse of the trace_recursion.
|
|
* As we need a way to maintain state if we are tracing the function
|
|
* graph in irq because we want to trace a particular function that
|
|
* was called in irq context but we have irq tracing off. Since this
|
|
* can only be modified by current, we can reuse trace_recursion.
|
|
*/
|
|
TRACE_IRQ_BIT,
|
|
|
|
/* Set if the function is in the set_graph_function file */
|
|
TRACE_GRAPH_BIT,
|
|
|
|
/*
|
|
* In the very unlikely case that an interrupt came in
|
|
* at a start of graph tracing, and we want to trace
|
|
* the function in that interrupt, the depth can be greater
|
|
* than zero, because of the preempted start of a previous
|
|
* trace. In an even more unlikely case, depth could be 2
|
|
* if a softirq interrupted the start of graph tracing,
|
|
* followed by an interrupt preempting a start of graph
|
|
* tracing in the softirq, and depth can even be 3
|
|
* if an NMI came in at the start of an interrupt function
|
|
* that preempted a softirq start of a function that
|
|
* preempted normal context!!!! Luckily, it can't be
|
|
* greater than 3, so the next two bits are a mask
|
|
* of what the depth is when we set TRACE_GRAPH_BIT
|
|
*/
|
|
|
|
TRACE_GRAPH_DEPTH_START_BIT,
|
|
TRACE_GRAPH_DEPTH_END_BIT,
|
|
|
|
/*
|
|
* To implement set_graph_notrace, if this bit is set, we ignore
|
|
* function graph tracing of called functions, until the return
|
|
* function is called to clear it.
|
|
*/
|
|
TRACE_GRAPH_NOTRACE_BIT,
|
|
};
|
|
|
|
#define trace_recursion_set(bit) do { (current)->trace_recursion |= (1<<(bit)); } while (0)
|
|
#define trace_recursion_clear(bit) do { (current)->trace_recursion &= ~(1<<(bit)); } while (0)
|
|
#define trace_recursion_test(bit) ((current)->trace_recursion & (1<<(bit)))
|
|
|
|
#define trace_recursion_depth() \
|
|
(((current)->trace_recursion >> TRACE_GRAPH_DEPTH_START_BIT) & 3)
|
|
#define trace_recursion_set_depth(depth) \
|
|
do { \
|
|
current->trace_recursion &= \
|
|
~(3 << TRACE_GRAPH_DEPTH_START_BIT); \
|
|
current->trace_recursion |= \
|
|
((depth) & 3) << TRACE_GRAPH_DEPTH_START_BIT; \
|
|
} while (0)
|
|
|
|
#define TRACE_CONTEXT_BITS 4
|
|
|
|
#define TRACE_FTRACE_START TRACE_FTRACE_BIT
|
|
|
|
#define TRACE_LIST_START TRACE_INTERNAL_BIT
|
|
|
|
#define TRACE_CONTEXT_MASK ((1 << (TRACE_LIST_START + TRACE_CONTEXT_BITS)) - 1)
|
|
|
|
enum {
|
|
TRACE_CTX_NMI,
|
|
TRACE_CTX_IRQ,
|
|
TRACE_CTX_SOFTIRQ,
|
|
TRACE_CTX_NORMAL,
|
|
TRACE_CTX_TRANSITION,
|
|
};
|
|
|
|
static __always_inline int trace_get_context_bit(void)
|
|
{
|
|
int bit;
|
|
|
|
if (in_interrupt()) {
|
|
if (in_nmi())
|
|
bit = TRACE_CTX_NMI;
|
|
|
|
else if (in_irq())
|
|
bit = TRACE_CTX_IRQ;
|
|
else
|
|
bit = TRACE_CTX_SOFTIRQ;
|
|
} else
|
|
bit = TRACE_CTX_NORMAL;
|
|
|
|
return bit;
|
|
}
|
|
|
|
static __always_inline int trace_test_and_set_recursion(int start)
|
|
{
|
|
unsigned int val = current->trace_recursion;
|
|
int bit;
|
|
|
|
bit = trace_get_context_bit() + start;
|
|
if (unlikely(val & (1 << bit))) {
|
|
/*
|
|
* It could be that preempt_count has not been updated during
|
|
* a switch between contexts. Allow for a single recursion.
|
|
*/
|
|
bit = start + TRACE_CTX_TRANSITION;
|
|
if (trace_recursion_test(bit))
|
|
return -1;
|
|
trace_recursion_set(bit);
|
|
barrier();
|
|
return bit;
|
|
}
|
|
|
|
val |= 1 << bit;
|
|
current->trace_recursion = val;
|
|
barrier();
|
|
|
|
return bit;
|
|
}
|
|
|
|
static __always_inline void trace_clear_recursion(int bit)
|
|
{
|
|
unsigned int val = current->trace_recursion;
|
|
|
|
bit = 1 << bit;
|
|
val &= ~bit;
|
|
|
|
barrier();
|
|
current->trace_recursion = val;
|
|
}
|
|
|
|
static inline struct ring_buffer_iter *
|
|
trace_buffer_iter(struct trace_iterator *iter, int cpu)
|
|
{
|
|
return iter->buffer_iter ? iter->buffer_iter[cpu] : NULL;
|
|
}
|
|
|
|
int tracer_init(struct tracer *t, struct trace_array *tr);
|
|
int tracing_is_enabled(void);
|
|
void tracing_reset_online_cpus(struct trace_buffer *buf);
|
|
void tracing_reset_current(int cpu);
|
|
void tracing_reset_all_online_cpus(void);
|
|
int tracing_open_generic(struct inode *inode, struct file *filp);
|
|
int tracing_open_generic_tr(struct inode *inode, struct file *filp);
|
|
bool tracing_is_disabled(void);
|
|
bool tracer_tracing_is_on(struct trace_array *tr);
|
|
void tracer_tracing_on(struct trace_array *tr);
|
|
void tracer_tracing_off(struct trace_array *tr);
|
|
struct dentry *trace_create_file(const char *name,
|
|
umode_t mode,
|
|
struct dentry *parent,
|
|
void *data,
|
|
const struct file_operations *fops);
|
|
|
|
struct dentry *tracing_init_dentry(void);
|
|
|
|
struct ring_buffer_event;
|
|
|
|
struct ring_buffer_event *
|
|
trace_buffer_lock_reserve(struct ring_buffer *buffer,
|
|
int type,
|
|
unsigned long len,
|
|
unsigned long flags,
|
|
int pc);
|
|
|
|
struct trace_entry *tracing_get_trace_entry(struct trace_array *tr,
|
|
struct trace_array_cpu *data);
|
|
|
|
struct trace_entry *trace_find_next_entry(struct trace_iterator *iter,
|
|
int *ent_cpu, u64 *ent_ts);
|
|
|
|
void trace_buffer_unlock_commit_nostack(struct ring_buffer *buffer,
|
|
struct ring_buffer_event *event);
|
|
|
|
int trace_empty(struct trace_iterator *iter);
|
|
|
|
void *trace_find_next_entry_inc(struct trace_iterator *iter);
|
|
|
|
void trace_init_global_iter(struct trace_iterator *iter);
|
|
|
|
void tracing_iter_reset(struct trace_iterator *iter, int cpu);
|
|
|
|
unsigned long trace_total_entries_cpu(struct trace_array *tr, int cpu);
|
|
unsigned long trace_total_entries(struct trace_array *tr);
|
|
|
|
void trace_function(struct trace_array *tr,
|
|
unsigned long ip,
|
|
unsigned long parent_ip,
|
|
unsigned long flags, int pc);
|
|
void trace_graph_function(struct trace_array *tr,
|
|
unsigned long ip,
|
|
unsigned long parent_ip,
|
|
unsigned long flags, int pc);
|
|
void trace_latency_header(struct seq_file *m);
|
|
void trace_default_header(struct seq_file *m);
|
|
void print_trace_header(struct seq_file *m, struct trace_iterator *iter);
|
|
int trace_empty(struct trace_iterator *iter);
|
|
|
|
void trace_graph_return(struct ftrace_graph_ret *trace);
|
|
int trace_graph_entry(struct ftrace_graph_ent *trace);
|
|
void set_graph_array(struct trace_array *tr);
|
|
|
|
void tracing_start_cmdline_record(void);
|
|
void tracing_stop_cmdline_record(void);
|
|
void tracing_start_tgid_record(void);
|
|
void tracing_stop_tgid_record(void);
|
|
|
|
int register_tracer(struct tracer *type);
|
|
int is_tracing_stopped(void);
|
|
|
|
loff_t tracing_lseek(struct file *file, loff_t offset, int whence);
|
|
|
|
extern cpumask_var_t __read_mostly tracing_buffer_mask;
|
|
|
|
#define for_each_tracing_cpu(cpu) \
|
|
for_each_cpu(cpu, tracing_buffer_mask)
|
|
|
|
extern unsigned long nsecs_to_usecs(unsigned long nsecs);
|
|
|
|
extern unsigned long tracing_thresh;
|
|
|
|
/* PID filtering */
|
|
|
|
extern int pid_max;
|
|
|
|
bool trace_find_filtered_pid(struct trace_pid_list *filtered_pids,
|
|
pid_t search_pid);
|
|
bool trace_ignore_this_task(struct trace_pid_list *filtered_pids,
|
|
struct task_struct *task);
|
|
void trace_filter_add_remove_task(struct trace_pid_list *pid_list,
|
|
struct task_struct *self,
|
|
struct task_struct *task);
|
|
void *trace_pid_next(struct trace_pid_list *pid_list, void *v, loff_t *pos);
|
|
void *trace_pid_start(struct trace_pid_list *pid_list, loff_t *pos);
|
|
int trace_pid_show(struct seq_file *m, void *v);
|
|
void trace_free_pid_list(struct trace_pid_list *pid_list);
|
|
int trace_pid_write(struct trace_pid_list *filtered_pids,
|
|
struct trace_pid_list **new_pid_list,
|
|
const char __user *ubuf, size_t cnt);
|
|
|
|
#ifdef CONFIG_TRACER_MAX_TRACE
|
|
void update_max_tr(struct trace_array *tr, struct task_struct *tsk, int cpu,
|
|
void *cond_data);
|
|
void update_max_tr_single(struct trace_array *tr,
|
|
struct task_struct *tsk, int cpu);
|
|
#endif /* CONFIG_TRACER_MAX_TRACE */
|
|
|
|
#ifdef CONFIG_STACKTRACE
|
|
void __trace_stack(struct trace_array *tr, unsigned long flags, int skip,
|
|
int pc);
|
|
#else
|
|
static inline void __trace_stack(struct trace_array *tr, unsigned long flags,
|
|
int skip, int pc)
|
|
{
|
|
}
|
|
#endif /* CONFIG_STACKTRACE */
|
|
|
|
extern u64 ftrace_now(int cpu);
|
|
|
|
extern void trace_find_cmdline(int pid, char comm[]);
|
|
extern int trace_find_tgid(int pid);
|
|
extern void trace_event_follow_fork(struct trace_array *tr, bool enable);
|
|
|
|
#ifdef CONFIG_DYNAMIC_FTRACE
|
|
extern unsigned long ftrace_update_tot_cnt;
|
|
void ftrace_init_trace_array(struct trace_array *tr);
|
|
#else
|
|
static inline void ftrace_init_trace_array(struct trace_array *tr) { }
|
|
#endif
|
|
#define DYN_FTRACE_TEST_NAME trace_selftest_dynamic_test_func
|
|
extern int DYN_FTRACE_TEST_NAME(void);
|
|
#define DYN_FTRACE_TEST_NAME2 trace_selftest_dynamic_test_func2
|
|
extern int DYN_FTRACE_TEST_NAME2(void);
|
|
|
|
extern bool ring_buffer_expanded;
|
|
extern bool tracing_selftest_disabled;
|
|
|
|
#ifdef CONFIG_FTRACE_STARTUP_TEST
|
|
extern int trace_selftest_startup_function(struct tracer *trace,
|
|
struct trace_array *tr);
|
|
extern int trace_selftest_startup_function_graph(struct tracer *trace,
|
|
struct trace_array *tr);
|
|
extern int trace_selftest_startup_irqsoff(struct tracer *trace,
|
|
struct trace_array *tr);
|
|
extern int trace_selftest_startup_preemptoff(struct tracer *trace,
|
|
struct trace_array *tr);
|
|
extern int trace_selftest_startup_preemptirqsoff(struct tracer *trace,
|
|
struct trace_array *tr);
|
|
extern int trace_selftest_startup_wakeup(struct tracer *trace,
|
|
struct trace_array *tr);
|
|
extern int trace_selftest_startup_nop(struct tracer *trace,
|
|
struct trace_array *tr);
|
|
extern int trace_selftest_startup_branch(struct tracer *trace,
|
|
struct trace_array *tr);
|
|
/*
|
|
* Tracer data references selftest functions that only occur
|
|
* on boot up. These can be __init functions. Thus, when selftests
|
|
* are enabled, then the tracers need to reference __init functions.
|
|
*/
|
|
#define __tracer_data __refdata
|
|
#else
|
|
/* Tracers are seldom changed. Optimize when selftests are disabled. */
|
|
#define __tracer_data __read_mostly
|
|
#endif /* CONFIG_FTRACE_STARTUP_TEST */
|
|
|
|
extern void *head_page(struct trace_array_cpu *data);
|
|
extern unsigned long long ns2usecs(u64 nsec);
|
|
extern int
|
|
trace_vbprintk(unsigned long ip, const char *fmt, va_list args);
|
|
extern int
|
|
trace_vprintk(unsigned long ip, const char *fmt, va_list args);
|
|
extern int
|
|
trace_array_vprintk(struct trace_array *tr,
|
|
unsigned long ip, const char *fmt, va_list args);
|
|
int trace_array_printk(struct trace_array *tr,
|
|
unsigned long ip, const char *fmt, ...);
|
|
int trace_array_printk_buf(struct ring_buffer *buffer,
|
|
unsigned long ip, const char *fmt, ...);
|
|
void trace_printk_seq(struct trace_seq *s);
|
|
enum print_line_t print_trace_line(struct trace_iterator *iter);
|
|
|
|
extern char trace_find_mark(unsigned long long duration);
|
|
|
|
struct ftrace_hash;
|
|
|
|
struct ftrace_mod_load {
|
|
struct list_head list;
|
|
char *func;
|
|
char *module;
|
|
int enable;
|
|
};
|
|
|
|
enum {
|
|
FTRACE_HASH_FL_MOD = (1 << 0),
|
|
};
|
|
|
|
struct ftrace_hash {
|
|
unsigned long size_bits;
|
|
struct hlist_head *buckets;
|
|
unsigned long count;
|
|
unsigned long flags;
|
|
struct rcu_head rcu;
|
|
};
|
|
|
|
struct ftrace_func_entry *
|
|
ftrace_lookup_ip(struct ftrace_hash *hash, unsigned long ip);
|
|
|
|
static __always_inline bool ftrace_hash_empty(struct ftrace_hash *hash)
|
|
{
|
|
return !hash || !(hash->count || (hash->flags & FTRACE_HASH_FL_MOD));
|
|
}
|
|
|
|
/* Standard output formatting function used for function return traces */
|
|
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
|
|
|
/* Flag options */
|
|
#define TRACE_GRAPH_PRINT_OVERRUN 0x1
|
|
#define TRACE_GRAPH_PRINT_CPU 0x2
|
|
#define TRACE_GRAPH_PRINT_OVERHEAD 0x4
|
|
#define TRACE_GRAPH_PRINT_PROC 0x8
|
|
#define TRACE_GRAPH_PRINT_DURATION 0x10
|
|
#define TRACE_GRAPH_PRINT_ABS_TIME 0x20
|
|
#define TRACE_GRAPH_PRINT_REL_TIME 0x40
|
|
#define TRACE_GRAPH_PRINT_IRQS 0x80
|
|
#define TRACE_GRAPH_PRINT_TAIL 0x100
|
|
#define TRACE_GRAPH_SLEEP_TIME 0x200
|
|
#define TRACE_GRAPH_GRAPH_TIME 0x400
|
|
#define TRACE_GRAPH_PRINT_FILL_SHIFT 28
|
|
#define TRACE_GRAPH_PRINT_FILL_MASK (0x3 << TRACE_GRAPH_PRINT_FILL_SHIFT)
|
|
|
|
extern void ftrace_graph_sleep_time_control(bool enable);
|
|
|
|
#ifdef CONFIG_FUNCTION_PROFILER
|
|
extern void ftrace_graph_graph_time_control(bool enable);
|
|
#else
|
|
static inline void ftrace_graph_graph_time_control(bool enable) { }
|
|
#endif
|
|
|
|
extern enum print_line_t
|
|
print_graph_function_flags(struct trace_iterator *iter, u32 flags);
|
|
extern void print_graph_headers_flags(struct seq_file *s, u32 flags);
|
|
extern void
|
|
trace_print_graph_duration(unsigned long long duration, struct trace_seq *s);
|
|
extern void graph_trace_open(struct trace_iterator *iter);
|
|
extern void graph_trace_close(struct trace_iterator *iter);
|
|
extern int __trace_graph_entry(struct trace_array *tr,
|
|
struct ftrace_graph_ent *trace,
|
|
unsigned long flags, int pc);
|
|
extern void __trace_graph_return(struct trace_array *tr,
|
|
struct ftrace_graph_ret *trace,
|
|
unsigned long flags, int pc);
|
|
|
|
#ifdef CONFIG_DYNAMIC_FTRACE
|
|
extern struct ftrace_hash __rcu *ftrace_graph_hash;
|
|
extern struct ftrace_hash __rcu *ftrace_graph_notrace_hash;
|
|
|
|
static inline int ftrace_graph_addr(struct ftrace_graph_ent *trace)
|
|
{
|
|
unsigned long addr = trace->func;
|
|
int ret = 0;
|
|
struct ftrace_hash *hash;
|
|
|
|
preempt_disable_notrace();
|
|
|
|
/*
|
|
* Have to open code "rcu_dereference_sched()" because the
|
|
* function graph tracer can be called when RCU is not
|
|
* "watching".
|
|
* Protected with schedule_on_each_cpu(ftrace_sync)
|
|
*/
|
|
hash = rcu_dereference_protected(ftrace_graph_hash, !preemptible());
|
|
|
|
if (ftrace_hash_empty(hash)) {
|
|
ret = 1;
|
|
goto out;
|
|
}
|
|
|
|
if (ftrace_lookup_ip(hash, addr)) {
|
|
|
|
/*
|
|
* This needs to be cleared on the return functions
|
|
* when the depth is zero.
|
|
*/
|
|
trace_recursion_set(TRACE_GRAPH_BIT);
|
|
trace_recursion_set_depth(trace->depth);
|
|
|
|
/*
|
|
* If no irqs are to be traced, but a set_graph_function
|
|
* is set, and called by an interrupt handler, we still
|
|
* want to trace it.
|
|
*/
|
|
if (in_irq())
|
|
trace_recursion_set(TRACE_IRQ_BIT);
|
|
else
|
|
trace_recursion_clear(TRACE_IRQ_BIT);
|
|
ret = 1;
|
|
}
|
|
|
|
out:
|
|
preempt_enable_notrace();
|
|
return ret;
|
|
}
|
|
|
|
static inline void ftrace_graph_addr_finish(struct ftrace_graph_ret *trace)
|
|
{
|
|
if (trace_recursion_test(TRACE_GRAPH_BIT) &&
|
|
trace->depth == trace_recursion_depth())
|
|
trace_recursion_clear(TRACE_GRAPH_BIT);
|
|
}
|
|
|
|
static inline int ftrace_graph_notrace_addr(unsigned long addr)
|
|
{
|
|
int ret = 0;
|
|
struct ftrace_hash *notrace_hash;
|
|
|
|
preempt_disable_notrace();
|
|
|
|
/*
|
|
* Have to open code "rcu_dereference_sched()" because the
|
|
* function graph tracer can be called when RCU is not
|
|
* "watching".
|
|
* Protected with schedule_on_each_cpu(ftrace_sync)
|
|
*/
|
|
notrace_hash = rcu_dereference_protected(ftrace_graph_notrace_hash,
|
|
!preemptible());
|
|
|
|
if (ftrace_lookup_ip(notrace_hash, addr))
|
|
ret = 1;
|
|
|
|
preempt_enable_notrace();
|
|
return ret;
|
|
}
|
|
#else
|
|
static inline int ftrace_graph_addr(struct ftrace_graph_ent *trace)
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
static inline int ftrace_graph_notrace_addr(unsigned long addr)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline void ftrace_graph_addr_finish(struct ftrace_graph_ret *trace)
|
|
{ }
|
|
#endif /* CONFIG_DYNAMIC_FTRACE */
|
|
|
|
extern unsigned int fgraph_max_depth;
|
|
|
|
static inline bool ftrace_graph_ignore_func(struct ftrace_graph_ent *trace)
|
|
{
|
|
/* trace it when it is-nested-in or is a function enabled. */
|
|
return !(trace_recursion_test(TRACE_GRAPH_BIT) ||
|
|
ftrace_graph_addr(trace)) ||
|
|
(trace->depth < 0) ||
|
|
(fgraph_max_depth && trace->depth >= fgraph_max_depth);
|
|
}
|
|
|
|
#else /* CONFIG_FUNCTION_GRAPH_TRACER */
|
|
static inline enum print_line_t
|
|
print_graph_function_flags(struct trace_iterator *iter, u32 flags)
|
|
{
|
|
return TRACE_TYPE_UNHANDLED;
|
|
}
|
|
#endif /* CONFIG_FUNCTION_GRAPH_TRACER */
|
|
|
|
extern struct list_head ftrace_pids;
|
|
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
struct ftrace_func_command {
|
|
struct list_head list;
|
|
char *name;
|
|
int (*func)(struct trace_array *tr,
|
|
struct ftrace_hash *hash,
|
|
char *func, char *cmd,
|
|
char *params, int enable);
|
|
};
|
|
extern bool ftrace_filter_param __initdata;
|
|
static inline int ftrace_trace_task(struct trace_array *tr)
|
|
{
|
|
return !this_cpu_read(tr->trace_buffer.data->ftrace_ignore_pid);
|
|
}
|
|
extern int ftrace_is_dead(void);
|
|
int ftrace_create_function_files(struct trace_array *tr,
|
|
struct dentry *parent);
|
|
void ftrace_destroy_function_files(struct trace_array *tr);
|
|
void ftrace_init_global_array_ops(struct trace_array *tr);
|
|
void ftrace_init_array_ops(struct trace_array *tr, ftrace_func_t func);
|
|
void ftrace_reset_array_ops(struct trace_array *tr);
|
|
void ftrace_init_tracefs(struct trace_array *tr, struct dentry *d_tracer);
|
|
void ftrace_init_tracefs_toplevel(struct trace_array *tr,
|
|
struct dentry *d_tracer);
|
|
void ftrace_clear_pids(struct trace_array *tr);
|
|
int init_function_trace(void);
|
|
void ftrace_pid_follow_fork(struct trace_array *tr, bool enable);
|
|
#else
|
|
static inline int ftrace_trace_task(struct trace_array *tr)
|
|
{
|
|
return 1;
|
|
}
|
|
static inline int ftrace_is_dead(void) { return 0; }
|
|
static inline int
|
|
ftrace_create_function_files(struct trace_array *tr,
|
|
struct dentry *parent)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline void ftrace_destroy_function_files(struct trace_array *tr) { }
|
|
static inline __init void
|
|
ftrace_init_global_array_ops(struct trace_array *tr) { }
|
|
static inline void ftrace_reset_array_ops(struct trace_array *tr) { }
|
|
static inline void ftrace_init_tracefs(struct trace_array *tr, struct dentry *d) { }
|
|
static inline void ftrace_init_tracefs_toplevel(struct trace_array *tr, struct dentry *d) { }
|
|
static inline void ftrace_clear_pids(struct trace_array *tr) { }
|
|
static inline int init_function_trace(void) { return 0; }
|
|
static inline void ftrace_pid_follow_fork(struct trace_array *tr, bool enable) { }
|
|
/* ftace_func_t type is not defined, use macro instead of static inline */
|
|
#define ftrace_init_array_ops(tr, func) do { } while (0)
|
|
#endif /* CONFIG_FUNCTION_TRACER */
|
|
|
|
#if defined(CONFIG_FUNCTION_TRACER) && defined(CONFIG_DYNAMIC_FTRACE)
|
|
|
|
struct ftrace_probe_ops {
|
|
void (*func)(unsigned long ip,
|
|
unsigned long parent_ip,
|
|
struct trace_array *tr,
|
|
struct ftrace_probe_ops *ops,
|
|
void *data);
|
|
int (*init)(struct ftrace_probe_ops *ops,
|
|
struct trace_array *tr,
|
|
unsigned long ip, void *init_data,
|
|
void **data);
|
|
void (*free)(struct ftrace_probe_ops *ops,
|
|
struct trace_array *tr,
|
|
unsigned long ip, void *data);
|
|
int (*print)(struct seq_file *m,
|
|
unsigned long ip,
|
|
struct ftrace_probe_ops *ops,
|
|
void *data);
|
|
};
|
|
|
|
struct ftrace_func_mapper;
|
|
typedef int (*ftrace_mapper_func)(void *data);
|
|
|
|
struct ftrace_func_mapper *allocate_ftrace_func_mapper(void);
|
|
void **ftrace_func_mapper_find_ip(struct ftrace_func_mapper *mapper,
|
|
unsigned long ip);
|
|
int ftrace_func_mapper_add_ip(struct ftrace_func_mapper *mapper,
|
|
unsigned long ip, void *data);
|
|
void *ftrace_func_mapper_remove_ip(struct ftrace_func_mapper *mapper,
|
|
unsigned long ip);
|
|
void free_ftrace_func_mapper(struct ftrace_func_mapper *mapper,
|
|
ftrace_mapper_func free_func);
|
|
|
|
extern int
|
|
register_ftrace_function_probe(char *glob, struct trace_array *tr,
|
|
struct ftrace_probe_ops *ops, void *data);
|
|
extern int
|
|
unregister_ftrace_function_probe_func(char *glob, struct trace_array *tr,
|
|
struct ftrace_probe_ops *ops);
|
|
extern void clear_ftrace_function_probes(struct trace_array *tr);
|
|
|
|
int register_ftrace_command(struct ftrace_func_command *cmd);
|
|
int unregister_ftrace_command(struct ftrace_func_command *cmd);
|
|
|
|
void ftrace_create_filter_files(struct ftrace_ops *ops,
|
|
struct dentry *parent);
|
|
void ftrace_destroy_filter_files(struct ftrace_ops *ops);
|
|
#else
|
|
struct ftrace_func_command;
|
|
|
|
static inline __init int register_ftrace_command(struct ftrace_func_command *cmd)
|
|
{
|
|
return -EINVAL;
|
|
}
|
|
static inline __init int unregister_ftrace_command(char *cmd_name)
|
|
{
|
|
return -EINVAL;
|
|
}
|
|
static inline void clear_ftrace_function_probes(struct trace_array *tr)
|
|
{
|
|
}
|
|
|
|
/*
|
|
* The ops parameter passed in is usually undefined.
|
|
* This must be a macro.
|
|
*/
|
|
#define ftrace_create_filter_files(ops, parent) do { } while (0)
|
|
#define ftrace_destroy_filter_files(ops) do { } while (0)
|
|
#endif /* CONFIG_FUNCTION_TRACER && CONFIG_DYNAMIC_FTRACE */
|
|
|
|
bool ftrace_event_is_function(struct trace_event_call *call);
|
|
|
|
/*
|
|
* struct trace_parser - servers for reading the user input separated by spaces
|
|
* @cont: set if the input is not complete - no final space char was found
|
|
* @buffer: holds the parsed user input
|
|
* @idx: user input length
|
|
* @size: buffer size
|
|
*/
|
|
struct trace_parser {
|
|
bool cont;
|
|
char *buffer;
|
|
unsigned idx;
|
|
unsigned size;
|
|
};
|
|
|
|
static inline bool trace_parser_loaded(struct trace_parser *parser)
|
|
{
|
|
return (parser->idx != 0);
|
|
}
|
|
|
|
static inline bool trace_parser_cont(struct trace_parser *parser)
|
|
{
|
|
return parser->cont;
|
|
}
|
|
|
|
static inline void trace_parser_clear(struct trace_parser *parser)
|
|
{
|
|
parser->cont = false;
|
|
parser->idx = 0;
|
|
}
|
|
|
|
extern int trace_parser_get_init(struct trace_parser *parser, int size);
|
|
extern void trace_parser_put(struct trace_parser *parser);
|
|
extern int trace_get_user(struct trace_parser *parser, const char __user *ubuf,
|
|
size_t cnt, loff_t *ppos);
|
|
|
|
/*
|
|
* Only create function graph options if function graph is configured.
|
|
*/
|
|
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
|
# define FGRAPH_FLAGS \
|
|
C(DISPLAY_GRAPH, "display-graph"),
|
|
#else
|
|
# define FGRAPH_FLAGS
|
|
#endif
|
|
|
|
#ifdef CONFIG_BRANCH_TRACER
|
|
# define BRANCH_FLAGS \
|
|
C(BRANCH, "branch"),
|
|
#else
|
|
# define BRANCH_FLAGS
|
|
#endif
|
|
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
# define FUNCTION_FLAGS \
|
|
C(FUNCTION, "function-trace"), \
|
|
C(FUNC_FORK, "function-fork"),
|
|
# define FUNCTION_DEFAULT_FLAGS TRACE_ITER_FUNCTION
|
|
#else
|
|
# define FUNCTION_FLAGS
|
|
# define FUNCTION_DEFAULT_FLAGS 0UL
|
|
# define TRACE_ITER_FUNC_FORK 0UL
|
|
#endif
|
|
|
|
#ifdef CONFIG_STACKTRACE
|
|
# define STACK_FLAGS \
|
|
C(STACKTRACE, "stacktrace"),
|
|
#else
|
|
# define STACK_FLAGS
|
|
#endif
|
|
|
|
/*
|
|
* trace_iterator_flags is an enumeration that defines bit
|
|
* positions into trace_flags that controls the output.
|
|
*
|
|
* NOTE: These bits must match the trace_options array in
|
|
* trace.c (this macro guarantees it).
|
|
*/
|
|
#define TRACE_FLAGS \
|
|
C(PRINT_PARENT, "print-parent"), \
|
|
C(SYM_OFFSET, "sym-offset"), \
|
|
C(SYM_ADDR, "sym-addr"), \
|
|
C(VERBOSE, "verbose"), \
|
|
C(RAW, "raw"), \
|
|
C(HEX, "hex"), \
|
|
C(BIN, "bin"), \
|
|
C(BLOCK, "block"), \
|
|
C(PRINTK, "trace_printk"), \
|
|
C(ANNOTATE, "annotate"), \
|
|
C(USERSTACKTRACE, "userstacktrace"), \
|
|
C(SYM_USEROBJ, "sym-userobj"), \
|
|
C(PRINTK_MSGONLY, "printk-msg-only"), \
|
|
C(CONTEXT_INFO, "context-info"), /* Print pid/cpu/time */ \
|
|
C(LATENCY_FMT, "latency-format"), \
|
|
C(RECORD_CMD, "record-cmd"), \
|
|
C(RECORD_TGID, "record-tgid"), \
|
|
C(OVERWRITE, "overwrite"), \
|
|
C(STOP_ON_FREE, "disable_on_free"), \
|
|
C(IRQ_INFO, "irq-info"), \
|
|
C(MARKERS, "markers"), \
|
|
C(EVENT_FORK, "event-fork"), \
|
|
FUNCTION_FLAGS \
|
|
FGRAPH_FLAGS \
|
|
STACK_FLAGS \
|
|
BRANCH_FLAGS
|
|
|
|
/*
|
|
* By defining C, we can make TRACE_FLAGS a list of bit names
|
|
* that will define the bits for the flag masks.
|
|
*/
|
|
#undef C
|
|
#define C(a, b) TRACE_ITER_##a##_BIT
|
|
|
|
enum trace_iterator_bits {
|
|
TRACE_FLAGS
|
|
/* Make sure we don't go more than we have bits for */
|
|
TRACE_ITER_LAST_BIT
|
|
};
|
|
|
|
/*
|
|
* By redefining C, we can make TRACE_FLAGS a list of masks that
|
|
* use the bits as defined above.
|
|
*/
|
|
#undef C
|
|
#define C(a, b) TRACE_ITER_##a = (1 << TRACE_ITER_##a##_BIT)
|
|
|
|
enum trace_iterator_flags { TRACE_FLAGS };
|
|
|
|
/*
|
|
* TRACE_ITER_SYM_MASK masks the options in trace_flags that
|
|
* control the output of kernel symbols.
|
|
*/
|
|
#define TRACE_ITER_SYM_MASK \
|
|
(TRACE_ITER_PRINT_PARENT|TRACE_ITER_SYM_OFFSET|TRACE_ITER_SYM_ADDR)
|
|
|
|
extern struct tracer nop_trace;
|
|
|
|
#ifdef CONFIG_BRANCH_TRACER
|
|
extern int enable_branch_tracing(struct trace_array *tr);
|
|
extern void disable_branch_tracing(void);
|
|
static inline int trace_branch_enable(struct trace_array *tr)
|
|
{
|
|
if (tr->trace_flags & TRACE_ITER_BRANCH)
|
|
return enable_branch_tracing(tr);
|
|
return 0;
|
|
}
|
|
static inline void trace_branch_disable(void)
|
|
{
|
|
/* due to races, always disable */
|
|
disable_branch_tracing();
|
|
}
|
|
#else
|
|
static inline int trace_branch_enable(struct trace_array *tr)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline void trace_branch_disable(void)
|
|
{
|
|
}
|
|
#endif /* CONFIG_BRANCH_TRACER */
|
|
|
|
/* set ring buffers to default size if not already done so */
|
|
int tracing_update_buffers(void);
|
|
|
|
struct ftrace_event_field {
|
|
struct list_head link;
|
|
const char *name;
|
|
const char *type;
|
|
int filter_type;
|
|
int offset;
|
|
int size;
|
|
int is_signed;
|
|
};
|
|
|
|
struct prog_entry;
|
|
|
|
struct event_filter {
|
|
struct prog_entry __rcu *prog;
|
|
char *filter_string;
|
|
};
|
|
|
|
struct event_subsystem {
|
|
struct list_head list;
|
|
const char *name;
|
|
struct event_filter *filter;
|
|
int ref_count;
|
|
};
|
|
|
|
struct trace_subsystem_dir {
|
|
struct list_head list;
|
|
struct event_subsystem *subsystem;
|
|
struct trace_array *tr;
|
|
struct dentry *entry;
|
|
int ref_count;
|
|
int nr_events;
|
|
};
|
|
|
|
extern int call_filter_check_discard(struct trace_event_call *call, void *rec,
|
|
struct ring_buffer *buffer,
|
|
struct ring_buffer_event *event);
|
|
|
|
void trace_buffer_unlock_commit_regs(struct trace_array *tr,
|
|
struct ring_buffer *buffer,
|
|
struct ring_buffer_event *event,
|
|
unsigned long flags, int pc,
|
|
struct pt_regs *regs);
|
|
|
|
static inline void trace_buffer_unlock_commit(struct trace_array *tr,
|
|
struct ring_buffer *buffer,
|
|
struct ring_buffer_event *event,
|
|
unsigned long flags, int pc)
|
|
{
|
|
trace_buffer_unlock_commit_regs(tr, buffer, event, flags, pc, NULL);
|
|
}
|
|
|
|
DECLARE_PER_CPU(struct ring_buffer_event *, trace_buffered_event);
|
|
DECLARE_PER_CPU(int, trace_buffered_event_cnt);
|
|
void trace_buffered_event_disable(void);
|
|
void trace_buffered_event_enable(void);
|
|
|
|
static inline void
|
|
__trace_event_discard_commit(struct ring_buffer *buffer,
|
|
struct ring_buffer_event *event)
|
|
{
|
|
if (this_cpu_read(trace_buffered_event) == event) {
|
|
/* Simply release the temp buffer */
|
|
this_cpu_dec(trace_buffered_event_cnt);
|
|
return;
|
|
}
|
|
ring_buffer_discard_commit(buffer, event);
|
|
}
|
|
|
|
/*
|
|
* Helper function for event_trigger_unlock_commit{_regs}().
|
|
* If there are event triggers attached to this event that requires
|
|
* filtering against its fields, then they wil be called as the
|
|
* entry already holds the field information of the current event.
|
|
*
|
|
* It also checks if the event should be discarded or not.
|
|
* It is to be discarded if the event is soft disabled and the
|
|
* event was only recorded to process triggers, or if the event
|
|
* filter is active and this event did not match the filters.
|
|
*
|
|
* Returns true if the event is discarded, false otherwise.
|
|
*/
|
|
static inline bool
|
|
__event_trigger_test_discard(struct trace_event_file *file,
|
|
struct ring_buffer *buffer,
|
|
struct ring_buffer_event *event,
|
|
void *entry,
|
|
enum event_trigger_type *tt)
|
|
{
|
|
unsigned long eflags = file->flags;
|
|
|
|
if (eflags & EVENT_FILE_FL_TRIGGER_COND)
|
|
*tt = event_triggers_call(file, entry, event);
|
|
|
|
if (likely(!(file->flags & (EVENT_FILE_FL_SOFT_DISABLED |
|
|
EVENT_FILE_FL_FILTERED |
|
|
EVENT_FILE_FL_PID_FILTER))))
|
|
return false;
|
|
|
|
if (file->flags & EVENT_FILE_FL_SOFT_DISABLED)
|
|
goto discard;
|
|
|
|
if (file->flags & EVENT_FILE_FL_FILTERED &&
|
|
!filter_match_preds(file->filter, entry))
|
|
goto discard;
|
|
|
|
if ((file->flags & EVENT_FILE_FL_PID_FILTER) &&
|
|
trace_event_ignore_this_pid(file))
|
|
goto discard;
|
|
|
|
return false;
|
|
discard:
|
|
__trace_event_discard_commit(buffer, event);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* event_trigger_unlock_commit - handle triggers and finish event commit
|
|
* @file: The file pointer assoctiated to the event
|
|
* @buffer: The ring buffer that the event is being written to
|
|
* @event: The event meta data in the ring buffer
|
|
* @entry: The event itself
|
|
* @irq_flags: The state of the interrupts at the start of the event
|
|
* @pc: The state of the preempt count at the start of the event.
|
|
* @len: The length of the payload data required for stm logging.
|
|
*
|
|
* This is a helper function to handle triggers that require data
|
|
* from the event itself. It also tests the event against filters and
|
|
* if the event is soft disabled and should be discarded.
|
|
*/
|
|
#ifdef CONFIG_CORESIGHT_QGKI
|
|
static inline void
|
|
event_trigger_unlock_commit(struct trace_event_file *file,
|
|
struct ring_buffer *buffer,
|
|
struct ring_buffer_event *event,
|
|
void *entry, unsigned long irq_flags, int pc,
|
|
unsigned long len)
|
|
{
|
|
enum event_trigger_type tt = ETT_NONE;
|
|
|
|
if (!__event_trigger_test_discard(file, buffer, event, entry, &tt)) {
|
|
if (len)
|
|
stm_log(OST_ENTITY_FTRACE_EVENTS, entry, len);
|
|
|
|
trace_buffer_unlock_commit(file->tr, buffer, event,
|
|
irq_flags, pc);
|
|
}
|
|
|
|
if (tt)
|
|
event_triggers_post_call(file, tt);
|
|
}
|
|
#else
|
|
static inline void
|
|
event_trigger_unlock_commit(struct trace_event_file *file,
|
|
struct ring_buffer *buffer,
|
|
struct ring_buffer_event *event,
|
|
void *entry, unsigned long irq_flags, int pc)
|
|
{
|
|
enum event_trigger_type tt = ETT_NONE;
|
|
|
|
if (!__event_trigger_test_discard(file, buffer, event, entry, &tt))
|
|
trace_buffer_unlock_commit(file->tr, buffer, event, irq_flags, pc);
|
|
|
|
if (tt)
|
|
event_triggers_post_call(file, tt);
|
|
}
|
|
#endif
|
|
/**
|
|
* event_trigger_unlock_commit_regs - handle triggers and finish event commit
|
|
* @file: The file pointer assoctiated to the event
|
|
* @buffer: The ring buffer that the event is being written to
|
|
* @event: The event meta data in the ring buffer
|
|
* @entry: The event itself
|
|
* @irq_flags: The state of the interrupts at the start of the event
|
|
* @pc: The state of the preempt count at the start of the event.
|
|
*
|
|
* This is a helper function to handle triggers that require data
|
|
* from the event itself. It also tests the event against filters and
|
|
* if the event is soft disabled and should be discarded.
|
|
*
|
|
* Same as event_trigger_unlock_commit() but calls
|
|
* trace_buffer_unlock_commit_regs() instead of trace_buffer_unlock_commit().
|
|
*/
|
|
static inline void
|
|
event_trigger_unlock_commit_regs(struct trace_event_file *file,
|
|
struct ring_buffer *buffer,
|
|
struct ring_buffer_event *event,
|
|
void *entry, unsigned long irq_flags, int pc,
|
|
struct pt_regs *regs)
|
|
{
|
|
enum event_trigger_type tt = ETT_NONE;
|
|
|
|
if (!__event_trigger_test_discard(file, buffer, event, entry, &tt))
|
|
trace_buffer_unlock_commit_regs(file->tr, buffer, event,
|
|
irq_flags, pc, regs);
|
|
|
|
if (tt)
|
|
event_triggers_post_call(file, tt);
|
|
}
|
|
|
|
#define FILTER_PRED_INVALID ((unsigned short)-1)
|
|
#define FILTER_PRED_IS_RIGHT (1 << 15)
|
|
#define FILTER_PRED_FOLD (1 << 15)
|
|
|
|
/*
|
|
* The max preds is the size of unsigned short with
|
|
* two flags at the MSBs. One bit is used for both the IS_RIGHT
|
|
* and FOLD flags. The other is reserved.
|
|
*
|
|
* 2^14 preds is way more than enough.
|
|
*/
|
|
#define MAX_FILTER_PRED 16384
|
|
|
|
struct filter_pred;
|
|
struct regex;
|
|
|
|
typedef int (*filter_pred_fn_t) (struct filter_pred *pred, void *event);
|
|
|
|
typedef int (*regex_match_func)(char *str, struct regex *r, int len);
|
|
|
|
enum regex_type {
|
|
MATCH_FULL = 0,
|
|
MATCH_FRONT_ONLY,
|
|
MATCH_MIDDLE_ONLY,
|
|
MATCH_END_ONLY,
|
|
MATCH_GLOB,
|
|
MATCH_INDEX,
|
|
};
|
|
|
|
struct regex {
|
|
char pattern[MAX_FILTER_STR_VAL];
|
|
int len;
|
|
int field_len;
|
|
regex_match_func match;
|
|
};
|
|
|
|
struct filter_pred {
|
|
filter_pred_fn_t fn;
|
|
u64 val;
|
|
struct regex regex;
|
|
unsigned short *ops;
|
|
struct ftrace_event_field *field;
|
|
int offset;
|
|
int not;
|
|
int op;
|
|
};
|
|
|
|
static inline bool is_string_field(struct ftrace_event_field *field)
|
|
{
|
|
return field->filter_type == FILTER_DYN_STRING ||
|
|
field->filter_type == FILTER_STATIC_STRING ||
|
|
field->filter_type == FILTER_PTR_STRING ||
|
|
field->filter_type == FILTER_COMM;
|
|
}
|
|
|
|
static inline bool is_function_field(struct ftrace_event_field *field)
|
|
{
|
|
return field->filter_type == FILTER_TRACE_FN;
|
|
}
|
|
|
|
extern enum regex_type
|
|
filter_parse_regex(char *buff, int len, char **search, int *not);
|
|
extern void print_event_filter(struct trace_event_file *file,
|
|
struct trace_seq *s);
|
|
extern int apply_event_filter(struct trace_event_file *file,
|
|
char *filter_string);
|
|
extern int apply_subsystem_event_filter(struct trace_subsystem_dir *dir,
|
|
char *filter_string);
|
|
extern void print_subsystem_event_filter(struct event_subsystem *system,
|
|
struct trace_seq *s);
|
|
extern int filter_assign_type(const char *type);
|
|
extern int create_event_filter(struct trace_array *tr,
|
|
struct trace_event_call *call,
|
|
char *filter_str, bool set_str,
|
|
struct event_filter **filterp);
|
|
extern void free_event_filter(struct event_filter *filter);
|
|
|
|
struct ftrace_event_field *
|
|
trace_find_event_field(struct trace_event_call *call, char *name);
|
|
|
|
extern void trace_event_enable_cmd_record(bool enable);
|
|
extern void trace_event_enable_tgid_record(bool enable);
|
|
|
|
extern int event_trace_init(void);
|
|
extern int init_events(void);
|
|
extern int event_trace_add_tracer(struct dentry *parent, struct trace_array *tr);
|
|
extern int event_trace_del_tracer(struct trace_array *tr);
|
|
|
|
extern struct trace_event_file *__find_event_file(struct trace_array *tr,
|
|
const char *system,
|
|
const char *event);
|
|
extern struct trace_event_file *find_event_file(struct trace_array *tr,
|
|
const char *system,
|
|
const char *event);
|
|
|
|
static inline void *event_file_data(struct file *filp)
|
|
{
|
|
return READ_ONCE(file_inode(filp)->i_private);
|
|
}
|
|
|
|
extern struct mutex event_mutex;
|
|
extern struct list_head ftrace_events;
|
|
|
|
extern const struct file_operations event_trigger_fops;
|
|
extern const struct file_operations event_hist_fops;
|
|
|
|
#ifdef CONFIG_HIST_TRIGGERS
|
|
extern int register_trigger_hist_cmd(void);
|
|
extern int register_trigger_hist_enable_disable_cmds(void);
|
|
#else
|
|
static inline int register_trigger_hist_cmd(void) { return 0; }
|
|
static inline int register_trigger_hist_enable_disable_cmds(void) { return 0; }
|
|
#endif
|
|
|
|
extern int register_trigger_cmds(void);
|
|
extern void clear_event_triggers(struct trace_array *tr);
|
|
|
|
struct event_trigger_data {
|
|
unsigned long count;
|
|
int ref;
|
|
struct event_trigger_ops *ops;
|
|
struct event_command *cmd_ops;
|
|
struct event_filter __rcu *filter;
|
|
char *filter_str;
|
|
void *private_data;
|
|
bool paused;
|
|
bool paused_tmp;
|
|
struct list_head list;
|
|
char *name;
|
|
struct list_head named_list;
|
|
struct event_trigger_data *named_data;
|
|
};
|
|
|
|
/* Avoid typos */
|
|
#define ENABLE_EVENT_STR "enable_event"
|
|
#define DISABLE_EVENT_STR "disable_event"
|
|
#define ENABLE_HIST_STR "enable_hist"
|
|
#define DISABLE_HIST_STR "disable_hist"
|
|
|
|
struct enable_trigger_data {
|
|
struct trace_event_file *file;
|
|
bool enable;
|
|
bool hist;
|
|
};
|
|
|
|
extern int event_enable_trigger_print(struct seq_file *m,
|
|
struct event_trigger_ops *ops,
|
|
struct event_trigger_data *data);
|
|
extern void event_enable_trigger_free(struct event_trigger_ops *ops,
|
|
struct event_trigger_data *data);
|
|
extern int event_enable_trigger_func(struct event_command *cmd_ops,
|
|
struct trace_event_file *file,
|
|
char *glob, char *cmd, char *param);
|
|
extern int event_enable_register_trigger(char *glob,
|
|
struct event_trigger_ops *ops,
|
|
struct event_trigger_data *data,
|
|
struct trace_event_file *file);
|
|
extern void event_enable_unregister_trigger(char *glob,
|
|
struct event_trigger_ops *ops,
|
|
struct event_trigger_data *test,
|
|
struct trace_event_file *file);
|
|
extern void trigger_data_free(struct event_trigger_data *data);
|
|
extern int event_trigger_init(struct event_trigger_ops *ops,
|
|
struct event_trigger_data *data);
|
|
extern int trace_event_trigger_enable_disable(struct trace_event_file *file,
|
|
int trigger_enable);
|
|
extern void update_cond_flag(struct trace_event_file *file);
|
|
extern int set_trigger_filter(char *filter_str,
|
|
struct event_trigger_data *trigger_data,
|
|
struct trace_event_file *file);
|
|
extern struct event_trigger_data *find_named_trigger(const char *name);
|
|
extern bool is_named_trigger(struct event_trigger_data *test);
|
|
extern int save_named_trigger(const char *name,
|
|
struct event_trigger_data *data);
|
|
extern void del_named_trigger(struct event_trigger_data *data);
|
|
extern void pause_named_trigger(struct event_trigger_data *data);
|
|
extern void unpause_named_trigger(struct event_trigger_data *data);
|
|
extern void set_named_trigger_data(struct event_trigger_data *data,
|
|
struct event_trigger_data *named_data);
|
|
extern struct event_trigger_data *
|
|
get_named_trigger_data(struct event_trigger_data *data);
|
|
extern int register_event_command(struct event_command *cmd);
|
|
extern int unregister_event_command(struct event_command *cmd);
|
|
extern int register_trigger_hist_enable_disable_cmds(void);
|
|
|
|
/**
|
|
* struct event_trigger_ops - callbacks for trace event triggers
|
|
*
|
|
* The methods in this structure provide per-event trigger hooks for
|
|
* various trigger operations.
|
|
*
|
|
* All the methods below, except for @init() and @free(), must be
|
|
* implemented.
|
|
*
|
|
* @func: The trigger 'probe' function called when the triggering
|
|
* event occurs. The data passed into this callback is the data
|
|
* that was supplied to the event_command @reg() function that
|
|
* registered the trigger (see struct event_command) along with
|
|
* the trace record, rec.
|
|
*
|
|
* @init: An optional initialization function called for the trigger
|
|
* when the trigger is registered (via the event_command reg()
|
|
* function). This can be used to perform per-trigger
|
|
* initialization such as incrementing a per-trigger reference
|
|
* count, for instance. This is usually implemented by the
|
|
* generic utility function @event_trigger_init() (see
|
|
* trace_event_triggers.c).
|
|
*
|
|
* @free: An optional de-initialization function called for the
|
|
* trigger when the trigger is unregistered (via the
|
|
* event_command @reg() function). This can be used to perform
|
|
* per-trigger de-initialization such as decrementing a
|
|
* per-trigger reference count and freeing corresponding trigger
|
|
* data, for instance. This is usually implemented by the
|
|
* generic utility function @event_trigger_free() (see
|
|
* trace_event_triggers.c).
|
|
*
|
|
* @print: The callback function invoked to have the trigger print
|
|
* itself. This is usually implemented by a wrapper function
|
|
* that calls the generic utility function @event_trigger_print()
|
|
* (see trace_event_triggers.c).
|
|
*/
|
|
struct event_trigger_ops {
|
|
void (*func)(struct event_trigger_data *data,
|
|
void *rec,
|
|
struct ring_buffer_event *rbe);
|
|
int (*init)(struct event_trigger_ops *ops,
|
|
struct event_trigger_data *data);
|
|
void (*free)(struct event_trigger_ops *ops,
|
|
struct event_trigger_data *data);
|
|
int (*print)(struct seq_file *m,
|
|
struct event_trigger_ops *ops,
|
|
struct event_trigger_data *data);
|
|
};
|
|
|
|
/**
|
|
* struct event_command - callbacks and data members for event commands
|
|
*
|
|
* Event commands are invoked by users by writing the command name
|
|
* into the 'trigger' file associated with a trace event. The
|
|
* parameters associated with a specific invocation of an event
|
|
* command are used to create an event trigger instance, which is
|
|
* added to the list of trigger instances associated with that trace
|
|
* event. When the event is hit, the set of triggers associated with
|
|
* that event is invoked.
|
|
*
|
|
* The data members in this structure provide per-event command data
|
|
* for various event commands.
|
|
*
|
|
* All the data members below, except for @post_trigger, must be set
|
|
* for each event command.
|
|
*
|
|
* @name: The unique name that identifies the event command. This is
|
|
* the name used when setting triggers via trigger files.
|
|
*
|
|
* @trigger_type: A unique id that identifies the event command
|
|
* 'type'. This value has two purposes, the first to ensure that
|
|
* only one trigger of the same type can be set at a given time
|
|
* for a particular event e.g. it doesn't make sense to have both
|
|
* a traceon and traceoff trigger attached to a single event at
|
|
* the same time, so traceon and traceoff have the same type
|
|
* though they have different names. The @trigger_type value is
|
|
* also used as a bit value for deferring the actual trigger
|
|
* action until after the current event is finished. Some
|
|
* commands need to do this if they themselves log to the trace
|
|
* buffer (see the @post_trigger() member below). @trigger_type
|
|
* values are defined by adding new values to the trigger_type
|
|
* enum in include/linux/trace_events.h.
|
|
*
|
|
* @flags: See the enum event_command_flags below.
|
|
*
|
|
* All the methods below, except for @set_filter() and @unreg_all(),
|
|
* must be implemented.
|
|
*
|
|
* @func: The callback function responsible for parsing and
|
|
* registering the trigger written to the 'trigger' file by the
|
|
* user. It allocates the trigger instance and registers it with
|
|
* the appropriate trace event. It makes use of the other
|
|
* event_command callback functions to orchestrate this, and is
|
|
* usually implemented by the generic utility function
|
|
* @event_trigger_callback() (see trace_event_triggers.c).
|
|
*
|
|
* @reg: Adds the trigger to the list of triggers associated with the
|
|
* event, and enables the event trigger itself, after
|
|
* initializing it (via the event_trigger_ops @init() function).
|
|
* This is also where commands can use the @trigger_type value to
|
|
* make the decision as to whether or not multiple instances of
|
|
* the trigger should be allowed. This is usually implemented by
|
|
* the generic utility function @register_trigger() (see
|
|
* trace_event_triggers.c).
|
|
*
|
|
* @unreg: Removes the trigger from the list of triggers associated
|
|
* with the event, and disables the event trigger itself, after
|
|
* initializing it (via the event_trigger_ops @free() function).
|
|
* This is usually implemented by the generic utility function
|
|
* @unregister_trigger() (see trace_event_triggers.c).
|
|
*
|
|
* @unreg_all: An optional function called to remove all the triggers
|
|
* from the list of triggers associated with the event. Called
|
|
* when a trigger file is opened in truncate mode.
|
|
*
|
|
* @set_filter: An optional function called to parse and set a filter
|
|
* for the trigger. If no @set_filter() method is set for the
|
|
* event command, filters set by the user for the command will be
|
|
* ignored. This is usually implemented by the generic utility
|
|
* function @set_trigger_filter() (see trace_event_triggers.c).
|
|
*
|
|
* @get_trigger_ops: The callback function invoked to retrieve the
|
|
* event_trigger_ops implementation associated with the command.
|
|
*/
|
|
struct event_command {
|
|
struct list_head list;
|
|
char *name;
|
|
enum event_trigger_type trigger_type;
|
|
int flags;
|
|
int (*func)(struct event_command *cmd_ops,
|
|
struct trace_event_file *file,
|
|
char *glob, char *cmd, char *params);
|
|
int (*reg)(char *glob,
|
|
struct event_trigger_ops *ops,
|
|
struct event_trigger_data *data,
|
|
struct trace_event_file *file);
|
|
void (*unreg)(char *glob,
|
|
struct event_trigger_ops *ops,
|
|
struct event_trigger_data *data,
|
|
struct trace_event_file *file);
|
|
void (*unreg_all)(struct trace_event_file *file);
|
|
int (*set_filter)(char *filter_str,
|
|
struct event_trigger_data *data,
|
|
struct trace_event_file *file);
|
|
struct event_trigger_ops *(*get_trigger_ops)(char *cmd, char *param);
|
|
};
|
|
|
|
/**
|
|
* enum event_command_flags - flags for struct event_command
|
|
*
|
|
* @POST_TRIGGER: A flag that says whether or not this command needs
|
|
* to have its action delayed until after the current event has
|
|
* been closed. Some triggers need to avoid being invoked while
|
|
* an event is currently in the process of being logged, since
|
|
* the trigger may itself log data into the trace buffer. Thus
|
|
* we make sure the current event is committed before invoking
|
|
* those triggers. To do that, the trigger invocation is split
|
|
* in two - the first part checks the filter using the current
|
|
* trace record; if a command has the @post_trigger flag set, it
|
|
* sets a bit for itself in the return value, otherwise it
|
|
* directly invokes the trigger. Once all commands have been
|
|
* either invoked or set their return flag, the current record is
|
|
* either committed or discarded. At that point, if any commands
|
|
* have deferred their triggers, those commands are finally
|
|
* invoked following the close of the current event. In other
|
|
* words, if the event_trigger_ops @func() probe implementation
|
|
* itself logs to the trace buffer, this flag should be set,
|
|
* otherwise it can be left unspecified.
|
|
*
|
|
* @NEEDS_REC: A flag that says whether or not this command needs
|
|
* access to the trace record in order to perform its function,
|
|
* regardless of whether or not it has a filter associated with
|
|
* it (filters make a trigger require access to the trace record
|
|
* but are not always present).
|
|
*/
|
|
enum event_command_flags {
|
|
EVENT_CMD_FL_POST_TRIGGER = 1,
|
|
EVENT_CMD_FL_NEEDS_REC = 2,
|
|
};
|
|
|
|
static inline bool event_command_post_trigger(struct event_command *cmd_ops)
|
|
{
|
|
return cmd_ops->flags & EVENT_CMD_FL_POST_TRIGGER;
|
|
}
|
|
|
|
static inline bool event_command_needs_rec(struct event_command *cmd_ops)
|
|
{
|
|
return cmd_ops->flags & EVENT_CMD_FL_NEEDS_REC;
|
|
}
|
|
|
|
extern int trace_event_enable_disable(struct trace_event_file *file,
|
|
int enable, int soft_disable);
|
|
extern int tracing_alloc_snapshot(void);
|
|
extern void tracing_snapshot_cond(struct trace_array *tr, void *cond_data);
|
|
extern int tracing_snapshot_cond_enable(struct trace_array *tr, void *cond_data, cond_update_fn_t update);
|
|
|
|
extern int tracing_snapshot_cond_disable(struct trace_array *tr);
|
|
extern void *tracing_cond_snapshot_data(struct trace_array *tr);
|
|
|
|
extern const char *__start___trace_bprintk_fmt[];
|
|
extern const char *__stop___trace_bprintk_fmt[];
|
|
|
|
extern const char *__start___tracepoint_str[];
|
|
extern const char *__stop___tracepoint_str[];
|
|
|
|
void trace_printk_control(bool enabled);
|
|
void trace_printk_init_buffers(void);
|
|
void trace_printk_start_comm(void);
|
|
int trace_keep_overwrite(struct tracer *tracer, u32 mask, int set);
|
|
int set_tracer_flag(struct trace_array *tr, unsigned int mask, int enabled);
|
|
|
|
#define MAX_EVENT_NAME_LEN 64
|
|
|
|
extern int trace_run_command(const char *buf, int (*createfn)(int, char**));
|
|
extern ssize_t trace_parse_run_command(struct file *file,
|
|
const char __user *buffer, size_t count, loff_t *ppos,
|
|
int (*createfn)(int, char**));
|
|
|
|
extern unsigned int err_pos(char *cmd, const char *str);
|
|
extern void tracing_log_err(struct trace_array *tr,
|
|
const char *loc, const char *cmd,
|
|
const char **errs, u8 type, u8 pos);
|
|
|
|
/*
|
|
* Normal trace_printk() and friends allocates special buffers
|
|
* to do the manipulation, as well as saves the print formats
|
|
* into sections to display. But the trace infrastructure wants
|
|
* to use these without the added overhead at the price of being
|
|
* a bit slower (used mainly for warnings, where we don't care
|
|
* about performance). The internal_trace_puts() is for such
|
|
* a purpose.
|
|
*/
|
|
#define internal_trace_puts(str) __trace_puts(_THIS_IP_, str, strlen(str))
|
|
|
|
#undef FTRACE_ENTRY
|
|
#define FTRACE_ENTRY(call, struct_name, id, tstruct, print, filter) \
|
|
extern struct trace_event_call \
|
|
__aligned(4) event_##call;
|
|
#undef FTRACE_ENTRY_DUP
|
|
#define FTRACE_ENTRY_DUP(call, struct_name, id, tstruct, print, filter) \
|
|
FTRACE_ENTRY(call, struct_name, id, PARAMS(tstruct), PARAMS(print), \
|
|
filter)
|
|
#undef FTRACE_ENTRY_PACKED
|
|
#define FTRACE_ENTRY_PACKED(call, struct_name, id, tstruct, print, filter) \
|
|
FTRACE_ENTRY(call, struct_name, id, PARAMS(tstruct), PARAMS(print), \
|
|
filter)
|
|
|
|
#include "trace_entries.h"
|
|
|
|
#if defined(CONFIG_PERF_EVENTS) && defined(CONFIG_FUNCTION_TRACER)
|
|
int perf_ftrace_event_register(struct trace_event_call *call,
|
|
enum trace_reg type, void *data);
|
|
#else
|
|
#define perf_ftrace_event_register NULL
|
|
#endif
|
|
|
|
#ifdef CONFIG_FTRACE_SYSCALLS
|
|
void init_ftrace_syscalls(void);
|
|
const char *get_syscall_name(int syscall);
|
|
#else
|
|
static inline void init_ftrace_syscalls(void) { }
|
|
static inline const char *get_syscall_name(int syscall)
|
|
{
|
|
return NULL;
|
|
}
|
|
#endif
|
|
|
|
#ifdef CONFIG_EVENT_TRACING
|
|
void trace_event_init(void);
|
|
void trace_event_eval_update(struct trace_eval_map **map, int len);
|
|
#else
|
|
static inline void __init trace_event_init(void) { }
|
|
static inline void trace_event_eval_update(struct trace_eval_map **map, int len) { }
|
|
#endif
|
|
|
|
#ifdef CONFIG_TRACER_SNAPSHOT
|
|
void tracing_snapshot_instance(struct trace_array *tr);
|
|
int tracing_alloc_snapshot_instance(struct trace_array *tr);
|
|
#else
|
|
static inline void tracing_snapshot_instance(struct trace_array *tr) { }
|
|
static inline int tracing_alloc_snapshot_instance(struct trace_array *tr)
|
|
{
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
#ifdef CONFIG_PREEMPT_TRACER
|
|
void tracer_preempt_on(unsigned long a0, unsigned long a1);
|
|
void tracer_preempt_off(unsigned long a0, unsigned long a1);
|
|
#else
|
|
static inline void tracer_preempt_on(unsigned long a0, unsigned long a1) { }
|
|
static inline void tracer_preempt_off(unsigned long a0, unsigned long a1) { }
|
|
#endif
|
|
#ifdef CONFIG_IRQSOFF_TRACER
|
|
void tracer_hardirqs_on(unsigned long a0, unsigned long a1);
|
|
void tracer_hardirqs_off(unsigned long a0, unsigned long a1);
|
|
#else
|
|
static inline void tracer_hardirqs_on(unsigned long a0, unsigned long a1) { }
|
|
static inline void tracer_hardirqs_off(unsigned long a0, unsigned long a1) { }
|
|
#endif
|
|
|
|
extern struct trace_iterator *tracepoint_print_iter;
|
|
|
|
/*
|
|
* Reset the state of the trace_iterator so that it can read consumed data.
|
|
* Normally, the trace_iterator is used for reading the data when it is not
|
|
* consumed, and must retain state.
|
|
*/
|
|
static __always_inline void trace_iterator_reset(struct trace_iterator *iter)
|
|
{
|
|
const size_t offset = offsetof(struct trace_iterator, seq);
|
|
|
|
/*
|
|
* Keep gcc from complaining about overwriting more than just one
|
|
* member in the structure.
|
|
*/
|
|
memset((char *)iter + offset, 0, sizeof(struct trace_iterator) - offset);
|
|
|
|
iter->pos = -1;
|
|
}
|
|
|
|
#endif /* _LINUX_KERNEL_TRACE_H */
|