freebsd-dev/sys
Mark Johnston c3179891f8 kerneldump: Inline dump_savectx() into its callers
The callers of dump_savectx() (i.e., doadump() and livedump_start())
subsequently call dumpsys()/minidumpsys(), which dump the calling
thread's stack when writing the dump.  If dump_savectx() gets its own
stack frame, that frame might be clobbered when its caller later calls
dumpsys()/minidumpsys(), making it difficult for debuggers to unwind the
stack.

Fix this by making dump_savectx() a macro, so that savectx() is always
called directly by the function which subsequently calls
dumpsys()/minidumpsys().

This fixes stack unwinding for the panicking thread from arm64
minidumps.  The same happened to work on amd64, but kgdb reports the
dump_savectx() calls as coming from dumpsys(), so in that case it
appears to work by accident.

Fixes:	c9114f9f86 ("Add new vnode dumper to support live minidumps")
Reviewed by:	mhorne, jhb
MFC after:	3 days
Differential Revision:	https://reviews.freebsd.org/D39151
2023-03-20 14:16:28 -04:00
..
amd64 acpi_wakeup.c: apply the reviewer' editorial corrections to the comment text. 2023-03-18 17:47:19 +02:00
arm arm: Remove SOCFPGA specific kernel configs 2023-03-17 14:49:01 +01:00
arm64 arm64: Adding a missing include file 2023-03-20 11:23:01 +00:00
bsm
cam
cddl dtrace/powerpc: Remove accidental commented out line 2023-03-13 11:37:40 -04:00
compat linux: Use the if_name() accessor to get loopback name 2023-03-07 09:47:01 -05:00
conf arm: Rename hdmi_if.m to crtc_if.m 2023-03-17 13:34:57 +01:00
contrib zfs: Use .section .rodata instead of .rodata on FreeBSD 2023-03-13 13:48:05 +00:00
crypto OpenSSL: Regen assembly files for OpenSSL 1.1.1t 2023-02-07 13:55:17 -05:00
ddb ddb: ansify 2023-02-08 00:09:23 +00:00
dev xhci(4): Describe Fresco Logic FL1009 USB 3.0 controller 2023-03-20 12:04:14 +08:00
dts
fs ext2_dirbad(): fix !DTRACE build 2023-03-20 10:44:22 +02:00
gdb
geom g_part_ebr: always create "compat" aliases 2023-03-01 13:44:01 -05:00
gnu
i386 linux(4): Reduce code duplication between MD files 2023-03-04 12:11:38 +03:00
isa
kern kerneldump: Inline dump_savectx() into its callers 2023-03-20 14:16:28 -04:00
kgssapi nfsd: Enable the NFSD_VNET vnet front end macros 2023-02-18 14:59:36 -08:00
libkern
modules powerpc: enable ZFS on 32 bit powerpc/powerpcspe 2023-03-12 03:20:11 -03:00
net pf: distinguish forwarding and output cases for pf_refragment6() 2023-03-16 10:59:04 +01:00
net80211 net80211: make ieee80211_scan_dump_channels private 2023-03-14 22:17:03 +00:00
netgraph ng_atmllc: remove 2023-03-09 18:04:21 +00:00
netinet carp: use if_name() 2023-03-20 14:37:10 +01:00
netinet6 pf: distinguish forwarding and output cases for pf_refragment6() 2023-03-16 10:59:04 +01:00
netipsec ipsec: only update lastused when it changes 2023-02-16 07:33:51 +00:00
netlink carp: support unicast 2023-03-20 14:37:09 +01:00
netpfil pfsync: fix pfsync_undefer_state() locking 2023-03-20 16:39:14 +01:00
netsmb
nfs
nfsclient
nfsserver
nlm
ofed infiniband: Convert BPF handling for IfAPI 2023-03-14 15:51:32 -04:00
opencrypto Complete removal of opt_compat.h 2023-02-13 19:07:38 +03:00
powerpc powerpc/pmap: Add pmap_sync_icache() for radix pmap 2023-03-12 11:51:42 -04:00
riscv riscv kernel config: clean up whitespace 2023-02-24 08:36:29 -06:00
rpc svc_rpcsec_gss.c: Separate out the non-vnet initialization 2023-03-01 15:29:25 -08:00
security vfs: retire KERN_VNODE 2023-03-17 16:21:45 +00:00
sys kerneldump: Inline dump_savectx() into its callers 2023-03-20 14:16:28 -04:00
teken
tests
tools Improve debuggability of VOP_* locking assertions 2023-01-18 22:11:05 -06:00
ufs Fix syntax error in 0697670. 2023-03-18 17:03:32 -07:00
vm vm: consistently prefix fault helpers with vm_fault_ 2023-03-13 11:00:28 +00:00
x86 xen: take struct size into account for video information 2023-03-14 09:59:08 +01:00
xdr xdr: ansify 2023-02-13 18:37:31 +00:00
xen xen: bump used interface version 2023-03-09 17:13:17 +01:00
Makefile
README.md note that some arch independent code can live in dev (e.g. SMBios) 2023-03-03 01:54:07 -08: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 and other arch independent code
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