opnsense-src/sys
Kristof Provost 18c38eda39 if_ovpn: cope with loops
User misconfiguration may lead to routing loops where we try to send the tunnel
packet into the tunnel. This eventually leads to stack overflows and panics.

Avoid this using if_tunnel_check_nesting(), which will drop the packet if we're
looping or we hit three layers of nested tunnels.

MFC after:	1 week
Sponsored by:	Rubicon Communications, LLC ("Netgate")

(cherry picked from commit 59a6666ec91d71f97aaae5195bbfafd9d422db2e)
2024-05-20 09:39:52 +02:00
..
amd64 ktrace: Record syscall violations with KTR_CAPFAIL 2024-05-11 18:57:44 -05:00
arm arm: Remove stray references to dev/sound/chip.h 2024-05-17 21:30:36 +02:00
arm64 arm64: Check DMAP address is valid in PHYS_IN_DMAP 2024-05-02 07:59:31 +00:00
bsm
cam cam: Check if cam_simq_alloc fails for the xpt bus during module init 2024-04-08 10:53:43 -07:00
cddl Revert "dtrace: make 'ring' and 'fill' policies imply 'noswitch' flag" 2024-04-21 15:27:11 +03:00
compat linuxkpi: Make arch_io_*_memtype_wc amd64-only 2024-05-11 17:32:51 +02:00
conf sound: Retire unit.* 2024-05-17 21:30:25 +02:00
contrib zfs: unbreak aarch64 build with non-gcc compilers 2024-05-04 01:49:05 +02:00
crypto ossl: Remove a stray __FBSDID("$FreeBSD$") 2024-03-29 09:53:05 -04:00
ddb
dev sound: Remove ncards variable from sound_oss_card_info() 2024-05-17 21:30:36 +02:00
dts
fs tmpfs_destroy_vobject(): clear v_object under the object lock 2024-05-19 03:57:54 +03:00
gdb
geom geli: add a read-only kern.geom.eli.use_uma_bytes sysctl 2024-05-09 14:20:16 -06:00
gnu
i386 ktrace: Record syscall violations with KTR_CAPFAIL 2024-05-11 18:57:44 -05:00
isa
kern vfs_domount_update(): style, use space instead of tab 2024-05-19 03:57:54 +03:00
kgssapi
libkern arm64: Mark the armv8 crc32c as supporting BTI 2024-02-19 13:17:47 +00:00
modules sound: Retire unit.* 2024-05-17 21:30:25 +02:00
net if_ovpn: cope with loops 2024-05-20 09:39:52 +02:00
net80211 net80211: amrr_init: change order of commands 2024-04-22 17:00:22 +00:00
netgraph ng_pipe: Do not panic when memory allocations fail 2024-05-08 09:06:16 -04:00
netinet ipfw: Fix a typo in a source code comment 2024-05-16 07:59:09 +02:00
netinet6 in6.h: expose s6_addr* definitions to user level 2024-05-10 09:37:43 -05:00
netipsec ipsec esp: avoid dereferencing freed secasindex 2024-03-04 02:27:17 +02:00
netlink netlink: Don't use a zero-length array 2024-04-08 10:58:16 -07:00
netpfil pf: always mark states as unlinked before detaching them 2024-05-16 09:41:02 +02:00
netsmb
nfs
nfsclient
nfsserver
nlm
ofed
opencrypto
powerpc busdma: fix page miscount for small segment sizes 2024-04-18 15:09:02 -03:00
riscv busdma: fix page miscount for small segment sizes 2024-04-18 15:09:02 -03:00
rpc krpc: Ref cnt the client structures for TLS upcalls 2024-05-01 18:09:52 -07:00
security
sys sound: Rename oss_audioinfo->real_device to oss_audioinfo->legacy_device 2024-05-17 21:30:36 +02:00
teken
tests
tools arm_kernel_bothdr.awk: Update to latest ota 2024-04-24 17:57:55 -06:00
ufs Eliminate unnecessary UFS1 integrity checks. 2024-03-04 16:09:10 -08:00
vm swap-like pagers: assert that writemapping decrease does not pass zero 2024-05-19 03:57:54 +03:00
x86 Increase IOAPIC_MAX_ID to 255 (from 254) 2024-05-15 13:21:14 -04:00
xdr
xen
Makefile
README.md

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.

Documentation:

Source code documentation is maintained in a set of man pages, under section 9. These pages are located in share/man/man9, from the top-level of the src tree. Consult intro(9) for an overview of existing pages.

Some additional high-level documentation of the kernel is maintained in the Architecture Handbook.

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