freebsd-src/sys
Mitchell Horne de09dcebd7 riscv: rework page table bootstrap
The overall goal of the change is to reduce the amount of work done in
locore assembly, and defer as much as possible until pmap_bootstrap().
Currently, half the setup is done in assembly, and then we pass the l1pt
address to pmap_bootstrap() where it is amended with other mappings.

Inspiration and understanding has been taken from amd64's
create_pagetables() routine, and I try to present the page table
construction in the same way: a linear procedure with commentary
explaining what we are doing and why. Thus the core of the new
implementation is contained in pmap_create_pagetables().

Once pmap_create_pagetables() has finished, we switch to the new
pagetable root and leave the bootstrap ones created by locore behind,
resulting in a minimal 8kB of wasted space.

Having the whole procedure in one place, in C code, allows it to be more
easily understood, while also making it more amenable to future changes
which depend on CPU feature/errata detection.

Note that with this change the size of the early devmap is bumped up
from one to four L2 pages (8MB).

Reviewed by:	markj
MFC after:	1 month
Sponsored by:	The FreeBSD Foundation
Differential Revision:	https://reviews.freebsd.org/D45327
2024-06-20 15:33:19 -03:00
..
amd64 sdt: Implement SDT probes using hot-patching 2024-06-19 16:57:41 -04:00
arm sdt: Implement SDT probes using hot-patching 2024-06-19 16:57:41 -04:00
arm64 sdt: Implement SDT probes using hot-patching 2024-06-19 16:57:41 -04:00
bsm
cam ctladm: don't require the use of "-p" with "port -r" 2024-06-10 10:01:25 -06:00
cddl dtrace: Add a partial implementation of dtrace_getarg() on arm64 2024-06-20 12:41:01 -04:00
compat linux: Translate Linux NVME ioctls to the lower layers. 2024-06-14 16:40:20 -06:00
conf sdt: Implement SDT probes using hot-patching 2024-06-19 16:57:41 -04:00
contrib zfs: Use a statement expression to implement SET_ERROR() 2024-06-19 16:57:30 -04:00
crypto padlock: Use device_set_descf() 2024-06-16 16:37:26 -04:00
ddb sys/ddb: Add hardware breakpoint support to ddb 2024-04-12 09:32:41 +00:00
dev Add an implementation of the 9P filesystem 2024-06-19 13:12:04 +01:00
dts dts: Bump the freebsd branding version to 6.8 2024-05-06 10:47:26 +02:00
fs p9fs: Fix the build for 32-bit kernels 2024-06-19 15:16:38 +01:00
gdb sys/gdb: Support hardware breakpoints 2024-04-12 09:32:55 +00:00
geom geom_io: Shift to pause_sbt to eliminate bogus min and update comment. 2024-05-24 08:31:55 -06:00
gnu
i386 sdt: Implement SDT probes using hot-patching 2024-06-19 16:57:41 -04:00
isa new-bus: Remove the 'rid' and 'type' arguments from BUS_RELEASE_RESOURCE 2024-03-13 15:05:54 -07:00
kern callout: assert that callout_init_*lock* functions are called with a lock 2024-06-20 10:53:31 -07:00
kgssapi
libkern
modules sdt: Implement SDT probes using hot-patching 2024-06-19 16:57:41 -04:00
net pf: fix the "keepcounters" to stop truncating to 32-bit 2024-06-20 17:55:43 +00:00
net80211 net80211: Correct a comment 2024-06-20 12:27:43 +08:00
netgraph netgraph: provide separate malloc type for nodes that are missing it 2024-05-31 09:19:54 -07:00
netinet udp_var: correct intoudpcb macro unintended identifier dependency 2024-06-14 17:28:28 +02:00
netinet6 in6_rmx: remove unnecessary socketvar.h 2024-05-07 14:15:56 -07:00
netipsec libipsec: make const-correct 2024-04-22 22:36:34 -06:00
netlink netlink: pass the correct arguments for SIOCDIFADDR and SIOCDIFADDR_IN6 2024-06-06 15:45:30 +02:00
netpfil pf: fix the "keepcounters" to stop truncating to 32-bit 2024-06-20 17:55:43 +00:00
netsmb
nfs
nfsclient
nfsserver
nlm
ofed ibcore: Mark write-only variables 2024-06-12 14:04:45 +01:00
opencrypto
powerpc sdt: Implement SDT probes using hot-patching 2024-06-19 16:57:41 -04:00
riscv riscv: rework page table bootstrap 2024-06-20 15:33:19 -03:00
rpc svc.c: Check for a non-NULL xp_socket 2024-05-27 19:22:04 -07:00
security MAC/do: allow to call setuid if real user id is 0 2024-05-23 12:09:11 +02:00
sys callout: assert that callout_init_*lock* functions are called with a lock 2024-06-20 10:53:31 -07:00
teken
tests
tools arm_kernel_bothdr.awk: Update to latest ota 2024-04-16 21:30:17 -06:00
ufs uio: Use switch statements when handling UIO_READ vs UIO_WRITE 2024-05-10 13:43:36 -07:00
vm Revert "swap_pager: small improvement to find_least" 2024-06-16 10:37:16 -05:00
x86 sdt: Implement SDT probes using hot-patching 2024-06-19 16:57:41 -04:00
xdr
xen x86/xen: introduce non-hypercall based emergency print 2024-02-22 11:08:03 +01:00
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