freebsd-dev/sys
Mark Johnston 84d7fe4a6f kinst: Add per-CPU interrupt trampolines
In the common case, kinst emulates a traced instruction by copying it to
a trampoline, where it is followed by a jump back to the original code,
and pointing the interrupted thread's %rip at the trampoline.  In
particular, the trampoline is executed with the same CPU context as the
original instruction, so if interrupts are enabled at the point where
the probe fires, they will be enabled when the trampoline is
subsequently executed.

It can happen that an interrupt is raised while a thread is executing a
kinst trampoline.  In that case, it is possible that the interrupt
handler will trigger a kinst probe, so we must ensure that the thread
does not recurse and overwrite its trampoline before it is finished
executing the original contents, otherwise an attempt to trace code
called from interrupt handlers can crash the kernel.

To that end, add a per-CPU trampoline, used when the probe fired with
interrupts disabled.  Note that this is not quite complete since it does
not handle the possibility of kinst probes firing while executing an NMI
handler.

Also ensure that we do not trace instructions which set IF, since in
that case it is not clear which trampoline (the per-thread trampoline or
the per-CPU trampoline) we should use, and since such instructions are
rare.

Reported and tested by:	Domagoj Stolfa
Reviewed by:	christos
Fixes:		f0bc4ed144 ("kinst: Initial revision")
Differential Revision:	https://reviews.freebsd.org/D37619
2022-12-08 15:03:51 -05:00
..
amd64 vmm: Remove stale comment for vm_rendezvous. 2022-11-30 13:06:46 -08:00
arm AM335x: Fix compatible name 2022-11-28 08:13:18 +01:00
arm64 arm64/machdep: Reserve memory when we find Linux EFI reserved memory table 2022-11-30 16:31:14 -07:00
bsm
cam CTL: Allow userland supply tags via ioctl frontend. 2022-12-03 12:05:05 -05:00
cddl kinst: Add per-CPU interrupt trampolines 2022-12-08 15:03:51 -05:00
compat linuxkpi: Fix style for dma_map_sgtable 2022-12-06 16:52:16 +01:00
conf tcp: embed inpcb into tcpcb 2022-12-07 09:00:48 -08:00
contrib ath: Fix mismatches in array bounds. 2022-12-07 12:30:42 -08:00
crypto aesni: Remove misleading array bounds for aesni_decryt_ecb. 2022-12-07 12:32:19 -08:00
ddb ddb: Don't flag breakpoint/watchpoint commands as MEMSAFE 2022-11-02 13:46:24 -04:00
dev atp: Fix mismatch in array bounds. 2022-12-07 12:33:56 -08:00
dts arm64/rockchip: Remove rk3328-dwc3 overlays 2022-11-16 11:58:32 +01:00
fs nfs: Fix common typos in source code comments 2022-11-08 14:58:32 +01:00
gdb
geom Don't panic when tasting a disk with sectorsize=0 2022-11-09 10:21:12 -07:00
gnu
i386 Retire broken GPROF support from the kernel 2022-11-15 14:17:10 +00:00
isa
kern imgact_binmisc: Optionally pre-open the interpreter vnode 2022-12-08 14:32:03 +00:00
kgssapi
libkern ashldi3: Use C89-style function definition 2022-11-27 13:23:25 -07:00
modules zfs: merge openzfs/zfs@59493b63c (master) 2022-12-07 14:10:46 +01:00
net if_ovpn: extend notifications with a reason 2022-12-05 11:09:34 +01:00
net80211 net80211: Fix mismatches in array bounds. 2022-12-07 12:31:53 -08:00
netgraph ng_hci: handle NG_HCI_M_PULLUP failure in le_advertizing_report 2022-11-01 14:33:37 -04:00
netinet udp: add protocol method declarations to udp_var.h 2022-12-07 11:51:49 -08:00
netinet6 udp6: fix build with INET6 and without INVARIANTS 2022-12-07 12:27:15 -08:00
netipsec tcp: embed inpcb into tcpcb 2022-12-07 09:00:48 -08:00
netlink netlink: fix non-multipath build 2022-12-02 22:21:00 +00:00
netpfil ipfilter: Fix mismatch in array bounds. 2022-12-07 12:32:38 -08:00
netsmb
nfs Allow any user to read the NFS stats, for example with nfsstat(1). 2022-12-01 22:21:14 -07:00
nfsclient
nfsserver
nlm nlm: only access refcounts using dedicated primitives 2022-11-24 19:46:43 +00:00
ofed
opencrypto crypto: move all zeroing into crypto_getreq 2022-11-22 12:28:07 +00:00
powerpc powerpc/mpc85xx: Add compat strings for P5040 PCIe 2022-11-30 19:45:10 -05:00
riscv Check alignment of fp in unwind_frame 2022-11-16 18:29:28 +00:00
rpc clnt_vc.c: Replace msleep() with pause() to avoid assert panic 2022-10-14 15:46:55 -07:00
security mac_lomac: whack giant usage 2022-11-15 14:31:41 +00:00
sys imgact_binmisc: Optionally pre-open the interpreter vnode 2022-12-08 14:32:03 +00:00
teken
tests
tools dtb: Be much less verbose in the building of dtb 2022-10-29 10:13:54 -06:00
ufs Provide more precise mount(8) failure message. 2022-12-05 14:50:42 -08:00
vm ddb: don't limit pindex output in 'show vmopag' 2022-11-11 14:25:39 -04:00
x86 Retire broken GPROF support from the kernel 2022-11-15 14:17:10 +00:00
xdr
xen
Makefile Remove dead code in the cscope target 2022-11-11 15:53:57 +00:00
README.md README.md: shift description of kernel config files 2022-11-01 12:20:55 -03:00

FreeBSD Kernel Source:

This directory contains the source files and build glue that make up the FreeBSD kernel and its modules, including both original and contributed software.

Kernel configuration files are located in the conf/ subdirectory of each architecture. GENERIC is the configuration used in release builds. NOTES contains documentation of all possible entries. LINT is a compile-only configuration used to maximize build coverage and detect regressions.

Source Roadmap:

Directory Description
amd64 AMD64 (64-bit x86) architecture support
arm 32-bit ARM architecture support
arm64 64-bit ARM (AArch64) architecture support
cam Common Access Method storage subsystem - cam(4) and ctl(4)
cddl CDDL-licensed optional sources such as DTrace
conf kernel build glue
compat Linux compatibility layer, FreeBSD 32-bit compatibility
contrib 3rd-party imported software such as OpenZFS
crypto crypto drivers
ddb interactive kernel debugger - ddb(4)
fs most filesystems, excluding UFS, NFS, and ZFS
dev device drivers
gdb kernel remote GDB stub - gdb(4)
geom GEOM framework - geom(4)
i386 i386 (32-bit x86) architecture support
kern main part of the kernel
libkern libc-like and other support functions for kernel use
modules kernel module infrastructure
net core networking code
net80211 wireless networking (IEEE 802.11) - net80211(4)
netgraph graph-based networking subsystem - netgraph(4)
netinet IPv4 protocol implementation - inet(4)
netinet6 IPv6 protocol implementation - inet6(4)
netipsec IPsec protocol implementation - ipsec(4)
netpfil packet filters - ipfw(4), pf(4), and ipfilter(4)
opencrypto OpenCrypto framework - crypto(7)
powerpc PowerPC/POWER (32 and 64-bit) architecture support
riscv 64-bit RISC-V architecture support
security security facilities - audit(4) and mac(4)
sys kernel headers
tests kernel unit tests
ufs Unix File System - ffs(7)
vm virtual memory system
x86 code shared by AMD64 and i386 architectures