4ac13bd161
* origin_4.19/tmp-0567d2f:
Linux 4.19.9
HID: quirks: fix RetroUSB.com devices
mac80211: ignore NullFunc frames in the duplicate detection
mac80211: fix reordering of buffered broadcast packets
mac80211: ignore tx status for PS stations in ieee80211_tx_status_ext
mac80211: Clear beacon_int in ieee80211_do_stop
mac80211: fix GFP_KERNEL under tasklet context
mac80211_hwsim: Timer should be initialized before device registered
cfg80211: Fix busy loop regression in ieee80211_ie_split_ric()
libnvdimm, pfn: Pad pfn namespaces relative to other regions
kgdboc: fix KASAN global-out-of-bounds bug in param_set_kgdboc_var()
gnss: sirf: fix activation retry handling
tty: do not set TTY_IO_ERROR flag if console port
tty: serial: 8250_mtk: always resume the device in probe.
Drivers: hv: vmbus: Offload the handling of channels to two workqueues
x86/efi: Allocate e820 buffer before calling efi_exit_boot_service
kprobes/x86: Fix instruction patching corruption when copying more than one RIP-relative instruction
drm/i915: Downgrade Gen9 Plane WM latency error
drm/amdgpu/gmc8: always load MC firmware in the driver
drm/amdgpu/gmc8: update MC firmware for polaris
drm/msm: Move fence put to where failure occurs
drm/lease: Send a distinct uevent
drm/amdgpu: update mc firmware image for polaris12 variants
crypto: do not free algorithm before using
Revert commit ef9209b642
"staging: rtl8723bs: Fix indenting errors and an off-by-one mistake in core/rtw_mlme_ext.c"
staging: rtl8712: Fix possible buffer overrun
cifs: Fix separator when building path from dentry
Revert "x86/e820: put !E820_TYPE_RAM regions into memblock.reserved"
arm64: dts: rockchip: remove vdd_log from rock960 to fix a stability issues
xhci: Prevent U1/U2 link pm states if exit latency is too long
xhci: workaround CSS timeout on AMD SNPS 3.0 xHC
ARM: 8806/1: kprobes: Fix false positive with FORTIFY_SOURCE
dmaengine: cppi41: delete channel from pending list when stop channel
dmaengine: imx-sdma: use GFP_NOWAIT for dma descriptor allocations
dmaengine: imx-sdma: implement channel termination via worker
Revert "dmaengine: imx-sdma: alloclate bd memory from dma pool"
Revert "dmaengine: imx-sdma: Use GFP_NOWAIT for dma allocations"
dmaengine: dw: Fix FIFO size for Intel Merrifield
SUNRPC: Fix leak of krb5p encode pages
arm64: hibernate: Avoid sending cross-calling with interrupts disabled
vhost/vsock: fix use-after-free in network stack callers
virtio/s390: fix race in ccw_io_helper()
virtio/s390: avoid race on vcdev->config
parisc: Enable -ffunction-sections for modules on 32-bit kernel
Revert "mfd: cros_ec: Use devm_kzalloc for private data"
media: dvb-pll: don't re-validate tuner frequencies
media: dvb-pll: fix tuner frequency ranges
media: vicodec: fix memchr() kernel oops
media: gspca: fix frame overflow error
ALSA: hda/realtek: Fix mic issue on Acer AIO Veriton Z4860G/Z6860G
ALSA: hda/realtek: Fix mic issue on Acer AIO Veriton Z4660G
ALSA: hda/realtek - Add support for Acer Aspire C24-860 headset mic
ALSA: hda/realtek: ALC286 mic and headset-mode fixups for Acer Aspire U27-880
ALSA: hda/realtek - Fix speaker output regression on Thinkpad T570
ALSA: pcm: Fix interval evaluation with openmin/max
ALSA: pcm: Call snd_pcm_unlink() conditionally at closing
ALSA: pcm: Fix starvation on down_write_nonblock()
ALSA: hda: Add support for AMD Stoney Ridge
ALSA: usb-audio: Fix UAF decrement if card has no live interfaces in card.c
ALSA: usb-audio: Add SMSL D1 to quirks for native DSD support
USB: serial: console: fix reported terminal settings
USB: check usb_get_extra_descriptor for proper size
usb: appledisplay: Add 27" Apple Cinema Display
usb: quirk: add no-LPM quirk on SanDisk Ultra Flair device
net: amd: add missing of_node_put()
team: no need to do team_notify_peers or team_mcast_rejoin when disabling port
ibmvnic: Update driver queues after change in ring size support
ibmvnic: Fix RX queue buffer cleanup
flexfiles: use per-mirror specified stateid for IO
NFSv4.2 copy do not allocate memory under the lock
iommu/vt-d: Use memunmap to free memremap
net: faraday: ftmac100: remove netif_running(netdev) check before disabling interrupts
riscv: fix warning in arch/riscv/include/asm/module.h
net/ibmnvic: Fix deadlock problem in reset
qed: Fix QM getters to always return a valid pq
qed: Fix bitmap_weight() check
NFSv4: Fix a NFSv4 state manager deadlock
net: ena: fix crash during failed resume from hibernation
mtd: spi-nor: Fix Cadence QSPI page fault kernel panic
HID: multitouch: Add pointstick support for Cirque Touchpad
Revert "HID: uhid: use strlcpy() instead of strncpy()"
cpufreq: ti-cpufreq: Only register platform_device when supported
mtd: rawnand: qcom: Namespace prefix some commands
tc-testing: tdc.py: Guard against lack of returncode in executed command
tc-testing: tdc.py: ignore errors when decoding stdout/stderr
gpio: mockup: fix indicated direction
gpio: pxa: fix legacy non pinctrl aware builds again
drivers/net/ethernet/qlogic/qed/qed_rdma.h: fix typo
net/mlx4: Fix UBSAN warning of signed integer overflow
net/mlx4_core: Fix uninitialized variable compilation warning
net/mlx4_core: Zero out lkey field in SW2HW_MPT fw command
drm/amd/display: Support amdgpu "max bpc" connector property (v2)
drm/amdgpu: Add amdgpu "max bpc" connector property (v2)
bnxt_en: Fix filling time in bnxt_fill_coredump_record()
nvme-fc: resolve io failures during connect
s390/ism: clear dmbe_mask bit before SMC IRQ handling
Revert "usb: gadget: ffs: Fix BUG when userland exits with submitted AIO transfers"
usb: dwc2: pci: Fix an error code in probe
qed: Fix reading wrong value in loop condition
qed: Fix rdma_info structure allocation
qed: Fix overriding offload_tc by protocols without APP TLV
qed: Fix PTT leak in qed_drain()
bnx2x: Assign unique DMAE channel number for FW DMAE transactions.
amd/iommu: Fix Guest Virtual APIC Log Tail Address Register
batman-adv: Expand merged fragment buffer for full packet
batman-adv: Use explicit tvlv padding for ELP packets
HID: input: Ignore battery reported by Symbol DS4308
test_firmware: fix error return getting clobbered
can: rcar_can: Fix erroneous registration
can: ucan: remove set but not used variable 'udev'
scsi: ufs: Fix hynix ufs bug with quirk on hi36xx SoC
iommu/ipmmu-vmsa: Fix crash on early domain free
mt76: fix building without CONFIG_LEDS_CLASS
brcmutil: really fix decoding channel info for 160 MHz bandwidth
iommu/vt-d: Fix NULL pointer dereference in prq_event_thread()
media: ipu3-cio2: Unregister device nodes first, then release resources
media: omap3isp: Unregister media device as first
media: cec: check for non-OK/NACK conditions while claiming a LA
media: vicodec: lower minimum height to 360
ANDROID: cuttlefish_defconfig: Enable VIRT_WIFI
FROMGIT: mac80211-next: rtnetlink wifi simulation device
Linux 4.19.8
blk-mq: punt failed direct issue to dispatch list
tipc: use destination length for copy string
arc: [devboards] Add support of NFSv3 ACL
ARC: change defconfig defaults to ARCv2
btrfs: tree-checker: Don't check max block group size as current max chunk size limit is unreliable
Input: elan_i2c - add support for ELAN0621 touchpad
Input: elan_i2c - add ACPI ID for Lenovo IdeaPad 330-15ARR
Input: elan_i2c - add ELAN0620 to the ACPI table
Input: cros_ec_keyb - fix button/switch capability reports
Input: matrix_keypad - check for errors from of_get_named_gpio()
Input: synaptics - add PNP ID for ThinkPad P50 to SMBus
Input: xpad - quirk all PDP Xbox One gamepads
scsi: lpfc: fix block guard enablement on SLI3 adapters
i40e: Fix deletion of MAC filters
selinux: add support for RTM_NEWCHAIN, RTM_DELCHAIN, and RTM_GETCHAIN
svm: Add mutex_lock to protect apic_access_page_done on AMD systems
kgdboc: Fix warning with module build
kgdboc: Fix restrict error
userfaultfd: shmem: UFFDIO_COPY: set the page dirty if VM_WRITE is not set
userfaultfd: shmem: add i_size checks
userfaultfd: shmem: allocate anonymous memory for MAP_PRIVATE shmem
userfaultfd: use ENOENT instead of EFAULT if the atomic copy user fails
drm/meson: Fix OOB memory accesses in meson_viu_set_osd_lut()
drm/meson: Enable fast_io in meson_dw_hdmi_regmap_config
drm/meson: Fixes for drm_crtc_vblank_on/off support
drm: set is_master to 0 upon drm_new_set_master() failure
drm/amd/dm: Don't forget to attach MST encoders
drm/ast: Fix incorrect free on ioregs
tracing/fgraph: Fix set_graph_function from showing interrupts
IB/mlx5: Avoid load failure due to unknown link width
mips: fix mips_get_syscall_arg o32 check
MIPS: ralink: Fix mt7620 nd_sd pinmux
tracepoint: Use __idx instead of idx in DO_TRACE macro to make it unique
sched, trace: Fix prev_state output in sched_switch tracepoint
arm64: ftrace: Fix to enable syscall events on arm64
mtd: nand: Fix memory allocation in nanddev_bbt_init()
uprobes: Fix handle_swbp() vs. unregister() + register() race once more
iser: set sector for ambiguous mr status errors
unifdef: use memcpy instead of strncpy
test_hexdump: use memcpy instead of strncpy
blk-mq: fix corruption with direct issue
ANDROID: cuttlefish_defconfig: Enable CONFIG_ARM64_LSE_ATOMICS
ANDROID: Move from clang r328903 to r346389b.
Linux 4.19.7
misc: mic/scif: fix copy-paste error in scif_create_remote_lookup
Drivers: hv: vmbus: check the creation_status in vmbus_establish_gpadl()
mm: use swp_offset as key in shmem_replace_page()
mm: cleancache: fix corruption on missed inode invalidation
lib/test_kmod.c: fix rmmod double free
iio:st_magn: Fix enable device after trigger
iio/hid-sensors: Fix IIO_CHAN_INFO_RAW returning wrong values for signed numbers
Revert "usb: dwc3: gadget: skip Set/Clear Halt when invalid"
usb: core: quirks: add RESET_RESUME quirk for Cherry G230 Stream series
USB: usb-storage: Add new IDs to ums-realtek
staging: rtl8723bs: Add missing return for cfg80211_rtw_get_station
staging: rtl8723bs: Fix incorrect sense of ether_addr_equal
staging: mt7621-pinctrl: fix uninitialized variable ngroups
staging: mt7621-dma: fix potentially dereferencing uninitialized 'tx_desc'
staging: vchiq_arm: fix compat VCHIQ_IOC_AWAIT_COMPLETION
staging: most: use format specifier "%s" in snprintf
dmaengine: at_hdmac: fix module unloading
dmaengine: at_hdmac: fix memory leak in at_dma_xlate()
ARM: dts: rockchip: Remove @0 from the veyron memory node
ASoC: pcm186x: Fix device reset-registers trigger value
ASoC: intel: cht_bsw_max98090_ti: Add quirk for boards using pmc_plt_clk_0
ext2: fix potential use after free
ext2: initialize opts.s_mount_opt as zero before using it
binder: fix race that allows malicious free of live buffer
function_graph: Reverse the order of pushing the ret_stack and the callback
function_graph: Move return callback before update of curr_ret_stack
function_graph: Have profiler use curr_ret_stack and not depth
function_graph: Use new curr_ret_depth to manage depth instead of curr_ret_stack
function_graph: Make ftrace_push_return_trace() static
MIPS: function_graph: Simplify with function_graph_enter()
arm64: function_graph: Simplify with function_graph_enter()
s390/function_graph: Simplify with function_graph_enter()
riscv/function_graph: Simplify with function_graph_enter()
parisc: function_graph: Simplify with function_graph_enter()
sparc/function_graph: Simplify with function_graph_enter()
sh/function_graph: Simplify with function_graph_enter()
powerpc/function_graph: Simplify with function_graph_enter()
nds32: function_graph: Simplify with function_graph_enter()
x86/function_graph: Simplify with function_graph_enter()
microblaze: function_graph: Simplify with function_graph_enter()
ARM: function_graph: Simplify with function_graph_enter()
function_graph: Create function_graph_enter() to consolidate architecture code
ALSA: hda/realtek - Add auto-mute quirk for HP Spectre x360 laptop
ALSA: hda/realtek - fix the pop noise on headphone for lenovo laptops
ALSA: hda/realtek - fix headset mic detection for MSI MS-B171
ALSA: hda/realtek - Support ALC300
ALSA: hda: Add ASRock N68C-S UCC the power_save blacklist
ALSA: sparc: Fix invalid snd_free_pages() at error path
ALSA: control: Fix race between adding and removing a user element
ALSA: ac97: Fix incorrect bit shift at AC97-SPSA control write
ALSA: wss: Fix invalid snd_free_pages() at error path
fs: fix lost error code in dio_complete
perf/x86/intel: Disallow precise_ip on BTS events
perf/x86/intel: Add generic branch tracing check to intel_pmu_has_bts()
perf/x86/intel: Move branch tracing setup to the Intel-specific source file
x86/fpu: Disable bottom halves while loading FPU registers
x86/MCE/AMD: Fix the thresholding machinery initialization order
arm64: dts: rockchip: Fix PCIe reset polarity for rk3399-puma-haikou.
PCI: Fix incorrect value returned from pcie_get_speed_cap()
PCI: dwc: Fix MSI-X EP framework address calculation bug
PCI: layerscape: Fix wrong invocation of outbound window disable accessor
btrfs: relocation: set trans to be NULL after ending transaction
Btrfs: fix race between enabling quotas and subvolume creation
Btrfs: fix rare chances for data loss when doing a fast fsync
Btrfs: ensure path name is null terminated at btrfs_control_ioctl
btrfs: Always try all copies when reading extent buffers
udf: Allow mounting volumes with incorrect identification strings
xtensa: fix coprocessor part of ptrace_{get,set}xregs
xtensa: fix coprocessor context offset definitions
xtensa: enable coprocessors that are being flushed
KVM: VMX: re-add ple_gap module parameter
KVM: X86: Fix scan ioapic use-before-initialization
KVM: LAPIC: Fix pv ipis use-before-initialization
KVM: x86: Fix kernel info-leak in KVM_HC_CLOCK_PAIRING hypercall
KVM: nVMX/nSVM: Fix bug which sets vcpu->arch.tsc_offset to L1 tsc_offset
kvm: svm: Ensure an IBPB on all affected CPUs when freeing a vmcb
kvm: mmu: Fix race in emulated page table writes
userfaultfd: shmem/hugetlbfs: only allow to register VM_MAYWRITE vmas
x86/speculation: Provide IBPB always command line options
x86/speculation: Add seccomp Spectre v2 user space protection mode
x86/speculation: Enable prctl mode for spectre_v2_user
x86/speculation: Add prctl() control for indirect branch speculation
x86/speculation: Prepare arch_smt_update() for PRCTL mode
x86/speculation: Prevent stale SPEC_CTRL msr content
x86/speculation: Split out TIF update
ptrace: Remove unused ptrace_may_access_sched() and MODE_IBRS
x86/speculation: Prepare for conditional IBPB in switch_mm()
x86/speculation: Avoid __switch_to_xtra() calls
x86/process: Consolidate and simplify switch_to_xtra() code
x86/speculation: Prepare for per task indirect branch speculation control
x86/speculation: Add command line control for indirect branch speculation
x86/speculation: Unify conditional spectre v2 print functions
x86/speculataion: Mark command line parser data __initdata
x86/speculation: Mark string arrays const correctly
x86/speculation: Reorder the spec_v2 code
x86/l1tf: Show actual SMT state
x86/speculation: Rework SMT state change
sched/smt: Expose sched_smt_present static key
x86/Kconfig: Select SCHED_SMT if SMP enabled
sched/smt: Make sched_smt_present track topology
x86/speculation: Reorganize speculation control MSRs update
x86/speculation: Rename SSBD update functions
x86/speculation: Disable STIBP when enhanced IBRS is in use
x86/speculation: Move STIPB/IBPB string conditionals out of cpu_show_common()
x86/speculation: Remove unnecessary ret variable in cpu_show_common()
x86/speculation: Clean up spectre_v2_parse_cmdline()
x86/speculation: Update the TIF_SSBD comment
x86/retpoline: Remove minimal retpoline support
x86/retpoline: Make CONFIG_RETPOLINE depend on compiler support
x86/speculation: Add RETPOLINE_AMD support to the inline asm CALL_NOSPEC variant
x86/speculation: Propagate information about RSB filling mitigation to sysfs
x86/speculation: Apply IBPB more strictly to avoid cross-process data leak
x86/speculation: Enable cross-hyperthread spectre v2 STIBP mitigation
tipc: fix lockdep warning during node delete
net: phy: add workaround for issue where PHY driver doesn't bind to the device
tcp: defer SACK compression after DupThresh
net/dim: Update DIM start sample after each DIM iteration
virtio-net: fail XDP set if guest csum is negotiated
virtio-net: disable guest csum during XDP set
net: skb_scrub_packet(): Scrub offload_fwd_mark
net: thunderx: set xdp_prog to NULL if bpf_prog_add fails
usbnet: ipheth: fix potential recvmsg bug and recvmsg bug 2
s390/qeth: fix length check in SNMP processing
rapidio/rionet: do not free skb before reading its length
packet: copy user buffers before orphan or clone
net: thunderx: set tso_hdrs pointer to NULL in nicvf_free_snd_queue
net: gemini: Fix copy/paste error
net: don't keep lonely packets forever in the gro hash
lan743x: fix return value for lan743x_tx_napi_poll
lan743x: Enable driver to work with LAN7431
mm/khugepaged: collapse_shmem() do not crash on Compound
mm/khugepaged: collapse_shmem() without freezing new_page
mm/khugepaged: minor reorderings in collapse_shmem()
mm/khugepaged: collapse_shmem() remember to clear holes
mm/khugepaged: fix crashes due to misaccounted holes
mm/khugepaged: collapse_shmem() stop if punched or truncated
mm/huge_memory: fix lockdep complaint on 32-bit i_size_read()
mm/huge_memory: splitting set mapping+index before unfreeze
mm/huge_memory: rename freeze_page() to unmap_page()
ANDROID: cuttlefish_defconfig: Enable CONFIG_CRYPTO_ADIANTUM
FROMGIT: fscrypt: add Adiantum support
BACKPORT, FROMGIT: crypto: adiantum - add Adiantum support
FROMGIT: crypto: arm/nhpoly1305 - add NEON-accelerated NHPoly1305
FROMGIT: crypto: nhpoly1305 - add NHPoly1305 support
FROMGIT: crypto: poly1305 - add Poly1305 core API
FROMGIT: crypto: poly1305 - use structures for key and accumulator
FROMGIT: crypto: arm/chacha - add XChaCha12 support
FROMGIT: crypto: arm/chacha20 - refactor to allow varying number of rounds
FROMGIT: crypto: arm/chacha20 - add XChaCha20 support
FROMGIT: crypto: arm/chacha20 - limit the preemption-disabled section
FROMGIT: crypto: chacha - add XChaCha12 support
BACKPORT, FROMGIT: crypto: chacha20-generic - refactor to allow varying number of rounds
FROMGIT: crypto: chacha20-generic - add XChaCha20 support
FROMGIT: crypto: chacha20-generic - don't unnecessarily use atomic walk
FROMGIT: crypto: chacha20-generic - add HChaCha20 library function
FROMGIT: crypto: arm/aes - add some hardening against cache-timing attacks
UPSTREAM: crypto: arm/chacha20 - faster 8-bit rotations and other optimizations
UPSTREAM: crypto: chacha20 - Fix chacha20_block() keystream alignment (again)
ANDROID: cuttlefish_defconfig: Enable CONFIG_SDCARD_FS
ANDROID: sdcardfs: Add sdcardfs filesystem
ANDROID: sdcardfs: Define magic value
ANDROID: fs: Restore vfs_path_lookup() export
ANDROID: vfs: add d_canonical_path for stacked filesystem support
ANDROID: vfs: Add permission2 for filesystems with per mount permissions
ANDROID: vfs: Add setattr2 for filesystems with per mount permissions
ANDROID: vfs: Allow filesystems to access their private mount data
ANDROID: mnt: Add filesystem private data to mount points
ANDROID: sdcardfs: Enable modular sdcardfs
Revert "proc: Convert proc_mount to use mount_ns."
ANDROID: binder: add support for RT prio inheritance.
UPSTREAM: binder: Add BINDER_GET_NODE_INFO_FOR_REF ioctl.
ANDROID: net: ipv6: autoconf routes into per-device tables
ANDROID: cuttlefish_defconfig: Enable SECURITY_PERF_EVENTS_RESTRICT
ANDROID: security,perf: Allow further restriction of perf_event_open
ANDROID: netfilter: xt_IDLETIMER: Add new netlink msg type
ANDROID: cuttlefish_defconfig: Enable CONFIG_NETFILTER_XT_MATCH_QUOTA2
ANDROID: netfilter: xt_quota2: adding the original quota2 from xtables-addons
ANDROID: power: wakeup_reason: add an API to log wakeup reasons
ANDROID: trace: sched: add sched blocked tracepoint which dumps out context of sleep.
ANDROID: add extra free kbytes tunable
CHROMIUM: cgroups: relax permissions on moving tasks between cgroups
ANDROID: cpu: send KOBJ_ONLINE event when enabling cpus
ANDROID: fs: FS tracepoints to track IO.
ANDROID: cuttlefish_defconfig: Enable CONFIG_DM_VERITY_AVB
ANDROID: AVB error handler to invalidate vbmeta partition.
ANDROID: cuttlefish_defconfig: Enable CONFIG_CPUSETS
ANDROID: cpuset: Make cpusets restore on hotplug
ANDROID: taskstats: track fsync syscalls
ANDROID: uid_cputime: add per-uid IO usage accounting
ANDROID: cuttlefish_defconfig: Enable CONFIG_UID_SYS_STATS
ANDROID: uid_cputime: Adds accounting for the cputimes per uid.
ANDROID: cuttlefish_defconfig: Enable CONFIG_MMC
ANDROID: mmc: core: Add "ignore mmc pm notify" functionality
ANDROID: cuttlefish_defconfig: Enable CONFIG_USB_CONFIGFS_F_AUDIO_SRC
ANDROID: usb: gadget: f_audio_source: New gadget driver for audio output
ANDROID: usb: gadget: f_midi: set fi->f to NULL when free f_midi function
ANDROID: usb: gadget: f_midi: create F_midi device
ANDROID: cuttlefish_defconfig: Enable CONFIG_USB_CONFIGFS_F_ACC
ANDROID: usb: gadget: f_accessory: Add Android Accessory function
ANDROID: usb: gadget: configfs: Add device attribute to determine gadget state
ANDROID: usb: gadget: configfs: Add "state" attribute to android_device
ANDROID: cuttlefish_defconfig: Enable CONFIG_USB_CONFIGFS_UEVENT
ANDROID: usb: gadget: configfs: Add function devices to the parent
ANDROID: usb: gadget: configfs: Add Uevent to notify userspace
ANDROID: usb: gadget: configfs: Add usb_function ptr to fi struct
ANDROID: mm: add a field to store names for private anonymous memory
ANDROID: fs: epoll: use freezable blocking call
ANDROID: cuttlefish_defconfig: Enable CONFIG_CMDLINE_EXTEND
ANDROID: of: Support CONFIG_CMDLINE_EXTEND config option
ANDROID: arm64: copy CONFIG_CMDLINE_EXTEND from ARM
UPSTREAM: tcp: start receiver buffer autotuning sooner
UPSTREAM: tcp: up initial rmem to 128KB and SYN rwin to around 64KB
ANDROID: net: xfrm: make PF_KEY SHA256 use RFC-compliant truncation.
ANDROID: cuttlefish_defconfig: Enable EAS related defines
BACKPORT: sched/fair: Fix cpu_util_wake() for 'execl' type workloads
ANDROID: defconfig / build config for cuttlefish
ANDROID: Kbuild, LLVMLinux: allow overriding clang target triple
ANDROID: x86: Remove a useless warning message
Revert "x86: Force asm-goto"
Revert "x86: Allow generating user-space headers without a compiler"
Linux 4.19.6
media: ov5640: fix auto controls values when switching to manual mode
media: ov5640: fix wrong binning value in exposure calculation
media: ov5640: fix auto gain & exposure when changing mode
media: ov5640: fix exposure regression
media: ov5640: Fix timings setup code
media: ov5640: Re-work MIPI startup sequence
rcu: Make need_resched() respond to urgent RCU-QS needs
gfs2: Fix iomap buffer head reference counting bug
tty: wipe buffer if not echoing data
tty: wipe buffer.
include/linux/pfn_t.h: force '~' to be parsed as an unary operator
dax: Avoid losing wakeup in dax_lock_mapping_entry
mm, page_alloc: check for max order in hot path
tmpfs: make lseek(SEEK_DATA/SEK_HOLE) return ENXIO with a negative offset
mm, memory_hotplug: check zone_movable in has_unmovable_pages
z3fold: fix possible reclaim races
efi/arm: Revert deferred unmap of early memmap mapping
powerpc/numa: Suppress "VPHN is not supported" messages
NFSv4: Fix an Oops during delegation callbacks
kdb: Use strscpy with destination buffer size
drm/amdgpu: fix bug with IH ring setup
RISC-V: Silence some module warnings on 32-bit
riscv: add missing vdso_install target
SUNRPC: Fix a bogus get/put in generic_key_to_expire()
block: copy ioprio in __bio_clone_fast() and bounce
perf/x86/intel/uncore: Add more IMC PCI IDs for KabyLake and CoffeeLake CPUs
sched/fair: Fix cpu_util_wake() for 'execl' type workloads
powerpc/io: Fix the IO workarounds code to work with Radix
floppy: fix race condition in __floppy_read_block_0()
crypto: simd - correctly take reqsize of wrapped skcipher into account
rtc: pcf2127: fix a kmemleak caused in pcf2127_i2c_gather_write
rtc: cmos: Do not export alarm rtc_ops when we do not support alarms
cpufreq: imx6q: add return value check for voltage scale
KVM: PPC: Move and undef TRACE_INCLUDE_PATH/FILE
scsi: hisi_sas: Remove set but not used variable 'dq_list'
scsi: lpfc: fix remoteport access
tools/testing/nvdimm: Fix the array size for dimm devices.
pinctrl: meson: fix meson8b ao pull register bits
pinctrl: meson: fix meson8 ao pull register bits
pinctrl: meson: fix gxl ao pull register bits
pinctrl: meson: fix gxbb ao pull register bits
pinctrl: meson: fix pinconf bias disable
fanotify: fix handling of events on child sub-directory
fsnotify: generalize handling of extra event flags
IB/hfi1: Eliminate races in the SDMA send error path
ACPICA: AML interpreter: add region addresses in global list during initialization
can: flexcan: remove not needed struct flexcan_priv::tx_mb and struct flexcan_priv::tx_mb_idx
can: flexcan: Always use last mailbox for TX
can: hi311x: Use level-triggered interrupt
can: raw: check for CAN FD capable netdev in raw_sendmsg()
can: flexcan: handle tx-complete CAN frames via rx-offload infrastructure
can: flexcan: use can_rx_offload_queue_sorted() for flexcan_irq_bus_*()
can: rx-offload: rename can_rx_offload_irq_queue_err_skb() to can_rx_offload_queue_tail()
can: rx-offload: introduce can_rx_offload_get_echo_skb() and can_rx_offload_queue_sorted() functions
can: dev: __can_get_echo_skb(): print error message, if trying to echo non existing skb
can: dev: __can_get_echo_skb(): Don't crash the kernel if can_priv::echo_skb is accessed out of bounds
can: dev: __can_get_echo_skb(): replace struct can_frame by canfd_frame to access frame length
can: dev: can_get_echo_skb(): factor out non sending code to __can_get_echo_skb()
can: flexcan: Unlock the MB unconditionally
drm/ast: Remove existing framebuffers before loading driver
drm/ast: fixed cursor may disappear sometimes
drm/ast: change resolution may cause screen blurred
drm/i915: Disable LP3 watermarks on all SNB machines
drm/amdgpu: Fix oops when pp_funcs->switch_power_profile is unset
drm/vc4: Set ->legacy_cursor_update to false when doing non-async updates
drm/amdgpu: Add missing firmware entry for HAINAN
drm/fb-helper: Blacklist writeback when adding connectors to fbdev
tcp: do not release socket ownership in tcp_close()
mm/memory.c: recheck page table entry with page table lock held
mm: don't warn about large allocations for slab
llc: do not use sk_eat_skb()
gfs2: Don't leave s_fs_info pointing to freed memory in init_sbd
sctp: clear the transport of some out_chunk_list chunks in sctp_assoc_rm_peer
bfs: add sanity check at bfs_fill_super()
Input: synaptics - avoid using uninitialized variable when probing
selinux: Add __GFP_NOWARN to allocation at str_read()
v9fs_dir_readdir: fix double-free on p9stat_read error
tools/power/cpupower: fix compilation with STATIC=true
opp: ti-opp-supply: Correct the supply in _get_optimal_vdd_voltage call
opp: ti-opp-supply: Dynamically update u_volt_min
brcmfmac: fix reporting support for 160 MHz channels
iwlwifi: mvm: don't use SAR Geo if basic SAR is not used
iwlwifi: mvm: fix regulatory domain update when the firmware starts
iwlwifi: mvm: support sta_statistics() even on older firmware
iwlwifi: fix wrong WGDS_WIFI_DATA_SIZE
gpio: don't free unallocated ida on gpiochip_add_data_with_key() error path
mmc: sdhci-pci: Workaround GLK firmware failing to restore the tuning value
mmc: sdhci-pci: Try "cd" for card-detect lookup before using NULL
Documentation/security-bugs: Postpone fix publication in exceptional cases
Documentation/security-bugs: Clarify treatment of embargoed information
MAINTAINERS: Add Sasha as a stable branch maintainer
ALSA: oss: Use kvzalloc() for local buffer allocations
usb: xhci: Prevent bus suspend if a port connect change or polling state is detected
xhci: Add quirk to workaround the errata seen on Cavium Thunder-X2 Soc
usb: xhci: fix timeout for transition from RExit to U0
usb: xhci: fix uninitialized completion when USB3 port got wrong status
xhci: Add check for invalid byte size error when UAS devices are connected.
xhci: handle port status events for removed USB3 hcd
xhci: Fix leaking USB3 shared_hcd at xhci removal
usb: dwc3: Fix NULL pointer exception in dwc3_pci_remove()
usb: dwc3: core: Clean up ULPI device
usb: dwc3: gadget: Properly check last unaligned/zero chain TRB
usb: dwc3: gadget: fix ISOC TRB type on unaligned transfers
usb: core: Fix hub port connection events lost
efi/libstub: arm: support building with clang
HID: steam: remove input device when a hid client is running.
Linux 4.19.5
mt76x0: run vco calibration for each channel configuration
libceph: fall back to sendmsg for slab pages
HID: Add quirk for Microsoft PIXART OEM mouse
HID: Add quirk for Primax PIXART OEM mice
HID: uhid: forbid UHID_CREATE under KERNEL_DS or elevated privileges
ACPI / platform: Add SMB0001 HID to forbidden_id_list
drivers/misc/sgi-gru: fix Spectre v1 vulnerability
mtd: rawnand: atmel: fix OF child-node lookup
gnss: sirf: fix synchronous write timeout
gnss: serial: fix synchronous write timeout
USB: misc: appledisplay: add 20" Apple Cinema Display
misc: atmel-ssc: Fix section annotation on atmel_ssc_get_driver_data
usb: quirks: Add delay-init quirk for Corsair K70 LUX RGB
USB: Wait for extra delay time after USB_PORT_FEAT_RESET for quirky hub
USB: quirks: Add no-lpm quirk for Raydium touchscreens
usb: cdc-acm: add entry for Hiro (Conexant) modem
can: kvaser_usb: Fix potential uninitialized variable use
can: kvaser_usb: Fix accessing freed memory in kvaser_usb_start_xmit()
ALSA: hda/ca0132 - Call pci_iounmap() instead of iounmap()
ALSA: hda/realtek - Add quirk entry for HP Pavilion 15
uio: Fix an Oops on load
RISC-V: Fix raw_copy_{to,from}_user()
MIPS: OCTEON: cavium_octeon_defconfig: re-enable OCTEON USB driver
media: v4l: event: Add subscription to list before calling "add" operation
x86/ldt: Remove unused variable in map_ldt_struct()
x86/ldt: Unmap PTEs for the slot before freeing LDT pages
x86/mm: Move LDT remap out of KASLR region on 5-level paging
SUNRPC: drop pointless static qualifier in xdr_get_next_encode_buffer()
Revert "scripts/setlocalversion: git: Make -dirty check more robust"
kbuild: deb-pkg: fix too low build version number
net: aquantia: invalid checksumm offload implementation
net: aquantia: fixed enable unicast on 32 macvlan
net: aquantia: fix potential IOMMU fault after driver unbind
net: stmmac: Fix RX packet size > 8191
qed: Fix potential memory corruption
qed: Fix SPQ entries not returned to pool in error flows
qed: Fix blocking/unlimited SPQ entries leak
qed: Fix memory/entry leak in qed_init_sp_request()
i40e: restore NETIF_F_GSO_IPXIP[46] to netdev features
ice: Change req_speeds to be u16
ice: Fix the bytecount sent to netdev_tx_sent_queue
ice: Fix dead device link issue with flow control
perf tools: Do not zero sample_id_all for group members
perf tools: Fix undefined symbol scnprintf in libperf-jvmti.so
sched/core: Take the hotplug lock in sched_init_smp()
i2c: qcom-geni: Fix runtime PM mismatch with child devices
i2c: omap: Enable for ARCH_K3
nvme: make sure ns head inherits underlying device limits
of/device: Really only set bus DMA mask when appropriate
ceph: quota: fix null pointer dereference in quota check
s390/perf: Change CPUM_CF return code in event init function
drm/amd/amdgpu/dm: Fix dm_dp_create_fake_mst_encoder()
drm/amd/display: Drop reusing drm connector for MST
block: Clear kernel memory before copying to user
drm/amd/display: Stop leaking planes
lib/raid6: Fix arm64 test build
mtd: nand: Fix nanddev_pos_next_page() kernel-doc header
clk: fixed-factor: fix of_node_get-put imbalance
xen/grant-table: Fix incorrect gnttab_dma_free_pages() pr_debug message
arm64: dts: renesas: condor: switch from EtherAVB to GEther
arm64: dts: renesas: r8a7795: add missing dma-names on hscif2
Revert "drm/exynos/decon5433: implement frame counter"
ARM: dts: fsl: Fix improperly quoted stdout-path values
ARM: dts: imx6sll: fix typo for fsl,imx6sll-i2c node
hwmon: (ibmpowernv) Remove bogus __init annotations
net: hns3: Fix for out-of-bounds access when setting pfc back pressure
s390/qeth: unregister netdevice only when registered
s390/qeth: fix HiperSockets sniffer
netfilter: nft_compat: ebtables 'nat' table is normal chain type
netfilter: ipset: Fix calling ip_set() macro at dumping
netfilter: xt_IDLETIMER: add sysfs filename checking routine
netfilter: ipset: Correct rcu_dereference() call in ip_set_put_comment()
bpf: fix bpf_prog_get_info_by_fd to return 0 func_lens for unpriv
s390/mm: Fix ERROR: "__node_distance" undefined!
s390/mm: fix mis-accounting of pgtable_bytes
netfilter: ipset: fix ip_set_list allocation failure
netfilter: ipset: actually allow allowable CIDR 0 in hash:net,port,net
netfilter: ipset: list:set: Decrease refcount synchronously on deletion and replace
Revert "netfilter: nft_numgen: add map lookups for numgen random operations"
HID: alps: allow incoming reports when only the trackstick is opened
Revert "HID: add NOGET quirk for Eaton Ellipse MAX UPS"
HID: i2c-hid: Add a small delay after sleep command for Raydium touchpanel
s390/vdso: add missing FORCE to build targets
s390/decompressor: add missing FORCE to build targets
netfilter: bridge: define INT_MIN & INT_MAX in userspace
netfilter: ipv6: fix oops when defragmenting locally generated fragments
serial: sh-sci: Fix receive on SCIFA/SCIFB variants with DMA
clk: ti: fix OF child-node lookup
clk: renesas: r9a06g032: Fix UART34567 clock rate
clk: meson: clk-pll: drop CLK_GET_RATE_NOCACHE where unnecessary
arm64: percpu: Initialize ret in the default case
clk: meson-axg: pcie: drop the mpll3 clock parent
platform/x86: acerhdf: Add BIOS entry for Gateway LT31 v1.3307
x86/earlyprintk: Add a force option for pciserial device
apparmor: Fix uninitialized value in aa_split_fqname
clk: samsung: exynos5420: Enable PERIS clocks for suspend
fs/exofs: fix potential memory leak in mount option parsing
perf symbols: Set PLT entry/header sizes properly on Sparc
clk: fixed-rate: fix of_node_get-put imbalance
platform/x86: intel_telemetry: report debugfs failure
afs: Handle EIO from delivery function
drm/edid: Add 6 bpc quirk for BOE panel.
um: Give start_idle_thread() a return code
perf unwind: Take pgoff into account when reporting elf to libdwfl
hfsplus: prevent btree data loss on root split
hfs: prevent btree data loss on root split
reiserfs: propagate errors from fill_with_dentries() properly
ixgbe: fix MAC anti-spoofing filter after VFLR
net: hns3: bugfix for the initialization of command queue's spin lock
net: hns3: bugfix for handling mailbox while the command queue reinitialized
net: hns3: bugfix for rtnl_lock's range in the hclge_reset()
net: hns3: bugfix for rtnl_lock's range in the hclgevf_reset()
block: brd: associate with queue until adding disk
arm64: kprobe: make page to RO mode when allocate it
cifs: fix return value for cifs_listxattr
cifs: don't dereference smb_file_target before null check
drm/i915: Replace some PAGE_SIZE with I915_GTT_PAGE_SIZE
f2fs: fix to keep project quota consistent
f2fs: guarantee journalled quota data by checkpoint
f2fs: cleanup dirty pages if recover failed
f2fs: fix data corruption issue with hardware encryption
f2fs: fix to recover inode->i_flags of inode block during POR
f2fs: spread f2fs_set_inode_flags()
f2fs: fix to spread clear_cold_data()
Revert "f2fs: fix to clear PG_checked flag in set_page_dirty()"
f2fs: account read IOs and use IO counts for is_idle
f2fs: fix to account IO correctly for cgroup writeback
f2fs: fix to account IO correctly
f2fs: remove request_list check in is_idle()
f2fs: allow to mount, if quota is failed
f2fs: update REQ_TIME in f2fs_cross_rename()
f2fs: do not update REQ_TIME in case of error conditions
f2fs: remove unneeded disable_nat_bits()
f2fs: remove unused sbi->trigger_ssr_threshold
f2fs: shrink sbi->sb_lock coverage in set_file_temperature()
f2fs: use rb_*_cached friends
f2fs: fix to recover cold bit of inode block during POR
f2fs: submit cached bio to avoid endless PageWriteback
f2fs: checkpoint disabling
f2fs: clear PageError on the read path
f2fs: allow out-place-update for direct IO in LFS mode
f2fs: refactor ->page_mkwrite() flow
Revert: "f2fs: check last page index in cached bio to decide submission"
f2fs: support superblock checksum
f2fs: add to account skip count of background GC
f2fs: add to account meta IO
f2fs: keep lazytime on remount
f2fs: fix missing up_read
f2fs: return correct errno in f2fs_gc
f2fs: avoid f2fs_bug_on if f2fs_get_meta_page_nofail got EIO
f2fs: mark inode dirty explicitly in recover_inode()
f2fs: fix to recover inode's crtime during POR
f2fs: fix to recover inode's i_gc_failures during POR
f2fs: fix to recover inode's i_flags during POR
f2fs: fix to recover inode's project id during POR
f2fs: update i_size after DIO completion
f2fs: report ENOENT correctly in f2fs_rename
f2fs: fix remount problem of option io_bits
f2fs: fix to recover inode's uid/gid during POR
f2fs: avoid infinite loop in f2fs_alloc_nid
f2fs: add new idle interval timing for discard and gc paths
f2fs: split IO error injection according to RW
f2fs: add SPDX license identifiers
f2fs: surround fault_injection related option parsing using CONFIG_F2FS_FAULT_INJECTION
f2fs: fix setattr project check upon fssetxattr ioctl
f2fs: avoid sleeping under spin_lock
f2fs: plug readahead IO in readdir()
f2fs: fix to do sanity check with current segment number
f2fs: fix memory leak of percpu counter in fill_super()
f2fs: fix memory leak of write_io in fill_super()
f2fs: cache NULL when both default_acl and acl are NULL
f2fs: fix to flush all dirty inodes recovered in readonly fs
f2fs: report error if quota off error during umount
f2fs: submit bio after shutdown
f2fs: avoid wrong decrypted data from disk
Revert "f2fs: use printk_ratelimited for f2fs_msg"
f2fs: fix unnecessary periodic wakeup of discard thread when dev is busy
f2fs: fix to avoid NULL pointer dereference on se->discard_map
f2fs: add additional sanity check in f2fs_acl_from_disk()
ANDROID: arm64: defconfig: Enable CONFIG_SCHED_TUNE
ANDROID: thermal: cpu_cooling: Migrate to using the EM framework
ANDROID: Add hold functionality to schedtune CPU boost
ANDROID: sched/rt: Add schedtune accounting to rt task enqueue/dequeue
ANDROID: sched: Make the cpu_util* accessors available without sugov
ANDROID: sched/events: Introduce overutilized trace event
ANDROID: sched/events: Introduce rt_rq load tracking trace event
ANDROID: sched/events: Introduce schedtune trace events
ANDROID: sched/events: Introduce find_best_target trace event
ANDROID: sched/events: Introduce util_est trace events
ANDROID: sched/events: Introduce task_group load tracking trace event
ANDROID: sched/events: Introduce sched_entity load tracking trace event
ANDROID: sched/events: Introduce cfs_rq load tracking trace event
ANDROID: sched/autogroup: Define autogroup_path() for !CONFIG_SCHED_DEBUG
ANDROID: sched/fair: Also do misfit in overloaded groups
ANDROID: sched/fair: Don't balance misfits if it would overload local group
ANDROID: sched/fair: Attempt to improve throughput for asym cap systems
ANDROID: cpufreq/schedutil: add up/down frequency transition rate limits
ANDROID: cpufreq/schedutil: Select frequency using util_avg for RT
ANDROID: sched: Update max cpu capacity in case of max frequency constraints
ANDROID: arm: enable max frequency capping
ANDROID: arm64: enable max frequency capping
ANDROID: implement max frequency capping
ANDROID: sched/fair: add arch scaling function for max frequency capping
ANDROID: sched/fair: Bypass energy computation for prefer_idle tasks
ANDROID: sched: fair: Bypass energy-aware wakeup for prefer-idle tasks
FROMLIST: sched/fair: Use wake_q length as a hint for wake_wide
ANDROID: sched: Unconditionally honor sync flag for energy-aware wakeups
ANDROID: Add find_best_target to minimise energy calculation overhead
ANDROID: sched/fair: Factor out CPU selection from find_energy_efficient_cpu
ANDROID: sched: Introduce sysctl_sched_cstate_aware
ANDROID: sched, cpuidle: Track cpuidle state index in the scheduler
ANDROID: sched: fair/tune: Add schedtune with cgroups interface
ANDROID: drivers: Introduce a legacy Energy Model loading driver
ANDROID: cpufreq: scmi: Register an Energy Model
UPSTREAM: firmware: arm_scmi: add a getter for power of performance states
ANDROID: cpufreq: arm_big_little: Register an Energy Model
ANDROID: cpufreq: scpi: Register an Energy Model
ANDROID: PM / OPP: cpufreq-dt: Move power estimation function
FROMLIST: cpufreq: dt: Register an Energy Model
ANDROID: arm: dts: vexpress-v2p-ca15_a7: Add dynamic-power-coefficient properties
ANDROID: arm64: dts: juno-r2: Add dynamic-power-coefficient properties
ANDROID: arm64: dts: juno: Add dynamic-power-coefficient properties
ANDROID: arm, arm64: Enable kernel config options required for EAS
ANDROID: sched: Enable idle balance to pull single task towards cpu with higher capacity
ANDROID: sched: Prevent unnecessary active balance of single task in sched group
FROMLIST: sched/fair: Select an energy-efficient CPU on task wake-up
FROMLIST: sched/fair: Introduce an energy estimation helper function
FROMLIST: sched: Add over-utilization/tipping point indicator
FROMLIST: sched/fair: Clean-up update_sg_lb_stats parameters
FROMLIST: sched: Introduce a sysctl for Energy Aware Scheduling
FROMLIST: sched: Introduce sched_energy_present static key
FROMLIST: sched/topology: Make Energy Aware Scheduling depend on schedutil
FROMLIST: sched/topology: Disable EAS on inappropriate platforms
FROMLIST: sched/topology: Lowest CPU asymmetry sched_domain level pointer
FROMLIST: sched/topology: Reference the Energy Model of CPUs when available
FROMLIST: PM / EM: Expose the Energy Model in sysfs
FROMLIST: PM: Introduce an Energy Model management framework
FROMLIST: sched/cpufreq: Prepare schedutil for Energy Aware Scheduling
FROMLIST: sched: Relocate arch_scale_cpu_capacity
UPSTREAM: sched/core: Disable SD_PREFER_SIBLING on asymmetric CPU capacity domains
UPSTREAM: sched/fair: Don't move tasks to lower capacity CPUs unless necessary
UPSTREAM: sched/fair: Set rq->rd->overload when misfit
UPSTREAM: sched/fair: Wrap rq->rd->overload accesses with READ/WRITE_ONCE()
UPSTREAM: sched/core: Change root_domain->overload type to int
UPSTREAM: sched/fair: Change 'prefer_sibling' type to bool
UPSTREAM: sched/fair: Kick nohz balance if rq->misfit_task_load
UPSTREAM: sched/fair: Consider misfit tasks when load-balancing
UPSTREAM: sched/fair: Add sched_group per-CPU max capacity
UPSTREAM: sched/fair: Add 'group_misfit_task' load-balance type
UPSTREAM: sched/topology: Add static_key for asymmetric CPU capacity optimizations
UPSTREAM: sched/topology, arch/arm: Rebuild sched_domain hierarchy when CPU capacity changes
UPSTREAM: sched/topology, arch/arm64: Rebuild the sched_domain hierarchy when the CPU capacity changes
UPSTREAM: sched/topology, drivers/base/arch_topology: Rebuild the sched_domain hierarchy when capacities change
UPSTREAM: sched/topology: Add SD_ASYM_CPUCAPACITY flag detection
Change-Id: I19fafa34b3fd39c4125708cb5c9c5a7634c40ec4
Signed-off-by: Rishabh Bhatnagar <rishabhb@codeaurora.org>
929 lines
29 KiB
C
929 lines
29 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Ftrace header. For implementation details beyond the random comments
|
|
* scattered below, see: Documentation/trace/ftrace-design.rst
|
|
*/
|
|
|
|
#ifndef _LINUX_FTRACE_H
|
|
#define _LINUX_FTRACE_H
|
|
|
|
#include <linux/trace_clock.h>
|
|
#include <linux/kallsyms.h>
|
|
#include <linux/linkage.h>
|
|
#include <linux/bitops.h>
|
|
#include <linux/ptrace.h>
|
|
#include <linux/ktime.h>
|
|
#include <linux/sched.h>
|
|
#include <linux/types.h>
|
|
#include <linux/init.h>
|
|
#include <linux/fs.h>
|
|
|
|
#include <asm/ftrace.h>
|
|
|
|
/*
|
|
* If the arch supports passing the variable contents of
|
|
* function_trace_op as the third parameter back from the
|
|
* mcount call, then the arch should define this as 1.
|
|
*/
|
|
#ifndef ARCH_SUPPORTS_FTRACE_OPS
|
|
#define ARCH_SUPPORTS_FTRACE_OPS 0
|
|
#endif
|
|
|
|
/*
|
|
* If the arch's mcount caller does not support all of ftrace's
|
|
* features, then it must call an indirect function that
|
|
* does. Or at least does enough to prevent any unwelcomed side effects.
|
|
*/
|
|
#if !ARCH_SUPPORTS_FTRACE_OPS
|
|
# define FTRACE_FORCE_LIST_FUNC 1
|
|
#else
|
|
# define FTRACE_FORCE_LIST_FUNC 0
|
|
#endif
|
|
|
|
/* Main tracing buffer and events set up */
|
|
#ifdef CONFIG_TRACING
|
|
void trace_init(void);
|
|
void early_trace_init(void);
|
|
#else
|
|
static inline void trace_init(void) { }
|
|
static inline void early_trace_init(void) { }
|
|
#endif
|
|
|
|
struct module;
|
|
struct ftrace_hash;
|
|
|
|
#if defined(CONFIG_FUNCTION_TRACER) && defined(CONFIG_MODULES) && \
|
|
defined(CONFIG_DYNAMIC_FTRACE)
|
|
const char *
|
|
ftrace_mod_address_lookup(unsigned long addr, unsigned long *size,
|
|
unsigned long *off, char **modname, char *sym);
|
|
int ftrace_mod_get_kallsym(unsigned int symnum, unsigned long *value,
|
|
char *type, char *name,
|
|
char *module_name, int *exported);
|
|
#else
|
|
static inline const char *
|
|
ftrace_mod_address_lookup(unsigned long addr, unsigned long *size,
|
|
unsigned long *off, char **modname, char *sym)
|
|
{
|
|
return NULL;
|
|
}
|
|
static inline int ftrace_mod_get_kallsym(unsigned int symnum, unsigned long *value,
|
|
char *type, char *name,
|
|
char *module_name, int *exported)
|
|
{
|
|
return -1;
|
|
}
|
|
#endif
|
|
|
|
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
|
|
extern int ftrace_enabled;
|
|
extern int
|
|
ftrace_enable_sysctl(struct ctl_table *table, int write,
|
|
void __user *buffer, size_t *lenp,
|
|
loff_t *ppos);
|
|
|
|
struct ftrace_ops;
|
|
|
|
typedef void (*ftrace_func_t)(unsigned long ip, unsigned long parent_ip,
|
|
struct ftrace_ops *op, struct pt_regs *regs);
|
|
|
|
ftrace_func_t ftrace_ops_get_func(struct ftrace_ops *ops);
|
|
|
|
/*
|
|
* FTRACE_OPS_FL_* bits denote the state of ftrace_ops struct and are
|
|
* set in the flags member.
|
|
* CONTROL, SAVE_REGS, SAVE_REGS_IF_SUPPORTED, RECURSION_SAFE, STUB and
|
|
* IPMODIFY are a kind of attribute flags which can be set only before
|
|
* registering the ftrace_ops, and can not be modified while registered.
|
|
* Changing those attribute flags after registering ftrace_ops will
|
|
* cause unexpected results.
|
|
*
|
|
* ENABLED - set/unset when ftrace_ops is registered/unregistered
|
|
* DYNAMIC - set when ftrace_ops is registered to denote dynamically
|
|
* allocated ftrace_ops which need special care
|
|
* SAVE_REGS - The ftrace_ops wants regs saved at each function called
|
|
* and passed to the callback. If this flag is set, but the
|
|
* architecture does not support passing regs
|
|
* (CONFIG_DYNAMIC_FTRACE_WITH_REGS is not defined), then the
|
|
* ftrace_ops will fail to register, unless the next flag
|
|
* is set.
|
|
* SAVE_REGS_IF_SUPPORTED - This is the same as SAVE_REGS, but if the
|
|
* handler can handle an arch that does not save regs
|
|
* (the handler tests if regs == NULL), then it can set
|
|
* this flag instead. It will not fail registering the ftrace_ops
|
|
* but, the regs field will be NULL if the arch does not support
|
|
* passing regs to the handler.
|
|
* Note, if this flag is set, the SAVE_REGS flag will automatically
|
|
* get set upon registering the ftrace_ops, if the arch supports it.
|
|
* RECURSION_SAFE - The ftrace_ops can set this to tell the ftrace infrastructure
|
|
* that the call back has its own recursion protection. If it does
|
|
* not set this, then the ftrace infrastructure will add recursion
|
|
* protection for the caller.
|
|
* STUB - The ftrace_ops is just a place holder.
|
|
* INITIALIZED - The ftrace_ops has already been initialized (first use time
|
|
* register_ftrace_function() is called, it will initialized the ops)
|
|
* DELETED - The ops are being deleted, do not let them be registered again.
|
|
* ADDING - The ops is in the process of being added.
|
|
* REMOVING - The ops is in the process of being removed.
|
|
* MODIFYING - The ops is in the process of changing its filter functions.
|
|
* ALLOC_TRAMP - A dynamic trampoline was allocated by the core code.
|
|
* The arch specific code sets this flag when it allocated a
|
|
* trampoline. This lets the arch know that it can update the
|
|
* trampoline in case the callback function changes.
|
|
* The ftrace_ops trampoline can be set by the ftrace users, and
|
|
* in such cases the arch must not modify it. Only the arch ftrace
|
|
* core code should set this flag.
|
|
* IPMODIFY - The ops can modify the IP register. This can only be set with
|
|
* SAVE_REGS. If another ops with this flag set is already registered
|
|
* for any of the functions that this ops will be registered for, then
|
|
* this ops will fail to register or set_filter_ip.
|
|
* PID - Is affected by set_ftrace_pid (allows filtering on those pids)
|
|
* RCU - Set when the ops can only be called when RCU is watching.
|
|
* TRACE_ARRAY - The ops->private points to a trace_array descriptor.
|
|
*/
|
|
enum {
|
|
FTRACE_OPS_FL_ENABLED = 1 << 0,
|
|
FTRACE_OPS_FL_DYNAMIC = 1 << 1,
|
|
FTRACE_OPS_FL_SAVE_REGS = 1 << 2,
|
|
FTRACE_OPS_FL_SAVE_REGS_IF_SUPPORTED = 1 << 3,
|
|
FTRACE_OPS_FL_RECURSION_SAFE = 1 << 4,
|
|
FTRACE_OPS_FL_STUB = 1 << 5,
|
|
FTRACE_OPS_FL_INITIALIZED = 1 << 6,
|
|
FTRACE_OPS_FL_DELETED = 1 << 7,
|
|
FTRACE_OPS_FL_ADDING = 1 << 8,
|
|
FTRACE_OPS_FL_REMOVING = 1 << 9,
|
|
FTRACE_OPS_FL_MODIFYING = 1 << 10,
|
|
FTRACE_OPS_FL_ALLOC_TRAMP = 1 << 11,
|
|
FTRACE_OPS_FL_IPMODIFY = 1 << 12,
|
|
FTRACE_OPS_FL_PID = 1 << 13,
|
|
FTRACE_OPS_FL_RCU = 1 << 14,
|
|
FTRACE_OPS_FL_TRACE_ARRAY = 1 << 15,
|
|
};
|
|
|
|
#ifdef CONFIG_DYNAMIC_FTRACE
|
|
/* The hash used to know what functions callbacks trace */
|
|
struct ftrace_ops_hash {
|
|
struct ftrace_hash __rcu *notrace_hash;
|
|
struct ftrace_hash __rcu *filter_hash;
|
|
struct mutex regex_lock;
|
|
};
|
|
|
|
void ftrace_free_init_mem(void);
|
|
void ftrace_free_mem(struct module *mod, void *start, void *end);
|
|
#else
|
|
static inline void ftrace_free_init_mem(void) { }
|
|
static inline void ftrace_free_mem(struct module *mod, void *start, void *end) { }
|
|
#endif
|
|
|
|
/*
|
|
* Note, ftrace_ops can be referenced outside of RCU protection, unless
|
|
* the RCU flag is set. If ftrace_ops is allocated and not part of kernel
|
|
* core data, the unregistering of it will perform a scheduling on all CPUs
|
|
* to make sure that there are no more users. Depending on the load of the
|
|
* system that may take a bit of time.
|
|
*
|
|
* Any private data added must also take care not to be freed and if private
|
|
* data is added to a ftrace_ops that is in core code, the user of the
|
|
* ftrace_ops must perform a schedule_on_each_cpu() before freeing it.
|
|
*/
|
|
struct ftrace_ops {
|
|
ftrace_func_t func;
|
|
struct ftrace_ops __rcu *next;
|
|
unsigned long flags;
|
|
void *private;
|
|
ftrace_func_t saved_func;
|
|
#ifdef CONFIG_DYNAMIC_FTRACE
|
|
struct ftrace_ops_hash local_hash;
|
|
struct ftrace_ops_hash *func_hash;
|
|
struct ftrace_ops_hash old_hash;
|
|
unsigned long trampoline;
|
|
unsigned long trampoline_size;
|
|
#endif
|
|
};
|
|
|
|
/*
|
|
* Type of the current tracing.
|
|
*/
|
|
enum ftrace_tracing_type_t {
|
|
FTRACE_TYPE_ENTER = 0, /* Hook the call of the function */
|
|
FTRACE_TYPE_RETURN, /* Hook the return of the function */
|
|
};
|
|
|
|
/* Current tracing type, default is FTRACE_TYPE_ENTER */
|
|
extern enum ftrace_tracing_type_t ftrace_tracing_type;
|
|
|
|
/*
|
|
* The ftrace_ops must be a static and should also
|
|
* be read_mostly. These functions do modify read_mostly variables
|
|
* so use them sparely. Never free an ftrace_op or modify the
|
|
* next pointer after it has been registered. Even after unregistering
|
|
* it, the next pointer may still be used internally.
|
|
*/
|
|
int register_ftrace_function(struct ftrace_ops *ops);
|
|
int unregister_ftrace_function(struct ftrace_ops *ops);
|
|
|
|
#ifdef CONFIG_CFI_CLANG
|
|
/* Use a C stub with the correct type for CFI */
|
|
static inline void ftrace_stub(unsigned long a0, unsigned long a1,
|
|
struct ftrace_ops *op, struct pt_regs *regs)
|
|
{
|
|
}
|
|
#else
|
|
extern void ftrace_stub(unsigned long a0, unsigned long a1,
|
|
struct ftrace_ops *op, struct pt_regs *regs);
|
|
#endif
|
|
|
|
#else /* !CONFIG_FUNCTION_TRACER */
|
|
/*
|
|
* (un)register_ftrace_function must be a macro since the ops parameter
|
|
* must not be evaluated.
|
|
*/
|
|
#define register_ftrace_function(ops) ({ 0; })
|
|
#define unregister_ftrace_function(ops) ({ 0; })
|
|
static inline void ftrace_kill(void) { }
|
|
static inline void ftrace_free_init_mem(void) { }
|
|
static inline void ftrace_free_mem(struct module *mod, void *start, void *end) { }
|
|
#endif /* CONFIG_FUNCTION_TRACER */
|
|
|
|
#ifdef CONFIG_STACK_TRACER
|
|
|
|
#define STACK_TRACE_ENTRIES 500
|
|
|
|
struct stack_trace;
|
|
|
|
extern unsigned stack_trace_index[];
|
|
extern struct stack_trace stack_trace_max;
|
|
extern unsigned long stack_trace_max_size;
|
|
extern arch_spinlock_t stack_trace_max_lock;
|
|
|
|
extern int stack_tracer_enabled;
|
|
void stack_trace_print(void);
|
|
int
|
|
stack_trace_sysctl(struct ctl_table *table, int write,
|
|
void __user *buffer, size_t *lenp,
|
|
loff_t *ppos);
|
|
|
|
/* DO NOT MODIFY THIS VARIABLE DIRECTLY! */
|
|
DECLARE_PER_CPU(int, disable_stack_tracer);
|
|
|
|
/**
|
|
* stack_tracer_disable - temporarily disable the stack tracer
|
|
*
|
|
* There's a few locations (namely in RCU) where stack tracing
|
|
* cannot be executed. This function is used to disable stack
|
|
* tracing during those critical sections.
|
|
*
|
|
* This function must be called with preemption or interrupts
|
|
* disabled and stack_tracer_enable() must be called shortly after
|
|
* while preemption or interrupts are still disabled.
|
|
*/
|
|
static inline void stack_tracer_disable(void)
|
|
{
|
|
/* Preemption or interupts must be disabled */
|
|
if (IS_ENABLED(CONFIG_DEBUG_PREEMPT))
|
|
WARN_ON_ONCE(!preempt_count() || !irqs_disabled());
|
|
this_cpu_inc(disable_stack_tracer);
|
|
}
|
|
|
|
/**
|
|
* stack_tracer_enable - re-enable the stack tracer
|
|
*
|
|
* After stack_tracer_disable() is called, stack_tracer_enable()
|
|
* must be called shortly afterward.
|
|
*/
|
|
static inline void stack_tracer_enable(void)
|
|
{
|
|
if (IS_ENABLED(CONFIG_DEBUG_PREEMPT))
|
|
WARN_ON_ONCE(!preempt_count() || !irqs_disabled());
|
|
this_cpu_dec(disable_stack_tracer);
|
|
}
|
|
#else
|
|
static inline void stack_tracer_disable(void) { }
|
|
static inline void stack_tracer_enable(void) { }
|
|
#endif
|
|
|
|
#ifdef CONFIG_DYNAMIC_FTRACE
|
|
|
|
int ftrace_arch_code_modify_prepare(void);
|
|
int ftrace_arch_code_modify_post_process(void);
|
|
|
|
struct dyn_ftrace;
|
|
|
|
enum ftrace_bug_type {
|
|
FTRACE_BUG_UNKNOWN,
|
|
FTRACE_BUG_INIT,
|
|
FTRACE_BUG_NOP,
|
|
FTRACE_BUG_CALL,
|
|
FTRACE_BUG_UPDATE,
|
|
};
|
|
extern enum ftrace_bug_type ftrace_bug_type;
|
|
|
|
/*
|
|
* Archs can set this to point to a variable that holds the value that was
|
|
* expected at the call site before calling ftrace_bug().
|
|
*/
|
|
extern const void *ftrace_expected;
|
|
|
|
void ftrace_bug(int err, struct dyn_ftrace *rec);
|
|
|
|
struct seq_file;
|
|
|
|
extern int ftrace_text_reserved(const void *start, const void *end);
|
|
|
|
struct ftrace_ops *ftrace_ops_trampoline(unsigned long addr);
|
|
|
|
bool is_ftrace_trampoline(unsigned long addr);
|
|
|
|
/*
|
|
* The dyn_ftrace record's flags field is split into two parts.
|
|
* the first part which is '0-FTRACE_REF_MAX' is a counter of
|
|
* the number of callbacks that have registered the function that
|
|
* the dyn_ftrace descriptor represents.
|
|
*
|
|
* The second part is a mask:
|
|
* ENABLED - the function is being traced
|
|
* REGS - the record wants the function to save regs
|
|
* REGS_EN - the function is set up to save regs.
|
|
* IPMODIFY - the record allows for the IP address to be changed.
|
|
* DISABLED - the record is not ready to be touched yet
|
|
*
|
|
* When a new ftrace_ops is registered and wants a function to save
|
|
* pt_regs, the rec->flag REGS is set. When the function has been
|
|
* set up to save regs, the REG_EN flag is set. Once a function
|
|
* starts saving regs it will do so until all ftrace_ops are removed
|
|
* from tracing that function.
|
|
*/
|
|
enum {
|
|
FTRACE_FL_ENABLED = (1UL << 31),
|
|
FTRACE_FL_REGS = (1UL << 30),
|
|
FTRACE_FL_REGS_EN = (1UL << 29),
|
|
FTRACE_FL_TRAMP = (1UL << 28),
|
|
FTRACE_FL_TRAMP_EN = (1UL << 27),
|
|
FTRACE_FL_IPMODIFY = (1UL << 26),
|
|
FTRACE_FL_DISABLED = (1UL << 25),
|
|
};
|
|
|
|
#define FTRACE_REF_MAX_SHIFT 25
|
|
#define FTRACE_FL_BITS 7
|
|
#define FTRACE_FL_MASKED_BITS ((1UL << FTRACE_FL_BITS) - 1)
|
|
#define FTRACE_FL_MASK (FTRACE_FL_MASKED_BITS << FTRACE_REF_MAX_SHIFT)
|
|
#define FTRACE_REF_MAX ((1UL << FTRACE_REF_MAX_SHIFT) - 1)
|
|
|
|
#define ftrace_rec_count(rec) ((rec)->flags & ~FTRACE_FL_MASK)
|
|
|
|
struct dyn_ftrace {
|
|
unsigned long ip; /* address of mcount call-site */
|
|
unsigned long flags;
|
|
struct dyn_arch_ftrace arch;
|
|
};
|
|
|
|
int ftrace_force_update(void);
|
|
int ftrace_set_filter_ip(struct ftrace_ops *ops, unsigned long ip,
|
|
int remove, int reset);
|
|
int ftrace_set_filter(struct ftrace_ops *ops, unsigned char *buf,
|
|
int len, int reset);
|
|
int ftrace_set_notrace(struct ftrace_ops *ops, unsigned char *buf,
|
|
int len, int reset);
|
|
void ftrace_set_global_filter(unsigned char *buf, int len, int reset);
|
|
void ftrace_set_global_notrace(unsigned char *buf, int len, int reset);
|
|
void ftrace_free_filter(struct ftrace_ops *ops);
|
|
void ftrace_ops_set_global_filter(struct ftrace_ops *ops);
|
|
|
|
enum {
|
|
FTRACE_UPDATE_CALLS = (1 << 0),
|
|
FTRACE_DISABLE_CALLS = (1 << 1),
|
|
FTRACE_UPDATE_TRACE_FUNC = (1 << 2),
|
|
FTRACE_START_FUNC_RET = (1 << 3),
|
|
FTRACE_STOP_FUNC_RET = (1 << 4),
|
|
};
|
|
|
|
/*
|
|
* The FTRACE_UPDATE_* enum is used to pass information back
|
|
* from the ftrace_update_record() and ftrace_test_record()
|
|
* functions. These are called by the code update routines
|
|
* to find out what is to be done for a given function.
|
|
*
|
|
* IGNORE - The function is already what we want it to be
|
|
* MAKE_CALL - Start tracing the function
|
|
* MODIFY_CALL - Stop saving regs for the function
|
|
* MAKE_NOP - Stop tracing the function
|
|
*/
|
|
enum {
|
|
FTRACE_UPDATE_IGNORE,
|
|
FTRACE_UPDATE_MAKE_CALL,
|
|
FTRACE_UPDATE_MODIFY_CALL,
|
|
FTRACE_UPDATE_MAKE_NOP,
|
|
};
|
|
|
|
enum {
|
|
FTRACE_ITER_FILTER = (1 << 0),
|
|
FTRACE_ITER_NOTRACE = (1 << 1),
|
|
FTRACE_ITER_PRINTALL = (1 << 2),
|
|
FTRACE_ITER_DO_PROBES = (1 << 3),
|
|
FTRACE_ITER_PROBE = (1 << 4),
|
|
FTRACE_ITER_MOD = (1 << 5),
|
|
FTRACE_ITER_ENABLED = (1 << 6),
|
|
};
|
|
|
|
void arch_ftrace_update_code(int command);
|
|
|
|
struct ftrace_rec_iter;
|
|
|
|
struct ftrace_rec_iter *ftrace_rec_iter_start(void);
|
|
struct ftrace_rec_iter *ftrace_rec_iter_next(struct ftrace_rec_iter *iter);
|
|
struct dyn_ftrace *ftrace_rec_iter_record(struct ftrace_rec_iter *iter);
|
|
|
|
#define for_ftrace_rec_iter(iter) \
|
|
for (iter = ftrace_rec_iter_start(); \
|
|
iter; \
|
|
iter = ftrace_rec_iter_next(iter))
|
|
|
|
|
|
int ftrace_update_record(struct dyn_ftrace *rec, int enable);
|
|
int ftrace_test_record(struct dyn_ftrace *rec, int enable);
|
|
void ftrace_run_stop_machine(int command);
|
|
unsigned long ftrace_location(unsigned long ip);
|
|
unsigned long ftrace_location_range(unsigned long start, unsigned long end);
|
|
unsigned long ftrace_get_addr_new(struct dyn_ftrace *rec);
|
|
unsigned long ftrace_get_addr_curr(struct dyn_ftrace *rec);
|
|
|
|
extern ftrace_func_t ftrace_trace_function;
|
|
|
|
int ftrace_regex_open(struct ftrace_ops *ops, int flag,
|
|
struct inode *inode, struct file *file);
|
|
ssize_t ftrace_filter_write(struct file *file, const char __user *ubuf,
|
|
size_t cnt, loff_t *ppos);
|
|
ssize_t ftrace_notrace_write(struct file *file, const char __user *ubuf,
|
|
size_t cnt, loff_t *ppos);
|
|
int ftrace_regex_release(struct inode *inode, struct file *file);
|
|
|
|
void __init
|
|
ftrace_set_early_filter(struct ftrace_ops *ops, char *buf, int enable);
|
|
|
|
/* defined in arch */
|
|
extern int ftrace_ip_converted(unsigned long ip);
|
|
extern int ftrace_dyn_arch_init(void);
|
|
extern void ftrace_replace_code(int enable);
|
|
extern int ftrace_update_ftrace_func(ftrace_func_t func);
|
|
extern void ftrace_caller(void);
|
|
extern void ftrace_regs_caller(void);
|
|
extern void ftrace_call(void);
|
|
extern void ftrace_regs_call(void);
|
|
extern void mcount_call(void);
|
|
|
|
void ftrace_modify_all_code(int command);
|
|
|
|
#ifndef FTRACE_ADDR
|
|
#define FTRACE_ADDR ((unsigned long)ftrace_caller)
|
|
#endif
|
|
|
|
#ifndef FTRACE_GRAPH_ADDR
|
|
#define FTRACE_GRAPH_ADDR ((unsigned long)ftrace_graph_caller)
|
|
#endif
|
|
|
|
#ifndef FTRACE_REGS_ADDR
|
|
#ifdef CONFIG_DYNAMIC_FTRACE_WITH_REGS
|
|
# define FTRACE_REGS_ADDR ((unsigned long)ftrace_regs_caller)
|
|
#else
|
|
# define FTRACE_REGS_ADDR FTRACE_ADDR
|
|
#endif
|
|
#endif
|
|
|
|
/*
|
|
* If an arch would like functions that are only traced
|
|
* by the function graph tracer to jump directly to its own
|
|
* trampoline, then they can define FTRACE_GRAPH_TRAMP_ADDR
|
|
* to be that address to jump to.
|
|
*/
|
|
#ifndef FTRACE_GRAPH_TRAMP_ADDR
|
|
#define FTRACE_GRAPH_TRAMP_ADDR ((unsigned long) 0)
|
|
#endif
|
|
|
|
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
|
extern void ftrace_graph_caller(void);
|
|
extern int ftrace_enable_ftrace_graph_caller(void);
|
|
extern int ftrace_disable_ftrace_graph_caller(void);
|
|
#else
|
|
static inline int ftrace_enable_ftrace_graph_caller(void) { return 0; }
|
|
static inline int ftrace_disable_ftrace_graph_caller(void) { return 0; }
|
|
#endif
|
|
|
|
/**
|
|
* ftrace_make_nop - convert code into nop
|
|
* @mod: module structure if called by module load initialization
|
|
* @rec: the mcount call site record
|
|
* @addr: the address that the call site should be calling
|
|
*
|
|
* This is a very sensitive operation and great care needs
|
|
* to be taken by the arch. The operation should carefully
|
|
* read the location, check to see if what is read is indeed
|
|
* what we expect it to be, and then on success of the compare,
|
|
* it should write to the location.
|
|
*
|
|
* The code segment at @rec->ip should be a caller to @addr
|
|
*
|
|
* Return must be:
|
|
* 0 on success
|
|
* -EFAULT on error reading the location
|
|
* -EINVAL on a failed compare of the contents
|
|
* -EPERM on error writing to the location
|
|
* Any other value will be considered a failure.
|
|
*/
|
|
extern int ftrace_make_nop(struct module *mod,
|
|
struct dyn_ftrace *rec, unsigned long addr);
|
|
|
|
/**
|
|
* ftrace_make_call - convert a nop call site into a call to addr
|
|
* @rec: the mcount call site record
|
|
* @addr: the address that the call site should call
|
|
*
|
|
* This is a very sensitive operation and great care needs
|
|
* to be taken by the arch. The operation should carefully
|
|
* read the location, check to see if what is read is indeed
|
|
* what we expect it to be, and then on success of the compare,
|
|
* it should write to the location.
|
|
*
|
|
* The code segment at @rec->ip should be a nop
|
|
*
|
|
* Return must be:
|
|
* 0 on success
|
|
* -EFAULT on error reading the location
|
|
* -EINVAL on a failed compare of the contents
|
|
* -EPERM on error writing to the location
|
|
* Any other value will be considered a failure.
|
|
*/
|
|
extern int ftrace_make_call(struct dyn_ftrace *rec, unsigned long addr);
|
|
|
|
#ifdef CONFIG_DYNAMIC_FTRACE_WITH_REGS
|
|
/**
|
|
* ftrace_modify_call - convert from one addr to another (no nop)
|
|
* @rec: the mcount call site record
|
|
* @old_addr: the address expected to be currently called to
|
|
* @addr: the address to change to
|
|
*
|
|
* This is a very sensitive operation and great care needs
|
|
* to be taken by the arch. The operation should carefully
|
|
* read the location, check to see if what is read is indeed
|
|
* what we expect it to be, and then on success of the compare,
|
|
* it should write to the location.
|
|
*
|
|
* The code segment at @rec->ip should be a caller to @old_addr
|
|
*
|
|
* Return must be:
|
|
* 0 on success
|
|
* -EFAULT on error reading the location
|
|
* -EINVAL on a failed compare of the contents
|
|
* -EPERM on error writing to the location
|
|
* Any other value will be considered a failure.
|
|
*/
|
|
extern int ftrace_modify_call(struct dyn_ftrace *rec, unsigned long old_addr,
|
|
unsigned long addr);
|
|
#else
|
|
/* Should never be called */
|
|
static inline int ftrace_modify_call(struct dyn_ftrace *rec, unsigned long old_addr,
|
|
unsigned long addr)
|
|
{
|
|
return -EINVAL;
|
|
}
|
|
#endif
|
|
|
|
/* May be defined in arch */
|
|
extern int ftrace_arch_read_dyn_info(char *buf, int size);
|
|
|
|
extern int skip_trace(unsigned long ip);
|
|
extern void ftrace_module_init(struct module *mod);
|
|
extern void ftrace_module_enable(struct module *mod);
|
|
extern void ftrace_release_mod(struct module *mod);
|
|
|
|
extern void ftrace_disable_daemon(void);
|
|
extern void ftrace_enable_daemon(void);
|
|
#else /* CONFIG_DYNAMIC_FTRACE */
|
|
static inline int skip_trace(unsigned long ip) { return 0; }
|
|
static inline int ftrace_force_update(void) { return 0; }
|
|
static inline void ftrace_disable_daemon(void) { }
|
|
static inline void ftrace_enable_daemon(void) { }
|
|
static inline void ftrace_module_init(struct module *mod) { }
|
|
static inline void ftrace_module_enable(struct module *mod) { }
|
|
static inline void ftrace_release_mod(struct module *mod) { }
|
|
static inline int ftrace_text_reserved(const void *start, const void *end)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline unsigned long ftrace_location(unsigned long ip)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
/*
|
|
* Again users of functions that have ftrace_ops may not
|
|
* have them defined when ftrace is not enabled, but these
|
|
* functions may still be called. Use a macro instead of inline.
|
|
*/
|
|
#define ftrace_regex_open(ops, flag, inod, file) ({ -ENODEV; })
|
|
#define ftrace_set_early_filter(ops, buf, enable) do { } while (0)
|
|
#define ftrace_set_filter_ip(ops, ip, remove, reset) ({ -ENODEV; })
|
|
#define ftrace_set_filter(ops, buf, len, reset) ({ -ENODEV; })
|
|
#define ftrace_set_notrace(ops, buf, len, reset) ({ -ENODEV; })
|
|
#define ftrace_free_filter(ops) do { } while (0)
|
|
#define ftrace_ops_set_global_filter(ops) do { } while (0)
|
|
|
|
static inline ssize_t ftrace_filter_write(struct file *file, const char __user *ubuf,
|
|
size_t cnt, loff_t *ppos) { return -ENODEV; }
|
|
static inline ssize_t ftrace_notrace_write(struct file *file, const char __user *ubuf,
|
|
size_t cnt, loff_t *ppos) { return -ENODEV; }
|
|
static inline int
|
|
ftrace_regex_release(struct inode *inode, struct file *file) { return -ENODEV; }
|
|
|
|
static inline bool is_ftrace_trampoline(unsigned long addr)
|
|
{
|
|
return false;
|
|
}
|
|
#endif /* CONFIG_DYNAMIC_FTRACE */
|
|
|
|
/* totally disable ftrace - can not re-enable after this */
|
|
void ftrace_kill(void);
|
|
|
|
static inline void tracer_disable(void)
|
|
{
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
ftrace_enabled = 0;
|
|
#endif
|
|
}
|
|
|
|
/*
|
|
* Ftrace disable/restore without lock. Some synchronization mechanism
|
|
* must be used to prevent ftrace_enabled to be changed between
|
|
* disable/restore.
|
|
*/
|
|
static inline int __ftrace_enabled_save(void)
|
|
{
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
int saved_ftrace_enabled = ftrace_enabled;
|
|
ftrace_enabled = 0;
|
|
return saved_ftrace_enabled;
|
|
#else
|
|
return 0;
|
|
#endif
|
|
}
|
|
|
|
static inline void __ftrace_enabled_restore(int enabled)
|
|
{
|
|
#ifdef CONFIG_FUNCTION_TRACER
|
|
ftrace_enabled = enabled;
|
|
#endif
|
|
}
|
|
|
|
/* All archs should have this, but we define it for consistency */
|
|
#ifndef ftrace_return_address0
|
|
# define ftrace_return_address0 __builtin_return_address(0)
|
|
#endif
|
|
|
|
/* Archs may use other ways for ADDR1 and beyond */
|
|
#ifndef ftrace_return_address
|
|
# ifdef CONFIG_FRAME_POINTER
|
|
# define ftrace_return_address(n) __builtin_return_address(n)
|
|
# else
|
|
# define ftrace_return_address(n) 0UL
|
|
# endif
|
|
#endif
|
|
|
|
#define CALLER_ADDR0 ((unsigned long)ftrace_return_address0)
|
|
#define CALLER_ADDR1 ((unsigned long)ftrace_return_address(1))
|
|
#define CALLER_ADDR2 ((unsigned long)ftrace_return_address(2))
|
|
#define CALLER_ADDR3 ((unsigned long)ftrace_return_address(3))
|
|
#define CALLER_ADDR4 ((unsigned long)ftrace_return_address(4))
|
|
#define CALLER_ADDR5 ((unsigned long)ftrace_return_address(5))
|
|
#define CALLER_ADDR6 ((unsigned long)ftrace_return_address(6))
|
|
|
|
static inline unsigned long get_lock_parent_ip(void)
|
|
{
|
|
unsigned long addr = CALLER_ADDR0;
|
|
|
|
if (!in_lock_functions(addr))
|
|
return addr;
|
|
addr = CALLER_ADDR1;
|
|
if (!in_lock_functions(addr))
|
|
return addr;
|
|
return CALLER_ADDR2;
|
|
}
|
|
|
|
#ifdef CONFIG_TRACE_PREEMPT_TOGGLE
|
|
extern void trace_preempt_on(unsigned long a0, unsigned long a1);
|
|
extern void trace_preempt_off(unsigned long a0, unsigned long a1);
|
|
#else
|
|
/*
|
|
* Use defines instead of static inlines because some arches will make code out
|
|
* of the CALLER_ADDR, when we really want these to be a real nop.
|
|
*/
|
|
# define trace_preempt_on(a0, a1) do { } while (0)
|
|
# define trace_preempt_off(a0, a1) do { } while (0)
|
|
#endif
|
|
|
|
#ifdef CONFIG_FTRACE_MCOUNT_RECORD
|
|
extern void ftrace_init(void);
|
|
#else
|
|
static inline void ftrace_init(void) { }
|
|
#endif
|
|
|
|
/*
|
|
* Structure that defines an entry function trace.
|
|
* It's already packed but the attribute "packed" is needed
|
|
* to remove extra padding at the end.
|
|
*/
|
|
struct ftrace_graph_ent {
|
|
unsigned long func; /* Current function */
|
|
int depth;
|
|
} __packed;
|
|
|
|
/*
|
|
* Structure that defines a return function trace.
|
|
* It's already packed but the attribute "packed" is needed
|
|
* to remove extra padding at the end.
|
|
*/
|
|
struct ftrace_graph_ret {
|
|
unsigned long func; /* Current function */
|
|
/* Number of functions that overran the depth limit for current task */
|
|
unsigned long overrun;
|
|
unsigned long long calltime;
|
|
unsigned long long rettime;
|
|
int depth;
|
|
} __packed;
|
|
|
|
/* Type of the callback handlers for tracing function graph*/
|
|
typedef void (*trace_func_graph_ret_t)(struct ftrace_graph_ret *); /* return */
|
|
typedef int (*trace_func_graph_ent_t)(struct ftrace_graph_ent *); /* entry */
|
|
|
|
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
|
|
|
/*
|
|
* Stack of return addresses for functions
|
|
* of a thread.
|
|
* Used in struct thread_info
|
|
*/
|
|
struct ftrace_ret_stack {
|
|
unsigned long ret;
|
|
unsigned long func;
|
|
unsigned long long calltime;
|
|
#ifdef CONFIG_FUNCTION_PROFILER
|
|
unsigned long long subtime;
|
|
#endif
|
|
#ifdef HAVE_FUNCTION_GRAPH_FP_TEST
|
|
unsigned long fp;
|
|
#endif
|
|
#ifdef HAVE_FUNCTION_GRAPH_RET_ADDR_PTR
|
|
unsigned long *retp;
|
|
#endif
|
|
};
|
|
|
|
/*
|
|
* Primary handler of a function return.
|
|
* It relays on ftrace_return_to_handler.
|
|
* Defined in entry_32/64.S
|
|
*/
|
|
extern void return_to_handler(void);
|
|
|
|
extern int
|
|
function_graph_enter(unsigned long ret, unsigned long func,
|
|
unsigned long frame_pointer, unsigned long *retp);
|
|
|
|
unsigned long ftrace_graph_ret_addr(struct task_struct *task, int *idx,
|
|
unsigned long ret, unsigned long *retp);
|
|
|
|
/*
|
|
* Sometimes we don't want to trace a function with the function
|
|
* graph tracer but we want them to keep traced by the usual function
|
|
* tracer if the function graph tracer is not configured.
|
|
*/
|
|
#define __notrace_funcgraph notrace
|
|
|
|
#define FTRACE_NOTRACE_DEPTH 65536
|
|
#define FTRACE_RETFUNC_DEPTH 50
|
|
#define FTRACE_RETSTACK_ALLOC_SIZE 32
|
|
extern int register_ftrace_graph(trace_func_graph_ret_t retfunc,
|
|
trace_func_graph_ent_t entryfunc);
|
|
|
|
extern bool ftrace_graph_is_dead(void);
|
|
extern void ftrace_graph_stop(void);
|
|
|
|
/* The current handlers in use */
|
|
extern trace_func_graph_ret_t ftrace_graph_return;
|
|
extern trace_func_graph_ent_t ftrace_graph_entry;
|
|
|
|
extern void unregister_ftrace_graph(void);
|
|
|
|
extern void ftrace_graph_init_task(struct task_struct *t);
|
|
extern void ftrace_graph_exit_task(struct task_struct *t);
|
|
extern void ftrace_graph_init_idle_task(struct task_struct *t, int cpu);
|
|
|
|
static inline int task_curr_ret_stack(struct task_struct *t)
|
|
{
|
|
return t->curr_ret_stack;
|
|
}
|
|
|
|
static inline void pause_graph_tracing(void)
|
|
{
|
|
atomic_inc(¤t->tracing_graph_pause);
|
|
}
|
|
|
|
static inline void unpause_graph_tracing(void)
|
|
{
|
|
atomic_dec(¤t->tracing_graph_pause);
|
|
}
|
|
#else /* !CONFIG_FUNCTION_GRAPH_TRACER */
|
|
|
|
#define __notrace_funcgraph
|
|
|
|
static inline void ftrace_graph_init_task(struct task_struct *t) { }
|
|
static inline void ftrace_graph_exit_task(struct task_struct *t) { }
|
|
static inline void ftrace_graph_init_idle_task(struct task_struct *t, int cpu) { }
|
|
|
|
static inline int register_ftrace_graph(trace_func_graph_ret_t retfunc,
|
|
trace_func_graph_ent_t entryfunc)
|
|
{
|
|
return -1;
|
|
}
|
|
static inline void unregister_ftrace_graph(void) { }
|
|
|
|
static inline int task_curr_ret_stack(struct task_struct *tsk)
|
|
{
|
|
return -1;
|
|
}
|
|
|
|
static inline unsigned long
|
|
ftrace_graph_ret_addr(struct task_struct *task, int *idx, unsigned long ret,
|
|
unsigned long *retp)
|
|
{
|
|
return ret;
|
|
}
|
|
|
|
static inline void pause_graph_tracing(void) { }
|
|
static inline void unpause_graph_tracing(void) { }
|
|
#endif /* CONFIG_FUNCTION_GRAPH_TRACER */
|
|
|
|
#ifdef CONFIG_TRACING
|
|
|
|
/* flags for current->trace */
|
|
enum {
|
|
TSK_TRACE_FL_TRACE_BIT = 0,
|
|
TSK_TRACE_FL_GRAPH_BIT = 1,
|
|
};
|
|
enum {
|
|
TSK_TRACE_FL_TRACE = 1 << TSK_TRACE_FL_TRACE_BIT,
|
|
TSK_TRACE_FL_GRAPH = 1 << TSK_TRACE_FL_GRAPH_BIT,
|
|
};
|
|
|
|
static inline void set_tsk_trace_trace(struct task_struct *tsk)
|
|
{
|
|
set_bit(TSK_TRACE_FL_TRACE_BIT, &tsk->trace);
|
|
}
|
|
|
|
static inline void clear_tsk_trace_trace(struct task_struct *tsk)
|
|
{
|
|
clear_bit(TSK_TRACE_FL_TRACE_BIT, &tsk->trace);
|
|
}
|
|
|
|
static inline int test_tsk_trace_trace(struct task_struct *tsk)
|
|
{
|
|
return tsk->trace & TSK_TRACE_FL_TRACE;
|
|
}
|
|
|
|
static inline void set_tsk_trace_graph(struct task_struct *tsk)
|
|
{
|
|
set_bit(TSK_TRACE_FL_GRAPH_BIT, &tsk->trace);
|
|
}
|
|
|
|
static inline void clear_tsk_trace_graph(struct task_struct *tsk)
|
|
{
|
|
clear_bit(TSK_TRACE_FL_GRAPH_BIT, &tsk->trace);
|
|
}
|
|
|
|
static inline int test_tsk_trace_graph(struct task_struct *tsk)
|
|
{
|
|
return tsk->trace & TSK_TRACE_FL_GRAPH;
|
|
}
|
|
|
|
enum ftrace_dump_mode;
|
|
|
|
extern enum ftrace_dump_mode ftrace_dump_on_oops;
|
|
extern int tracepoint_printk;
|
|
|
|
extern void disable_trace_on_warning(void);
|
|
extern int __disable_trace_on_warning;
|
|
|
|
int tracepoint_printk_sysctl(struct ctl_table *table, int write,
|
|
void __user *buffer, size_t *lenp,
|
|
loff_t *ppos);
|
|
|
|
#else /* CONFIG_TRACING */
|
|
static inline void disable_trace_on_warning(void) { }
|
|
#endif /* CONFIG_TRACING */
|
|
|
|
#ifdef CONFIG_FTRACE_SYSCALLS
|
|
|
|
unsigned long arch_syscall_addr(int nr);
|
|
|
|
#endif /* CONFIG_FTRACE_SYSCALLS */
|
|
|
|
#endif /* _LINUX_FTRACE_H */
|